@wener/utils 1.1.2 → 1.1.3

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.
Files changed (139) hide show
  1. package/dist/cjs/index.js +1 -578
  2. package/dist/cjs/index.js.map +1 -1
  3. package/dist/cjs/server.js +2 -0
  4. package/dist/cjs/server.js.map +1 -0
  5. package/dist/esm/index.js +2 -0
  6. package/dist/esm/index.js.map +1 -0
  7. package/dist/esm/server.js +2 -0
  8. package/dist/esm/server.js.map +1 -0
  9. package/dist/system/index.js +2 -0
  10. package/dist/system/index.js.map +1 -0
  11. package/dist/system/server.js +2 -0
  12. package/dist/system/server.js.map +1 -0
  13. package/index.ts +1 -0
  14. package/lib/arrays/MaybeArray.js +30 -0
  15. package/lib/arrays/MaybeArray.js.map +1 -0
  16. package/lib/asyncs/AsyncInterval.js +15 -0
  17. package/lib/asyncs/AsyncInterval.js.map +1 -0
  18. package/lib/asyncs/LazyPromise.js +27 -0
  19. package/lib/asyncs/LazyPromise.js.map +1 -0
  20. package/lib/asyncs/isPromise.js +6 -0
  21. package/lib/asyncs/isPromise.js.map +1 -0
  22. package/lib/{esm/asyncs/sleep.mjs → asyncs/sleep.js} +1 -1
  23. package/lib/asyncs/sleep.js.map +1 -0
  24. package/lib/asyncs/timeout.js +27 -0
  25. package/lib/asyncs/timeout.js.map +1 -0
  26. package/lib/browsers/copy.js +51 -0
  27. package/lib/browsers/copy.js.map +1 -0
  28. package/lib/browsers/download.js +28 -0
  29. package/lib/browsers/download.js.map +1 -0
  30. package/lib/browsers/getFileFromDataTransfer.js +31 -0
  31. package/lib/browsers/getFileFromDataTransfer.js.map +1 -0
  32. package/lib/browsers/loaders.js +50 -0
  33. package/lib/browsers/loaders.js.map +1 -0
  34. package/lib/crypto/hashing.js +24 -0
  35. package/lib/crypto/hashing.js.map +1 -0
  36. package/lib/crypto/hex.js +6 -0
  37. package/lib/crypto/hex.js.map +1 -0
  38. package/lib/crypto/randomUUID.js +13 -0
  39. package/lib/crypto/randomUUID.js.map +1 -0
  40. package/lib/formats/formatBytes.js +17 -0
  41. package/lib/formats/formatBytes.js.map +1 -0
  42. package/lib/index.js +27 -0
  43. package/lib/index.js.map +1 -0
  44. package/lib/io/isBuffer.js +6 -0
  45. package/lib/io/isBuffer.js.map +1 -0
  46. package/lib/isomorphics/getGlobalThis.js +14 -0
  47. package/lib/isomorphics/getGlobalThis.js.map +1 -0
  48. package/lib/maths/random.js +17 -0
  49. package/lib/maths/random.js.map +1 -0
  50. package/lib/modules/parseModuleId.js +31 -0
  51. package/lib/modules/parseModuleId.js.map +1 -0
  52. package/lib/server/polyfill.js +8 -0
  53. package/lib/server/polyfill.js.map +1 -0
  54. package/lib/server.js +2 -0
  55. package/lib/server.js.map +1 -0
  56. package/lib/shim/urljoin.js +51 -0
  57. package/lib/shim/urljoin.js.map +1 -0
  58. package/lib/strings/camelCase.js +56 -0
  59. package/lib/strings/camelCase.js.map +1 -0
  60. package/lib/strings/templates.js +8 -0
  61. package/lib/strings/templates.js.map +1 -0
  62. package/lib/validations/dequal.js +95 -0
  63. package/lib/validations/dequal.js.map +1 -0
  64. package/lib/validations/isClass.js +6 -0
  65. package/lib/validations/isClass.js.map +1 -0
  66. package/lib/validations/isDefined.js +6 -0
  67. package/lib/validations/isDefined.js.map +1 -0
  68. package/lib/validations/isEmptyObject.js +9 -0
  69. package/lib/validations/isEmptyObject.js.map +1 -0
  70. package/lib/validations/shallow.js +21 -0
  71. package/lib/validations/shallow.js.map +1 -0
  72. package/package.json +37 -35
  73. package/server.ts +1 -0
  74. package/src/arrays/MaybeArray.ts +8 -4
  75. package/src/crypto/randomUUID.ts +3 -0
  76. package/src/index.ts +13 -1
  77. package/src/modules/parseModuleId.test.ts +68 -0
  78. package/src/modules/parseModuleId.ts +46 -0
  79. package/src/server/polyfill.ts +5 -0
  80. package/src/server.ts +1 -0
  81. package/src/shim/urljoin.test.ts +1 -1
  82. package/src/validations/dequal.test.ts +17 -0
  83. package/src/validations/dequal.ts +105 -0
  84. package/src/validations/shallow.ts +26 -0
  85. package/dist/esm/index.development.js +0 -545
  86. package/dist/esm/index.development.js.map +0 -1
  87. package/dist/esm/index.min.js +0 -2
  88. package/dist/esm/index.min.js.map +0 -1
  89. package/dist/system/index.development.js +0 -585
  90. package/dist/system/index.development.js.map +0 -1
  91. package/dist/system/index.min.js +0 -2
  92. package/dist/system/index.min.js.map +0 -1
  93. package/lib/esm/arrays/MaybeArray.mjs +0 -30
  94. package/lib/esm/arrays/MaybeArray.mjs.map +0 -1
  95. package/lib/esm/asyncs/AsyncInterval.mjs +0 -15
  96. package/lib/esm/asyncs/AsyncInterval.mjs.map +0 -1
  97. package/lib/esm/asyncs/LazyPromise.mjs +0 -24
  98. package/lib/esm/asyncs/LazyPromise.mjs.map +0 -1
  99. package/lib/esm/asyncs/isPromise.mjs +0 -6
  100. package/lib/esm/asyncs/isPromise.mjs.map +0 -1
  101. package/lib/esm/asyncs/sleep.mjs.map +0 -1
  102. package/lib/esm/asyncs/timeout.mjs +0 -24
  103. package/lib/esm/asyncs/timeout.mjs.map +0 -1
  104. package/lib/esm/browsers/copy.mjs +0 -57
  105. package/lib/esm/browsers/copy.mjs.map +0 -1
  106. package/lib/esm/browsers/download.mjs +0 -40
  107. package/lib/esm/browsers/download.mjs.map +0 -1
  108. package/lib/esm/browsers/getFileFromDataTransfer.mjs +0 -39
  109. package/lib/esm/browsers/getFileFromDataTransfer.mjs.map +0 -1
  110. package/lib/esm/browsers/loaders.mjs +0 -52
  111. package/lib/esm/browsers/loaders.mjs.map +0 -1
  112. package/lib/esm/crypto/hashing.mjs +0 -25
  113. package/lib/esm/crypto/hashing.mjs.map +0 -1
  114. package/lib/esm/crypto/hex.mjs +0 -8
  115. package/lib/esm/crypto/hex.mjs.map +0 -1
  116. package/lib/esm/crypto/randomUUID.mjs +0 -13
  117. package/lib/esm/crypto/randomUUID.mjs.map +0 -1
  118. package/lib/esm/formats/formatBytes.mjs +0 -29
  119. package/lib/esm/formats/formatBytes.mjs.map +0 -1
  120. package/lib/esm/index.mjs +0 -24
  121. package/lib/esm/index.mjs.map +0 -1
  122. package/lib/esm/io/isBuffer.mjs +0 -10
  123. package/lib/esm/io/isBuffer.mjs.map +0 -1
  124. package/lib/esm/isomorphics/getGlobalThis.mjs +0 -23
  125. package/lib/esm/isomorphics/getGlobalThis.mjs.map +0 -1
  126. package/lib/esm/maths/random.mjs +0 -18
  127. package/lib/esm/maths/random.mjs.map +0 -1
  128. package/lib/esm/shim/urljoin.mjs +0 -65
  129. package/lib/esm/shim/urljoin.mjs.map +0 -1
  130. package/lib/esm/strings/camelCase.mjs +0 -70
  131. package/lib/esm/strings/camelCase.mjs.map +0 -1
  132. package/lib/esm/strings/templates.mjs +0 -16
  133. package/lib/esm/strings/templates.mjs.map +0 -1
  134. package/lib/esm/validations/isClass.mjs +0 -6
  135. package/lib/esm/validations/isClass.mjs.map +0 -1
  136. package/lib/esm/validations/isDefined.mjs +0 -6
  137. package/lib/esm/validations/isDefined.mjs.map +0 -1
  138. package/lib/esm/validations/isEmptyObject.mjs +0 -9
  139. package/lib/esm/validations/isEmptyObject.mjs.map +0 -1
