From d14fac052c79a92d4c8b8b9bfc3fb70ac5401c37 Mon Sep 17 00:00:00 2001 From: zhujingjing Date: Mon, 29 Jan 2024 00:10:57 +0800 Subject: [PATCH] build --- lib/index.d.ts | 3 +- lib/index.es.js | 126 ++++++++++++++++++++++++++-------------- lib/index.es.js.map | 2 +- lib/index.umd.js | 2 +- lib/index.umd.js.map | 2 +- src/commons/optional.ts | 80 +++++++++++++++++++++++++ src/index.ts | 50 ++++++++-------- 7 files changed, 193 insertions(+), 72 deletions(-) create mode 100644 src/commons/optional.ts diff --git a/lib/index.d.ts b/lib/index.d.ts index 17e0477..10fe937 100644 --- a/lib/index.d.ts +++ b/lib/index.d.ts @@ -1,4 +1,5 @@ import { withRecord, assignRecords, RecordClearMode } from "./commons/record-util"; 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, strLength, strMonospacePad }; +import { Optional } from "./commons/optional"; +export { Optional, RecordClearMode, assignRecords, equalsIgnoreCase, getFileExt, getFileFullName as getFileName, getFileInfo, getFileNameWithoutExt, includeIgnoreCase, strLength, strMonospacePad, stringTokenizer, withRecord, }; diff --git a/lib/index.es.js b/lib/index.es.js index d6040e6..52b370d 100644 --- a/lib/index.es.js +++ b/lib/index.es.js @@ -1,5 +1,5 @@ -var a = /* @__PURE__ */ ((e) => (e[e.delete = 2] = "delete", e[e.reset = 1] = "reset", e))(a || {}); -const d = (e) => ({ +var h = /* @__PURE__ */ ((e) => (e[e.delete = 2] = "delete", e[e.reset = 1] = "reset", e))(h || {}); +const m = (e) => ({ clear: function(t = 2) { t === 1 ? Object.keys(e).forEach((n) => { e[n] = void 0; @@ -14,51 +14,51 @@ const d = (e) => ({ ), Object.assign(e, t); } }); -function m(...e) { +function p(...e) { let t = e ?? []; return { test: function(n) { if (t.length <= 1) return t.length === 1 ? t[0] : []; - let i = n ?? function(s, r) { - return s === r; + let s = n ?? function(r, i) { + return r === i; }; - 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), []); + return t.reduce((r, i) => (i && i.length > 0 && (r.length === 0 ? r.push(...i) : i.forEach((f) => { + r.some((u) => s(u, f)) || r.push(f); + })), r), []); }, path: function(...n) { - return this.test((i, s) => n.every((r) => i[r] === s[r])); + return this.test((s, r) => n.every((i) => s[i] === r[i])); } }; } 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; + const s = t, r = n || t; + return function(i) { + const f = [], l = i.matchAll(e); + let u = 0; + for (const o of l) { + const g = i.slice(u, o.index); + g && f.push(r(g, !1)), f.push(s(o[0], !0)), u = o.index + o[0].length; } - return l < r.length && u.push(s(r.slice(l), !1)), u; + return u < i.length && f.push(r(i.slice(u), !1)), f; }; } -function g(e, t) { +function a(e, t) { return typeof e == "string" && typeof t == "string" ? e.toLowerCase() === t.toLowerCase() : e === void 0 && t === void 0; } const O = (e, t) => { for (let n = 0; n < e.length; n++) { - let i = e[n]; - if (g(i, t)) + let s = e[n]; + if (a(s, 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); +}, d = (e) => e.replaceAll(/[\u4e00-\u9fa5]/g, "--").length, E = (e, t, n = " ") => { + const s = t - (d(e) - e.length); + return e.padEnd(s, n); }; -function E(e) { +function b(e) { const t = e.lastIndexOf("."); return t === -1 ? "" : e.substring(t + 1); } @@ -66,36 +66,74 @@ function x(e) { let t = e.lastIndexOf("/"); return t === -1 && (t = e.lastIndexOf("\\"), t === -1) ? e : e.substring(t + 1); } -function b(e) { +function y(e) { const t = x(e), n = t.lastIndexOf("."); return n === -1 ? t : t.substring(0, n); } -function y(e, t = "win32") { +function N(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: r, + let s, r, i, f; + const l = e.lastIndexOf(n); + l === -1 ? (s = "", r = e) : (s = e.substring(0, l + 1), r = e.substring(l + 1)); + const u = r.lastIndexOf("."); + return u === -1 ? (i = "", f = r) : (i = r.substring(u + 1), f = r.substring(0, u)), { + fileName: r, + fileNameNoExt: f, + fileExtName: i, fullPath: e, - pathOnly: i + pathOnly: s }; } +const c = { + /** + * Creates an optional of the specified value. The value may be undefined or null. + * @return OptionalInstance + */ + of(e) { + function t(n) { + return n == null; + } + return { + get() { + return e; + }, + orElse(n) { + return t(e) ? n : e; + }, + then(n, s) { + t(e) ? s && s() : n(e); + }, + ifPresent(n) { + e != null && n(e); + }, + isPresent() { + return !t(e); + }, + filter(n) { + return t(e) || n(e) ? this : c.of(void 0); + }, + map(n) { + return e == null ? c.of(void 0) : c.of(n(e)); + }, + flatMap(n) { + return n(e); + } + }; + } +}; export { - a as RecordClearMode, - m as assignRecords, - g as equalsIgnoreCase, - E as getFileExt, - y as getFileInfo, + c as Optional, + h as RecordClearMode, + p as assignRecords, + a as equalsIgnoreCase, + b as getFileExt, + N as getFileInfo, x as getFileName, - b as getFileNameWithoutExt, + y as getFileNameWithoutExt, O as includeIgnoreCase, - h as strLength, - p as strMonospacePad, + d as strLength, + E as strMonospacePad, I as stringTokenizer, - d as withRecord + m as withRecord }; //# sourceMappingURL=index.es.js.map diff --git a/lib/index.es.js.map b/lib/index.es.js.map index 8cdb45f..186f4ac 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","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 +{"version":3,"file":"index.es.js","sources":["../src/commons/record-util.ts","../src/commons/str-utils.ts","../src/commons/file-util.ts","../src/commons/optional.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","/*\r\n * Copyright 2015,2016 DevCon5 GmbH, info@devcon5.io\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n *\r\n */\r\n\r\n/**\r\n * Optional monad for Javascript | Typescript.\r\n */\r\nexport const Optional = {\r\n /**\r\n * Creates an optional of the specified value. The value may be undefined or null.\r\n * @return OptionalInstance\r\n */\r\n of(value: T) {\r\n function notPresent(value: any): value is null {\r\n return value == null;\r\n }\r\n\r\n return {\r\n get() {\r\n return value;\r\n },\r\n orElse(elseValue: NonNullable): NonNullable {\r\n if (notPresent(value)) {\r\n return elseValue;\r\n }\r\n return value as NonNullable;\r\n },\r\n then(\r\n presentFunction: (value: T) => void,\r\n notPresentFunction?: () => void\r\n ) {\r\n if (!notPresent(value)) {\r\n presentFunction(value);\r\n } else if (notPresentFunction) {\r\n notPresentFunction();\r\n }\r\n },\r\n ifPresent(func: (val: NonNullable) => R) {\r\n if (value != null) {\r\n func(value);\r\n }\r\n },\r\n isPresent() {\r\n return !notPresent(value);\r\n },\r\n filter(filterFunction: (value: T) => boolean) {\r\n if (notPresent(value) || filterFunction(value)) {\r\n return this;\r\n } else {\r\n return Optional.of(undefined);\r\n }\r\n },\r\n map(mapperFunction: (value: NonNullable) => R) {\r\n if (value == null) {\r\n return Optional.of(undefined);\r\n } else {\r\n return Optional.of(mapperFunction(value));\r\n }\r\n },\r\n flatMap(mapperFunction: (value: T) => R) {\r\n return mapperFunction(value);\r\n },\r\n };\r\n },\r\n};\r\n\r\nexport default Optional;\r\n"],"names":["RecordClearMode","withRecord","obj","mode","key","newVal","assignRecords","arrays","_arrays","equal","localEqual","ll","rr","acc","crt","c","a","paths","l","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","Optional","value","notPresent","elseValue","presentFunction","notPresentFunction","func","filterFunction","mapperFunction"],"mappings":"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"} \ No newline at end of file diff --git a/lib/index.umd.js b/lib/index.umd.js index ca7b0ec..d405a91 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 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"})}); +(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 O=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 E(...e){let n=e??[];return{test:function(t){if(n.length<=1)return n.length===1?n[0]:[];let f=t??function(i,s){return i===s};return n.reduce((i,s)=>(s&&s.length>0&&(i.length===0?i.push(...s):s.forEach(u=>{i.some(l=>f(l,u))||i.push(u)})),i),[])},path:function(...t){return this.test((f,i)=>t.every(s=>f[s]===i[s]))}}}function b(e,n,t){const f=n,i=t||n;return function(s){const u=[],c=s.matchAll(e);let l=0;for(const d of c){const I=s.slice(l,d.index);I&&u.push(i(I,!1)),u.push(f(d[0],!0)),l=d.index+d[0].length}return l{for(let t=0;te.replaceAll(/[\u4e00-\u9fa5]/g,"--").length,y=(e,n,t=" ")=>{const f=n-(h(e)-e.length);return e.padEnd(f,t)};function p(e){const n=e.lastIndexOf(".");return n===-1?"":e.substring(n+1)}function m(e){let n=e.lastIndexOf("/");return n===-1&&(n=e.lastIndexOf("\\"),n===-1)?e:e.substring(n+1)}function F(e){const n=m(e),t=n.lastIndexOf(".");return t===-1?n:n.substring(0,t)}function N(e,n="win32"){const t=n==="win32"?"\\":"/";let f,i,s,u;const c=e.lastIndexOf(t);c===-1?(f="",i=e):(f=e.substring(0,c+1),i=e.substring(c+1));const l=i.lastIndexOf(".");return l===-1?(s="",u=i):(s=i.substring(l+1),u=i.substring(0,l)),{fileName:i,fileNameNoExt:u,fileExtName:s,fullPath:e,pathOnly:f}}const g={of(e){function n(t){return t==null}return{get(){return e},orElse(t){return n(e)?t:e},then(t,f){n(e)?f&&f():t(e)},ifPresent(t){e!=null&&t(e)},isPresent(){return!n(e)},filter(t){return n(e)||t(e)?this:g.of(void 0)},map(t){return e==null?g.of(void 0):g.of(t(e))},flatMap(t){return t(e)}}}};r.Optional=g,r.RecordClearMode=o,r.assignRecords=E,r.equalsIgnoreCase=a,r.getFileExt=p,r.getFileInfo=N,r.getFileName=m,r.getFileNameWithoutExt=F,r.includeIgnoreCase=x,r.strLength=h,r.strMonospacePad=y,r.stringTokenizer=b,r.withRecord=O,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 2d7a17b..7bf183f 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","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 +{"version":3,"file":"index.umd.js","sources":["../src/commons/record-util.ts","../src/commons/str-utils.ts","../src/commons/file-util.ts","../src/commons/optional.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","/*\r\n * Copyright 2015,2016 DevCon5 GmbH, info@devcon5.io\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n *\r\n */\r\n\r\n/**\r\n * Optional monad for Javascript | Typescript.\r\n */\r\nexport const Optional = {\r\n /**\r\n * Creates an optional of the specified value. The value may be undefined or null.\r\n * @return OptionalInstance\r\n */\r\n of(value: T) {\r\n function notPresent(value: any): value is null {\r\n return value == null;\r\n }\r\n\r\n return {\r\n get() {\r\n return value;\r\n },\r\n orElse(elseValue: NonNullable): NonNullable {\r\n if (notPresent(value)) {\r\n return elseValue;\r\n }\r\n return value as NonNullable;\r\n },\r\n then(\r\n presentFunction: (value: T) => void,\r\n notPresentFunction?: () => void\r\n ) {\r\n if (!notPresent(value)) {\r\n presentFunction(value);\r\n } else if (notPresentFunction) {\r\n notPresentFunction();\r\n }\r\n },\r\n ifPresent(func: (val: NonNullable) => R) {\r\n if (value != null) {\r\n func(value);\r\n }\r\n },\r\n isPresent() {\r\n return !notPresent(value);\r\n },\r\n filter(filterFunction: (value: T) => boolean) {\r\n if (notPresent(value) || filterFunction(value)) {\r\n return this;\r\n } else {\r\n return Optional.of(undefined);\r\n }\r\n },\r\n map(mapperFunction: (value: NonNullable) => R) {\r\n if (value == null) {\r\n return Optional.of(undefined);\r\n } else {\r\n return Optional.of(mapperFunction(value));\r\n }\r\n },\r\n flatMap(mapperFunction: (value: T) => R) {\r\n return mapperFunction(value);\r\n },\r\n };\r\n },\r\n};\r\n\r\nexport default Optional;\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","Optional","value","notPresent","elseValue","presentFunction","notPresentFunction","func","filterFunction","mapperFunction"],"mappings":"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"} \ No newline at end of file diff --git a/src/commons/optional.ts b/src/commons/optional.ts new file mode 100644 index 0000000..12b19d1 --- /dev/null +++ b/src/commons/optional.ts @@ -0,0 +1,80 @@ +/* + * Copyright 2015,2016 DevCon5 GmbH, info@devcon5.io + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ + +/** + * Optional monad for Javascript | Typescript. + */ +export const Optional = { + /** + * Creates an optional of the specified value. The value may be undefined or null. + * @return OptionalInstance + */ + of(value: T) { + function notPresent(value: any): value is null { + return value == null; + } + + return { + get() { + return value; + }, + orElse(elseValue: NonNullable): NonNullable { + if (notPresent(value)) { + return elseValue; + } + return value as NonNullable; + }, + then( + presentFunction: (value: T) => void, + notPresentFunction?: () => void + ) { + if (!notPresent(value)) { + presentFunction(value); + } else if (notPresentFunction) { + notPresentFunction(); + } + }, + ifPresent(func: (val: NonNullable) => R) { + if (value != null) { + func(value); + } + }, + isPresent() { + return !notPresent(value); + }, + filter(filterFunction: (value: T) => boolean) { + if (notPresent(value) || filterFunction(value)) { + return this; + } else { + return Optional.of(undefined); + } + }, + map(mapperFunction: (value: NonNullable) => R) { + if (value == null) { + return Optional.of(undefined); + } else { + return Optional.of(mapperFunction(value)); + } + }, + flatMap(mapperFunction: (value: T) => R) { + return mapperFunction(value); + }, + }; + }, +}; + +export default Optional; diff --git a/src/index.ts b/src/index.ts index 125c34d..fe484ae 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,33 +1,35 @@ import { - withRecord, - assignRecords, - RecordClearMode, + withRecord, + assignRecords, + RecordClearMode, } from "./commons/record-util"; import { - stringTokenizer, - equalsIgnoreCase, - includeIgnoreCase, - strLength, - strMonospacePad + stringTokenizer, + equalsIgnoreCase, + includeIgnoreCase, + strLength, + strMonospacePad, } from "./commons/str-utils"; import { - getFileExt, - getFileFullName, - getFileNameWithoutExt, - getFileInfo, + getFileExt, + getFileFullName, + getFileNameWithoutExt, + getFileInfo, } from "./commons/file-util"; +import { Optional } from "./commons/optional"; export { - stringTokenizer, - withRecord, - equalsIgnoreCase, - includeIgnoreCase, - assignRecords, - RecordClearMode, - getFileExt, - getFileFullName as getFileName, - getFileNameWithoutExt, - getFileInfo, - strLength, - strMonospacePad + Optional, + RecordClearMode, + assignRecords, + equalsIgnoreCase, + getFileExt, + getFileFullName as getFileName, + getFileInfo, + getFileNameWithoutExt, + includeIgnoreCase, + strLength, + strMonospacePad, + stringTokenizer, + withRecord, };