@wener/utils 1.1.7 → 1.1.9

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 (89) hide show
  1. package/dist/LICENSE.txt +1 -0
  2. package/dist/cjs/index.cjs +2 -0
  3. package/dist/cjs/index.cjs.map +1 -0
  4. package/dist/cjs/server.cjs +2 -0
  5. package/dist/cjs/server.cjs.map +1 -0
  6. package/dist/esm/index.js +1 -1
  7. package/dist/esm/index.js.map +1 -1
  8. package/dist/esm/server.js +1 -1
  9. package/dist/esm/server.js.map +1 -1
  10. package/dist/system/index.js +1 -1
  11. package/dist/system/index.js.map +1 -1
  12. package/dist/system/server.js +1 -1
  13. package/dist/system/server.js.map +1 -1
  14. package/lib/asyncs/createLazyPromise.js +12 -1
  15. package/lib/asyncs/createLazyPromise.js.map +1 -1
  16. package/lib/browsers/copy.js.map +1 -1
  17. package/lib/crypto/getRandomValues.js +27 -0
  18. package/lib/crypto/getRandomValues.js.map +1 -0
  19. package/lib/crypto/randomUUID.js +1 -1
  20. package/lib/crypto/randomUUID.js.map +1 -1
  21. package/lib/crypto/ulid.js +139 -0
  22. package/lib/crypto/ulid.js.map +1 -0
  23. package/lib/i18n/createTranslate.js +17 -1
  24. package/lib/i18n/createTranslate.js.map +1 -1
  25. package/lib/index.js +11 -4
  26. package/lib/index.js.map +1 -1
  27. package/lib/io/ArrayBuffers.js +30 -24
  28. package/lib/io/ArrayBuffers.js.map +1 -1
  29. package/lib/io/Buffer.js +21 -0
  30. package/lib/io/Buffer.js.map +1 -0
  31. package/lib/isomorphics/structuredClone.js.map +1 -1
  32. package/lib/langs/shallowClone.js +15 -0
  33. package/lib/langs/shallowClone.js.map +1 -0
  34. package/lib/logging/createChildLogger.js +2 -2
  35. package/lib/logging/createChildLogger.js.map +1 -1
  36. package/lib/logging/createLogger.js +26 -0
  37. package/lib/logging/createLogger.js.map +1 -0
  38. package/lib/logging/createNoopLogger.js.map +1 -1
  39. package/lib/objects/get.js.map +1 -1
  40. package/lib/objects/set.js.map +1 -1
  41. package/lib/server/polyfillFetch.js +17 -24
  42. package/lib/server/polyfillFetch.js.map +1 -1
  43. package/lib/validations/isEmptyObject.js +3 -4
  44. package/lib/validations/isEmptyObject.js.map +1 -1
  45. package/lib/validations/isPlainObject.js +11 -0
  46. package/lib/validations/isPlainObject.js.map +1 -0
  47. package/lib/validations/parseBoolean.js +31 -0
  48. package/lib/validations/parseBoolean.js.map +1 -0
  49. package/lib/validations/parseTimestamp.js +25 -0
  50. package/lib/validations/parseTimestamp.js.map +1 -0
  51. package/package.json +8 -11
  52. package/src/asyncs/createLazyPromise.test.ts +16 -1
  53. package/src/asyncs/createLazyPromise.ts +18 -2
  54. package/src/asyncs/isThenable.ts +4 -0
  55. package/src/browsers/copy.ts +1 -1
  56. package/src/crypto/getRandomValues.ts +42 -0
  57. package/src/crypto/randomUUID.ts +1 -1
  58. package/src/crypto/ulid.test.ts +30 -0
  59. package/src/crypto/ulid.ts +183 -0
  60. package/src/i18n/createTranslate.test.ts +15 -0
  61. package/src/i18n/createTranslate.ts +19 -3
  62. package/src/index.ts +16 -6
  63. package/src/io/ArrayBuffers.base64.test.ts +1 -1
  64. package/src/io/ArrayBuffers.ts +41 -25
  65. package/src/io/Buffer.test.ts +23 -0
  66. package/src/io/Buffer.ts +14 -0
  67. package/src/isomorphics/structuredClone.ts +1 -1
  68. package/src/langs/shallowClone.ts +13 -0
  69. package/src/logging/createChildLogger.ts +3 -3
  70. package/src/logging/createLogger.ts +31 -0
  71. package/src/logging/createNoopLogger.ts +1 -1
  72. package/src/logging/logger.test.ts +5 -3
  73. package/src/objects/get.ts +2 -1
  74. package/src/objects/set.ts +2 -1
  75. package/src/server/polyfillBrowser.test.ts +5 -1
  76. package/src/server/polyfillFetch.ts +22 -24
  77. package/src/validations/isEmptyObject.ts +3 -4
  78. package/src/validations/isFunction.ts +3 -0
  79. package/src/validations/isPlainObject.ts +10 -0
  80. package/src/validations/parseBoolean.ts +30 -0
  81. package/src/validations/parseTimestamp.test.ts +7 -0
  82. package/src/validations/parseTimestamp.ts +29 -0
  83. package/dist/cjs/index.js +0 -2
  84. package/dist/cjs/index.js.map +0 -1
  85. package/dist/cjs/server.js +0 -2
  86. package/dist/cjs/server.js.map +0 -1
  87. package/lib/logging/createWriteLogger.js +0 -13
  88. package/lib/logging/createWriteLogger.js.map +0 -1
  89. package/src/logging/createWriteLogger.ts +0 -15
