@wener/utils 1.1.11 → 1.1.13
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/cjs/globalThis-ee7c1669.js +2 -0
- package/dist/cjs/globalThis-ee7c1669.js.map +1 -0
- package/dist/cjs/index.cjs +5 -5
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/server.cjs +1 -1
- package/dist/cjs/server.cjs.map +1 -1
- package/dist/esm/globalThis-000611c3.js +2 -0
- package/dist/esm/globalThis-000611c3.js.map +1 -0
- package/dist/esm/index.js +4 -4
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/server.js +1 -1
- package/dist/esm/server.js.map +1 -1
- package/dist/system/globalThis-7bba6592.js +2 -0
- package/dist/system/globalThis-7bba6592.js.map +1 -0
- package/dist/system/index.js +5 -5
- package/dist/system/index.js.map +1 -1
- package/dist/system/server.js +1 -1
- package/dist/system/server.js.map +1 -1
- package/lib/asyncs/AsyncInterval.js +1 -1
- package/lib/asyncs/AsyncInterval.js.map +1 -1
- package/lib/asyncs/timeout.js +3 -1
- package/lib/asyncs/timeout.js.map +1 -1
- package/lib/browsers/copy.js +2 -1
- package/lib/browsers/copy.js.map +1 -1
- package/lib/browsers/download.js +3 -1
- package/lib/browsers/download.js.map +1 -1
- package/lib/browsers/getFileFromDataTransfer.js +3 -2
- package/lib/browsers/getFileFromDataTransfer.js.map +1 -1
- package/lib/browsers/loaders.js +6 -2
- package/lib/browsers/loaders.js.map +1 -1
- package/lib/crypto/getRandomValues.js +7 -4
- package/lib/crypto/getRandomValues.js.map +1 -1
- package/lib/crypto/pem/pem.js +3 -2
- package/lib/crypto/pem/pem.js.map +1 -1
- package/lib/crypto/randomUUID.js +4 -1
- package/lib/crypto/randomUUID.js.map +1 -1
- package/lib/crypto/ulid.js +3 -3
- package/lib/crypto/ulid.js.map +1 -1
- package/lib/i18n/createTranslate.js +2 -1
- package/lib/i18n/createTranslate.js.map +1 -1
- package/lib/index.js +2 -0
- package/lib/index.js.map +1 -1
- package/lib/io/ArrayBuffers.js +166 -142
- package/lib/io/ArrayBuffers.js.map +1 -1
- package/lib/io/Buffer.js +6 -5
- package/lib/io/Buffer.js.map +1 -1
- package/lib/io/isBuffer.js +2 -1
- package/lib/io/isBuffer.js.map +1 -1
- package/lib/io/isTransferable.js +3 -1
- package/lib/io/isTransferable.js.map +1 -1
- package/lib/isomorphics/getGlobalThis.js.map +1 -1
- package/lib/isomorphics/globalThis.js +6 -0
- package/lib/isomorphics/globalThis.js.map +1 -0
- package/lib/isomorphics/structuredClone.js +1 -0
- package/lib/isomorphics/structuredClone.js.map +1 -1
- package/lib/langs/parseBoolean.js.map +1 -1
- package/lib/libs/ms.js +117 -0
- package/lib/libs/ms.js.map +1 -0
- package/lib/logging/createLogger.js +17 -6
- package/lib/logging/createLogger.js.map +1 -1
- package/lib/maths/random.js +2 -1
- package/lib/maths/random.js.map +1 -1
- package/lib/modules/parseModuleId.js +2 -1
- package/lib/modules/parseModuleId.js.map +1 -1
- package/lib/servers/createProxyFetch.js +3 -1
- package/lib/servers/createProxyFetch.js.map +1 -1
- package/lib/servers/polyfillCrypto.js +2 -0
- package/lib/servers/polyfillCrypto.js.map +1 -1
- package/lib/servers/polyfillFetch.js.map +1 -1
- package/lib/servers/polyfillJsDom.js +2 -0
- package/lib/servers/polyfillJsDom.js.map +1 -1
- package/package.json +2 -1
- package/src/asyncs/timeout.ts +1 -1
- package/src/browsers/copy.ts +1 -1
- package/src/browsers/download.ts +1 -1
- package/src/browsers/loaders.ts +2 -2
- package/src/crypto/getRandomValues.ts +1 -0
- package/src/crypto/randomUUID.ts +2 -0
- package/src/i18n/createTranslate.ts +2 -1
- package/src/index.ts +4 -0
- package/src/io/ArrayBuffers.ts +1 -0
- package/src/io/isTransferable.ts +2 -0
- package/src/isomorphics/getGlobalThis.ts +3 -1
- package/src/isomorphics/globalThis.ts +3 -0
- package/src/isomorphics/structuredClone.ts +1 -0
- package/src/langs/parseBoolean.ts +1 -1
- package/src/libs/README.md +1 -0
- package/src/libs/ms.ts +205 -0
- package/src/logging/createLogger.ts +5 -5
- package/src/objects/set.test.ts +1 -1
- package/src/servers/createProxyFetch.ts +2 -1
- package/src/servers/polyfillCrypto.ts +3 -1
- package/src/servers/polyfillFetch.ts +1 -0
- package/src/servers/polyfillJsDom.ts +1 -0
- package/src/servers/polyfillWebSocket.ts +15 -0
package/lib/libs/ms.js
ADDED
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
const s = 1e3;
|
|
2
|
+
const m = s * 60;
|
|
3
|
+
const h = m * 60;
|
|
4
|
+
const d = h * 24;
|
|
5
|
+
const w = d * 7;
|
|
6
|
+
const y = d * 365.25;
|
|
7
|
+
function msFn(value, options) {
|
|
8
|
+
try {
|
|
9
|
+
if (typeof value === "string" && value.length > 0) {
|
|
10
|
+
return parse(value);
|
|
11
|
+
} else if (typeof value === "number" && isFinite(value)) {
|
|
12
|
+
return (options == null ? void 0 : options.long) ? fmtLong(value) : fmtShort(value);
|
|
13
|
+
}
|
|
14
|
+
throw new Error("Value is not a string or number.");
|
|
15
|
+
} catch (error) {
|
|
16
|
+
const message = isError(error) ? `${error.message}. value=${JSON.stringify(value)}` : "An unknown error has occurred.";
|
|
17
|
+
throw new Error(message);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
function parse(str) {
|
|
21
|
+
if (str.length > 100) {
|
|
22
|
+
throw new Error("Value exceeds the maximum length of 100 characters.");
|
|
23
|
+
}
|
|
24
|
+
const match = /^(?<value>-?(?:\d+)?\.?\d+) *(?<type>milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(
|
|
25
|
+
str
|
|
26
|
+
);
|
|
27
|
+
const groups = match == null ? void 0 : match.groups;
|
|
28
|
+
if (!groups) {
|
|
29
|
+
return NaN;
|
|
30
|
+
}
|
|
31
|
+
const n = parseFloat(groups.value);
|
|
32
|
+
const type = (groups.type || "ms").toLowerCase();
|
|
33
|
+
switch (type) {
|
|
34
|
+
case "years":
|
|
35
|
+
case "year":
|
|
36
|
+
case "yrs":
|
|
37
|
+
case "yr":
|
|
38
|
+
case "y":
|
|
39
|
+
return n * y;
|
|
40
|
+
case "weeks":
|
|
41
|
+
case "week":
|
|
42
|
+
case "w":
|
|
43
|
+
return n * w;
|
|
44
|
+
case "days":
|
|
45
|
+
case "day":
|
|
46
|
+
case "d":
|
|
47
|
+
return n * d;
|
|
48
|
+
case "hours":
|
|
49
|
+
case "hour":
|
|
50
|
+
case "hrs":
|
|
51
|
+
case "hr":
|
|
52
|
+
case "h":
|
|
53
|
+
return n * h;
|
|
54
|
+
case "minutes":
|
|
55
|
+
case "minute":
|
|
56
|
+
case "mins":
|
|
57
|
+
case "min":
|
|
58
|
+
case "m":
|
|
59
|
+
return n * m;
|
|
60
|
+
case "seconds":
|
|
61
|
+
case "second":
|
|
62
|
+
case "secs":
|
|
63
|
+
case "sec":
|
|
64
|
+
case "s":
|
|
65
|
+
return n * s;
|
|
66
|
+
case "milliseconds":
|
|
67
|
+
case "millisecond":
|
|
68
|
+
case "msecs":
|
|
69
|
+
case "msec":
|
|
70
|
+
case "ms":
|
|
71
|
+
return n;
|
|
72
|
+
default:
|
|
73
|
+
throw new Error(`The unit ${type} was matched, but no matching case exists.`);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
function fmtShort(ms) {
|
|
77
|
+
const msAbs = Math.abs(ms);
|
|
78
|
+
if (msAbs >= d) {
|
|
79
|
+
return `${Math.round(ms / d)}d`;
|
|
80
|
+
}
|
|
81
|
+
if (msAbs >= h) {
|
|
82
|
+
return `${Math.round(ms / h)}h`;
|
|
83
|
+
}
|
|
84
|
+
if (msAbs >= m) {
|
|
85
|
+
return `${Math.round(ms / m)}m`;
|
|
86
|
+
}
|
|
87
|
+
if (msAbs >= s) {
|
|
88
|
+
return `${Math.round(ms / s)}s`;
|
|
89
|
+
}
|
|
90
|
+
return `${ms}ms`;
|
|
91
|
+
}
|
|
92
|
+
function fmtLong(ms) {
|
|
93
|
+
const msAbs = Math.abs(ms);
|
|
94
|
+
if (msAbs >= d) {
|
|
95
|
+
return plural(ms, msAbs, d, "day");
|
|
96
|
+
}
|
|
97
|
+
if (msAbs >= h) {
|
|
98
|
+
return plural(ms, msAbs, h, "hour");
|
|
99
|
+
}
|
|
100
|
+
if (msAbs >= m) {
|
|
101
|
+
return plural(ms, msAbs, m, "minute");
|
|
102
|
+
}
|
|
103
|
+
if (msAbs >= s) {
|
|
104
|
+
return plural(ms, msAbs, s, "second");
|
|
105
|
+
}
|
|
106
|
+
return `${ms} ms`;
|
|
107
|
+
}
|
|
108
|
+
function plural(ms, msAbs, n, name) {
|
|
109
|
+
const isPlural = msAbs >= n * 1.5;
|
|
110
|
+
return `${Math.round(ms / n)} ${name}${isPlural ? "s" : ""}`;
|
|
111
|
+
}
|
|
112
|
+
function isError(value) {
|
|
113
|
+
return typeof value === "object" && value !== null && "message" in value;
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
export { msFn as default };
|
|
117
|
+
//# sourceMappingURL=ms.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ms.js","sources":["../../src/libs/ms.ts"],"sourcesContent":["// Helpers.\nconst s = 1000;\nconst m = s * 60;\nconst h = m * 60;\nconst d = h * 24;\nconst w = d * 7;\nconst y = d * 365.25;\n\ntype Unit =\n | 'Years'\n | 'Year'\n | 'Yrs'\n | 'Yr'\n | 'Y'\n | 'Weeks'\n | 'Week'\n | 'W'\n | 'Days'\n | 'Day'\n | 'D'\n | 'Hours'\n | 'Hour'\n | 'Hrs'\n | 'Hr'\n | 'H'\n | 'Minutes'\n | 'Minute'\n | 'Mins'\n | 'Min'\n | 'M'\n | 'Seconds'\n | 'Second'\n | 'Secs'\n | 'Sec'\n | 's'\n | 'Milliseconds'\n | 'Millisecond'\n | 'Msecs'\n | 'Msec'\n | 'Ms';\n\ntype UnitAnyCase = Unit | Uppercase<Unit> | Lowercase<Unit>;\n\nexport type StringValue = `${number}` | `${number}${UnitAnyCase}` | `${number} ${UnitAnyCase}`;\n\ninterface Options {\n /**\n * Set to `true` to use verbose formatting. Defaults to `false`.\n */\n long?: boolean;\n}\n\n/**\n * Parse or format the given value.\n *\n * @param value - The string or number to convert\n * @param options - Options for the conversion\n * @throws Error if `value` is not a non-empty string or a number\n */\nfunction msFn(value: StringValue, options?: Options): number;\nfunction msFn(value: number, options?: Options): string;\nfunction msFn(value: StringValue | number, options?: Options): number | string {\n try {\n if (typeof value === 'string' && value.length > 0) {\n return parse(value);\n } else if (typeof value === 'number' && isFinite(value)) {\n return options?.long ? fmtLong(value) : fmtShort(value);\n }\n throw new Error('Value is not a string or number.');\n } catch (error) {\n const message = isError(error)\n ? `${error.message}. value=${JSON.stringify(value)}`\n : 'An unknown error has occurred.';\n throw new Error(message);\n }\n}\n\n/**\n * Parse the given string and return milliseconds.\n *\n * @param str - A string to parse to milliseconds\n * @returns The parsed value in milliseconds, or `NaN` if the string can't be\n * parsed\n */\nfunction parse(str: string): number {\n if (str.length > 100) {\n throw new Error('Value exceeds the maximum length of 100 characters.');\n }\n const match =\n /^(?<value>-?(?:\\d+)?\\.?\\d+) *(?<type>milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str,\n );\n // Named capture groups need to be manually typed today.\n // https://github.com/microsoft/TypeScript/issues/32098\n const groups = match?.groups as { value: string; type?: string } | undefined;\n if (!groups) {\n return NaN;\n }\n const n = parseFloat(groups.value);\n const type = (groups.type || 'ms').toLowerCase() as Lowercase<Unit>;\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n // This should never occur.\n throw new Error(`The unit ${type as string} was matched, but no matching case exists.`);\n }\n}\n\n// eslint-disable-next-line import/no-default-export\nexport default msFn;\n\n/**\n * Short format for `ms`.\n */\nfunction fmtShort(ms: number): StringValue {\n const msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return `${Math.round(ms / d)}d`;\n }\n if (msAbs >= h) {\n return `${Math.round(ms / h)}h`;\n }\n if (msAbs >= m) {\n return `${Math.round(ms / m)}m`;\n }\n if (msAbs >= s) {\n return `${Math.round(ms / s)}s`;\n }\n return `${ms}ms`;\n}\n\n/**\n * Long format for `ms`.\n */\nfunction fmtLong(ms: number): StringValue {\n const msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return `${ms} ms`;\n}\n\n/**\n * Pluralization helper.\n */\nfunction plural(ms: number, msAbs: number, n: number, name: string): StringValue {\n const isPlural = msAbs >= n * 1.5;\n return `${Math.round(ms / n)} ${name}${isPlural ? 's' : ''}` as StringValue;\n}\n\n/**\n * A type guard for errors.\n *\n * @param value - The value to test\n * @returns A boolean `true` if the provided value is an Error-like object\n */\nfunction isError(value: unknown): value is Error {\n return typeof value === 'object' && value !== null && 'message' in value;\n}\n"],"names":[],"mappings":"AACA,MAAM,CAAI,GAAA,GAAA,CAAA;AACV,MAAM,IAAI,CAAI,GAAA,EAAA,CAAA;AACd,MAAM,IAAI,CAAI,GAAA,EAAA,CAAA;AACd,MAAM,IAAI,CAAI,GAAA,EAAA,CAAA;AACd,MAAM,IAAI,CAAI,GAAA,CAAA,CAAA;AACd,MAAM,IAAI,CAAI,GAAA,MAAA,CAAA;AAuDd,SAAS,IAAA,CAAK,OAA6B,OAAoC,EAAA;AAC7E,EAAI,IAAA;AACF,IAAA,IAAI,OAAO,KAAA,KAAU,QAAY,IAAA,KAAA,CAAM,SAAS,CAAG,EAAA;AACjD,MAAA,OAAO,MAAM,KAAK,CAAA,CAAA;AAAA,eACT,OAAO,KAAA,KAAU,QAAY,IAAA,QAAA,CAAS,KAAK,CAAG,EAAA;AACvD,MAAA,OAAA,CAAO,mCAAS,IAAO,IAAA,OAAA,CAAQ,KAAK,CAAA,GAAI,SAAS,KAAK,CAAA,CAAA;AAAA,KACxD;AACA,IAAM,MAAA,IAAI,MAAM,kCAAkC,CAAA,CAAA;AAAA,WAC3C,KAAP,EAAA;AACA,IAAM,MAAA,OAAA,GAAU,OAAQ,CAAA,KAAK,CACzB,GAAA,CAAA,EAAG,MAAM,OAAkB,CAAA,QAAA,EAAA,IAAA,CAAK,SAAU,CAAA,KAAK,CAC/C,CAAA,CAAA,GAAA,gCAAA,CAAA;AACJ,IAAM,MAAA,IAAI,MAAM,OAAO,CAAA,CAAA;AAAA,GACzB;AACF,CAAA;AASA,SAAS,MAAM,GAAqB,EAAA;AAClC,EAAI,IAAA,GAAA,CAAI,SAAS,GAAK,EAAA;AACpB,IAAM,MAAA,IAAI,MAAM,qDAAqD,CAAA,CAAA;AAAA,GACvE;AACA,EAAA,MAAM,QACJ,iJAAkJ,CAAA,IAAA;AAAA,IAChJ,GAAA;AAAA,GACF,CAAA;AAGF,EAAA,MAAM,SAAS,KAAO,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAA,MAAA,CAAA;AACtB,EAAA,IAAI,CAAC,MAAQ,EAAA;AACX,IAAO,OAAA,GAAA,CAAA;AAAA,GACT;AACA,EAAM,MAAA,CAAA,GAAI,UAAW,CAAA,MAAA,CAAO,KAAK,CAAA,CAAA;AACjC,EAAA,MAAM,IAAQ,GAAA,CAAA,MAAA,CAAO,IAAQ,IAAA,IAAA,EAAM,WAAY,EAAA,CAAA;AAC/C,EAAA,QAAQ,IAAM;AAAA,IACZ,KAAK,OAAA,CAAA;AAAA,IACL,KAAK,MAAA,CAAA;AAAA,IACL,KAAK,KAAA,CAAA;AAAA,IACL,KAAK,IAAA,CAAA;AAAA,IACL,KAAK,GAAA;AACH,MAAA,OAAO,CAAI,GAAA,CAAA,CAAA;AAAA,IACb,KAAK,OAAA,CAAA;AAAA,IACL,KAAK,MAAA,CAAA;AAAA,IACL,KAAK,GAAA;AACH,MAAA,OAAO,CAAI,GAAA,CAAA,CAAA;AAAA,IACb,KAAK,MAAA,CAAA;AAAA,IACL,KAAK,KAAA,CAAA;AAAA,IACL,KAAK,GAAA;AACH,MAAA,OAAO,CAAI,GAAA,CAAA,CAAA;AAAA,IACb,KAAK,OAAA,CAAA;AAAA,IACL,KAAK,MAAA,CAAA;AAAA,IACL,KAAK,KAAA,CAAA;AAAA,IACL,KAAK,IAAA,CAAA;AAAA,IACL,KAAK,GAAA;AACH,MAAA,OAAO,CAAI,GAAA,CAAA,CAAA;AAAA,IACb,KAAK,SAAA,CAAA;AAAA,IACL,KAAK,QAAA,CAAA;AAAA,IACL,KAAK,MAAA,CAAA;AAAA,IACL,KAAK,KAAA,CAAA;AAAA,IACL,KAAK,GAAA;AACH,MAAA,OAAO,CAAI,GAAA,CAAA,CAAA;AAAA,IACb,KAAK,SAAA,CAAA;AAAA,IACL,KAAK,QAAA,CAAA;AAAA,IACL,KAAK,MAAA,CAAA;AAAA,IACL,KAAK,KAAA,CAAA;AAAA,IACL,KAAK,GAAA;AACH,MAAA,OAAO,CAAI,GAAA,CAAA,CAAA;AAAA,IACb,KAAK,cAAA,CAAA;AAAA,IACL,KAAK,aAAA,CAAA;AAAA,IACL,KAAK,OAAA,CAAA;AAAA,IACL,KAAK,MAAA,CAAA;AAAA,IACL,KAAK,IAAA;AACH,MAAO,OAAA,CAAA,CAAA;AAAA,IACT;AAEE,MAAM,MAAA,IAAI,KAAM,CAAA,CAAA,SAAA,EAAY,IAA0D,CAAA,0CAAA,CAAA,CAAA,CAAA;AAAA,GAC1F;AACF,CAAA;AAQA,SAAS,SAAS,EAAyB,EAAA;AACzC,EAAM,MAAA,KAAA,GAAQ,IAAK,CAAA,GAAA,CAAI,EAAE,CAAA,CAAA;AACzB,EAAA,IAAI,SAAS,CAAG,EAAA;AACd,IAAA,OAAO,CAAG,EAAA,IAAA,CAAK,KAAM,CAAA,EAAA,GAAK,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA;AAAA,GAC7B;AACA,EAAA,IAAI,SAAS,CAAG,EAAA;AACd,IAAA,OAAO,CAAG,EAAA,IAAA,CAAK,KAAM,CAAA,EAAA,GAAK,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA;AAAA,GAC7B;AACA,EAAA,IAAI,SAAS,CAAG,EAAA;AACd,IAAA,OAAO,CAAG,EAAA,IAAA,CAAK,KAAM,CAAA,EAAA,GAAK,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA;AAAA,GAC7B;AACA,EAAA,IAAI,SAAS,CAAG,EAAA;AACd,IAAA,OAAO,CAAG,EAAA,IAAA,CAAK,KAAM,CAAA,EAAA,GAAK,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA;AAAA,GAC7B;AACA,EAAA,OAAO,CAAG,EAAA,EAAA,CAAA,EAAA,CAAA,CAAA;AACZ,CAAA;AAKA,SAAS,QAAQ,EAAyB,EAAA;AACxC,EAAM,MAAA,KAAA,GAAQ,IAAK,CAAA,GAAA,CAAI,EAAE,CAAA,CAAA;AACzB,EAAA,IAAI,SAAS,CAAG,EAAA;AACd,IAAA,OAAO,MAAO,CAAA,EAAA,EAAI,KAAO,EAAA,CAAA,EAAG,KAAK,CAAA,CAAA;AAAA,GACnC;AACA,EAAA,IAAI,SAAS,CAAG,EAAA;AACd,IAAA,OAAO,MAAO,CAAA,EAAA,EAAI,KAAO,EAAA,CAAA,EAAG,MAAM,CAAA,CAAA;AAAA,GACpC;AACA,EAAA,IAAI,SAAS,CAAG,EAAA;AACd,IAAA,OAAO,MAAO,CAAA,EAAA,EAAI,KAAO,EAAA,CAAA,EAAG,QAAQ,CAAA,CAAA;AAAA,GACtC;AACA,EAAA,IAAI,SAAS,CAAG,EAAA;AACd,IAAA,OAAO,MAAO,CAAA,EAAA,EAAI,KAAO,EAAA,CAAA,EAAG,QAAQ,CAAA,CAAA;AAAA,GACtC;AACA,EAAA,OAAO,CAAG,EAAA,EAAA,CAAA,GAAA,CAAA,CAAA;AACZ,CAAA;AAKA,SAAS,MAAO,CAAA,EAAA,EAAY,KAAe,EAAA,CAAA,EAAW,IAA2B,EAAA;AAC/E,EAAM,MAAA,QAAA,GAAW,SAAS,CAAI,GAAA,GAAA,CAAA;AAC9B,EAAO,OAAA,CAAA,EAAG,KAAK,KAAM,CAAA,EAAA,GAAK,CAAC,CAAK,CAAA,CAAA,EAAA,IAAA,CAAA,EAAO,WAAW,GAAM,GAAA,EAAA,CAAA,CAAA,CAAA;AAC1D,CAAA;AAQA,SAAS,QAAQ,KAAgC,EAAA;AAC/C,EAAA,OAAO,OAAO,KAAA,KAAU,QAAY,IAAA,KAAA,KAAU,QAAQ,SAAa,IAAA,KAAA,CAAA;AACrE;;;;"}
|
|
@@ -3,15 +3,26 @@ function createLogger(write = ({
|
|
|
3
3
|
values,
|
|
4
4
|
...ctx
|
|
5
5
|
}) => {
|
|
6
|
+
var _a;
|
|
6
7
|
({ values, ...ctx } = merge(ctx, values));
|
|
7
|
-
console[level]
|
|
8
|
+
(_a = console[level]) == null ? void 0 : _a.call(console, ...values, ctx);
|
|
8
9
|
}, context = {}) {
|
|
9
10
|
return {
|
|
10
|
-
trace: (...values) =>
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
11
|
+
trace: (...values) => {
|
|
12
|
+
write({ ...context, level: "trace", values });
|
|
13
|
+
},
|
|
14
|
+
debug: (...values) => {
|
|
15
|
+
write({ ...context, level: "debug", values });
|
|
16
|
+
},
|
|
17
|
+
info: (...values) => {
|
|
18
|
+
write({ ...context, level: "info", values });
|
|
19
|
+
},
|
|
20
|
+
warn: (...values) => {
|
|
21
|
+
write({ ...context, level: "warn", values });
|
|
22
|
+
},
|
|
23
|
+
error: (...values) => {
|
|
24
|
+
write({ ...context, level: "error", values });
|
|
25
|
+
},
|
|
15
26
|
child: (ctx) => createLogger(write, { ...context, ...ctx })
|
|
16
27
|
};
|
|
17
28
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createLogger.js","sources":["../../src/logging/createLogger.ts"],"sourcesContent":["import type { LoggerWithChild, LogLevel } from './Logger';\n\nexport function createLogger(\n write: (o: { level: LogLevel; values: any[] } & Record<string | symbol, any>) => void = ({\n level,\n values,\n ...ctx\n }) => {\n ({ values, ...ctx } = merge(ctx, values));\n console[level]?.(...values, ctx);\n },\n context: object = {},\n): LoggerWithChild {\n return {\n trace: (...values) => write({ ...context, level: 'trace', values }),\n debug: (...values) => write({ ...context, level: 'debug', values }),\n info: (...values) => write({ ...context, level: 'info', values }),\n warn: (...values) => write({ ...context, level: 'warn', values }),\n error: (...values) => write({ ...context, level: 'error', values }),\n child: (ctx) => createLogger(write, { ...context, ...ctx }),\n };\n}\n\n// logger.info({name:'wener'},'message')\n// merge initial context with message object\nfunction merge(ctx: any, values: any[]) {\n if (values[0] && typeof values[0] === 'object') {\n return { ...ctx, ...values[0], values: values.slice(1) };\n }\n return { ...ctx, values };\n}\n"],"names":[],"mappings":"AAEgB,SAAA,YAAA,CACd,QAAwF,CAAC;AAAA,EACvF,KAAA;AAAA,EACA,MAAA;AAAA,EACA,GAAG,GAAA;AACL,CAAM,KAAA;
|
|
1
|
+
{"version":3,"file":"createLogger.js","sources":["../../src/logging/createLogger.ts"],"sourcesContent":["import type { LoggerWithChild, LogLevel } from './Logger';\n\nexport function createLogger(\n write: (o: { level: LogLevel; values: any[] } & Record<string | symbol, any>) => void = ({\n level,\n values,\n ...ctx\n }) => {\n ({ values, ...ctx } = merge(ctx, values));\n console[level]?.(...values, ctx);\n },\n context: object = {},\n): LoggerWithChild {\n return {\n trace: (...values) => { write({ ...context, level: 'trace', values }); },\n debug: (...values) => { write({ ...context, level: 'debug', values }); },\n info: (...values) => { write({ ...context, level: 'info', values }); },\n warn: (...values) => { write({ ...context, level: 'warn', values }); },\n error: (...values) => { write({ ...context, level: 'error', values }); },\n child: (ctx) => createLogger(write, { ...context, ...ctx }),\n };\n}\n\n// logger.info({name:'wener'},'message')\n// merge initial context with message object\nfunction merge(ctx: any, values: any[]) {\n if (values[0] && typeof values[0] === 'object') {\n return { ...ctx, ...values[0], values: values.slice(1) };\n }\n return { ...ctx, values };\n}\n"],"names":[],"mappings":"AAEgB,SAAA,YAAA,CACd,QAAwF,CAAC;AAAA,EACvF,KAAA;AAAA,EACA,MAAA;AAAA,EACA,GAAG,GAAA;AACL,CAAM,KAAA;AAPR,EAAA,IAAA,EAAA,CAAA;AAQI,EAAA,CAAC,EAAE,MAAQ,EAAA,GAAG,KAAQ,GAAA,KAAA,CAAM,KAAK,MAAM,CAAA,EAAA;AACvC,EAAQ,CAAA,EAAA,GAAA,OAAA,CAAA,KAAA,CAAA,KAAR,IAAiB,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,IAAA,CAAA,OAAA,EAAA,GAAG,MAAQ,EAAA,GAAA,CAAA,CAAA;AAC9B,CACA,EAAA,OAAA,GAAkB,EACD,EAAA;AACjB,EAAO,OAAA;AAAA,IACL,KAAA,EAAO,IAAI,MAAW,KAAA;AAAE,MAAA,KAAA,CAAM,EAAE,GAAG,OAAA,EAAS,KAAO,EAAA,OAAA,EAAS,QAAQ,CAAA,CAAA;AAAA,KAAG;AAAA,IACvE,KAAA,EAAO,IAAI,MAAW,KAAA;AAAE,MAAA,KAAA,CAAM,EAAE,GAAG,OAAA,EAAS,KAAO,EAAA,OAAA,EAAS,QAAQ,CAAA,CAAA;AAAA,KAAG;AAAA,IACvE,IAAA,EAAM,IAAI,MAAW,KAAA;AAAE,MAAA,KAAA,CAAM,EAAE,GAAG,OAAA,EAAS,KAAO,EAAA,MAAA,EAAQ,QAAQ,CAAA,CAAA;AAAA,KAAG;AAAA,IACrE,IAAA,EAAM,IAAI,MAAW,KAAA;AAAE,MAAA,KAAA,CAAM,EAAE,GAAG,OAAA,EAAS,KAAO,EAAA,MAAA,EAAQ,QAAQ,CAAA,CAAA;AAAA,KAAG;AAAA,IACrE,KAAA,EAAO,IAAI,MAAW,KAAA;AAAE,MAAA,KAAA,CAAM,EAAE,GAAG,OAAA,EAAS,KAAO,EAAA,OAAA,EAAS,QAAQ,CAAA,CAAA;AAAA,KAAG;AAAA,IACvE,KAAA,EAAO,CAAC,GAAA,KAAQ,YAAa,CAAA,KAAA,EAAO,EAAE,GAAG,OAAA,EAAS,GAAG,GAAA,EAAK,CAAA;AAAA,GAC5D,CAAA;AACF,CAAA;AAIA,SAAS,KAAA,CAAM,KAAU,MAAe,EAAA;AACtC,EAAA,IAAI,OAAO,CAAC,CAAA,IAAK,OAAO,MAAO,CAAA,CAAC,MAAM,QAAU,EAAA;AAC9C,IAAO,OAAA,EAAE,GAAG,GAAA,EAAK,GAAG,MAAA,CAAO,CAAC,CAAA,EAAG,MAAQ,EAAA,MAAA,CAAO,KAAM,CAAA,CAAC,CAAE,EAAA,CAAA;AAAA,GACzD;AACA,EAAO,OAAA,EAAE,GAAG,GAAA,EAAK,MAAO,EAAA,CAAA;AAC1B;;;;"}
|
package/lib/maths/random.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
function createRandom(o = {}) {
|
|
2
|
-
|
|
2
|
+
var _a;
|
|
3
|
+
let seed = typeof o.seed === "string" ? 0 : (_a = o.seed) != null ? _a : 0;
|
|
3
4
|
if (typeof o.seed === "string") {
|
|
4
5
|
let sum = 0;
|
|
5
6
|
for (let i = 0; i < o.seed.length; i++) {
|
package/lib/maths/random.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"random.js","sources":["../../src/maths/random.ts"],"sourcesContent":["/// javascript pseudo random\nexport function createRandom(o: { seed?: string | number } = {}) {\n let seed = typeof o.seed === 'string' ? 0 : o.seed ?? 0;\n if (typeof o.seed === 'string') {\n let sum = 0;\n for (let i = 0; i < o.seed.length; i++) {\n sum += o.seed.charCodeAt(i);\n }\n seed = sum;\n }\n\n return () => {\n const x = Math.sin(seed++) * 10000;\n return x - Math.floor(x);\n };\n}\n"],"names":[],"mappings":"AACgB,SAAA,YAAA,CAAa,CAAgC,GAAA,EAAI,EAAA;
|
|
1
|
+
{"version":3,"file":"random.js","sources":["../../src/maths/random.ts"],"sourcesContent":["/// javascript pseudo random\nexport function createRandom(o: { seed?: string | number } = {}) {\n let seed = typeof o.seed === 'string' ? 0 : o.seed ?? 0;\n if (typeof o.seed === 'string') {\n let sum = 0;\n for (let i = 0; i < o.seed.length; i++) {\n sum += o.seed.charCodeAt(i);\n }\n seed = sum;\n }\n\n return () => {\n const x = Math.sin(seed++) * 10000;\n return x - Math.floor(x);\n };\n}\n"],"names":[],"mappings":"AACgB,SAAA,YAAA,CAAa,CAAgC,GAAA,EAAI,EAAA;AADjE,EAAA,IAAA,EAAA,CAAA;AAEE,EAAI,IAAA,IAAA,GAAO,OAAO,CAAE,CAAA,IAAA,KAAS,WAAW,CAAI,GAAA,CAAA,EAAA,GAAA,CAAA,CAAE,SAAF,IAAU,GAAA,EAAA,GAAA,CAAA,CAAA;AACtD,EAAI,IAAA,OAAO,CAAE,CAAA,IAAA,KAAS,QAAU,EAAA;AAC9B,IAAA,IAAI,GAAM,GAAA,CAAA,CAAA;AACV,IAAA,KAAA,IAAS,IAAI,CAAG,EAAA,CAAA,GAAI,CAAE,CAAA,IAAA,CAAK,QAAQ,CAAK,EAAA,EAAA;AACtC,MAAO,GAAA,IAAA,CAAA,CAAE,IAAK,CAAA,UAAA,CAAW,CAAC,CAAA,CAAA;AAAA,KAC5B;AACA,IAAO,IAAA,GAAA,GAAA,CAAA;AAAA,GACT;AAEA,EAAA,OAAO,MAAM;AACX,IAAA,MAAM,CAAI,GAAA,IAAA,CAAK,GAAI,CAAA,IAAA,EAAM,CAAI,GAAA,GAAA,CAAA;AAC7B,IAAO,OAAA,CAAA,GAAI,IAAK,CAAA,KAAA,CAAM,CAAC,CAAA,CAAA;AAAA,GACzB,CAAA;AACF;;;;"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
const regModuleId = /^(?<n>(?:@(?<org>[a-z0-9-~][a-z0-9-._~]*)\/)?(?<pkg>[a-z0-9-~][a-z0-9-._~]*))(?:@(?<v>[-a-z0-9><=_.^~]+))?(?<p>\/[^\r\n]*)?$/;
|
|
2
2
|
function parseModuleId(s) {
|
|
3
|
-
|
|
3
|
+
var _a;
|
|
4
|
+
const groups = (_a = s.match(regModuleId)) == null ? void 0 : _a.groups;
|
|
4
5
|
if (!groups) {
|
|
5
6
|
return void 0;
|
|
6
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parseModuleId.js","sources":["../../src/modules/parseModuleId.ts"],"sourcesContent":["// https://regex101.com/r/eMcXQ9/1\nconst regModuleId =\n /^(?<n>(?:@(?<org>[a-z0-9-~][a-z0-9-._~]*)\\/)?(?<pkg>[a-z0-9-~][a-z0-9-._~]*))(?:@(?<v>[-a-z0-9><=_.^~]+))?(?<p>\\/[^\\r\\n]*)?$/;\n\nexport type ParsedModuleId = {\n id: string; // name@version\n name: string; // @org/pkg, pkg\n version?: string; // 1.1.1\n range: string; // version, tag, range\n pkg: string;\n path?: string;\n org?: string;\n versioned: boolean; // is module id contain a version specifier\n} & (\n | { scoped: false }\n | {\n scoped: true;\n org: string;\n }\n);\n\n/**\n * Parse NPM module id\n *\n * @example\n * parseModuleId('@wener/reaction@latest/index.js')\n * // { id: '@wener/reaction@latest', name: '@wener/reaction', version: 'latest', range: 'latest', pkg: 'reaction', path: '/index.js', scoped: true, org: 'wener' }\n */\nexport function parseModuleId(s: string): ParsedModuleId | undefined {\n const groups = s.match(regModuleId)?.groups;\n if (!groups) {\n return undefined;\n }\n const { n: name, v: version, p: path, org, pkg } = groups;\n const scoped = Boolean(org);\n const v = /^\\d+\\.\\d+\\.\\d+/.test(version) ? version : undefined;\n const range = version || 'latest';\n const o: ParsedModuleId = {\n id: `${name}@${range}`,\n name,\n range,\n scoped,\n pkg,\n org,\n versioned: Boolean(version),\n };\n if (v) {\n o.version = v;\n }\n if (path) {\n o.path = path;\n }\n if (!o.scoped) {\n delete o.org;\n }\n return o;\n}\n"],"names":[],"mappings":"AACA,MAAM,WACJ,GAAA,8HAAA,CAAA;AA0BK,SAAS,cAAc,CAAuC,EAAA;
|
|
1
|
+
{"version":3,"file":"parseModuleId.js","sources":["../../src/modules/parseModuleId.ts"],"sourcesContent":["// https://regex101.com/r/eMcXQ9/1\nconst regModuleId =\n /^(?<n>(?:@(?<org>[a-z0-9-~][a-z0-9-._~]*)\\/)?(?<pkg>[a-z0-9-~][a-z0-9-._~]*))(?:@(?<v>[-a-z0-9><=_.^~]+))?(?<p>\\/[^\\r\\n]*)?$/;\n\nexport type ParsedModuleId = {\n id: string; // name@version\n name: string; // @org/pkg, pkg\n version?: string; // 1.1.1\n range: string; // version, tag, range\n pkg: string;\n path?: string;\n org?: string;\n versioned: boolean; // is module id contain a version specifier\n} & (\n | { scoped: false }\n | {\n scoped: true;\n org: string;\n }\n);\n\n/**\n * Parse NPM module id\n *\n * @example\n * parseModuleId('@wener/reaction@latest/index.js')\n * // { id: '@wener/reaction@latest', name: '@wener/reaction', version: 'latest', range: 'latest', pkg: 'reaction', path: '/index.js', scoped: true, org: 'wener' }\n */\nexport function parseModuleId(s: string): ParsedModuleId | undefined {\n const groups = s.match(regModuleId)?.groups;\n if (!groups) {\n return undefined;\n }\n const { n: name, v: version, p: path, org, pkg } = groups;\n const scoped = Boolean(org);\n const v = /^\\d+\\.\\d+\\.\\d+/.test(version) ? version : undefined;\n const range = version || 'latest';\n const o: ParsedModuleId = {\n id: `${name}@${range}`,\n name,\n range,\n scoped,\n pkg,\n org,\n versioned: Boolean(version),\n };\n if (v) {\n o.version = v;\n }\n if (path) {\n o.path = path;\n }\n if (!o.scoped) {\n delete o.org;\n }\n return o;\n}\n"],"names":[],"mappings":"AACA,MAAM,WACJ,GAAA,8HAAA,CAAA;AA0BK,SAAS,cAAc,CAAuC,EAAA;AA5BrE,EAAA,IAAA,EAAA,CAAA;AA6BE,EAAA,MAAM,MAAS,GAAA,CAAA,EAAA,GAAA,CAAA,CAAE,KAAM,CAAA,WAAW,MAAnB,IAAsB,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,MAAA,CAAA;AACrC,EAAA,IAAI,CAAC,MAAQ,EAAA;AACX,IAAO,OAAA,KAAA,CAAA,CAAA;AAAA,GACT;AACA,EAAM,MAAA,EAAE,GAAG,IAAM,EAAA,CAAA,EAAG,SAAS,CAAG,EAAA,IAAA,EAAM,GAAK,EAAA,GAAA,EAAQ,GAAA,MAAA,CAAA;AACnD,EAAM,MAAA,MAAA,GAAS,QAAQ,GAAG,CAAA,CAAA;AAC1B,EAAA,MAAM,CAAI,GAAA,gBAAA,CAAiB,IAAK,CAAA,OAAO,IAAI,OAAU,GAAA,KAAA,CAAA,CAAA;AACrD,EAAA,MAAM,QAAQ,OAAW,IAAA,QAAA,CAAA;AACzB,EAAA,MAAM,CAAoB,GAAA;AAAA,IACxB,EAAA,EAAI,GAAG,IAAQ,CAAA,CAAA,EAAA,KAAA,CAAA,CAAA;AAAA,IACf,IAAA;AAAA,IACA,KAAA;AAAA,IACA,MAAA;AAAA,IACA,GAAA;AAAA,IACA,GAAA;AAAA,IACA,SAAA,EAAW,QAAQ,OAAO,CAAA;AAAA,GAC5B,CAAA;AACA,EAAA,IAAI,CAAG,EAAA;AACL,IAAA,CAAA,CAAE,OAAU,GAAA,CAAA,CAAA;AAAA,GACd;AACA,EAAA,IAAI,IAAM,EAAA;AACR,IAAA,CAAA,CAAE,IAAO,GAAA,IAAA,CAAA;AAAA,GACX;AACA,EAAI,IAAA,CAAC,EAAE,MAAQ,EAAA;AACb,IAAA,OAAO,CAAE,CAAA,GAAA,CAAA;AAAA,GACX;AACA,EAAO,OAAA,CAAA,CAAA;AACT;;;;"}
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import { globalThis } from '../isomorphics/globalThis.js';
|
|
2
|
+
|
|
1
3
|
function createProxyFetch(proxy, fetch) {
|
|
2
4
|
if (!proxy) {
|
|
3
5
|
return fetch || globalThis.fetch;
|
|
@@ -14,7 +16,7 @@ function createProxyFetch(proxy, fetch) {
|
|
|
14
16
|
if (!NodeRequest) {
|
|
15
17
|
({ Request: NodeRequest, default: NodeFetch } = await import('node-fetch'));
|
|
16
18
|
}
|
|
17
|
-
fetch
|
|
19
|
+
fetch || (fetch = NodeFetch);
|
|
18
20
|
if (url instanceof Request) {
|
|
19
21
|
return fetch(new Request(url, { agent }));
|
|
20
22
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createProxyFetch.js","sources":["../../src/servers/createProxyFetch.ts"],"sourcesContent":["import { FetchLike } from '../fetch';\n\nexport function createProxyFetch(proxy?: string, fetch?: FetchLike): FetchLike {\n if (!proxy) {\n return fetch || globalThis.fetch;\n }\n\n let agent: any;\n const Request = globalThis.Request;\n let NodeRequest: any;\n let NodeFetch: any;\n return async (url, init?: RequestInit) => {\n if (!agent) {\n const { default: createHttpsProxyAgent } = await import('https-proxy-agent');\n agent = createHttpsProxyAgent(proxy);\n }\n\n // node-fetch 才可以,node v18 fetch 不支持\n if (!NodeRequest) {\n ({ Request: NodeRequest, default: NodeFetch } = await import('node-fetch'));\n }\n\n fetch ||= NodeFetch;\n\n if (url instanceof Request) {\n return (fetch as any)(new Request(url, { agent } as any));\n }\n if ((url as any) instanceof NodeRequest) {\n return (fetch as any)(new NodeRequest(url, { agent } as any));\n }\n return (fetch as any)(url, {\n ...init,\n agent,\n } as any);\n };\n}\n"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"createProxyFetch.js","sources":["../../src/servers/createProxyFetch.ts"],"sourcesContent":["import { type FetchLike } from '../fetch';\nimport { globalThis } from '../isomorphics/globalThis';\n\nexport function createProxyFetch(proxy?: string, fetch?: FetchLike): FetchLike {\n if (!proxy) {\n return fetch || globalThis.fetch;\n }\n\n let agent: any;\n const Request = globalThis.Request;\n let NodeRequest: any;\n let NodeFetch: any;\n return async (url, init?: RequestInit) => {\n if (!agent) {\n const { default: createHttpsProxyAgent } = await import('https-proxy-agent');\n agent = createHttpsProxyAgent(proxy);\n }\n\n // node-fetch 才可以,node v18 fetch 不支持\n if (!NodeRequest) {\n ({ Request: NodeRequest, default: NodeFetch } = await import('node-fetch'));\n }\n\n fetch ||= NodeFetch;\n\n if (url instanceof Request) {\n return (fetch as any)(new Request(url, { agent } as any));\n }\n if ((url as any) instanceof NodeRequest) {\n return (fetch as any)(new NodeRequest(url, { agent } as any));\n }\n return (fetch as any)(url, {\n ...init,\n agent,\n } as any);\n };\n}\n"],"names":[],"mappings":";;AAGgB,SAAA,gBAAA,CAAiB,OAAgB,KAA8B,EAAA;AAC7E,EAAA,IAAI,CAAC,KAAO,EAAA;AACV,IAAA,OAAO,SAAS,UAAW,CAAA,KAAA,CAAA;AAAA,GAC7B;AAEA,EAAI,IAAA,KAAA,CAAA;AACJ,EAAA,MAAM,UAAU,UAAW,CAAA,OAAA,CAAA;AAC3B,EAAI,IAAA,WAAA,CAAA;AACJ,EAAI,IAAA,SAAA,CAAA;AACJ,EAAO,OAAA,OAAO,KAAK,IAAuB,KAAA;AACxC,IAAA,IAAI,CAAC,KAAO,EAAA;AACV,MAAA,MAAM,EAAE,OAAS,EAAA,qBAAA,EAA0B,GAAA,MAAM,OAAO,mBAAmB,CAAA,CAAA;AAC3E,MAAA,KAAA,GAAQ,sBAAsB,KAAK,CAAA,CAAA;AAAA,KACrC;AAGA,IAAA,IAAI,CAAC,WAAa,EAAA;AAChB,MAAC,CAAA,EAAE,SAAS,WAAa,EAAA,OAAA,EAAS,WAAc,GAAA,MAAM,OAAO,YAAY,CAAA,EAAA;AAAA,KAC3E;AAEA,IAAU,KAAA,KAAA,KAAA,GAAA,SAAA,CAAA,CAAA;AAEV,IAAA,IAAI,eAAe,OAAS,EAAA;AAC1B,MAAA,OAAQ,MAAc,IAAI,OAAA,CAAQ,KAAK,EAAE,KAAA,EAAc,CAAC,CAAA,CAAA;AAAA,KAC1D;AACA,IAAA,IAAK,eAAuB,WAAa,EAAA;AACvC,MAAA,OAAQ,MAAc,IAAI,WAAA,CAAY,KAAK,EAAE,KAAA,EAAc,CAAC,CAAA,CAAA;AAAA,KAC9D;AACA,IAAA,OAAQ,MAAc,GAAK,EAAA;AAAA,MACzB,GAAG,IAAA;AAAA,MACH,KAAA;AAAA,KACM,CAAA,CAAA;AAAA,GACV,CAAA;AACF;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"polyfillCrypto.js","sources":["../../src/servers/polyfillCrypto.ts"],"sourcesContent":["
|
|
1
|
+
{"version":3,"file":"polyfillCrypto.js","sources":["../../src/servers/polyfillCrypto.ts"],"sourcesContent":["import { globalThis } from '../isomorphics/globalThis';\n\nexport async function polyfillCrypto() {\n if ('crypto' in globalThis) {\n return false;\n }\n (globalThis as any).crypto = (await import('node:crypto')).webcrypto as Crypto;\n return true;\n}\n"],"names":[],"mappings":";;AAEA,eAAsB,cAAiB,GAAA;AACrC,EAAA,IAAI,YAAY,UAAY,EAAA;AAC1B,IAAO,OAAA,KAAA,CAAA;AAAA,GACT;AACA,EAAC,UAAmB,CAAA,MAAA,GAAA,CAAU,MAAM,OAAO,aAAa,CAAG,EAAA,SAAA,CAAA;AAC3D,EAAO,OAAA,IAAA,CAAA;AACT;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"polyfillFetch.js","sources":["../../src/servers/polyfillFetch.ts"],"sourcesContent":["import type { MaybePromise } from '../asyncs/MaybePromise';\n\nexport function polyfillFetch(nodeFetch: typeof import('node-fetch')): boolean;\nexport function polyfillFetch(nodeFetch?: undefined): Promise<boolean>;\nexport function polyfillFetch(nodeFetch?: typeof import('node-fetch')): MaybePromise<boolean> {\n if ('fetch' in globalThis) {\n return false;\n }\n // sync mode\n if (nodeFetch) {\n const { default: fetch, Response, Headers, Request, AbortError, FetchError, FormData, Blob, File } = nodeFetch;\n Object.assign(globalThis, {\n fetch,\n Response,\n Headers,\n Request,\n AbortError,\n FetchError,\n FormData,\n Blob,\n File,\n });\n return true;\n }\n return import('node-fetch').then((v) => polyfillFetch(v));\n}\n"],"names":[],"mappings":"AAIO,SAAS,cAAc,SAAgE,EAAA;AAC5F,EAAA,IAAI,WAAW,UAAY,EAAA;AACzB,IAAO,OAAA,KAAA,CAAA;AAAA,GACT;AAEA,EAAA,IAAI,SAAW,EAAA;AACb,IAAM,MAAA,EAAE,OAAS,EAAA,KAAA,EAAO,QAAU,EAAA,OAAA,EAAS,OAAS,EAAA,UAAA,EAAY,UAAY,EAAA,QAAA,EAAU,IAAM,EAAA,IAAA,EAAS,GAAA,SAAA,CAAA;AACrG,IAAA,MAAA,CAAO,OAAO,UAAY,EAAA;AAAA,MACxB,KAAA;AAAA,MACA,QAAA;AAAA,MACA,OAAA;AAAA,MACA,OAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAA;AAAA,MACA,QAAA;AAAA,MACA,IAAA;AAAA,MACA,IAAA;AAAA,KACD,CAAA,CAAA;
|
|
1
|
+
{"version":3,"file":"polyfillFetch.js","sources":["../../src/servers/polyfillFetch.ts"],"sourcesContent":["import type { MaybePromise } from '../asyncs/MaybePromise';\n\nexport function polyfillFetch(nodeFetch: typeof import('node-fetch')): boolean;\nexport function polyfillFetch(nodeFetch?: undefined): Promise<boolean>;\nexport function polyfillFetch(nodeFetch?: typeof import('node-fetch')): MaybePromise<boolean> {\n if ('fetch' in globalThis) {\n return false;\n }\n // sync mode\n if (nodeFetch) {\n const { default: fetch, Response, Headers, Request, AbortError, FetchError, FormData, Blob, File } = nodeFetch;\n Object.assign(globalThis, {\n fetch,\n Response,\n Headers,\n Request,\n AbortError,\n FetchError,\n FormData,\n Blob,\n File,\n });\n // abort controller\n return true;\n }\n return import('node-fetch').then((v) => polyfillFetch(v));\n}\n"],"names":[],"mappings":"AAIO,SAAS,cAAc,SAAgE,EAAA;AAC5F,EAAA,IAAI,WAAW,UAAY,EAAA;AACzB,IAAO,OAAA,KAAA,CAAA;AAAA,GACT;AAEA,EAAA,IAAI,SAAW,EAAA;AACb,IAAM,MAAA,EAAE,OAAS,EAAA,KAAA,EAAO,QAAU,EAAA,OAAA,EAAS,OAAS,EAAA,UAAA,EAAY,UAAY,EAAA,QAAA,EAAU,IAAM,EAAA,IAAA,EAAS,GAAA,SAAA,CAAA;AACrG,IAAA,MAAA,CAAO,OAAO,UAAY,EAAA;AAAA,MACxB,KAAA;AAAA,MACA,QAAA;AAAA,MACA,OAAA;AAAA,MACA,OAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAA;AAAA,MACA,QAAA;AAAA,MACA,IAAA;AAAA,MACA,IAAA;AAAA,KACD,CAAA,CAAA;AAED,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AACA,EAAO,OAAA,OAAO,YAAY,CAAE,CAAA,IAAA,CAAK,CAAC,CAAM,KAAA,aAAA,CAAc,CAAC,CAAC,CAAA,CAAA;AAC1D;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"polyfillJsDom.js","sources":["../../src/servers/polyfillJsDom.ts"],"sourcesContent":["import type { ConstructorOptions, ResourceLoaderConstructorOptions } from 'jsdom';\n\nexport async function polyfillJsDom() {\n if (typeof window !== 'undefined') {\n return false;\n }\n\n const { ResourceLoader, JSDOM } = await import('jsdom');\n\n // https://github.com/lukechilds/window/blob/master/src/index.js\n // eslint-disable-next-line @typescript-eslint/no-extraneous-class\n class Window {\n constructor(opts: ResourceLoaderConstructorOptions & ConstructorOptions = {}) {\n const { proxy, strictSSL, userAgent, ...jsdomOpts } = opts;\n const resources = new ResourceLoader({\n proxy,\n strictSSL,\n userAgent,\n });\n return new JSDOM(\n '',\n Object.assign(jsdomOpts, {\n resources,\n }),\n ).window;\n }\n }\n\n // https://github.com/lukechilds/browser-env/blob/master/src/index.js\n // Default jsdom config.\n // These settings must override any custom settings to make sure we can iterate\n // over the window object.\n const defaultJsdomConfig = {\n // features: {\n // FetchExternalResources: false,\n // ProcessExternalResources: false,\n // },\n };\n // IIFE executed on import to return an array of global Node.js properties that\n // conflict with global browser properties.\n const protectedProperties = (() =>\n Object.getOwnPropertyNames(new Window(defaultJsdomConfig)).filter(\n (prop) => typeof globalThis[prop as keyof typeof globalThis] !== 'undefined',\n ))();\n\n function installEnv(...args: any[]) {\n // Sets up global browser environment\n // Extract options from args\n const properties = args.filter((arg: any) => Array.isArray(arg))[0];\n const userJsdomConfig = args.filter((arg: any) => !Array.isArray(arg))[0];\n\n // Create window object\n const window = new Window(Object.assign({}, userJsdomConfig, defaultJsdomConfig));\n\n // Get all global browser properties\n Object.getOwnPropertyNames(window)\n\n // Remove protected properties\n .filter((prop) => !protectedProperties.includes(prop))\n\n // If we're only applying specific required properties remove everything else\n .filter((prop) => !(properties && properties.indexOf(prop) === -1))\n .filter((prop) => {\n switch (prop) {\n case 'undefined':\n return false;\n }\n return true;\n })\n\n // Copy what's left to the Node.js global scope\n .forEach((prop) => {\n // console.debug(`define globalThis.${prop}`);\n Object.defineProperty(globalThis, prop, {\n configurable: true,\n get: () => window[prop as keyof Window] as any,\n });\n });\n\n return window;\n }\n\n installEnv({ url: 'http://localhost' });\n return true;\n}\n"],"names":["window"],"mappings":"
|
|
1
|
+
{"version":3,"file":"polyfillJsDom.js","sources":["../../src/servers/polyfillJsDom.ts"],"sourcesContent":["import type { ConstructorOptions, ResourceLoaderConstructorOptions } from 'jsdom';\nimport { globalThis } from '../isomorphics/globalThis';\n\nexport async function polyfillJsDom() {\n if (typeof window !== 'undefined') {\n return false;\n }\n\n const { ResourceLoader, JSDOM } = await import('jsdom');\n\n // https://github.com/lukechilds/window/blob/master/src/index.js\n // eslint-disable-next-line @typescript-eslint/no-extraneous-class\n class Window {\n constructor(opts: ResourceLoaderConstructorOptions & ConstructorOptions = {}) {\n const { proxy, strictSSL, userAgent, ...jsdomOpts } = opts;\n const resources = new ResourceLoader({\n proxy,\n strictSSL,\n userAgent,\n });\n return new JSDOM(\n '',\n Object.assign(jsdomOpts, {\n resources,\n }),\n ).window;\n }\n }\n\n // https://github.com/lukechilds/browser-env/blob/master/src/index.js\n // Default jsdom config.\n // These settings must override any custom settings to make sure we can iterate\n // over the window object.\n const defaultJsdomConfig = {\n // features: {\n // FetchExternalResources: false,\n // ProcessExternalResources: false,\n // },\n };\n // IIFE executed on import to return an array of global Node.js properties that\n // conflict with global browser properties.\n const protectedProperties = (() =>\n Object.getOwnPropertyNames(new Window(defaultJsdomConfig)).filter(\n (prop) => typeof globalThis[prop as keyof typeof globalThis] !== 'undefined',\n ))();\n\n function installEnv(...args: any[]) {\n // Sets up global browser environment\n // Extract options from args\n const properties = args.filter((arg: any) => Array.isArray(arg))[0];\n const userJsdomConfig = args.filter((arg: any) => !Array.isArray(arg))[0];\n\n // Create window object\n const window = new Window(Object.assign({}, userJsdomConfig, defaultJsdomConfig));\n\n // Get all global browser properties\n Object.getOwnPropertyNames(window)\n\n // Remove protected properties\n .filter((prop) => !protectedProperties.includes(prop))\n\n // If we're only applying specific required properties remove everything else\n .filter((prop) => !(properties && properties.indexOf(prop) === -1))\n .filter((prop) => {\n switch (prop) {\n case 'undefined':\n return false;\n }\n return true;\n })\n\n // Copy what's left to the Node.js global scope\n .forEach((prop) => {\n // console.debug(`define globalThis.${prop}`);\n Object.defineProperty(globalThis, prop, {\n configurable: true,\n get: () => window[prop as keyof Window] as any,\n });\n });\n\n return window;\n }\n\n installEnv({ url: 'http://localhost' });\n return true;\n}\n"],"names":["window"],"mappings":";;AAGA,eAAsB,aAAgB,GAAA;AACpC,EAAI,IAAA,OAAO,WAAW,WAAa,EAAA;AACjC,IAAO,OAAA,KAAA,CAAA;AAAA,GACT;AAEA,EAAA,MAAM,EAAE,cAAgB,EAAA,KAAA,EAAU,GAAA,MAAM,OAAO,OAAO,CAAA,CAAA;AAItD,EAAA,MAAM,MAAO,CAAA;AAAA,IACX,WAAA,CAAY,IAA8D,GAAA,EAAI,EAAA;AAC5E,MAAA,MAAM,EAAE,KAAO,EAAA,SAAA,EAAW,SAAW,EAAA,GAAG,WAAc,GAAA,IAAA,CAAA;AACtD,MAAM,MAAA,SAAA,GAAY,IAAI,cAAe,CAAA;AAAA,QACnC,KAAA;AAAA,QACA,SAAA;AAAA,QACA,SAAA;AAAA,OACD,CAAA,CAAA;AACD,MAAA,OAAO,IAAI,KAAA;AAAA,QACT,EAAA;AAAA,QACA,MAAA,CAAO,OAAO,SAAW,EAAA;AAAA,UACvB,SAAA;AAAA,SACD,CAAA;AAAA,OACD,CAAA,MAAA,CAAA;AAAA,KACJ;AAAA,GACF;AAMA,EAAA,MAAM,kBAAqB,GAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAK3B,CAAA;AAGA,EAAM,MAAA,mBAAA,GAAA,CAAuB,MAC3B,MAAO,CAAA,mBAAA,CAAoB,IAAI,MAAO,CAAA,kBAAkB,CAAC,CAAE,CAAA,MAAA;AAAA,IACzD,CAAC,IAAA,KAAS,OAAO,UAAA,CAAW,IAA+B,CAAM,KAAA,WAAA;AAAA,GAChE,GAAA,CAAA;AAEL,EAAA,SAAS,cAAc,IAAa,EAAA;AAGlC,IAAM,MAAA,UAAA,GAAa,IAAK,CAAA,MAAA,CAAO,CAAC,GAAA,KAAa,MAAM,OAAQ,CAAA,GAAG,CAAC,CAAA,CAAE,CAAC,CAAA,CAAA;AAClE,IAAM,MAAA,eAAA,GAAkB,IAAK,CAAA,MAAA,CAAO,CAAC,GAAA,KAAa,CAAC,KAAA,CAAM,OAAQ,CAAA,GAAG,CAAC,CAAA,CAAE,CAAC,CAAA,CAAA;AAGxE,IAAMA,MAAAA,OAAAA,GAAS,IAAI,MAAO,CAAA,MAAA,CAAO,OAAO,EAAC,EAAG,eAAiB,EAAA,kBAAkB,CAAC,CAAA,CAAA;AAGhF,IAAO,MAAA,CAAA,mBAAA,CAAoBA,OAAM,CAAA,CAG9B,MAAO,CAAA,CAAC,SAAS,CAAC,mBAAA,CAAoB,QAAS,CAAA,IAAI,CAAC,CAAA,CAGpD,OAAO,CAAC,IAAA,KAAS,EAAE,UAAA,IAAc,UAAW,CAAA,OAAA,CAAQ,IAAI,CAAA,KAAM,CAAG,CAAA,CAAA,CAAA,CACjE,MAAO,CAAA,CAAC,IAAS,KAAA;AAChB,MAAA,QAAQ,IAAM;AAAA,QACZ,KAAK,WAAA;AACH,UAAO,OAAA,KAAA,CAAA;AAAA,OACX;AACA,MAAO,OAAA,IAAA,CAAA;AAAA,KACR,CAAA,CAGA,OAAQ,CAAA,CAAC,IAAS,KAAA;AAEjB,MAAO,MAAA,CAAA,cAAA,CAAe,YAAY,IAAM,EAAA;AAAA,QACtC,YAAc,EAAA,IAAA;AAAA,QACd,GAAA,EAAK,MAAMA,OAAAA,CAAO,IAAoB,CAAA;AAAA,OACvC,CAAA,CAAA;AAAA,KACF,CAAA,CAAA;AAEH,IAAOA,OAAAA,OAAAA,CAAAA;AAAA,GACT;AAEA,EAAW,UAAA,CAAA,EAAE,GAAK,EAAA,kBAAA,EAAoB,CAAA,CAAA;AACtC,EAAO,OAAA,IAAA,CAAA;AACT;;;;"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@wener/utils",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.13",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"description": "Utils for daily use",
|
|
6
6
|
"repository": {
|
|
@@ -58,6 +58,7 @@
|
|
|
58
58
|
],
|
|
59
59
|
"devDependencies": {
|
|
60
60
|
"@types/lodash": "^4.14.191",
|
|
61
|
+
"@types/ws": "^8.5.4",
|
|
61
62
|
"ava": "^5.1.1",
|
|
62
63
|
"https-proxy-agent": "^5.0.1",
|
|
63
64
|
"lodash": "^4.17.21",
|
package/src/asyncs/timeout.ts
CHANGED
|
@@ -4,7 +4,7 @@ export function timeout<T = any>(v: Promise<T>, ms: number): Promise<T> {
|
|
|
4
4
|
return Promise.race([
|
|
5
5
|
v,
|
|
6
6
|
new Promise((_resolve, reject) => {
|
|
7
|
-
timeout = setTimeout(() => reject(error), ms);
|
|
7
|
+
timeout = setTimeout(() => { reject(error); }, ms);
|
|
8
8
|
}),
|
|
9
9
|
]).then(
|
|
10
10
|
(v) => {
|
package/src/browsers/copy.ts
CHANGED
package/src/browsers/download.ts
CHANGED
|
@@ -26,7 +26,7 @@ export function download(filename: string, data: any, { type = 'application/octe
|
|
|
26
26
|
|
|
27
27
|
if (data instanceof File || data instanceof Blob || data instanceof MediaSource) {
|
|
28
28
|
a.href = URL.createObjectURL(data);
|
|
29
|
-
closer = () => URL.revokeObjectURL(a.href);
|
|
29
|
+
closer = () => { URL.revokeObjectURL(a.href); };
|
|
30
30
|
} else {
|
|
31
31
|
console.error(`invalid download data`, data);
|
|
32
32
|
throw new Error(`can not download ${Object.getPrototypeOf(data)}`);
|
package/src/browsers/loaders.ts
CHANGED
|
@@ -4,13 +4,13 @@ function load(
|
|
|
4
4
|
reject: (v: any) => void,
|
|
5
5
|
options: { attributes: Record<string, string> } | undefined,
|
|
6
6
|
) {
|
|
7
|
-
el.onload = () => resolve(el);
|
|
7
|
+
el.onload = () => { resolve(el); };
|
|
8
8
|
el.onerror = (e) => {
|
|
9
9
|
el.remove();
|
|
10
10
|
reject(e);
|
|
11
11
|
};
|
|
12
12
|
const { attributes = {} } = options || {};
|
|
13
|
-
Object.entries(attributes).forEach(([k, v]) => el.setAttribute(k, v));
|
|
13
|
+
Object.entries(attributes).forEach(([k, v]) => { el.setAttribute(k, v); });
|
|
14
14
|
|
|
15
15
|
document.head.appendChild(el);
|
|
16
16
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
// eslint-disable-next-line @typescript-eslint/consistent-type-imports
|
|
2
2
|
import type { TypedArray } from '../io/ArrayBuffers';
|
|
3
|
+
import { globalThis } from '../isomorphics/globalThis';
|
|
3
4
|
import { getNodeCrypto } from './getNodeCrypto';
|
|
4
5
|
|
|
5
6
|
export let getRandomValues: <T extends Exclude<TypedArray, Float32Array | Float64Array>>(typedArray: T) => T =
|
package/src/crypto/randomUUID.ts
CHANGED
|
@@ -53,11 +53,12 @@ export function createTranslate<T extends object>(obj?: Record<string, T>): Tran
|
|
|
53
53
|
}
|
|
54
54
|
if (process.env.NODE_ENV === 'development') {
|
|
55
55
|
if (val == null) {
|
|
56
|
-
|
|
56
|
+
console.error(
|
|
57
57
|
`[Translate] Missing the "${[].concat(key as any).join('.')}" key within the "${
|
|
58
58
|
lang || locale
|
|
59
59
|
}" dictionary`,
|
|
60
60
|
);
|
|
61
|
+
return;
|
|
61
62
|
}
|
|
62
63
|
}
|
|
63
64
|
if (typeof val === 'function') return val(params);
|
package/src/index.ts
CHANGED
|
@@ -72,6 +72,7 @@ export { getFileFromDataTransfer } from './browsers/getFileFromDataTransfer';
|
|
|
72
72
|
|
|
73
73
|
// polyfills
|
|
74
74
|
export { getGlobalThis } from './isomorphics/getGlobalThis';
|
|
75
|
+
export { globalThis } from './isomorphics/globalThis';
|
|
75
76
|
export { structuredClone } from './isomorphics/structuredClone';
|
|
76
77
|
|
|
77
78
|
// crypto
|
|
@@ -86,3 +87,6 @@ export { PEM } from './crypto/pem/pem';
|
|
|
86
87
|
export { createRandom } from './maths/random';
|
|
87
88
|
|
|
88
89
|
export { type FetchLike } from './fetch';
|
|
90
|
+
|
|
91
|
+
// bundled
|
|
92
|
+
export { default as ms } from './libs/ms';
|
package/src/io/ArrayBuffers.ts
CHANGED
package/src/io/isTransferable.ts
CHANGED
|
@@ -5,6 +5,8 @@ declare const global: typeof globalThis;
|
|
|
5
5
|
*
|
|
6
6
|
* globalThis supported by ff 65, Chrome 71, Node 12, babel
|
|
7
7
|
*
|
|
8
|
+
* non-standard globalThis supported for Alipay Miniprogram
|
|
9
|
+
*
|
|
8
10
|
* @see https://caniuse.com/#search=globalThis
|
|
9
11
|
* @see https://v8.dev/features/globalthis
|
|
10
12
|
*/
|
|
@@ -13,6 +15,6 @@ export const getGlobalThis = (): typeof globalThis => {
|
|
|
13
15
|
if (typeof self !== 'undefined') return self;
|
|
14
16
|
if (typeof window !== 'undefined') return window;
|
|
15
17
|
if (typeof global !== 'undefined') return global as any;
|
|
16
|
-
|
|
18
|
+
if (typeof this !== 'undefined') return this as any;
|
|
17
19
|
throw new Error('Unable to locate global `this`');
|
|
18
20
|
};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export function parseBoolean(s: string | boolean | number | null | undefined, strict: true): boolean | undefined;
|
|
2
|
-
export function parseBoolean(s: string | boolean | number | null | undefined): boolean;
|
|
2
|
+
export function parseBoolean(s: string | boolean | number | null | undefined | any): boolean;
|
|
3
3
|
export function parseBoolean(s?: string | boolean | number | null, strict = false): boolean | undefined {
|
|
4
4
|
if (typeof s === 'boolean') {
|
|
5
5
|
return s;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
- https://github.com/vercel/ms/blob/master/src/index.ts
|