@@ -0,0 +1,51 @@
1
+ let _copy;
2
+ function initCopy() {
3
+ let textArea;
4
+ function isIOS() {
5
+ return navigator.userAgent.match(/ipad|iphone/i);
6
+ }
7
+ function createTextArea(text) {
8
+ textArea = document.createElement("textArea");
9
+ textArea.value = text;
10
+ document.body.appendChild(textArea);
11
+ }
12
+ function selectText() {
13
+ let range, selection;
14
+ if (isIOS()) {
15
+ range = document.createRange();
16
+ range.selectNodeContents(textArea);
17
+ selection = window.getSelection();
18
+ if (selection === null) {
19
+ console.error(`no selection`);
20
+ return;
21
+ }
22
+ selection.removeAllRanges();
23
+ selection.addRange(range);
24
+ textArea.setSelectionRange(0, 999999);
25
+ } else {
26
+ textArea.select();
27
+ }
28
+ }
29
+ function copyToClipboard() {
30
+ document.execCommand("copy");
31
+ document.body.removeChild(textArea);
32
+ }
33
+ _copy = (text) => {
34
+ createTextArea(text);
35
+ selectText();
36
+ copyToClipboard();
37
+ };
38
+ }
39
+ function copy(content) {
40
+ if (window.navigator?.clipboard?.writeText) {
41
+ window.navigator.clipboard.writeText(content);
42
+ return;
43
+ }
44
+ if (!_copy) {
45
+ initCopy();
46
+ }
47
+ _copy(content);
48
+ }
49
+
50
+ export { copy };
51
+ //# sourceMappingURL=copy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"copy.js","sources":["../../src/browsers/copy.ts"],"sourcesContent":["// https://gist.github.com/rproenca/64781c6a1329b48a455b645d361a9aa3\nlet _copy: (s: any) => void;\n\nfunction initCopy() {\n let textArea: HTMLTextAreaElement;\n\n function isIOS() {\n return navigator.userAgent.match(/ipad|iphone/i);\n }\n\n function createTextArea(text: string) {\n textArea = document.createElement('textArea') as HTMLTextAreaElement;\n textArea.value = text;\n document.body.appendChild(textArea);\n }\n\n function selectText() {\n let range, selection;\n\n if (isIOS()) {\n range = document.createRange();\n range.selectNodeContents(textArea);\n selection = window.getSelection();\n if (selection === null) {\n console.error(`no selection`);\n return;\n }\n selection.removeAllRanges();\n selection.addRange(range);\n textArea.setSelectionRange(0, 999999);\n } else {\n textArea.select();\n }\n }\n\n function copyToClipboard() {\n document.execCommand('copy');\n document.body.removeChild(textArea);\n }\n\n _copy = (text) => {\n createTextArea(text);\n selectText();\n copyToClipboard();\n };\n}\n\n/**\n * Write text to clipboard\n * @param content content\n */\nexport function copy(content: string) {\n if (window.navigator?.clipboard?.writeText) {\n window.navigator.clipboard.writeText(content);\n return;\n }\n if (!_copy) {\n initCopy();\n }\n _copy(content);\n}\n"],"names":[],"mappings":"AACA,IAAI,KAAA,CAAA;AAEJ,SAAS,QAAW,GAAA;AAClB,EAAI,IAAA,QAAA,CAAA;AAEJ,EAAA,SAAS,KAAQ,GAAA;AACf,IAAO,OAAA,SAAA,CAAU,SAAU,CAAA,KAAA,CAAM,cAAc,CAAA,CAAA;AAAA,GACjD;AAEA,EAAA,SAAS,eAAe,IAAc,EAAA;AACpC,IAAW,QAAA,GAAA,QAAA,CAAS,cAAc,UAAU,CAAA,CAAA;AAC5C,IAAA,QAAA,CAAS,KAAQ,GAAA,IAAA,CAAA;AACjB,IAAS,QAAA,CAAA,IAAA,CAAK,YAAY,QAAQ,CAAA,CAAA;AAAA,GACpC;AAEA,EAAA,SAAS,UAAa,GAAA;AACpB,IAAA,IAAI,KAAO,EAAA,SAAA,CAAA;AAEX,IAAA,IAAI,OAAS,EAAA;AACX,MAAA,KAAA,GAAQ,SAAS,WAAY,EAAA,CAAA;AAC7B,MAAA,KAAA,CAAM,mBAAmB,QAAQ,CAAA,CAAA;AACjC,MAAA,SAAA,GAAY,OAAO,YAAa,EAAA,CAAA;AAChC,MAAA,IAAI,cAAc,IAAM,EAAA;AACtB,QAAA,OAAA,CAAQ,MAAM,CAAc,YAAA,CAAA,CAAA,CAAA;AAC5B,QAAA,OAAA;AAAA,OACF;AACA,MAAA,SAAA,CAAU,eAAgB,EAAA,CAAA;AAC1B,MAAA,SAAA,CAAU,SAAS,KAAK,CAAA,CAAA;AACxB,MAAS,QAAA,CAAA,iBAAA,CAAkB,GAAG,MAAM,CAAA,CAAA;AAAA,KAC/B,MAAA;AACL,MAAA,QAAA,CAAS,MAAO,EAAA,CAAA;AAAA,KAClB;AAAA,GACF;AAEA,EAAA,SAAS,eAAkB,GAAA;AACzB,IAAA,QAAA,CAAS,YAAY,MAAM,CAAA,CAAA;AAC3B,IAAS,QAAA,CAAA,IAAA,CAAK,YAAY,QAAQ,CAAA,CAAA;AAAA,GACpC;AAEA,EAAA,KAAA,GAAQ,CAAC,IAAS,KAAA;AAChB,IAAA,cAAA,CAAe,IAAI,CAAA,CAAA;AACnB,IAAW,UAAA,EAAA,CAAA;AACX,IAAgB,eAAA,EAAA,CAAA;AAAA,GAClB,CAAA;AACF,CAAA;AAMO,SAAS,KAAK,OAAiB,EAAA;AACpC,EAAI,IAAA,MAAA,CAAO,SAAW,EAAA,SAAA,EAAW,SAAW,EAAA;AAC1C,IAAO,MAAA,CAAA,SAAA,CAAU,SAAU,CAAA,SAAA,CAAU,OAAO,CAAA,CAAA;AAC5C,IAAA,OAAA;AAAA,GACF;AACA,EAAA,IAAI,CAAC,KAAO,EAAA;AACV,IAAS,QAAA,EAAA,CAAA;AAAA,GACX;AACA,EAAA,KAAA,CAAM,OAAO,CAAA,CAAA;AACf;;;;"}
@@ -0,0 +1,28 @@
1
+ function download(filename, data, { type = "application/octet-stream", raw = false } = {}) {
2
+ const a = document.createElement("a");
3
+ let closer = () => null;
4
+ try {
5
+ a.download = filename;
6
+ if (typeof data === "string" && /^(https?:|data:)/.test(data) && !raw) {
7
+ a.href = data;
8
+ } else if (typeof data === "string") {
9
+ data = new TextEncoder().encode(data);
10
+ }
11
+ if (data instanceof Uint8Array) {
12
+ data = new Blob([data], { type });
13
+ }
14
+ if (data instanceof File || data instanceof Blob || data instanceof MediaSource) {
15
+ a.href = URL.createObjectURL(data);
16
+ closer = () => URL.revokeObjectURL(a.href);
17
+ } else {
18
+ console.error(`invalid download data`, data);
19
+ throw new Error(`can not download ${Object.getPrototypeOf(data)}`);
20
+ }
21
+ a.click();
22
+ } finally {
23
+ closer();
24
+ }
25
+ }
26
+
27
+ export { download };
28
+ //# sourceMappingURL=download.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"download.js","sources":["../../src/browsers/download.ts"],"sourcesContent":["/**\n * Trigger browser download\n * @param filename download as filename\n * @param data data or url to download\n * @param type content type\n * @param raw if true, data is treated as raw data, not url\n */\nexport function download(filename: string, data: any, { type = 'application/octet-stream', raw = false } = {}) {\n const a = document.createElement('a');\n let closer: () => void = () => null;\n try {\n a.download = filename;\n\n // console.info(`downloading ${name}`, data);\n\n // url or data url\n if (typeof data === 'string' && /^(https?:|data:)/.test(data) && !raw) {\n a.href = data;\n } else if (typeof data === 'string') {\n data = new TextEncoder().encode(data);\n }\n\n if (data instanceof Uint8Array) {\n data = new Blob([data], { type });\n }\n\n if (data instanceof File || data instanceof Blob || data instanceof MediaSource) {\n a.href = URL.createObjectURL(data);\n closer = () => URL.revokeObjectURL(a.href);\n } else {\n console.error(`invalid download data`, data);\n throw new Error(`can not download ${Object.getPrototypeOf(data)}`);\n }\n a.click();\n } finally {\n closer();\n }\n}\n"],"names":[],"mappings":"AAOgB,SAAA,QAAA,CAAS,QAAkB,EAAA,IAAA,EAAW,EAAE,IAAA,GAAO,4BAA4B,GAAM,GAAA,KAAA,EAAU,GAAA,EAAI,EAAA;AAC7G,EAAM,MAAA,CAAA,GAAI,QAAS,CAAA,aAAA,CAAc,GAAG,CAAA,CAAA;AACpC,EAAA,IAAI,SAAqB,MAAM,IAAA,CAAA;AAC/B,EAAI,IAAA;AACF,IAAA,CAAA,CAAE,QAAW,GAAA,QAAA,CAAA;AAKb,IAAI,IAAA,OAAO,SAAS,QAAY,IAAA,kBAAA,CAAmB,KAAK,IAAI,CAAA,IAAK,CAAC,GAAK,EAAA;AACrE,MAAA,CAAA,CAAE,IAAO,GAAA,IAAA,CAAA;AAAA,KACX,MAAA,IAAW,OAAO,IAAA,KAAS,QAAU,EAAA;AACnC,MAAA,IAAA,GAAO,IAAI,WAAA,EAAc,CAAA,MAAA,CAAO,IAAI,CAAA,CAAA;AAAA,KACtC;AAEA,IAAA,IAAI,gBAAgB,UAAY,EAAA;AAC9B,MAAA,IAAA,GAAO,IAAI,IAAK,CAAA,CAAC,IAAI,CAAG,EAAA,EAAE,MAAM,CAAA,CAAA;AAAA,KAClC;AAEA,IAAA,IAAI,IAAgB,YAAA,IAAA,IAAQ,IAAgB,YAAA,IAAA,IAAQ,gBAAgB,WAAa,EAAA;AAC/E,MAAE,CAAA,CAAA,IAAA,GAAO,GAAI,CAAA,eAAA,CAAgB,IAAI,CAAA,CAAA;AACjC,MAAA,MAAA,GAAS,MAAM,GAAA,CAAI,eAAgB,CAAA,CAAA,CAAE,IAAI,CAAA,CAAA;AAAA,KACpC,MAAA;AACL,MAAQ,OAAA,CAAA,KAAA,CAAM,yBAAyB,IAAI,CAAA,CAAA;AAC3C,MAAA,MAAM,IAAI,KAAM,CAAA,CAAA,iBAAA,EAAoB,MAAO,CAAA,cAAA,CAAe,IAAI,CAAG,CAAA,CAAA,CAAA,CAAA;AAAA,KACnE;AACA,IAAA,CAAA,CAAE,KAAM,EAAA,CAAA;AAAA,GACR,SAAA;AACA,IAAO,MAAA,EAAA,CAAA;AAAA,GACT;AACF;;;;"}
@@ -0,0 +1,31 @@
1
+ function getFileFromDataTransfer(dataTransfer) {
2
+ if (!dataTransfer) {
3
+ return {};
4
+ }
5
+ const items = dataTransfer.items ?? [];
6
+ if (items.length >= 2 && items[0].kind === "string" && items[1].kind === "file") {
7
+ const text = dataTransfer.getData("text");
8
+ const file = items[1].getAsFile() ?? dataTransfer.files?.item(0);
9
+ if (!file) {
10
+ console.error(`no file ${text}`, items[1]);
11
+ return {};
12
+ }
13
+ return { file, name: text };
14
+ } else if (items[0].kind === "file") {
15
+ const file = items[0].getAsFile();
16
+ if (!file) {
17
+ console.error(`no file`, items[0]);
18
+ return {};
19
+ }
20
+ return { file, name: file.name };
21
+ } else {
22
+ console.debug(
23
+ `file item not match`,
24
+ Array.from(items).map((v) => ({ type: v.type, kind: v.kind }))
25
+ );
26
+ }
27
+ return {};
28
+ }
29
+
30
+ export { getFileFromDataTransfer };
31
+ //# sourceMappingURL=getFileFromDataTransfer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getFileFromDataTransfer.js","sources":["../../src/browsers/getFileFromDataTransfer.ts"],"sourcesContent":["export function getFileFromDataTransfer(dataTransfer?: DataTransfer | null): { file?: File; name?: string } {\n if (!dataTransfer) {\n return {};\n }\n\n const items: DataTransferItemList = dataTransfer.items ?? [];\n\n if (items.length >= 2 && items[0].kind === 'string' && items[1].kind === 'file') {\n // name, file\n const text = dataTransfer.getData('text');\n const file = items[1].getAsFile() ?? dataTransfer.files?.item(0);\n if (!file) {\n console.error(`no file ${text}`, items[1]);\n return {};\n }\n\n // let type = file.type;\n // // fix type\n // type = type;\n // // NOTE paste file can not parse by libs\n // if (type !== file.type) {\n // const blob = file.slice(0, file.size);\n // file = new File([blob], text, {type});\n // }\n\n return { file, name: text };\n } else if (items[0].kind === 'file') {\n const file = items[0].getAsFile();\n if (!file) {\n console.error(`no file`, items[0]);\n return {};\n }\n return { file, name: file.name };\n } else {\n console.debug(\n `file item not match`,\n Array.from(items).map((v) => ({ type: v.type, kind: v.kind })),\n );\n }\n return {};\n}\n"],"names":[],"mappings":"AAAO,SAAS,wBAAwB,YAAoE,EAAA;AAC1G,EAAA,IAAI,CAAC,YAAc,EAAA;AACjB,IAAA,OAAO,EAAC,CAAA;AAAA,GACV;AAEA,EAAM,MAAA,KAAA,GAA8B,YAAa,CAAA,KAAA,IAAS,EAAC,CAAA;AAE3D,EAAI,IAAA,KAAA,CAAM,MAAU,IAAA,CAAA,IAAK,KAAM,CAAA,CAAA,CAAA,CAAG,SAAS,QAAY,IAAA,KAAA,CAAM,CAAG,CAAA,CAAA,IAAA,KAAS,MAAQ,EAAA;AAE/E,IAAM,MAAA,IAAA,GAAO,YAAa,CAAA,OAAA,CAAQ,MAAM,CAAA,CAAA;AACxC,IAAM,MAAA,IAAA,GAAO,MAAM,CAAG,CAAA,CAAA,SAAA,MAAe,YAAa,CAAA,KAAA,EAAO,KAAK,CAAC,CAAA,CAAA;AAC/D,IAAA,IAAI,CAAC,IAAM,EAAA;AACT,MAAA,OAAA,CAAQ,KAAM,CAAA,CAAA,QAAA,EAAW,IAAQ,CAAA,CAAA,EAAA,KAAA,CAAM,CAAE,CAAA,CAAA,CAAA;AACzC,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAWA,IAAO,OAAA,EAAE,IAAM,EAAA,IAAA,EAAM,IAAK,EAAA,CAAA;AAAA,GACjB,MAAA,IAAA,KAAA,CAAM,CAAG,CAAA,CAAA,IAAA,KAAS,MAAQ,EAAA;AACnC,IAAM,MAAA,IAAA,GAAO,KAAM,CAAA,CAAA,CAAA,CAAG,SAAU,EAAA,CAAA;AAChC,IAAA,IAAI,CAAC,IAAM,EAAA;AACT,MAAQ,OAAA,CAAA,KAAA,CAAM,CAAW,OAAA,CAAA,EAAA,KAAA,CAAM,CAAE,CAAA,CAAA,CAAA;AACjC,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AACA,IAAA,OAAO,EAAE,IAAA,EAAM,IAAM,EAAA,IAAA,CAAK,IAAK,EAAA,CAAA;AAAA,GAC1B,MAAA;AACL,IAAQ,OAAA,CAAA,KAAA;AAAA,MACN,CAAA,mBAAA,CAAA;AAAA,MACA,KAAM,CAAA,IAAA,CAAK,KAAK,CAAA,CAAE,IAAI,CAAC,CAAA,MAAO,EAAE,IAAA,EAAM,CAAE,CAAA,IAAA,EAAM,IAAM,EAAA,CAAA,CAAE,MAAO,CAAA,CAAA;AAAA,KAC/D,CAAA;AAAA,GACF;AACA,EAAA,OAAO,EAAC,CAAA;AACV;;;;"}
@@ -0,0 +1,50 @@
1
+ function load(el, resolve, reject, options) {
2
+ el.onload = () => resolve(el);
3
+ el.onerror = (e) => {
4
+ el.remove();
5
+ reject(e);
6
+ };
7
+ const { attributes = {} } = options || {};
8
+ Object.entries(attributes).forEach(([k, v]) => el.setAttribute(k, v));
9
+ document.head.appendChild(el);
10
+ }
11
+ function loadScripts(src, options) {
12
+ if (Array.isArray(src)) {
13
+ return new Promise(async (resolve, reject) => {
14
+ const all = [];
15
+ try {
16
+ for (let s of src) {
17
+ all.push(await loadScripts(s));
18
+ }
19
+ } catch (e) {
20
+ reject(e);
21
+ return;
22
+ }
23
+ resolve(all);
24
+ });
25
+ }
26
+ let $ele = document.querySelector(`script[src="${src}"]`);
27
+ if ($ele) {
28
+ return Promise.resolve($ele);
29
+ }
30
+ return new Promise((resolve, reject) => {
31
+ const el = document.createElement("script");
32
+ el.src = src;
33
+ load(el, resolve, reject, options);
34
+ });
35
+ }
36
+ function loadStyles(href, options) {
37
+ let $ele = document.querySelector(`link[href="${href}"]`);
38
+ if ($ele) {
39
+ return Promise.resolve($ele);
40
+ }
41
+ return new Promise((resolve, reject) => {
42
+ const el = document.createElement("link");
43
+ el.rel = "stylesheet";
44
+ el.href = href;
45
+ load(el, resolve, reject, options);
46
+ });
47
+ }
48
+
49
+ export { loadScripts, loadStyles };
50
+ //# sourceMappingURL=loaders.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loaders.js","sources":["../../src/browsers/loaders.ts"],"sourcesContent":["function load(\n el: HTMLScriptElement | HTMLLinkElement,\n resolve: (v: any) => void,\n reject: (v: any) => void,\n options: { attributes: Record<string, string> } | undefined,\n) {\n el.onload = () => resolve(el);\n el.onerror = (e) => {\n el.remove();\n reject(e);\n };\n const { attributes = {} } = options || {};\n Object.entries(attributes).forEach(([k, v]) => el.setAttribute(k, v));\n\n document.head.appendChild(el);\n}\n\nexport function loadScripts(\n src: string[],\n options?: { attributes: Record<string, string> },\n): Promise<HTMLScriptElement[]>;\nexport function loadScripts(src: string, options?: { attributes: Record<string, string> }): Promise<HTMLScriptElement>;\n\nexport function loadScripts(\n src: string | string[],\n options?: { attributes: Record<string, string> },\n): Promise<HTMLScriptElement | HTMLScriptElement[]> {\n if (Array.isArray(src)) {\n return new Promise(async (resolve, reject) => {\n const all = [];\n try {\n for (let s of src) {\n all.push(await loadScripts(s));\n }\n } catch (e) {\n reject(e);\n return;\n }\n resolve(all);\n });\n }\n // todo quote ?\n let $ele = document.querySelector(`script[src=\"${src}\"]`) as HTMLScriptElement;\n if ($ele) {\n return Promise.resolve($ele);\n }\n return new Promise((resolve, reject) => {\n const el = document.createElement('script');\n el.src = src;\n load(el, resolve, reject, options);\n });\n}\n\nexport function loadStyles(href: string, options?: { attributes: Record<string, string> }): Promise<HTMLLinkElement> {\n let $ele = document.querySelector(`link[href=\"${href}\"]`) as HTMLLinkElement;\n if ($ele) {\n return Promise.resolve($ele);\n }\n\n return new Promise((resolve, reject) => {\n const el = document.createElement('link');\n el.rel = 'stylesheet';\n el.href = href;\n load(el, resolve, reject, options);\n });\n}\n"],"names":[],"mappings":"AAAA,SAAS,IACP,CAAA,EAAA,EACA,OACA,EAAA,MAAA,EACA,OACA,EAAA;AACA,EAAG,EAAA,CAAA,MAAA,GAAS,MAAM,OAAA,CAAQ,EAAE,CAAA,CAAA;AAC5B,EAAG,EAAA,CAAA,OAAA,GAAU,CAAC,CAAM,KAAA;AAClB,IAAA,EAAA,CAAG,MAAO,EAAA,CAAA;AACV,IAAA,MAAA,CAAO,CAAC,CAAA,CAAA;AAAA,GACV,CAAA;AACA,EAAA,MAAM,EAAE,UAAa,GAAA,EAAG,EAAA,GAAI,WAAW,EAAC,CAAA;AACxC,EAAA,MAAA,CAAO,OAAQ,CAAA,UAAU,CAAE,CAAA,OAAA,CAAQ,CAAC,CAAC,CAAG,EAAA,CAAC,CAAM,KAAA,EAAA,CAAG,YAAa,CAAA,CAAA,EAAG,CAAC,CAAC,CAAA,CAAA;AAEpE,EAAS,QAAA,CAAA,IAAA,CAAK,YAAY,EAAE,CAAA,CAAA;AAC9B,CAAA;AAQgB,SAAA,WAAA,CACd,KACA,OACkD,EAAA;AAClD,EAAI,IAAA,KAAA,CAAM,OAAQ,CAAA,GAAG,CAAG,EAAA;AACtB,IAAA,OAAO,IAAI,OAAA,CAAQ,OAAO,OAAA,EAAS,MAAW,KAAA;AAC5C,MAAA,MAAM,MAAM,EAAC,CAAA;AACb,MAAI,IAAA;AACF,QAAA,KAAA,IAAS,KAAK,GAAK,EAAA;AACjB,UAAA,GAAA,CAAI,IAAK,CAAA,MAAM,WAAY,CAAA,CAAC,CAAC,CAAA,CAAA;AAAA,SAC/B;AAAA,eACO,CAAP,EAAA;AACA,QAAA,MAAA,CAAO,CAAC,CAAA,CAAA;AACR,QAAA,OAAA;AAAA,OACF;AACA,MAAA,OAAA,CAAQ,GAAG,CAAA,CAAA;AAAA,KACZ,CAAA,CAAA;AAAA,GACH;AAEA,EAAA,IAAI,IAAO,GAAA,QAAA,CAAS,aAAc,CAAA,CAAA,YAAA,EAAe,GAAO,CAAA,EAAA,CAAA,CAAA,CAAA;AACxD,EAAA,IAAI,IAAM,EAAA;AACR,IAAO,OAAA,OAAA,CAAQ,QAAQ,IAAI,CAAA,CAAA;AAAA,GAC7B;AACA,EAAA,OAAO,IAAI,OAAA,CAAQ,CAAC,OAAA,EAAS,MAAW,KAAA;AACtC,IAAM,MAAA,EAAA,GAAK,QAAS,CAAA,aAAA,CAAc,QAAQ,CAAA,CAAA;AAC1C,IAAA,EAAA,CAAG,GAAM,GAAA,GAAA,CAAA;AACT,IAAK,IAAA,CAAA,EAAA,EAAI,OAAS,EAAA,MAAA,EAAQ,OAAO,CAAA,CAAA;AAAA,GAClC,CAAA,CAAA;AACH,CAAA;AAEgB,SAAA,UAAA,CAAW,MAAc,OAA4E,EAAA;AACnH,EAAA,IAAI,IAAO,GAAA,QAAA,CAAS,aAAc,CAAA,CAAA,WAAA,EAAc,IAAQ,CAAA,EAAA,CAAA,CAAA,CAAA;AACxD,EAAA,IAAI,IAAM,EAAA;AACR,IAAO,OAAA,OAAA,CAAQ,QAAQ,IAAI,CAAA,CAAA;AAAA,GAC7B;AAEA,EAAA,OAAO,IAAI,OAAA,CAAQ,CAAC,OAAA,EAAS,MAAW,KAAA;AACtC,IAAM,MAAA,EAAA,GAAK,QAAS,CAAA,aAAA,CAAc,MAAM,CAAA,CAAA;AACxC,IAAA,EAAA,CAAG,GAAM,GAAA,YAAA,CAAA;AACT,IAAA,EAAA,CAAG,IAAO,GAAA,IAAA,CAAA;AACV,IAAK,IAAA,CAAA,EAAA,EAAI,OAAS,EAAA,MAAA,EAAQ,OAAO,CAAA,CAAA;AAAA,GAClC,CAAA,CAAA;AACH;;;;"}
@@ -0,0 +1,24 @@
1
+ async function sha1(s) {
2
+ return digestOf("SHA-1", s);
3
+ }
4
+ async function sha256(s) {
5
+ return digestOf("SHA-256", s);
6
+ }
7
+ async function sha384(s) {
8
+ return digestOf("SHA-384", s);
9
+ }
10
+ async function sha512(s) {
11
+ return digestOf("SHA-512", s);
12
+ }
13
+ function digestOf(a, s) {
14
+ return crypto.subtle.digest(a, bufferOf(s));
15
+ }
16
+ function bufferOf(s) {
17
+ if (typeof s === "string") {
18
+ return new TextEncoder().encode(s);
19
+ }
20
+ return s;
21
+ }
22
+
23
+ export { sha1, sha256, sha384, sha512 };
24
+ //# sourceMappingURL=hashing.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hashing.js","sources":["../../src/crypto/hashing.ts"],"sourcesContent":["export async function sha1(s: string | BufferSource) {\n return digestOf('SHA-1', s);\n}\n\nexport async function sha256(s: string | BufferSource) {\n return digestOf('SHA-256', s);\n}\n\nexport async function sha384(s: string | BufferSource) {\n return digestOf('SHA-384', s);\n}\n\nexport async function sha512(s: string | BufferSource) {\n return digestOf('SHA-512', s);\n}\n\nfunction digestOf(a: string, s: string | BufferSource) {\n return crypto.subtle.digest(a, bufferOf(s));\n}\n\nfunction bufferOf(s: string | BufferSource) {\n // ArrayBuffer, TypedArray, DataView\n if (typeof s === 'string') {\n return new TextEncoder().encode(s);\n }\n return s;\n}\n"],"names":[],"mappings":"AAAA,eAAsB,KAAK,CAA0B,EAAA;AACnD,EAAO,OAAA,QAAA,CAAS,SAAS,CAAC,CAAA,CAAA;AAC5B,CAAA;AAEA,eAAsB,OAAO,CAA0B,EAAA;AACrD,EAAO,OAAA,QAAA,CAAS,WAAW,CAAC,CAAA,CAAA;AAC9B,CAAA;AAEA,eAAsB,OAAO,CAA0B,EAAA;AACrD,EAAO,OAAA,QAAA,CAAS,WAAW,CAAC,CAAA,CAAA;AAC9B,CAAA;AAEA,eAAsB,OAAO,CAA0B,EAAA;AACrD,EAAO,OAAA,QAAA,CAAS,WAAW,CAAC,CAAA,CAAA;AAC9B,CAAA;AAEA,SAAS,QAAA,CAAS,GAAW,CAA0B,EAAA;AACrD,EAAA,OAAO,OAAO,MAAO,CAAA,MAAA,CAAO,CAAG,EAAA,QAAA,CAAS,CAAC,CAAC,CAAA,CAAA;AAC5C,CAAA;AAEA,SAAS,SAAS,CAA0B,EAAA;AAE1C,EAAI,IAAA,OAAO,MAAM,QAAU,EAAA;AACzB,IAAA,OAAO,IAAI,WAAA,EAAc,CAAA,MAAA,CAAO,CAAC,CAAA,CAAA;AAAA,GACnC;AACA,EAAO,OAAA,CAAA,CAAA;AACT;;;;"}
@@ -0,0 +1,6 @@
1
+ function hex(s) {
2
+ return Array.from(new Uint8Array(s)).map((v) => v.toString(16).padStart(2, "0")).join("");
3
+ }
4
+
5
+ export { hex };
6
+ //# sourceMappingURL=hex.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hex.js","sources":["../../src/crypto/hex.ts"],"sourcesContent":["export function hex(s: Uint8Array | ArrayBuffer) {\n return Array.from(new Uint8Array(s))\n .map((v) => v.toString(16).padStart(2, '0'))\n .join('');\n}\n"],"names":[],"mappings":"AAAO,SAAS,IAAI,CAA6B,EAAA;AAC/C,EAAO,OAAA,KAAA,CAAM,KAAK,IAAI,UAAA,CAAW,CAAC,CAAC,CAAA,CAChC,IAAI,CAAC,CAAA,KAAM,EAAE,QAAS,CAAA,EAAE,EAAE,QAAS,CAAA,CAAA,EAAG,GAAG,CAAC,CAAA,CAC1C,KAAK,EAAE,CAAA,CAAA;AACZ;;;;"}
@@ -0,0 +1,13 @@
1
+ function randomUUID() {
2
+ if ("randomUUID" in crypto) {
3
+ return crypto.randomUUID();
4
+ }
5
+ return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, (c) => {
6
+ const r = Math.random() * 16 | 0;
7
+ const v = c === "x" ? r : r & 3 | 8;
8
+ return v.toString(16);
9
+ });
10
+ }
11
+
12
+ export { randomUUID };
13
+ //# sourceMappingURL=randomUUID.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"randomUUID.js","sources":["../../src/crypto/randomUUID.ts"],"sourcesContent":["/**\n * generate random UUIDv4\n */\nexport function randomUUID() {\n if ('randomUUID' in crypto) {\n return crypto.randomUUID();\n }\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n const r = (Math.random() * 16) | 0;\n const v = c === 'x' ? r : (r & 0x3) | 0x8;\n return v.toString(16);\n });\n}\n"],"names":[],"mappings":"AAGO,SAAS,UAAa,GAAA;AAC3B,EAAA,IAAI,gBAAgB,MAAQ,EAAA;AAC1B,IAAA,OAAO,OAAO,UAAW,EAAA,CAAA;AAAA,GAC3B;AACA,EAAA,OAAO,sCAAuC,CAAA,OAAA,CAAQ,OAAS,EAAA,CAAC,CAAM,KAAA;AACpE,IAAA,MAAM,CAAK,GAAA,IAAA,CAAK,MAAO,EAAA,GAAI,EAAM,GAAA,CAAA,CAAA;AACjC,IAAA,MAAM,CAAI,GAAA,CAAA,KAAM,GAAM,GAAA,CAAA,GAAK,IAAI,CAAO,GAAA,CAAA,CAAA;AACtC,IAAO,OAAA,CAAA,CAAE,SAAS,EAAE,CAAA,CAAA;AAAA,GACrB,CAAA,CAAA;AACH;;;;"}
@@ -0,0 +1,17 @@
1
+ function formatBytes(bytes, si = false, dp = 1) {
2
+ const thresh = si ? 1e3 : 1024;
3
+ if (Math.abs(bytes) < thresh) {
4
+ return bytes + " B";
5
+ }
6
+ const units = si ? ["kB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"] : ["KiB", "MiB", "GiB", "TiB", "PiB", "EiB", "ZiB", "YiB"];
7
+ let u = -1;
8
+ const r = 10 ** dp;
9
+ do {
10
+ bytes /= thresh;
11
+ ++u;
12
+ } while (Math.round(Math.abs(bytes) * r) / r >= thresh && u < units.length - 1);
13
+ return bytes.toFixed(dp) + " " + units[u];
14
+ }
15
+
16
+ export { formatBytes };
17
+ //# sourceMappingURL=formatBytes.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"formatBytes.js","sources":["../../src/formats/formatBytes.ts"],"sourcesContent":["/**\n * Format bytes as human-readable text.\n *\n * @param bytes Number of bytes.\n * @param si True to use metric (SI) units, aka powers of 1000. False to use\n * binary (IEC), aka powers of 1024.\n * @param dp Number of decimal places to display.\n *\n * @return Formatted string.\n */\nexport function formatBytes(bytes: number, si = false, dp = 1) {\n const thresh = si ? 1000 : 1024;\n\n if (Math.abs(bytes) < thresh) {\n return bytes + ' B';\n }\n\n const units = si\n ? ['kB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB']\n : ['KiB', 'MiB', 'GiB', 'TiB', 'PiB', 'EiB', 'ZiB', 'YiB'];\n let u = -1;\n const r = 10 ** dp;\n\n do {\n bytes /= thresh;\n ++u;\n } while (Math.round(Math.abs(bytes) * r) / r >= thresh && u < units.length - 1);\n\n return bytes.toFixed(dp) + ' ' + units[u];\n}\n"],"names":[],"mappings":"AAUO,SAAS,WAAY,CAAA,KAAA,EAAe,EAAK,GAAA,KAAA,EAAO,KAAK,CAAG,EAAA;AAC7D,EAAM,MAAA,MAAA,GAAS,KAAK,GAAO,GAAA,IAAA,CAAA;AAE3B,EAAA,IAAI,IAAK,CAAA,GAAA,CAAI,KAAK,CAAA,GAAI,MAAQ,EAAA;AAC5B,IAAA,OAAO,KAAQ,GAAA,IAAA,CAAA;AAAA,GACjB;AAEA,EAAM,MAAA,KAAA,GAAQ,KACV,CAAC,IAAA,EAAM,MAAM,IAAM,EAAA,IAAA,EAAM,MAAM,IAAM,EAAA,IAAA,EAAM,IAAI,CAC/C,GAAA,CAAC,OAAO,KAAO,EAAA,KAAA,EAAO,OAAO,KAAO,EAAA,KAAA,EAAO,OAAO,KAAK,CAAA,CAAA;AAC3D,EAAA,IAAI,CAAI,GAAA,CAAA,CAAA,CAAA;AACR,EAAA,MAAM,IAAI,EAAM,IAAA,EAAA,CAAA;AAEhB,EAAG,GAAA;AACD,IAAS,KAAA,IAAA,MAAA,CAAA;AACT,IAAE,EAAA,CAAA,CAAA;AAAA,GACK,QAAA,IAAA,CAAK,KAAM,CAAA,IAAA,CAAK,GAAI,CAAA,KAAK,CAAI,GAAA,CAAC,CAAI,GAAA,CAAA,IAAK,MAAU,IAAA,CAAA,GAAI,MAAM,MAAS,GAAA,CAAA,EAAA;AAE7E,EAAA,OAAO,KAAM,CAAA,OAAA,CAAQ,EAAE,CAAA,GAAI,MAAM,KAAM,CAAA,CAAA,CAAA,CAAA;AACzC;;;;"}
package/lib/index.js ADDED
@@ -0,0 +1,27 @@
1
+ export { arrayOfMaybeArray, firstOfMaybeArray, lastOfMaybeArray, objectOfMaybeArray } from './arrays/MaybeArray.js';
2
+ export { createLazyPromise } from './asyncs/LazyPromise.js';
3
+ export { clearAsyncInterval, setAsyncInterval } from './asyncs/AsyncInterval.js';
4
+ export { sleep } from './asyncs/sleep.js';
5
+ export { TimeoutError, timeout } from './asyncs/timeout.js';
6
+ export { isPromise } from './asyncs/isPromise.js';
7
+ export { isClass } from './validations/isClass.js';
8
+ export { isDefined } from './validations/isDefined.js';
9
+ export { isEmptyObject } from './validations/isEmptyObject.js';
10
+ export { shallow } from './validations/shallow.js';
11
+ export { dequal } from './validations/dequal.js';
12
+ export { parseModuleId } from './modules/parseModuleId.js';
13
+ export { camelCase, pascalCase } from './strings/camelCase.js';
14
+ export { templateString } from './strings/templates.js';
15
+ export { createRandom } from './maths/random.js';
16
+ export { isBuffer } from './io/isBuffer.js';
17
+ export { copy } from './browsers/copy.js';
18
+ export { download } from './browsers/download.js';
19
+ export { loadScripts, loadStyles } from './browsers/loaders.js';
20
+ export { getFileFromDataTransfer } from './browsers/getFileFromDataTransfer.js';
21
+ export { getGlobalThis } from './isomorphics/getGlobalThis.js';
22
+ export { formatBytes } from './formats/formatBytes.js';
23
+ export { urljoin } from './shim/urljoin.js';
24
+ export { randomUUID } from './crypto/randomUUID.js';
25
+ export { sha1, sha256, sha384, sha512 } from './crypto/hashing.js';
26
+ export { hex } from './crypto/hex.js';
27
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,6 @@
1
+ function isBuffer(obj) {
2
+ return obj != null && obj.constructor != null && typeof obj.constructor.isBuffer === "function" && obj.constructor.isBuffer(obj);
3
+ }
4
+
5
+ export { isBuffer };
6
+ //# sourceMappingURL=isBuffer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isBuffer.js","sources":["../../src/io/isBuffer.ts"],"sourcesContent":["// https://github.com/feross/is-buffer/blob/master/index.js\nexport function isBuffer(obj: any): obj is Buffer {\n return (\n obj != null &&\n obj.constructor != null &&\n typeof obj.constructor.isBuffer === 'function' &&\n obj.constructor.isBuffer(obj)\n );\n}\n"],"names":[],"mappings":"AACO,SAAS,SAAS,GAAyB,EAAA;AAChD,EAAA,OACE,GAAO,IAAA,IAAA,IACP,GAAI,CAAA,WAAA,IAAe,IACnB,IAAA,OAAO,GAAI,CAAA,WAAA,CAAY,QAAa,KAAA,UAAA,IACpC,GAAI,CAAA,WAAA,CAAY,SAAS,GAAG,CAAA,CAAA;AAEhC;;;;"}
@@ -0,0 +1,14 @@
1
+ const getGlobalThis = () => {
2
+ if (typeof globalThis !== "undefined")
3
+ return globalThis;
4
+ if (typeof self !== "undefined")
5
+ return self;
6
+ if (typeof window !== "undefined")
7
+ return window;
8
+ if (typeof global !== "undefined")
9
+ return global;
10
+ throw new Error("Unable to locate global `this`");
11
+ };
12
+
13
+ export { getGlobalThis };
14
+ //# sourceMappingURL=getGlobalThis.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getGlobalThis.js","sources":["../../src/isomorphics/getGlobalThis.ts"],"sourcesContent":["declare const global: typeof globalThis;\n\n/**\n * isomorphic globalThis\n *\n * globalThis supported by ff 65, Chrome 71, Node 12, babel\n *\n * @see https://caniuse.com/#search=globalThis\n * @see https://v8.dev/features/globalthis\n */\nexport const getGlobalThis = (): typeof globalThis => {\n if (typeof globalThis !== 'undefined') return globalThis;\n if (typeof self !== 'undefined') return self;\n if (typeof window !== 'undefined') return window;\n if (typeof global !== 'undefined') return global as any;\n // if (typeof this !== 'undefined') return this;\n throw new Error('Unable to locate global `this`');\n};\n"],"names":[],"mappings":"AAUO,MAAM,gBAAgB,MAAyB;AACpD,EAAA,IAAI,OAAO,UAAe,KAAA,WAAA;AAAa,IAAO,OAAA,UAAA,CAAA;AAC9C,EAAA,IAAI,OAAO,IAAS,KAAA,WAAA;AAAa,IAAO,OAAA,IAAA,CAAA;AACxC,EAAA,IAAI,OAAO,MAAW,KAAA,WAAA;AAAa,IAAO,OAAA,MAAA,CAAA;AAC1C,EAAA,IAAI,OAAO,MAAW,KAAA,WAAA;AAAa,IAAO,OAAA,MAAA,CAAA;AAE1C,EAAM,MAAA,IAAI,MAAM,gCAAgC,CAAA,CAAA;AAClD;;;;"}
@@ -0,0 +1,17 @@
1
+ function createRandom(o = {}) {
2
+ let seed = typeof o.seed === "string" ? 0 : o.seed ?? 0;
3
+ if (typeof o.seed === "string") {
4
+ let sum = 0;
5
+ for (let i = 0; i < o.seed.length; i++) {
6
+ sum += o.seed.charCodeAt(i);
7
+ }
8
+ seed = sum;
9
+ }
10
+ return () => {
11
+ const x = Math.sin(seed++) * 1e4;
12
+ return x - Math.floor(x);
13
+ };
14
+ }
15
+
16
+ export { createRandom };
17
+ //# sourceMappingURL=random.js.map
@@ -0,0 +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;AAC/D,EAAA,IAAI,OAAO,OAAO,CAAA,CAAE,SAAS,QAAW,GAAA,CAAA,GAAI,EAAE,IAAQ,IAAA,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;;;;"}
@@ -0,0 +1,31 @@
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
+ function parseModuleId(s) {
3
+ const groups = s.match(regModuleId)?.groups;
4
+ if (!groups) {
5
+ return void 0;
6
+ }
7
+ const { n: name, v: version, p: path, org, pkg } = groups;
8
+ let scoped = Boolean(org);
9
+ const v = /^\d+\.\d+\.\d+/.test(version) ? version : void 0;
10
+ let range = version || "latest";
11
+ const o = {
12
+ id: `${name}@${range}`,
13
+ name,
14
+ range,
15
+ scoped,
16
+ pkg
17
+ };
18
+ if (v) {
19
+ o.version = v;
20
+ }
21
+ if (path) {
22
+ o.path = path;
23
+ }
24
+ if (o.scoped) {
25
+ o.org = org;
26
+ }
27
+ return o;
28
+ }
29
+
30
+ export { parseModuleId };
31
+ //# sourceMappingURL=parseModuleId.js.map
@@ -0,0 +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} & (\n | { scoped: false }\n | {\n scoped: true;\n org?: string;\n }\n);\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 let scoped = Boolean(org);\n const v = /^\\d+\\.\\d+\\.\\d+/.test(version) ? version : undefined;\n let range = version || 'latest';\n const o = {\n id: `${name}@${range}`,\n name,\n range: range,\n scoped,\n pkg,\n } as ParsedModuleId;\n if (v) {\n o.version = v;\n }\n if (path) {\n o.path = path;\n }\n if (o.scoped) {\n o.org = org;\n }\n return o;\n}\n"],"names":[],"mappings":"AACA,MAAM,WACJ,GAAA,8HAAA,CAAA;AAiBK,SAAS,cAAc,CAAuC,EAAA;AACnE,EAAA,MAAM,MAAS,GAAA,CAAA,CAAE,KAAM,CAAA,WAAW,CAAG,EAAA,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,EAAI,IAAA,MAAA,GAAS,QAAQ,GAAG,CAAA,CAAA;AACxB,EAAA,MAAM,CAAI,GAAA,gBAAA,CAAiB,IAAK,CAAA,OAAO,IAAI,OAAU,GAAA,KAAA,CAAA,CAAA;AACrD,EAAA,IAAI,QAAQ,OAAW,IAAA,QAAA,CAAA;AACvB,EAAA,MAAM,CAAI,GAAA;AAAA,IACR,EAAA,EAAI,GAAG,IAAQ,CAAA,CAAA,EAAA,KAAA,CAAA,CAAA;AAAA,IACf,IAAA;AAAA,IACA,KAAA;AAAA,IACA,MAAA;AAAA,IACA,GAAA;AAAA,GACF,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,EAAA,IAAI,EAAE,MAAQ,EAAA;AACZ,IAAA,CAAA,CAAE,GAAM,GAAA,GAAA,CAAA;AAAA,GACV;AACA,EAAO,OAAA,CAAA,CAAA;AACT;;;;"}
@@ -0,0 +1,8 @@
1
+ async function polyfill() {
2
+ if (!("crypto" in globalThis)) {
3
+ globalThis.crypto = (await import('node:crypto')).webcrypto;
4
+ }
5
+ }
6
+
7
+ export { polyfill };
8
+ //# sourceMappingURL=polyfill.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"polyfill.js","sources":["../../src/server/polyfill.ts"],"sourcesContent":["export async function polyfill() {\n if (!('crypto' in globalThis)) {\n (globalThis as any).crypto = (await import('node:crypto')).webcrypto;\n }\n}\n"],"names":[],"mappings":"AAAA,eAAsB,QAAW,GAAA;AAC/B,EAAI,IAAA,EAAE,YAAY,UAAa,CAAA,EAAA;AAC7B,IAAC,UAAmB,CAAA,MAAA,GAAA,CAAU,MAAM,OAAO,aAAgB,CAAA,EAAA,SAAA,CAAA;AAAA,GAC7D;AACF;;;;"}
package/lib/server.js ADDED
@@ -0,0 +1,2 @@
1
+ export { polyfill } from './server/polyfill.js';
2
+ //# sourceMappingURL=server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,51 @@
1
+ function urljoin(...args) {
2
+ if (Array.isArray(args[0])) {
3
+ return normalize(args[0]);
4
+ } else {
5
+ return normalize(args);
6
+ }
7
+ }
8
+ function normalize(strArray) {
9
+ const resultArray = [];
10
+ if (strArray.length === 0) {
11
+ return "";
12
+ }
13
+ if (typeof strArray[0] !== "string") {
14
+ throw new TypeError("Url must be a string. Received " + strArray[0]);
15
+ }
16
+ if (strArray[0].match(/^[^/:]+:\/*$/) && strArray.length > 1) {
17
+ const first = strArray.shift();
18
+ strArray[0] = first + strArray[0];
19
+ }
20
+ if (strArray[0].match(/^file:\/\/\//)) {
21
+ strArray[0] = strArray[0].replace(/^([^/:]+):\/*/, "$1:///");
22
+ } else {
23
+ strArray[0] = strArray[0].replace(/^([^/:]+):\/*/, "$1://");
24
+ }
25
+ for (let i = 0; i < strArray.length; i++) {
26
+ let component = strArray[i];
27
+ if (typeof component !== "string") {
28
+ throw new TypeError("Url must be a string. Received " + component);
29
+ }
30
+ if (component === "") {
31
+ continue;
32
+ }
33
+ if (i > 0) {
34
+ component = component.replace(/^[\/]+/, "");
35
+ }
36
+ if (i < strArray.length - 1) {
37
+ component = component.replace(/[\/]+$/, "");
38
+ } else {
39
+ component = component.replace(/[\/]+$/, "/");
40
+ }
41
+ resultArray.push(component);
42
+ }
43
+ let str = resultArray.join("/");
44
+ str = str.replace(/\/(\?|&|#[^!])/g, "$1");
45
+ const parts = str.split("?");
46
+ str = parts.shift() + (parts.length > 0 ? "?" : "") + parts.join("&");
47
+ return str;
48
+ }
49
+
50
+ export { urljoin };
51
+ //# sourceMappingURL=urljoin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"urljoin.js","sources":["../../src/shim/urljoin.ts"],"sourcesContent":["export function urljoin(...strArray: string[]): string;\nexport function urljoin(strArray: string[]): string;\n\n/**\n * @see {@link https://github.com/jfromaniello/url-join}\n */\nexport function urljoin(...args: string[] | [string[]]): string {\n if (Array.isArray(args[0])) {\n return normalize(args[0]);\n } else {\n return normalize(args as any);\n }\n}\n\nfunction normalize(strArray: string[]) {\n const resultArray: string[] = [];\n if (strArray.length === 0) {\n return '';\n }\n\n if (typeof strArray[0] !== 'string') {\n throw new TypeError('Url must be a string. Received ' + strArray[0]);\n }\n\n // If the first part is a plain protocol, we combine it with the next part.\n if (strArray[0].match(/^[^/:]+:\\/*$/) && strArray.length > 1) {\n const first = strArray.shift();\n strArray[0] = first + strArray[0];\n }\n\n // There must be two or three slashes in the file protocol, two slashes in anything else.\n if (strArray[0].match(/^file:\\/\\/\\//)) {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1:///');\n } else {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1://');\n }\n\n for (let i = 0; i < strArray.length; i++) {\n let component = strArray[i];\n\n if (typeof component !== 'string') {\n throw new TypeError('Url must be a string. Received ' + component);\n }\n\n if (component === '') {\n continue;\n }\n\n if (i > 0) {\n // Removing the starting slashes for each component but the first.\n component = component.replace(/^[\\/]+/, '');\n }\n if (i < strArray.length - 1) {\n // Removing the ending slashes for each component but the last.\n component = component.replace(/[\\/]+$/, '');\n } else {\n // For the last component we will combine multiple slashes to a single one.\n component = component.replace(/[\\/]+$/, '/');\n }\n\n resultArray.push(component);\n }\n\n let str = resultArray.join('/');\n // Each input component is now separated by a single slash except the possible first plain protocol part.\n\n // remove trailing slash before parameters or hash\n str = str.replace(/\\/(\\?|&|#[^!])/g, '$1');\n\n // replace ? in parameters with &\n const parts = str.split('?');\n str = parts.shift() + (parts.length > 0 ? '?' : '') + parts.join('&');\n\n return str;\n}\n"],"names":[],"mappings":"AAMO,SAAS,WAAW,IAAqC,EAAA;AAC9D,EAAA,IAAI,KAAM,CAAA,OAAA,CAAQ,IAAK,CAAA,CAAA,CAAE,CAAG,EAAA;AAC1B,IAAO,OAAA,SAAA,CAAU,KAAK,CAAE,CAAA,CAAA,CAAA;AAAA,GACnB,MAAA;AACL,IAAA,OAAO,UAAU,IAAW,CAAA,CAAA;AAAA,GAC9B;AACF,CAAA;AAEA,SAAS,UAAU,QAAoB,EAAA;AACrC,EAAA,MAAM,cAAwB,EAAC,CAAA;AAC/B,EAAI,IAAA,QAAA,CAAS,WAAW,CAAG,EAAA;AACzB,IAAO,OAAA,EAAA,CAAA;AAAA,GACT;AAEA,EAAI,IAAA,OAAO,QAAS,CAAA,CAAA,CAAA,KAAO,QAAU,EAAA;AACnC,IAAA,MAAM,IAAI,SAAA,CAAU,iCAAoC,GAAA,QAAA,CAAS,CAAE,CAAA,CAAA,CAAA;AAAA,GACrE;AAGA,EAAA,IAAI,SAAS,CAAG,CAAA,CAAA,KAAA,CAAM,cAAc,CAAK,IAAA,QAAA,CAAS,SAAS,CAAG,EAAA;AAC5D,IAAM,MAAA,KAAA,GAAQ,SAAS,KAAM,EAAA,CAAA;AAC7B,IAAS,QAAA,CAAA,CAAA,CAAA,GAAK,QAAQ,QAAS,CAAA,CAAA,CAAA,CAAA;AAAA,GACjC;AAGA,EAAA,IAAI,QAAS,CAAA,CAAA,CAAA,CAAG,KAAM,CAAA,cAAc,CAAG,EAAA;AACrC,IAAA,QAAA,CAAS,CAAK,CAAA,GAAA,QAAA,CAAS,CAAG,CAAA,CAAA,OAAA,CAAQ,iBAAiB,QAAQ,CAAA,CAAA;AAAA,GACtD,MAAA;AACL,IAAA,QAAA,CAAS,CAAK,CAAA,GAAA,QAAA,CAAS,CAAG,CAAA,CAAA,OAAA,CAAQ,iBAAiB,OAAO,CAAA,CAAA;AAAA,GAC5D;AAEA,EAAA,KAAA,IAAS,CAAI,GAAA,CAAA,EAAG,CAAI,GAAA,QAAA,CAAS,QAAQ,CAAK,EAAA,EAAA;AACxC,IAAA,IAAI,YAAY,QAAS,CAAA,CAAA,CAAA,CAAA;AAEzB,IAAI,IAAA,OAAO,cAAc,QAAU,EAAA;AACjC,MAAM,MAAA,IAAI,SAAU,CAAA,iCAAA,GAAoC,SAAS,CAAA,CAAA;AAAA,KACnE;AAEA,IAAA,IAAI,cAAc,EAAI,EAAA;AACpB,MAAA,SAAA;AAAA,KACF;AAEA,IAAA,IAAI,IAAI,CAAG,EAAA;AAET,MAAY,SAAA,GAAA,SAAA,CAAU,OAAQ,CAAA,QAAA,EAAU,EAAE,CAAA,CAAA;AAAA,KAC5C;AACA,IAAI,IAAA,CAAA,GAAI,QAAS,CAAA,MAAA,GAAS,CAAG,EAAA;AAE3B,MAAY,SAAA,GAAA,SAAA,CAAU,OAAQ,CAAA,QAAA,EAAU,EAAE,CAAA,CAAA;AAAA,KACrC,MAAA;AAEL,MAAY,SAAA,GAAA,SAAA,CAAU,OAAQ,CAAA,QAAA,EAAU,GAAG,CAAA,CAAA;AAAA,KAC7C;AAEA,IAAA,WAAA,CAAY,KAAK,SAAS,CAAA,CAAA;AAAA,GAC5B;AAEA,EAAI,IAAA,GAAA,GAAM,WAAY,CAAA,IAAA,CAAK,GAAG,CAAA,CAAA;AAI9B,EAAM,GAAA,GAAA,GAAA,CAAI,OAAQ,CAAA,iBAAA,EAAmB,IAAI,CAAA,CAAA;AAGzC,EAAM,MAAA,KAAA,GAAQ,GAAI,CAAA,KAAA,CAAM,GAAG,CAAA,CAAA;AAC3B,EAAM,GAAA,GAAA,KAAA,CAAM,KAAM,EAAA,IAAK,KAAM,CAAA,MAAA,GAAS,IAAI,GAAM,GAAA,EAAA,CAAA,GAAM,KAAM,CAAA,IAAA,CAAK,GAAG,CAAA,CAAA;AAEpE,EAAO,OAAA,GAAA,CAAA;AACT;;;;"}
@@ -0,0 +1,56 @@
1
+ function preserveCamelCase(string) {
2
+ let isLastCharLower = false;
3
+ let isLastCharUpper = false;
4
+ let isLastLastCharUpper = false;
5
+ for (let i = 0; i < string.length; i++) {
6
+ const character = string[i];
7
+ if (isLastCharLower && /[a-zA-Z]/.test(character) && character.toUpperCase() === character) {
8
+ string = string.slice(0, i) + "-" + string.slice(i);
9
+ isLastCharLower = false;
10
+ isLastLastCharUpper = isLastCharUpper;
11
+ isLastCharUpper = true;
12
+ i++;
13
+ } else if (isLastCharUpper && isLastLastCharUpper && /[a-zA-Z]/.test(character) && character.toLowerCase() === character) {
14
+ string = string.slice(0, i - 1) + "-" + string.slice(i - 1);
15
+ isLastLastCharUpper = isLastCharUpper;
16
+ isLastCharUpper = false;
17
+ isLastCharLower = true;
18
+ } else {
19
+ isLastCharLower = character.toLowerCase() === character && character.toUpperCase() !== character;
20
+ isLastLastCharUpper = isLastCharUpper;
21
+ isLastCharUpper = character.toUpperCase() === character && character.toLowerCase() !== character;
22
+ }
23
+ }
24
+ return string;
25
+ }
26
+ function pascalCase(input) {
27
+ return camelCase(input, { pascalCase: true });
28
+ }
29
+ function camelCase(input, options = {
30
+ pascalCase: false
31
+ }) {
32
+ if (!(typeof input === "string" || Array.isArray(input))) {
33
+ throw new TypeError("Expected the input to be `string | string[]`");
34
+ }
35
+ const postProcess = (x) => options.pascalCase ? x.charAt(0).toUpperCase() + x.slice(1) : x;
36
+ if (Array.isArray(input)) {
37
+ input = input.map((x) => x.trim()).filter((x) => x.length).join("-");
38
+ } else {
39
+ input = input.trim();
40
+ }
41
+ if (input.length === 0) {
42
+ return "";
43
+ }
44
+ if (input.length === 1) {
45
+ return options.pascalCase ? input.toUpperCase() : input.toLowerCase();
46
+ }
47
+ const hasUpperCase = input !== input.toLowerCase();
48
+ if (hasUpperCase) {
49
+ input = preserveCamelCase(input);
50
+ }
51
+ input = input.replace(/^[_.\- ]+/, "").toLowerCase().replace(/[_.\- ]+(\w|$)/g, (_, p1) => p1.toUpperCase()).replace(/\d+(\w|$)/g, (m) => m.toUpperCase());
52
+ return postProcess(input);
53
+ }
54
+
55
+ export { camelCase, pascalCase };
56
+ //# sourceMappingURL=camelCase.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"camelCase.js","sources":["../../src/strings/camelCase.ts"],"sourcesContent":["// https://github.com/sindresorhus/camelcase/blob/master/index.js\n\nfunction preserveCamelCase(string: string) {\n let isLastCharLower = false;\n let isLastCharUpper = false;\n let isLastLastCharUpper = false;\n\n for (let i = 0; i < string.length; i++) {\n const character = string[i];\n\n if (isLastCharLower && /[a-zA-Z]/.test(character) && character.toUpperCase() === character) {\n string = string.slice(0, i) + '-' + string.slice(i);\n isLastCharLower = false;\n isLastLastCharUpper = isLastCharUpper;\n isLastCharUpper = true;\n i++;\n } else if (\n isLastCharUpper &&\n isLastLastCharUpper &&\n /[a-zA-Z]/.test(character) &&\n character.toLowerCase() === character\n ) {\n string = string.slice(0, i - 1) + '-' + string.slice(i - 1);\n isLastLastCharUpper = isLastCharUpper;\n isLastCharUpper = false;\n isLastCharLower = true;\n } else {\n isLastCharLower = character.toLowerCase() === character && character.toUpperCase() !== character;\n isLastLastCharUpper = isLastCharUpper;\n isLastCharUpper = character.toUpperCase() === character && character.toLowerCase() !== character;\n }\n }\n\n return string;\n}\n\nexport function pascalCase(input: string | string[]) {\n return camelCase(input, { pascalCase: true });\n}\n\nexport function camelCase(\n input: string | string[],\n options: { pascalCase: boolean } = {\n pascalCase: false,\n },\n) {\n if (!(typeof input === 'string' || Array.isArray(input))) {\n throw new TypeError('Expected the input to be `string | string[]`');\n }\n\n const postProcess = (x: string) => (options.pascalCase ? x.charAt(0).toUpperCase() + x.slice(1) : x);\n\n if (Array.isArray(input)) {\n input = input\n .map((x) => x.trim())\n .filter((x) => x.length)\n .join('-');\n } else {\n input = input.trim();\n }\n\n if (input.length === 0) {\n return '';\n }\n\n if (input.length === 1) {\n return options.pascalCase ? input.toUpperCase() : input.toLowerCase();\n }\n\n const hasUpperCase = input !== input.toLowerCase();\n\n if (hasUpperCase) {\n input = preserveCamelCase(input);\n }\n\n input = input\n .replace(/^[_.\\- ]+/, '')\n .toLowerCase()\n .replace(/[_.\\- ]+(\\w|$)/g, (_, p1) => p1.toUpperCase())\n .replace(/\\d+(\\w|$)/g, (m) => m.toUpperCase());\n\n return postProcess(input);\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ function templateString(template, getter) {
2
+ return template.replace(/\${(.*?)}/g, (_, g) => {
3
+ return getter(g.trim());
4
+ });
5
+ }
6
+
7
+ export { templateString };
8
+ //# sourceMappingURL=templates.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"templates.js","sources":["../../src/strings/templates.ts"],"sourcesContent":["/**\n * 替换类似于 JS 的模板字符串\n *\n * @example\n * templateString('My name is ${name}',{name:'wener'})\n */\nexport function templateString(template: string, getter: (v: string) => any) {\n return template.replace(/\\${(.*?)}/g, (_, g) => {\n // variables[g.trim()]\n // 支持路径 - 例如 a.b[0]\n return getter(g.trim());\n });\n}\n"],"names":[],"mappings":"AAMgB,SAAA,cAAA,CAAe,UAAkB,MAA4B,EAAA;AAC3E,EAAA,OAAO,QAAS,CAAA,OAAA,CAAQ,YAAc,EAAA,CAAC,GAAG,CAAM,KAAA;AAG9C,IAAO,OAAA,MAAA,CAAO,CAAE,CAAA,IAAA,EAAM,CAAA,CAAA;AAAA,GACvB,CAAA,CAAA;AACH;;;;"}