diff --git a/lib/index.d.ts b/lib/index.d.ts index 7493f05..17e0477 100644 --- a/lib/index.d.ts +++ b/lib/index.d.ts @@ -1,4 +1,4 @@ import { withRecord, assignRecords, RecordClearMode } from "./commons/record-util"; -import { stringTokenizer, equalsIgnoreCase, includeIgnoreCase } from "./commons/str-utils"; +import { stringTokenizer, equalsIgnoreCase, includeIgnoreCase, strLength, strMonospacePad } from "./commons/str-utils"; import { getFileExt, getFileFullName, getFileNameWithoutExt, getFileInfo } from "./commons/file-util"; -export { stringTokenizer, withRecord, equalsIgnoreCase, includeIgnoreCase, assignRecords, RecordClearMode, getFileExt, getFileFullName as getFileName, getFileNameWithoutExt, getFileInfo, }; +export { stringTokenizer, withRecord, equalsIgnoreCase, includeIgnoreCase, assignRecords, RecordClearMode, getFileExt, getFileFullName as getFileName, getFileNameWithoutExt, getFileInfo, strLength, strMonospacePad }; diff --git a/lib/index.es.js b/lib/index.es.js index 50a19ab..d6040e6 100644 --- a/lib/index.es.js +++ b/lib/index.es.js @@ -1,10 +1,10 @@ var a = /* @__PURE__ */ ((e) => (e[e.delete = 2] = "delete", e[e.reset = 1] = "reset", e))(a || {}); -const h = (e) => ({ +const d = (e) => ({ clear: function(t = 2) { - t === 1 ? Object.keys(e).forEach((s) => { - e[s] = void 0; - }) : t === 2 && Object.keys(e).forEach((s) => { - delete e[s]; + t === 1 ? Object.keys(e).forEach((n) => { + e[n] = void 0; + }) : t === 2 && Object.keys(e).forEach((n) => { + delete e[n]; }); }, replace: function(t) { @@ -14,48 +14,51 @@ const h = (e) => ({ ), Object.assign(e, t); } }); -function d(...e) { +function m(...e) { let t = e ?? []; return { - test: function(s) { + test: function(n) { if (t.length <= 1) return t.length === 1 ? t[0] : []; - let r = s ?? function(n, i) { - return n === i; + let i = n ?? function(s, r) { + return s === r; }; - return t.reduce((n, i) => (i && i.length > 0 && (n.length === 0 ? n.push(...i) : i.forEach((u) => { - n.some((f) => r(f, u)) || n.push(u); - })), n), []); + return t.reduce((s, r) => (r && r.length > 0 && (s.length === 0 ? s.push(...r) : r.forEach((u) => { + s.some((l) => i(l, u)) || s.push(u); + })), s), []); }, - path: function(...s) { - return this.test((r, n) => s.every((i) => r[i] === n[i])); + path: function(...n) { + return this.test((i, s) => n.every((r) => i[r] === s[r])); } }; } -function m(e, t, s) { - const r = t, n = s || t; - return function(i) { - const u = [], l = i.matchAll(e); - let f = 0; - for (const o of l) { - const c = i.slice(f, o.index); - c && u.push(n(c, !1)), u.push(r(o[0], !0)), f = o.index + o[0].length; +function I(e, t, n) { + const i = t, s = n || t; + return function(r) { + const u = [], f = r.matchAll(e); + let l = 0; + for (const o of f) { + const c = r.slice(l, o.index); + c && u.push(s(c, !1)), u.push(i(o[0], !0)), l = o.index + o[0].length; } - return f < i.length && u.push(n(i.slice(f), !1)), u; + return l < r.length && u.push(s(r.slice(l), !1)), u; }; } function g(e, t) { return typeof e == "string" && typeof t == "string" ? e.toLowerCase() === t.toLowerCase() : e === void 0 && t === void 0; } -const I = (e, t) => { - for (let s = 0; s < e.length; s++) { - let r = e[s]; - if (g(r, t)) +const O = (e, t) => { + for (let n = 0; n < e.length; n++) { + let i = e[n]; + if (g(i, t)) return !0; } return !1; +}, h = (e) => e.replaceAll(/[\u4e00-\u9fa5]/g, "--").length, p = (e, t, n = " ") => { + const i = t - (h(e) - e.length); + return e.padEnd(i, n); }; -function O(e) { +function E(e) { const t = e.lastIndexOf("."); return t === -1 ? "" : e.substring(t + 1); } @@ -63,34 +66,36 @@ function x(e) { let t = e.lastIndexOf("/"); return t === -1 && (t = e.lastIndexOf("\\"), t === -1) ? e : e.substring(t + 1); } -function E(e) { - const t = x(e), s = t.lastIndexOf("."); - return s === -1 ? t : t.substring(0, s); +function b(e) { + const t = x(e), n = t.lastIndexOf("."); + return n === -1 ? t : t.substring(0, n); } -function b(e, t = "win32") { - const s = t === "win32" ? "\\" : "/"; - let r, n, i, u; - const l = e.lastIndexOf(s); - l === -1 ? (r = "", n = e) : (r = e.substring(0, l + 1), n = e.substring(l + 1)); - const f = n.lastIndexOf("."); - return f === -1 ? (i = "", u = n) : (i = n.substring(f + 1), u = n.substring(0, f)), { - fileName: n, +function y(e, t = "win32") { + const n = t === "win32" ? "\\" : "/"; + let i, s, r, u; + const f = e.lastIndexOf(n); + f === -1 ? (i = "", s = e) : (i = e.substring(0, f + 1), s = e.substring(f + 1)); + const l = s.lastIndexOf("."); + return l === -1 ? (r = "", u = s) : (r = s.substring(l + 1), u = s.substring(0, l)), { + fileName: s, fileNameNoExt: u, - fileExtName: i, + fileExtName: r, fullPath: e, - pathOnly: r + pathOnly: i }; } export { a as RecordClearMode, - d as assignRecords, + m as assignRecords, g as equalsIgnoreCase, - O as getFileExt, - b as getFileInfo, + E as getFileExt, + y as getFileInfo, x as getFileName, - E as getFileNameWithoutExt, - I as includeIgnoreCase, - m as stringTokenizer, - h as withRecord + b as getFileNameWithoutExt, + O as includeIgnoreCase, + h as strLength, + p as strMonospacePad, + I as stringTokenizer, + d as withRecord }; //# sourceMappingURL=index.es.js.map diff --git a/lib/index.es.js.map b/lib/index.es.js.map index ca56a18..8cdb45f 100644 --- a/lib/index.es.js.map +++ b/lib/index.es.js.map @@ -1 +1 @@ -{"version":3,"file":"index.es.js","sources":["../src/commons/record-util.ts","../src/commons/str-utils.ts","../src/commons/file-util.ts"],"sourcesContent":["import { UnwrapNestedRefs } from \"vue\";\r\nexport enum RecordClearMode {\r\n delete = 2,\r\n reset = 1,\r\n}\r\nexport const withRecord = (obj: UnwrapNestedRefs>) => {\r\n return {\r\n clear: function (mode: RecordClearMode = RecordClearMode.delete) {\r\n if (mode === RecordClearMode.reset) {\r\n Object.keys(obj).forEach((key) => {\r\n obj[key] = undefined;\r\n });\r\n } else if (mode === RecordClearMode.delete) {\r\n Object.keys(obj).forEach((key) => {\r\n delete obj[key];\r\n });\r\n }\r\n },\r\n replace: function (newVal: UnwrapNestedRefs>) {\r\n this.clear(RecordClearMode.delete);\r\n Object.assign(obj, newVal);\r\n },\r\n };\r\n};\r\n\r\n/**\r\n * 这是一个泛型函数,接受任意个数的数组作为参数,并返回一个对象。\r\n * 该对象包含两个方法:test 和 path。\r\n * test 方法用于测试所有数组的元素是否相等,\r\n * path 方法用于测试所有数组的指定路径的值是否相等。\r\n\r\n * @param arrays \r\n * @returns \r\n */\r\nexport function assignRecords>(...arrays: T[][]) {\r\n let _arrays = arrays ?? [];\r\n\r\n return {\r\n test: function (equal?: (l: T, r: T) => boolean) {\r\n if (_arrays.length <= 1) {\r\n return _arrays.length === 1 ? _arrays[0] : [];\r\n }\r\n\r\n let localEqual =\r\n equal ??\r\n function (ll: T, rr: T) {\r\n return ll === rr;\r\n };\r\n return _arrays.reduce((acc, crt) => {\r\n if (crt && crt.length > 0) {\r\n if (acc.length === 0) {\r\n acc.push(...crt);\r\n } else {\r\n crt.forEach((c) => {\r\n const some = acc.some((a) => localEqual(a, c));\r\n if (!some) {\r\n acc.push(c);\r\n }\r\n });\r\n }\r\n }\r\n return acc;\r\n }, []);\r\n },\r\n path: function (...paths: string[]) {\r\n return this.test((l, r) => {\r\n return paths.every((path) => {\r\n return l[path] === r[path];\r\n });\r\n });\r\n },\r\n };\r\n}\r\n\r\n/**\r\n *\r\n * 接受一个目标对象和多个源对象作为参数,并返回合并后的对象。\r\n * 它会将源对象的属性复制到目标对象中,\r\n * 如果多个源对象有同名属性,\r\n * 则最后的属性值将覆盖前面的属性值。\r\n * @param target 目标对象\r\n * @param sources 来源对象参数\r\n * @returns 目标对象\r\n */\r\nexport const extend = >(\r\n // 目标对象\r\n target: T,\r\n // 其他对象参数\r\n ...sources: (T | undefined)[]\r\n): T => {\r\n // 遍历其他对象参数\r\n for (const source of sources) {\r\n if (source !== undefined) {\r\n // 遍历参数对象的属性\r\n for (const key in source) {\r\n // 判断属性存在于参数对象中且值不为 null\r\n if (source.hasOwnProperty(key) && source[key] != null) {\r\n // 将属性赋值给目标对象\r\n target[key] = source[key];\r\n }\r\n }\r\n }\r\n }\r\n // 返回目标对象\r\n return target;\r\n};\r\n","/**\r\n * 生成给定函数体的函数注释。\r\n *\r\n * @param {RegExp} regExp - 用于匹配的正则表达式。\r\n * @param {(text: string, match: boolean) => T} matchHandler - 处理匹配到的文本的函数。\r\n * @param {(text: string, match: boolean) => T} [textHandler] - 处理未匹配到的文本的函数。\r\n * @return {(str: string) => T[]} - 分词器函数。\r\n */\r\nexport function stringTokenizer(\r\n regExp: RegExp,\r\n matchHandler: (text: string, match: boolean) => T,\r\n textHandler?: (text: string, match: boolean) => T\r\n): (str: string) => T[] {\r\n\r\n const ifMatch = matchHandler;\r\n const ifText = textHandler?textHandler: matchHandler;\r\n\r\n return function (str: string) {\r\n const result: T[] = [];\r\n const matches = str.matchAll(regExp);\r\n let index = 0;\r\n for (const match of matches) {\r\n const before = str.slice(index, match.index);\r\n if (before) {\r\n result.push(ifText(before, false));\r\n }\r\n result.push(ifMatch(match[0], true));\r\n index = match.index! + match[0].length;\r\n }\r\n if (index < str.length) {\r\n result.push(ifText(str.slice(index), false));\r\n }\r\n return result;\r\n };\r\n}\r\n\r\n/**\r\n * 该函数接受两个参数,判断它们是否相等,不区分大小写。\r\n * 如果参数都是字符串类型,则将它们转换为小写后比较。\r\n * 如果两个参数都是undefined,则返回true,\r\n * 否则返回false。\r\n * @param source\r\n * @param target\r\n * @returns\r\n */\r\nexport function equalsIgnoreCase(\r\n source: string | undefined,\r\n target: string | undefined\r\n) {\r\n if (typeof source === \"string\" && typeof target === \"string\") {\r\n return source.toLowerCase() === target.toLowerCase();\r\n } else if (source === undefined && target === undefined) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * 这个函数接受一个字符串数组和一个字符串作为参数,\r\n * 在数组中判断是否存在与搜索字符串相同或相似的字符串,忽略大小写。\r\n * 如果找到匹配项则返回true,否则返回false。\r\n * @param list 字符串数组\r\n * @param search 用来搜索的字符串\r\n * @returns 是否包含\r\n */\r\nexport const includeIgnoreCase = (list: string[], search: string) => {\r\n for (let i = 0; i < list.length; i++) {\r\n let item = list[i];\r\n if (equalsIgnoreCase(item, search)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n};\r\n\r\nexport const strLength = (str: string) => {\r\n return str.replaceAll(/[\\u4e00-\\u9fa5]/g, \"--\").length;\r\n};\r\n\r\nexport const strMonospacePad = (\r\n str: string,\r\n length: number,\r\n pad: string = \" \"\r\n) => {\r\n const visibleLength = length - (strLength(str) - str.length);\r\n return str.padEnd(visibleLength, pad);\r\n};\r\n","/**\r\n * 获取文件的后缀名\r\n * @param fileName 文件名\r\n * @returns 文件后缀名\r\n */\r\nexport function getFileExt(fileName: string): string {\r\n const index = fileName.lastIndexOf(\".\");\r\n if (index === -1) {\r\n return \"\";\r\n }\r\n return fileName.substring(index + 1);\r\n}\r\n\r\n/**\r\n * 获取文件全名(包含扩展名)\r\n * 该函数接收一个表示文件路径的字符串作为参数,返回该路径中文件名部分。\r\n * 首先查找路径中最后一个斜杠或反斜杠的索引,若未找到则直接返回路径;\r\n * 若找到,则使用substring方法提取最后一个斜杠或反斜杠后面的字符串作为文件名并返回。\r\n * @param path 文件路径\r\n * @returns 文件全名(包含扩展名)\r\n */\r\nexport function getFileFullName(path: string): string {\r\n let index = path.lastIndexOf(\"/\");\r\n if (index === -1) {\r\n index = path.lastIndexOf(\"\\\\\");\r\n if (index === -1) {\r\n return path;\r\n }\r\n }\r\n return path.substring(index + 1);\r\n}\r\n\r\n/**\r\n * 获取文件名不包含扩展名\r\n */\r\nexport function getFileNameWithoutExt(path: string): string {\r\n const fileName = getFileFullName(path);\r\n const index = fileName.lastIndexOf(\".\");\r\n if (index === -1) {\r\n return fileName;\r\n }\r\n return fileName.substring(0, index);\r\n}\r\n\r\n/**\r\n * 文件信息\r\n */\r\nexport interface IFileInfo {\r\n /** 文件名(包含扩展名) */\r\n fileName: string;\r\n /**\r\n * 文件名不带扩展名\r\n */\r\n fileNameNoExt: string;\r\n /** 文件扩展名 */\r\n fileExtName: string;\r\n /** 路径仅包含文件夹 */\r\n pathOnly: string;\r\n /** 完整路径 */\r\n fullPath: string;\r\n}\r\n\r\n/**\r\n * 获取文件信息\r\n * @param path 文件路径\r\n * @param platform 平台名称,默认为\"win32\"\r\n * @returns 包含文件名、文件名不带扩展名、文件扩展名、路径仅包含文件夹、完整路径的对象\r\n */\r\nexport function getFileInfo(\r\n path: string,\r\n platform: string = \"win32\"\r\n): IFileInfo {\r\n const pathSaprator = platform === \"win32\" ? \"\\\\\" : \"/\";\r\n\r\n let pathOnly: string;\r\n\r\n let fileName: string;\r\n let fileExtName: string;\r\n let fileNameNoExt: string;\r\n const pathIndex = path.lastIndexOf(pathSaprator);\r\n if (pathIndex === -1) {\r\n pathOnly = \"\";\r\n fileName = path;\r\n } else {\r\n pathOnly = path.substring(0, pathIndex + 1);\r\n fileName = path.substring(pathIndex + 1);\r\n }\r\n\r\n const extIndex = fileName.lastIndexOf(\".\");\r\n if (extIndex === -1) {\r\n fileExtName = \"\";\r\n fileNameNoExt = fileName;\r\n } else {\r\n fileExtName = fileName.substring(extIndex + 1);\r\n fileNameNoExt = fileName.substring(0, extIndex);\r\n }\r\n\r\n return {\r\n fileName,\r\n fileNameNoExt,\r\n fileExtName,\r\n fullPath: path,\r\n pathOnly,\r\n };\r\n}\r\n"],"names":["RecordClearMode","withRecord","obj","mode","key","newVal","assignRecords","arrays","_arrays","equal","localEqual","ll","rr","acc","crt","c","a","paths","l","r","path","stringTokenizer","regExp","matchHandler","textHandler","ifMatch","ifText","str","result","matches","index","match","before","equalsIgnoreCase","source","target","includeIgnoreCase","list","search","i","item","getFileExt","fileName","getFileFullName","getFileNameWithoutExt","getFileInfo","platform","pathSaprator","pathOnly","fileExtName","fileNameNoExt","pathIndex","extIndex"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"index.es.js","sources":["../src/commons/record-util.ts","../src/commons/str-utils.ts","../src/commons/file-util.ts"],"sourcesContent":["import { UnwrapNestedRefs } from \"vue\";\r\nexport enum RecordClearMode {\r\n delete = 2,\r\n reset = 1,\r\n}\r\nexport const withRecord = (obj: UnwrapNestedRefs>) => {\r\n return {\r\n clear: function (mode: RecordClearMode = RecordClearMode.delete) {\r\n if (mode === RecordClearMode.reset) {\r\n Object.keys(obj).forEach((key) => {\r\n obj[key] = undefined;\r\n });\r\n } else if (mode === RecordClearMode.delete) {\r\n Object.keys(obj).forEach((key) => {\r\n delete obj[key];\r\n });\r\n }\r\n },\r\n replace: function (newVal: UnwrapNestedRefs>) {\r\n this.clear(RecordClearMode.delete);\r\n Object.assign(obj, newVal);\r\n },\r\n };\r\n};\r\n\r\n/**\r\n * 这是一个泛型函数,接受任意个数的数组作为参数,并返回一个对象。\r\n * 该对象包含两个方法:test 和 path。\r\n * test 方法用于测试所有数组的元素是否相等,\r\n * path 方法用于测试所有数组的指定路径的值是否相等。\r\n\r\n * @param arrays \r\n * @returns \r\n */\r\nexport function assignRecords>(...arrays: T[][]) {\r\n let _arrays = arrays ?? [];\r\n\r\n return {\r\n test: function (equal?: (l: T, r: T) => boolean) {\r\n if (_arrays.length <= 1) {\r\n return _arrays.length === 1 ? _arrays[0] : [];\r\n }\r\n\r\n let localEqual =\r\n equal ??\r\n function (ll: T, rr: T) {\r\n return ll === rr;\r\n };\r\n return _arrays.reduce((acc, crt) => {\r\n if (crt && crt.length > 0) {\r\n if (acc.length === 0) {\r\n acc.push(...crt);\r\n } else {\r\n crt.forEach((c) => {\r\n const some = acc.some((a) => localEqual(a, c));\r\n if (!some) {\r\n acc.push(c);\r\n }\r\n });\r\n }\r\n }\r\n return acc;\r\n }, []);\r\n },\r\n path: function (...paths: string[]) {\r\n return this.test((l, r) => {\r\n return paths.every((path) => {\r\n return l[path] === r[path];\r\n });\r\n });\r\n },\r\n };\r\n}\r\n\r\n/**\r\n *\r\n * 接受一个目标对象和多个源对象作为参数,并返回合并后的对象。\r\n * 它会将源对象的属性复制到目标对象中,\r\n * 如果多个源对象有同名属性,\r\n * 则最后的属性值将覆盖前面的属性值。\r\n * @param target 目标对象\r\n * @param sources 来源对象参数\r\n * @returns 目标对象\r\n */\r\nexport const extend = >(\r\n // 目标对象\r\n target: T,\r\n // 其他对象参数\r\n ...sources: (T | undefined)[]\r\n): T => {\r\n // 遍历其他对象参数\r\n for (const source of sources) {\r\n if (source !== undefined) {\r\n // 遍历参数对象的属性\r\n for (const key in source) {\r\n // 判断属性存在于参数对象中且值不为 null\r\n if (source.hasOwnProperty(key) && source[key] != null) {\r\n // 将属性赋值给目标对象\r\n target[key] = source[key];\r\n }\r\n }\r\n }\r\n }\r\n // 返回目标对象\r\n return target;\r\n};\r\n","/**\r\n * 生成给定函数体的函数注释。\r\n *\r\n * @param {RegExp} regExp - 用于匹配的正则表达式。\r\n * @param {(text: string, match: boolean) => T} matchHandler - 处理匹配到的文本的函数。\r\n * @param {(text: string, match: boolean) => T} [textHandler] - 处理未匹配到的文本的函数。\r\n * @return {(str: string) => T[]} - 分词器函数。\r\n */\r\nexport function stringTokenizer(\r\n regExp: RegExp,\r\n matchHandler: (text: string, match: boolean) => T,\r\n textHandler?: (text: string, match: boolean) => T\r\n): (str: string) => T[] {\r\n\r\n const ifMatch = matchHandler;\r\n const ifText = textHandler?textHandler: matchHandler;\r\n\r\n return function (str: string) {\r\n const result: T[] = [];\r\n const matches = str.matchAll(regExp);\r\n let index = 0;\r\n for (const match of matches) {\r\n const before = str.slice(index, match.index);\r\n if (before) {\r\n result.push(ifText(before, false));\r\n }\r\n result.push(ifMatch(match[0], true));\r\n index = match.index! + match[0].length;\r\n }\r\n if (index < str.length) {\r\n result.push(ifText(str.slice(index), false));\r\n }\r\n return result;\r\n };\r\n}\r\n\r\n/**\r\n * 该函数接受两个参数,判断它们是否相等,不区分大小写。\r\n * 如果参数都是字符串类型,则将它们转换为小写后比较。\r\n * 如果两个参数都是undefined,则返回true,\r\n * 否则返回false。\r\n * @param source\r\n * @param target\r\n * @returns\r\n */\r\nexport function equalsIgnoreCase(\r\n source: string | undefined,\r\n target: string | undefined\r\n) {\r\n if (typeof source === \"string\" && typeof target === \"string\") {\r\n return source.toLowerCase() === target.toLowerCase();\r\n } else if (source === undefined && target === undefined) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * 这个函数接受一个字符串数组和一个字符串作为参数,\r\n * 在数组中判断是否存在与搜索字符串相同或相似的字符串,忽略大小写。\r\n * 如果找到匹配项则返回true,否则返回false。\r\n * @param list 字符串数组\r\n * @param search 用来搜索的字符串\r\n * @returns 是否包含\r\n */\r\nexport const includeIgnoreCase = (list: string[], search: string) => {\r\n for (let i = 0; i < list.length; i++) {\r\n let item = list[i];\r\n if (equalsIgnoreCase(item, search)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n};\r\n\r\nexport const strLength = (str: string) => {\r\n return str.replaceAll(/[\\u4e00-\\u9fa5]/g, \"--\").length;\r\n};\r\n\r\nexport const strMonospacePad = (\r\n str: string,\r\n length: number,\r\n pad: string = \" \"\r\n) => {\r\n const visibleLength = length - (strLength(str) - str.length);\r\n return str.padEnd(visibleLength, pad);\r\n};\r\n","/**\r\n * 获取文件的后缀名\r\n * @param fileName 文件名\r\n * @returns 文件后缀名\r\n */\r\nexport function getFileExt(fileName: string): string {\r\n const index = fileName.lastIndexOf(\".\");\r\n if (index === -1) {\r\n return \"\";\r\n }\r\n return fileName.substring(index + 1);\r\n}\r\n\r\n/**\r\n * 获取文件全名(包含扩展名)\r\n * 该函数接收一个表示文件路径的字符串作为参数,返回该路径中文件名部分。\r\n * 首先查找路径中最后一个斜杠或反斜杠的索引,若未找到则直接返回路径;\r\n * 若找到,则使用substring方法提取最后一个斜杠或反斜杠后面的字符串作为文件名并返回。\r\n * @param path 文件路径\r\n * @returns 文件全名(包含扩展名)\r\n */\r\nexport function getFileFullName(path: string): string {\r\n let index = path.lastIndexOf(\"/\");\r\n if (index === -1) {\r\n index = path.lastIndexOf(\"\\\\\");\r\n if (index === -1) {\r\n return path;\r\n }\r\n }\r\n return path.substring(index + 1);\r\n}\r\n\r\n/**\r\n * 获取文件名不包含扩展名\r\n */\r\nexport function getFileNameWithoutExt(path: string): string {\r\n const fileName = getFileFullName(path);\r\n const index = fileName.lastIndexOf(\".\");\r\n if (index === -1) {\r\n return fileName;\r\n }\r\n return fileName.substring(0, index);\r\n}\r\n\r\n/**\r\n * 文件信息\r\n */\r\nexport interface IFileInfo {\r\n /** 文件名(包含扩展名) */\r\n fileName: string;\r\n /**\r\n * 文件名不带扩展名\r\n */\r\n fileNameNoExt: string;\r\n /** 文件扩展名 */\r\n fileExtName: string;\r\n /** 路径仅包含文件夹 */\r\n pathOnly: string;\r\n /** 完整路径 */\r\n fullPath: string;\r\n}\r\n\r\n/**\r\n * 获取文件信息\r\n * @param path 文件路径\r\n * @param platform 平台名称,默认为\"win32\"\r\n * @returns 包含文件名、文件名不带扩展名、文件扩展名、路径仅包含文件夹、完整路径的对象\r\n */\r\nexport function getFileInfo(\r\n path: string,\r\n platform: string = \"win32\"\r\n): IFileInfo {\r\n const pathSaprator = platform === \"win32\" ? \"\\\\\" : \"/\";\r\n\r\n let pathOnly: string;\r\n\r\n let fileName: string;\r\n let fileExtName: string;\r\n let fileNameNoExt: string;\r\n const pathIndex = path.lastIndexOf(pathSaprator);\r\n if (pathIndex === -1) {\r\n pathOnly = \"\";\r\n fileName = path;\r\n } else {\r\n pathOnly = path.substring(0, pathIndex + 1);\r\n fileName = path.substring(pathIndex + 1);\r\n }\r\n\r\n const extIndex = fileName.lastIndexOf(\".\");\r\n if (extIndex === -1) {\r\n fileExtName = \"\";\r\n fileNameNoExt = fileName;\r\n } else {\r\n fileExtName = fileName.substring(extIndex + 1);\r\n fileNameNoExt = fileName.substring(0, extIndex);\r\n }\r\n\r\n return {\r\n fileName,\r\n fileNameNoExt,\r\n fileExtName,\r\n fullPath: path,\r\n pathOnly,\r\n };\r\n}\r\n"],"names":["RecordClearMode","withRecord","obj","mode","key","newVal","assignRecords","arrays","_arrays","equal","localEqual","ll","rr","acc","crt","c","a","paths","l","r","path","stringTokenizer","regExp","matchHandler","textHandler","ifMatch","ifText","str","result","matches","index","match","before","equalsIgnoreCase","source","target","includeIgnoreCase","list","search","i","item","strLength","strMonospacePad","length","pad","visibleLength","getFileExt","fileName","getFileFullName","getFileNameWithoutExt","getFileInfo","platform","pathSaprator","pathOnly","fileExtName","fileNameNoExt","pathIndex","extIndex"],"mappings":"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"} \ No newline at end of file diff --git a/lib/index.umd.js b/lib/index.umd.js index e0cb666..ca7b0ec 100644 --- a/lib/index.umd.js +++ b/lib/index.umd.js @@ -1,2 +1,2 @@ -(function(r,o){typeof exports=="object"&&typeof module<"u"?o(exports):typeof define=="function"&&define.amd?define(["exports"],o):(r=typeof globalThis<"u"?globalThis:r||self,o(r["ez-common-ts"]={}))})(this,function(r){"use strict";var o=(e=>(e[e.delete=2]="delete",e[e.reset=1]="reset",e))(o||{});const m=e=>({clear:function(n=2){n===1?Object.keys(e).forEach(i=>{e[i]=void 0}):n===2&&Object.keys(e).forEach(i=>{delete e[i]})},replace:function(n){this.clear(2),Object.assign(e,n)}});function x(...e){let n=e??[];return{test:function(i){if(n.length<=1)return n.length===1?n[0]:[];let u=i??function(t,s){return t===s};return n.reduce((t,s)=>(s&&s.length>0&&(t.length===0?t.push(...s):s.forEach(f=>{t.some(l=>u(l,f))||t.push(f)})),t),[])},path:function(...i){return this.test((u,t)=>i.every(s=>u[s]===t[s]))}}}function I(e,n,i){const u=n,t=i||n;return function(s){const f=[],c=s.matchAll(e);let l=0;for(const g of c){const h=s.slice(l,g.index);h&&f.push(t(h,!1)),f.push(u(g[0],!0)),l=g.index+g[0].length}return l{for(let i=0;i(e[e.delete=2]="delete",e[e.reset=1]="reset",e))(o||{});const I=e=>({clear:function(n=2){n===1?Object.keys(e).forEach(t=>{e[t]=void 0}):n===2&&Object.keys(e).forEach(t=>{delete e[t]})},replace:function(n){this.clear(2),Object.assign(e,n)}});function x(...e){let n=e??[];return{test:function(t){if(n.length<=1)return n.length===1?n[0]:[];let u=t??function(i,s){return i===s};return n.reduce((i,s)=>(s&&s.length>0&&(i.length===0?i.push(...s):s.forEach(l=>{i.some(f=>u(f,l))||i.push(l)})),i),[])},path:function(...t){return this.test((u,i)=>t.every(s=>u[s]===i[s]))}}}function b(e,n,t){const u=n,i=t||n;return function(s){const l=[],c=s.matchAll(e);let f=0;for(const a of c){const m=s.slice(f,a.index);m&&l.push(i(m,!1)),l.push(u(a[0],!0)),f=a.index+a[0].length}return f{for(let t=0;te.replaceAll(/[\u4e00-\u9fa5]/g,"--").length,E=(e,n,t=" ")=>{const u=n-(d(e)-e.length);return e.padEnd(u,t)};function O(e){const n=e.lastIndexOf(".");return n===-1?"":e.substring(n+1)}function h(e){let n=e.lastIndexOf("/");return n===-1&&(n=e.lastIndexOf("\\"),n===-1)?e:e.substring(n+1)}function F(e){const n=h(e),t=n.lastIndexOf(".");return t===-1?n:n.substring(0,t)}function N(e,n="win32"){const t=n==="win32"?"\\":"/";let u,i,s,l;const c=e.lastIndexOf(t);c===-1?(u="",i=e):(u=e.substring(0,c+1),i=e.substring(c+1));const f=i.lastIndexOf(".");return f===-1?(s="",l=i):(s=i.substring(f+1),l=i.substring(0,f)),{fileName:i,fileNameNoExt:l,fileExtName:s,fullPath:e,pathOnly:u}}r.RecordClearMode=o,r.assignRecords=x,r.equalsIgnoreCase=g,r.getFileExt=O,r.getFileInfo=N,r.getFileName=h,r.getFileNameWithoutExt=F,r.includeIgnoreCase=y,r.strLength=d,r.strMonospacePad=E,r.stringTokenizer=b,r.withRecord=I,Object.defineProperty(r,Symbol.toStringTag,{value:"Module"})}); //# sourceMappingURL=index.umd.js.map diff --git a/lib/index.umd.js.map b/lib/index.umd.js.map index 95dda3d..2d7a17b 100644 --- a/lib/index.umd.js.map +++ b/lib/index.umd.js.map @@ -1 +1 @@ -{"version":3,"file":"index.umd.js","sources":["../src/commons/record-util.ts","../src/commons/str-utils.ts","../src/commons/file-util.ts"],"sourcesContent":["import { UnwrapNestedRefs } from \"vue\";\r\nexport enum RecordClearMode {\r\n delete = 2,\r\n reset = 1,\r\n}\r\nexport const withRecord = (obj: UnwrapNestedRefs>) => {\r\n return {\r\n clear: function (mode: RecordClearMode = RecordClearMode.delete) {\r\n if (mode === RecordClearMode.reset) {\r\n Object.keys(obj).forEach((key) => {\r\n obj[key] = undefined;\r\n });\r\n } else if (mode === RecordClearMode.delete) {\r\n Object.keys(obj).forEach((key) => {\r\n delete obj[key];\r\n });\r\n }\r\n },\r\n replace: function (newVal: UnwrapNestedRefs>) {\r\n this.clear(RecordClearMode.delete);\r\n Object.assign(obj, newVal);\r\n },\r\n };\r\n};\r\n\r\n/**\r\n * 这是一个泛型函数,接受任意个数的数组作为参数,并返回一个对象。\r\n * 该对象包含两个方法:test 和 path。\r\n * test 方法用于测试所有数组的元素是否相等,\r\n * path 方法用于测试所有数组的指定路径的值是否相等。\r\n\r\n * @param arrays \r\n * @returns \r\n */\r\nexport function assignRecords>(...arrays: T[][]) {\r\n let _arrays = arrays ?? [];\r\n\r\n return {\r\n test: function (equal?: (l: T, r: T) => boolean) {\r\n if (_arrays.length <= 1) {\r\n return _arrays.length === 1 ? _arrays[0] : [];\r\n }\r\n\r\n let localEqual =\r\n equal ??\r\n function (ll: T, rr: T) {\r\n return ll === rr;\r\n };\r\n return _arrays.reduce((acc, crt) => {\r\n if (crt && crt.length > 0) {\r\n if (acc.length === 0) {\r\n acc.push(...crt);\r\n } else {\r\n crt.forEach((c) => {\r\n const some = acc.some((a) => localEqual(a, c));\r\n if (!some) {\r\n acc.push(c);\r\n }\r\n });\r\n }\r\n }\r\n return acc;\r\n }, []);\r\n },\r\n path: function (...paths: string[]) {\r\n return this.test((l, r) => {\r\n return paths.every((path) => {\r\n return l[path] === r[path];\r\n });\r\n });\r\n },\r\n };\r\n}\r\n\r\n/**\r\n *\r\n * 接受一个目标对象和多个源对象作为参数,并返回合并后的对象。\r\n * 它会将源对象的属性复制到目标对象中,\r\n * 如果多个源对象有同名属性,\r\n * 则最后的属性值将覆盖前面的属性值。\r\n * @param target 目标对象\r\n * @param sources 来源对象参数\r\n * @returns 目标对象\r\n */\r\nexport const extend = >(\r\n // 目标对象\r\n target: T,\r\n // 其他对象参数\r\n ...sources: (T | undefined)[]\r\n): T => {\r\n // 遍历其他对象参数\r\n for (const source of sources) {\r\n if (source !== undefined) {\r\n // 遍历参数对象的属性\r\n for (const key in source) {\r\n // 判断属性存在于参数对象中且值不为 null\r\n if (source.hasOwnProperty(key) && source[key] != null) {\r\n // 将属性赋值给目标对象\r\n target[key] = source[key];\r\n }\r\n }\r\n }\r\n }\r\n // 返回目标对象\r\n return target;\r\n};\r\n","/**\r\n * 生成给定函数体的函数注释。\r\n *\r\n * @param {RegExp} regExp - 用于匹配的正则表达式。\r\n * @param {(text: string, match: boolean) => T} matchHandler - 处理匹配到的文本的函数。\r\n * @param {(text: string, match: boolean) => T} [textHandler] - 处理未匹配到的文本的函数。\r\n * @return {(str: string) => T[]} - 分词器函数。\r\n */\r\nexport function stringTokenizer(\r\n regExp: RegExp,\r\n matchHandler: (text: string, match: boolean) => T,\r\n textHandler?: (text: string, match: boolean) => T\r\n): (str: string) => T[] {\r\n\r\n const ifMatch = matchHandler;\r\n const ifText = textHandler?textHandler: matchHandler;\r\n\r\n return function (str: string) {\r\n const result: T[] = [];\r\n const matches = str.matchAll(regExp);\r\n let index = 0;\r\n for (const match of matches) {\r\n const before = str.slice(index, match.index);\r\n if (before) {\r\n result.push(ifText(before, false));\r\n }\r\n result.push(ifMatch(match[0], true));\r\n index = match.index! + match[0].length;\r\n }\r\n if (index < str.length) {\r\n result.push(ifText(str.slice(index), false));\r\n }\r\n return result;\r\n };\r\n}\r\n\r\n/**\r\n * 该函数接受两个参数,判断它们是否相等,不区分大小写。\r\n * 如果参数都是字符串类型,则将它们转换为小写后比较。\r\n * 如果两个参数都是undefined,则返回true,\r\n * 否则返回false。\r\n * @param source\r\n * @param target\r\n * @returns\r\n */\r\nexport function equalsIgnoreCase(\r\n source: string | undefined,\r\n target: string | undefined\r\n) {\r\n if (typeof source === \"string\" && typeof target === \"string\") {\r\n return source.toLowerCase() === target.toLowerCase();\r\n } else if (source === undefined && target === undefined) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * 这个函数接受一个字符串数组和一个字符串作为参数,\r\n * 在数组中判断是否存在与搜索字符串相同或相似的字符串,忽略大小写。\r\n * 如果找到匹配项则返回true,否则返回false。\r\n * @param list 字符串数组\r\n * @param search 用来搜索的字符串\r\n * @returns 是否包含\r\n */\r\nexport const includeIgnoreCase = (list: string[], search: string) => {\r\n for (let i = 0; i < list.length; i++) {\r\n let item = list[i];\r\n if (equalsIgnoreCase(item, search)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n};\r\n\r\nexport const strLength = (str: string) => {\r\n return str.replaceAll(/[\\u4e00-\\u9fa5]/g, \"--\").length;\r\n};\r\n\r\nexport const strMonospacePad = (\r\n str: string,\r\n length: number,\r\n pad: string = \" \"\r\n) => {\r\n const visibleLength = length - (strLength(str) - str.length);\r\n return str.padEnd(visibleLength, pad);\r\n};\r\n","/**\r\n * 获取文件的后缀名\r\n * @param fileName 文件名\r\n * @returns 文件后缀名\r\n */\r\nexport function getFileExt(fileName: string): string {\r\n const index = fileName.lastIndexOf(\".\");\r\n if (index === -1) {\r\n return \"\";\r\n }\r\n return fileName.substring(index + 1);\r\n}\r\n\r\n/**\r\n * 获取文件全名(包含扩展名)\r\n * 该函数接收一个表示文件路径的字符串作为参数,返回该路径中文件名部分。\r\n * 首先查找路径中最后一个斜杠或反斜杠的索引,若未找到则直接返回路径;\r\n * 若找到,则使用substring方法提取最后一个斜杠或反斜杠后面的字符串作为文件名并返回。\r\n * @param path 文件路径\r\n * @returns 文件全名(包含扩展名)\r\n */\r\nexport function getFileFullName(path: string): string {\r\n let index = path.lastIndexOf(\"/\");\r\n if (index === -1) {\r\n index = path.lastIndexOf(\"\\\\\");\r\n if (index === -1) {\r\n return path;\r\n }\r\n }\r\n return path.substring(index + 1);\r\n}\r\n\r\n/**\r\n * 获取文件名不包含扩展名\r\n */\r\nexport function getFileNameWithoutExt(path: string): string {\r\n const fileName = getFileFullName(path);\r\n const index = fileName.lastIndexOf(\".\");\r\n if (index === -1) {\r\n return fileName;\r\n }\r\n return fileName.substring(0, index);\r\n}\r\n\r\n/**\r\n * 文件信息\r\n */\r\nexport interface IFileInfo {\r\n /** 文件名(包含扩展名) */\r\n fileName: string;\r\n /**\r\n * 文件名不带扩展名\r\n */\r\n fileNameNoExt: string;\r\n /** 文件扩展名 */\r\n fileExtName: string;\r\n /** 路径仅包含文件夹 */\r\n pathOnly: string;\r\n /** 完整路径 */\r\n fullPath: string;\r\n}\r\n\r\n/**\r\n * 获取文件信息\r\n * @param path 文件路径\r\n * @param platform 平台名称,默认为\"win32\"\r\n * @returns 包含文件名、文件名不带扩展名、文件扩展名、路径仅包含文件夹、完整路径的对象\r\n */\r\nexport function getFileInfo(\r\n path: string,\r\n platform: string = \"win32\"\r\n): IFileInfo {\r\n const pathSaprator = platform === \"win32\" ? \"\\\\\" : \"/\";\r\n\r\n let pathOnly: string;\r\n\r\n let fileName: string;\r\n let fileExtName: string;\r\n let fileNameNoExt: string;\r\n const pathIndex = path.lastIndexOf(pathSaprator);\r\n if (pathIndex === -1) {\r\n pathOnly = \"\";\r\n fileName = path;\r\n } else {\r\n pathOnly = path.substring(0, pathIndex + 1);\r\n fileName = path.substring(pathIndex + 1);\r\n }\r\n\r\n const extIndex = fileName.lastIndexOf(\".\");\r\n if (extIndex === -1) {\r\n fileExtName = \"\";\r\n fileNameNoExt = fileName;\r\n } else {\r\n fileExtName = fileName.substring(extIndex + 1);\r\n fileNameNoExt = fileName.substring(0, extIndex);\r\n }\r\n\r\n return {\r\n fileName,\r\n fileNameNoExt,\r\n fileExtName,\r\n fullPath: path,\r\n pathOnly,\r\n };\r\n}\r\n"],"names":["RecordClearMode","withRecord","obj","mode","key","newVal","assignRecords","arrays","_arrays","equal","localEqual","ll","rr","acc","crt","c","a","paths","l","r","path","stringTokenizer","regExp","matchHandler","textHandler","ifMatch","ifText","str","result","matches","index","match","before","equalsIgnoreCase","source","target","includeIgnoreCase","list","search","item","getFileExt","fileName","getFileFullName","getFileNameWithoutExt","getFileInfo","platform","pathSaprator","pathOnly","fileExtName","fileNameNoExt","pathIndex","extIndex"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"index.umd.js","sources":["../src/commons/record-util.ts","../src/commons/str-utils.ts","../src/commons/file-util.ts"],"sourcesContent":["import { UnwrapNestedRefs } from \"vue\";\r\nexport enum RecordClearMode {\r\n delete = 2,\r\n reset = 1,\r\n}\r\nexport const withRecord = (obj: UnwrapNestedRefs>) => {\r\n return {\r\n clear: function (mode: RecordClearMode = RecordClearMode.delete) {\r\n if (mode === RecordClearMode.reset) {\r\n Object.keys(obj).forEach((key) => {\r\n obj[key] = undefined;\r\n });\r\n } else if (mode === RecordClearMode.delete) {\r\n Object.keys(obj).forEach((key) => {\r\n delete obj[key];\r\n });\r\n }\r\n },\r\n replace: function (newVal: UnwrapNestedRefs>) {\r\n this.clear(RecordClearMode.delete);\r\n Object.assign(obj, newVal);\r\n },\r\n };\r\n};\r\n\r\n/**\r\n * 这是一个泛型函数,接受任意个数的数组作为参数,并返回一个对象。\r\n * 该对象包含两个方法:test 和 path。\r\n * test 方法用于测试所有数组的元素是否相等,\r\n * path 方法用于测试所有数组的指定路径的值是否相等。\r\n\r\n * @param arrays \r\n * @returns \r\n */\r\nexport function assignRecords>(...arrays: T[][]) {\r\n let _arrays = arrays ?? [];\r\n\r\n return {\r\n test: function (equal?: (l: T, r: T) => boolean) {\r\n if (_arrays.length <= 1) {\r\n return _arrays.length === 1 ? _arrays[0] : [];\r\n }\r\n\r\n let localEqual =\r\n equal ??\r\n function (ll: T, rr: T) {\r\n return ll === rr;\r\n };\r\n return _arrays.reduce((acc, crt) => {\r\n if (crt && crt.length > 0) {\r\n if (acc.length === 0) {\r\n acc.push(...crt);\r\n } else {\r\n crt.forEach((c) => {\r\n const some = acc.some((a) => localEqual(a, c));\r\n if (!some) {\r\n acc.push(c);\r\n }\r\n });\r\n }\r\n }\r\n return acc;\r\n }, []);\r\n },\r\n path: function (...paths: string[]) {\r\n return this.test((l, r) => {\r\n return paths.every((path) => {\r\n return l[path] === r[path];\r\n });\r\n });\r\n },\r\n };\r\n}\r\n\r\n/**\r\n *\r\n * 接受一个目标对象和多个源对象作为参数,并返回合并后的对象。\r\n * 它会将源对象的属性复制到目标对象中,\r\n * 如果多个源对象有同名属性,\r\n * 则最后的属性值将覆盖前面的属性值。\r\n * @param target 目标对象\r\n * @param sources 来源对象参数\r\n * @returns 目标对象\r\n */\r\nexport const extend = >(\r\n // 目标对象\r\n target: T,\r\n // 其他对象参数\r\n ...sources: (T | undefined)[]\r\n): T => {\r\n // 遍历其他对象参数\r\n for (const source of sources) {\r\n if (source !== undefined) {\r\n // 遍历参数对象的属性\r\n for (const key in source) {\r\n // 判断属性存在于参数对象中且值不为 null\r\n if (source.hasOwnProperty(key) && source[key] != null) {\r\n // 将属性赋值给目标对象\r\n target[key] = source[key];\r\n }\r\n }\r\n }\r\n }\r\n // 返回目标对象\r\n return target;\r\n};\r\n","/**\r\n * 生成给定函数体的函数注释。\r\n *\r\n * @param {RegExp} regExp - 用于匹配的正则表达式。\r\n * @param {(text: string, match: boolean) => T} matchHandler - 处理匹配到的文本的函数。\r\n * @param {(text: string, match: boolean) => T} [textHandler] - 处理未匹配到的文本的函数。\r\n * @return {(str: string) => T[]} - 分词器函数。\r\n */\r\nexport function stringTokenizer(\r\n regExp: RegExp,\r\n matchHandler: (text: string, match: boolean) => T,\r\n textHandler?: (text: string, match: boolean) => T\r\n): (str: string) => T[] {\r\n\r\n const ifMatch = matchHandler;\r\n const ifText = textHandler?textHandler: matchHandler;\r\n\r\n return function (str: string) {\r\n const result: T[] = [];\r\n const matches = str.matchAll(regExp);\r\n let index = 0;\r\n for (const match of matches) {\r\n const before = str.slice(index, match.index);\r\n if (before) {\r\n result.push(ifText(before, false));\r\n }\r\n result.push(ifMatch(match[0], true));\r\n index = match.index! + match[0].length;\r\n }\r\n if (index < str.length) {\r\n result.push(ifText(str.slice(index), false));\r\n }\r\n return result;\r\n };\r\n}\r\n\r\n/**\r\n * 该函数接受两个参数,判断它们是否相等,不区分大小写。\r\n * 如果参数都是字符串类型,则将它们转换为小写后比较。\r\n * 如果两个参数都是undefined,则返回true,\r\n * 否则返回false。\r\n * @param source\r\n * @param target\r\n * @returns\r\n */\r\nexport function equalsIgnoreCase(\r\n source: string | undefined,\r\n target: string | undefined\r\n) {\r\n if (typeof source === \"string\" && typeof target === \"string\") {\r\n return source.toLowerCase() === target.toLowerCase();\r\n } else if (source === undefined && target === undefined) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * 这个函数接受一个字符串数组和一个字符串作为参数,\r\n * 在数组中判断是否存在与搜索字符串相同或相似的字符串,忽略大小写。\r\n * 如果找到匹配项则返回true,否则返回false。\r\n * @param list 字符串数组\r\n * @param search 用来搜索的字符串\r\n * @returns 是否包含\r\n */\r\nexport const includeIgnoreCase = (list: string[], search: string) => {\r\n for (let i = 0; i < list.length; i++) {\r\n let item = list[i];\r\n if (equalsIgnoreCase(item, search)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n};\r\n\r\nexport const strLength = (str: string) => {\r\n return str.replaceAll(/[\\u4e00-\\u9fa5]/g, \"--\").length;\r\n};\r\n\r\nexport const strMonospacePad = (\r\n str: string,\r\n length: number,\r\n pad: string = \" \"\r\n) => {\r\n const visibleLength = length - (strLength(str) - str.length);\r\n return str.padEnd(visibleLength, pad);\r\n};\r\n","/**\r\n * 获取文件的后缀名\r\n * @param fileName 文件名\r\n * @returns 文件后缀名\r\n */\r\nexport function getFileExt(fileName: string): string {\r\n const index = fileName.lastIndexOf(\".\");\r\n if (index === -1) {\r\n return \"\";\r\n }\r\n return fileName.substring(index + 1);\r\n}\r\n\r\n/**\r\n * 获取文件全名(包含扩展名)\r\n * 该函数接收一个表示文件路径的字符串作为参数,返回该路径中文件名部分。\r\n * 首先查找路径中最后一个斜杠或反斜杠的索引,若未找到则直接返回路径;\r\n * 若找到,则使用substring方法提取最后一个斜杠或反斜杠后面的字符串作为文件名并返回。\r\n * @param path 文件路径\r\n * @returns 文件全名(包含扩展名)\r\n */\r\nexport function getFileFullName(path: string): string {\r\n let index = path.lastIndexOf(\"/\");\r\n if (index === -1) {\r\n index = path.lastIndexOf(\"\\\\\");\r\n if (index === -1) {\r\n return path;\r\n }\r\n }\r\n return path.substring(index + 1);\r\n}\r\n\r\n/**\r\n * 获取文件名不包含扩展名\r\n */\r\nexport function getFileNameWithoutExt(path: string): string {\r\n const fileName = getFileFullName(path);\r\n const index = fileName.lastIndexOf(\".\");\r\n if (index === -1) {\r\n return fileName;\r\n }\r\n return fileName.substring(0, index);\r\n}\r\n\r\n/**\r\n * 文件信息\r\n */\r\nexport interface IFileInfo {\r\n /** 文件名(包含扩展名) */\r\n fileName: string;\r\n /**\r\n * 文件名不带扩展名\r\n */\r\n fileNameNoExt: string;\r\n /** 文件扩展名 */\r\n fileExtName: string;\r\n /** 路径仅包含文件夹 */\r\n pathOnly: string;\r\n /** 完整路径 */\r\n fullPath: string;\r\n}\r\n\r\n/**\r\n * 获取文件信息\r\n * @param path 文件路径\r\n * @param platform 平台名称,默认为\"win32\"\r\n * @returns 包含文件名、文件名不带扩展名、文件扩展名、路径仅包含文件夹、完整路径的对象\r\n */\r\nexport function getFileInfo(\r\n path: string,\r\n platform: string = \"win32\"\r\n): IFileInfo {\r\n const pathSaprator = platform === \"win32\" ? \"\\\\\" : \"/\";\r\n\r\n let pathOnly: string;\r\n\r\n let fileName: string;\r\n let fileExtName: string;\r\n let fileNameNoExt: string;\r\n const pathIndex = path.lastIndexOf(pathSaprator);\r\n if (pathIndex === -1) {\r\n pathOnly = \"\";\r\n fileName = path;\r\n } else {\r\n pathOnly = path.substring(0, pathIndex + 1);\r\n fileName = path.substring(pathIndex + 1);\r\n }\r\n\r\n const extIndex = fileName.lastIndexOf(\".\");\r\n if (extIndex === -1) {\r\n fileExtName = \"\";\r\n fileNameNoExt = fileName;\r\n } else {\r\n fileExtName = fileName.substring(extIndex + 1);\r\n fileNameNoExt = fileName.substring(0, extIndex);\r\n }\r\n\r\n return {\r\n fileName,\r\n fileNameNoExt,\r\n fileExtName,\r\n fullPath: path,\r\n pathOnly,\r\n };\r\n}\r\n"],"names":["RecordClearMode","withRecord","obj","mode","key","newVal","assignRecords","arrays","_arrays","equal","localEqual","ll","rr","acc","crt","c","a","paths","l","r","path","stringTokenizer","regExp","matchHandler","textHandler","ifMatch","ifText","str","result","matches","index","match","before","equalsIgnoreCase","source","target","includeIgnoreCase","list","search","i","item","strLength","strMonospacePad","length","pad","visibleLength","getFileExt","fileName","getFileFullName","getFileNameWithoutExt","getFileInfo","platform","pathSaprator","pathOnly","fileExtName","fileNameNoExt","pathIndex","extIndex"],"mappings":"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"} \ No newline at end of file diff --git a/src/index.ts b/src/index.ts index 0e9f8fd..125c34d 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,29 +1,33 @@ import { - withRecord, - assignRecords, - RecordClearMode, + withRecord, + assignRecords, + RecordClearMode, } from "./commons/record-util"; import { - stringTokenizer, - equalsIgnoreCase, - includeIgnoreCase, + stringTokenizer, + equalsIgnoreCase, + includeIgnoreCase, + strLength, + strMonospacePad } from "./commons/str-utils"; import { - getFileExt, - getFileFullName, - getFileNameWithoutExt, - getFileInfo, + getFileExt, + getFileFullName, + getFileNameWithoutExt, + getFileInfo, } from "./commons/file-util"; export { - stringTokenizer, - withRecord, - equalsIgnoreCase, - includeIgnoreCase, - assignRecords, - RecordClearMode, - getFileExt, - getFileFullName as getFileName, - getFileNameWithoutExt, - getFileInfo, + stringTokenizer, + withRecord, + equalsIgnoreCase, + includeIgnoreCase, + assignRecords, + RecordClearMode, + getFileExt, + getFileFullName as getFileName, + getFileNameWithoutExt, + getFileInfo, + strLength, + strMonospacePad };