@@ -1 +1 @@
1
- {"version":3,"file":"server.js","sources":["../../src/server/polyfillCrypto.ts","../../src/server/polyfillFetch.ts","../../src/server/polyfillJsDom.ts","../../src/server/polyfillBrowser.ts"],"sourcesContent":["export async function polyfillCrypto() {\n if ('crypto' in globalThis) {\n return false;\n }\n globalThis.crypto = (await import('node:crypto')).webcrypto as Crypto;\n return true;\n}\n","export async function polyfillFetch() {\n if ('fetch' in globalThis) {\n return false;\n }\n const {\n default: fetch,\n Response,\n Headers,\n Request,\n AbortError,\n FetchError,\n FormData,\n Blob,\n File,\n } = await import('node-fetch');\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","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","import { polyfillCrypto } from './polyfillCrypto';\nimport { polyfillFetch } from './polyfillFetch';\nimport { polyfillJsDom } from './polyfillJsDom';\n\n/**\n * Polyfills the browser environment with the necessary APIs for the server.\n * Currently, this includes:\n * - `window`\n * - `document`\n * - `fetch`\n * - `crypto`\n */\nexport async function polyfillBrowser() {\n await polyfillCrypto();\n await polyfillFetch();\n await polyfillJsDom();\n}\n"],"names":["polyfillCrypto","module","polyfillFetch","fetch","Response","Headers","Request","AbortError","FetchError","FormData","Blob","File","polyfillJsDom","ResourceLoader","JSDOM","Window","opts","proxy","strictSSL","userAgent","jsdomOpts","resources","defaultJsdomConfig","protectedProperties","prop","installEnv","args","properties","arg","userJsdomConfig","window","polyfillBrowser"],"mappings":"gJAAA,eAAsBA,GAAiB,CACrC,MAAI,WAAY,WACP,IAET,WAAW,QAAU,MAAMC,EAAO,OAAA,aAAgB,GAAA,UAC3C,GACT,CCNsB,eAAAC,GAAgB,CACpC,GAAI,UAAW,WACb,MAAO,GAET,KAAM,CACJ,QAASC,EACT,SAAAC,EACA,QAAAC,EACA,QAAAC,EACA,WAAAC,EACA,WAAAC,EACA,SAAAC,EACA,KAAAC,EACA,KAAAC,CACF,EAAI,MAAMV,EAAO,OAAA,YACjB,EAAA,OAAA,OAAO,OAAO,WAAY,CACxB,MAAAE,EACA,SAAAC,EACA,QAAAC,EACA,QAAAC,EACA,WAAAC,EACA,WAAAC,EACA,SAAAC,EACA,KAAAC,EACA,KAAAC,CACF,CAAC,EACM,EACT,CCzBA,eAAsBC,GAAgB,CACpC,GAAI,OAAO,OAAW,IACpB,MAAO,GAGT,KAAM,CAAE,eAAAC,EAAgB,MAAAC,CAAM,EAAI,MAAab,EAAA,OAAA,OAAA,EAI/C,MAAMc,CAAO,CACX,YAAYC,EAA8D,GAAI,CAC5E,KAAM,CAAE,MAAAC,EAAO,UAAAC,EAAW,UAAAC,KAAcC,CAAU,EAAIJ,EAChDK,EAAY,IAAIR,EAAe,CACnC,MAAAI,EACA,UAAAC,EACA,UAAAC,CACF,CAAC,EACD,OAAO,IAAIL,EACT,GACA,OAAO,OAAOM,EAAW,CACvB,UAAAC,CACF,CAAC,CACH,EAAE,MACJ,CACF,CAMA,MAAMC,EAAqB,GAQrBC,GAAuB,IAC3B,OAAO,oBAAoB,IAAIR,EAAOO,CAAkB,CAAC,EAAE,OACxDE,GAAS,OAAO,WAAWA,GAAqC,GACnE,KAEF,SAASC,KAAcC,EAAa,CAGlC,MAAMC,EAAaD,EAAK,OAAQE,GAAa,MAAM,QAAQA,CAAG,CAAC,EAAE,GAC3DC,EAAkBH,EAAK,OAAQE,GAAa,CAAC,MAAM,QAAQA,CAAG,CAAC,EAAE,GAGjEE,EAAS,IAAIf,EAAO,OAAO,OAAO,CAAIc,EAAAA,EAAiBP,CAAkB,CAAC,EAGhF,cAAO,oBAAoBQ,CAAM,EAG9B,OAAQN,GAAS,CAACD,EAAoB,SAASC,CAAI,CAAC,EAGpD,OAAQA,GAAS,EAAEG,GAAcA,EAAW,QAAQH,CAAI,IAAM,GAAG,EACjE,OAAQA,GAAS,CAChB,OAAQA,EAAAA,CACN,IAAK,YACH,MAAO,EACX,CACA,MAAO,EACT,CAAC,EAGA,QAASA,GAAS,CAEjB,OAAO,eAAe,WAAYA,EAAM,CACtC,aAAc,GACd,IAAK,IAAMM,EAAON,EACpB,CAAC,CACH,CAAC,EAEIM,CACT,CAEA,OAAAL,EAAW,CAAE,IAAK,kBAAmB,CAAC,EAC/B,EACT,gBCxEsBM,GAAkB,CACtC,MAAM/B,EAAe,EACrB,MAAME,EAAc,EACpB,MAAMU,EACR,CAAA"}
1
+ {"version":3,"file":"server.js","sources":["../../src/server/polyfillCrypto.ts","../../src/server/polyfillFetch.ts","../../src/server/polyfillJsDom.ts","../../src/server/polyfillBrowser.ts"],"sourcesContent":["export async function polyfillCrypto() {\n if ('crypto' in globalThis) {\n return false;\n }\n globalThis.crypto = (await import('node:crypto')).webcrypto as Crypto;\n return true;\n}\n","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","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","import { polyfillCrypto } from './polyfillCrypto';\nimport { polyfillFetch } from './polyfillFetch';\nimport { polyfillJsDom } from './polyfillJsDom';\n\n/**\n * Polyfills the browser environment with the necessary APIs for the server.\n * Currently, this includes:\n * - `window`\n * - `document`\n * - `fetch`\n * - `crypto`\n */\nexport async function polyfillBrowser() {\n await polyfillCrypto();\n await polyfillFetch();\n await polyfillJsDom();\n}\n"],"names":["polyfillCrypto","module","polyfillFetch","nodeFetch","fetch","Response","Headers","Request","AbortError","FetchError","FormData","Blob","File","v","polyfillJsDom","ResourceLoader","JSDOM","Window","opts","proxy","strictSSL","userAgent","jsdomOpts","resources","defaultJsdomConfig","protectedProperties","prop","installEnv","args","properties","arg","userJsdomConfig","window","polyfillBrowser"],"mappings":"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"}
@@ -1,3 +1,5 @@
1
+ import { isPromise } from './isPromise.js';
2
+
1
3
  function createLazyPromise(executor) {
2
4
  const holder = {
3
5
  resolve(_) {
@@ -32,7 +34,16 @@ function createLazyPromise(executor) {
32
34
  future.then = (...args) => {
33
35
  if (shouldExec) {
34
36
  shouldExec = false;
35
- executor(holder.resolve, holder.reject);
37
+ try {
38
+ const result = executor(holder.resolve, holder.reject);
39
+ if (isPromise(result)) {
40
+ result.then(holder.resolve, holder.reject);
41
+ } else if (result !== void 0) {
42
+ holder.resolve(result);
43
+ }
44
+ } catch (e) {
45
+ holder.reject(e);
46
+ }
36
47
  }
37
48
  return then(...args);
38
49
  };
@@ -1 +1 @@
1
- {"version":3,"file":"createLazyPromise.js","sources":["../../src/asyncs/createLazyPromise.ts"],"sourcesContent":["export type LazyPromise<T> = Promise<T> & {\n reject(reason?: any): void;\n resolve(v?: T | PromiseLike<T>): void;\n};\n\n/**\n * createLazyPromise return a promise that can be resolved or rejected manually.\n * if you pass a function to it, it will be executed when the promise try to resolve.\n */\nexport function createLazyPromise<T = any>(\n executor?: (resolve: LazyPromise<T>['resolve'], reject: LazyPromise<T>['reject']) => void,\n): LazyPromise<T> {\n const holder = {\n resolve(_: any): void {\n throw new Error('pending resolve');\n },\n reject(_: any): void {\n throw new Error('pending reject');\n },\n };\n const future = Object.assign(\n new Promise<T>((resolve, reject) => {\n holder.reject = reject;\n holder.resolve = resolve;\n }),\n {\n resolve(v: any) {\n holder.resolve(v);\n },\n reject(v: any) {\n holder.resolve(v);\n },\n },\n );\n if (executor) {\n const r = holder.resolve;\n let shouldExec = true;\n holder.resolve = (v: any) => {\n shouldExec = false;\n r(v);\n };\n const then = future.then.bind(future);\n future.then = (...args) => {\n if (shouldExec) {\n shouldExec = false;\n executor(holder.resolve, holder.reject);\n }\n return then(...args);\n };\n const like = holder as LazyPromise<T>;\n like.then = future.then;\n like.catch = future.catch.bind(future);\n if (future.finally) like.finally = future.finally;\n\n void Object.defineProperty(like, Symbol.species, {\n get() {\n return Promise;\n },\n });\n return like;\n }\n return future;\n}\n"],"names":[],"mappings":"AASO,SAAS,kBACd,QACgB,EAAA;AAChB,EAAA,MAAM,MAAS,GAAA;AAAA,IACb,QAAQ,CAAc,EAAA;AACpB,MAAM,MAAA,IAAI,MAAM,iBAAiB,CAAA,CAAA;AAAA,KACnC;AAAA,IACA,OAAO,CAAc,EAAA;AACnB,MAAM,MAAA,IAAI,MAAM,gBAAgB,CAAA,CAAA;AAAA,KAClC;AAAA,GACF,CAAA;AACA,EAAA,MAAM,SAAS,MAAO,CAAA,MAAA;AAAA,IACpB,IAAI,OAAA,CAAW,CAAC,OAAA,EAAS,MAAW,KAAA;AAClC,MAAA,MAAA,CAAO,MAAS,GAAA,MAAA,CAAA;AAChB,MAAA,MAAA,CAAO,OAAU,GAAA,OAAA,CAAA;AAAA,KAClB,CAAA;AAAA,IACD;AAAA,MACE,QAAQ,CAAQ,EAAA;AACd,QAAA,MAAA,CAAO,QAAQ,CAAC,CAAA,CAAA;AAAA,OAClB;AAAA,MACA,OAAO,CAAQ,EAAA;AACb,QAAA,MAAA,CAAO,QAAQ,CAAC,CAAA,CAAA;AAAA,OAClB;AAAA,KACF;AAAA,GACF,CAAA;AACA,EAAA,IAAI,QAAU,EAAA;AACZ,IAAA,MAAM,IAAI,MAAO,CAAA,OAAA,CAAA;AACjB,IAAA,IAAI,UAAa,GAAA,IAAA,CAAA;AACjB,IAAO,MAAA,CAAA,OAAA,GAAU,CAAC,CAAW,KAAA;AAC3B,MAAa,UAAA,GAAA,KAAA,CAAA;AACb,MAAA,CAAA,CAAE,CAAC,CAAA,CAAA;AAAA,KACL,CAAA;AACA,IAAA,MAAM,IAAO,GAAA,MAAA,CAAO,IAAK,CAAA,IAAA,CAAK,MAAM,CAAA,CAAA;AACpC,IAAO,MAAA,CAAA,IAAA,GAAO,IAAI,IAAS,KAAA;AACzB,MAAA,IAAI,UAAY,EAAA;AACd,QAAa,UAAA,GAAA,KAAA,CAAA;AACb,QAAS,QAAA,CAAA,MAAA,CAAO,OAAS,EAAA,MAAA,CAAO,MAAM,CAAA,CAAA;AAAA,OACxC;AACA,MAAO,OAAA,IAAA,CAAK,GAAG,IAAI,CAAA,CAAA;AAAA,KACrB,CAAA;AACA,IAAA,MAAM,IAAO,GAAA,MAAA,CAAA;AACb,IAAA,IAAA,CAAK,OAAO,MAAO,CAAA,IAAA,CAAA;AACnB,IAAA,IAAA,CAAK,KAAQ,GAAA,MAAA,CAAO,KAAM,CAAA,IAAA,CAAK,MAAM,CAAA,CAAA;AACrC,IAAA,IAAI,MAAO,CAAA,OAAA;AAAS,MAAA,IAAA,CAAK,UAAU,MAAO,CAAA,OAAA,CAAA;AAE1C,IAAA,KAAK,MAAO,CAAA,cAAA,CAAe,IAAM,EAAA,MAAA,CAAO,OAAS,EAAA;AAAA,MAC/C,GAAM,GAAA;AACJ,QAAO,OAAA,OAAA,CAAA;AAAA,OACT;AAAA,KACD,CAAA,CAAA;AACD,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AACA,EAAO,OAAA,MAAA,CAAA;AACT;;;;"}
1
+ {"version":3,"file":"createLazyPromise.js","sources":["../../src/asyncs/createLazyPromise.ts"],"sourcesContent":["import type { MaybePromise } from './MaybePromise';\nimport { isPromise } from './isPromise';\n\nexport type LazyPromise<T> = Promise<T> & {\n reject(reason?: any): void;\n resolve(v?: T | PromiseLike<T>): void;\n};\n\n/**\n * createLazyPromise return a promise that can be resolved or rejected manually.\n * if you pass a function to it, it will be executed when the promise try to resolve.\n */\nexport function createLazyPromise<T = any>(\n executor?:\n | ((resolve: LazyPromise<T>['resolve'], reject: LazyPromise<T>['reject']) => void)\n | ((resolve: LazyPromise<T>['resolve'], reject: LazyPromise<T>['reject']) => MaybePromise<T>),\n): LazyPromise<T> {\n const holder = {\n resolve(_: any): void {\n throw new Error('pending resolve');\n },\n reject(_: any): void {\n throw new Error('pending reject');\n },\n };\n const future = Object.assign(\n new Promise<T>((resolve, reject) => {\n holder.reject = reject;\n holder.resolve = resolve;\n }),\n {\n resolve(v: any) {\n holder.resolve(v);\n },\n reject(v: any) {\n holder.resolve(v);\n },\n },\n );\n if (executor) {\n const r = holder.resolve;\n let shouldExec = true;\n holder.resolve = (v: any) => {\n shouldExec = false;\n r(v);\n };\n const then = future.then.bind(future);\n future.then = (...args) => {\n if (shouldExec) {\n shouldExec = false;\n try {\n // kind of bad\n const result = executor(holder.resolve, holder.reject);\n // ensure resolve/reject is called\n if (isPromise(result)) {\n result.then(holder.resolve, holder.reject);\n } else if (result !== undefined) {\n holder.resolve(result);\n }\n } catch (e) {\n holder.reject(e);\n }\n }\n return then(...args);\n };\n const like = holder as LazyPromise<T>;\n like.then = future.then;\n like.catch = future.catch.bind(future);\n if (future.finally) like.finally = future.finally;\n\n void Object.defineProperty(like, Symbol.species, {\n get() {\n return Promise;\n },\n });\n return like;\n }\n return future;\n}\n"],"names":[],"mappings":";;AAYO,SAAS,kBACd,QAGgB,EAAA;AAChB,EAAA,MAAM,MAAS,GAAA;AAAA,IACb,QAAQ,CAAc,EAAA;AACpB,MAAM,MAAA,IAAI,MAAM,iBAAiB,CAAA,CAAA;AAAA,KACnC;AAAA,IACA,OAAO,CAAc,EAAA;AACnB,MAAM,MAAA,IAAI,MAAM,gBAAgB,CAAA,CAAA;AAAA,KAClC;AAAA,GACF,CAAA;AACA,EAAA,MAAM,SAAS,MAAO,CAAA,MAAA;AAAA,IACpB,IAAI,OAAA,CAAW,CAAC,OAAA,EAAS,MAAW,KAAA;AAClC,MAAA,MAAA,CAAO,MAAS,GAAA,MAAA,CAAA;AAChB,MAAA,MAAA,CAAO,OAAU,GAAA,OAAA,CAAA;AAAA,KAClB,CAAA;AAAA,IACD;AAAA,MACE,QAAQ,CAAQ,EAAA;AACd,QAAA,MAAA,CAAO,QAAQ,CAAC,CAAA,CAAA;AAAA,OAClB;AAAA,MACA,OAAO,CAAQ,EAAA;AACb,QAAA,MAAA,CAAO,QAAQ,CAAC,CAAA,CAAA;AAAA,OAClB;AAAA,KACF;AAAA,GACF,CAAA;AACA,EAAA,IAAI,QAAU,EAAA;AACZ,IAAA,MAAM,IAAI,MAAO,CAAA,OAAA,CAAA;AACjB,IAAA,IAAI,UAAa,GAAA,IAAA,CAAA;AACjB,IAAO,MAAA,CAAA,OAAA,GAAU,CAAC,CAAW,KAAA;AAC3B,MAAa,UAAA,GAAA,KAAA,CAAA;AACb,MAAA,CAAA,CAAE,CAAC,CAAA,CAAA;AAAA,KACL,CAAA;AACA,IAAA,MAAM,IAAO,GAAA,MAAA,CAAO,IAAK,CAAA,IAAA,CAAK,MAAM,CAAA,CAAA;AACpC,IAAO,MAAA,CAAA,IAAA,GAAO,IAAI,IAAS,KAAA;AACzB,MAAA,IAAI,UAAY,EAAA;AACd,QAAa,UAAA,GAAA,KAAA,CAAA;AACb,QAAI,IAAA;AAEF,UAAA,MAAM,MAAS,GAAA,QAAA,CAAS,MAAO,CAAA,OAAA,EAAS,OAAO,MAAM,CAAA,CAAA;AAErD,UAAI,IAAA,SAAA,CAAU,MAAM,CAAG,EAAA;AACrB,YAAA,MAAA,CAAO,IAAK,CAAA,MAAA,CAAO,OAAS,EAAA,MAAA,CAAO,MAAM,CAAA,CAAA;AAAA,WAC3C,MAAA,IAAW,WAAW,KAAW,CAAA,EAAA;AAC/B,YAAA,MAAA,CAAO,QAAQ,MAAM,CAAA,CAAA;AAAA,WACvB;AAAA,iBACO,CAAP,EAAA;AACA,UAAA,MAAA,CAAO,OAAO,CAAC,CAAA,CAAA;AAAA,SACjB;AAAA,OACF;AACA,MAAO,OAAA,IAAA,CAAK,GAAG,IAAI,CAAA,CAAA;AAAA,KACrB,CAAA;AACA,IAAA,MAAM,IAAO,GAAA,MAAA,CAAA;AACb,IAAA,IAAA,CAAK,OAAO,MAAO,CAAA,IAAA,CAAA;AACnB,IAAA,IAAA,CAAK,KAAQ,GAAA,MAAA,CAAO,KAAM,CAAA,IAAA,CAAK,MAAM,CAAA,CAAA;AACrC,IAAA,IAAI,MAAO,CAAA,OAAA;AAAS,MAAA,IAAA,CAAK,UAAU,MAAO,CAAA,OAAA,CAAA;AAE1C,IAAA,KAAK,MAAO,CAAA,cAAA,CAAe,IAAM,EAAA,MAAA,CAAO,OAAS,EAAA;AAAA,MAC/C,GAAM,GAAA;AACJ,QAAO,OAAA,OAAA,CAAA;AAAA,OACT;AAAA,KACD,CAAA,CAAA;AACD,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AACA,EAAO,OAAA,MAAA,CAAA;AACT;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"copy.js","sources":["../../src/browsers/copy.ts"],"sourcesContent":["import { MaybePromise } from '../asyncs/MaybePromise';\n\nlet _copy: (s: any) => void;\n\n// https://gist.github.com/rproenca/64781c6a1329b48a455b645d361a9aa3\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): MaybePromise<void> {\n if (window.navigator?.clipboard?.writeText) {\n return window.navigator.clipboard.writeText(content);\n }\n if (!_copy) {\n initCopy();\n }\n return _copy(content);\n}\n"],"names":[],"mappings":"AAEA,IAAI,KAAA,CAAA;AAGJ,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,OAAqC,EAAA;AACxD,EAAI,IAAA,MAAA,CAAO,SAAW,EAAA,SAAA,EAAW,SAAW,EAAA;AAC1C,IAAA,OAAO,MAAO,CAAA,SAAA,CAAU,SAAU,CAAA,SAAA,CAAU,OAAO,CAAA,CAAA;AAAA,GACrD;AACA,EAAA,IAAI,CAAC,KAAO,EAAA;AACV,IAAS,QAAA,EAAA,CAAA;AAAA,GACX;AACA,EAAA,OAAO,MAAM,OAAO,CAAA,CAAA;AACtB;;;;"}
1
+ {"version":3,"file":"copy.js","sources":["../../src/browsers/copy.ts"],"sourcesContent":["import type { MaybePromise } from '../asyncs/MaybePromise';\n\nlet _copy: (s: any) => void;\n\n// https://gist.github.com/rproenca/64781c6a1329b48a455b645d361a9aa3\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): MaybePromise<void> {\n if (window.navigator?.clipboard?.writeText) {\n return window.navigator.clipboard.writeText(content);\n }\n if (!_copy) {\n initCopy();\n }\n return _copy(content);\n}\n"],"names":[],"mappings":"AAEA,IAAI,KAAA,CAAA;AAGJ,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,OAAqC,EAAA;AACxD,EAAI,IAAA,MAAA,CAAO,SAAW,EAAA,SAAA,EAAW,SAAW,EAAA;AAC1C,IAAA,OAAO,MAAO,CAAA,SAAA,CAAU,SAAU,CAAA,SAAA,CAAU,OAAO,CAAA,CAAA;AAAA,GACrD;AACA,EAAA,IAAI,CAAC,KAAO,EAAA;AACV,IAAS,QAAA,EAAA,CAAA;AAAA,GACX;AACA,EAAA,OAAO,MAAM,OAAO,CAAA,CAAA;AACtB;;;;"}
@@ -0,0 +1,27 @@
1
+ let nodeCrypto;
2
+ let getRandomValues = globalThis.crypto?.getRandomValues?.bind(globalThis.crypto) || globalThis.msCrypto?.getRandomValues?.bind(globalThis.msCrypto) || _getRandomValues;
3
+ function _getRandomValues(buf) {
4
+ if (nodeCrypto?.webcrypto?.getRandomValues) {
5
+ getRandomValues = nodeCrypto?.webcrypto?.getRandomValues?.bind(nodeCrypto?.webcrypto);
6
+ return nodeCrypto.webcrypto.getRandomValues(buf);
7
+ }
8
+ if (nodeCrypto?.randomBytes) {
9
+ if (!(buf instanceof Uint8Array)) {
10
+ throw new TypeError("expected Uint8Array");
11
+ }
12
+ if (buf.length > 65536) {
13
+ const e = new Error();
14
+ e.code = 22;
15
+ e.message = `Failed to execute 'getRandomValues' on 'Crypto': The ArrayBufferView's byte length (${buf.length}) exceeds the number of bytes of entropy available via this API (65536).`;
16
+ e.name = "QuotaExceededError";
17
+ throw e;
18
+ }
19
+ const bytes = nodeCrypto.randomBytes(buf.length);
20
+ buf.set(bytes);
21
+ return buf;
22
+ }
23
+ throw new Error("No secure random number generator available.");
24
+ }
25
+
26
+ export { getRandomValues };
27
+ //# sourceMappingURL=getRandomValues.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getRandomValues.js","sources":["../../src/crypto/getRandomValues.ts"],"sourcesContent":["// eslint-disable-next-line @typescript-eslint/consistent-type-imports\nlet nodeCrypto: Awaited<typeof import('node:crypto')>;\n// globalThis.process?.release?.name\n\n// typedoc error\n// if (!(process as any).browser) {\n// try {\n// if (typeof require === 'undefined') {\n// void import('node:crypto').then((v) => (nodeCrypto = v.default));\n// } else {\n// nodeCrypto = require('node:crypto');\n// }\n// } catch (e) {}\n// }\n\nexport let getRandomValues: <T extends Exclude<NodeJS.TypedArray, Float32Array | Float64Array>>(typedArray: T) => T =\n globalThis.crypto?.getRandomValues?.bind(globalThis.crypto) ||\n (globalThis as any).msCrypto?.getRandomValues?.bind((globalThis as any).msCrypto) ||\n _getRandomValues;\n\nfunction _getRandomValues<T extends Exclude<NodeJS.TypedArray, Float32Array | Float64Array>>(buf: T) {\n if (nodeCrypto?.webcrypto?.getRandomValues) {\n getRandomValues = nodeCrypto?.webcrypto?.getRandomValues?.bind(nodeCrypto?.webcrypto);\n return nodeCrypto.webcrypto.getRandomValues(buf);\n }\n if (nodeCrypto?.randomBytes) {\n if (!(buf instanceof Uint8Array)) {\n throw new TypeError('expected Uint8Array');\n }\n if (buf.length > 65536) {\n const e: any = new Error();\n e.code = 22;\n e.message = `Failed to execute 'getRandomValues' on 'Crypto': The ArrayBufferView's byte length (${buf.length}) exceeds the number of bytes of entropy available via this API (65536).`;\n e.name = 'QuotaExceededError';\n throw e;\n }\n const bytes = nodeCrypto.randomBytes(buf.length);\n buf.set(bytes);\n return buf;\n }\n throw new Error('No secure random number generator available.');\n}\n"],"names":[],"mappings":"AACA,IAAI,UAAA,CAAA;AAcG,IAAI,eACT,GAAA,UAAA,CAAW,MAAQ,EAAA,eAAA,EAAiB,KAAK,UAAW,CAAA,MAAM,CACzD,IAAA,UAAA,CAAmB,QAAU,EAAA,eAAA,EAAiB,IAAM,CAAA,UAAA,CAAmB,QAAQ,CAChF,IAAA,iBAAA;AAEF,SAAS,iBAAoF,GAAQ,EAAA;AACnG,EAAI,IAAA,UAAA,EAAY,WAAW,eAAiB,EAAA;AAC1C,IAAA,eAAA,GAAkB,UAAY,EAAA,SAAA,EAAW,eAAiB,EAAA,IAAA,CAAK,YAAY,SAAS,CAAA,CAAA;AACpF,IAAO,OAAA,UAAA,CAAW,SAAU,CAAA,eAAA,CAAgB,GAAG,CAAA,CAAA;AAAA,GACjD;AACA,EAAA,IAAI,YAAY,WAAa,EAAA;AAC3B,IAAI,IAAA,EAAE,eAAe,UAAa,CAAA,EAAA;AAChC,MAAM,MAAA,IAAI,UAAU,qBAAqB,CAAA,CAAA;AAAA,KAC3C;AACA,IAAI,IAAA,GAAA,CAAI,SAAS,KAAO,EAAA;AACtB,MAAM,MAAA,CAAA,GAAS,IAAI,KAAM,EAAA,CAAA;AACzB,MAAA,CAAA,CAAE,IAAO,GAAA,EAAA,CAAA;AACT,MAAE,CAAA,CAAA,OAAA,GAAU,uFAAuF,GAAI,CAAA,MAAA,CAAA,wEAAA,CAAA,CAAA;AACvG,MAAA,CAAA,CAAE,IAAO,GAAA,oBAAA,CAAA;AACT,MAAM,MAAA,CAAA,CAAA;AAAA,KACR;AACA,IAAA,MAAM,KAAQ,GAAA,UAAA,CAAW,WAAY,CAAA,GAAA,CAAI,MAAM,CAAA,CAAA;AAC/C,IAAA,GAAA,CAAI,IAAI,KAAK,CAAA,CAAA;AACb,IAAO,OAAA,GAAA,CAAA;AAAA,GACT;AACA,EAAM,MAAA,IAAI,MAAM,8CAA8C,CAAA,CAAA;AAChE;;;;"}
@@ -1,4 +1,4 @@
1
- const randomUUID = globalThis.crypto?.randomUUID || _randomUUID;
1
+ const randomUUID = globalThis.crypto?.randomUUID.bind(globalThis.crypto) || _randomUUID;
2
2
  function _randomUUID() {
3
3
  return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, (c) => {
4
4
  const r = Math.random() * 16 | 0;
@@ -1 +1 @@
1
- {"version":3,"file":"randomUUID.js","sources":["../../src/crypto/randomUUID.ts"],"sourcesContent":["/**\n * generate random UUIDv4\n */\nexport const randomUUID: () => string = globalThis.crypto?.randomUUID || _randomUUID;\n\n/**\n * @internal\n */\nexport function _randomUUID() {\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":"AAGa,MAAA,UAAA,GAA2B,UAAW,CAAA,MAAA,EAAQ,UAAc,IAAA,YAAA;AAKlE,SAAS,WAAc,GAAA;AAC5B,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;;;;"}
1
+ {"version":3,"file":"randomUUID.js","sources":["../../src/crypto/randomUUID.ts"],"sourcesContent":["/**\n * generate random UUIDv4\n */\nexport const randomUUID: () => string = globalThis.crypto?.randomUUID.bind(globalThis.crypto) || _randomUUID;\n\n/**\n * @internal\n */\nexport function _randomUUID() {\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,MAAM,aAA2B,UAAW,CAAA,MAAA,EAAQ,WAAW,IAAK,CAAA,UAAA,CAAW,MAAM,CAAK,IAAA,YAAA;AAK1F,SAAS,WAAc,GAAA;AAC5B,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,139 @@
1
+ import { getRandomValues } from './getRandomValues.js';
2
+
3
+ function createError(message) {
4
+ const err = new Error(message);
5
+ err.source = "ulid";
6
+ return err;
7
+ }
8
+ const ENCODING = "0123456789ABCDEFGHJKMNPQRSTVWXYZ";
9
+ const ENCODING_LEN = ENCODING.length;
10
+ const TIME_MAX = Math.pow(2, 48) - 1;
11
+ const TIME_LEN = 10;
12
+ const RANDOM_LEN = 16;
13
+ function isULID(str) {
14
+ return str?.length === 26 && /^[0-9A-HJKMNP-TV-Z]{26}$/i.test(str);
15
+ }
16
+ function replaceCharAt(str, index, char) {
17
+ if (index > str.length - 1) {
18
+ return str;
19
+ }
20
+ return str.substr(0, index) + char + str.substr(index + 1);
21
+ }
22
+ function incrementBase32(str) {
23
+ let done;
24
+ let index = str.length;
25
+ let char;
26
+ let charIndex;
27
+ const maxCharIndex = ENCODING_LEN - 1;
28
+ while (!done && index-- >= 0) {
29
+ char = str[index];
30
+ charIndex = ENCODING.indexOf(char);
31
+ if (charIndex === -1) {
32
+ throw createError("incorrectly encoded string");
33
+ }
34
+ if (charIndex === maxCharIndex) {
35
+ str = replaceCharAt(str, index, ENCODING[0]);
36
+ continue;
37
+ }
38
+ done = replaceCharAt(str, index, ENCODING[charIndex + 1]);
39
+ }
40
+ if (typeof done === "string") {
41
+ return done;
42
+ }
43
+ throw createError("cannot increment this string");
44
+ }
45
+ function randomChar(prng) {
46
+ let rand = Math.floor(prng() * ENCODING_LEN);
47
+ if (rand === ENCODING_LEN) {
48
+ rand = ENCODING_LEN - 1;
49
+ }
50
+ return ENCODING.charAt(rand);
51
+ }
52
+ function encodeTime(now, len) {
53
+ if (isNaN(now)) {
54
+ throw new Error(`${now} must be a number`);
55
+ }
56
+ if (now > TIME_MAX) {
57
+ throw createError(`cannot encode time greater than ${TIME_MAX}`);
58
+ }
59
+ if (now < 0) {
60
+ throw createError("time must be positive");
61
+ }
62
+ if (!Number.isInteger(now)) {
63
+ throw createError("time must be an integer");
64
+ }
65
+ let mod;
66
+ let str = "";
67
+ for (; len > 0; len--) {
68
+ mod = now % ENCODING_LEN;
69
+ str = ENCODING.charAt(mod) + str;
70
+ now = (now - mod) / ENCODING_LEN;
71
+ }
72
+ return str;
73
+ }
74
+ function encodeRandom(len, prng) {
75
+ let str = "";
76
+ for (; len > 0; len--) {
77
+ str = randomChar(prng) + str;
78
+ }
79
+ return str;
80
+ }
81
+ function parseULID(id) {
82
+ if (id.length !== TIME_LEN + RANDOM_LEN) {
83
+ throw createError("malformed ulid");
84
+ }
85
+ const time = id.substr(0, TIME_LEN).split("").reverse().reduce((carry, char, index) => {
86
+ const encodingIndex = ENCODING.indexOf(char);
87
+ if (encodingIndex === -1) {
88
+ throw createError("invalid character found: " + char);
89
+ }
90
+ return carry += encodingIndex * Math.pow(ENCODING_LEN, index);
91
+ }, 0);
92
+ if (time > TIME_MAX) {
93
+ throw createError("malformed ulid, timestamp too large");
94
+ }
95
+ return { timestamp: time, random: id.substring(TIME_LEN) };
96
+ }
97
+ function createPrng() {
98
+ return () => {
99
+ const buffer = new Uint8Array(1);
100
+ getRandomValues(buffer);
101
+ return buffer[0] / 255;
102
+ };
103
+ }
104
+ function createULID({
105
+ monotonic = true,
106
+ random = createPrng(),
107
+ now = Date.now
108
+ } = {}) {
109
+ if (!monotonic) {
110
+ return function ulid2(seedTime) {
111
+ seedTime ||= now();
112
+ return encodeTime(seedTime, TIME_LEN) + encodeRandom(RANDOM_LEN, random);
113
+ };
114
+ }
115
+ let lastTime = 0;
116
+ let lastRandom;
117
+ return function ulid2(seedTime) {
118
+ seedTime ||= now();
119
+ if (seedTime <= lastTime && lastRandom) {
120
+ const incrementedRandom = lastRandom = incrementBase32(lastRandom);
121
+ return encodeTime(lastTime, TIME_LEN) + incrementedRandom;
122
+ }
123
+ lastTime = seedTime;
124
+ const newRandom = lastRandom = encodeRandom(RANDOM_LEN, random);
125
+ return encodeTime(seedTime, TIME_LEN) + newRandom;
126
+ };
127
+ }
128
+ let ulid = (...args) => {
129
+ if (_real) {
130
+ return _real(...args);
131
+ }
132
+ _real = createULID();
133
+ ulid = _real;
134
+ return _real(...args);
135
+ };
136
+ let _real;
137
+
138
+ export { createULID, isULID, parseULID, ulid };
139
+ //# sourceMappingURL=ulid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ulid.js","sources":["../../src/crypto/ulid.ts"],"sourcesContent":["import { getRandomValues } from './getRandomValues';\n\ntype PRNG = () => number;\n\n/**\n * Universally Unique Lexicographically Sortable Identifier\n *\n * @see https://github.com/ulid/spec ulid/spec\n */\nexport type ULID = (seedTime?: number) => string;\n\nexport interface ULIDError extends Error {\n source: string;\n}\n\nfunction createError(message: string): ULIDError {\n const err = new Error(message) as ULIDError;\n err.source = 'ulid';\n return err;\n}\n\n// These values should NEVER change. If\n// they do, we're no longer making ulids!\nconst ENCODING = '0123456789ABCDEFGHJKMNPQRSTVWXYZ'; // Crockford's Base32\nconst ENCODING_LEN = ENCODING.length;\nconst TIME_MAX = Math.pow(2, 48) - 1;\nconst TIME_LEN = 10;\nconst RANDOM_LEN = 16;\n\n/**\n * check give {@link str} is a valid ulid\n */\nexport function isULID(str: string): boolean {\n // ttttttttttrrrrrrrrrrrrrrrr\n return str?.length === 26 && /^[0-9A-HJKMNP-TV-Z]{26}$/i.test(str);\n}\n\nfunction replaceCharAt(str: string, index: number, char: string) {\n if (index > str.length - 1) {\n return str;\n }\n return str.substr(0, index) + char + str.substr(index + 1);\n}\n\nfunction incrementBase32(str: string): string {\n let done;\n let index = str.length;\n let char;\n let charIndex;\n const maxCharIndex = ENCODING_LEN - 1;\n while (!done && index-- >= 0) {\n char = str[index];\n charIndex = ENCODING.indexOf(char);\n if (charIndex === -1) {\n throw createError('incorrectly encoded string');\n }\n if (charIndex === maxCharIndex) {\n str = replaceCharAt(str, index, ENCODING[0]);\n continue;\n }\n done = replaceCharAt(str, index, ENCODING[charIndex + 1]);\n }\n if (typeof done === 'string') {\n return done;\n }\n throw createError('cannot increment this string');\n}\n\nfunction randomChar(prng: PRNG): string {\n let rand = Math.floor(prng() * ENCODING_LEN);\n if (rand === ENCODING_LEN) {\n rand = ENCODING_LEN - 1;\n }\n return ENCODING.charAt(rand);\n}\n\nfunction encodeTime(now: number, len: number): string {\n if (isNaN(now)) {\n throw new Error(`${now} must be a number`);\n }\n if (now > TIME_MAX) {\n throw createError(`cannot encode time greater than ${TIME_MAX}`);\n }\n if (now < 0) {\n throw createError('time must be positive');\n }\n if (!Number.isInteger(now)) {\n throw createError('time must be an integer');\n }\n let mod;\n let str = '';\n for (; len > 0; len--) {\n mod = now % ENCODING_LEN;\n str = ENCODING.charAt(mod) + str;\n now = (now - mod) / ENCODING_LEN;\n }\n return str;\n}\n\nfunction encodeRandom(len: number, prng: PRNG): string {\n let str = '';\n for (; len > 0; len--) {\n str = randomChar(prng) + str;\n }\n return str;\n}\n\n/**\n * extract time & random from ulid\n *\n * @throws ULIDError\n */\nexport function parseULID(id: string): { timestamp: number; random: string } {\n if (id.length !== TIME_LEN + RANDOM_LEN) {\n throw createError('malformed ulid');\n }\n const time = id\n .substr(0, TIME_LEN)\n .split('')\n .reverse()\n .reduce((carry, char, index) => {\n const encodingIndex = ENCODING.indexOf(char);\n if (encodingIndex === -1) {\n throw createError('invalid character found: ' + char);\n }\n return (carry += encodingIndex * Math.pow(ENCODING_LEN, index));\n }, 0);\n if (time > TIME_MAX) {\n throw createError('malformed ulid, timestamp too large');\n }\n return { timestamp: time, random: id.substring(TIME_LEN) };\n}\n\nfunction createPrng(): PRNG {\n return () => {\n const buffer = new Uint8Array(1);\n getRandomValues(buffer);\n return buffer[0] / 0xff;\n };\n}\n\n/**\n * create a ulid generator\n */\nexport function createULID({\n monotonic = true,\n random = createPrng(),\n now = Date.now,\n}: { monotonic?: boolean; now?: () => number; random?: () => number } = {}) {\n if (!monotonic) {\n return function ulid(seedTime?: number): string {\n seedTime ||= now();\n return encodeTime(seedTime, TIME_LEN) + encodeRandom(RANDOM_LEN, random);\n };\n }\n\n let lastTime: number = 0;\n let lastRandom: string;\n return function ulid(seedTime?: number): string {\n seedTime ||= now();\n if (seedTime <= lastTime && lastRandom) {\n const incrementedRandom = (lastRandom = incrementBase32(lastRandom));\n return encodeTime(lastTime, TIME_LEN) + incrementedRandom;\n }\n lastTime = seedTime;\n const newRandom = (lastRandom = encodeRandom(RANDOM_LEN, random));\n return encodeTime(seedTime, TIME_LEN) + newRandom;\n };\n}\n\n/**\n * default monotonic ulid generator\n */\nexport let ulid: ULID = (...args) => {\n if (_real) {\n return _real(...args);\n }\n // delay initialize crypto\n _real = createULID();\n ulid = _real;\n return _real(...args);\n};\nlet _real: ULID;\n"],"names":["ulid"],"mappings":"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"}
@@ -4,6 +4,16 @@ import { renderTemplate } from '../strings/renderTemplate.js';
4
4
  function createTranslate(obj) {
5
5
  let locale = "";
6
6
  const tree = obj || {};
7
+ const keyOfDict = (s) => {
8
+ if (Array.isArray(s)) {
9
+ return s;
10
+ }
11
+ const sp = s.split(/[_-]/);
12
+ if (sp.length > 1) {
13
+ return [s, sp[0]];
14
+ }
15
+ return [s];
16
+ };
7
17
  return {
8
18
  locale(lang) {
9
19
  return locale = lang || locale;
@@ -16,7 +26,13 @@ function createTranslate(obj) {
16
26
  return tree[lang];
17
27
  },
18
28
  t(key, params, lang) {
19
- const val = get(tree[lang || locale], key, "");
29
+ let val;
30
+ for (const k of keyOfDict(lang || locale)) {
31
+ val = get(tree[k], key, "");
32
+ if (val) {
33
+ break;
34
+ }
35
+ }
20
36
  if (process.env.NODE_ENV === "development") {
21
37
  if (val == null) {
22
38
  return console.error(
@@ -1 +1 @@
1
- {"version":3,"file":"createTranslate.js","sources":["../../src/i18n/createTranslate.ts"],"sourcesContent":["import { get } from '../objects/get';\nimport { ObjectPathLike } from '../objects/parseObjectPath';\nimport { renderTemplate } from '../strings/renderTemplate';\n\nexport interface Translate<T extends object> {\n /** Get/Set the language key */\n locale(lang?: string): string;\n\n /** Define the dict of translations for a language */\n dict(lang: string, dict: T): void;\n\n /** Get the dict of translations for a language */\n dict(lang: string): T;\n\n /** Retrieve a translation segment for the current language */\n t<X extends Record<string, any> | any[]>(key: ObjectPathLike, params?: X, lang?: string): string;\n}\n\nexport function createTranslate<T extends object>(obj?: Record<string, T>): Translate<T> {\n let locale = '';\n const tree = obj || {};\n\n return {\n locale(lang) {\n return (locale = lang || locale);\n },\n\n dict: ((lang, dict?) => {\n if (dict) {\n tree[lang] = Object.assign(tree[lang] || {}, dict);\n return;\n }\n return tree[lang];\n }) as Translate<T>['dict'],\n\n t(key, params, lang) {\n const val = get(tree[lang || locale], key, '') as any;\n if (process.env.NODE_ENV === 'development') {\n if (val == null) {\n return console.error(\n `[Translate] Missing the \"${[].concat(key as any).join('.')}\" key within the \"${\n lang || locale\n }\" dictionary`,\n );\n }\n }\n if (typeof val === 'function') return val(params);\n if (typeof val === 'string') return renderTemplate(val, params, 'common');\n return val;\n },\n };\n}\n"],"names":[],"mappings":";;;AAkBO,SAAS,gBAAkC,GAAuC,EAAA;AACvF,EAAA,IAAI,MAAS,GAAA,EAAA,CAAA;AACb,EAAM,MAAA,IAAA,GAAO,OAAO,EAAC,CAAA;AAErB,EAAO,OAAA;AAAA,IACL,OAAO,IAAM,EAAA;AACX,MAAA,OAAQ,SAAS,IAAQ,IAAA,MAAA,CAAA;AAAA,KAC3B;AAAA,IAEA,IAAA,EAAO,CAAC,IAAA,EAAM,IAAU,KAAA;AACtB,MAAA,IAAI,IAAM,EAAA;AACR,QAAA,IAAA,CAAK,QAAQ,MAAO,CAAA,MAAA,CAAO,KAAK,IAAS,CAAA,IAAA,IAAI,IAAI,CAAA,CAAA;AACjD,QAAA,OAAA;AAAA,OACF;AACA,MAAA,OAAO,IAAK,CAAA,IAAA,CAAA,CAAA;AAAA,KACd;AAAA,IAEA,CAAA,CAAE,GAAK,EAAA,MAAA,EAAQ,IAAM,EAAA;AACnB,MAAA,MAAM,MAAM,GAAI,CAAA,IAAA,CAAK,IAAQ,IAAA,MAAA,CAAA,EAAS,KAAK,EAAE,CAAA,CAAA;AAC7C,MAAI,IAAA,OAAA,CAAQ,GAAI,CAAA,QAAA,KAAa,aAAe,EAAA;AAC1C,QAAA,IAAI,OAAO,IAAM,EAAA;AACf,UAAA,OAAO,OAAQ,CAAA,KAAA;AAAA,YACb,CAAA,yBAAA,EAA4B,EAAG,CAAA,MAAA,CAAO,GAAU,CAAE,CAAA,IAAA,CAAK,GAAG,CAAA,CAAA,kBAAA,EACxD,IAAQ,IAAA,MAAA,CAAA,YAAA,CAAA;AAAA,WAEZ,CAAA;AAAA,SACF;AAAA,OACF;AACA,MAAA,IAAI,OAAO,GAAQ,KAAA,UAAA;AAAY,QAAA,OAAO,IAAI,MAAM,CAAA,CAAA;AAChD,MAAA,IAAI,OAAO,GAAQ,KAAA,QAAA;AAAU,QAAO,OAAA,cAAA,CAAe,GAAK,EAAA,MAAA,EAAQ,QAAQ,CAAA,CAAA;AACxE,MAAO,OAAA,GAAA,CAAA;AAAA,KACT;AAAA,GACF,CAAA;AACF;;;;"}
1
+ {"version":3,"file":"createTranslate.js","sources":["../../src/i18n/createTranslate.ts"],"sourcesContent":["import { get } from '../objects/get';\nimport type { ObjectPathLike } from '../objects/parseObjectPath';\nimport { renderTemplate } from '../strings/renderTemplate';\n\nexport interface Translate<T extends object> {\n /** Get/Set the language key */\n locale(lang?: string): string;\n\n /** Define the dict of translations for a language */\n dict(lang: string, dict: T): void;\n\n /** Get the dict of translations for a language */\n dict(lang: string): T;\n\n /** Retrieve a translation segment for the current language */\n t<X extends Record<string, any> | any[]>(key: ObjectPathLike, params?: X, lang?: string): string;\n}\n\nexport function createTranslate<T extends object>(obj?: Record<string, T>): Translate<T> {\n let locale = '';\n const tree = obj || {};\n // en-US -> en-US,en\n const keyOfDict = (s: string | string[]) => {\n if (Array.isArray(s)) {\n return s;\n }\n const sp = s.split(/[_-]/);\n if (sp.length > 1) {\n return [s, sp[0]];\n }\n return [s];\n };\n return {\n locale(lang) {\n return (locale = lang || locale);\n },\n\n dict: ((lang, dict?) => {\n if (dict) {\n tree[lang] = Object.assign(tree[lang] || {}, dict);\n return;\n }\n return tree[lang];\n }) as Translate<T>['dict'],\n\n t(key, params, lang) {\n let val: any;\n for (const k of keyOfDict(lang || locale)) {\n val = get(tree[k], key, '');\n if (val) {\n break;\n }\n }\n if (process.env.NODE_ENV === 'development') {\n if (val == null) {\n return console.error(\n `[Translate] Missing the \"${[].concat(key as any).join('.')}\" key within the \"${\n lang || locale\n }\" dictionary`,\n );\n }\n }\n if (typeof val === 'function') return val(params);\n if (typeof val === 'string') return renderTemplate(val, params, 'common');\n return val;\n },\n };\n}\n"],"names":[],"mappings":";;;AAkBO,SAAS,gBAAkC,GAAuC,EAAA;AACvF,EAAA,IAAI,MAAS,GAAA,EAAA,CAAA;AACb,EAAM,MAAA,IAAA,GAAO,OAAO,EAAC,CAAA;AAErB,EAAM,MAAA,SAAA,GAAY,CAAC,CAAyB,KAAA;AAC1C,IAAI,IAAA,KAAA,CAAM,OAAQ,CAAA,CAAC,CAAG,EAAA;AACpB,MAAO,OAAA,CAAA,CAAA;AAAA,KACT;AACA,IAAM,MAAA,EAAA,GAAK,CAAE,CAAA,KAAA,CAAM,MAAM,CAAA,CAAA;AACzB,IAAI,IAAA,EAAA,CAAG,SAAS,CAAG,EAAA;AACjB,MAAO,OAAA,CAAC,CAAG,EAAA,EAAA,CAAG,CAAE,CAAA,CAAA,CAAA;AAAA,KAClB;AACA,IAAA,OAAO,CAAC,CAAC,CAAA,CAAA;AAAA,GACX,CAAA;AACA,EAAO,OAAA;AAAA,IACL,OAAO,IAAM,EAAA;AACX,MAAA,OAAQ,SAAS,IAAQ,IAAA,MAAA,CAAA;AAAA,KAC3B;AAAA,IAEA,IAAA,EAAO,CAAC,IAAA,EAAM,IAAU,KAAA;AACtB,MAAA,IAAI,IAAM,EAAA;AACR,QAAA,IAAA,CAAK,QAAQ,MAAO,CAAA,MAAA,CAAO,KAAK,IAAS,CAAA,IAAA,IAAI,IAAI,CAAA,CAAA;AACjD,QAAA,OAAA;AAAA,OACF;AACA,MAAA,OAAO,IAAK,CAAA,IAAA,CAAA,CAAA;AAAA,KACd;AAAA,IAEA,CAAA,CAAE,GAAK,EAAA,MAAA,EAAQ,IAAM,EAAA;AACnB,MAAI,IAAA,GAAA,CAAA;AACJ,MAAA,KAAA,MAAW,CAAK,IAAA,SAAA,CAAU,IAAQ,IAAA,MAAM,CAAG,EAAA;AACzC,QAAA,GAAA,GAAM,GAAI,CAAA,IAAA,CAAK,CAAI,CAAA,EAAA,GAAA,EAAK,EAAE,CAAA,CAAA;AAC1B,QAAA,IAAI,GAAK,EAAA;AACP,UAAA,MAAA;AAAA,SACF;AAAA,OACF;AACA,MAAI,IAAA,OAAA,CAAQ,GAAI,CAAA,QAAA,KAAa,aAAe,EAAA;AAC1C,QAAA,IAAI,OAAO,IAAM,EAAA;AACf,UAAA,OAAO,OAAQ,CAAA,KAAA;AAAA,YACb,CAAA,yBAAA,EAA4B,EAAG,CAAA,MAAA,CAAO,GAAU,CAAE,CAAA,IAAA,CAAK,GAAG,CAAA,CAAA,kBAAA,EACxD,IAAQ,IAAA,MAAA,CAAA,YAAA,CAAA;AAAA,WAEZ,CAAA;AAAA,SACF;AAAA,OACF;AACA,MAAA,IAAI,OAAO,GAAQ,KAAA,UAAA;AAAY,QAAA,OAAO,IAAI,MAAM,CAAA,CAAA;AAChD,MAAA,IAAI,OAAO,GAAQ,KAAA,QAAA;AAAU,QAAO,OAAA,cAAA,CAAe,GAAK,EAAA,MAAA,EAAQ,QAAQ,CAAA,CAAA;AACxE,MAAO,OAAA,GAAA,CAAA;AAAA,KACT;AAAA,GACF,CAAA;AACF;;;;"}
package/lib/index.js CHANGED
@@ -7,16 +7,20 @@ export { clearAsyncInterval, setAsyncInterval } from './asyncs/AsyncInterval.js'
7
7
  export { sleep } from './asyncs/sleep.js';
8
8
  export { TimeoutError, timeout } from './asyncs/timeout.js';
9
9
  export { isPromise } from './asyncs/isPromise.js';
10
+ export { shallowEqual } from './langs/shallowEqual.js';
11
+ export { deepEqual } from './langs/deepEqual.js';
12
+ export { classOf } from './langs/classOf.js';
13
+ export { shallowClone } from './langs/shallowClone.js';
10
14
  export { isClass } from './validations/isClass.js';
11
15
  export { isDefined } from './validations/isDefined.js';
12
16
  export { isEmptyObject } from './validations/isEmptyObject.js';
13
- export { shallowEqual } from './langs/shallowEqual.js';
14
- export { deepEqual } from './langs/deepEqual.js';
15
17
  export { isUUID } from './validations/isUUID.js';
16
- export { classOf } from './langs/classOf.js';
18
+ export { isPlainObject } from './validations/isPlainObject.js';
19
+ export { parseTimestamp } from './validations/parseTimestamp.js';
20
+ export { parseBoolean } from './validations/parseBoolean.js';
17
21
  export { parseModuleId } from './modules/parseModuleId.js';
18
22
  export { isModule } from './modules/isModule.js';
19
- export { createWriteLogger } from './logging/createWriteLogger.js';
23
+ export { createLogger } from './logging/createLogger.js';
20
24
  export { createNoopLogger } from './logging/createNoopLogger.js';
21
25
  export { createChildLogger } from './logging/createChildLogger.js';
22
26
  export { camelCase, pascalCase } from './strings/camelCase.js';
@@ -26,6 +30,7 @@ export { createTranslate } from './i18n/createTranslate.js';
26
30
  export { isBuffer } from './io/isBuffer.js';
27
31
  export { isTransferable } from './io/isTransferable.js';
28
32
  export { ArrayBuffers } from './io/ArrayBuffers.js';
33
+ export { Buffer } from './io/Buffer.js';
29
34
  export { copy } from './browsers/copy.js';
30
35
  export { download } from './browsers/download.js';
31
36
  export { loadScripts, loadStyles } from './browsers/loaders.js';
@@ -33,7 +38,9 @@ export { getFileFromDataTransfer } from './browsers/getFileFromDataTransfer.js';
33
38
  export { getGlobalThis } from './isomorphics/getGlobalThis.js';
34
39
  export { structuredClone } from './isomorphics/structuredClone.js';
35
40
  export { randomUUID } from './crypto/randomUUID.js';
41
+ export { getRandomValues } from './crypto/getRandomValues.js';
36
42
  export { sha1, sha256, sha384, sha512 } from './crypto/hashing.js';
37
43
  export { hex } from './crypto/base.js';
44
+ export { createULID, isULID, parseULID, ulid } from './crypto/ulid.js';
38
45
  export { createRandom } from './maths/random.js';
39
46
  //# sourceMappingURL=index.js.map
package/lib/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,34 +1,40 @@
1
1
  import { classOf } from '../langs/classOf.js';
2
2
  import { isBuffer } from './isBuffer.js';
3
3
 
4
- const ArrayBuffers = {
5
- _allowedBuffer: true,
6
- isArrayBuffer: (v) => {
4
+ class ArrayBuffers {
5
+ static #_allowedNativeBuffer = true;
6
+ static #isNativeBufferValid() {
7
+ return this.#_allowedNativeBuffer && !globalThis.Buffer?.isPollyfill?.();
8
+ }
9
+ static setAllowedNativeBuffer(v) {
10
+ this.#_allowedNativeBuffer = v;
11
+ }
12
+ static isArrayBuffer = (v) => {
7
13
  return v instanceof ArrayBuffer;
8
- },
9
- slice: (o, start, end) => {
14
+ };
15
+ static slice = (o, start, end) => {
10
16
  if (isBuffer(o)) {
11
17
  return Uint8Array.prototype.slice.call(o, start, end);
12
18
  }
13
19
  return o.slice(start, end);
14
- },
15
- asView: (TypedArray, v, byteOffset, byteLength) => {
20
+ };
21
+ static asView = (TypedArray, v, byteOffset, byteLength) => {
16
22
  if (v instanceof TypedArray && (byteOffset ?? 0) === 0 && byteLength === void 0) {
17
23
  return v;
18
24
  }
19
25
  if (ArrayBuffer.isView(v) || isBuffer(v)) {
20
- if (ArrayBuffers._allowedBuffer && typeof Buffer !== "undefined" && TypedArray === Buffer) {
26
+ if (ArrayBuffers.#isNativeBufferValid() && TypedArray === Buffer) {
21
27
  return Buffer.from(v.buffer, byteOffset, byteLength);
22
28
  }
23
29
  return new TypedArray(v.buffer, v.byteOffset + (byteOffset ?? 0), byteLength ?? v.byteLength);
24
30
  }
25
31
  return new TypedArray(v, byteOffset, byteLength);
26
- },
27
- toString: (buf, encoding = "utf8") => {
32
+ };
33
+ static toString = (buf, encoding = "utf8") => {
28
34
  if (typeof buf === "string") {
29
35
  return buf;
30
36
  }
31
- if (typeof Buffer !== "undefined" && ArrayBuffers._allowedBuffer) {
37
+ if (ArrayBuffers.#isNativeBufferValid()) {
32
38
  return Buffer.from(ArrayBuffers.asView(Uint8Array, buf)).toString(encoding);
33
39
  }
34
40
  switch (encoding) {
@@ -65,11 +71,11 @@ const ArrayBuffers = {
65
71
  default:
66
72
  throw new Error(`[ArrayBuffers.toString] Unknown encoding: ${encoding}`);
67
73
  }
68
- },
69
- toJSON: (v, reviver) => {
74
+ };
75
+ static toJSON = (v, reviver) => {
70
76
  return JSON.parse(ArrayBuffers.toString(v), reviver);
71
- },
72
- alloc: (size, fill, encoding) => {
77
+ };
78
+ static alloc = (size, fill, encoding) => {
73
79
  if (fill !== void 0) {
74
80
  if (typeof fill === "number") {
75
81
  return new Uint8Array(size).fill(fill);
@@ -77,13 +83,13 @@ const ArrayBuffers = {
77
83
  return ArrayBuffers.asView(Uint8Array, ArrayBuffers.from(fill, encoding)).slice(0, size);
78
84
  }
79
85
  return new ArrayBuffer(size);
80
- },
81
- from: (v, encoding = "utf8") => {
86
+ };
87
+ static from = (v, encoding = "utf8") => {
82
88
  if (!v) {
83
89
  return new ArrayBuffer(0);
84
90
  }
85
91
  if (typeof v === "string") {
86
- if (typeof Buffer !== "undefined" && ArrayBuffers._allowedBuffer) {
92
+ if (ArrayBuffers.#isNativeBufferValid()) {
87
93
  return Buffer.from(v, encoding);
88
94
  }
89
95
  switch (encoding) {
@@ -110,8 +116,8 @@ const ArrayBuffers = {
110
116
  }
111
117
  const type = classOf(v);
112
118
  throw new TypeError(`ArrayBuffers.from unsupported type ${type}`);
113
- },
114
- isEncoding: (encoding) => {
119
+ };
120
+ static isEncoding = (encoding) => {
115
121
  switch (String(encoding).toLowerCase()) {
116
122
  case "hex":
117
123
  case "utf8":
@@ -127,8 +133,8 @@ const ArrayBuffers = {
127
133
  default:
128
134
  return false;
129
135
  }
130
- },
131
- concat: (buffers, result, offset = 0) => {
136
+ };
137
+ static concat = (buffers, result, offset = 0) => {
132
138
  const length = buffers.reduce((a, b) => a + b.byteLength, 0);
133
139
  const r = result ? new Uint8Array(result) : new Uint8Array(length);
134
140
  for (const buffer of buffers) {
@@ -146,8 +152,8 @@ const ArrayBuffers = {
146
152
  offset += buffer.byteLength;
147
153
  }
148
154
  return r.buffer;
149
- }
150
- };
155
+ };
156
+ }
151
157
  const hexLookupTable = function() {
152
158
  const alphabet = "0123456789abcdef";
153
159
  const table = new Array(256);
@@ -1 +1 @@
1
- {"version":3,"file":"ArrayBuffers.js","sources":["../../src/io/ArrayBuffers.ts"],"sourcesContent":["import { classOf } from '../langs/classOf';\nimport { isBuffer } from './isBuffer';\n\n/**\n * Various utils to work with {@link ArrayBuffer}\n */\nexport interface ArrayBuffers {\n /**\n * isArrayBuffer check if the given value is an {@link ArrayBuffer}\n */\n isArrayBuffer(v: any): v is ArrayBuffer;\n\n /**\n * slice the given view with the given offset and length, will handle the {@link Buffer} as well\n *\n * @see {@link https://nodejs.org/api/buffer.html#bufslicestart-end Buffer.slice}\n */\n slice<T extends ArrayBufferView>(o: T, start?: number, end?: number): T;\n\n /**\n * asView convert the given value to given {@link TypedArray} view\n *\n * TypedArray can be {@link Buffer}, will avoid copy\n */\n asView<C extends ArrayBufferViewConstructor<unknown>>(\n TypedArray: C,\n v: BufferSource,\n byteOffset?: number,\n byteLength?: number,\n ): InstanceType<C>;\n\n /**\n * toString convert the given {@link BufferSource} to string\n */\n toString(v: BufferSource | string, encoding?: ToStringEncoding): string;\n\n /**\n * Returns true if encoding is the name of a supported character encoding, or false otherwise.\n */\n isEncoding(v?: string): v is ToStringEncoding;\n\n toJSON<T = any>(v: BufferSource | string, reviver?: (this: any, key: string, value: any) => any): T;\n\n /**\n * from convert the given value to {@link ArrayBuffer}\n */\n from(v: string | BufferSource, encoding?: ToStringEncoding): ArrayBuffer;\n\n /**\n * concat the given {@link BufferSource} to a new {@link ArrayBuffer}\n */\n concat(buffers: Array<BufferSource>, result?: ArrayBuffer, offset?: number): ArrayBuffer;\n}\n\ntype ToStringEncoding =\n | 'ascii'\n | 'utf16le'\n // | 'utf-16le'\n | 'ucs2'\n | 'ucs-2'\n | 'base64'\n | 'base64url'\n | 'latin1'\n | 'binary'\n | 'utf8'\n | 'utf-8'\n | 'hex';\n\n// eslint-disable-next-line @typescript-eslint/no-redeclare\nexport const ArrayBuffers = {\n _allowedBuffer: true,\n isArrayBuffer: (v: any): v is ArrayBuffer => {\n return v instanceof ArrayBuffer;\n },\n slice: (o: TypedArray, start?: number, end?: number) => {\n // NodeJS Buffer slice is not the same as UInt8Array slice\n // https://nodejs.org/api/buffer.html#bufslicestart-end\n if (isBuffer(o)) {\n return Uint8Array.prototype.slice.call(o, start, end);\n }\n return o.slice(start, end);\n },\n asView: <C extends ArrayBufferViewConstructor<unknown>, I extends InstanceType<C>>(\n TypedArray: C,\n v: BufferSource,\n byteOffset?: number,\n byteLength?: number,\n ): I => {\n if (v instanceof TypedArray && (byteOffset ?? 0) === 0 && byteLength === undefined) {\n return v as I;\n }\n if (ArrayBuffer.isView(v) || isBuffer(v)) {\n if (ArrayBuffers._allowedBuffer && typeof Buffer !== 'undefined' && (TypedArray as any) === Buffer) {\n // new Buffer() is deprecated\n return Buffer.from(v.buffer, byteOffset, byteLength) as I;\n }\n return new TypedArray(v.buffer, v.byteOffset + (byteOffset ?? 0), byteLength ?? v.byteLength) as I;\n }\n return new TypedArray(v, byteOffset, byteLength) as I;\n },\n toString: (buf: BufferSource | string, encoding: ToStringEncoding = 'utf8') => {\n // 'ascii' 'utf16le' | 'ucs2' | 'ucs-2' | 'base64' | 'base64url' | 'latin1' | 'binary' | 'hex'\n if (typeof buf === 'string') {\n return buf;\n }\n if (typeof Buffer !== 'undefined' && ArrayBuffers._allowedBuffer) {\n return Buffer.from(ArrayBuffers.asView(Uint8Array, buf)).toString(encoding);\n }\n // reference\n // https://github.com/feross/buffer/blob/master/index.js\n switch (encoding) {\n case 'hex': {\n const view: Uint8Array = ArrayBuffers.asView(Uint8Array, buf);\n return [...view].map((b) => hexLookupTable[b]).join('');\n }\n case 'base64': {\n const view: Uint8Array = ArrayBuffers.asView(Uint8Array, buf);\n return btoa(String.fromCharCode(...view));\n }\n case 'utf8':\n // falls through\n case 'utf-8':\n return new TextDecoder().decode(buf as any);\n case 'ascii': {\n const view: Uint8Array = ArrayBuffers.asView(Uint8Array, buf);\n return String.fromCharCode(...view.map((v) => v & 0x7f));\n }\n case 'latin1':\n // falls through\n case 'binary': {\n const view: Uint8Array = ArrayBuffers.asView(Uint8Array, buf);\n return String.fromCharCode(...view);\n }\n case 'ucs2':\n // falls through\n case 'ucs-2':\n // case 'utf-16le':\n // falls through\n case 'utf16le': {\n const view: Uint8Array = ArrayBuffers.asView(Uint8Array, buf);\n let res = '';\n // If length is odd, the last 8 bits must be ignored (same as node.js)\n for (let i = 0; i < view.length - 1; i += 2) {\n res += String.fromCharCode(view[i] + view[i + 1] * 256);\n }\n return res;\n }\n default:\n throw new Error(`[ArrayBuffers.toString] Unknown encoding: ${encoding}`);\n }\n },\n toJSON: (v: BufferSource | string, reviver?: (this: any, key: string, value: any) => any) => {\n return JSON.parse(ArrayBuffers.toString(v), reviver);\n },\n alloc: (size: number, fill?: string | number, encoding?: ToStringEncoding) => {\n if (fill !== undefined) {\n if (typeof fill === 'number') {\n return new Uint8Array(size).fill(fill);\n }\n // as cast\n // https://stackoverflow.com/questions/73994091\n return ArrayBuffers.asView(Uint8Array, ArrayBuffers.from(fill, encoding)).slice(0, size);\n }\n return new ArrayBuffer(size);\n },\n from: (\n v: string | BufferSource | ArrayLike<number> | Iterable<number>,\n encoding: ToStringEncoding = 'utf8',\n ): BufferSource => {\n if (!v) {\n return new ArrayBuffer(0);\n }\n if (typeof v === 'string') {\n if (typeof Buffer !== 'undefined' && ArrayBuffers._allowedBuffer) {\n return Buffer.from(v, encoding);\n }\n\n switch (encoding) {\n case 'utf-8':\n // falls through\n case 'utf8':\n return new TextEncoder().encode(v).buffer;\n case 'base64':\n // replaceAll\n return Uint8Array.from(atob(v.replace(/[^0-9a-zA-Z=+/_ \\r\\n]/g, '')), (c) => c.charCodeAt(0));\n default:\n throw new Error(`[ArrayBuffers.from] Unknown encoding: ${encoding}`);\n }\n }\n if (v instanceof ArrayBuffer) {\n return v;\n }\n // lost length\n if (ArrayBuffer.isView(v) || isBuffer(v)) {\n if (v.byteOffset !== 0) {\n // return v.buffer.slice(v.byteOffset, v.byteOffset + v.byteLength)\n throw new Error('ArrayBuffers.from do not support view with offset');\n }\n return v.buffer;\n }\n if (Array.isArray(v)) {\n return new Uint8Array(v);\n }\n const type = classOf(v);\n throw new TypeError(`ArrayBuffers.from unsupported type ${type}`);\n },\n isEncoding: (encoding?: string) => {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n // case 'utf-16le':\n return true;\n default:\n return false;\n }\n },\n concat: (buffers: Array<BufferSource>, result?: ArrayBuffer, offset = 0) => {\n // https://stackoverflow.com/questions/10786128/appending-arraybuffers\n\n const length = buffers.reduce((a, b) => a + b.byteLength, 0);\n const r = result ? new Uint8Array(result) : new Uint8Array(length);\n for (const buffer of buffers) {\n if (!buffer || !buffer.byteLength) continue;\n let n: Uint8Array;\n if (buffer instanceof ArrayBuffer) {\n n = new Uint8Array(buffer);\n } else if (ArrayBuffer.isView(buffer)) {\n n = new Uint8Array(buffer.buffer, buffer.byteOffset, buffer.byteLength);\n } else {\n throw new Error(`ArrayBuffers.concat unsupported type ${classOf(buffer)}`);\n }\n r.set(n, offset);\n offset += buffer.byteLength;\n }\n return r.buffer;\n },\n};\n\nexport type TypedArray =\n | Uint8Array\n | Uint8ClampedArray\n | Uint16Array\n | Uint32Array\n | Int8Array\n | Int16Array\n | Int32Array\n | BigUint64Array\n | BigInt64Array\n | Float32Array\n | Float64Array;\n\ntype ArrayBufferViewConstructor<T> = new (buffer: ArrayBufferLike, byteOffset?: number, byteLength?: number) => T;\n\nconst hexLookupTable = (function () {\n const alphabet = '0123456789abcdef';\n const table = new Array(256);\n for (let i = 0; i < 16; ++i) {\n const i16 = i * 16;\n for (let j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j];\n }\n }\n return table;\n})();\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ArrayBuffers.js","sources":["../../src/io/ArrayBuffers.ts"],"sourcesContent":["import { classOf } from '../langs/classOf';\nimport { isBuffer } from './isBuffer';\n\n/**\n * Various utils to work with {@link ArrayBuffer}\n */\nexport interface ArrayBuffers {\n /**\n * isArrayBuffer check if the given value is an {@link ArrayBuffer}\n */\n isArrayBuffer(v: any): v is ArrayBuffer;\n\n /**\n * slice the given view with the given offset and length, will handle the {@link Buffer} as well\n *\n * @see {@link https://nodejs.org/api/buffer.html#bufslicestart-end Buffer.slice}\n */\n slice<T extends ArrayBufferView>(o: T, start?: number, end?: number): T;\n\n /**\n * asView convert the given value to given {@link TypedArray} view\n *\n * TypedArray can be {@link Buffer}, will avoid copy\n */\n asView<C extends ArrayBufferViewConstructor<unknown>>(\n TypedArray: C,\n v: BufferSource,\n byteOffset?: number,\n byteLength?: number,\n ): InstanceType<C>;\n\n /**\n * toString convert the given {@link BufferSource} to string\n */\n toString(v: BufferSource | string, encoding?: ToStringEncoding): string;\n\n /**\n * Returns true if encoding is the name of a supported character encoding, or false otherwise.\n */\n isEncoding(v?: string): v is ToStringEncoding;\n\n toJSON<T = any>(v: BufferSource | string, reviver?: (this: any, key: string, value: any) => any): T;\n\n /**\n * from convert the given value to {@link ArrayBuffer}\n */\n from(v: string | BufferSource, encoding?: ToStringEncoding): ArrayBuffer;\n\n /**\n * concat the given {@link BufferSource} to a new {@link ArrayBuffer}\n */\n concat(buffers: Array<BufferSource>, result?: ArrayBuffer, offset?: number): ArrayBuffer;\n}\n\ntype ToStringEncoding =\n | 'ascii'\n | 'utf16le'\n // | 'utf-16le'\n | 'ucs2'\n | 'ucs-2'\n | 'base64'\n | 'base64url'\n | 'latin1'\n | 'binary'\n | 'utf8'\n | 'utf-8'\n | 'hex';\n\nexport class ArrayBuffers {\n static #_allowedNativeBuffer: boolean = true;\n\n static #isNativeBufferValid() {\n return this.#_allowedNativeBuffer && !(globalThis.Buffer as any)?.isPollyfill?.();\n }\n\n static setAllowedNativeBuffer(v: boolean) {\n this.#_allowedNativeBuffer = v;\n }\n\n static isArrayBuffer = (v: any): v is ArrayBuffer => {\n return v instanceof ArrayBuffer;\n };\n\n static slice = (o: TypedArray, start?: number, end?: number) => {\n // NodeJS Buffer slice is not the same as UInt8Array slice\n // https://nodejs.org/api/buffer.html#bufslicestart-end\n if (isBuffer(o)) {\n return Uint8Array.prototype.slice.call(o, start, end);\n }\n return o.slice(start, end);\n };\n\n static asView = <C extends ArrayBufferViewConstructor<unknown>, I extends InstanceType<C>>(\n TypedArray: C,\n v: BufferSource,\n byteOffset?: number,\n byteLength?: number,\n ): I => {\n if (v instanceof TypedArray && (byteOffset ?? 0) === 0 && byteLength === undefined) {\n return v as I;\n }\n if (ArrayBuffer.isView(v) || isBuffer(v)) {\n if (ArrayBuffers.#isNativeBufferValid() && (TypedArray as any) === Buffer) {\n // new Buffer() is deprecated\n return Buffer.from(v.buffer, byteOffset, byteLength) as I;\n }\n return new TypedArray(v.buffer, v.byteOffset + (byteOffset ?? 0), byteLength ?? v.byteLength) as I;\n }\n return new TypedArray(v, byteOffset, byteLength) as I;\n };\n\n static toString = (buf: BufferSource | string, encoding: ToStringEncoding = 'utf8') => {\n // 'ascii' 'utf16le' | 'ucs2' | 'ucs-2' | 'base64' | 'base64url' | 'latin1' | 'binary' | 'hex'\n if (typeof buf === 'string') {\n return buf;\n }\n if (ArrayBuffers.#isNativeBufferValid()) {\n return Buffer.from(ArrayBuffers.asView(Uint8Array, buf)).toString(encoding);\n }\n // reference\n // https://github.com/feross/buffer/blob/master/index.js\n switch (encoding) {\n case 'hex': {\n const view: Uint8Array = ArrayBuffers.asView(Uint8Array, buf);\n return [...view].map((b) => hexLookupTable[b]).join('');\n }\n case 'base64': {\n const view: Uint8Array = ArrayBuffers.asView(Uint8Array, buf);\n return btoa(String.fromCharCode(...view));\n }\n case 'utf8':\n // falls through\n case 'utf-8':\n return new TextDecoder().decode(buf as any);\n case 'ascii': {\n const view: Uint8Array = ArrayBuffers.asView(Uint8Array, buf);\n return String.fromCharCode(...view.map((v) => v & 0x7f));\n }\n case 'latin1':\n // falls through\n case 'binary': {\n const view: Uint8Array = ArrayBuffers.asView(Uint8Array, buf);\n return String.fromCharCode(...view);\n }\n case 'ucs2':\n // falls through\n case 'ucs-2':\n // case 'utf-16le':\n // falls through\n case 'utf16le': {\n const view: Uint8Array = ArrayBuffers.asView(Uint8Array, buf);\n let res = '';\n // If length is odd, the last 8 bits must be ignored (same as node.js)\n for (let i = 0; i < view.length - 1; i += 2) {\n res += String.fromCharCode(view[i] + view[i + 1] * 256);\n }\n return res;\n }\n default:\n throw new Error(`[ArrayBuffers.toString] Unknown encoding: ${encoding}`);\n }\n };\n\n static toJSON = (v: BufferSource | string, reviver?: (this: any, key: string, value: any) => any) => {\n return JSON.parse(ArrayBuffers.toString(v), reviver);\n };\n\n static alloc = (size: number, fill?: string | number, encoding?: ToStringEncoding) => {\n if (fill !== undefined) {\n if (typeof fill === 'number') {\n return new Uint8Array(size).fill(fill);\n }\n // as cast\n // https://stackoverflow.com/questions/73994091\n return ArrayBuffers.asView(Uint8Array, ArrayBuffers.from(fill, encoding)).slice(0, size);\n }\n return new ArrayBuffer(size);\n };\n\n static from = (\n v: string | BufferSource | ArrayLike<number> | Iterable<number>,\n encoding: ToStringEncoding = 'utf8',\n ): BufferSource => {\n if (!v) {\n return new ArrayBuffer(0);\n }\n if (typeof v === 'string') {\n if (ArrayBuffers.#isNativeBufferValid()) {\n return Buffer.from(v, encoding);\n }\n\n switch (encoding) {\n case 'utf-8':\n // falls through\n case 'utf8':\n return new TextEncoder().encode(v).buffer;\n case 'base64':\n // replaceAll\n return Uint8Array.from(atob(v.replace(/[^0-9a-zA-Z=+/_ \\r\\n]/g, '')), (c) => c.charCodeAt(0));\n default:\n throw new Error(`[ArrayBuffers.from] Unknown encoding: ${encoding}`);\n }\n }\n if (v instanceof ArrayBuffer) {\n return v;\n }\n // lost length\n if (ArrayBuffer.isView(v) || isBuffer(v)) {\n if (v.byteOffset !== 0) {\n // return v.buffer.slice(v.byteOffset, v.byteOffset + v.byteLength)\n throw new Error('ArrayBuffers.from do not support view with offset');\n }\n return v.buffer;\n }\n if (Array.isArray(v)) {\n return new Uint8Array(v);\n }\n const type = classOf(v);\n throw new TypeError(`ArrayBuffers.from unsupported type ${type}`);\n };\n\n static isEncoding = (encoding?: string) => {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n // case 'utf-16le':\n return true;\n default:\n return false;\n }\n };\n\n static concat = (buffers: Array<BufferSource>, result?: ArrayBuffer, offset = 0) => {\n // https://stackoverflow.com/questions/10786128/appending-arraybuffers\n\n const length = buffers.reduce((a, b) => a + b.byteLength, 0);\n const r = result ? new Uint8Array(result) : new Uint8Array(length);\n for (const buffer of buffers) {\n if (!buffer || !buffer.byteLength) continue;\n let n: Uint8Array;\n if (buffer instanceof ArrayBuffer) {\n n = new Uint8Array(buffer);\n } else if (ArrayBuffer.isView(buffer)) {\n n = new Uint8Array(buffer.buffer, buffer.byteOffset, buffer.byteLength);\n } else {\n throw new Error(`ArrayBuffers.concat unsupported type ${classOf(buffer)}`);\n }\n r.set(n, offset);\n offset += buffer.byteLength;\n }\n return r.buffer;\n };\n}\n\nexport type TypedArray =\n | Uint8Array\n | Uint8ClampedArray\n | Uint16Array\n | Uint32Array\n | Int8Array\n | Int16Array\n | Int32Array\n | BigUint64Array\n | BigInt64Array\n | Float32Array\n | Float64Array;\n\ntype ArrayBufferViewConstructor<T> = new (buffer: ArrayBufferLike, byteOffset?: number, byteLength?: number) => T;\n\nconst hexLookupTable = (function () {\n const alphabet = '0123456789abcdef';\n const table = new Array(256);\n for (let i = 0; i < 16; ++i) {\n const i16 = i * 16;\n for (let j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j];\n }\n }\n return table;\n})();\n"],"names":[],"mappings":"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"}