@alibarbar/common 1.0.9 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{chunk-O3O67R4I.js → algorithm.cjs} +1 -3
- package/dist/algorithm.js +130 -44
- package/dist/{chunk-LOAZSPGQ.js → array.cjs} +1 -3
- package/dist/array.js +135 -84
- package/dist/{chunk-Y364QIQH.js → color.cjs} +1 -3
- package/dist/color.js +127 -40
- package/dist/{chunk-DYBSRI7V.js → crypto.cjs} +109 -3
- package/dist/crypto.d.mts +48 -1
- package/dist/crypto.d.ts +48 -1
- package/dist/crypto.js +274 -60
- package/dist/{chunk-BHCRFURU.js → data-structure.cjs} +1 -3
- package/dist/data-structure.js +481 -32
- package/dist/{chunk-I3L42475.js → date.cjs} +1 -3
- package/dist/date.js +125 -72
- package/dist/{chunk-JK2SE3I2.js → dom.cjs} +1 -3
- package/dist/dom.js +84 -56
- package/dist/{chunk-7V5UQXIO.js → file.cjs} +1 -3
- package/dist/file.js +79 -32
- package/dist/{chunk-OX5PLOWB.js → i18n.cjs} +1 -3
- package/dist/i18n.js +78 -40
- package/dist/index.cjs +4543 -0
- package/dist/index.d.mts +6 -162
- package/dist/index.d.ts +6 -162
- package/dist/index.js +3712 -17374
- package/dist/{chunk-4RGXV4SJ.js → network.cjs} +1 -3
- package/dist/network.js +97 -28
- package/dist/{chunk-3FRYJPHG.js → number.cjs} +1 -3
- package/dist/number.js +77 -56
- package/dist/{chunk-27UDDVLZ.js → object.cjs} +1 -3
- package/dist/object.js +237 -80
- package/dist/{chunk-JQZBPAPO.js → performance.cjs} +1 -3
- package/dist/performance.js +145 -40
- package/dist/services.cjs +291 -0
- package/dist/services.d.mts +161 -0
- package/dist/services.d.ts +161 -0
- package/dist/services.js +281 -0
- package/dist/storage.cjs +943 -0
- package/dist/storage.d.mts +46 -1
- package/dist/storage.d.ts +46 -1
- package/dist/storage.js +930 -32
- package/dist/{chunk-D7CS5EKF.js → string.cjs} +1 -3
- package/dist/string.js +91 -68
- package/dist/{chunk-56W6YECK.js → tracking.cjs} +1 -3
- package/dist/tracking.js +359 -52
- package/dist/{chunk-ZDMFMUDR.js → transform.cjs} +1 -3
- package/dist/transform.js +299 -32
- package/dist/{chunk-NJARVI6X.mjs → upload.cjs} +42 -15
- package/dist/upload.d.mts +1 -1
- package/dist/upload.d.ts +1 -1
- package/dist/upload.js +402 -20
- package/dist/{chunk-KGFTD255.js → url.cjs} +1 -3
- package/dist/url.js +91 -44
- package/dist/{chunk-TQN37HIN.js → validation.cjs} +1 -3
- package/dist/validation.js +77 -60
- package/package.json +7 -2
- package/dist/algorithm.js.map +0 -1
- package/dist/algorithm.mjs +0 -4
- package/dist/algorithm.mjs.map +0 -1
- package/dist/array.js.map +0 -1
- package/dist/array.mjs +0 -4
- package/dist/array.mjs.map +0 -1
- package/dist/chunk-27UDDVLZ.js.map +0 -1
- package/dist/chunk-2R2QWFJC.mjs +0 -138
- package/dist/chunk-2R2QWFJC.mjs.map +0 -1
- package/dist/chunk-3FRYJPHG.js.map +0 -1
- package/dist/chunk-4RGXV4SJ.js.map +0 -1
- package/dist/chunk-56W6YECK.js.map +0 -1
- package/dist/chunk-5BGSUGTI.mjs +0 -128
- package/dist/chunk-5BGSUGTI.mjs.map +0 -1
- package/dist/chunk-7E6GELHJ.mjs +0 -302
- package/dist/chunk-7E6GELHJ.mjs.map +0 -1
- package/dist/chunk-7V5UQXIO.js.map +0 -1
- package/dist/chunk-A4SWQXX7.mjs +0 -484
- package/dist/chunk-A4SWQXX7.mjs.map +0 -1
- package/dist/chunk-BHCRFURU.js.map +0 -1
- package/dist/chunk-CDSGEAOK.mjs +0 -80
- package/dist/chunk-CDSGEAOK.mjs.map +0 -1
- package/dist/chunk-D7CS5EKF.js.map +0 -1
- package/dist/chunk-DYBSRI7V.js.map +0 -1
- package/dist/chunk-FEBKPX5A.js +0 -386
- package/dist/chunk-FEBKPX5A.js.map +0 -1
- package/dist/chunk-FJ6ZGZIA.mjs +0 -39
- package/dist/chunk-FJ6ZGZIA.mjs.map +0 -1
- package/dist/chunk-HLDFI7R2.mjs +0 -175
- package/dist/chunk-HLDFI7R2.mjs.map +0 -1
- package/dist/chunk-I3L42475.js.map +0 -1
- package/dist/chunk-JBLX27WD.mjs +0 -240
- package/dist/chunk-JBLX27WD.mjs.map +0 -1
- package/dist/chunk-JHZ7M2MR.mjs +0 -133
- package/dist/chunk-JHZ7M2MR.mjs.map +0 -1
- package/dist/chunk-JK2SE3I2.js.map +0 -1
- package/dist/chunk-JQZBPAPO.js.map +0 -1
- package/dist/chunk-JXYGC2C5.mjs +0 -100
- package/dist/chunk-JXYGC2C5.mjs.map +0 -1
- package/dist/chunk-KGFTD255.js.map +0 -1
- package/dist/chunk-LBHBNPNJ.mjs +0 -148
- package/dist/chunk-LBHBNPNJ.mjs.map +0 -1
- package/dist/chunk-LF4CILQS.mjs +0 -87
- package/dist/chunk-LF4CILQS.mjs.map +0 -1
- package/dist/chunk-LOAZSPGQ.js.map +0 -1
- package/dist/chunk-NJARVI6X.mjs.map +0 -1
- package/dist/chunk-NSSDYX2U.mjs +0 -80
- package/dist/chunk-NSSDYX2U.mjs.map +0 -1
- package/dist/chunk-O3O67R4I.js.map +0 -1
- package/dist/chunk-OIXQ3E6W.mjs +0 -354
- package/dist/chunk-OIXQ3E6W.mjs.map +0 -1
- package/dist/chunk-OX5PLOWB.js.map +0 -1
- package/dist/chunk-PJ7UCTX4.mjs +0 -362
- package/dist/chunk-PJ7UCTX4.mjs.map +0 -1
- package/dist/chunk-PR4QN5HX.js +0 -44
- package/dist/chunk-PR4QN5HX.js.map +0 -1
- package/dist/chunk-QIBE7GVN.mjs +0 -81
- package/dist/chunk-QIBE7GVN.mjs.map +0 -1
- package/dist/chunk-QIOC54LQ.mjs +0 -130
- package/dist/chunk-QIOC54LQ.mjs.map +0 -1
- package/dist/chunk-TQN37HIN.js.map +0 -1
- package/dist/chunk-WZDOPUJW.js +0 -361
- package/dist/chunk-WZDOPUJW.js.map +0 -1
- package/dist/chunk-XJTZDXSR.mjs +0 -94
- package/dist/chunk-XJTZDXSR.mjs.map +0 -1
- package/dist/chunk-Y364QIQH.js.map +0 -1
- package/dist/chunk-YXM6Q4JS.mjs +0 -94
- package/dist/chunk-YXM6Q4JS.mjs.map +0 -1
- package/dist/chunk-ZDMFMUDR.js.map +0 -1
- package/dist/chunk-ZVJ6NQUM.mjs +0 -82
- package/dist/chunk-ZVJ6NQUM.mjs.map +0 -1
- package/dist/color.js.map +0 -1
- package/dist/color.mjs +0 -4
- package/dist/color.mjs.map +0 -1
- package/dist/crypto.js.map +0 -1
- package/dist/crypto.mjs +0 -4
- package/dist/crypto.mjs.map +0 -1
- package/dist/data-structure.js.map +0 -1
- package/dist/data-structure.mjs +0 -4
- package/dist/data-structure.mjs.map +0 -1
- package/dist/date.js.map +0 -1
- package/dist/date.mjs +0 -4
- package/dist/date.mjs.map +0 -1
- package/dist/dom.js.map +0 -1
- package/dist/dom.mjs +0 -4
- package/dist/dom.mjs.map +0 -1
- package/dist/file.js.map +0 -1
- package/dist/file.mjs +0 -4
- package/dist/file.mjs.map +0 -1
- package/dist/i18n.js.map +0 -1
- package/dist/i18n.mjs +0 -4
- package/dist/i18n.mjs.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/index.mjs +0 -17155
- package/dist/index.mjs.map +0 -1
- package/dist/network.js.map +0 -1
- package/dist/network.mjs +0 -4
- package/dist/network.mjs.map +0 -1
- package/dist/number.js.map +0 -1
- package/dist/number.mjs +0 -4
- package/dist/number.mjs.map +0 -1
- package/dist/object.js.map +0 -1
- package/dist/object.mjs +0 -4
- package/dist/object.mjs.map +0 -1
- package/dist/performance.js.map +0 -1
- package/dist/performance.mjs +0 -4
- package/dist/performance.mjs.map +0 -1
- package/dist/storage.js.map +0 -1
- package/dist/storage.mjs +0 -5
- package/dist/storage.mjs.map +0 -1
- package/dist/string.js.map +0 -1
- package/dist/string.mjs +0 -4
- package/dist/string.mjs.map +0 -1
- package/dist/tracking.js.map +0 -1
- package/dist/tracking.mjs +0 -4
- package/dist/tracking.mjs.map +0 -1
- package/dist/transform.js.map +0 -1
- package/dist/transform.mjs +0 -4
- package/dist/transform.mjs.map +0 -1
- package/dist/upload.js.map +0 -1
- package/dist/upload.mjs +0 -5
- package/dist/upload.mjs.map +0 -1
- package/dist/url.js.map +0 -1
- package/dist/url.mjs +0 -4
- package/dist/url.mjs.map +0 -1
- package/dist/validation.js.map +0 -1
- package/dist/validation.mjs +0 -4
- package/dist/validation.mjs.map +0 -1
- /package/dist/{upload-DchqyDBQ.d.mts → index-DchqyDBQ.d.mts} +0 -0
- /package/dist/{upload-DchqyDBQ.d.ts → index-DchqyDBQ.d.ts} +0 -0
package/dist/chunk-NSSDYX2U.mjs
DELETED
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
// src/core/validation.ts
|
|
2
|
-
function isValidEmail(email) {
|
|
3
|
-
const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
|
|
4
|
-
return emailRegex.test(email);
|
|
5
|
-
}
|
|
6
|
-
function isValidPhone(phone) {
|
|
7
|
-
const phoneRegex = /^1[3-9]\d{9}$/;
|
|
8
|
-
return phoneRegex.test(phone);
|
|
9
|
-
}
|
|
10
|
-
function isValidUrl(url) {
|
|
11
|
-
try {
|
|
12
|
-
new URL(url);
|
|
13
|
-
return true;
|
|
14
|
-
} catch {
|
|
15
|
-
return false;
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
function isValidIdCard(idCard) {
|
|
19
|
-
const idCardRegex = /^[1-9]\d{5}(18|19|20)\d{2}(0[1-9]|1[0-2])(0[1-9]|[12]\d|3[01])\d{3}[\dXx]$/;
|
|
20
|
-
return idCardRegex.test(idCard);
|
|
21
|
-
}
|
|
22
|
-
function isEmpty(value) {
|
|
23
|
-
if (value === null || value === void 0) return true;
|
|
24
|
-
if (typeof value === "string") return value.trim().length === 0;
|
|
25
|
-
if (Array.isArray(value)) return value.length === 0;
|
|
26
|
-
if (typeof value === "object") return Object.keys(value).length === 0;
|
|
27
|
-
return false;
|
|
28
|
-
}
|
|
29
|
-
function isValidUUID(uuid) {
|
|
30
|
-
const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;
|
|
31
|
-
return uuidRegex.test(uuid);
|
|
32
|
-
}
|
|
33
|
-
function isValidIP(ip) {
|
|
34
|
-
const ipRegex = /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;
|
|
35
|
-
return ipRegex.test(ip);
|
|
36
|
-
}
|
|
37
|
-
function isValidDomain(domain) {
|
|
38
|
-
const domainRegex = /^([a-z0-9]+(-[a-z0-9]+)*\.)+[a-z]{2,}$/i;
|
|
39
|
-
return domainRegex.test(domain);
|
|
40
|
-
}
|
|
41
|
-
function isValidHexColor(color) {
|
|
42
|
-
const hexColorRegex = /^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/;
|
|
43
|
-
return hexColorRegex.test(color);
|
|
44
|
-
}
|
|
45
|
-
function isValidJSON(json) {
|
|
46
|
-
try {
|
|
47
|
-
JSON.parse(json);
|
|
48
|
-
return true;
|
|
49
|
-
} catch {
|
|
50
|
-
return false;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
function isNumeric(value) {
|
|
54
|
-
if (typeof value === "number") return !isNaN(value) && isFinite(value);
|
|
55
|
-
if (typeof value === "string") {
|
|
56
|
-
return value.trim() !== "" && !isNaN(Number(value)) && isFinite(Number(value));
|
|
57
|
-
}
|
|
58
|
-
return false;
|
|
59
|
-
}
|
|
60
|
-
function isInteger(value) {
|
|
61
|
-
if (typeof value === "number") return Number.isInteger(value);
|
|
62
|
-
if (typeof value === "string") {
|
|
63
|
-
const num = Number(value);
|
|
64
|
-
return !isNaN(num) && Number.isInteger(num);
|
|
65
|
-
}
|
|
66
|
-
return false;
|
|
67
|
-
}
|
|
68
|
-
function isFloat(value) {
|
|
69
|
-
if (typeof value === "number")
|
|
70
|
-
return !isNaN(value) && isFinite(value) && !Number.isInteger(value);
|
|
71
|
-
if (typeof value === "string") {
|
|
72
|
-
const num = Number(value);
|
|
73
|
-
return !isNaN(num) && isFinite(num) && !Number.isInteger(num);
|
|
74
|
-
}
|
|
75
|
-
return false;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
export { isEmpty, isFloat, isInteger, isNumeric, isValidDomain, isValidEmail, isValidHexColor, isValidIP, isValidIdCard, isValidJSON, isValidPhone, isValidUUID, isValidUrl };
|
|
79
|
-
//# sourceMappingURL=chunk-NSSDYX2U.mjs.map
|
|
80
|
-
//# sourceMappingURL=chunk-NSSDYX2U.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/core/validation.ts"],"names":[],"mappings":"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","file":"chunk-NSSDYX2U.mjs","sourcesContent":["/**\n * 验证工具函数\n */\n\n/**\n * 验证邮箱格式\n * @param email - 邮箱地址\n * @returns 是否为有效邮箱\n */\nexport function isValidEmail(email: string): boolean {\n const emailRegex = /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/;\n return emailRegex.test(email);\n}\n\n/**\n * 验证手机号格式(中国大陆)\n * @param phone - 手机号\n * @returns 是否为有效手机号\n */\nexport function isValidPhone(phone: string): boolean {\n const phoneRegex = /^1[3-9]\\d{9}$/;\n return phoneRegex.test(phone);\n}\n\n/**\n * 验证URL格式\n * @param url - URL地址\n * @returns 是否为有效URL\n */\nexport function isValidUrl(url: string): boolean {\n try {\n new URL(url);\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * 验证身份证号格式(中国大陆18位)\n * @param idCard - 身份证号\n * @returns 是否为有效身份证号\n */\nexport function isValidIdCard(idCard: string): boolean {\n const idCardRegex = /^[1-9]\\d{5}(18|19|20)\\d{2}(0[1-9]|1[0-2])(0[1-9]|[12]\\d|3[01])\\d{3}[\\dXx]$/;\n return idCardRegex.test(idCard);\n}\n\n/**\n * 验证是否为空值\n * @param value - 待验证的值\n * @returns 是否为空\n */\nexport function isEmpty(value: unknown): boolean {\n if (value === null || value === undefined) return true;\n if (typeof value === 'string') return value.trim().length === 0;\n if (Array.isArray(value)) return value.length === 0;\n if (typeof value === 'object') return Object.keys(value).length === 0;\n return false;\n}\n\n/**\n * 验证UUID格式\n * @param uuid - UUID字符串\n * @returns 是否为有效UUID\n */\nexport function isValidUUID(uuid: string): boolean {\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\n return uuidRegex.test(uuid);\n}\n\n/**\n * 验证IP地址格式(IPv4)\n * @param ip - IP地址\n * @returns 是否为有效IP地址\n */\nexport function isValidIP(ip: string): boolean {\n const ipRegex =\n /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;\n return ipRegex.test(ip);\n}\n\n/**\n * 验证域名格式\n * @param domain - 域名\n * @returns 是否为有效域名\n */\nexport function isValidDomain(domain: string): boolean {\n const domainRegex = /^([a-z0-9]+(-[a-z0-9]+)*\\.)+[a-z]{2,}$/i;\n return domainRegex.test(domain);\n}\n\n/**\n * 验证十六进制颜色格式\n * @param color - 颜色值\n * @returns 是否为有效十六进制颜色\n */\nexport function isValidHexColor(color: string): boolean {\n const hexColorRegex = /^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/;\n return hexColorRegex.test(color);\n}\n\n/**\n * 验证JSON字符串格式\n * @param json - JSON字符串\n * @returns 是否为有效JSON\n */\nexport function isValidJSON(json: string): boolean {\n try {\n JSON.parse(json);\n return true;\n } catch {\n return false;\n }\n}\n\n/**\n * 验证是否为数字\n * @param value - 待验证的值\n * @returns 是否为数字\n */\nexport function isNumeric(value: unknown): boolean {\n if (typeof value === 'number') return !isNaN(value) && isFinite(value);\n if (typeof value === 'string') {\n return value.trim() !== '' && !isNaN(Number(value)) && isFinite(Number(value));\n }\n return false;\n}\n\n/**\n * 验证是否为整数\n * @param value - 待验证的值\n * @returns 是否为整数\n */\nexport function isInteger(value: unknown): boolean {\n if (typeof value === 'number') return Number.isInteger(value);\n if (typeof value === 'string') {\n const num = Number(value);\n return !isNaN(num) && Number.isInteger(num);\n }\n return false;\n}\n\n/**\n * 验证是否为浮点数\n * @param value - 待验证的值\n * @returns 是否为浮点数\n */\nexport function isFloat(value: unknown): boolean {\n if (typeof value === 'number')\n return !isNaN(value) && isFinite(value) && !Number.isInteger(value);\n if (typeof value === 'string') {\n const num = Number(value);\n return !isNaN(num) && isFinite(num) && !Number.isInteger(num);\n }\n return false;\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/data/algorithm.ts"],"names":[],"mappings":"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","file":"chunk-O3O67R4I.js","sourcesContent":["/**\n * 算法工具函数\n */\n\n/**\n * 二分查找\n * @param array - 已排序的数组\n * @param target - 目标值\n * @param compareFn - 比较函数(可选)\n * @returns 目标值的索引,如果未找到返回 -1\n */\nexport function binarySearch<T>(array: T[], target: T, compareFn?: (a: T, b: T) => number): number {\n let left = 0;\n let right = array.length - 1;\n\n const compare = compareFn || ((a: T, b: T) => (a < b ? -1 : a > b ? 1 : 0));\n\n while (left <= right) {\n const mid = Math.floor((left + right) / 2);\n const comparison = compare(array[mid], target);\n\n if (comparison === 0) {\n return mid;\n } else if (comparison < 0) {\n left = mid + 1;\n } else {\n right = mid - 1;\n }\n }\n\n return -1;\n}\n\n/**\n * 快速排序\n * @param array - 要排序的数组\n * @param compareFn - 比较函数(可选)\n * @returns 排序后的新数组\n */\nexport function quickSort<T>(array: T[], compareFn?: (a: T, b: T) => number): T[] {\n if (array.length <= 1) {\n return [...array];\n }\n\n const compare = compareFn || ((a: T, b: T) => (a < b ? -1 : a > b ? 1 : 0));\n const pivot = array[Math.floor(array.length / 2)];\n const left: T[] = [];\n const right: T[] = [];\n const equal: T[] = [];\n\n for (const item of array) {\n const comparison = compare(item, pivot);\n if (comparison < 0) {\n left.push(item);\n } else if (comparison > 0) {\n right.push(item);\n } else {\n equal.push(item);\n }\n }\n\n return [...quickSort(left, compareFn), ...equal, ...quickSort(right, compareFn)];\n}\n\n/**\n * 归并排序\n * @param array - 要排序的数组\n * @param compareFn - 比较函数(可选)\n * @returns 排序后的新数组\n */\nexport function mergeSort<T>(array: T[], compareFn?: (a: T, b: T) => number): T[] {\n if (array.length <= 1) {\n return [...array];\n }\n\n const compare = compareFn || ((a: T, b: T) => (a < b ? -1 : a > b ? 1 : 0));\n const mid = Math.floor(array.length / 2);\n const left = mergeSort(array.slice(0, mid), compareFn);\n const right = mergeSort(array.slice(mid), compareFn);\n\n return merge(left, right, compare);\n}\n\n/**\n * 合并两个已排序的数组\n */\nfunction merge<T>(left: T[], right: T[], compareFn: (a: T, b: T) => number): T[] {\n const result: T[] = [];\n let i = 0;\n let j = 0;\n\n while (i < left.length && j < right.length) {\n if (compareFn(left[i], right[j]) <= 0) {\n result.push(left[i]);\n i++;\n } else {\n result.push(right[j]);\n j++;\n }\n }\n\n return result.concat(left.slice(i)).concat(right.slice(j));\n}\n\n/**\n * 冒泡排序\n * @param array - 要排序的数组\n * @param compareFn - 比较函数(可选)\n * @returns 排序后的新数组\n */\nexport function bubbleSort<T>(array: T[], compareFn?: (a: T, b: T) => number): T[] {\n const result = [...array];\n const compare = compareFn || ((a: T, b: T) => (a < b ? -1 : a > b ? 1 : 0));\n const n = result.length;\n\n for (let i = 0; i < n - 1; i++) {\n let swapped = false;\n\n for (let j = 0; j < n - i - 1; j++) {\n if (compare(result[j], result[j + 1]) > 0) {\n [result[j], result[j + 1]] = [result[j + 1], result[j]];\n swapped = true;\n }\n }\n\n // 如果没有交换,说明已经排序完成\n if (!swapped) {\n break;\n }\n }\n\n return result;\n}\n\n/**\n * 计算斐波那契数列的第n项\n * @param n - 位置(从0开始)\n * @returns 斐波那契数\n */\nexport function fibonacci(n: number): number {\n if (n < 0) {\n throw new Error('n must be non-negative');\n }\n\n if (n === 0) return 0;\n if (n === 1) return 1;\n\n // 使用动态规划优化\n let a = 0;\n let b = 1;\n\n for (let i = 2; i <= n; i++) {\n [a, b] = [b, a + b];\n }\n\n return b;\n}\n\n/**\n * 计算斐波那契数列(返回前n项)\n * @param n - 项数\n * @returns 斐波那契数列数组\n */\nexport function fibonacciSequence(n: number): number[] {\n if (n <= 0) return [];\n if (n === 1) return [0];\n if (n === 2) return [0, 1];\n\n const sequence = [0, 1];\n for (let i = 2; i < n; i++) {\n sequence.push(sequence[i - 1] + sequence[i - 2]);\n }\n\n return sequence;\n}\n\n/**\n * 计算阶乘\n * @param n - 非负整数\n * @returns 阶乘结果\n */\nexport function factorial(n: number): number {\n if (n < 0) {\n throw new Error('n must be non-negative');\n }\n\n if (n === 0 || n === 1) {\n return 1;\n }\n\n let result = 1;\n for (let i = 2; i <= n; i++) {\n result *= i;\n }\n\n return result;\n}\n\n/**\n * 计算最大公约数(GCD)\n * @param a - 第一个数\n * @param b - 第二个数\n * @returns 最大公约数\n */\nexport function gcd(a: number, b: number): number {\n a = Math.abs(a);\n b = Math.abs(b);\n\n while (b !== 0) {\n [a, b] = [b, a % b];\n }\n\n return a;\n}\n\n/**\n * 计算最小公倍数(LCM)\n * @param a - 第一个数\n * @param b - 第二个数\n * @returns 最小公倍数\n */\nexport function lcm(a: number, b: number): number {\n return Math.abs(a * b) / gcd(a, b);\n}\n"]}
|
package/dist/chunk-OIXQ3E6W.mjs
DELETED
|
@@ -1,354 +0,0 @@
|
|
|
1
|
-
import { rsaDecrypt, rsaEncrypt } from './chunk-HLDFI7R2.mjs';
|
|
2
|
-
|
|
3
|
-
// src/browser/storage.ts
|
|
4
|
-
var globalKeyPair = null;
|
|
5
|
-
function setStorageKeyPair(keyPair) {
|
|
6
|
-
globalKeyPair = keyPair;
|
|
7
|
-
}
|
|
8
|
-
function getStorageKeyPair() {
|
|
9
|
-
return globalKeyPair;
|
|
10
|
-
}
|
|
11
|
-
async function encryptValue(value, publicKey) {
|
|
12
|
-
return rsaEncrypt(value, publicKey);
|
|
13
|
-
}
|
|
14
|
-
async function decryptValue(encryptedValue, privateKey) {
|
|
15
|
-
try {
|
|
16
|
-
return await rsaDecrypt(encryptedValue, privateKey);
|
|
17
|
-
} catch {
|
|
18
|
-
try {
|
|
19
|
-
JSON.parse(encryptedValue);
|
|
20
|
-
return encryptedValue;
|
|
21
|
-
} catch {
|
|
22
|
-
throw new Error("Failed to decrypt storage value");
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
var localStorage = {
|
|
27
|
-
/**
|
|
28
|
-
* 设置值
|
|
29
|
-
* @param key - 键
|
|
30
|
-
* @param value - 值
|
|
31
|
-
* @param options - 选项(过期时间、密钥等)
|
|
32
|
-
* @returns Promise<void>
|
|
33
|
-
*/
|
|
34
|
-
async set(key, value, options = {}) {
|
|
35
|
-
if (typeof window === "undefined" || !window.localStorage) {
|
|
36
|
-
throw new Error("localStorage is not available");
|
|
37
|
-
}
|
|
38
|
-
const { expiry, publicKey } = options;
|
|
39
|
-
const item = {
|
|
40
|
-
value,
|
|
41
|
-
expiry: expiry ? Date.now() + expiry : void 0
|
|
42
|
-
};
|
|
43
|
-
try {
|
|
44
|
-
const jsonStr = JSON.stringify(item);
|
|
45
|
-
const keyToUse = publicKey || globalKeyPair?.publicKey;
|
|
46
|
-
if (keyToUse) {
|
|
47
|
-
const encrypted = await encryptValue(jsonStr, keyToUse);
|
|
48
|
-
window.localStorage.setItem(key, encrypted);
|
|
49
|
-
} else {
|
|
50
|
-
const { base64Encode } = await import('./crypto.mjs');
|
|
51
|
-
const encoded = base64Encode(jsonStr);
|
|
52
|
-
window.localStorage.setItem(key, encoded);
|
|
53
|
-
}
|
|
54
|
-
} catch (error) {
|
|
55
|
-
console.error("localStorage.set error:", error);
|
|
56
|
-
throw error;
|
|
57
|
-
}
|
|
58
|
-
},
|
|
59
|
-
/**
|
|
60
|
-
* 获取值
|
|
61
|
-
* @param key - 键
|
|
62
|
-
* @param options - 选项(默认值、私钥等)
|
|
63
|
-
* @returns Promise<T | undefined> 值或默认值
|
|
64
|
-
*/
|
|
65
|
-
async get(key, options = {}) {
|
|
66
|
-
if (typeof window === "undefined" || !window.localStorage) {
|
|
67
|
-
return options.defaultValue;
|
|
68
|
-
}
|
|
69
|
-
const { defaultValue, privateKey } = options;
|
|
70
|
-
try {
|
|
71
|
-
const encryptedStr = window.localStorage.getItem(key);
|
|
72
|
-
if (!encryptedStr) return defaultValue;
|
|
73
|
-
let decryptedStr;
|
|
74
|
-
const keyToUse = privateKey || globalKeyPair?.privateKey;
|
|
75
|
-
if (keyToUse) {
|
|
76
|
-
try {
|
|
77
|
-
decryptedStr = await decryptValue(encryptedStr, keyToUse);
|
|
78
|
-
} catch {
|
|
79
|
-
const { base64Decode } = await import('./crypto.mjs');
|
|
80
|
-
try {
|
|
81
|
-
decryptedStr = base64Decode(encryptedStr);
|
|
82
|
-
} catch {
|
|
83
|
-
return defaultValue;
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
} else {
|
|
87
|
-
const { base64Decode } = await import('./crypto.mjs');
|
|
88
|
-
try {
|
|
89
|
-
decryptedStr = base64Decode(encryptedStr);
|
|
90
|
-
} catch {
|
|
91
|
-
return defaultValue;
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
const item = JSON.parse(decryptedStr);
|
|
95
|
-
if (item.expiry && Date.now() > item.expiry) {
|
|
96
|
-
window.localStorage.removeItem(key);
|
|
97
|
-
return defaultValue;
|
|
98
|
-
}
|
|
99
|
-
return item.value;
|
|
100
|
-
} catch {
|
|
101
|
-
return defaultValue;
|
|
102
|
-
}
|
|
103
|
-
},
|
|
104
|
-
/**
|
|
105
|
-
* 移除值
|
|
106
|
-
* @param key - 键
|
|
107
|
-
*/
|
|
108
|
-
remove(key) {
|
|
109
|
-
if (typeof window === "undefined" || !window.localStorage) return;
|
|
110
|
-
try {
|
|
111
|
-
window.localStorage.removeItem(key);
|
|
112
|
-
} catch (error) {
|
|
113
|
-
console.error("localStorage.remove error:", error);
|
|
114
|
-
}
|
|
115
|
-
},
|
|
116
|
-
/**
|
|
117
|
-
* 清空所有值
|
|
118
|
-
*/
|
|
119
|
-
clear() {
|
|
120
|
-
if (typeof window === "undefined" || !window.localStorage) return;
|
|
121
|
-
try {
|
|
122
|
-
window.localStorage.clear();
|
|
123
|
-
} catch (error) {
|
|
124
|
-
console.error("localStorage.clear error:", error);
|
|
125
|
-
}
|
|
126
|
-
},
|
|
127
|
-
/**
|
|
128
|
-
* 获取所有键
|
|
129
|
-
* @returns 键数组
|
|
130
|
-
*/
|
|
131
|
-
keys() {
|
|
132
|
-
if (typeof window === "undefined" || !window.localStorage) return [];
|
|
133
|
-
const keys = [];
|
|
134
|
-
try {
|
|
135
|
-
for (let i = 0; i < window.localStorage.length; i++) {
|
|
136
|
-
const key = window.localStorage.key(i);
|
|
137
|
-
if (key) keys.push(key);
|
|
138
|
-
}
|
|
139
|
-
} catch (error) {
|
|
140
|
-
console.error("localStorage.keys error:", error);
|
|
141
|
-
}
|
|
142
|
-
return keys;
|
|
143
|
-
}
|
|
144
|
-
};
|
|
145
|
-
var sessionStorage = {
|
|
146
|
-
/**
|
|
147
|
-
* 设置值
|
|
148
|
-
* @param key - 键
|
|
149
|
-
* @param value - 值
|
|
150
|
-
* @param options - 选项(公钥等)
|
|
151
|
-
* @returns Promise<void>
|
|
152
|
-
*/
|
|
153
|
-
async set(key, value, options = {}) {
|
|
154
|
-
if (typeof window === "undefined" || !window.sessionStorage) {
|
|
155
|
-
throw new Error("sessionStorage is not available");
|
|
156
|
-
}
|
|
157
|
-
const { publicKey } = options;
|
|
158
|
-
try {
|
|
159
|
-
const jsonStr = JSON.stringify(value);
|
|
160
|
-
const keyToUse = publicKey || globalKeyPair?.publicKey;
|
|
161
|
-
if (keyToUse) {
|
|
162
|
-
const encrypted = await encryptValue(jsonStr, keyToUse);
|
|
163
|
-
window.sessionStorage.setItem(key, encrypted);
|
|
164
|
-
} else {
|
|
165
|
-
const { base64Encode } = await import('./crypto.mjs');
|
|
166
|
-
const encoded = base64Encode(jsonStr);
|
|
167
|
-
window.sessionStorage.setItem(key, encoded);
|
|
168
|
-
}
|
|
169
|
-
} catch (error) {
|
|
170
|
-
console.error("sessionStorage.set error:", error);
|
|
171
|
-
throw error;
|
|
172
|
-
}
|
|
173
|
-
},
|
|
174
|
-
/**
|
|
175
|
-
* 获取值
|
|
176
|
-
* @param key - 键
|
|
177
|
-
* @param options - 选项(默认值、私钥等)
|
|
178
|
-
* @returns Promise<T | undefined> 值或默认值
|
|
179
|
-
*/
|
|
180
|
-
async get(key, options = {}) {
|
|
181
|
-
if (typeof window === "undefined" || !window.sessionStorage) {
|
|
182
|
-
return options.defaultValue;
|
|
183
|
-
}
|
|
184
|
-
const { defaultValue, privateKey } = options;
|
|
185
|
-
try {
|
|
186
|
-
const encryptedStr = window.sessionStorage.getItem(key);
|
|
187
|
-
if (!encryptedStr) return defaultValue;
|
|
188
|
-
let decryptedStr;
|
|
189
|
-
const keyToUse = privateKey || globalKeyPair?.privateKey;
|
|
190
|
-
if (keyToUse) {
|
|
191
|
-
try {
|
|
192
|
-
decryptedStr = await decryptValue(encryptedStr, keyToUse);
|
|
193
|
-
} catch {
|
|
194
|
-
const { base64Decode } = await import('./crypto.mjs');
|
|
195
|
-
try {
|
|
196
|
-
decryptedStr = base64Decode(encryptedStr);
|
|
197
|
-
} catch {
|
|
198
|
-
return defaultValue;
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
} else {
|
|
202
|
-
const { base64Decode } = await import('./crypto.mjs');
|
|
203
|
-
try {
|
|
204
|
-
decryptedStr = base64Decode(encryptedStr);
|
|
205
|
-
} catch {
|
|
206
|
-
return defaultValue;
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
return JSON.parse(decryptedStr);
|
|
210
|
-
} catch {
|
|
211
|
-
return defaultValue;
|
|
212
|
-
}
|
|
213
|
-
},
|
|
214
|
-
/**
|
|
215
|
-
* 移除值
|
|
216
|
-
* @param key - 键
|
|
217
|
-
*/
|
|
218
|
-
remove(key) {
|
|
219
|
-
if (typeof window === "undefined" || !window.sessionStorage) return;
|
|
220
|
-
try {
|
|
221
|
-
window.sessionStorage.removeItem(key);
|
|
222
|
-
} catch (error) {
|
|
223
|
-
console.error("sessionStorage.remove error:", error);
|
|
224
|
-
}
|
|
225
|
-
},
|
|
226
|
-
/**
|
|
227
|
-
* 清空所有值
|
|
228
|
-
*/
|
|
229
|
-
clear() {
|
|
230
|
-
if (typeof window === "undefined" || !window.sessionStorage) return;
|
|
231
|
-
try {
|
|
232
|
-
window.sessionStorage.clear();
|
|
233
|
-
} catch (error) {
|
|
234
|
-
console.error("sessionStorage.clear error:", error);
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
};
|
|
238
|
-
var cookie = {
|
|
239
|
-
/**
|
|
240
|
-
* 设置Cookie
|
|
241
|
-
* @param key - 键
|
|
242
|
-
* @param value - 值
|
|
243
|
-
* @param options - Cookie选项
|
|
244
|
-
*/
|
|
245
|
-
set(key, value, options = {}) {
|
|
246
|
-
if (typeof document === "undefined") {
|
|
247
|
-
throw new Error("document is not available");
|
|
248
|
-
}
|
|
249
|
-
let cookieStr = `${encodeURIComponent(key)}=${encodeURIComponent(value)}`;
|
|
250
|
-
if (options.expires) {
|
|
251
|
-
const expiresDate = options.expires instanceof Date ? options.expires : new Date(Date.now() + options.expires * 24 * 60 * 60 * 1e3);
|
|
252
|
-
cookieStr += `; expires=${expiresDate.toUTCString()}`;
|
|
253
|
-
}
|
|
254
|
-
if (options.path) cookieStr += `; path=${options.path}`;
|
|
255
|
-
if (options.domain) cookieStr += `; domain=${options.domain}`;
|
|
256
|
-
if (options.secure) cookieStr += "; secure";
|
|
257
|
-
if (options.sameSite) cookieStr += `; sameSite=${options.sameSite}`;
|
|
258
|
-
document.cookie = cookieStr;
|
|
259
|
-
},
|
|
260
|
-
/**
|
|
261
|
-
* 获取Cookie
|
|
262
|
-
* @param key - 键
|
|
263
|
-
* @returns Cookie值
|
|
264
|
-
*/
|
|
265
|
-
get(key) {
|
|
266
|
-
if (typeof document === "undefined") return void 0;
|
|
267
|
-
const name = encodeURIComponent(key);
|
|
268
|
-
const cookies = document.cookie.split(";");
|
|
269
|
-
for (const cookie2 of cookies) {
|
|
270
|
-
const [cookieKey, cookieValue] = cookie2.trim().split("=");
|
|
271
|
-
if (cookieKey === name) {
|
|
272
|
-
return decodeURIComponent(cookieValue);
|
|
273
|
-
}
|
|
274
|
-
}
|
|
275
|
-
return void 0;
|
|
276
|
-
},
|
|
277
|
-
/**
|
|
278
|
-
* 移除Cookie
|
|
279
|
-
* @param key - 键
|
|
280
|
-
* @param options - Cookie选项
|
|
281
|
-
*/
|
|
282
|
-
remove(key, options = {}) {
|
|
283
|
-
cookie.set(key, "", {
|
|
284
|
-
...options,
|
|
285
|
-
expires: /* @__PURE__ */ new Date(0)
|
|
286
|
-
});
|
|
287
|
-
},
|
|
288
|
-
/**
|
|
289
|
-
* 获取所有Cookie
|
|
290
|
-
* @returns Cookie对象
|
|
291
|
-
*/
|
|
292
|
-
getAll() {
|
|
293
|
-
if (typeof document === "undefined") return {};
|
|
294
|
-
const cookies = {};
|
|
295
|
-
document.cookie.split(";").forEach((cookieStr) => {
|
|
296
|
-
const [key, value] = cookieStr.trim().split("=");
|
|
297
|
-
if (key && value) {
|
|
298
|
-
cookies[decodeURIComponent(key)] = decodeURIComponent(value);
|
|
299
|
-
}
|
|
300
|
-
});
|
|
301
|
-
return cookies;
|
|
302
|
-
}
|
|
303
|
-
};
|
|
304
|
-
var storage = {
|
|
305
|
-
/**
|
|
306
|
-
* 设置值(优先使用localStorage,失败则使用sessionStorage)
|
|
307
|
-
* @param key - 键
|
|
308
|
-
* @param value - 值
|
|
309
|
-
* @param options - 选项(过期时间、公钥等)
|
|
310
|
-
* @returns Promise<void>
|
|
311
|
-
*/
|
|
312
|
-
async set(key, value, options = {}) {
|
|
313
|
-
try {
|
|
314
|
-
await localStorage.set(key, value, options);
|
|
315
|
-
} catch {
|
|
316
|
-
try {
|
|
317
|
-
await sessionStorage.set(key, value, { publicKey: options.publicKey });
|
|
318
|
-
} catch {
|
|
319
|
-
console.warn("Both localStorage and sessionStorage are not available");
|
|
320
|
-
}
|
|
321
|
-
}
|
|
322
|
-
},
|
|
323
|
-
/**
|
|
324
|
-
* 获取值
|
|
325
|
-
* @param key - 键
|
|
326
|
-
* @param options - 选项(默认值、私钥等)
|
|
327
|
-
* @returns Promise<T | undefined> 值或默认值
|
|
328
|
-
*/
|
|
329
|
-
async get(key, options = {}) {
|
|
330
|
-
const localValue = await localStorage.get(key, options);
|
|
331
|
-
if (localValue !== void 0) return localValue;
|
|
332
|
-
const sessionValue = await sessionStorage.get(key, options);
|
|
333
|
-
return sessionValue !== void 0 ? sessionValue : options.defaultValue;
|
|
334
|
-
},
|
|
335
|
-
/**
|
|
336
|
-
* 移除值
|
|
337
|
-
* @param key - 键
|
|
338
|
-
*/
|
|
339
|
-
remove(key) {
|
|
340
|
-
localStorage.remove(key);
|
|
341
|
-
sessionStorage.remove(key);
|
|
342
|
-
},
|
|
343
|
-
/**
|
|
344
|
-
* 清空所有值
|
|
345
|
-
*/
|
|
346
|
-
clear() {
|
|
347
|
-
localStorage.clear();
|
|
348
|
-
sessionStorage.clear();
|
|
349
|
-
}
|
|
350
|
-
};
|
|
351
|
-
|
|
352
|
-
export { cookie, getStorageKeyPair, localStorage, sessionStorage, setStorageKeyPair, storage };
|
|
353
|
-
//# sourceMappingURL=chunk-OIXQ3E6W.mjs.map
|
|
354
|
-
//# sourceMappingURL=chunk-OIXQ3E6W.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/browser/storage.ts"],"names":["cookie"],"mappings":"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","file":"chunk-OIXQ3E6W.mjs","sourcesContent":["/**\n * 存储工具函数\n */\n\nimport { rsaEncrypt, rsaDecrypt, type RSAKeyPair } from '../helper/crypto';\n\n/**\n * 存储项配置\n */\ninterface StorageItem<T> {\n value: T;\n expiry?: number; // 过期时间戳\n}\n\n/**\n * 存储配置选项\n */\nexport interface StorageOptions {\n /** RSA公钥(用于加密) */\n publicKey?: CryptoKey;\n /** RSA私钥(用于解密) */\n privateKey?: CryptoKey;\n /** 是否启用加密,默认为 true */\n encrypt?: boolean;\n}\n\n// 全局密钥对(可选,用户也可以传入)\nlet globalKeyPair: RSAKeyPair | null = null;\n\n/**\n * 设置全局RSA密钥对\n * @param keyPair - RSA密钥对\n */\nexport function setStorageKeyPair(keyPair: RSAKeyPair): void {\n globalKeyPair = keyPair;\n}\n\n/**\n * 获取全局密钥对\n * @returns 全局密钥对或null\n */\nexport function getStorageKeyPair(): RSAKeyPair | null {\n return globalKeyPair;\n}\n\n/**\n * 加密存储值\n * @param value - 要加密的值\n * @param publicKey - RSA公钥\n * @returns Promise<string> 加密后的Base64字符串\n */\nasync function encryptValue(value: string, publicKey: CryptoKey): Promise<string> {\n return rsaEncrypt(value, publicKey);\n}\n\n/**\n * 解密存储值\n * @param encryptedValue - 加密后的Base64字符串\n * @param privateKey - RSA私钥\n * @returns Promise<string> 解密后的字符串\n */\nasync function decryptValue(encryptedValue: string, privateKey: CryptoKey): Promise<string> {\n try {\n return await rsaDecrypt(encryptedValue, privateKey);\n } catch {\n // 如果解密失败,可能是旧数据(未加密)或格式错误\n // 尝试直接解析 JSON(向后兼容)\n try {\n JSON.parse(encryptedValue);\n return encryptedValue; // 如果是有效的 JSON,返回原值\n } catch {\n throw new Error('Failed to decrypt storage value');\n }\n }\n}\n\n/**\n * localStorage封装(支持过期时间和RSA加密)\n */\nexport const localStorage = {\n /**\n * 设置值\n * @param key - 键\n * @param value - 值\n * @param options - 选项(过期时间、密钥等)\n * @returns Promise<void>\n */\n async set<T>(\n key: string,\n value: T,\n options: {\n expiry?: number;\n publicKey?: CryptoKey;\n } = {}\n ): Promise<void> {\n if (typeof window === 'undefined' || !window.localStorage) {\n throw new Error('localStorage is not available');\n }\n\n const { expiry, publicKey } = options;\n const item: StorageItem<T> = {\n value,\n expiry: expiry ? Date.now() + expiry : undefined,\n };\n\n try {\n const jsonStr = JSON.stringify(item);\n\n // 如果提供了公钥或全局密钥对存在,使用RSA加密\n const keyToUse = publicKey || globalKeyPair?.publicKey;\n if (keyToUse) {\n const encrypted = await encryptValue(jsonStr, keyToUse);\n window.localStorage.setItem(key, encrypted);\n } else {\n // 如果没有密钥,使用Base64编码(向后兼容)\n const { base64Encode } = await import('../helper/crypto');\n const encoded = base64Encode(jsonStr);\n window.localStorage.setItem(key, encoded);\n }\n } catch (error) {\n console.error('localStorage.set error:', error);\n throw error;\n }\n },\n\n /**\n * 获取值\n * @param key - 键\n * @param options - 选项(默认值、私钥等)\n * @returns Promise<T | undefined> 值或默认值\n */\n async get<T>(\n key: string,\n options: {\n defaultValue?: T;\n privateKey?: CryptoKey;\n } = {}\n ): Promise<T | undefined> {\n if (typeof window === 'undefined' || !window.localStorage) {\n return options.defaultValue;\n }\n\n const { defaultValue, privateKey } = options;\n\n try {\n const encryptedStr = window.localStorage.getItem(key);\n if (!encryptedStr) return defaultValue;\n\n let decryptedStr: string;\n\n // 如果提供了私钥或全局密钥对存在,使用RSA解密\n const keyToUse = privateKey || globalKeyPair?.privateKey;\n if (keyToUse) {\n try {\n decryptedStr = await decryptValue(encryptedStr, keyToUse);\n } catch {\n // RSA解密失败,尝试Base64解码(向后兼容)\n const { base64Decode } = await import('../helper/crypto');\n try {\n decryptedStr = base64Decode(encryptedStr);\n } catch {\n return defaultValue;\n }\n }\n } else {\n // 如果没有密钥,尝试Base64解码\n const { base64Decode } = await import('../helper/crypto');\n try {\n decryptedStr = base64Decode(encryptedStr);\n } catch {\n return defaultValue;\n }\n }\n\n const item: StorageItem<T> = JSON.parse(decryptedStr);\n\n // 检查是否过期\n if (item.expiry && Date.now() > item.expiry) {\n window.localStorage.removeItem(key);\n return defaultValue;\n }\n\n return item.value;\n } catch {\n return defaultValue;\n }\n },\n\n /**\n * 移除值\n * @param key - 键\n */\n remove(key: string): void {\n if (typeof window === 'undefined' || !window.localStorage) return;\n try {\n window.localStorage.removeItem(key);\n } catch (error) {\n console.error('localStorage.remove error:', error);\n }\n },\n\n /**\n * 清空所有值\n */\n clear(): void {\n if (typeof window === 'undefined' || !window.localStorage) return;\n try {\n window.localStorage.clear();\n } catch (error) {\n console.error('localStorage.clear error:', error);\n }\n },\n\n /**\n * 获取所有键\n * @returns 键数组\n */\n keys(): string[] {\n if (typeof window === 'undefined' || !window.localStorage) return [];\n const keys: string[] = [];\n try {\n for (let i = 0; i < window.localStorage.length; i++) {\n const key = window.localStorage.key(i);\n if (key) keys.push(key);\n }\n } catch (error) {\n console.error('localStorage.keys error:', error);\n }\n return keys;\n },\n};\n\n/**\n * sessionStorage封装(支持RSA加密)\n */\nexport const sessionStorage = {\n /**\n * 设置值\n * @param key - 键\n * @param value - 值\n * @param options - 选项(公钥等)\n * @returns Promise<void>\n */\n async set<T>(\n key: string,\n value: T,\n options: {\n publicKey?: CryptoKey;\n } = {}\n ): Promise<void> {\n if (typeof window === 'undefined' || !window.sessionStorage) {\n throw new Error('sessionStorage is not available');\n }\n\n const { publicKey } = options;\n\n try {\n const jsonStr = JSON.stringify(value);\n\n // 如果提供了公钥或全局密钥对存在,使用RSA加密\n const keyToUse = publicKey || globalKeyPair?.publicKey;\n if (keyToUse) {\n const encrypted = await encryptValue(jsonStr, keyToUse);\n window.sessionStorage.setItem(key, encrypted);\n } else {\n // 如果没有密钥,使用Base64编码(向后兼容)\n const { base64Encode } = await import('../helper/crypto');\n const encoded = base64Encode(jsonStr);\n window.sessionStorage.setItem(key, encoded);\n }\n } catch (error) {\n console.error('sessionStorage.set error:', error);\n throw error;\n }\n },\n\n /**\n * 获取值\n * @param key - 键\n * @param options - 选项(默认值、私钥等)\n * @returns Promise<T | undefined> 值或默认值\n */\n async get<T>(\n key: string,\n options: {\n defaultValue?: T;\n privateKey?: CryptoKey;\n } = {}\n ): Promise<T | undefined> {\n if (typeof window === 'undefined' || !window.sessionStorage) {\n return options.defaultValue;\n }\n\n const { defaultValue, privateKey } = options;\n\n try {\n const encryptedStr = window.sessionStorage.getItem(key);\n if (!encryptedStr) return defaultValue;\n\n let decryptedStr: string;\n\n // 如果提供了私钥或全局密钥对存在,使用RSA解密\n const keyToUse = privateKey || globalKeyPair?.privateKey;\n if (keyToUse) {\n try {\n decryptedStr = await decryptValue(encryptedStr, keyToUse);\n } catch {\n // RSA解密失败,尝试Base64解码(向后兼容)\n const { base64Decode } = await import('../helper/crypto');\n try {\n decryptedStr = base64Decode(encryptedStr);\n } catch {\n return defaultValue;\n }\n }\n } else {\n // 如果没有密钥,尝试Base64解码\n const { base64Decode } = await import('../helper/crypto');\n try {\n decryptedStr = base64Decode(encryptedStr);\n } catch {\n return defaultValue;\n }\n }\n\n return JSON.parse(decryptedStr) as T;\n } catch {\n return defaultValue;\n }\n },\n\n /**\n * 移除值\n * @param key - 键\n */\n remove(key: string): void {\n if (typeof window === 'undefined' || !window.sessionStorage) return;\n try {\n window.sessionStorage.removeItem(key);\n } catch (error) {\n console.error('sessionStorage.remove error:', error);\n }\n },\n\n /**\n * 清空所有值\n */\n clear(): void {\n if (typeof window === 'undefined' || !window.sessionStorage) return;\n try {\n window.sessionStorage.clear();\n } catch (error) {\n console.error('sessionStorage.clear error:', error);\n }\n },\n};\n\n/**\n * Cookie操作封装\n */\nexport const cookie = {\n /**\n * 设置Cookie\n * @param key - 键\n * @param value - 值\n * @param options - Cookie选项\n */\n set(\n key: string,\n value: string,\n options: {\n expires?: number | Date; // 过期时间(天数或Date对象)\n path?: string;\n domain?: string;\n secure?: boolean;\n sameSite?: 'strict' | 'lax' | 'none';\n } = {}\n ): void {\n if (typeof document === 'undefined') {\n throw new Error('document is not available');\n }\n\n let cookieStr = `${encodeURIComponent(key)}=${encodeURIComponent(value)}`;\n\n if (options.expires) {\n const expiresDate =\n options.expires instanceof Date\n ? options.expires\n : new Date(Date.now() + options.expires * 24 * 60 * 60 * 1000);\n cookieStr += `; expires=${expiresDate.toUTCString()}`;\n }\n\n if (options.path) cookieStr += `; path=${options.path}`;\n if (options.domain) cookieStr += `; domain=${options.domain}`;\n if (options.secure) cookieStr += '; secure';\n if (options.sameSite) cookieStr += `; sameSite=${options.sameSite}`;\n\n document.cookie = cookieStr;\n },\n\n /**\n * 获取Cookie\n * @param key - 键\n * @returns Cookie值\n */\n get(key: string): string | undefined {\n if (typeof document === 'undefined') return undefined;\n\n const name = encodeURIComponent(key);\n const cookies = document.cookie.split(';');\n\n for (const cookie of cookies) {\n const [cookieKey, cookieValue] = cookie.trim().split('=');\n if (cookieKey === name) {\n return decodeURIComponent(cookieValue);\n }\n }\n\n return undefined;\n },\n\n /**\n * 移除Cookie\n * @param key - 键\n * @param options - Cookie选项\n */\n remove(key: string, options: { path?: string; domain?: string } = {}): void {\n cookie.set(key, '', {\n ...options,\n expires: new Date(0),\n });\n },\n\n /**\n * 获取所有Cookie\n * @returns Cookie对象\n */\n getAll(): Record<string, string> {\n if (typeof document === 'undefined') return {};\n\n const cookies: Record<string, string> = {};\n document.cookie.split(';').forEach(cookieStr => {\n const [key, value] = cookieStr.trim().split('=');\n if (key && value) {\n cookies[decodeURIComponent(key)] = decodeURIComponent(value);\n }\n });\n\n return cookies;\n },\n};\n\n/**\n * 统一存储接口(自动选择存储方式,支持RSA加密)\n */\nexport const storage = {\n /**\n * 设置值(优先使用localStorage,失败则使用sessionStorage)\n * @param key - 键\n * @param value - 值\n * @param options - 选项(过期时间、公钥等)\n * @returns Promise<void>\n */\n async set<T>(\n key: string,\n value: T,\n options: {\n expiry?: number;\n publicKey?: CryptoKey;\n } = {}\n ): Promise<void> {\n try {\n await localStorage.set(key, value, options);\n } catch {\n try {\n await sessionStorage.set(key, value, { publicKey: options.publicKey });\n } catch {\n console.warn('Both localStorage and sessionStorage are not available');\n }\n }\n },\n\n /**\n * 获取值\n * @param key - 键\n * @param options - 选项(默认值、私钥等)\n * @returns Promise<T | undefined> 值或默认值\n */\n async get<T>(\n key: string,\n options: {\n defaultValue?: T;\n privateKey?: CryptoKey;\n } = {}\n ): Promise<T | undefined> {\n const localValue = await localStorage.get<T>(key, options);\n if (localValue !== undefined) return localValue;\n\n const sessionValue = await sessionStorage.get<T>(key, options);\n return sessionValue !== undefined ? sessionValue : options.defaultValue;\n },\n\n /**\n * 移除值\n * @param key - 键\n */\n remove(key: string): void {\n localStorage.remove(key);\n sessionStorage.remove(key);\n },\n\n /**\n * 清空所有值\n */\n clear(): void {\n localStorage.clear();\n sessionStorage.clear();\n },\n};\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/format/i18n.ts"],"names":[],"mappings":"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","file":"chunk-OX5PLOWB.js","sourcesContent":["/**\n * 国际化工具函数\n */\n\n/**\n * 语言环境类型\n */\nexport type Locale = string;\n\n/**\n * 货币代码类型(ISO 4217)\n */\nexport type CurrencyCode = string;\n\n/**\n * 获取当前语言环境\n * @returns 语言环境字符串(如 'zh-CN', 'en-US')\n */\nexport function getLocale(): Locale {\n if (typeof navigator !== 'undefined' && navigator.language) {\n return navigator.language;\n }\n return 'en-US';\n}\n\n/**\n * 数字本地化格式化\n * @param value - 数字值\n * @param locale - 语言环境,默认为当前环境\n * @param options - Intl.NumberFormat选项\n * @returns 格式化后的字符串\n */\nexport function formatNumberI18n(\n value: number,\n locale?: Locale,\n options?: Intl.NumberFormatOptions\n): string {\n const loc = locale || getLocale();\n return new Intl.NumberFormat(loc, options).format(value);\n}\n\n/**\n * 日期本地化格式化\n * @param date - 日期对象或时间戳\n * @param locale - 语言环境,默认为当前环境\n * @param options - Intl.DateTimeFormat选项\n * @returns 格式化后的字符串\n */\nexport function formatDateI18n(\n date: Date | number,\n locale?: Locale,\n options?: Intl.DateTimeFormatOptions\n): string {\n const loc = locale || getLocale();\n const dateObj = typeof date === 'number' ? new Date(date) : date;\n return new Intl.DateTimeFormat(loc, options).format(dateObj);\n}\n\n/**\n * 货币本地化格式化\n * @param value - 金额\n * @param currency - 货币代码(ISO 4217),如 'USD', 'CNY', 'EUR'\n * @param locale - 语言环境,默认为当前环境\n * @param options - Intl.NumberFormat选项\n * @returns 格式化后的货币字符串\n */\nexport function formatCurrencyI18n(\n value: number,\n currency: CurrencyCode,\n locale?: Locale,\n options?: Intl.NumberFormatOptions\n): string {\n const loc = locale || getLocale();\n return new Intl.NumberFormat(loc, {\n style: 'currency',\n currency,\n ...options,\n }).format(value);\n}\n\n/**\n * 翻译字典类型\n */\nexport type TranslationDictionary = Record<string, string | Record<string, unknown>>;\n\n/**\n * 翻译函数\n * @param key - 翻译键(支持点号分隔的嵌套键,如 'user.name')\n * @param dictionary - 翻译字典\n * @param defaultValue - 默认值(如果找不到翻译)\n * @returns 翻译后的字符串\n */\nexport function translate(\n key: string,\n dictionary: TranslationDictionary,\n defaultValue?: string\n): string {\n const keys = key.split('.');\n let current: unknown = dictionary;\n\n for (const k of keys) {\n if (typeof current === 'object' && current !== null && k in current) {\n current = (current as TranslationDictionary)[k];\n } else {\n return defaultValue || key;\n }\n }\n\n if (typeof current === 'string') {\n return current;\n }\n\n return defaultValue || key;\n}\n\n/**\n * 创建翻译函数(带预设字典)\n * @param dictionary - 翻译字典\n * @returns 翻译函数\n */\nexport function createTranslator(dictionary: TranslationDictionary) {\n return (key: string, defaultValue?: string): string => {\n return translate(key, dictionary, defaultValue);\n };\n}\n\n/**\n * 获取相对时间格式化(本地化)\n * @param date - 日期对象或时间戳\n * @param locale - 语言环境,默认为当前环境\n * @returns 格式化后的相对时间字符串\n */\nexport function formatRelativeTime(date: Date | number, locale?: Locale): string {\n const loc = locale || getLocale();\n const dateObj = typeof date === 'number' ? new Date(date) : date;\n const now = new Date();\n const diffInSeconds = Math.floor((now.getTime() - dateObj.getTime()) / 1000);\n\n const rtf = new Intl.RelativeTimeFormat(loc, { numeric: 'auto' });\n\n const intervals: Array<{ unit: Intl.RelativeTimeFormatUnit; seconds: number }> = [\n { unit: 'year', seconds: 31536000 },\n { unit: 'month', seconds: 2592000 },\n { unit: 'week', seconds: 604800 },\n { unit: 'day', seconds: 86400 },\n { unit: 'hour', seconds: 3600 },\n { unit: 'minute', seconds: 60 },\n { unit: 'second', seconds: 1 },\n ];\n\n for (const interval of intervals) {\n const count = Math.floor(Math.abs(diffInSeconds) / interval.seconds);\n if (count >= 1) {\n return rtf.format(diffInSeconds < 0 ? count : -count, interval.unit);\n }\n }\n\n return rtf.format(0, 'second');\n}\n\n/**\n * 获取复数形式(简单实现)\n * @param count - 数量\n * @param singular - 单数形式\n * @param plural - 复数形式(可选,默认为 singular + 's')\n * @param locale - 语言环境,默认为当前环境\n * @returns 格式化后的字符串\n */\nexport function pluralize(\n count: number,\n singular: string,\n plural?: string,\n locale?: Locale\n): string {\n const loc = locale || getLocale();\n const pluralForm = plural || `${singular}s`;\n\n // 使用 Intl.PluralRules 获取正确的复数形式\n const pluralRules = new Intl.PluralRules(loc);\n const rule = pluralRules.select(count);\n\n // 简单实现:大多数语言中,1 使用单数,其他使用复数\n if (rule === 'one' || count === 1) {\n return `${count} ${singular}`;\n }\n\n return `${count} ${pluralForm}`;\n}\n"]}
|