zeed 0.7.88 → 0.7.92
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunk-5RYTX72C.js +7 -0
- package/dist/{chunk-Y627QIN4.js.map → chunk-5RYTX72C.js.map} +1 -1
- package/dist/chunk-CX4BRL7A.js +2 -0
- package/dist/{chunk-M4DWYKRV.js.map → chunk-CX4BRL7A.js.map} +1 -1
- package/dist/chunk-JL5GA55T.js +2 -0
- package/dist/{chunk-ZGT7XOTR.js.map → chunk-JL5GA55T.js.map} +1 -1
- package/dist/chunk-LNZLD7Y3.js +2 -0
- package/dist/chunk-LNZLD7Y3.js.map +1 -0
- package/dist/chunk-QHJAXTKB.js +5 -0
- package/dist/chunk-QHJAXTKB.js.map +1 -0
- package/dist/index.all.cjs +9 -2
- package/dist/index.all.cjs.map +1 -1
- package/dist/index.all.d.ts +3 -3
- package/dist/index.all.js +1 -1
- package/dist/index.browser.cjs +4 -2
- package/dist/index.browser.cjs.map +1 -1
- package/dist/index.browser.d.ts +2 -2
- package/dist/index.browser.js +1 -1
- package/dist/index.log.cjs +1 -1
- package/dist/index.log.cjs.map +1 -1
- package/dist/index.log.js +1 -1
- package/dist/index.node.cjs +9 -2
- package/dist/index.node.cjs.map +1 -1
- package/dist/index.node.d.ts +2 -2
- package/dist/index.node.js +1 -1
- package/dist/{log-colors-d3a31301.d.ts → log-colors-cbc6f14c.d.ts} +1 -1
- package/dist/{log-util-59218e84.d.ts → log-util-f967a299.d.ts} +1 -1
- package/dist/{uuid-c63c5872.d.ts → uuid-45c3296c.d.ts} +28 -8
- package/package.json +7 -7
- package/dist/chunk-77QKZOKH.js +0 -3
- package/dist/chunk-77QKZOKH.js.map +0 -1
- package/dist/chunk-DZWX2X3Q.js +0 -2
- package/dist/chunk-DZWX2X3Q.js.map +0 -1
- package/dist/chunk-M4DWYKRV.js +0 -2
- package/dist/chunk-Y627QIN4.js +0 -2
- package/dist/chunk-ZGT7XOTR.js +0 -2
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import{Xa as K,ib as j,oa as $}from"./chunk-QHJAXTKB.js";import{c as l,q as T,r as F,s as m,x,y as P,z as _}from"./chunk-LNZLD7Y3.js";import O from"fs";import{resolve as ae}from"path";var L=x("zeed:env"),ce=`
|
|
2
|
+
`,fe=/^\s*([\w_.-]+)\s*=\s*(.*)?\s*$/,ge=/\\n/g,ue=/\n|\r|\r\n/;function U(e,t={}){let r={};return e.toString().split(ue).forEach(function(n,i){let o=n.match(fe);if(o!=null){let c=o[1],s=o[2]||"",g=s.length-1,p=s[0]==='"'&&s[g]==='"';s[0]==="'"&&s[g]==="'"||p?(s=s.substring(1,g),p&&(s=s.replace(ge,ce))):s=s.trim(),r[c]=s}else L.debug(`did not match key and value when parsing line ${i+1}: ${n}`)}),r}l(U,"parse");function me(e,t="."){return ae(process.cwd(),e!=null?e:t)}l(me,"stringToPath");function de(e,t=""){return e==null&&(e=t),me(String(e).trim(),t)}l(de,"valueToPath");var R=de;function Ie(e={}){var i,o,c,s;let t=(o=e==null?void 0:e.path)!=null?o:R((i=e==null?void 0:e.filename)!=null?i:".env"),r=(c=e==null?void 0:e.encoding)!=null?c:"utf8",n=(e==null?void 0:e.debug)||!1;n!==!0&&(L.level=m.off);try{let g=O.existsSync(t)?U(O.readFileSync(t,{encoding:r}),{debug:n}):{},p=O.existsSync(t+".local")?U(O.readFileSync(t+".local",{encoding:r}),{debug:n}):{},y=Object.assign({},g,p),f=(s=e==null?void 0:e.env)!=null?s:process.env;return Object.entries(y).forEach(([u,d])=>{typeof(e==null?void 0:e.prefix)=="string"&&(u=(e==null?void 0:e.prefix)+u),Object.prototype.hasOwnProperty.call(f,u)?L.debug(`"${u}" is already defined and will not be overwritten`):d!=null&&(L.info(`set env.${u} = ${d}`),f[u]=d)}),{parsed:y}}catch(g){return L.error(g),{error:g}}}l(Ie,"setupEnv");import{mkdirSync as pe,readdirSync as he,readFileSync as Y,rmSync as ye,unlinkSync as be,writeFileSync as Se}from"fs";import{dirname as ve,resolve as J}from"path";var B=x("zeed:filestorage"),Q=class{constructor(t={}){this.store={};this.fileKeys=void 0;this.pretty=!1;var r,n,i,o;this.dirname=J(process.cwd(),t.path||".fileStorage"),this.pretty=!!t.pretty,this.extension=(r=t.extension)!=null?r:".json",t.extension&&!this.extension.startsWith(".")&&(this.extension="."+this.extension),this.extensionLength=this.extension.length,this.objectToString=(n=t.objectToString)!=null?n:c=>this.pretty?JSON.stringify(c,null,2):JSON.stringify(c),this.objectFromString=(i=t.objectFromString)!=null?i:c=>{try{return JSON.parse(c)}catch(s){B.warn(`fileStorage parse error '${s}' in`,c)}},this.keyToFilename=(o=t.keyToFilename)!=null?o:K}setItem(t,r){this.store[t]=j(r);try{let n=this.objectToString(r),i=this.getPath(t);pe(ve(i),{recursive:!0}),Se(i,n,"utf8")}catch(n){B.error("setItem error",n)}}getPath(t){return J(this.dirname,this.keyToFilename(t)+this.extension)}getBuffer(t){let r=this.getPath(t);return Buffer.from(Y(r))}getItem(t){let r=this.store[t];if(r!==null){if(r!=null)return j(r);try{let n=this.getPath(t),i=Y(n,"utf8");if(i!=null){let o=this.objectFromString(i);return this.store[t]=o,o}}catch(n){B.warn("getItem error",n),this.store[t]=null}}}removeItem(t){if(delete this.store[t],this.fileKeys!=null){let r=this.fileKeys.indexOf(t);r!==-1&&this.fileKeys.splice(r,1)}try{let r=this.getPath(t);be(r)}catch{}}clear(){this.fileKeys=[],this.store={},ye(this.dirname,{recursive:!0,force:!0})}allKeys(){if(this.fileKeys==null)try{this.fileKeys=he(this.dirname,{withFileTypes:!0}).filter(r=>!r.isDirectory()&&r.name.endsWith(this.extension)).map(r=>r.name.slice(0,-this.extensionLength))||[]}catch{}let t=[...this.fileKeys||[]];for(let r of Object.keys(this.store))t.includes(r)||t.push(r);return t.sort(),t}};l(Q,"FileStorage");import{createWriteStream as xe,mkdirSync as Le}from"fs";import{dirname as Ee,resolve as we}from"path";var z={};function V(e,t={}){let{level:r=m.all,filter:n="*"}=t;e=we(process.cwd(),e),Le(Ee(e),{recursive:!0});var i=xe(e,{flags:"a"});let o=T(n),c=F(r);return s=>{if(!c(s.level)||!o(s.name))return;let g=new Date().toISOString(),p=s.name||"",y=z[p||""];y==null&&(z[p]=y);let f=[`[${p||"*"}]`,$(s.messages,{pretty:!1})];function u(...d){i.write(d.join(" ")+`
|
|
3
|
+
`)}switch(l(u,"write"),s.level){case m.info:u(g,"I|* ",...f);break;case m.warn:u(g,"W|** ",...f);break;case m.error:u(g,"E|***",...f);break;default:u(g,"D| ",...f);break}}}l(V,"LoggerFileHandler");import{resolve as Z}from"path";function Ne(e){var t,r;return typeof e!="string"?[]:((r=(t=e==null?void 0:e.split(`
|
|
4
|
+
`))==null?void 0:t.map(n=>{let i=n.match(/^\s+at.*(\((.*)\)|file:\/\/(.*)$)/);if(i){let o=i[3]||i[2];return o.endsWith(")")&&(o=o.slice(0,-1)),o}}))==null?void 0:r.filter(n=>n!=null))||[]}l(Ne,"getStackLlocationList");var D=Z(process.cwd()),ee,te,H=((ee=process.env)==null?void 0:ee.HOME)?Z((te=process.env)==null?void 0:te.HOME):"";function q(e){if(e.includes("/node_modules/"))return"";let t="file://";return e.startsWith(t)?e.substr(t.length):D&&e.startsWith(D)?e.substr(D.length+1):(H&&e.startsWith(H)&&(e="~/"+e.substr(H.length+1)),e)}l(q,"pathStripCwd");function Te(e){let t=e.match(/^\s*at.*(\((.*)\)|file:\/\/(.*)$)/);if(t){let r=t[3]||t[2];return r.endsWith(")")&&(r=r.slice(0,-1)),r}return""}l(Te,"extractFileInfo");function I(e=2,t=!0){var i;let r=new Error().stack||"",n=(i=Ne(r))==null?void 0:i[e];return n&&t&&(n=q(n)),n||""}l(I,"getSourceLocation");function X(){return new Error().stack||""}l(X,"getStack");function C(e,t=!0){let r="",n=new Error().stack||"";if(typeof n=="string"){let i=n.split(`
|
|
5
|
+
`).map(c=>c.trim()),o=i.findIndex(c=>e.some(s=>c.startsWith(s)));r=i[o+1],r&&(r=Te(r)),r&&t&&(r=q(r))}return r}l(C,"getSourceLocationByPrecedingPattern");import re from"tty";function Fe(){try{return re.isatty(process.stdout.fd)}catch{}return!1}l(Fe,"isTTY");var ne=[6,2,3,4,5,1];function $e(e){let t=0;for(let r=0;r<e.length;r++)t=(t<<5)-t+e.charCodeAt(r),t|=0;return ne[Math.abs(t)%ne.length]}l($e,"selectColor");var ie={},Oe=P(),W=re.isatty(process.stderr.fd);function k(...e){return process.stderr.write($(e)+`
|
|
6
|
+
`)}l(k,"log");var E={BOLD:"[1m",UNBOLD:"[2m",RED:"[31m",GREEN:"[32m",BLUE:"[34m",PURPLE:"[35m",GRAY:"[37m",ORANGE:"[38;5;208m",UNCOLOR:"[0m"};var se="[0m";function w(e,t){return`${t===8?E.ORANGE:"[3"+(t<8?t:"8;5;"+t)+"m"}${e}${se}`}l(w,"colorString");function oe(e,t,r=!0){return e.map(n=>{if(typeof n!="string")return n;let i=t,o=se;return r&&(i=`${E.BOLD}${i}`,o=`${o}${E.BOLD}`),`${i}${n}${o}`})}l(oe,"colorStringList");var ke="loggerStackTraceDebug-7d38e5a9214b58d29734374cdb9521fd964d7485";function le(e={}){let{level:t=void 0,filter:r=void 0,colors:n=Fe(),levelHelper:i=!0,nameBrackets:o=!0,padding:c=0,fill:s=0,stack:g=!0}=e,p=T(r),y=F(t);return f=>{var M;if(!y(f.level)||!p(f.name))return;let u=P(),d=f.name||"",N=ie[d||""];N==null&&(N={color:$e(d)},ie[d]=N);let G=_(u-Oe),a,v=o?`[${d}]`:d;if(c>0&&(v=v.padStart(c," ")),s>0&&(v=v.padEnd(s," ")),n&&W){let h=N.color;a=[w(v,h)+" | "],f.level===m.warn?a.push(...oe(f.messages,E.ORANGE)):f.level===m.error?a.push(...oe(f.messages,E.RED)):a.push(...f.messages),a.push(w(`+${G}`,h))}else a=[v,...f.messages],a.push(`+${G}`);if(((M=f.messages)==null?void 0:M[0])===ke&&console.log(X()),g){let h="";typeof g=="boolean"?(h=C(["at Function.","at null.log (","at log ("],!0),h||(h=I(0,!0))):h=I(typeof g=="number"?g:3,!0),h&&a.push(w(`(${h})`,7))}switch(f.level){case m.info:i&&(a[0]="I|* "+a[0]),k(...a);break;case m.warn:i&&(a[0]=(n&&W?w("W|** ",8):"W|** ")+a[0]),k(...a);break;case m.error:i&&(a[0]=(n&&W?w("E|*** ",1):"E|*** ")+a[0]),k(...a);break;default:i&&(a[0]="D| "+a[0]),k(...a);break}}}l(le,"LoggerNodeHandler");import A from"crypto";try{A&&A.webcrypto&&typeof globalThis!="undefined"&&typeof globalThis.crypto=="undefined"&&(globalThis.crypto=A.webcrypto)}catch(e){console.warn("Failed to polyfill webcrypto",e)}function je(){var r;let e=[le({padding:32,nameBrackets:!1})],t=(r=process.env.ZEED_LOG)!=null?r:process.env.LOG;t&&e.unshift(V(R(t))),x.setHandlers(e)}l(je,"setupLogContextNode");je();export{me as a,de as b,R as c,Ie as d,Q as e,V as f,Ne as g,I as h,X as i,C as j,Fe as k,w as l,oe as m,ke as n,le as o};
|
|
7
|
+
//# sourceMappingURL=chunk-5RYTX72C.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/node/env.ts","../src/node/filestorage.ts","../src/node/log-file.ts","../src/node/log-util.ts","../src/node/log-node.ts","../src/node/crypto.ts","../src/node/log-context-node.ts"],"sourcesContent":["// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\n// Adopted from https://github.com/motdotla/dotenv BSD-2\n\nimport { LogLevel } from \"../common/log-base\"\nimport { Logger } from \"../common/log\"\n\nimport fs from \"fs\"\nimport { resolve } from \"path\"\n\nconst log = Logger(\"zeed:env\")\n\nconst NEWLINE = \"\\n\"\nconst RE_INI_KEY_VAL = /^\\s*([\\w_.-]+)\\s*=\\s*(.*)?\\s*$/\nconst RE_NEWLINES = /\\\\n/g\nconst NEWLINES_MATCH = /\\n|\\r|\\r\\n/\n\ntype csvOptions = {\n /** @deprecated will probably be replaced by logLevel */\n debug?: boolean\n path?: string\n filename?: string\n encoding?: BufferEncoding\n prefix?: string\n env?: Record<string, string>\n}\n\n// Parses src into an Object\nfunction parse(src: string, options: csvOptions = {}) {\n let obj: Record<string, string> = {}\n\n // convert Buffers before splitting into lines and processing\n src\n .toString()\n .split(NEWLINES_MATCH)\n .forEach(function (line, idx) {\n // matching \"KEY' and 'VAL' in 'KEY=VAL'\n const keyValueArr = line.match(RE_INI_KEY_VAL)\n // matched?\n\n // log.debug(\"keyValueArr\", keyValueArr)\n\n if (keyValueArr != null) {\n const key = keyValueArr[1]\n // default undefined or missing values to empty string\n let val = keyValueArr[2] || \"\"\n const end = val.length - 1\n const isDoubleQuoted = val[0] === '\"' && val[end] === '\"'\n const isSingleQuoted = val[0] === \"'\" && val[end] === \"'\"\n\n // if single or double quoted, remove quotes\n if (isSingleQuoted || isDoubleQuoted) {\n val = val.substring(1, end)\n\n // if double quoted, expand newlines\n if (isDoubleQuoted) {\n val = val.replace(RE_NEWLINES, NEWLINE)\n }\n } else {\n // remove surrounding whitespace\n val = val.trim()\n }\n obj[key] = val\n } else {\n log.debug(\n `did not match key and value when parsing line ${idx + 1}: ${line}`\n )\n }\n })\n\n // log.debug(\"obj\", obj)\n return obj\n}\n\n/**\n * Return a path relative to the current working directory\n */\nexport function stringToPath(\n value?: string,\n defaultValue: string = \".\"\n): string {\n return resolve(process.cwd(), value ?? defaultValue)\n}\n\nexport function valueToPath(value?: any, defaultValue = \"\"): string {\n if (value == null) value = defaultValue\n return stringToPath(String(value).trim(), defaultValue)\n}\n\nexport const toPath = valueToPath\n\n// Populates process.env from .env file\nexport function setupEnv(options: csvOptions = {}) {\n const dotenvPath: string =\n options?.path ?? toPath(options?.filename ?? \".env\")\n const encoding: BufferEncoding = options?.encoding ?? \"utf8\"\n const debug = options?.debug || false\n\n if (debug !== true) log.level = LogLevel.off\n\n try {\n // specifying an encoding returns a string instead of a buffer\n const parsedEnv = fs.existsSync(dotenvPath)\n ? parse(fs.readFileSync(dotenvPath, { encoding }), { debug })\n : {}\n const parsedEnvLocal = fs.existsSync(dotenvPath + \".local\")\n ? parse(fs.readFileSync(dotenvPath + \".local\", { encoding }), { debug })\n : {}\n\n const parsed: Record<string, string> = Object.assign(\n {},\n parsedEnv,\n parsedEnvLocal\n )\n let env = options?.env ?? process.env\n\n Object.entries(parsed).forEach(([key, value]) => {\n if (typeof options?.prefix === \"string\") {\n key = options?.prefix + key\n }\n if (!Object.prototype.hasOwnProperty.call(env, key)) {\n if (value != null) {\n log.info(`set env.${key} = ${value}`)\n env[key] = value\n }\n } else {\n log.debug(`\"${key}\" is already defined and will not be overwritten`)\n }\n })\n return { parsed }\n } catch (e) {\n log.error(e)\n return { error: e }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport {\n mkdirSync,\n readdirSync,\n readFileSync,\n rmSync,\n unlinkSync,\n writeFileSync,\n} from \"fs\"\nimport { dirname, resolve } from \"path\"\nimport { toValidFilename } from \"../common/data/path\"\nimport { cloneObject } from \"../common/data/utils\"\nimport { Logger } from \"../common/log\"\nimport { Json, ObjectStorage } from \"../common/types\"\n\nconst log = Logger(\"zeed:filestorage\")\n\nexport interface FileStorageOptions {\n pretty?: boolean\n path?: string\n extension?: string\n objectFromString?: (data: string) => any\n objectToString?: (data: any) => string\n keyToFilename?: (key: string) => string\n}\n\nexport class FileStorage<T = Json> implements ObjectStorage<T> {\n private store: Record<string, T | null> = {}\n private dirname: string\n private fileKeys?: string[] = undefined\n private pretty: boolean = false\n private extension: string\n private extensionLength: number\n private objectFromString: (data: string) => any\n private objectToString: (data: any) => string\n private keyToFilename: (key: string) => string\n\n constructor(opt: FileStorageOptions = {}) {\n this.dirname = resolve(process.cwd(), opt.path || \".fileStorage\")\n this.pretty = !!opt.pretty\n this.extension = opt.extension ?? \".json\"\n\n if (opt.extension && !this.extension.startsWith(\".\")) {\n this.extension = \".\" + this.extension\n }\n this.extensionLength = this.extension.length\n\n this.objectToString =\n opt.objectToString ??\n ((data: any): string => {\n return this.pretty\n ? JSON.stringify(data, null, 2)\n : JSON.stringify(data)\n })\n\n this.objectFromString =\n opt.objectFromString ??\n ((data: string) => {\n try {\n return JSON.parse(data)\n } catch (err) {\n log.warn(`fileStorage parse error '${err}' in`, data)\n }\n })\n\n this.keyToFilename = opt.keyToFilename ?? toValidFilename\n }\n\n setItem(key: string, value: T): void {\n this.store[key] = cloneObject(value)\n try {\n const data = this.objectToString(value)\n const path = this.getPath(key)\n mkdirSync(dirname(path), { recursive: true })\n writeFileSync(path, data, \"utf8\")\n } catch (err) {\n log.error(\"setItem error\", err)\n }\n }\n\n getPath(key: string): string {\n return resolve(this.dirname, this.keyToFilename(key) + this.extension)\n }\n\n getBuffer(key: string): Buffer {\n const path = this.getPath(key)\n return Buffer.from(readFileSync(path))\n }\n\n getItem(key: string): T | undefined {\n let value = this.store[key]\n\n // null is an indicator for not existing!\n if (value === null) return\n\n if (value != null) {\n return cloneObject(value) // this.objectFromString(value)\n }\n\n try {\n const path = this.getPath(key)\n const data = readFileSync(path, \"utf8\")\n if (data != null) {\n const value = this.objectFromString(data)\n this.store[key] = value\n return value\n }\n } catch (err) {\n log.warn(\"getItem error\", err)\n this.store[key] = null // do not retry next time\n }\n }\n\n removeItem(key: string): void {\n delete this.store[key]\n if (this.fileKeys != null) {\n const index: number = this.fileKeys.indexOf(key)\n if (index !== -1) {\n this.fileKeys.splice(index, 1)\n }\n }\n try {\n const path = this.getPath(key)\n unlinkSync(path)\n } catch (err) {}\n }\n\n clear(): void {\n this.fileKeys = []\n this.store = {}\n rmSync(this.dirname, { recursive: true, force: true })\n }\n\n allKeys(): string[] {\n if (this.fileKeys == null) {\n try {\n this.fileKeys =\n readdirSync(this.dirname, { withFileTypes: true })\n .filter(\n (item) =>\n !item.isDirectory() && item.name.endsWith(this.extension)\n )\n .map((item) => item.name.slice(0, -this.extensionLength)) || []\n } catch (err) {}\n }\n let keys = [...(this.fileKeys || [])]\n for (let key of Object.keys(this.store)) {\n if (!keys.includes(key)) {\n keys.push(key)\n }\n }\n keys.sort()\n return keys\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { createWriteStream, mkdirSync } from \"fs\"\nimport { dirname, resolve } from \"path\"\nimport { renderMessages } from \"../common/data/convert\"\nimport { LogHandlerOptions, LogLevel, LogMessage } from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\n\nlet namespaces: Record<string, any> = {}\n\nexport function LoggerFileHandler(path: string, opt: LogHandlerOptions = {}) {\n const { level = LogLevel.all, filter = \"*\" } = opt\n path = resolve(process.cwd(), path)\n mkdirSync(dirname(path), { recursive: true })\n var stream = createWriteStream(path, { flags: \"a\" })\n // stream.end()\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n\n const time = new Date().toISOString()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n namespaces[name] = ninfo\n }\n\n let args: string[] = [\n `[${name || \"*\"}]`,\n renderMessages(msg.messages, { pretty: false }),\n ]\n\n function write(...args: string[]): void {\n stream.write(args.join(\"\\t\") + \"\\n\")\n }\n\n switch (msg.level) {\n case LogLevel.info:\n write(time, `I|* `, ...args)\n break\n case LogLevel.warn:\n write(time, `W|** `, ...args)\n break\n case LogLevel.error:\n write(time, `E|***`, ...args)\n break\n default:\n write(time, `D| `, ...args)\n break\n }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { resolve } from \"path\"\n\nexport function getStackLlocationList(stack: string): any[] {\n if (typeof stack !== \"string\") return []\n // console.log(\"stack\", stack)\n return (\n stack\n ?.split(\"\\n\")\n ?.map((rawLine) => {\n let m = rawLine.match(/^\\s+at.*(\\((.*)\\)|file:\\/\\/(.*)$)/)\n if (m) {\n let line = m[3] || m[2]\n if (line.endsWith(\")\")) line = line.slice(0, -1)\n return line\n }\n })\n ?.filter((v) => v != null) || []\n )\n}\n\nconst cwd = resolve(process.cwd())\nconst home = process.env?.HOME ? resolve(process.env?.HOME) : \"\"\n// console.log(`cwd = ${cwd}, home = ${home}}`)\n\nfunction pathStripCwd(path: string) {\n // console.log(\">\", path)\n\n if (path.includes(\"/node_modules/\")) {\n return \"\"\n }\n\n const fileURL = \"file://\"\n if (path.startsWith(fileURL)) {\n return path.substr(fileURL.length)\n }\n\n if (cwd && path.startsWith(cwd)) {\n return path.substr(cwd.length + 1)\n }\n\n if (home && path.startsWith(home)) {\n path = \"~/\" + path.substr(home.length + 1)\n }\n\n return path\n}\n\nfunction extractFileInfo(stackLine: string): string {\n let m = stackLine.match(/^\\s*at.*(\\((.*)\\)|file:\\/\\/(.*)$)/)\n if (m) {\n let line = m[3] || m[2]\n if (line.endsWith(\")\")) line = line.slice(0, -1)\n return line\n }\n return \"\"\n}\n\n/**\n * Get the source code location of the caller\n * https://stackoverflow.com/a/47296370/140927\n *\n * @param level Number of levels to go down the stack trace\n * @param stripCwd Strip the current working directory, only reasonable for Node.js environment\n * @returns\n */\nexport function getSourceLocation(level = 2, stripCwd = true): string {\n let stack = new Error().stack || \"\"\n let line: string | undefined = getStackLlocationList(stack)?.[level]\n if (line && stripCwd) {\n line = pathStripCwd(line)\n }\n return line || \"\"\n}\n\nexport function getStack(): string {\n return new Error().stack || \"\"\n}\n\nexport function getSourceLocationByPrecedingPattern(\n patterns: string[],\n stripCwd = true\n) {\n let line = \"\"\n let stack = new Error().stack || \"\"\n if (typeof stack === \"string\") {\n const lines = stack.split(\"\\n\").map((l) => l.trim())\n // console.log(lines)\n const index = lines.findIndex((l) => patterns.some((p) => l.startsWith(p)))\n line = lines[index + 1]\n if (line) {\n line = extractFileInfo(line)\n }\n if (line && stripCwd) {\n line = pathStripCwd(line)\n }\n }\n return line\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport tty from \"tty\"\nimport { renderMessages } from \"../common/data/convert\"\nimport {\n LogHandler,\n LogHandlerOptions,\n LogLevel,\n LogMessage,\n} from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\nimport {\n getSourceLocation,\n getSourceLocationByPrecedingPattern,\n getStack,\n} from \"./log-util\"\nimport { formatMilliseconds, getTimestamp } from \"../common/time\"\n\nexport function isTTY(): boolean {\n try {\n return tty.isatty(process.stdout.fd)\n } catch (err) {}\n return false\n}\n\nconst colors = [6, 2, 3, 4, 5, 1]\n\nfunction selectColor(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n\nlet namespaces: Record<string, any> = {}\n\nlet time = getTimestamp()\n\nconst useColors = tty.isatty(process.stderr.fd)\n\nfunction log(...args: any[]) {\n return process.stderr.write(renderMessages(args) + \"\\n\")\n}\n\n// export const BOLD = Symbol()\n// export const UNBOLD = Symbol()\n// export const BLUE = Symbol()\n// export const GREY = Symbol()\n// export const GREEN = Symbol()\n// export const RED = Symbol()\n// export const PURPLE = Symbol()\n// export const ORANGE = Symbol()\n// export const UNCOLOR = Symbol()\n\n// const _browserStyleMap = {\n// [BOLD]: pair.create(\"font-weight\", \"bold\"),\n// [UNBOLD]: pair.create(\"font-weight\", \"normal\"),\n// [BLUE]: pair.create(\"color\", \"blue\"),\n// [GREEN]: pair.create(\"color\", \"green\"),\n// [GREY]: pair.create(\"color\", \"grey\"),\n// [RED]: pair.create(\"color\", \"red\"),\n// [PURPLE]: pair.create(\"color\", \"purple\"),\n// [ORANGE]: pair.create(\"color\", \"orange\"), // not well supported in chrome when debugging node with inspector - TODO: deprecate\n// [UNCOLOR]: pair.create(\"color\", \"black\"),\n// }\n\nconst TTY_STYLE = {\n BOLD: \"\\u001b[1m\",\n UNBOLD: \"\\u001b[2m\",\n RED: \"\\u001b[31m\",\n GREEN: \"\\u001b[32m\",\n BLUE: \"\\u001b[34m\",\n PURPLE: \"\\u001b[35m\",\n GRAY: \"\\u001b[37m\",\n ORANGE: \"\\u001b[38;5;208m\",\n UNCOLOR: \"\\u001b[0m\",\n}\n\nenum COLOR {\n RED = 1,\n GREEN = 2,\n BLUE = 4,\n PURPLE = 5,\n GRAY = 7,\n ORANGE = 8,\n}\n\nconst colorEnd = \"\\u001B[0m\"\n\nexport function colorString(value: string, colorCode: number) {\n const colorStart =\n colorCode === COLOR.ORANGE\n ? TTY_STYLE.ORANGE\n : \"\\u001B[3\" + (colorCode < 8 ? colorCode : \"8;5;\" + colorCode) + \"m\"\n return `${colorStart}${value}${colorEnd}`\n}\n\nexport function colorStringList(\n list: Array<any>,\n style: string,\n bold: boolean = true\n) {\n return list.map((value) => {\n if (typeof value !== \"string\") return value\n let start = style\n let end = colorEnd\n if (bold) {\n start = `${TTY_STYLE.BOLD}${start}`\n end = `${end}${TTY_STYLE.BOLD}`\n }\n return `${start}${value}${end}`\n })\n}\n\nexport const loggerStackTraceDebug =\n \"loggerStackTraceDebug-7d38e5a9214b58d29734374cdb9521fd964d7485\"\n\nexport function LoggerNodeHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n level = undefined,\n filter = undefined,\n colors = isTTY(),\n levelHelper = true,\n nameBrackets = true,\n padding = 0,\n fill = 0,\n stack = true,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n const timeNow = getTimestamp()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n ninfo = {\n color: selectColor(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const diff = formatMilliseconds(timeNow - time)\n\n let args: string[]\n\n let displayName = nameBrackets ? `[${name}]` : name\n\n if (padding > 0) {\n displayName = displayName.padStart(padding, \" \")\n }\n\n if (fill > 0) {\n displayName = displayName.padEnd(fill, \" \")\n }\n\n if (colors && useColors) {\n const c = ninfo.color\n args = [colorString(displayName, c) + ` | `] // nameBrackets ? [`%c[${name}]`] : [`%c${name}`]\n if (msg.level === LogLevel.warn) {\n args.push(...colorStringList(msg.messages, TTY_STYLE.ORANGE))\n } else if (msg.level === LogLevel.error) {\n args.push(...colorStringList(msg.messages, TTY_STYLE.RED))\n } else {\n args.push(...msg.messages)\n }\n args.push(colorString(`+${diff}`, c))\n } else {\n args = [displayName, ...msg.messages]\n args.push(`+${diff}`)\n }\n\n if (msg.messages?.[0] === loggerStackTraceDebug) {\n console.log(getStack())\n }\n\n if (stack) {\n let line: string = \"\"\n if (typeof stack === \"boolean\") {\n line = getSourceLocationByPrecedingPattern(\n [\"at Function.\", \"at null.log (\", \"at log (\"],\n true\n )\n if (!line) {\n line = getSourceLocation(0, true)\n }\n } else {\n const depth = typeof stack === \"number\" ? stack : 3\n line = getSourceLocation(depth, true)\n }\n if (line) {\n args.push(colorString(`(${line})`, COLOR.GRAY))\n }\n }\n switch (msg.level) {\n case LogLevel.info:\n if (levelHelper) args[0] = `I|* ` + args[0]\n log(...args)\n break\n case LogLevel.warn:\n if (levelHelper)\n args[0] =\n (colors && useColors\n ? colorString(`W|** `, COLOR.ORANGE)\n : `W|** `) + args[0]\n log(...args)\n break\n case LogLevel.error:\n if (levelHelper)\n args[0] =\n (colors && useColors\n ? colorString(`E|*** `, COLOR.RED)\n : `E|*** `) + args[0]\n log(...args)\n break\n default:\n if (levelHelper) args[0] = `D| ` + args[0]\n log(...args)\n break\n }\n }\n}\n","// https://nodejs.org/api/webcrypto.html\nimport nodeCrypto from \"crypto\"\n\nexport {}\n\ndeclare module NodeJS {\n interface Global {\n crypto: Crypto\n }\n}\n\ntry {\n if (\n nodeCrypto &&\n nodeCrypto.webcrypto &&\n typeof globalThis !== \"undefined\" &&\n typeof globalThis.crypto === \"undefined\"\n ) {\n // @ts-ignore\n globalThis.crypto = nodeCrypto.webcrypto\n }\n} catch (err) {\n console.warn(\"Failed to polyfill webcrypto\", err)\n}\n","import { Logger } from \"../common/log\"\nimport { toPath } from \"./env\"\nimport { LoggerFileHandler } from \"./log-file\"\nimport { LoggerNodeHandler } from \"./log-node\"\n\nfunction setupLogContextNode() {\n let handlers = [\n LoggerNodeHandler({\n padding: 32,\n nameBrackets: false,\n // levelHelper: false,\n }),\n ]\n\n let logFilePath = process.env.ZEED_LOG ?? process.env.LOG\n if (logFilePath) {\n handlers.unshift(LoggerFileHandler(toPath(logFilePath)))\n }\n\n Logger.setHandlers(handlers)\n}\n\nsetupLogContextNode()\n"],"mappings":"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","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/node/env.ts","../src/node/filestorage.ts","../src/node/log-file.ts","../src/node/log-util.ts","../src/node/log-node.ts","../src/node/crypto.ts","../src/node/log-context-node.ts"],"sourcesContent":["// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\n// Adopted from https://github.com/motdotla/dotenv BSD-2\n\nimport { LogLevel } from \"../common/log-base\"\nimport { Logger } from \"../common/log\"\n\nimport fs from \"fs\"\nimport { resolve } from \"path\"\n\nconst log = Logger(\"zeed:env\")\n\nconst NEWLINE = \"\\n\"\nconst RE_INI_KEY_VAL = /^\\s*([\\w_.-]+)\\s*=\\s*(.*)?\\s*$/\nconst RE_NEWLINES = /\\\\n/g\nconst NEWLINES_MATCH = /\\n|\\r|\\r\\n/\n\ntype csvOptions = {\n /** @deprecated will probably be replaced by logLevel */\n debug?: boolean\n path?: string\n filename?: string\n encoding?: BufferEncoding\n prefix?: string\n env?: Record<string, string>\n}\n\n// Parses src into an Object\nfunction parse(src: string, options: csvOptions = {}) {\n let obj: Record<string, string> = {}\n\n // convert Buffers before splitting into lines and processing\n src\n .toString()\n .split(NEWLINES_MATCH)\n .forEach(function (line, idx) {\n // matching \"KEY' and 'VAL' in 'KEY=VAL'\n const keyValueArr = line.match(RE_INI_KEY_VAL)\n // matched?\n\n // log.debug(\"keyValueArr\", keyValueArr)\n\n if (keyValueArr != null) {\n const key = keyValueArr[1]\n // default undefined or missing values to empty string\n let val = keyValueArr[2] || \"\"\n const end = val.length - 1\n const isDoubleQuoted = val[0] === '\"' && val[end] === '\"'\n const isSingleQuoted = val[0] === \"'\" && val[end] === \"'\"\n\n // if single or double quoted, remove quotes\n if (isSingleQuoted || isDoubleQuoted) {\n val = val.substring(1, end)\n\n // if double quoted, expand newlines\n if (isDoubleQuoted) {\n val = val.replace(RE_NEWLINES, NEWLINE)\n }\n } else {\n // remove surrounding whitespace\n val = val.trim()\n }\n obj[key] = val\n } else {\n log.debug(\n `did not match key and value when parsing line ${idx + 1}: ${line}`\n )\n }\n })\n\n // log.debug(\"obj\", obj)\n return obj\n}\n\n/**\n * Return a path relative to the current working directory\n */\nexport function stringToPath(\n value?: string,\n defaultValue: string = \".\"\n): string {\n return resolve(process.cwd(), value ?? defaultValue)\n}\n\nexport function valueToPath(value?: any, defaultValue = \"\"): string {\n if (value == null) value = defaultValue\n return stringToPath(String(value).trim(), defaultValue)\n}\n\nexport const toPath = valueToPath\n\n// Populates process.env from .env file\nexport function setupEnv(options: csvOptions = {}) {\n const dotenvPath: string =\n options?.path ?? toPath(options?.filename ?? \".env\")\n const encoding: BufferEncoding = options?.encoding ?? \"utf8\"\n const debug = options?.debug || false\n\n if (debug !== true) log.level = LogLevel.off\n\n try {\n // specifying an encoding returns a string instead of a buffer\n const parsedEnv = fs.existsSync(dotenvPath)\n ? parse(fs.readFileSync(dotenvPath, { encoding }), { debug })\n : {}\n const parsedEnvLocal = fs.existsSync(dotenvPath + \".local\")\n ? parse(fs.readFileSync(dotenvPath + \".local\", { encoding }), { debug })\n : {}\n\n const parsed: Record<string, string> = Object.assign(\n {},\n parsedEnv,\n parsedEnvLocal\n )\n let env = options?.env ?? process.env\n\n Object.entries(parsed).forEach(([key, value]) => {\n if (typeof options?.prefix === \"string\") {\n key = options?.prefix + key\n }\n if (!Object.prototype.hasOwnProperty.call(env, key)) {\n if (value != null) {\n log.info(`set env.${key} = ${value}`)\n env[key] = value\n }\n } else {\n log.debug(`\"${key}\" is already defined and will not be overwritten`)\n }\n })\n return { parsed }\n } catch (e) {\n log.error(e)\n return { error: e }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport {\n mkdirSync,\n readdirSync,\n readFileSync,\n rmSync,\n unlinkSync,\n writeFileSync,\n} from \"fs\"\nimport { dirname, resolve } from \"path\"\nimport { toValidFilename } from \"../common/data/path\"\nimport { cloneObject } from \"../common/data/utils\"\nimport { Logger } from \"../common/log\"\nimport { Json, ObjectStorage } from \"../common/types\"\n\nconst log = Logger(\"zeed:filestorage\")\n\nexport interface FileStorageOptions {\n pretty?: boolean\n path?: string\n extension?: string\n objectFromString?: (data: string) => any\n objectToString?: (data: any) => string\n keyToFilename?: (key: string) => string\n}\n\nexport class FileStorage<T = Json> implements ObjectStorage<T> {\n private store: Record<string, T | null> = {}\n private dirname: string\n private fileKeys?: string[] = undefined\n private pretty: boolean = false\n private extension: string\n private extensionLength: number\n private objectFromString: (data: string) => any\n private objectToString: (data: any) => string\n private keyToFilename: (key: string) => string\n\n constructor(opt: FileStorageOptions = {}) {\n this.dirname = resolve(process.cwd(), opt.path || \".fileStorage\")\n this.pretty = !!opt.pretty\n this.extension = opt.extension ?? \".json\"\n\n if (opt.extension && !this.extension.startsWith(\".\")) {\n this.extension = \".\" + this.extension\n }\n this.extensionLength = this.extension.length\n\n this.objectToString =\n opt.objectToString ??\n ((data: any): string => {\n return this.pretty\n ? JSON.stringify(data, null, 2)\n : JSON.stringify(data)\n })\n\n this.objectFromString =\n opt.objectFromString ??\n ((data: string) => {\n try {\n return JSON.parse(data)\n } catch (err) {\n log.warn(`fileStorage parse error '${err}' in`, data)\n }\n })\n\n this.keyToFilename = opt.keyToFilename ?? toValidFilename\n }\n\n setItem(key: string, value: T): void {\n this.store[key] = cloneObject(value)\n try {\n const data = this.objectToString(value)\n const path = this.getPath(key)\n mkdirSync(dirname(path), { recursive: true })\n writeFileSync(path, data, \"utf8\")\n } catch (err) {\n log.error(\"setItem error\", err)\n }\n }\n\n getPath(key: string): string {\n return resolve(this.dirname, this.keyToFilename(key) + this.extension)\n }\n\n getBuffer(key: string): Buffer {\n const path = this.getPath(key)\n return Buffer.from(readFileSync(path))\n }\n\n getItem(key: string): T | undefined {\n let value = this.store[key]\n\n // null is an indicator for not existing!\n if (value === null) return\n\n if (value != null) {\n return cloneObject(value) // this.objectFromString(value)\n }\n\n try {\n const path = this.getPath(key)\n const data = readFileSync(path, \"utf8\")\n if (data != null) {\n const value = this.objectFromString(data)\n this.store[key] = value\n return value\n }\n } catch (err) {\n log.warn(\"getItem error\", err)\n this.store[key] = null // do not retry next time\n }\n }\n\n removeItem(key: string): void {\n delete this.store[key]\n if (this.fileKeys != null) {\n const index: number = this.fileKeys.indexOf(key)\n if (index !== -1) {\n this.fileKeys.splice(index, 1)\n }\n }\n try {\n const path = this.getPath(key)\n unlinkSync(path)\n } catch (err) {}\n }\n\n clear(): void {\n this.fileKeys = []\n this.store = {}\n rmSync(this.dirname, { recursive: true, force: true })\n }\n\n allKeys(): string[] {\n if (this.fileKeys == null) {\n try {\n this.fileKeys =\n readdirSync(this.dirname, { withFileTypes: true })\n .filter(\n (item) =>\n !item.isDirectory() && item.name.endsWith(this.extension)\n )\n .map((item) => item.name.slice(0, -this.extensionLength)) || []\n } catch (err) {}\n }\n let keys = [...(this.fileKeys || [])]\n for (let key of Object.keys(this.store)) {\n if (!keys.includes(key)) {\n keys.push(key)\n }\n }\n keys.sort()\n return keys\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { createWriteStream, mkdirSync } from \"fs\"\nimport { dirname, resolve } from \"path\"\nimport { renderMessages } from \"../common/data/convert\"\nimport { LogHandlerOptions, LogLevel, LogMessage } from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\n\nlet namespaces: Record<string, any> = {}\n\nexport function LoggerFileHandler(path: string, opt: LogHandlerOptions = {}) {\n const { level = LogLevel.all, filter = \"*\" } = opt\n path = resolve(process.cwd(), path)\n mkdirSync(dirname(path), { recursive: true })\n var stream = createWriteStream(path, { flags: \"a\" })\n // stream.end()\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n\n const time = new Date().toISOString()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n namespaces[name] = ninfo\n }\n\n let args: string[] = [\n `[${name || \"*\"}]`,\n renderMessages(msg.messages, { pretty: false }),\n ]\n\n function write(...args: string[]): void {\n stream.write(args.join(\"\\t\") + \"\\n\")\n }\n\n switch (msg.level) {\n case LogLevel.info:\n write(time, `I|* `, ...args)\n break\n case LogLevel.warn:\n write(time, `W|** `, ...args)\n break\n case LogLevel.error:\n write(time, `E|***`, ...args)\n break\n default:\n write(time, `D| `, ...args)\n break\n }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { resolve } from \"path\"\n\nexport function getStackLlocationList(stack: string): any[] {\n if (typeof stack !== \"string\") return []\n // console.log(\"stack\", stack)\n return (\n stack\n ?.split(\"\\n\")\n ?.map((rawLine) => {\n let m = rawLine.match(/^\\s+at.*(\\((.*)\\)|file:\\/\\/(.*)$)/)\n if (m) {\n let line = m[3] || m[2]\n if (line.endsWith(\")\")) line = line.slice(0, -1)\n return line\n }\n })\n ?.filter((v) => v != null) || []\n )\n}\n\nconst cwd = resolve(process.cwd())\nconst home = process.env?.HOME ? resolve(process.env?.HOME) : \"\"\n// console.log(`cwd = ${cwd}, home = ${home}}`)\n\nfunction pathStripCwd(path: string) {\n // console.log(\">\", path)\n\n if (path.includes(\"/node_modules/\")) {\n return \"\"\n }\n\n const fileURL = \"file://\"\n if (path.startsWith(fileURL)) {\n return path.substr(fileURL.length)\n }\n\n if (cwd && path.startsWith(cwd)) {\n return path.substr(cwd.length + 1)\n }\n\n if (home && path.startsWith(home)) {\n path = \"~/\" + path.substr(home.length + 1)\n }\n\n return path\n}\n\nfunction extractFileInfo(stackLine: string): string {\n let m = stackLine.match(/^\\s*at.*(\\((.*)\\)|file:\\/\\/(.*)$)/)\n if (m) {\n let line = m[3] || m[2]\n if (line.endsWith(\")\")) line = line.slice(0, -1)\n return line\n }\n return \"\"\n}\n\n/**\n * Get the source code location of the caller\n * https://stackoverflow.com/a/47296370/140927\n *\n * @param level Number of levels to go down the stack trace\n * @param stripCwd Strip the current working directory, only reasonable for Node.js environment\n * @returns\n */\nexport function getSourceLocation(level = 2, stripCwd = true): string {\n let stack = new Error().stack || \"\"\n let line: string | undefined = getStackLlocationList(stack)?.[level]\n if (line && stripCwd) {\n line = pathStripCwd(line)\n }\n return line || \"\"\n}\n\nexport function getStack(): string {\n return new Error().stack || \"\"\n}\n\nexport function getSourceLocationByPrecedingPattern(\n patterns: string[],\n stripCwd = true\n) {\n let line = \"\"\n let stack = new Error().stack || \"\"\n if (typeof stack === \"string\") {\n const lines = stack.split(\"\\n\").map((l) => l.trim())\n // console.log(lines)\n const index = lines.findIndex((l) => patterns.some((p) => l.startsWith(p)))\n line = lines[index + 1]\n if (line) {\n line = extractFileInfo(line)\n }\n if (line && stripCwd) {\n line = pathStripCwd(line)\n }\n }\n return line\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport tty from \"tty\"\nimport { renderMessages } from \"../common/data/convert\"\nimport {\n LogHandler,\n LogHandlerOptions,\n LogLevel,\n LogMessage,\n} from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\nimport {\n getSourceLocation,\n getSourceLocationByPrecedingPattern,\n getStack,\n} from \"./log-util\"\nimport { formatMilliseconds, getTimestamp } from \"../common/time\"\n\nexport function isTTY(): boolean {\n try {\n return tty.isatty(process.stdout.fd)\n } catch (err) {}\n return false\n}\n\nconst colors = [6, 2, 3, 4, 5, 1]\n\nfunction selectColor(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n\nlet namespaces: Record<string, any> = {}\n\nlet time = getTimestamp()\n\nconst useColors = tty.isatty(process.stderr.fd)\n\nfunction log(...args: any[]) {\n return process.stderr.write(renderMessages(args) + \"\\n\")\n}\n\n// export const BOLD = Symbol()\n// export const UNBOLD = Symbol()\n// export const BLUE = Symbol()\n// export const GREY = Symbol()\n// export const GREEN = Symbol()\n// export const RED = Symbol()\n// export const PURPLE = Symbol()\n// export const ORANGE = Symbol()\n// export const UNCOLOR = Symbol()\n\n// const _browserStyleMap = {\n// [BOLD]: pair.create(\"font-weight\", \"bold\"),\n// [UNBOLD]: pair.create(\"font-weight\", \"normal\"),\n// [BLUE]: pair.create(\"color\", \"blue\"),\n// [GREEN]: pair.create(\"color\", \"green\"),\n// [GREY]: pair.create(\"color\", \"grey\"),\n// [RED]: pair.create(\"color\", \"red\"),\n// [PURPLE]: pair.create(\"color\", \"purple\"),\n// [ORANGE]: pair.create(\"color\", \"orange\"), // not well supported in chrome when debugging node with inspector - TODO: deprecate\n// [UNCOLOR]: pair.create(\"color\", \"black\"),\n// }\n\nconst TTY_STYLE = {\n BOLD: \"\\u001b[1m\",\n UNBOLD: \"\\u001b[2m\",\n RED: \"\\u001b[31m\",\n GREEN: \"\\u001b[32m\",\n BLUE: \"\\u001b[34m\",\n PURPLE: \"\\u001b[35m\",\n GRAY: \"\\u001b[37m\",\n ORANGE: \"\\u001b[38;5;208m\",\n UNCOLOR: \"\\u001b[0m\",\n}\n\nenum COLOR {\n RED = 1,\n GREEN = 2,\n BLUE = 4,\n PURPLE = 5,\n GRAY = 7,\n ORANGE = 8,\n}\n\nconst colorEnd = \"\\u001B[0m\"\n\nexport function colorString(value: string, colorCode: number) {\n const colorStart =\n colorCode === COLOR.ORANGE\n ? TTY_STYLE.ORANGE\n : \"\\u001B[3\" + (colorCode < 8 ? colorCode : \"8;5;\" + colorCode) + \"m\"\n return `${colorStart}${value}${colorEnd}`\n}\n\nexport function colorStringList(\n list: Array<any>,\n style: string,\n bold: boolean = true\n) {\n return list.map((value) => {\n if (typeof value !== \"string\") return value\n let start = style\n let end = colorEnd\n if (bold) {\n start = `${TTY_STYLE.BOLD}${start}`\n end = `${end}${TTY_STYLE.BOLD}`\n }\n return `${start}${value}${end}`\n })\n}\n\nexport const loggerStackTraceDebug =\n \"loggerStackTraceDebug-7d38e5a9214b58d29734374cdb9521fd964d7485\"\n\nexport function LoggerNodeHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n level = undefined,\n filter = undefined,\n colors = isTTY(),\n levelHelper = true,\n nameBrackets = true,\n padding = 0,\n fill = 0,\n stack = true,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n const timeNow = getTimestamp()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n ninfo = {\n color: selectColor(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const diff = formatMilliseconds(timeNow - time)\n\n let args: string[]\n\n let displayName = nameBrackets ? `[${name}]` : name\n\n if (padding > 0) {\n displayName = displayName.padStart(padding, \" \")\n }\n\n if (fill > 0) {\n displayName = displayName.padEnd(fill, \" \")\n }\n\n if (colors && useColors) {\n const c = ninfo.color\n args = [colorString(displayName, c) + ` | `] // nameBrackets ? [`%c[${name}]`] : [`%c${name}`]\n if (msg.level === LogLevel.warn) {\n args.push(...colorStringList(msg.messages, TTY_STYLE.ORANGE))\n } else if (msg.level === LogLevel.error) {\n args.push(...colorStringList(msg.messages, TTY_STYLE.RED))\n } else {\n args.push(...msg.messages)\n }\n args.push(colorString(`+${diff}`, c))\n } else {\n args = [displayName, ...msg.messages]\n args.push(`+${diff}`)\n }\n\n if (msg.messages?.[0] === loggerStackTraceDebug) {\n console.log(getStack())\n }\n\n if (stack) {\n let line: string = \"\"\n if (typeof stack === \"boolean\") {\n line = getSourceLocationByPrecedingPattern(\n [\"at Function.\", \"at null.log (\", \"at log (\"],\n true\n )\n if (!line) {\n line = getSourceLocation(0, true)\n }\n } else {\n const depth = typeof stack === \"number\" ? stack : 3\n line = getSourceLocation(depth, true)\n }\n if (line) {\n args.push(colorString(`(${line})`, COLOR.GRAY))\n }\n }\n switch (msg.level) {\n case LogLevel.info:\n if (levelHelper) args[0] = `I|* ` + args[0]\n log(...args)\n break\n case LogLevel.warn:\n if (levelHelper)\n args[0] =\n (colors && useColors\n ? colorString(`W|** `, COLOR.ORANGE)\n : `W|** `) + args[0]\n log(...args)\n break\n case LogLevel.error:\n if (levelHelper)\n args[0] =\n (colors && useColors\n ? colorString(`E|*** `, COLOR.RED)\n : `E|*** `) + args[0]\n log(...args)\n break\n default:\n if (levelHelper) args[0] = `D| ` + args[0]\n log(...args)\n break\n }\n }\n}\n","// https://nodejs.org/api/webcrypto.html\nimport nodeCrypto from \"crypto\"\n\nexport {}\n\ndeclare module NodeJS {\n interface Global {\n crypto: Crypto\n }\n}\n\ntry {\n if (\n nodeCrypto &&\n nodeCrypto.webcrypto &&\n typeof globalThis !== \"undefined\" &&\n typeof globalThis.crypto === \"undefined\"\n ) {\n // @ts-ignore\n globalThis.crypto = nodeCrypto.webcrypto\n }\n} catch (err) {\n console.warn(\"Failed to polyfill webcrypto\", err)\n}\n","import { Logger } from \"../common/log\"\nimport { toPath } from \"./env\"\nimport { LoggerFileHandler } from \"./log-file\"\nimport { LoggerNodeHandler } from \"./log-node\"\n\nfunction setupLogContextNode() {\n let handlers = [\n LoggerNodeHandler({\n padding: 32,\n nameBrackets: false,\n // levelHelper: false,\n }),\n ]\n\n let logFilePath = process.env.ZEED_LOG ?? process.env.LOG\n if (logFilePath) {\n handlers.unshift(LoggerFileHandler(toPath(logFilePath)))\n }\n\n Logger.setHandlers(handlers)\n}\n\nsetupLogContextNode()\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{a as z,b as F,c as I,d as B}from"./chunk-JL5GA55T.js";import{Xb as A}from"./chunk-QHJAXTKB.js";import{c as l,q as H,r as O,s as w,x as h,y as k,z as T}from"./chunk-LNZLD7Y3.js";var{error:M}=h("zeed:base64");function K(p){try{let i="=".repeat((4-p.length%4)%4),m=(p+i).replace(/-/g,"+").replace(/_/g,"/"),b=window.atob(m),c=new Uint8Array(b.length);for(let s=0;s<b.length;++s)c[s]=b.charCodeAt(s);return c}catch(i){M(i,p)}}l(K,"urlBase64ToUint8Array");var R=h("zeed:gravatar");function W(p,i){function m(t,a){var e=t[0],r=t[1],n=t[2],o=t[3];e=c(e,r,n,o,a[0],7,-680876936),o=c(o,e,r,n,a[1],12,-389564586),n=c(n,o,e,r,a[2],17,606105819),r=c(r,n,o,e,a[3],22,-1044525330),e=c(e,r,n,o,a[4],7,-176418897),o=c(o,e,r,n,a[5],12,1200080426),n=c(n,o,e,r,a[6],17,-1473231341),r=c(r,n,o,e,a[7],22,-45705983),e=c(e,r,n,o,a[8],7,1770035416),o=c(o,e,r,n,a[9],12,-1958414417),n=c(n,o,e,r,a[10],17,-42063),r=c(r,n,o,e,a[11],22,-1990404162),e=c(e,r,n,o,a[12],7,1804603682),o=c(o,e,r,n,a[13],12,-40341101),n=c(n,o,e,r,a[14],17,-1502002290),r=c(r,n,o,e,a[15],22,1236535329),e=s(e,r,n,o,a[1],5,-165796510),o=s(o,e,r,n,a[6],9,-1069501632),n=s(n,o,e,r,a[11],14,643717713),r=s(r,n,o,e,a[0],20,-373897302),e=s(e,r,n,o,a[5],5,-701558691),o=s(o,e,r,n,a[10],9,38016083),n=s(n,o,e,r,a[15],14,-660478335),r=s(r,n,o,e,a[4],20,-405537848),e=s(e,r,n,o,a[9],5,568446438),o=s(o,e,r,n,a[14],9,-1019803690),n=s(n,o,e,r,a[3],14,-187363961),r=s(r,n,o,e,a[8],20,1163531501),e=s(e,r,n,o,a[13],5,-1444681467),o=s(o,e,r,n,a[2],9,-51403784),n=s(n,o,e,r,a[7],14,1735328473),r=s(r,n,o,e,a[12],20,-1926607734),e=f(e,r,n,o,a[5],4,-378558),o=f(o,e,r,n,a[8],11,-2022574463),n=f(n,o,e,r,a[11],16,1839030562),r=f(r,n,o,e,a[14],23,-35309556),e=f(e,r,n,o,a[1],4,-1530992060),o=f(o,e,r,n,a[4],11,1272893353),n=f(n,o,e,r,a[7],16,-155497632),r=f(r,n,o,e,a[10],23,-1094730640),e=f(e,r,n,o,a[13],4,681279174),o=f(o,e,r,n,a[0],11,-358537222),n=f(n,o,e,r,a[3],16,-722521979),r=f(r,n,o,e,a[6],23,76029189),e=f(e,r,n,o,a[9],4,-640364487),o=f(o,e,r,n,a[12],11,-421815835),n=f(n,o,e,r,a[15],16,530742520),r=f(r,n,o,e,a[2],23,-995338651),e=u(e,r,n,o,a[0],6,-198630844),o=u(o,e,r,n,a[7],10,1126891415),n=u(n,o,e,r,a[14],15,-1416354905),r=u(r,n,o,e,a[5],21,-57434055),e=u(e,r,n,o,a[12],6,1700485571),o=u(o,e,r,n,a[3],10,-1894986606),n=u(n,o,e,r,a[10],15,-1051523),r=u(r,n,o,e,a[1],21,-2054922799),e=u(e,r,n,o,a[8],6,1873313359),o=u(o,e,r,n,a[15],10,-30611744),n=u(n,o,e,r,a[6],15,-1560198380),r=u(r,n,o,e,a[13],21,1309151649),e=u(e,r,n,o,a[4],6,-145523070),o=u(o,e,r,n,a[11],10,-1120210379),n=u(n,o,e,r,a[2],15,718787259),r=u(r,n,o,e,a[9],21,-343485551),t[0]=d(e,t[0]),t[1]=d(r,t[1]),t[2]=d(n,t[2]),t[3]=d(o,t[3])}l(m,"md5cycle");function b(t,a,e,r,n,o){return a=d(d(a,t),d(r,o)),d(a<<n|a>>>32-n,e)}l(b,"cmn");function c(t,a,e,r,n,o,y){return b(a&e|~a&r,t,a,n,o,y)}l(c,"ff");function s(t,a,e,r,n,o,y){return b(a&r|e&~r,t,a,n,o,y)}l(s,"gg");function f(t,a,e,r,n,o,y){return b(a^e^r,t,a,n,o,y)}l(f,"hh");function u(t,a,e,r,n,o,y){return b(e^(a|~r),t,a,n,o,y)}l(u,"ii");function v(t){var a=t.length,e=[1732584193,-271733879,-1732584194,271733878],r;for(r=64;r<=t.length;r+=64)m(e,j(t.substring(r-64,r)));t=t.substring(r-64);var n=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];for(r=0;r<t.length;r++)n[r>>2]|=t.charCodeAt(r)<<(r%4<<3);if(n[r>>2]|=128<<(r%4<<3),r>55)for(m(e,n),r=0;r<16;r++)n[r]=0;return n[14]=a*8,m(e,n),e}l(v,"md51");function j(t){var a=[],e;for(e=0;e<64;e+=4)a[e>>2]=t.charCodeAt(e)+(t.charCodeAt(e+1)<<8)+(t.charCodeAt(e+2)<<16)+(t.charCodeAt(e+3)<<24);return a}l(j,"md5blk");function g(t){for(var a="",e=0;e<4;e++)a+=$[t>>e*8+4&15]+$[t>>e*8&15];return a}l(g,"rhex");function D(t){for(var a=0;a<t.length;a++)t[a]=g(t[a]);return t.join("")}l(D,"hex");function E(t){return D(v(t))}l(E,"md5");function d(t,a){return t+a&4294967295}l(d,"add32");var $="0123456789abcdef".split(""),i=i||{},C,S=[];return i={size:i.size||"50",rating:i.rating||"g",secure:i.secure||location.protocol==="https:",backup:i.backup||""},p=p.trim().toLowerCase(),C=i.secure?"https://secure.gravatar.com/avatar/":"http://www.gravatar.com/avatar/",i.rating&&S.push("r="+i.rating),i.backup&&S.push("d="+encodeURIComponent(i.backup)),i.size&&S.push("s="+i.size),C+E(p)+"?"+S.join("&")}l(W,"gravatar");function V(p,i=""){try{return W(p,{size:256,backup:"monsterid",secure:!0})}catch{return R("Gravatar issue: Did not find an image for "+p),i}}l(V,"gravatarURLByEmail");var N=h("zeed:localstorage"),J=class{constructor(i){this.pretty=!1;var m,b;N.assert(i.name,"name required"),this.name=i.name,this.prefix=`${i.name}$`,this.objectToString=(m=i.objectToString)!=null?m:c=>this.pretty?JSON.stringify(c,null,2):JSON.stringify(c),this.objectFromString=(b=i.objectFromString)!=null?b:c=>{try{return JSON.parse(c)}catch(s){N.warn(`LocalStorage parse error '${s}' in`,c)}}}setItem(i,m){let b=this.objectToString(m);localStorage.setItem(`${this.prefix}${i}`,b)}getItem(i){let m=localStorage.getItem(`${this.prefix}${i}`);if(m!=null)return this.objectFromString(m)}removeItem(i){localStorage.removeItem(`${this.prefix}${i}`)}clear(){Object.keys(localStorage).filter(i=>i.startsWith(this.prefix)).forEach(i=>{localStorage.removeItem(i)})}allKeys(){let i=this.prefix.length;return Object.keys(localStorage).filter(m=>m.startsWith(this.prefix)).map(m=>m.substr(i))}};l(J,"LocalStorage");var U={},_=k(),q=z();function sr(p,i={}){let{filter:m=void 0}=i,b=H(m),c=O(p);return s=>{if(!c(s.level)||!b(s.name))return;let f=k(),u=s.name||"",v=U[u||""];v==null&&(v={color:F(u)},U[u]=v);let j=T(f-_),g;switch(i.colors&&q?(g=i.nameBrackets?[`%c[${u}]`]:[`%c${u}`],g.push(`color:${v.color}`),g.push(...s.messages)):g=[u,...s.messages],g.push(`+${j}`),s.level){case w.info:i.levelHelper&&(g[0]="I|* "+g[0]),console.info(...g);break;case w.warn:i.levelHelper&&(g[0]="W|** "+g[0]),console.warn(...g);break;case w.error:i.levelHelper&&(g[0]="E|*** "+g[0]),console.error(...g);break;default:i.levelHelper&&(g[0]="D| "+g[0]),console.debug(...g);break}}}l(sr,"LoggerBrowserClassicHandler");A()&&(h.setHandlers([I()]),h.setFactory(B({})));export{K as a,V as b,J as c,sr as d};
|
|
2
|
+
//# sourceMappingURL=chunk-CX4BRL7A.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/browser/base64.ts","../src/browser/gravatar.ts","../src/browser/localstorage.ts","../src/browser/log-browser-classic.ts","../src/browser/log-context-browser.ts"],"sourcesContent":["// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { Logger } from \"../common/log\"\n\nconst { error } = Logger(\"zeed:base64\")\n\nexport function urlBase64ToUint8Array(\n base64String: string\n): Uint8Array | undefined {\n try {\n let padding = \"=\".repeat((4 - (base64String.length % 4)) % 4)\n let base64 = (base64String + padding).replace(/-/g, \"+\").replace(/_/g, \"/\")\n\n let rawData = window.atob(base64)\n let outputArray = new Uint8Array(rawData.length)\n\n for (let i = 0; i < rawData.length; ++i) {\n outputArray[i] = rawData.charCodeAt(i)\n }\n return outputArray\n } catch (err) {\n error(err, base64String)\n }\n}\n","// MIT licensed\n// https://github.com/mazondo/gravatarjs/blob/master/gravatar.js\n// https://en.gravatar.com/site/implement/images/\n\nimport { Logger } from \"../common/log\"\n\nconst log = Logger(\"zeed:gravatar\")\n\nfunction gravatar(\n email: string,\n options: { size?: any; backup?: any; secure?: any; rating?: any }\n) {\n // using md5() from here: http://www.myersdaily.org/joseph/javascript/md5-text.html\n function md5cycle(e: any[], t: any[]) {\n var n = e[0],\n r = e[1],\n i = e[2],\n s = e[3]\n n = ff(n, r, i, s, t[0], 7, -680876936)\n s = ff(s, n, r, i, t[1], 12, -389564586)\n i = ff(i, s, n, r, t[2], 17, 606105819)\n r = ff(r, i, s, n, t[3], 22, -1044525330)\n n = ff(n, r, i, s, t[4], 7, -176418897)\n s = ff(s, n, r, i, t[5], 12, 1200080426)\n i = ff(i, s, n, r, t[6], 17, -1473231341)\n r = ff(r, i, s, n, t[7], 22, -45705983)\n n = ff(n, r, i, s, t[8], 7, 1770035416)\n s = ff(s, n, r, i, t[9], 12, -1958414417)\n i = ff(i, s, n, r, t[10], 17, -42063)\n r = ff(r, i, s, n, t[11], 22, -1990404162)\n n = ff(n, r, i, s, t[12], 7, 1804603682)\n s = ff(s, n, r, i, t[13], 12, -40341101)\n i = ff(i, s, n, r, t[14], 17, -1502002290)\n r = ff(r, i, s, n, t[15], 22, 1236535329)\n n = gg(n, r, i, s, t[1], 5, -165796510)\n s = gg(s, n, r, i, t[6], 9, -1069501632)\n i = gg(i, s, n, r, t[11], 14, 643717713)\n r = gg(r, i, s, n, t[0], 20, -373897302)\n n = gg(n, r, i, s, t[5], 5, -701558691)\n s = gg(s, n, r, i, t[10], 9, 38016083)\n i = gg(i, s, n, r, t[15], 14, -660478335)\n r = gg(r, i, s, n, t[4], 20, -405537848)\n n = gg(n, r, i, s, t[9], 5, 568446438)\n s = gg(s, n, r, i, t[14], 9, -1019803690)\n i = gg(i, s, n, r, t[3], 14, -187363961)\n r = gg(r, i, s, n, t[8], 20, 1163531501)\n n = gg(n, r, i, s, t[13], 5, -1444681467)\n s = gg(s, n, r, i, t[2], 9, -51403784)\n i = gg(i, s, n, r, t[7], 14, 1735328473)\n r = gg(r, i, s, n, t[12], 20, -1926607734)\n n = hh(n, r, i, s, t[5], 4, -378558)\n s = hh(s, n, r, i, t[8], 11, -2022574463)\n i = hh(i, s, n, r, t[11], 16, 1839030562)\n r = hh(r, i, s, n, t[14], 23, -35309556)\n n = hh(n, r, i, s, t[1], 4, -1530992060)\n s = hh(s, n, r, i, t[4], 11, 1272893353)\n i = hh(i, s, n, r, t[7], 16, -155497632)\n r = hh(r, i, s, n, t[10], 23, -1094730640)\n n = hh(n, r, i, s, t[13], 4, 681279174)\n s = hh(s, n, r, i, t[0], 11, -358537222)\n i = hh(i, s, n, r, t[3], 16, -722521979)\n r = hh(r, i, s, n, t[6], 23, 76029189)\n n = hh(n, r, i, s, t[9], 4, -640364487)\n s = hh(s, n, r, i, t[12], 11, -421815835)\n i = hh(i, s, n, r, t[15], 16, 530742520)\n r = hh(r, i, s, n, t[2], 23, -995338651)\n n = ii(n, r, i, s, t[0], 6, -198630844)\n s = ii(s, n, r, i, t[7], 10, 1126891415)\n i = ii(i, s, n, r, t[14], 15, -1416354905)\n r = ii(r, i, s, n, t[5], 21, -57434055)\n n = ii(n, r, i, s, t[12], 6, 1700485571)\n s = ii(s, n, r, i, t[3], 10, -1894986606)\n i = ii(i, s, n, r, t[10], 15, -1051523)\n r = ii(r, i, s, n, t[1], 21, -2054922799)\n n = ii(n, r, i, s, t[8], 6, 1873313359)\n s = ii(s, n, r, i, t[15], 10, -30611744)\n i = ii(i, s, n, r, t[6], 15, -1560198380)\n r = ii(r, i, s, n, t[13], 21, 1309151649)\n n = ii(n, r, i, s, t[4], 6, -145523070)\n s = ii(s, n, r, i, t[11], 10, -1120210379)\n i = ii(i, s, n, r, t[2], 15, 718787259)\n r = ii(r, i, s, n, t[9], 21, -343485551)\n e[0] = add32(n, e[0])\n e[1] = add32(r, e[1])\n e[2] = add32(i, e[2])\n e[3] = add32(s, e[3])\n }\n function cmn(e: number, t: number, n: any, r: any, i: number, s: any) {\n t = add32(add32(t, e), add32(r, s))\n return add32((t << i) | (t >>> (32 - i)), n)\n }\n function ff(\n e: any,\n t: number,\n n: number,\n r: number,\n i: any,\n s: number,\n o: number\n ) {\n return cmn((t & n) | (~t & r), e, t, i, s, o)\n }\n function gg(\n e: any,\n t: number,\n n: number,\n r: number,\n i: any,\n s: number,\n o: number\n ) {\n return cmn((t & r) | (n & ~r), e, t, i, s, o)\n }\n function hh(\n e: any,\n t: number,\n n: number,\n r: number,\n i: any,\n s: number,\n o: number\n ) {\n return cmn(t ^ n ^ r, e, t, i, s, o)\n }\n function ii(\n e: any,\n t: number,\n n: number,\n r: number,\n i: any,\n s: number,\n o: number\n ) {\n return cmn(n ^ (t | ~r), e, t, i, s, o)\n }\n function md51(e: string) {\n var t = e.length,\n n = [1732584193, -271733879, -1732584194, 271733878],\n r: number\n for (r = 64; r <= e.length; r += 64) {\n md5cycle(n, md5blk(e.substring(r - 64, r)))\n }\n e = e.substring(r - 64)\n var i = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]\n for (r = 0; r < e.length; r++) i[r >> 2] |= e.charCodeAt(r) << (r % 4 << 3)\n i[r >> 2] |= 128 << (r % 4 << 3)\n if (r > 55) {\n md5cycle(n, i)\n for (r = 0; r < 16; r++) i[r] = 0\n }\n i[14] = t * 8\n md5cycle(n, i)\n return n\n }\n function md5blk(e: string) {\n var t = [],\n n: number\n for (n = 0; n < 64; n += 4) {\n t[n >> 2] =\n e.charCodeAt(n) +\n (e.charCodeAt(n + 1) << 8) +\n (e.charCodeAt(n + 2) << 16) +\n (e.charCodeAt(n + 3) << 24)\n }\n return t\n }\n function rhex(e: number) {\n var t = \"\",\n n = 0\n for (; n < 4; n++)\n t += hex_chr[(e >> (n * 8 + 4)) & 15] + hex_chr[(e >> (n * 8)) & 15]\n return t\n }\n function hex(e: any[]) {\n for (var t = 0; t < e.length; t++) e[t] = rhex(e[t])\n return e.join(\"\")\n }\n function md5(e: string) {\n return hex(md51(e))\n }\n function add32(e: number, t: number) {\n return (e + t) & 4294967295\n }\n var hex_chr = \"0123456789abcdef\".split(\"\")\n //check to make sure you gave us something\n var options = options || {},\n base: string,\n params = []\n\n //set some defaults, just in case\n options = {\n size: options.size || \"50\",\n rating: options.rating || \"g\",\n secure: options.secure || location.protocol === \"https:\",\n backup: options.backup || \"\",\n }\n\n //setup the email address\n email = email.trim().toLowerCase()\n\n //determine which base to use\n base = options.secure\n ? \"https://secure.gravatar.com/avatar/\"\n : \"http://www.gravatar.com/avatar/\"\n\n //add the params\n if (options.rating) {\n params.push(\"r=\" + options.rating)\n }\n if (options.backup) {\n params.push(\"d=\" + encodeURIComponent(options.backup))\n }\n if (options.size) {\n params.push(\"s=\" + options.size)\n }\n\n //now throw it all together\n return base + md5(email) + \"?\" + params.join(\"&\")\n}\n\nexport function gravatarURLByEmail(\n email: string,\n defaultURL: string = \"\"\n): string {\n try {\n return gravatar(email, {\n size: 256,\n backup: \"monsterid\",\n // backup: \"https://holtwick.de/download/user.png\", // \"retro\",\n secure: true,\n })\n } catch (error) {\n log(\"Gravatar issue: Did not find an image for \" + email)\n return defaultURL\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { Json, ObjectStorage } from \"../common/types\"\nimport { Logger } from \"../common/log\"\n\nconst log = Logger(\"zeed:localstorage\")\n\nexport interface LocalStorageOptions {\n name: string\n objectFromString?: (data: string) => any\n objectToString?: (data: any) => string\n}\n\nexport class LocalStorage<T = Json> implements ObjectStorage<T> {\n private name: string\n private prefix: string\n private pretty: boolean = false\n private objectFromString: (data: string) => any\n private objectToString: (data: any) => string\n\n constructor(opt: LocalStorageOptions) {\n log.assert(opt.name, \"name required\")\n this.name = opt.name\n this.prefix = `${opt.name}$`\n this.objectToString =\n opt.objectToString ??\n ((data: any): string => {\n return this.pretty\n ? JSON.stringify(data, null, 2)\n : JSON.stringify(data)\n })\n\n this.objectFromString =\n opt.objectFromString ??\n ((data: string) => {\n try {\n return JSON.parse(data)\n } catch (err) {\n log.warn(`LocalStorage parse error '${err}' in`, data)\n }\n })\n }\n\n setItem(key: string, value: T): void {\n const data = this.objectToString(value)\n localStorage.setItem(`${this.prefix}${key}`, data)\n }\n\n getItem(key: string): T | undefined {\n let value = localStorage.getItem(`${this.prefix}${key}`)\n if (value != null) {\n return this.objectFromString(value)\n }\n }\n\n removeItem(key: string): void {\n localStorage.removeItem(`${this.prefix}${key}`)\n }\n\n clear(): void {\n Object.keys(localStorage)\n .filter((key) => key.startsWith(this.prefix))\n .forEach((key) => {\n localStorage.removeItem(key)\n })\n }\n\n allKeys(): string[] {\n const prefixLength = this.prefix.length\n return Object.keys(localStorage)\n .filter((key) => key.startsWith(this.prefix))\n .map((key) => key.substr(prefixLength))\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { getTimestamp, formatMilliseconds } from \"../common/time\"\nimport {\n LogHandler,\n LogHandlerOptions,\n LogLevel,\n LogMessage,\n} from \"../common/log-base\"\nimport { selectColor, supportsColors } from \"./log-colors\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\n\nlet namespaces: Record<string, any> = {}\n\nlet time = getTimestamp()\n\nconst useColors = supportsColors()\n\n/** @deprecated */\nexport function LoggerBrowserClassicHandler(\n level?: LogLevel,\n opt: LogHandlerOptions = {}\n): LogHandler {\n const { filter = undefined } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n\n const timeNow = getTimestamp()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n ninfo = {\n color: selectColor(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n\n const diff = formatMilliseconds(timeNow - time)\n\n let args: string[]\n if (opt.colors && useColors) {\n args = opt.nameBrackets ? [`%c[${name}]`] : [`%c${name}`]\n args.push(`color:${ninfo.color}`)\n args.push(...msg.messages)\n } else {\n args = [name, ...msg.messages]\n }\n args.push(`+${diff}`)\n switch (msg.level) {\n case LogLevel.info:\n if (opt.levelHelper) args[0] = `I|* ` + args[0]\n console.info(...args)\n break\n case LogLevel.warn:\n if (opt.levelHelper) args[0] = `W|** ` + args[0]\n console.warn(...args)\n break\n case LogLevel.error:\n if (opt.levelHelper) args[0] = `E|*** ` + args[0]\n console.error(...args)\n break\n default:\n if (opt.levelHelper) args[0] = `D| ` + args[0]\n console.debug(...args)\n break\n }\n }\n}\n","import { isBrowser } from \"../common/platform\"\nimport { Logger } from \"../common/log\"\nimport {\n LoggerBrowserHandler,\n LoggerBrowserSetupDebugFactory,\n} from \"./log-browser\"\n\nif (isBrowser()) {\n Logger.setHandlers([LoggerBrowserHandler()]) // Fallback for previously registered Loggers\n Logger.setFactory(LoggerBrowserSetupDebugFactory({}))\n}\n"],"mappings":"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","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/browser/base64.ts","../src/browser/gravatar.ts","../src/browser/localstorage.ts","../src/browser/log-browser-classic.ts","../src/browser/log-context-browser.ts"],"sourcesContent":["// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { Logger } from \"../common/log\"\n\nconst { error } = Logger(\"zeed:base64\")\n\nexport function urlBase64ToUint8Array(\n base64String: string\n): Uint8Array | undefined {\n try {\n let padding = \"=\".repeat((4 - (base64String.length % 4)) % 4)\n let base64 = (base64String + padding).replace(/-/g, \"+\").replace(/_/g, \"/\")\n\n let rawData = window.atob(base64)\n let outputArray = new Uint8Array(rawData.length)\n\n for (let i = 0; i < rawData.length; ++i) {\n outputArray[i] = rawData.charCodeAt(i)\n }\n return outputArray\n } catch (err) {\n error(err, base64String)\n }\n}\n","// MIT licensed\n// https://github.com/mazondo/gravatarjs/blob/master/gravatar.js\n// https://en.gravatar.com/site/implement/images/\n\nimport { Logger } from \"../common/log\"\n\nconst log = Logger(\"zeed:gravatar\")\n\nfunction gravatar(\n email: string,\n options: { size?: any; backup?: any; secure?: any; rating?: any }\n) {\n // using md5() from here: http://www.myersdaily.org/joseph/javascript/md5-text.html\n function md5cycle(e: any[], t: any[]) {\n var n = e[0],\n r = e[1],\n i = e[2],\n s = e[3]\n n = ff(n, r, i, s, t[0], 7, -680876936)\n s = ff(s, n, r, i, t[1], 12, -389564586)\n i = ff(i, s, n, r, t[2], 17, 606105819)\n r = ff(r, i, s, n, t[3], 22, -1044525330)\n n = ff(n, r, i, s, t[4], 7, -176418897)\n s = ff(s, n, r, i, t[5], 12, 1200080426)\n i = ff(i, s, n, r, t[6], 17, -1473231341)\n r = ff(r, i, s, n, t[7], 22, -45705983)\n n = ff(n, r, i, s, t[8], 7, 1770035416)\n s = ff(s, n, r, i, t[9], 12, -1958414417)\n i = ff(i, s, n, r, t[10], 17, -42063)\n r = ff(r, i, s, n, t[11], 22, -1990404162)\n n = ff(n, r, i, s, t[12], 7, 1804603682)\n s = ff(s, n, r, i, t[13], 12, -40341101)\n i = ff(i, s, n, r, t[14], 17, -1502002290)\n r = ff(r, i, s, n, t[15], 22, 1236535329)\n n = gg(n, r, i, s, t[1], 5, -165796510)\n s = gg(s, n, r, i, t[6], 9, -1069501632)\n i = gg(i, s, n, r, t[11], 14, 643717713)\n r = gg(r, i, s, n, t[0], 20, -373897302)\n n = gg(n, r, i, s, t[5], 5, -701558691)\n s = gg(s, n, r, i, t[10], 9, 38016083)\n i = gg(i, s, n, r, t[15], 14, -660478335)\n r = gg(r, i, s, n, t[4], 20, -405537848)\n n = gg(n, r, i, s, t[9], 5, 568446438)\n s = gg(s, n, r, i, t[14], 9, -1019803690)\n i = gg(i, s, n, r, t[3], 14, -187363961)\n r = gg(r, i, s, n, t[8], 20, 1163531501)\n n = gg(n, r, i, s, t[13], 5, -1444681467)\n s = gg(s, n, r, i, t[2], 9, -51403784)\n i = gg(i, s, n, r, t[7], 14, 1735328473)\n r = gg(r, i, s, n, t[12], 20, -1926607734)\n n = hh(n, r, i, s, t[5], 4, -378558)\n s = hh(s, n, r, i, t[8], 11, -2022574463)\n i = hh(i, s, n, r, t[11], 16, 1839030562)\n r = hh(r, i, s, n, t[14], 23, -35309556)\n n = hh(n, r, i, s, t[1], 4, -1530992060)\n s = hh(s, n, r, i, t[4], 11, 1272893353)\n i = hh(i, s, n, r, t[7], 16, -155497632)\n r = hh(r, i, s, n, t[10], 23, -1094730640)\n n = hh(n, r, i, s, t[13], 4, 681279174)\n s = hh(s, n, r, i, t[0], 11, -358537222)\n i = hh(i, s, n, r, t[3], 16, -722521979)\n r = hh(r, i, s, n, t[6], 23, 76029189)\n n = hh(n, r, i, s, t[9], 4, -640364487)\n s = hh(s, n, r, i, t[12], 11, -421815835)\n i = hh(i, s, n, r, t[15], 16, 530742520)\n r = hh(r, i, s, n, t[2], 23, -995338651)\n n = ii(n, r, i, s, t[0], 6, -198630844)\n s = ii(s, n, r, i, t[7], 10, 1126891415)\n i = ii(i, s, n, r, t[14], 15, -1416354905)\n r = ii(r, i, s, n, t[5], 21, -57434055)\n n = ii(n, r, i, s, t[12], 6, 1700485571)\n s = ii(s, n, r, i, t[3], 10, -1894986606)\n i = ii(i, s, n, r, t[10], 15, -1051523)\n r = ii(r, i, s, n, t[1], 21, -2054922799)\n n = ii(n, r, i, s, t[8], 6, 1873313359)\n s = ii(s, n, r, i, t[15], 10, -30611744)\n i = ii(i, s, n, r, t[6], 15, -1560198380)\n r = ii(r, i, s, n, t[13], 21, 1309151649)\n n = ii(n, r, i, s, t[4], 6, -145523070)\n s = ii(s, n, r, i, t[11], 10, -1120210379)\n i = ii(i, s, n, r, t[2], 15, 718787259)\n r = ii(r, i, s, n, t[9], 21, -343485551)\n e[0] = add32(n, e[0])\n e[1] = add32(r, e[1])\n e[2] = add32(i, e[2])\n e[3] = add32(s, e[3])\n }\n function cmn(e: number, t: number, n: any, r: any, i: number, s: any) {\n t = add32(add32(t, e), add32(r, s))\n return add32((t << i) | (t >>> (32 - i)), n)\n }\n function ff(\n e: any,\n t: number,\n n: number,\n r: number,\n i: any,\n s: number,\n o: number\n ) {\n return cmn((t & n) | (~t & r), e, t, i, s, o)\n }\n function gg(\n e: any,\n t: number,\n n: number,\n r: number,\n i: any,\n s: number,\n o: number\n ) {\n return cmn((t & r) | (n & ~r), e, t, i, s, o)\n }\n function hh(\n e: any,\n t: number,\n n: number,\n r: number,\n i: any,\n s: number,\n o: number\n ) {\n return cmn(t ^ n ^ r, e, t, i, s, o)\n }\n function ii(\n e: any,\n t: number,\n n: number,\n r: number,\n i: any,\n s: number,\n o: number\n ) {\n return cmn(n ^ (t | ~r), e, t, i, s, o)\n }\n function md51(e: string) {\n var t = e.length,\n n = [1732584193, -271733879, -1732584194, 271733878],\n r: number\n for (r = 64; r <= e.length; r += 64) {\n md5cycle(n, md5blk(e.substring(r - 64, r)))\n }\n e = e.substring(r - 64)\n var i = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]\n for (r = 0; r < e.length; r++) i[r >> 2] |= e.charCodeAt(r) << (r % 4 << 3)\n i[r >> 2] |= 128 << (r % 4 << 3)\n if (r > 55) {\n md5cycle(n, i)\n for (r = 0; r < 16; r++) i[r] = 0\n }\n i[14] = t * 8\n md5cycle(n, i)\n return n\n }\n function md5blk(e: string) {\n var t = [],\n n: number\n for (n = 0; n < 64; n += 4) {\n t[n >> 2] =\n e.charCodeAt(n) +\n (e.charCodeAt(n + 1) << 8) +\n (e.charCodeAt(n + 2) << 16) +\n (e.charCodeAt(n + 3) << 24)\n }\n return t\n }\n function rhex(e: number) {\n var t = \"\",\n n = 0\n for (; n < 4; n++)\n t += hex_chr[(e >> (n * 8 + 4)) & 15] + hex_chr[(e >> (n * 8)) & 15]\n return t\n }\n function hex(e: any[]) {\n for (var t = 0; t < e.length; t++) e[t] = rhex(e[t])\n return e.join(\"\")\n }\n function md5(e: string) {\n return hex(md51(e))\n }\n function add32(e: number, t: number) {\n return (e + t) & 4294967295\n }\n var hex_chr = \"0123456789abcdef\".split(\"\")\n //check to make sure you gave us something\n var options = options || {},\n base: string,\n params = []\n\n //set some defaults, just in case\n options = {\n size: options.size || \"50\",\n rating: options.rating || \"g\",\n secure: options.secure || location.protocol === \"https:\",\n backup: options.backup || \"\",\n }\n\n //setup the email address\n email = email.trim().toLowerCase()\n\n //determine which base to use\n base = options.secure\n ? \"https://secure.gravatar.com/avatar/\"\n : \"http://www.gravatar.com/avatar/\"\n\n //add the params\n if (options.rating) {\n params.push(\"r=\" + options.rating)\n }\n if (options.backup) {\n params.push(\"d=\" + encodeURIComponent(options.backup))\n }\n if (options.size) {\n params.push(\"s=\" + options.size)\n }\n\n //now throw it all together\n return base + md5(email) + \"?\" + params.join(\"&\")\n}\n\nexport function gravatarURLByEmail(\n email: string,\n defaultURL: string = \"\"\n): string {\n try {\n return gravatar(email, {\n size: 256,\n backup: \"monsterid\",\n // backup: \"https://holtwick.de/download/user.png\", // \"retro\",\n secure: true,\n })\n } catch (error) {\n log(\"Gravatar issue: Did not find an image for \" + email)\n return defaultURL\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { Json, ObjectStorage } from \"../common/types\"\nimport { Logger } from \"../common/log\"\n\nconst log = Logger(\"zeed:localstorage\")\n\nexport interface LocalStorageOptions {\n name: string\n objectFromString?: (data: string) => any\n objectToString?: (data: any) => string\n}\n\nexport class LocalStorage<T = Json> implements ObjectStorage<T> {\n private name: string\n private prefix: string\n private pretty: boolean = false\n private objectFromString: (data: string) => any\n private objectToString: (data: any) => string\n\n constructor(opt: LocalStorageOptions) {\n log.assert(opt.name, \"name required\")\n this.name = opt.name\n this.prefix = `${opt.name}$`\n this.objectToString =\n opt.objectToString ??\n ((data: any): string => {\n return this.pretty\n ? JSON.stringify(data, null, 2)\n : JSON.stringify(data)\n })\n\n this.objectFromString =\n opt.objectFromString ??\n ((data: string) => {\n try {\n return JSON.parse(data)\n } catch (err) {\n log.warn(`LocalStorage parse error '${err}' in`, data)\n }\n })\n }\n\n setItem(key: string, value: T): void {\n const data = this.objectToString(value)\n localStorage.setItem(`${this.prefix}${key}`, data)\n }\n\n getItem(key: string): T | undefined {\n let value = localStorage.getItem(`${this.prefix}${key}`)\n if (value != null) {\n return this.objectFromString(value)\n }\n }\n\n removeItem(key: string): void {\n localStorage.removeItem(`${this.prefix}${key}`)\n }\n\n clear(): void {\n Object.keys(localStorage)\n .filter((key) => key.startsWith(this.prefix))\n .forEach((key) => {\n localStorage.removeItem(key)\n })\n }\n\n allKeys(): string[] {\n const prefixLength = this.prefix.length\n return Object.keys(localStorage)\n .filter((key) => key.startsWith(this.prefix))\n .map((key) => key.substr(prefixLength))\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { getTimestamp, formatMilliseconds } from \"../common/time\"\nimport {\n LogHandler,\n LogHandlerOptions,\n LogLevel,\n LogMessage,\n} from \"../common/log-base\"\nimport { selectColor, supportsColors } from \"./log-colors\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\n\nlet namespaces: Record<string, any> = {}\n\nlet time = getTimestamp()\n\nconst useColors = supportsColors()\n\n/** @deprecated */\nexport function LoggerBrowserClassicHandler(\n level?: LogLevel,\n opt: LogHandlerOptions = {}\n): LogHandler {\n const { filter = undefined } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n\n const timeNow = getTimestamp()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n ninfo = {\n color: selectColor(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n\n const diff = formatMilliseconds(timeNow - time)\n\n let args: string[]\n if (opt.colors && useColors) {\n args = opt.nameBrackets ? [`%c[${name}]`] : [`%c${name}`]\n args.push(`color:${ninfo.color}`)\n args.push(...msg.messages)\n } else {\n args = [name, ...msg.messages]\n }\n args.push(`+${diff}`)\n switch (msg.level) {\n case LogLevel.info:\n if (opt.levelHelper) args[0] = `I|* ` + args[0]\n console.info(...args)\n break\n case LogLevel.warn:\n if (opt.levelHelper) args[0] = `W|** ` + args[0]\n console.warn(...args)\n break\n case LogLevel.error:\n if (opt.levelHelper) args[0] = `E|*** ` + args[0]\n console.error(...args)\n break\n default:\n if (opt.levelHelper) args[0] = `D| ` + args[0]\n console.debug(...args)\n break\n }\n }\n}\n","import { isBrowser } from \"../common/platform\"\nimport { Logger } from \"../common/log\"\nimport {\n LoggerBrowserHandler,\n LoggerBrowserSetupDebugFactory,\n} from \"./log-browser\"\n\nif (isBrowser()) {\n Logger.setHandlers([LoggerBrowserHandler()]) // Fallback for previously registered Loggers\n Logger.setFactory(LoggerBrowserSetupDebugFactory({}))\n}\n"],"mappings":"wLAIA,GAAM,CAAE,SAAU,EAAO,eAElB,WACL,EACwB,CACxB,GAAI,CACF,GAAI,GAAU,IAAI,OAAQ,GAAK,EAAa,OAAS,GAAM,GACvD,EAAU,GAAe,GAAS,QAAQ,KAAM,KAAK,QAAQ,KAAM,KAEnE,EAAU,OAAO,KAAK,GACtB,EAAc,GAAI,YAAW,EAAQ,QAEzC,OAAS,GAAI,EAAG,EAAI,EAAQ,OAAQ,EAAE,EACpC,EAAY,GAAK,EAAQ,WAAW,GAEtC,MAAO,SACA,EAAP,CACA,EAAM,EAAK,IAfC,6BCAhB,GAAM,GAAM,EAAO,iBAEnB,WACE,EACA,EACA,CAEA,WAAkB,EAAU,EAAU,CACpC,GAAI,GAAI,EAAE,GACR,EAAI,EAAE,GACN,EAAI,EAAE,GACN,EAAI,EAAE,GACR,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,YAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,WAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,aAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,YAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,aAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,WAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,YAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,aAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,QAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,aAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,EAAG,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,WAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,aAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,YAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,YAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,aAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,WAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,YAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,EAAG,UAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,YAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,WAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,EAAG,aAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,EAAG,aAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,WAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,aAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,SAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,aAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,YAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,WAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,aAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,aAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,EAAG,WAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,UAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,YAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,YAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,WAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,YAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,aAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,WAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,EAAG,YAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,aAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,UAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,aAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,YAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,WAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,aAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,YAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,EAAG,YAC5B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,IAAK,GAAI,aAC9B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,WAC7B,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAE,GAAI,GAAI,YAC7B,EAAE,GAAK,EAAM,EAAG,EAAE,IAClB,EAAE,GAAK,EAAM,EAAG,EAAE,IAClB,EAAE,GAAK,EAAM,EAAG,EAAE,IAClB,EAAE,GAAK,EAAM,EAAG,EAAE,IAxEX,gBA0ET,WAAa,EAAW,EAAW,EAAQ,EAAQ,EAAW,EAAQ,CACpE,SAAI,EAAM,EAAM,EAAG,GAAI,EAAM,EAAG,IACzB,EAAO,GAAK,EAAM,IAAO,GAAK,EAAK,GAFnC,WAIT,WACE,EACA,EACA,EACA,EACA,EACA,EACA,EACA,CACA,MAAO,GAAK,EAAI,EAAM,CAAC,EAAI,EAAI,EAAG,EAAG,EAAG,EAAG,GATpC,UAWT,WACE,EACA,EACA,EACA,EACA,EACA,EACA,EACA,CACA,MAAO,GAAK,EAAI,EAAM,EAAI,CAAC,EAAI,EAAG,EAAG,EAAG,EAAG,GATpC,UAWT,WACE,EACA,EACA,EACA,EACA,EACA,EACA,EACA,CACA,MAAO,GAAI,EAAI,EAAI,EAAG,EAAG,EAAG,EAAG,EAAG,GAT3B,UAWT,WACE,EACA,EACA,EACA,EACA,EACA,EACA,EACA,CACA,MAAO,GAAI,EAAK,GAAI,CAAC,GAAI,EAAG,EAAG,EAAG,EAAG,GAT9B,UAWT,WAAc,EAAW,CACvB,GAAI,GAAI,EAAE,OACR,EAAI,CAAC,WAAY,WAAY,YAAa,WAC1C,EACF,IAAK,EAAI,GAAI,GAAK,EAAE,OAAQ,GAAK,GAC/B,EAAS,EAAG,EAAO,EAAE,UAAU,EAAI,GAAI,KAEzC,EAAI,EAAE,UAAU,EAAI,IACpB,GAAI,GAAI,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,GACtD,IAAK,EAAI,EAAG,EAAI,EAAE,OAAQ,IAAK,EAAE,GAAK,IAAM,EAAE,WAAW,IAAO,GAAI,GAAK,GAEzE,GADA,EAAE,GAAK,IAAM,KAAQ,GAAI,GAAK,GAC1B,EAAI,GAEN,IADA,EAAS,EAAG,GACP,EAAI,EAAG,EAAI,GAAI,IAAK,EAAE,GAAK,EAElC,SAAE,IAAM,EAAI,EACZ,EAAS,EAAG,GACL,EAjBA,YAmBT,WAAgB,EAAW,CACzB,GAAI,GAAI,GACN,EACF,IAAK,EAAI,EAAG,EAAI,GAAI,GAAK,EACvB,EAAE,GAAK,GACL,EAAE,WAAW,GACZ,GAAE,WAAW,EAAI,IAAM,GACvB,GAAE,WAAW,EAAI,IAAM,IACvB,GAAE,WAAW,EAAI,IAAM,IAE5B,MAAO,GAVA,cAYT,WAAc,EAAW,CAGvB,OAFI,GAAI,GACN,EAAI,EACC,EAAI,EAAG,IACZ,GAAK,EAAS,GAAM,EAAI,EAAI,EAAM,IAAM,EAAS,GAAM,EAAI,EAAM,IACnE,MAAO,GALA,YAOT,WAAa,EAAU,CACrB,OAAS,GAAI,EAAG,EAAI,EAAE,OAAQ,IAAK,EAAE,GAAK,EAAK,EAAE,IACjD,MAAO,GAAE,KAAK,IAFP,WAIT,WAAa,EAAW,CACtB,MAAO,GAAI,EAAK,IADT,WAGT,WAAe,EAAW,EAAW,CACnC,MAAQ,GAAI,EAAK,WADV,aAGT,GAAI,GAAU,mBAAmB,MAAM,IAEnC,EAAU,GAAW,GACvB,EACA,EAAS,GAGX,SAAU,CACR,KAAM,EAAQ,MAAQ,KACtB,OAAQ,EAAQ,QAAU,IAC1B,OAAQ,EAAQ,QAAU,SAAS,WAAa,SAChD,OAAQ,EAAQ,QAAU,IAI5B,EAAQ,EAAM,OAAO,cAGrB,EAAO,EAAQ,OACX,sCACA,kCAGA,EAAQ,QACV,EAAO,KAAK,KAAO,EAAQ,QAEzB,EAAQ,QACV,EAAO,KAAK,KAAO,mBAAmB,EAAQ,SAE5C,EAAQ,MACV,EAAO,KAAK,KAAO,EAAQ,MAItB,EAAO,EAAI,GAAS,IAAM,EAAO,KAAK,KAjNtC,gBAoNF,WACL,EACA,EAAqB,GACb,CACR,GAAI,CACF,MAAO,GAAS,EAAO,CACrB,KAAM,IACN,OAAQ,YAER,OAAQ,UAEV,CACA,SAAI,6CAA+C,GAC5C,GAbK,0BCvNhB,GAAM,GAAM,EAAO,qBAQZ,OAAyD,CAO9D,YAAY,EAA0B,CAJ9B,YAAkB,GAhB5B,QAqBI,EAAI,OAAO,EAAI,KAAM,iBACrB,KAAK,KAAO,EAAI,KAChB,KAAK,OAAS,GAAG,EAAI,QACrB,KAAK,eACH,KAAI,iBAAJ,OACC,AAAC,GACO,KAAK,OACR,KAAK,UAAU,EAAM,KAAM,GAC3B,KAAK,UAAU,GAGvB,KAAK,iBACH,KAAI,mBAAJ,OACC,AAAC,GAAiB,CACjB,GAAI,CACF,MAAO,MAAK,MAAM,SACX,EAAP,CACA,EAAI,KAAK,6BAA6B,QAAW,KAKzD,QAAQ,EAAa,EAAgB,CACnC,GAAM,GAAO,KAAK,eAAe,GACjC,aAAa,QAAQ,GAAG,KAAK,SAAS,IAAO,GAG/C,QAAQ,EAA4B,CAClC,GAAI,GAAQ,aAAa,QAAQ,GAAG,KAAK,SAAS,KAClD,GAAI,GAAS,KACX,MAAO,MAAK,iBAAiB,GAIjC,WAAW,EAAmB,CAC5B,aAAa,WAAW,GAAG,KAAK,SAAS,KAG3C,OAAc,CACZ,OAAO,KAAK,cACT,OAAO,AAAC,GAAQ,EAAI,WAAW,KAAK,SACpC,QAAQ,AAAC,GAAQ,CAChB,aAAa,WAAW,KAI9B,SAAoB,CAClB,GAAM,GAAe,KAAK,OAAO,OACjC,MAAO,QAAO,KAAK,cAChB,OAAO,AAAC,GAAQ,EAAI,WAAW,KAAK,SACpC,IAAI,AAAC,GAAQ,EAAI,OAAO,MA1DxB,oBCDP,GAAI,GAAkC,GAElC,EAAO,IAEL,EAAY,IAGX,YACL,EACA,EAAyB,GACb,CACZ,GAAM,CAAE,SAAS,QAAc,EACzB,EAAmB,EAAmB,GACtC,EAAe,EAAe,GACpC,MAAO,AAAC,IAAoB,CAE1B,GADI,CAAC,EAAa,EAAI,QAClB,CAAC,EAAiB,EAAI,MAAO,OAEjC,GAAM,GAAU,IACZ,EAAO,EAAI,MAAQ,GACnB,EAAQ,EAAW,GAAQ,IAC/B,AAAI,GAAS,MACX,GAAQ,CACN,MAAO,EAAY,IAGrB,EAAW,GAAQ,GAGrB,GAAM,GAAO,EAAmB,EAAU,GAEtC,EASJ,OARA,AAAI,EAAI,QAAU,EAChB,GAAO,EAAI,aAAe,CAAC,MAAM,MAAW,CAAC,KAAK,KAClD,EAAK,KAAK,SAAS,EAAM,SACzB,EAAK,KAAK,GAAG,EAAI,WAEjB,EAAO,CAAC,EAAM,GAAG,EAAI,UAEvB,EAAK,KAAK,IAAI,KACN,EAAI,WACL,GAAS,KACZ,AAAI,EAAI,aAAa,GAAK,GAAK,SAAW,EAAK,IAC/C,QAAQ,KAAK,GAAG,GAChB,UACG,GAAS,KACZ,AAAI,EAAI,aAAa,GAAK,GAAK,SAAW,EAAK,IAC/C,QAAQ,KAAK,GAAG,GAChB,UACG,GAAS,MACZ,AAAI,EAAI,aAAa,GAAK,GAAK,SAAW,EAAK,IAC/C,QAAQ,MAAM,GAAG,GACjB,cAEA,AAAI,EAAI,aAAa,GAAK,GAAK,SAAW,EAAK,IAC/C,QAAQ,MAAM,GAAG,GACjB,QAjDQ,oCCZhB,AAAI,KACF,GAAO,YAAY,CAAC,MACpB,EAAO,WAAW,EAA+B","names":[]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{c as i,n as u,q as g,r as v,s as f,y as p,z as $}from"./chunk-LNZLD7Y3.js";var E=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function H(){return typeof window!="undefined"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator!="undefined"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)?!1:typeof document!="undefined"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window!="undefined"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator!="undefined"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||typeof navigator!="undefined"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}i(H,"supportsColors");function w(r){let C=0;for(let c=0;c<r.length;c++)C=(C<<5)-C+r.charCodeAt(c),C|=0;return E[Math.abs(C)%E.length]}i(w,"selectColor");var A='font-family: "JetBrains Mono", Menlo; font-size: 11px;',x=`${A}`,q=`font-weight: 600; ${A}`,k=H(),I={},M=p();function G(r={}){let{filter:C=void 0,level:c=void 0,colors:F=!0,levelHelper:m=!1,nameBrackets:d=!0,padding:o=16}=r,b=g(C),e=v(c);return t=>{var y,L;if(!e(t.level)||!b(t.name))return;let a=p(),s=t.name||"",l=I[s||""];l==null&&(l={color:w(s)},I[s]=l);let h=$(a-M),n;switch(o>0&&(s=s.padEnd(16," ")),F&&k?(n=[`%c${s}%c %s %c+${h}`],n.push(`color:${l.color}; ${q}`),n.push(x),n.push((L=(y=t.messages)==null?void 0:y[0])!=null?L:""),n.push(`color:${l.color};`),n.push(...t.messages.slice(1))):n=[s,...t.messages,`+${h}`],t.level){case f.info:r.levelHelper&&(n[0]="I|* "+n[0]),console.info(...n);break;case f.warn:r.levelHelper&&(n[0]="W|** "+n[0]),console.warn(...n);break;case f.error:r.levelHelper&&(n[0]="E|*** "+n[0]),console.error(...n);break;default:r.levelHelper&&(n[0]="D| "+n[0]),console.debug(...n);break}}}i(G,"LoggerBrowserHandler");function K(r={}){var c,F;let C=(F=(c=r.filter)!=null?c:localStorage.zeed)!=null?F:localStorage.debug;return i(function m(d=""){let o;if(g(C)(d)){let e=[];if(k){let t=w(d);e.push(`%c${d.padEnd(16," ")}%c %s`),e.push(`color:${t}; ${q}`),e.push(x)}else e.push(`[${d}] %s`);o=console.debug.bind(console,...e),o.debug=console.debug.bind(console,...e),o.info=console.info.bind(console,...e),o.warn=console.warn.bind(console,...e),o.error=console.error.bind(console,...e),o.assert=console.assert.bind(console),o.assertEqual=function(t,a,...s){let l=u(t,a);l||o.assert(l,`Assert did fail. Expected ${a} got ${t}`,a,t,...s)},o.assertNotEqual=function(t,a,...s){let l=u(t,a);l&&o.assert(l,`Assert did fail. Expected ${a} not to be equal with ${t}`,a,t,...s)}}else{let e=i(()=>{},"noop");o=e,o.debug=e,o.info=e,o.warn=e,o.error=e,o.assert=e,o.assertEqual=e,o.assertNotEqual=e}return o.extend=e=>m(d?`${d}:${e}`:e),o},"LoggerBrowserDebugFactory")}i(K,"LoggerBrowserSetupDebugFactory");function P(r={}){console.info("activateConsoleDebug is activated by default in browsers")}i(P,"activateConsoleDebug");export{H as a,w as b,G as c,K as d,P as e};
|
|
2
|
+
//# sourceMappingURL=chunk-JL5GA55T.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/browser/log-colors.ts","../src/browser/log-browser.ts"],"sourcesContent":["// Taken from https://github.com/visionmedia/debug/blob/master/src/browser.js#L27\n\nconst colors = [\n \"#0000CC\",\n \"#0000FF\",\n \"#0033CC\",\n \"#0033FF\",\n \"#0066CC\",\n \"#0066FF\",\n \"#0099CC\",\n \"#0099FF\",\n \"#00CC00\",\n \"#00CC33\",\n \"#00CC66\",\n \"#00CC99\",\n \"#00CCCC\",\n \"#00CCFF\",\n \"#3300CC\",\n \"#3300FF\",\n \"#3333CC\",\n \"#3333FF\",\n \"#3366CC\",\n \"#3366FF\",\n \"#3399CC\",\n \"#3399FF\",\n \"#33CC00\",\n \"#33CC33\",\n \"#33CC66\",\n \"#33CC99\",\n \"#33CCCC\",\n \"#33CCFF\",\n \"#6600CC\",\n \"#6600FF\",\n \"#6633CC\",\n \"#6633FF\",\n \"#66CC00\",\n \"#66CC33\",\n \"#9900CC\",\n \"#9900FF\",\n \"#9933CC\",\n \"#9933FF\",\n \"#99CC00\",\n \"#99CC33\",\n \"#CC0000\",\n \"#CC0033\",\n \"#CC0066\",\n \"#CC0099\",\n \"#CC00CC\",\n \"#CC00FF\",\n \"#CC3300\",\n \"#CC3333\",\n \"#CC3366\",\n \"#CC3399\",\n \"#CC33CC\",\n \"#CC33FF\",\n \"#CC6600\",\n \"#CC6633\",\n \"#CC9900\",\n \"#CC9933\",\n \"#CCCC00\",\n \"#CCCC33\",\n \"#FF0000\",\n \"#FF0033\",\n \"#FF0066\",\n \"#FF0099\",\n \"#FF00CC\",\n \"#FF00FF\",\n \"#FF3300\",\n \"#FF3333\",\n \"#FF3366\",\n \"#FF3399\",\n \"#FF33CC\",\n \"#FF33FF\",\n \"#FF6600\",\n \"#FF6633\",\n \"#FF9900\",\n \"#FF9933\",\n \"#FFCC00\",\n \"#FFCC33\",\n]\n\nexport function supportsColors(): boolean {\n // NB: In an Electron preload script, document will be defined but not fully\n // initialized. Since we know we're in Chrome, we'll just detect this case\n // explicitly\n if (\n typeof window !== \"undefined\" &&\n window.process &&\n // @ts-ignore\n (window.process.type === \"renderer\" || window.process.__nwjs)\n ) {\n return true\n }\n\n // Internet Explorer and Edge do not support colors.\n if (\n typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)\n ) {\n return false\n }\n\n // Is webkit? http://stackoverflow.com/a/16459606/376773\n // document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n return (\n (typeof document !== \"undefined\" &&\n document.documentElement &&\n document.documentElement.style &&\n // @ts-ignore\n document.documentElement.style.WebkitAppearance) ||\n // Is firebug? http://stackoverflow.com/a/398120/376773\n (typeof window !== \"undefined\" &&\n window.console &&\n // @ts-ignore\n (window.console.firebug ||\n // @ts-ignore\n (window.console.exception && window.console.table))) ||\n // Is firefox >= v31?\n // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n (typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) &&\n parseInt(RegExp.$1, 10) >= 31) ||\n // Double check webkit in userAgent just in case we are in a worker\n (typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/))\n )\n}\n\nexport function selectColor(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { deepEqual } from \"../common/data/deep\"\nimport {\n LoggerInterface,\n LogHandler,\n LogHandlerOptions,\n LogLevel,\n LogMessage,\n} from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\nimport { formatMilliseconds, getTimestamp } from \"../common/time\"\nimport { selectColor, supportsColors } from \"./log-colors\"\n\nconst styleFont = `font-family: \"JetBrains Mono\", Menlo; font-size: 11px;`\nconst styleDefault = `${styleFont}`\nconst styleBold = `font-weight: 600; ${styleFont}`\nconst useColors = supportsColors()\n\nlet namespaces: Record<string, any> = {}\n\nlet time = getTimestamp()\n\nexport function LoggerBrowserHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n filter = undefined,\n level = undefined,\n colors = true,\n levelHelper = false,\n nameBrackets = true,\n padding = 16,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n\n const timeNow = getTimestamp()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n ninfo = {\n color: selectColor(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const diff = formatMilliseconds(timeNow - time)\n let args: string[]\n\n if (padding > 0) {\n name = name.padEnd(16, \" \")\n }\n\n if (colors && useColors) {\n args = [`%c${name}%c \\t%s %c+${diff}`]\n args.push(`color:${ninfo.color}; ${styleBold}`)\n args.push(styleDefault)\n args.push(msg.messages?.[0] ?? \"\")\n args.push(`color:${ninfo.color};`)\n args.push(...msg.messages.slice(1))\n } else {\n args = [name, ...msg.messages, `+${diff}`]\n }\n\n // function consoleArgs(args: any[] = []): any[] {\n // return [\n // args\n // .filter((a) => typeof a === \"string\")\n // .map((a) => String(a))\n // .join(\" \"),\n // ...styles,\n // ...args.filter((a) => typeof a !== \"string\"),\n // ]\n // }\n\n switch (msg.level) {\n case LogLevel.info:\n if (opt.levelHelper) args[0] = `I|* ` + args[0]\n console.info(...args)\n break\n case LogLevel.warn:\n if (opt.levelHelper) args[0] = `W|** ` + args[0]\n console.warn(...args)\n break\n case LogLevel.error:\n if (opt.levelHelper) args[0] = `E|*** ` + args[0]\n console.error(...args)\n break\n default:\n if (opt.levelHelper) args[0] = `D| ` + args[0]\n console.debug(...args)\n break\n }\n }\n}\n\nexport function LoggerBrowserSetupDebugFactory(opt: LogHandlerOptions = {}) {\n const filter = opt.filter ?? localStorage.zeed ?? localStorage.debug\n\n /// The trick is, that console called directly provides a reference to the source code.\n /// For the regular implementation this information is lost. But this approach has other\n /// drawbacks, therefore only use it in the Browser when actively debugging.\n return function LoggerBrowserDebugFactory(\n name: string = \"\"\n ): LoggerInterface {\n let log: LoggerInterface\n\n const matches = useNamespaceFilter(filter)\n\n if (matches(name)) {\n let fixedArgs = []\n if (useColors) {\n const color = selectColor(name)\n fixedArgs.push(`%c${name.padEnd(16, \" \")}%c \\t%s`)\n fixedArgs.push(`color:${color}; ${styleBold}`)\n fixedArgs.push(styleDefault)\n } else {\n fixedArgs.push(`[${name}] \\t%s`)\n }\n\n // @ts-ignore\n // console.previous = {\n // debug: console.debug,\n // info: console.info,\n // warn: console.warn,\n // error: console.error,\n // assert: console.assert,\n // }\n\n log = console.debug.bind(console, ...fixedArgs) as LoggerInterface\n log.debug = console.debug.bind(console, ...fixedArgs)\n log.info = console.info.bind(console, ...fixedArgs)\n log.warn = console.warn.bind(console, ...fixedArgs)\n log.error = console.error.bind(console, ...fixedArgs)\n\n log.assert = console.assert.bind(console)\n\n log.assertEqual = function (value: any, expected: any, ...args: any[]) {\n let equal = deepEqual(value, expected)\n if (!equal) {\n log.assert(\n equal,\n `Assert did fail. Expected ${expected} got ${value}`,\n expected,\n value,\n ...args\n )\n }\n }\n\n log.assertNotEqual = function (\n value: any,\n expected: any,\n ...args: any[]\n ) {\n let equal = deepEqual(value, expected)\n if (equal) {\n log.assert(\n equal,\n `Assert did fail. Expected ${expected} not to be equal with ${value}`,\n expected,\n value,\n ...args\n )\n }\n }\n } else {\n const noop = () => {}\n log = noop as LoggerInterface\n log.debug = noop\n log.info = noop\n log.warn = noop\n log.error = noop\n\n log.assert = noop\n log.assertEqual = noop\n log.assertNotEqual = noop\n }\n\n log.extend = (subName: string) => {\n return LoggerBrowserDebugFactory(name ? `${name}:${subName}` : subName)\n }\n\n return log\n }\n}\n\n/** @deprecated This output is default for initial use of Logger in browser environments. */\nexport function activateConsoleDebug(opt: LogHandlerOptions = {}) {\n console.info(\"activateConsoleDebug is activated by default in browsers\")\n // Logger.setHandlers([LoggerBrowserHandler(opt)]) // Fallback for previously registered Loggers\n // Logger.setFactory(LoggerBrowserSetupDebugFactory(opt))\n}\n\n// let klass = console\n// let debug = console.debug.bind(window.console, klass.toString() + \": \")\n\n// debug(\"test\")\n// console.debug(\"test2\")\n\n// let dd\n// if (Function.prototype.bind) {\n// dd = Function.prototype.bind.call(console.log, console)\n// } else {\n// dd = function () {\n// Function.prototype.apply.call(console.log, console, arguments)\n// }\n// }\n\n// dd(\"dd\")\n\n// let c = 1\n// Object.defineProperty(window, \"log2\", {\n// get: () => {\n// return console.log.bind(\n// window.console,\n// \"%c[log]%c %s\" + c++,\n// \"color:red\",\n// \"\"\n// )\n// },\n// })\n\n// // usage:\n// log2(\"Back to the future\")\n// log2(\"Back to the future\")\n\n// let plog = new Proxy(console.debug, {\n// apply: function (target, that, args) {\n// target.apply(that, args)\n// // base.apply(that, args);\n// },\n// })\n\n// let cons = console.debug\n// let plog = (...args) => {\n// cons.apply(window.console, [\"|\", ...args])\n// }\n\n// plog(\"xxx\")\n\n// function a() {\n// var err = new Error()\n// var caller_line = err.stack.split(\"\\n\")[2]\n// var index = caller_line.indexOf(\"at \")\n// var clean = caller_line.slice(index + 2, caller_line.length)\n// clean = clean.replace(/\\?t=\\d+/, \"\").replace(\"@fs/\", \"\")\n// console.log(clean)\n// console.log(\n// \"http://localhost:8080/Users/dirk/work/viidoo/lib/src/browser/log-browser.ts:188:1 log-browser.ts:291:10\"\n// )\n// }\n// function b() {\n// a()\n// }\n// b()\n"],"mappings":"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","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/browser/log-colors.ts","../src/browser/log-browser.ts"],"sourcesContent":["// Taken from https://github.com/visionmedia/debug/blob/master/src/browser.js#L27\n\nconst colors = [\n \"#0000CC\",\n \"#0000FF\",\n \"#0033CC\",\n \"#0033FF\",\n \"#0066CC\",\n \"#0066FF\",\n \"#0099CC\",\n \"#0099FF\",\n \"#00CC00\",\n \"#00CC33\",\n \"#00CC66\",\n \"#00CC99\",\n \"#00CCCC\",\n \"#00CCFF\",\n \"#3300CC\",\n \"#3300FF\",\n \"#3333CC\",\n \"#3333FF\",\n \"#3366CC\",\n \"#3366FF\",\n \"#3399CC\",\n \"#3399FF\",\n \"#33CC00\",\n \"#33CC33\",\n \"#33CC66\",\n \"#33CC99\",\n \"#33CCCC\",\n \"#33CCFF\",\n \"#6600CC\",\n \"#6600FF\",\n \"#6633CC\",\n \"#6633FF\",\n \"#66CC00\",\n \"#66CC33\",\n \"#9900CC\",\n \"#9900FF\",\n \"#9933CC\",\n \"#9933FF\",\n \"#99CC00\",\n \"#99CC33\",\n \"#CC0000\",\n \"#CC0033\",\n \"#CC0066\",\n \"#CC0099\",\n \"#CC00CC\",\n \"#CC00FF\",\n \"#CC3300\",\n \"#CC3333\",\n \"#CC3366\",\n \"#CC3399\",\n \"#CC33CC\",\n \"#CC33FF\",\n \"#CC6600\",\n \"#CC6633\",\n \"#CC9900\",\n \"#CC9933\",\n \"#CCCC00\",\n \"#CCCC33\",\n \"#FF0000\",\n \"#FF0033\",\n \"#FF0066\",\n \"#FF0099\",\n \"#FF00CC\",\n \"#FF00FF\",\n \"#FF3300\",\n \"#FF3333\",\n \"#FF3366\",\n \"#FF3399\",\n \"#FF33CC\",\n \"#FF33FF\",\n \"#FF6600\",\n \"#FF6633\",\n \"#FF9900\",\n \"#FF9933\",\n \"#FFCC00\",\n \"#FFCC33\",\n]\n\nexport function supportsColors(): boolean {\n // NB: In an Electron preload script, document will be defined but not fully\n // initialized. Since we know we're in Chrome, we'll just detect this case\n // explicitly\n if (\n typeof window !== \"undefined\" &&\n window.process &&\n // @ts-ignore\n (window.process.type === \"renderer\" || window.process.__nwjs)\n ) {\n return true\n }\n\n // Internet Explorer and Edge do not support colors.\n if (\n typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)\n ) {\n return false\n }\n\n // Is webkit? http://stackoverflow.com/a/16459606/376773\n // document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n return (\n (typeof document !== \"undefined\" &&\n document.documentElement &&\n document.documentElement.style &&\n // @ts-ignore\n document.documentElement.style.WebkitAppearance) ||\n // Is firebug? http://stackoverflow.com/a/398120/376773\n (typeof window !== \"undefined\" &&\n window.console &&\n // @ts-ignore\n (window.console.firebug ||\n // @ts-ignore\n (window.console.exception && window.console.table))) ||\n // Is firefox >= v31?\n // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n (typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) &&\n parseInt(RegExp.$1, 10) >= 31) ||\n // Double check webkit in userAgent just in case we are in a worker\n (typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/))\n )\n}\n\nexport function selectColor(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { deepEqual } from \"../common/data/deep\"\nimport {\n LoggerInterface,\n LogHandler,\n LogHandlerOptions,\n LogLevel,\n LogMessage,\n} from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\nimport { formatMilliseconds, getTimestamp } from \"../common/time\"\nimport { selectColor, supportsColors } from \"./log-colors\"\n\nconst styleFont = `font-family: \"JetBrains Mono\", Menlo; font-size: 11px;`\nconst styleDefault = `${styleFont}`\nconst styleBold = `font-weight: 600; ${styleFont}`\nconst useColors = supportsColors()\n\nlet namespaces: Record<string, any> = {}\n\nlet time = getTimestamp()\n\nexport function LoggerBrowserHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n filter = undefined,\n level = undefined,\n colors = true,\n levelHelper = false,\n nameBrackets = true,\n padding = 16,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n\n const timeNow = getTimestamp()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n ninfo = {\n color: selectColor(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const diff = formatMilliseconds(timeNow - time)\n let args: string[]\n\n if (padding > 0) {\n name = name.padEnd(16, \" \")\n }\n\n if (colors && useColors) {\n args = [`%c${name}%c \\t%s %c+${diff}`]\n args.push(`color:${ninfo.color}; ${styleBold}`)\n args.push(styleDefault)\n args.push(msg.messages?.[0] ?? \"\")\n args.push(`color:${ninfo.color};`)\n args.push(...msg.messages.slice(1))\n } else {\n args = [name, ...msg.messages, `+${diff}`]\n }\n\n // function consoleArgs(args: any[] = []): any[] {\n // return [\n // args\n // .filter((a) => typeof a === \"string\")\n // .map((a) => String(a))\n // .join(\" \"),\n // ...styles,\n // ...args.filter((a) => typeof a !== \"string\"),\n // ]\n // }\n\n switch (msg.level) {\n case LogLevel.info:\n if (opt.levelHelper) args[0] = `I|* ` + args[0]\n console.info(...args)\n break\n case LogLevel.warn:\n if (opt.levelHelper) args[0] = `W|** ` + args[0]\n console.warn(...args)\n break\n case LogLevel.error:\n if (opt.levelHelper) args[0] = `E|*** ` + args[0]\n console.error(...args)\n break\n default:\n if (opt.levelHelper) args[0] = `D| ` + args[0]\n console.debug(...args)\n break\n }\n }\n}\n\nexport function LoggerBrowserSetupDebugFactory(opt: LogHandlerOptions = {}) {\n const filter = opt.filter ?? localStorage.zeed ?? localStorage.debug\n\n /// The trick is, that console called directly provides a reference to the source code.\n /// For the regular implementation this information is lost. But this approach has other\n /// drawbacks, therefore only use it in the Browser when actively debugging.\n return function LoggerBrowserDebugFactory(\n name: string = \"\"\n ): LoggerInterface {\n let log: LoggerInterface\n\n const matches = useNamespaceFilter(filter)\n\n if (matches(name)) {\n let fixedArgs = []\n if (useColors) {\n const color = selectColor(name)\n fixedArgs.push(`%c${name.padEnd(16, \" \")}%c \\t%s`)\n fixedArgs.push(`color:${color}; ${styleBold}`)\n fixedArgs.push(styleDefault)\n } else {\n fixedArgs.push(`[${name}] \\t%s`)\n }\n\n // @ts-ignore\n // console.previous = {\n // debug: console.debug,\n // info: console.info,\n // warn: console.warn,\n // error: console.error,\n // assert: console.assert,\n // }\n\n log = console.debug.bind(console, ...fixedArgs) as LoggerInterface\n log.debug = console.debug.bind(console, ...fixedArgs)\n log.info = console.info.bind(console, ...fixedArgs)\n log.warn = console.warn.bind(console, ...fixedArgs)\n log.error = console.error.bind(console, ...fixedArgs)\n\n log.assert = console.assert.bind(console)\n\n log.assertEqual = function (value: any, expected: any, ...args: any[]) {\n let equal = deepEqual(value, expected)\n if (!equal) {\n log.assert(\n equal,\n `Assert did fail. Expected ${expected} got ${value}`,\n expected,\n value,\n ...args\n )\n }\n }\n\n log.assertNotEqual = function (\n value: any,\n expected: any,\n ...args: any[]\n ) {\n let equal = deepEqual(value, expected)\n if (equal) {\n log.assert(\n equal,\n `Assert did fail. Expected ${expected} not to be equal with ${value}`,\n expected,\n value,\n ...args\n )\n }\n }\n } else {\n const noop = () => {}\n log = noop as LoggerInterface\n log.debug = noop\n log.info = noop\n log.warn = noop\n log.error = noop\n\n log.assert = noop\n log.assertEqual = noop\n log.assertNotEqual = noop\n }\n\n log.extend = (subName: string) => {\n return LoggerBrowserDebugFactory(name ? `${name}:${subName}` : subName)\n }\n\n return log\n }\n}\n\n/** @deprecated This output is default for initial use of Logger in browser environments. */\nexport function activateConsoleDebug(opt: LogHandlerOptions = {}) {\n console.info(\"activateConsoleDebug is activated by default in browsers\")\n // Logger.setHandlers([LoggerBrowserHandler(opt)]) // Fallback for previously registered Loggers\n // Logger.setFactory(LoggerBrowserSetupDebugFactory(opt))\n}\n\n// let klass = console\n// let debug = console.debug.bind(window.console, klass.toString() + \": \")\n\n// debug(\"test\")\n// console.debug(\"test2\")\n\n// let dd\n// if (Function.prototype.bind) {\n// dd = Function.prototype.bind.call(console.log, console)\n// } else {\n// dd = function () {\n// Function.prototype.apply.call(console.log, console, arguments)\n// }\n// }\n\n// dd(\"dd\")\n\n// let c = 1\n// Object.defineProperty(window, \"log2\", {\n// get: () => {\n// return console.log.bind(\n// window.console,\n// \"%c[log]%c %s\" + c++,\n// \"color:red\",\n// \"\"\n// )\n// },\n// })\n\n// // usage:\n// log2(\"Back to the future\")\n// log2(\"Back to the future\")\n\n// let plog = new Proxy(console.debug, {\n// apply: function (target, that, args) {\n// target.apply(that, args)\n// // base.apply(that, args);\n// },\n// })\n\n// let cons = console.debug\n// let plog = (...args) => {\n// cons.apply(window.console, [\"|\", ...args])\n// }\n\n// plog(\"xxx\")\n\n// function a() {\n// var err = new Error()\n// var caller_line = err.stack.split(\"\\n\")[2]\n// var index = caller_line.indexOf(\"at \")\n// var clean = caller_line.slice(index + 2, caller_line.length)\n// clean = clean.replace(/\\?t=\\d+/, \"\").replace(\"@fs/\", \"\")\n// console.log(clean)\n// console.log(\n// \"http://localhost:8080/Users/dirk/work/viidoo/lib/src/browser/log-browser.ts:188:1 log-browser.ts:291:10\"\n// )\n// }\n// function b() {\n// a()\n// }\n// b()\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var H=Object.defineProperty,_=Object.defineProperties;var M=Object.getOwnPropertyDescriptors;var k=Object.getOwnPropertySymbols;var z=Object.prototype.hasOwnProperty,B=Object.prototype.propertyIsEnumerable;var C=(e,n,r)=>n in e?H(e,n,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[n]=r,K=(e,n)=>{for(var r in n||(n={}))z.call(n,r)&&C(e,r,n[r]);if(k)for(var r of k(n))B.call(n,r)&&C(e,r,n[r]);return e},N=(e,n)=>_(e,M(n));var o=(e,n)=>H(e,"name",{value:n,configurable:!0});function m(e){return e!=null&&typeof e=="object"}o(m,"isObject");function j(e){return Object(e)!==e}o(j,"isPrimitive");function V(e){return Array.isArray(e)}o(V,"isArray");function X(e){return m(e)&&!V(e)}o(X,"isRecord");function Y(e){return typeof e=="string"}o(Y,"isString");function ee(e){return typeof e=="number"}o(ee,"isNumber");function ne(e){return typeof e=="number"&&Number.isInteger(e)}o(ne,"isInteger");function re(e){return typeof e=="number"&&Number.isSafeInteger(e)}o(re,"isSafeInteger");function oe(e){return typeof e=="boolean"}o(oe,"isBoolean");function te(e){return e==null}o(te,"isNullOrUndefined");function x(e,n,r=new WeakSet){if(e===n||r.has(n))return!0;if(j(n)||r.add(n),!(e instanceof Object)||!(n instanceof Object)||e.constructor!==n.constructor||e.length!==n.length)return!1;for(let i in e){if(!e.hasOwnProperty(i))continue;if(!n.hasOwnProperty(i))return!1;let f=e[i],u=n[i];if(!x(f,u,r))return!1}for(let i in n)if(n.hasOwnProperty(i)&&!e.hasOwnProperty(i))return!1;return!0}o(x,"deepEqual");function T(e,...n){for(let r of n)m(e)||(e={}),r!=null&&Object.keys(r).forEach(i=>{let f=e[i],u=r[i];Array.isArray(f)&&Array.isArray(u)?e[i]=f.concat(u):m(f)&&m(u)?e[i]=T(Object.assign({},f),u):e[i]=u});return e}o(T,"deepMerge");function E(e={}){let{level:n=void 0,filter:r=void 0,colors:i=!0,levelHelper:f=!1,nameBrackets:u=!0,padding:b=16}=e,l=w(r),t=G(n);return s=>{if(!t(s.level)||!l(s.name))return;let g=s.name?`[${s.name}]`:"";switch(s.level){case p.info:console.info(`I|* ${g}`,...s.messages);break;case p.warn:console.warn(`W|** ${g}`,...s.messages);break;case p.error:console.error(`E|*** ${g}`,...s.messages);break;default:console.debug(`D| ${g}`,...s.messages);break}}}o(E,"LoggerConsoleHandler");var p=(l=>(l[l.all=-1]="all",l[l.debug=0]="debug",l[l.info=1]="info",l[l.warn=2]="warn",l[l.error=3]="error",l[l.fatal=4]="fatal",l[l.off=1/0]="off",l))(p||{}),A={"*":-1,a:-1,all:-1,d:0,dbg:0,debug:0,i:1,inf:1,info:1,w:2,warn:2,warning:2,e:3,err:3,error:3,fatal:4,off:1/0,"-":1/0};function O(e=""){let n=[E()],r=2,i=o(t=>!0,"logCheckNamespace"),f=!1,u=b;function b(t=""){g.extend=function(a){return u(t?`${t}:${a}`:a)};let s=o(a=>{if(g.active===!0&&a.level>=l.level&&a.level>=g.level&&i(t))for(let c of n)c&&c(a)},"emit");function g(...a){s({name:t,messages:a,level:0})}return o(g,"log"),g.active=!0,g.level=-1,g.debug=function(...a){s({name:t,messages:a,level:0})},g.info=function(...a){s({name:t,messages:a,level:1})},g.warn=function(...a){s({name:t,messages:a,level:2})},g.error=function(...a){s({name:t,messages:a,level:3})},g.assert=function(a,...c){a||(typeof console!==void 0&&(console.assert?console.assert(a,...c):console.error(`Assert did fail with: ${a}`,...c)),s({name:t,messages:c||[`Assert did fail with: ${a}`],level:r}))},g.assertEqual=function(a,c,...h){let y=x(a,c);y||g.assert(y,`Assert did fail. Expected ${c} got ${a}`,c,a,...h)},g.assertNotEqual=function(a,c,...h){let y=x(a,c);y&&g.assert(y,`Assert did fail. Expected ${c} not to be equal with ${a}`,c,a,...h)},g}o(b,"LoggerBaseFactory");function l(t=""){return u(t)}return o(l,"Logger"),l.registerHandler=function(t){n.push(t)},l.setFilter=function(t){i=w(t)},l.setLock=(t=!0)=>f=t,l.setHandlers=function(t=[]){u!==b&&(u=b),!f&&(n=[...t].filter(s=>typeof s=="function"))},l.level=-1,l.setLogLevel=function(t=-1){f||(l.level=t)},l.setFactory=function(t){f||(u=t)},l}o(O,"LoggerContext");function F(e){return e===!0||e==="true"||e==="1"||typeof e=="number"&&e!==0?e="*":e===!1||e==="false"||e===0||e==="0"||e==null||e==="null"||e==="undefined"?e="":e=String(e),e}o(F,"getNamespaceFilterString");var $,D,U=F(typeof process!="undefined"?($=process.env.ZEED)!=null?$:process.env.DEBUG:typeof localStorage!="undefined"?(D=localStorage.zeed)!=null?D:localStorage.debug:"*");function w(e=U){let n,r=[],i=[];if(!e)n=o(function(f){return!1},"fn");else if(e==="*")n=o(function(f){return!0},"fn");else{let f,u=e.split(/[\s,]+/),b=u.length;for(f=0;f<b;f++){if(!u[f])continue;let l=u[f].replace(/\*/g,".*?");l[0]==="-"?r.push(new RegExp("^"+l.substr(1)+"$")):i.push(new RegExp("^"+l+"$"))}n=o(function(l){if(r.length===0&&i.length===0)return!0;let t,s;for(t=0,s=r.length;t<s;t++)if(r[t].test(l))return!1;for(t=0,s=i.length;t<s;t++)if(i[t].test(l))return!0;return!1},"fn")}return n.accept=i,n.reject=r,n.filter=e,n}o(w,"useNamespaceFilter");var S,Z,q,R,W=typeof process!="undefined"?(Z=(S=process.env.ZEED_LEVEL)!=null?S:process.env.LEVEL)!=null?Z:process.env.DEBUG_LEVEL:typeof localStorage!="undefined"?(R=(q=localStorage.zeed_level)!=null?q:localStorage.level)!=null?R:localStorage.debug_level:void 0;function G(e=W){let n=p.all;if(typeof e=="string"){let r=A[e.toLocaleLowerCase().trim()];r!=null&&(n=r)}else typeof e=="number"&&(n=e);return r=>r>=n}o(G,"useLevelFilter");function J(){if(typeof self!="undefined")return self;if(typeof window!="undefined")return window;if(typeof global!="undefined")return global;if(typeof globalThis!="undefined")return globalThis;throw new Error("unable to locate global object")}o(J,"_global");function P(){let e=J();return e._zeedGlobal==null&&(e._zeedGlobal={}),e._zeedGlobal}o(P,"getGlobalContext");var v;function I(){let e=O();return e.setHandlers([E()]),e}o(I,"getLoggerContext");try{let e=P();e!=null?(e==null?void 0:e.logger)==null?(v=I(),e.logger=v):v=e.logger:v=I()}catch{v=I()}var He=v;var Ce=o(()=>typeof performance!="undefined"?performance.now():new Date().getTime(),"getTimestamp");function je(e){return e>999?(e/1e3).toFixed(1)+"s":e.toFixed(2)+"ms"}o(je,"formatMilliseconds");function Ge(...e){for(let n of e){if(n instanceof Date)return n;if(typeof n=="string"){let r=null;if(n.includes(":"))try{r=new Date(n)}catch{}if(!(r instanceof Date)){let i=/(\d\d\d\d)-(\d\d)-(\d\d)/.exec(n);i&&(r=new Date(+i[1],+i[2]-1,+i[3],12,0))}if(r instanceof Date)return r}}}o(Ge,"parseDate");export{K as a,N as b,o as c,m as d,j as e,V as f,X as g,Y as h,ee as i,ne as j,re as k,oe as l,te as m,x as n,T as o,F as p,w as q,G as r,p as s,A as t,O as u,E as v,P as w,He as x,Ce as y,je as z,Ge as A};
|
|
2
|
+
//# sourceMappingURL=chunk-LNZLD7Y3.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/common/data/is.ts","../src/common/data/deep.ts","../src/common/log-console.ts","../src/common/log-base.ts","../src/common/log-filter.ts","../src/common/global.ts","../src/common/log.ts","../src/common/time.ts"],"sourcesContent":["// https://github.com/sindresorhus/is/ MIT\n// https://github.com/sindresorhus/ts-extras\n// https://github.com/sindresorhus/type-fest\n// https://github.com/antfu/utils\n\nexport type Primitive =\n | null\n | undefined\n | string\n | number\n | boolean\n | symbol\n | bigint\n\nexport function isObject(obj: unknown): obj is object {\n return obj != null && typeof obj === \"object\"\n}\n\nexport function isPrimitive(obj: unknown): obj is Primitive {\n return Object(obj) !== obj\n}\n\nexport function isArray(obj: unknown): obj is Array<any> {\n return Array.isArray(obj)\n}\n\nexport function isRecord(obj: unknown): obj is Record<string, any> {\n return isObject(obj) && !isArray(obj)\n}\n\nexport function isString(obj: unknown): obj is string {\n return typeof obj === \"string\"\n}\n\nexport function isNumber(obj: unknown): obj is number {\n return typeof obj === \"number\"\n}\n\nexport function isInteger(obj: unknown): obj is number {\n return typeof obj === \"number\" && Number.isInteger(obj)\n}\n\nexport function isSafeInteger(obj: unknown): obj is number {\n return typeof obj === \"number\" && Number.isSafeInteger(obj)\n}\n\nexport function isBoolean(obj: unknown): obj is boolean {\n return typeof obj === \"boolean\"\n}\n\nexport function isNullOrUndefined(obj: unknown): obj is null | undefined {\n return obj == null\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { isObject, isPrimitive } from \"./is\"\n\n// // https://stackoverflow.com/a/40294058/140927\n// // Handles cyclic references\n// export function deepClonePrimitives(obj, hash = new WeakMap()) {\n//\n// // primitives\n// if (Object(obj) !== obj) {\n// // log('Primitive', obj)\n// return obj\n// }\n//\n// // cyclic reference\n// if (hash.has(obj)) {\n// return hash.get(obj)\n// }\n//\n// let result\n//\n// // primitives as objects like new String(), new Number()\n// if (\n// obj instanceof String ||\n// obj instanceof Number ||\n// obj instanceof BigInt ||\n// obj instanceof Boolean ||\n// obj instanceof Symbol\n// ) {\n// result = new obj.constructor(obj.valueOf())\n// // hash.set(obj, result)\n// return result\n// }\n//\n// // log('Obj', obj)\n//\n// if (obj instanceof Set) {\n// result = new Set(obj)\n// } else if (obj instanceof Map) {\n// result = new Map(Array.from(obj, ([key, val]) => [key, deepClonePrimitives(val, hash)]))\n// } else if (obj instanceof Date) {\n// result = new Date(obj)\n// } else if (obj instanceof RegExp) {\n// result = new RegExp(obj.source, obj.flags)\n// } else if (Array.isArray(obj)) {\n// result = Array.from(obj, val => deepClonePrimitives(val, hash))\n// } else if (obj.constructor) {\n// result = new obj.constructor()\n// log('bj object', result)\n// } else if (obj instanceof Function || typeof obj === 'function') {\n// log('Keep object', obj, Object.getPrototypeOf(obj))\n// result = obj\n// } else {\n// result = Object.create(null)\n// }\n//\n// hash.set(obj, result)\n//\n// return Object.assign(result, ...Object.keys(obj).map(key => ({\n// [key]: deepClonePrimitives(obj[key], hash),\n// })))\n// }\n\nexport function deepEqual(a: any, b: any, hash = new WeakSet()) {\n // if both x and y are null or undefined and exactly the same\n if (a === b) {\n return true\n }\n\n // Cyclic\n if (hash.has(b)) {\n // console.log('cyclic')\n return true\n }\n\n if (!isPrimitive(b)) {\n hash.add(b)\n }\n\n // if they are not strictly equal, they both need to be Objects\n if (!(a instanceof Object) || !(b instanceof Object)) {\n return false\n }\n\n // they must have the exact same prototype chain, the closest we can do is\n // test there constructor.\n if (a.constructor !== b.constructor) {\n return false\n }\n\n // Shortcut to avoid to many loops\n if (a.length !== b.length) {\n return false\n }\n\n for (let p in a) {\n // other properties were tested using x.constructor === y.constructor\n if (!a.hasOwnProperty(p)) {\n continue\n }\n\n // allows to compare x[ p ] and y[ p ] when set to undefined\n if (!b.hasOwnProperty(p)) {\n return false\n }\n\n let aa = a[p]\n let bb = b[p]\n\n // if they have the same strict value or identity then they are equal\n // if (aa === bb) {\n // console.log('eq', typeof bb)\n // if (bb != null) hash.set(bb, true)\n // continue\n // }\n //\n // // Numbers, Strings, Functions, Booleans must be strictly equal\n // if (typeof (aa) !== 'object') {\n // return false\n // }\n\n // Objects and Arrays must be tested recursively\n if (!deepEqual(aa, bb, hash)) {\n return false\n }\n }\n\n // allows x[ p ] to be set to undefined\n for (let p in b) {\n if (b.hasOwnProperty(p) && !a.hasOwnProperty(p)) {\n return false\n }\n }\n\n return true\n}\n\nexport function deepMerge(target: any, ...sources: any[]) {\n for (let source of sources) {\n if (!isObject(target)) {\n target = {}\n }\n\n if (source == null) continue\n\n Object.keys(source).forEach((key) => {\n const targetValue = target[key]\n const sourceValue = source[key]\n\n if (Array.isArray(targetValue) && Array.isArray(sourceValue)) {\n target[key] = targetValue.concat(sourceValue)\n } else if (isObject(targetValue) && isObject(sourceValue)) {\n target[key] = deepMerge(Object.assign({}, targetValue), sourceValue)\n } else {\n target[key] = sourceValue\n }\n })\n }\n\n return target\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { LogHandler, LogHandlerOptions, LogLevel, LogMessage } from \"./log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"./log-filter\"\n\n/**\n * Very basic logger. Please take a look at the browser and node\n * optimized loggers. This one is just the absolute fallback option.\n *\n * @param level Log level\n * @returns Logger\n */\nexport function LoggerConsoleHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n level = undefined,\n filter = undefined,\n colors = true,\n levelHelper = false,\n nameBrackets = true,\n padding = 16,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n let name = msg.name ? `[${msg.name}]` : \"\"\n switch (msg.level) {\n case LogLevel.info:\n console.info(`I|* ${name}`, ...msg.messages)\n break\n case LogLevel.warn:\n console.warn(`W|** ${name}`, ...msg.messages)\n break\n case LogLevel.error:\n console.error(`E|*** ${name}`, ...msg.messages)\n break\n default:\n console.debug(`D| ${name}`, ...msg.messages)\n break\n }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { deepEqual } from \"./data/deep\"\nimport { LoggerConsoleHandler } from \"./log-console\"\nimport { useNamespaceFilter } from \"./log-filter\"\n\nexport enum LogLevel {\n all = -1,\n debug = 0,\n info,\n warn,\n error,\n fatal,\n off = Infinity,\n}\n\nexport const LogLevelAlias: Record<string, LogLevel> = {\n \"*\": LogLevel.all,\n a: LogLevel.all,\n all: LogLevel.all,\n d: LogLevel.debug,\n dbg: LogLevel.debug,\n debug: LogLevel.debug,\n i: LogLevel.info,\n inf: LogLevel.info,\n info: LogLevel.info,\n w: LogLevel.warn,\n warn: LogLevel.warn,\n warning: LogLevel.warn,\n e: LogLevel.error,\n err: LogLevel.error,\n error: LogLevel.error,\n fatal: LogLevel.fatal,\n off: LogLevel.off,\n \"-\": LogLevel.off,\n}\n\nexport interface LogMessage {\n level: LogLevel\n name: string\n messages: any[]\n line?: number\n file?: string\n timestamp?: number\n}\n\nexport type LogHandler = (msg: LogMessage) => void\n\nexport interface LoggerInterface {\n (...messages: any[]): void\n\n /** @deprecated use .level = LogLevel.off or LogLevel.all */\n active: boolean\n\n level: LogLevel\n\n debug(...messages: any[]): void\n\n info(...messages: any[]): void\n\n warn(...messages: any[]): void\n\n error(...messages: any[]): void\n\n assert(cond: any, ...messages: any[]): void\n\n /** @deprecated use .assert */\n assertEqual(value: any, expected: any, ...args: any[]): void\n\n /** @deprecated use .assert */\n assertNotEqual(value: any, expected: any, ...args: any[]): void\n\n extend(prefix: string): LoggerInterface\n\n factory?: LoggerContextInterface\n}\n\nexport interface LoggerContextInterface {\n (name?: string): LoggerInterface\n registerHandler(handler: LogHandler): void\n setFilter(namespaces: string): void\n setHandlers(handlers?: (LogHandler | undefined | null)[]): void\n setLock(lock: boolean): void\n setLogLevel(level?: LogLevel): void\n setFactory(factory: (name?: string) => LoggerInterface): void\n}\n\nexport interface LogHandlerOptions {\n level?: LogLevel\n filter?: string\n colors?: boolean\n levelHelper?: boolean\n nameBrackets?: boolean\n padding?: number\n fill?: number\n stack?: boolean | number\n}\n\nexport function LoggerContext(prefix: string = \"\"): LoggerContextInterface {\n let logHandlers: LogHandler[] = [LoggerConsoleHandler()]\n let logAssertLevel: LogLevel = LogLevel.warn\n let logCheckNamespace = (name: string) => true\n let logLock = false\n let logFactory = LoggerBaseFactory\n\n function LoggerBaseFactory(name: string = \"\"): LoggerInterface {\n log.extend = function (prefix: string): LoggerInterface {\n return logFactory(name ? `${name}:${prefix}` : prefix)\n }\n\n const emit = (msg: LogMessage) => {\n if (log.active === true) {\n if (msg.level >= Logger.level && msg.level >= log.level) {\n if (logCheckNamespace(name)) {\n for (let handler of logHandlers) {\n if (handler) handler(msg)\n }\n }\n }\n }\n }\n\n function log(...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.debug,\n })\n }\n\n log.active = true\n log.level = LogLevel.all\n\n log.debug = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.debug,\n })\n }\n\n log.info = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.info,\n })\n }\n\n log.warn = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.warn,\n })\n }\n\n log.error = function (...messages: any[]) {\n emit({\n name,\n messages,\n level: LogLevel.error,\n })\n }\n\n // fatal(...args: any[]) {\n // console.error(...args)\n // },\n\n log.assert = function (cond: any, ...messages: any[]) {\n if (!cond) {\n if (typeof console !== undefined) {\n if (console.assert) {\n // https://developer.mozilla.org/de/docs/Web/API/Console/assert\n console.assert(cond, ...messages)\n } else {\n console.error(`Assert did fail with: ${cond}`, ...messages)\n }\n }\n emit({\n name,\n messages: messages || [`Assert did fail with: ${cond}`],\n level: logAssertLevel,\n })\n // try {\n // if (typeof expect !== undefined) {\n // expect(cond).toBeTruthy()\n // }\n // } catch (err) {\n // methods.warn(...args)\n // }\n }\n }\n\n log.assertEqual = function (value: any, expected: any, ...args: any[]) {\n let equal = deepEqual(value, expected)\n if (!equal) {\n log.assert(\n equal,\n `Assert did fail. Expected ${expected} got ${value}`,\n expected,\n value,\n ...args\n )\n // } else {\n // methods.debug(`Passed equal`)\n }\n }\n\n log.assertNotEqual = function (value: any, expected: any, ...args: any[]) {\n let equal = deepEqual(value, expected)\n if (equal) {\n log.assert(\n equal,\n `Assert did fail. Expected ${expected} not to be equal with ${value}`,\n expected,\n value,\n ...args\n )\n // } else {\n // methods.debug(`Passed not equal check`)\n }\n }\n\n return log\n }\n\n function Logger(name: string = \"\"): LoggerInterface {\n return logFactory(name)\n }\n\n Logger.registerHandler = function (handler: LogHandler) {\n logHandlers.push(handler)\n }\n\n Logger.setFilter = function (namespaces: string) {\n logCheckNamespace = useNamespaceFilter(namespaces)\n }\n\n Logger.setLock = (lock: boolean = true) => (logLock = lock)\n\n Logger.setHandlers = function (handlers: LogHandler[] = []) {\n if (logFactory !== LoggerBaseFactory) {\n logFactory = LoggerBaseFactory\n }\n if (logLock) return\n logHandlers = [...handlers].filter((h) => typeof h === \"function\")\n }\n\n Logger.level = LogLevel.all\n\n /** @deprecated */\n Logger.setLogLevel = function (level: LogLevel = LogLevel.all) {\n if (logLock) return\n Logger.level = level\n }\n\n Logger.setFactory = function (\n factory: (name?: string) => LoggerInterface\n ): void {\n if (logLock) return\n logFactory = factory\n }\n\n return Logger\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { LogLevel, LogLevelAlias } from \"./log-base\"\n\ninterface NamespaceFilter {\n (name: string): boolean\n accept: RegExp[]\n reject: RegExp[]\n filter: string\n}\n\nexport function getNamespaceFilterString(defaultNamespaceFilter: any): string {\n if (\n defaultNamespaceFilter === true ||\n defaultNamespaceFilter === \"true\" ||\n defaultNamespaceFilter === \"1\" ||\n (typeof defaultNamespaceFilter === \"number\" && defaultNamespaceFilter !== 0)\n ) {\n defaultNamespaceFilter = \"*\"\n } else if (\n defaultNamespaceFilter === false ||\n defaultNamespaceFilter === \"false\" ||\n defaultNamespaceFilter === 0 ||\n defaultNamespaceFilter === \"0\" ||\n defaultNamespaceFilter == null ||\n defaultNamespaceFilter === \"null\" ||\n defaultNamespaceFilter === \"undefined\"\n ) {\n defaultNamespaceFilter = \"\"\n } else {\n defaultNamespaceFilter = String(defaultNamespaceFilter)\n }\n return defaultNamespaceFilter\n}\n\nconst defaultNamespaceFilter: string = getNamespaceFilterString(\n typeof process !== \"undefined\"\n ? process.env.ZEED ?? process.env.DEBUG\n : typeof localStorage !== \"undefined\"\n ? localStorage.zeed ?? localStorage.debug\n : \"*\"\n)\n\n/**\n * Filter as described here https://github.com/visionmedia/debug#wildcards\n *\n * @param filter Namespace filter\n * @returns Function to check if filter applies\n */\nexport function useNamespaceFilter(\n filter: string = defaultNamespaceFilter\n): NamespaceFilter {\n let fn: any // (name: string) => boolean\n let reject = [] as RegExp[]\n let accept = [] as RegExp[]\n\n if (!filter) {\n fn = function (name: string) {\n return false\n }\n } else if (filter === \"*\") {\n fn = function (name: string) {\n return true\n }\n } else {\n let i\n const split = filter.split(/[\\s,]+/)\n const len = split.length\n for (i = 0; i < len; i++) {\n if (!split[i]) {\n // ignore empty strings\n continue\n }\n let template = split[i].replace(/\\*/g, \".*?\")\n if (template[0] === \"-\") {\n reject.push(new RegExp(\"^\" + template.substr(1) + \"$\"))\n } else {\n accept.push(new RegExp(\"^\" + template + \"$\"))\n }\n }\n\n fn = function (name: string) {\n if (reject.length === 0 && accept.length === 0) {\n return true\n }\n let i, len\n for (i = 0, len = reject.length; i < len; i++) {\n if (reject[i].test(name)) {\n return false\n }\n }\n for (i = 0, len = accept.length; i < len; i++) {\n if (accept[i].test(name)) {\n return true\n }\n }\n return false\n }\n }\n fn.accept = accept\n fn.reject = reject\n fn.filter = filter\n return fn as NamespaceFilter\n}\n\nconst defaultLevelFilter: any =\n typeof process !== \"undefined\"\n ? process.env.ZEED_LEVEL ?? process.env.LEVEL ?? process.env.DEBUG_LEVEL\n : typeof localStorage !== \"undefined\"\n ? localStorage.zeed_level ?? localStorage.level ?? localStorage.debug_level\n : undefined\n\nexport function useLevelFilter(\n filter: string | number = defaultLevelFilter\n): (level: LogLevel) => boolean {\n let filterLevel: LogLevel = LogLevel.all\n if (typeof filter === \"string\") {\n const l = LogLevelAlias[filter.toLocaleLowerCase().trim()]\n if (l != null) filterLevel = l\n } else if (typeof filter === \"number\") {\n filterLevel = filter as number\n }\n return (level) => level >= filterLevel\n}\n","// Global context across build systems etc.\n\ndeclare global {\n interface ZeedGlobalContext {}\n}\n\ninterface ZeedGlobalIntegration {\n _zeedGlobal?: ZeedGlobalContext\n}\n\nfunction _global(): ZeedGlobalIntegration {\n if (typeof self !== \"undefined\") return self as ZeedGlobalIntegration\n if (typeof window !== \"undefined\") return window as ZeedGlobalIntegration\n if (typeof global !== \"undefined\") return global as ZeedGlobalIntegration\n if (typeof globalThis !== \"undefined\")\n return globalThis as ZeedGlobalIntegration\n throw new Error(\"unable to locate global object\")\n}\n\nexport function getGlobalContext(): ZeedGlobalContext {\n let gcontext = _global()\n if (gcontext._zeedGlobal == null) {\n gcontext._zeedGlobal = {}\n }\n return gcontext._zeedGlobal\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { LoggerConsoleHandler } from \"./log-console\"\nimport { getGlobalContext } from \"./global\"\nimport { LoggerContext, LoggerContextInterface } from \"./log-base\"\n\n// Global logger to guarantee all submodules use the same logger instance\n\nlet globalLogger: LoggerContextInterface\n\ndeclare global {\n interface ZeedGlobalContext {\n logger?: any // Should be LoggerContextInterface, but avoid compiler issues this way\n }\n}\n\nfunction getLoggerContext() {\n let logger = LoggerContext()\n logger.setHandlers([LoggerConsoleHandler()])\n return logger\n}\n\ntry {\n let _global = getGlobalContext()\n if (_global != null) {\n if (_global?.logger == null) {\n globalLogger = getLoggerContext()\n _global.logger = globalLogger\n } else {\n globalLogger = _global.logger\n }\n } else {\n globalLogger = getLoggerContext()\n }\n} catch (e) {\n globalLogger = getLoggerContext()\n}\n\n// /** @deprecated Use `Logger` instead, it is global as well */\n// export const GlobalLogger = globalLogger\n\nexport const Logger = globalLogger\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\n/**\n * @returns Timestamp in miliseconds\n */\nexport const getTimestamp = (): number =>\n // @ts-ignore\n typeof performance !== \"undefined\" ? performance.now() : new Date().getTime()\n\nexport function formatMilliseconds(ms: number): string {\n return ms > 999 ? (ms / 1000).toFixed(1) + \"s\" : ms.toFixed(2) + \"ms\"\n}\n\nexport function parseDate(\n ...dateCandidates: (string | Date)[]\n): Date | undefined {\n for (let dateCandidate of dateCandidates) {\n if (dateCandidate instanceof Date) {\n return dateCandidate\n }\n if (typeof dateCandidate === \"string\") {\n let date = null\n if (dateCandidate.includes(\":\")) {\n try {\n date = new Date(dateCandidate)\n } catch (err) {}\n }\n if (!(date instanceof Date)) {\n let m = /(\\d\\d\\d\\d)-(\\d\\d)-(\\d\\d)/.exec(dateCandidate)\n if (m) {\n date = new Date(+m[1], +m[2] - 1, +m[3], 12, 0)\n }\n }\n if (date instanceof Date) {\n return date\n }\n }\n }\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import{a as D,b as W,c as o,s as xe,w as ie,x as b,y as be}from"./chunk-LNZLD7Y3.js";var Te=b("bin"),Y;function we(e){return typeof TextEncoder=="undefined"?new Uint8Array:(Y!=null?Y:Y=new TextEncoder).encode(e.normalize("NFC"))}o(we,"stringToUInt8Array");var X;function Xe(e){return typeof TextDecoder=="undefined"?"":(X!=null?X:X=new TextDecoder("utf-8",{ignoreBOM:!0})).decode(e).normalize("NFC")}o(Xe,"Uint8ArrayToString");function U(e){return e instanceof ArrayBuffer?new Uint8Array(e):typeof e=="string"?we(e):e.length?new Uint8Array(e):e}o(U,"toUint8Array");function Gt(e){if(typeof Buffer!="undefined")return Buffer.from(U(e)).toString("hex");let t="0123456789abcdef",r="";for(let n of[...U(e)])r+=t[n>>4]+t[n&15];return r}o(Gt,"toHex");function jt(e){let t=U(e);if(typeof Buffer!="undefined")return Buffer.from(t).toString("base64");let r="";for(let n=0;n<t.byteLength;n++)r+=String.fromCharCode(t[n]);return btoa(r)}o(jt,"toBase64");function Wt(e){let t=U(e);if(typeof Buffer!="undefined")return Buffer.from(t).toString("base64url");let r="";for(let n=0;n<t.byteLength;n++)r+=String.fromCharCode(t[n]);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_")}o(Wt,"toBase64Url");function Ae(e,t){if(e.byteLength!==t.byteLength)return!1;let r=U(e),n=U(t);for(let i=0;i<r.length;i++)if(r[i]!==n[i])return!1;return!0}o(Ae,"equalBinary");function se(e){try{return we(JSON.stringify(e))}catch(t){throw Te.warn("jsonToUint8Array",e),t}}o(se,"jsonToUint8Array");function ae(e){try{return JSON.parse(Xe(e))}catch(t){throw Te.warn("Uint8ArrayToJson",e),t}}o(ae,"Uint8ArrayToJson");function Q(e=16){let t=new Uint8Array(e);if(typeof crypto!="undefined"&&crypto.getRandomValues)crypto.getRandomValues(t);else for(let r=0;r<e;r++)t[r]=Math.floor(Math.random()*256);return t}o(Q,"randomUint8Array");var Me="SHA-256",ue="AES-GCM",Pe="PBKDF2";async function Zt(e,t=Me){return await crypto.subtle.digest(t,U(e))}o(Zt,"digest");async function Kt(e,t={}){var i;let r=U(e),n=await crypto.subtle.importKey("raw",r,Pe,!1,["deriveKey"]);return await crypto.subtle.deriveKey({name:Pe,salt:t.salt?U(t.salt):new Uint8Array(0),iterations:(i=t.iterations)!=null?i:1e5,hash:Me},n,{name:ue,length:256},!0,["encrypt","decrypt"])}o(Kt,"deriveKeyPbkdf2");var ee=new Uint8Array([1,1]);async function Ee(e,t){let r=Q(12),n=await crypto.subtle.encrypt({name:ue,iv:r},t,e),i=new Uint8Array(n),s=ee.length+r.length+i.length,c=new Uint8Array(s),a=0;return c.set(ee,a),a+=ee.length,c.set(r,a),a+=r.length,c.set(i,a),c}o(Ee,"encrypt");async function Le(e,t){let r=e.subarray(0,2);if(!Ae(r,ee))return Promise.reject(`Unknown magic ${r}`);let n=e.subarray(2,2+12),i=e.subarray(2+12,e.length),s=await crypto.subtle.decrypt({name:ue,iv:n},t,i);return new Uint8Array(s)}o(Le,"decrypt");var Ce=",",et=!1,tt=!0;function rt(e){return/^([-+])?([0-9]+(\.[0-9]+)?|Infinity)$/.test(e)?Number(e):NaN}o(rt,"filterFloat");function nt(e){return tt&&e==null?"":et?'="'+String(e).replace(/"/g,'""')+'"':!isNaN(rt(e))&&isFinite(e)?parseFloat(e):'"'+String(e).replace(/"/g,'""')+'"'}o(nt,"escape");function Xt(e,t){let r="";t&&(r=t.join(Ce)+`\r
|
|
2
|
+
`);for(let n=0;n<e.length;n++)r+=e[n].map(nt).join(Ce)+`\r
|
|
3
|
+
`;return r}o(Xt,"csv");function ot(e=""){let[t="",r="asc"]=e.split(" ");return r=r.toLowerCase(),{field:t,orderby:r,asc:r!=="desc",desc:r==="desc"}}o(ot,"parseOrderby");function tr(e,t=!0){return`${e} ${t?"asc":"desc"}`}o(tr,"composeOrderby");function ce(e,t,r=!0){let n=e||0,i=t||0;return n>i?r?1:-1:n<i?r?-1:1:0}o(ce,"cmp");function rr(e,...t){if(t.length>0){let r=t.map(ot),n=Array.from(e);return n.sort((i,s)=>{for(let{field:c,asc:a}of r){let u=ce(i[c],s[c],a);if(u!==0)return u}return 0}),n}return e}o(rr,"sortedOrderby");function fe(e){return e.filter((t,r)=>e.indexOf(t)===r)}o(fe,"arrayUnique");function it(e,t){return fe(e.filter(r=>!t.includes(r)))}o(it,"arrayMinus");function st(...e){return fe(e.reduce((t=[],r)=>t.concat(r),[]))}o(st,"arrayUnion");function V(...e){return e.flat(1/0)}o(V,"arrayFlatten");function at(e,t){return fe(e).filter(r=>t.includes(r))}o(at,"arrayIntersection");function ir(e,t){return it(st(e,t),at(e,t))}o(ir,"arraySymmetricDifference");function sr(e,t){if(e&&Array.isArray(e)){let r;for(;(r=e.indexOf(t))!==-1;)e.splice(r,1);return e}return[]}o(sr,"arrayRemoveElement");function ar(e,t){return e.includes(t)||e.push(t),e}o(ar,"arraySetElement");function Ue(e,t){return e.splice(0,e.length,...e.filter(t)),e}o(Ue,"arrayFilterInPlace");function ur(e,t){let r=e.findIndex(n=>n===t);return r>=0?e.splice(r,1):e.push(t),e}o(ur,"arrayToggleInPlace");function cr(e){return e.splice(0,e.length),e}o(cr,"arrayEmptyInPlace");function ut(e,t=ce){return Array.from(e).sort(t)}o(ut,"arraySorted");function fr(e){return ut(e,(t,r)=>t-r)}o(fr,"arraySortedNumbers");function ct(e,t){return e.length===t.length&&e.every((r,n)=>r===t[n])}o(ct,"arrayIsEqual");function ke(e){return e.sort(()=>Math.random()>.5?1:-1),e}o(ke,"arrayShuffleInPlace");function lr(e){return ke(Array.from(e))}o(lr,"arrayShuffle");function pr(e){for(;e.length>1;){let t=Array.from(e);if(ke(t),!ct(e,t))return t}return e}o(pr,"arrayShuffleForce");function dr(e){return e[Math.floor(Math.random()*e.length)]}o(dr,"arrayRandomElement");function mr(...e){return V(e).reduce((t,r)=>t!=null?r>t?r:t:r,void 0)}o(mr,"arrayMax");function yr(...e){return V(e).reduce((t,r)=>t!=null?r<t?r:t:r,void 0)}o(yr,"arrayMin");function gr(e=0,t){if(e<=0)return[];let r=new Array(e);for(let n=0;n<e;n++)r[n]=t instanceof Function?t(n):t;return r}o(gr,"createArray");var ft=b("zeed:basex"),lt={"2":"01","8":"01234567","11":"0123456789a","16":"0123456789abcdef","32":"0123456789ABCDEFGHJKMNPQRSTVWXYZ","32-rfc":"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567","32-hex":"0123456789ABCDEFGHIJKLMNOPQRSTUV","32-zbase":"ybndrfg8ejkmcpqxot1uwisza345h769","36":"0123456789abcdefghijklmnopqrstuvwxyz","58":"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz","62":"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz","64":"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/","64-url":"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_","66":"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.!~","85":"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz!#$%&()*+-;<=>?@^_`{|}~"};function I(e){let t;if(typeof e=="string")t=e;else if(t=lt[e.toString()],t==null)throw new Error(`Unknown base ${e}`);if(t.length>=255)throw new TypeError("Alphabet too long");let r=new Uint8Array(256);for(let f=0;f<r.length;f++)r[f]=255;for(let f=0;f<t.length;f++){let d=t.charAt(f),m=d.charCodeAt(0);if(r[m]!==255)throw new TypeError(d+" is ambiguous");r[m]=f}let n=t.length,i=t.charAt(0),s=Math.log(n)/Math.log(256),c=Math.log(256)/Math.log(n);function a(f,d=-1){let m=U(f);if(m.byteLength===0)return"";let L=0,M=0,P=m.byteLength;for(;M!==P&&m[M]===0;)M++;let x=(P-M)*c+1>>>0,y=new Uint8Array(x);for(;M!==P;){let S=m[M],T=0;for(let k=x-1;(S!==0||T<L)&&k!==-1;k--,T++)S+=256*y[k]>>>0,y[k]=S%n>>>0,S=S/n>>>0;if(S!==0)throw ft.warn("Non-zero carry",m,d,T,x),new Error("Non-zero carry");L=T,M++}let g=x-L;for(;g!==x&&y[g]===0;)g++;let E="";for(;g<x;++g)E+=t.charAt(y[g]);return d>0?E.padStart(d,i):E}o(a,"encode");function u(f,d=-1){if(typeof f!="string")throw new TypeError("Expected String");if(f.length===0)return new Uint8Array;f=f.replace(/\s+/gi,"");let m=0,L=0;for(;f[m]===i;)m++;let M=(f.length-m)*s+1>>>0,P=new Uint8Array(M);for(;f[m];){let y=r[f.charCodeAt(m)];if(y===255)throw new Error(`Unsupported character "${f[m]}"`);let g=0;for(let E=M-1;(y!==0||g<L)&&E!==-1;E--,g++)y+=n*P[E]>>>0,P[E]=y%256>>>0,y=y/256>>>0;if(y!==0)throw new Error("Non-zero carry");L=g,m++}let x=M-L;for(;x!==M&&P[x]===0;)x++;return d>0?new Uint8Array([...new Uint8Array(d-P.length+x),...P.slice(x)]):P.slice(x)}return o(u,"decode"),{encode:a,decode:u}}o(I,"useBase");var{encode:wr,decode:Ar}=I(16),{encode:Mr,decode:Pr}=I(32),{encode:Er,decode:Lr}=I(58),{encode:Cr,decode:Ur}=I(62),{encode:kr,decode:Sr}=I(62);var Ir=o(e=>(e.length>0&&(/^[A-Z0-9_\-\ ]*$/g.test(e)&&(e=e.toLowerCase()),e=e.replace(/^[-_\ ]+/gi,"").replace(/[-_\ ]+$/gi,"").replace(/[-_\ ]+([a-z0-9])/gi,(t,r)=>r.toUpperCase()),e=e[0].toLowerCase()+e.substring(1)),e),"toCamelCase");function pt(e){return e.charAt(0).toUpperCase()+e.toLowerCase().slice(1)}o(pt,"toCapitalize");function Or(e){return e.replace(/\w\S*/g,pt)}o(Or,"toCapitalizeWords");function Fr(e,t="-"){return t=typeof t=="undefined"?"_":t,e.replace(/([a-z\d])([A-Z])/g,"$1"+t+"$2").replace(/([A-Z]+)([A-Z][a-z\d]+)/g,"$1"+t+"$2").toLowerCase()}o(Fr,"fromCamelCase");function dt(e,t){var r=[],n=[];return t==null&&(t=o(function(i,s){return r[0]===s?"[Circular ~]":"[Circular ~."+n.slice(0,r.indexOf(s)).join(".")+"]"},"cycleReplacer")),function(i,s){if(r.length>0){var c=r.indexOf(this);~c?r.splice(c+1):r.push(this),~c?n.splice(c,1/0,i):n.push(i),~r.indexOf(s)&&(s=t==null?void 0:t.call(this,i,s))}else r.push(s);return e==null?s:e.call(this,i,s)}}o(dt,"serializer");function le(e,t,r,n){return JSON.stringify(e,dt(t,n),r)}o(le,"jsonStringify");var Se=["1","true","yes","y","on"];function $r(e,t=!1){return e==null||typeof e!="string"?t:Se.includes(String(e).trim().toLowerCase())}o($r,"stringToBoolean");function Br(e,t=0){var r;return e==null||typeof e!="string"?t:(r=parseInt(e.trim(),10))!=null?r:t}o(Br,"stringToInteger");function Nr(e,t=0){var r;return e==null||typeof e!="string"?t:(r=parseFloat(e.trim()))!=null?r:t}o(Nr,"stringToFloat");function mt(e,t=!1){return e==null?t:typeof e=="boolean"?e:typeof e=="number"?e!==0:Se.includes(String(e).trim().toLowerCase())}o(mt,"valueToBoolean");function yt(e,t=0){var r;return e==null?t:typeof e=="boolean"?e?1:0:typeof e=="number"?Math.floor(e):(r=parseInt(String(e).trim(),10))!=null?r:t}o(yt,"valueToInteger");function gt(e,t=0){var r;return e==null?t:typeof e=="boolean"?e?1:0:typeof e=="number"?Math.floor(e):(r=parseFloat(String(e).trim()))!=null?r:t}o(gt,"valueToFloat");function pe(e,t=""){var r;return e==null?t:(r=String(e))!=null?r:t}o(pe,"valueToString");var zr=gt,Hr=yt,Jr=pe,qr=mt;function ht(e,t={}){let{trace:r=!0,pretty:n=!0}=t;return e.map(i=>i&&typeof i=="object"?i instanceof Error?r?`${i.name||"Error"}: ${i.message}
|
|
4
|
+
${i.stack}`:`${i.name||"Error"}: ${i.message}`:n?le(i,null,2):le(i):String(i))}o(ht,"formatMessages");function jr(e,t={}){return ht(e,t).join(" ")}o(jr,"renderMessages");function Wr(e){try{return decodeURIComponent(escape(e))}catch{}return e}o(Wr,"fixBrokenUth8String");var xt={symbol:"$",separator:",",decimal:".",errorOnInvalid:!1,precision:2,pattern:"!#",negativePattern:"-!#",format:At,fromCents:!1},De=o(e=>Math.round(e),"round"),de=o(e=>Math.pow(10,e),"pow"),bt=o((e,t)=>De(e/t)*t,"rounding"),Tt=/(\d)(?=(\d{3})+\b)/g,wt=/(\d)(?=(\d\d)+\d\b)/g;function B(e,t={}){return new O(e,t)}o(B,"currency");var re=class{constructor(t,r={}){var c;let n=Object.assign({},xt,r),i=de((c=n.precision)!=null?c:2),s=te(t,n);this.intValue=s,this.value=s/i,n.increment=n.increment||1/i,n.useVedic?n.groups=wt:n.groups=Tt,this._settings=n,this._precision=i}add(t){let{intValue:r,_settings:n,_precision:i}=this;return B((r+=te(t,n))/(n.fromCents?1:i),n)}subtract(t){let{intValue:r,_settings:n,_precision:i}=this;return B((r-=te(t,n))/(n.fromCents?1:i),n)}multiply(t){let{intValue:r,_settings:n,_precision:i}=this;return B((r*=t)/(n.fromCents?1:de(i)),n)}divide(t){let{intValue:r,_settings:n}=this;return B(r/=te(t,n,!1),n)}distribute(t){let{intValue:r,_precision:n,_settings:i}=this,s=[],c=Math[r>=0?"floor":"ceil"](r/t),a=Math.abs(r-c*t),u=i.fromCents?1:n;for(;t!==0;t--){let f=B(c/u,i);a-- >0&&(f=f[r>=0?"add":"subtract"](1/u)),s.push(f)}return s}dollars(){return~~this.value}cents(){let{intValue:t,_precision:r}=this;return~~(t%r)}format(t){let{_settings:r}=this;return typeof t=="function"?t(this,r):r.format(this,Object.assign({},r,t))}toString(){let{intValue:t,_precision:r,_settings:n}=this;return bt(t/r,n.increment).toFixed(n.precision)}toJSON(){return this.value}static sum(...t){return V(t).reduce((r,n)=>B(r).add(n),this.zero)}static avg(...t){let r=V(t);return r.reduce((n,i)=>B(n).add(i),this.zero).divide(r.length)}},O=re;o(O,"Currency"),O.zero=new re(0),O.one=new re(1);function te(e,t,r=!0){let n=0,{decimal:i,errorOnInvalid:s,precision:c,fromCents:a}=t,u=de(c),f=typeof e=="number";if(e instanceof O&&a)return e.intValue;if(f||e instanceof O)n=e instanceof O?e.value:e;else if(typeof e=="string"){let d=new RegExp("[^-\\d"+i+"]","g"),m=new RegExp("\\"+i,"g");n=e.replace(/\((.*)\)/,"-$1").replace(d,"").replace(m,"."),n=n||0}else{if(s)throw Error("Invalid Input");n=0}return a||(n*=u,n=n.toFixed(4)),r?De(n):n}o(te,"parse");function At(e,t){let{pattern:r,negativePattern:n,symbol:i,separator:s,decimal:c,groups:a}=t,u=(""+e).replace(/^-/,"").split("."),f=u[0],d=u[1];return(e.value>=0?r:n).replace("!",i).replace("#",f.replace(a,"$1"+s)+(d?c+d:""))}o(At,"format");var _=o(e=>Math.abs(e)%1==.5,"isHalf"),Ie=o(e=>e%2==0,"isEven"),_r=o(e=>Math.ceil(e),"roundUp"),Zr=o(e=>Math.floor(e),"roundDown"),Kr=o(e=>Math.round(e),"roundHalfUp"),Yr=o(e=>{let t=Math.round(e);return _(e)&&Ie(t)?t-1:t},"roundHalfOdd"),Xr=o(e=>_(e)?Math.sign(e)*Math.ceil(Math.abs(e)):Math.round(e),"roundHalfAwayFromZero"),en=o(e=>_(e)?Math.floor(e):Math.round(e),"roundHalfDown"),tn=o(e=>{let t=Math.round(e);return _(e)?Ie(t)?t:t-1:t},"roundHalfEven"),rn=o(e=>_(e)?Math.sign(e)*Math.floor(Math.abs(e)):Math.round(e),"roundHalfTowardsZero");var{warn:Oe}=b("zeed:promise");async function sn(e){return new Promise(t=>setTimeout(t,e))}o(sn,"sleep");async function an(){return new Promise(e=>setTimeout(e,0))}o(an,"immediate");var Fe=Symbol("timeout");async function un(e,t,r=Fe){return new Promise(async(n,i)=>{let s=!1,c=setTimeout(()=>{s=!0,n(r)},t);try{let a=await e;clearTimeout(c),s||n(a)}catch(a){clearTimeout(c),s||i(a)}})}o(un,"timeout");var Re=new Error("Timeout reached");function cn(e){return e===Fe||e===Re}o(cn,"isTimeout");async function ve(e,t){return t<=0?await e:new Promise(async(r,n)=>{let i=!1,s=setTimeout(()=>{i=!0,n(Re)},t);try{let c=await e;clearTimeout(s),i||r(c)}catch(c){clearTimeout(s),i||n(c)}})}o(ve,"tryTimeout");function fn(e,t,r=1e3){return new Promise((n,i)=>{let s=o(u=>{a&&(clearTimeout(a),c(),n(u))},"fn"),c=o(()=>{a=null,e.off?e.off(t,s):e.removeEventListener?e.removeEventListener(t,s):Oe("No remove listener method found for",e,t)},"done"),a=setTimeout(()=>{c(),i(new Error("Did not response in time"))},r);e.on?e.on(t,s):e.addEventListener?e.addEventListener(t,s):Oe("No listener method found for",e)})}o(fn,"waitOn");function F(e){return Boolean(e&&(e instanceof Promise||typeof e.then=="function"))}o(F,"isPromise");function N(e){return Promise.resolve(e)}o(N,"promisify");var $e=1e3*60*60*24,w=class{constructor(t){var r;if(typeof t=="number"){this.days=t;return}if(t!=null&&(t=(r=w.from(t))==null?void 0:r.days),t==null){let n=new Date;this.days=n.getFullYear()*1e4+(n.getMonth()+1)*100+n.getDate()}else this.days=t}static fromNumber(t){return new w(t)}static fromString(t){return new w(+t.replace(/[^0-9]/g,""))}static fromDate(t,r=!1){return r?w.fromString(t.toISOString().substr(0,10)):new w(t.getFullYear()*1e4+(t.getMonth()+1)*100+t.getDate())}static fromDateGMT(t){return w.fromDate(t,!0)}static from(t,r=!1){if(typeof t=="number")return new w(t);if(typeof t=="string")return w.fromString(t);if(t instanceof Date)return w.fromDate(t,r);if(t instanceof w)return t}toNumber(){return this.days}toJson(){return this.days}toString(t="-"){let r=String(this.days);return r.slice(0,4)+t+r.slice(4,6)+t+r.slice(6,8)}toDate(t=!1){return t?new Date(`${this.toString()}T00:00:00.000Z`):new Date(this.days/1e4,this.days/100%100-1,this.days%100)}toDateGMT(){return this.toDate(!0)}dayOffset(t){return w.fromDateGMT(new Date(this.toDateGMT().getTime()+t*$e))}daysUntil(t){var r;return Math.round((((r=new w(t))==null?void 0:r.toDateGMT().getTime())-this.toDateGMT().getTime())/$e)}yesterday(){return this.dayOffset(-1)}tomorrow(){return this.dayOffset(1)}};o(w,"Day");async function dn(e,t,r){let n=w.from(e),i=w.from(t);for(;n&&i&&(n==null?void 0:n.days)<=(i==null?void 0:i.days);){let s=r(n);F(s)&&await s,n=n.dayOffset(1)}}o(dn,"forEachDay");function mn(){return new w}o(mn,"today");function yn(e){return new w(e)}o(yn,"day");var Be=o(e=>e.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/'/g,"'").replace(/"/g,"""),"escapeHTML"),hn=o(e=>e.replace(/</gi,"<").replace(/>/gi,">").replace(/"/gi,'"').replace(/'/gi,"'").replace(/&/gi,"&"),"unescapeHTML");function bn(e=.25){return Math.random()<e}o(bn,"randomBoolean");function Tn(e=100,t=0){return t+Math.floor(Math.random()*(e-t))}o(Tn,"randomInt");function wn(e=100,t=0){return t+Math.random()*(e-t)}o(wn,"randomFloat");function An(e,t,r){return Math.max(e,Math.min(r,t))}o(An,"between");var Mt=100,Ne=/[\u0000-\u001F\u0080-\u009F]/g,Pt=/^\.+/,Et=/\.+$/;function ze(){return/[<>:"/\\|?*\u0000-\u001F]/g}o(ze,"filenameReservedRegex");function Lt(){return/^(con|prn|aux|nul|com\d|lpt\d)$/i}o(Lt,"windowsReservedNameRegex");function Pn(e){if(typeof e!="string")throw new TypeError("Expected a string");let t="_";if(ze().test(t)&&Ne.test(t))throw new Error("Replacement string cannot contain reserved filename characters");return e=e.replace(ze(),t).replace(Ne,t).replace(Pt,t).replace(Et,""),e=Lt().test(e)?e+t:e,e.slice(0,Mt)}o(Pn,"toValidFilename");var Ct=/[\\\-\[\]\/{}()*+?.^$|]/g;function Ln(e){return e?e instanceof RegExp?e.source:e.replace(Ct,"\\$&"):""}o(Ln,"escapeRegExp");function He(e){return e.reduce((t,r)=>Math.min(t,r.sort_weight||0),0)-1-Math.random()}o(He,"startSortWeight");function Je(e){return e.reduce((t,r)=>Math.max(t,r.sort_weight||0),0)+1+Math.random()}o(Je,"endSortWeight");function Un(e,t,r){let n=r.length,i=e<t;if(n<=0||e>=n-1)return Je(r);if(e<=0)return He(r);r=Ut([...r]);let s=i?-1:0,c=r[e+s].sort_weight||0,u=(r[e+s+1].sort_weight||0)-c;if(u===0)return i?He(r):Je(r);let f=c+u/2,d=u*.01*(Math.random()-.5);return f+d}o(Un,"moveSortWeight");function Ut(e){return e.sort((t,r)=>(t.sort_weight||0)-(r.sort_weight||0)),e}o(Ut,"sortedItems");var kt=/((?:(?:(?:https?|ftp):)?\/\/)(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z0-9\u00a1-\uffff][a-z0-9\u00a1-\uffff_-]{0,62})?[a-z0-9\u00a1-\uffff]\.)+(?:[a-z\u00a1-\uffff]{2,}\.?))(?::\d{2,5})?(?:[/?#]\S*)?)/gim;function Dn(e){return e.split(kt).map((t,r)=>{let n=Be(t);return r%2?`<a target="_blank" href="${n}">${St(n)}</a>`:n}).join("")}o(Dn,"linkifyPlainText");function St(e){return e.replace(/^https?:\/\/(www\.)?/,"").replace(/\/$/,"")}o(St,"toHumanReadableUrl");function qe(e){let t=[];for(let[r,n]of Object.entries(e))if(n!=null){Array.isArray(n)||(n=[n]);for(let i of n)i!=null&&t.push(encodeURIComponent(r)+"="+encodeURIComponent(i.toString()||""))}return t.join("&")}o(qe,"encodeQuery");function In(e){let t={},r=(e[0]==="?"?e.substr(1):e).split("&");for(let n=0;n<r.length;n++){let i=r[n].split("="),s=decodeURIComponent(i[0]),c=decodeURIComponent(i[1]||"");t[s]!=null?(Array.isArray(t[s])||(t[s]=[t[s]]),t[s].push(c)):t[s]=c}return t}o(In,"parseQuery");function Fn(e){return e!=null?e.size!=null?e.size:e.length!=null?e.length:Object.keys(e).length:0}o(Fn,"size");function Rn(e){return e!=null&&e.length>0?e[e.length-1]:void 0}o(Rn,"last");function vn(e){try{if(e!=null)return Array.isArray(e)||typeof e=="string"?e.length<=0:(e==null?void 0:e.size)!=null?e.size<=0:Object.keys(e).length<=0}catch(t){console.error("Failed to check if empty for",e,t)}return!0}o(vn,"empty");function me(e){return Object(e)!==e?e:JSON.parse(JSON.stringify(e))}o(me,"cloneObject");function $n(e){return Object(e)!==e?e:JSON.parse(JSON.stringify(e))}o($n,"cloneJsonObject");async function Dt(e){typeof e=="function"?await N(e()):F(e)?await e:typeof e.dispose=="function"?await N(e.dispose()):F(e.dispose)?await e.dispose:typeof e.cleanup=="function"?await N(e.cleanup()):F(e.cleanup)&&await e.cleanup}o(Dt,"callDisposer");function Hn(){let e=[],t=o(async i=>{e.includes(i)&&(Ue(e,s=>s!==i),await Dt(i))},"untrack"),r=o(async()=>{for(;e.length>0;)await t(e[0])},"dispose");return Object.assign(r,{track:o(i=>(e.unshift(i),()=>t(i)),"track"),untrack:t,dispose:r,getSize(){return e.length}})}o(Hn,"useDisposer");function Jn(e,t=0){let r=setTimeout(e,t);return()=>{r&&(clearTimeout(r),r=void 0)}}o(Jn,"useTimeout");function qn(e,t){let r=setInterval(e,t);return()=>{r&&(clearInterval(r),r=void 0)}}o(qn,"useInterval");function Gn(e,t,r,...n){return e==null?()=>{}:(e.on?e.on(t,r,...n):e.addEventListener&&e.addEventListener(t,r,...n),()=>{e.off?e.off(t,r,...n):e.removeEventListener&&e.removeEventListener(t,r,...n)})}o(Gn,"useEventListener");function Wn(e=window.location.hostname){return["localhost","127.0.0.1","","::1","::"].includes(e)||e.startsWith("192.168.")||e.startsWith("10.0.")||e.endsWith(".local")}o(Wn,"isLocalHost");var{encode:Ge,decode:It}=I(62),{encode:Ot}=I(32);function je(){return Q(16)}o(je,"uuidBytes");function Z(){return Ge(je(),22)}o(Z,"uuid");function Kn(){return Ot(je(),26)}o(Kn,"uuidB32");var ye={};function z(e="id"){return ye[e]==null&&(ye[e]=0),`${e}-${ye[e]++}`}o(z,"uname");var Ft=0;function Yn(){return`id-${Ft++}`}o(Yn,"qid");var Rt="10000000-1000-4000-8000-100000000000",Xn=o(()=>Rt.replace(/[018]/g,e=>(e^Q(1)[0]&15>>e/4).toString(16)),"uuidv4"),We=16e11;function vt(e){var t=new Uint8Array([0,0,0,0,0,0]);let r=t.length-1;for(var n=0;n<t.length;n++){var i=e&255;t[r-n]=i,e=(e-i)/256}return t}o(vt,"longToByteArray");function $t(){let e=be()-We;return new Uint8Array([...vt(e),...Q(10)])}o($t,"suidBytes");function eo(){return Ge($t(),22)}o(eo,"suid");function to(e){return Bt(It(e,16))}o(to,"suidDate");function Bt(e){return new Date(We+e.slice(0,6).reduce((t,r)=>t*256+r,0))}o(Bt,"suidBytesDate");var H=b("zeed:emitter"),R=class{constructor(){this.subscribers={};this.subscribersOnAny=[];this.call=new Proxy({},{get:(t,r)=>(...n)=>this.emit(r,...n)})}async emit(t,...r){let n=!1;try{let i=this.subscribers[t]||[];if(this.subscribersOnAny.forEach(s=>s(t,...r)),i.length>0){let s=i.map(c=>{try{return N(c(...r))}catch(a){H.warn("emit warning:",a)}});n=!0,await Promise.all(s)}}catch(i){H.error("emit exception",i)}return n}onAny(t){this.subscribersOnAny.push(t)}on(t,r){let n=this.subscribers[t]||[];return n.push(r),this.subscribers[t]=n,()=>{this.off(t,r)}}onCall(t){for(let[r,n]of Object.entries(t))this.on(r,n)}once(t,r){let n=o(async(...i)=>(this.off(t,n),await N(r(...i))),"onceListener");return this.on(t,n),()=>{this.off(t,r)}}off(t,r){return this.subscribers[t]=(this.subscribers[t]||[]).filter(n=>r&&n!==r),this}removeAllListeners(t){return this.subscribers={},this}dispose(){this.subscribers={},this.subscribersOnAny=[]}};o(R,"Emitter");function so(){let e=ie().emitter;return e||(e=new R,ie().emitter=e),e}o(so,"getGlobalEmitter");var ao=new R;function uo(e,t){let r=Math.round(Math.random()*100);var n=[],i;let s=o((a,u)=>{let f={key:a,obj:u};n.push(f),i&&i()},"incoming");return t?e.on?e.on(t,a=>{s(t,a)}):e.addEventListener?e.addEventListener(t,a=>{s(t,a)}):H.error(r,"Cannot listen to key"):e.onAny?e.onAny((a,u)=>{s(a,u)}):H.error(r,"cannot listen to all for",e),o((a,u=!0)=>new Promise((f,d)=>{a||(a=t,a||n.length&&(a=n[0].key)),i=o(()=>{for(;n.length>0;){let m=n.shift();if(m.key===a)i=void 0,f(m.obj);else{if(u){H.warn(r,`Unhandled event ${a} with value: ${m.obj}`);continue}d(`Expected ${a}, but found ${m.key} with value=${m.obj}`),H.error(r,`Unhandled event ${a} with value: ${m.obj}`)}break}},"lazyResolve"),i()}),"on")}o(uo,"lazyListener");var ge=class extends R{constructor(){super(...arguments);this.id=Z()}close(){}};o(ge,"Channel");var ne=class extends ge{constructor(){super(...arguments);this.isConnected=!0}postMessage(t){var r;(r=this.other)==null||r.emit("message",{data:t,origin:"local",lastEventId:Z()})}};o(ne,"LocalChannel");function po(){let e=new ne,t=new ne;return e.other=t,t.other=e,[e,t]}o(po,"fakeWorkerPair");var J=class{async encode(t){return se(t)}async decode(t){return ae(t)}};o(J,"JsonEncoder");var Qe=class{constructor(t){this.key=t}async encode(t){let r=se(t);return await Ee(r,this.key)}async decode(t){let r=await Le(t,this.key);return ae(r)}};o(Qe,"CryptoEncoder");var Ve=o((e,t,r={})=>new Proxy(r,{get:(n,i)=>i in n?n[i]:(...s)=>e(i,s,t)}),"createPromiseProxy");function Po(e={}){let{name:t=z("hub"),encoder:r=new J,retryAfter:n=1e3,ignoreUnhandled:i=!0}=e,s=b(t),c={},a,u=[],f,d={},m=o(()=>{clearTimeout(f)},"dispose"),L=o(async()=>{if(clearTimeout(f),a){if(a.isConnected)for(;u.length;){let y=u[0];try{a.postMessage(await r.encode(y)),u.shift()}catch(g){s.warn("postMessage",g);break}}u.length>0&&n>0&&(f=setTimeout(L,n))}},"postNext"),M=o(async y=>{s("enqueue postMessage",y),u.push(y),await L()},"postMessage"),P=o(async y=>{a=y,a.on("connect",L),a.on("message",async g=>{s("onmessage",typeof g);let{name:E,args:S,id:T,result:k,error:v}=await r.decode(g.data);if(E){s(`name ${E} id ${T}`);try{if(c[E]==null)throw new Error(`handler for ${E} was not found`);let C=c[E](...S);F(C)&&(C=await C),s(`result ${C}`),T&&M({id:T,result:C})}catch(C){let $=C instanceof Error?C:new Error(pe(C));s.warn("execution error",$.name),M({id:T,error:{message:$.message,stack:$.stack,name:$.name}})}}else if(T)if(s(`response for id=${T}: result=${k}, error=${v}`),d[T]==null)k===void 0?s(`skip response for ${T}`):s.warn(`no response hook for ${T}`);else{let[C,$]=d[T];if(C&&$)if(delete d[T],v){let K=new Error(v.message);K.stack=v.stack,K.name=v.name,s.warn("reject",K.name),$(K)}else s("resolve",k),C(k)}else i||s.warn("Unhandled message",g)}),L()},"connect"),x=o(async(y,g,E={})=>{let{timeout:S=5e3}=E,T=Z();return M({name:y,args:g,id:T}),ve(new Promise((k,v)=>d[T]=[k,v]),S)},"fetchMessage");return e.channel&&P(e.channel),{dispose:m,connect:P,listen(y){Object.assign(c,y)},send(){return Ve(x,{},{options(y){return Ve(x,D({},y))}})}}}o(Po,"useMessageHub");var he=class extends R{constructor(t){super();this.publish=this.emit;this.subscribe=this.on;var c;let{name:r,encoder:n=new J,channel:i,debug:s=!1}=t;this.channel=i,this.encoder=n,this.debug=s,this.name=(c=r!=null?r:this.channel.id)!=null?c:z("pubsub"),this.log=b(`${this.shortId}`),this.debug&&(this.channel.on("connect",()=>{this.log("channel connected")}),this.channel.on("disconnect",()=>{this.log("channel disconnected")})),this.channel.on("message",async({data:a})=>{let u=await this.encoder.decode(a);if(this.debug?this.log(`channel message, event=${u==null?void 0:u.event}, info=`,u):this.log(`channel message, event=${u==null?void 0:u.event}`),u){let{event:f,args:d}=u;await this.emitSuper(f,...d)}})}get shortId(){return this.name.substr(0,6)}async emitSuper(t,...r){return await super.emit(t,...r)}async emit(t,...r){try{if(this.debug?this.log(`emit(${t})`,t):this.log(`emit(${t})`,r.length),!this.channel.isConnected)return this.log.warn("channel not connected"),!1;let n=await this.encoder.encode({event:t,args:r});return this.channel.postMessage(n),!0}catch(n){this.log.warn(`emit(${t})`,n)}return!1}};o(he,"PubSub");function Oo(e){return new he(e)}o(Oo,"usePubSub");function Ro(){let e=!0;return(t,r)=>{let n=!1;if(e){e=!1;try{t(),n=!0}finally{e=!0}}else r!==void 0&&r();return n}}o(Ro,"createMutex");var q=b("network"),oe={cache:"no-cache",redirect:"follow"};async function _e(e,t={},r=fetch){try{let n=await r(e,t);if(n.status<400)return n;try{q.warn(`Fetch of ${e} with ${t} returned status=${n.status}`),q.warn(`Response: ${await n.text()}`)}catch(i){q.error("Exception:",i)}}catch(n){q.error("fetchBasic",n)}}o(_e,"fetchBasic");async function No(e,t={},r=fetch){try{let n=await _e(e,D(W(D({method:"GET"},oe),{headers:{}}),t),r);if(n)return await n.json()}catch(n){q.error("fetchJSON error:",n)}}o(No,"fetchJson");function zo(e,t="POST"){return W(D({method:t},oe),{headers:{"Content-Type":"application/x-www-form-urlencoded; charset=utf-8"},body:qe(e)})}o(zo,"fetchOptionsFormURLEncoded");function Ho(e,t="POST"){return W(D({method:t},oe),{headers:{"Content-Type":"application/json; charset=utf-8",Accept:"application/json"},body:JSON.stringify(e)})}o(Ho,"fetchOptionsJson");async function Jo(e,t={},r=fetch){try{let n=await _e(e,D(W(D({method:"GET"},oe),{headers:{}}),t),r);if(n)return await n.text()}catch(n){q.error("fetchHTML error:",n)}}o(Jo,"fetchText");function Ze(){if(typeof window!="undefined")return window}o(Ze,"getWindow");function Nt(){if(typeof navigator!="undefined")return navigator}o(Nt,"getNavigator");function Go(){var e;return((e=Ze())!=null?e:typeof WorkerGlobalScope!="undefined")?self:typeof global!="undefined"?global:Function("return this;")()}o(Go,"getGlobal");var h=Nt(),A=Ze();function zt(e={ios:!1,macos:!1,windows:!1,beaker:!1,electron:!1,wkwebview:!1,pwa:!1,pwaInstalled:!1,browser:!1,node:!1,worker:!1,jest:!1,macosNative:!1,iosNative:!1,appleNative:!1,touch:!1}){var t,r,n,i,s,c,a,u,f;return e.ios=((t=h==null?void 0:h.platform)==null?void 0:t.match(/(iPhone|iPod|iPad)/i))!=null,e.macos=!!((r=h==null?void 0:h.platform)==null?void 0:r.startsWith("Mac")),e.windows=!!((n=h==null?void 0:h.platform)==null?void 0:n.startsWith("Win")),e.beaker=(A==null?void 0:A.beaker)!=null,e.electron=(((s=(i=h==null?void 0:h.userAgent)==null?void 0:i.toLowerCase())==null?void 0:s.indexOf(" electron/"))||-1)>-1&&!e.beaker,e.wkwebview=((c=A==null?void 0:A.webkit)==null?void 0:c.messageHandlers)!=null,e.pwa=(h==null?void 0:h.serviceWorker)!=null,e.pwaInstalled=(h==null?void 0:h.standalone)||((u=(a=A==null?void 0:A.matchMedia)==null?void 0:a.call(A,"(display-mode: standalone)"))==null?void 0:u.matches),e.node=typeof process!="undefined"&&((f=process==null?void 0:process.release)==null?void 0:f.name)==="node",e.browser=!e.electron&&!e.wkwebview&&!e.node,e.worker=typeof WorkerGlobalScope!="undefined"&&self instanceof WorkerGlobalScope,e.jest=typeof jest!="undefined",e.macosNative=e.wkwebview&&e.macos,e.iosNative=e.wkwebview&&e.ios,e.appleNative=e.wkwebview,e.touch=A&&"ontouchstart"in A||((h==null?void 0:h.maxTouchPoints)||0)>1||(h==null?void 0:h.msPointerEnabled)&&(A==null?void 0:A.MSGesture)||(A==null?void 0:A.DocumentTouch)&&document instanceof DocumentTouch,e}o(zt,"detect");var Ht=o(()=>typeof window!="undefined"&&globalThis===window,"isBrowser"),jo=zt();function Wo(e){Ht()?window.addEventListener("beforeunload",e):typeof process!="undefined"&&process.on("exit",()=>e)}o(Wo,"useExitHandler");function Vo(e={}){let{maxParallel:t=3}=e,r=0,n=0,i={};function s(){if(r>=t)return;let a=Object.values(i).filter(u=>!u.running);if(a.length>0){let u;for(let f of a)(u==null||f.priority<u.priority)&&(u=f);u&&(u.running=!0,++r,u.task().then(f=>{(u==null?void 0:u.id)&&delete i[u.id],--r,s()}).catch(f=>{(u==null?void 0:u.id)&&delete i[u.id],--r,s()}))}}o(s,"performNext");function c(a){let u=i[a];u&&u.running!==!0&&delete i[a]}return o(c,"cancel"),{cancel:c,enqueue(a,u){return i[a]==null&&(i[a]={id:a,task:u,priority:++n,running:!1},s()),()=>c(a)}}}o(Vo,"usePool");var Jt=b("zeed:queue"),Ke=class{constructor(t={}){this.queue=[];this.isPaused=!1;this.waitToFinish=[];let{name:r=z("queue"),logLevel:n}=t;this.name=r,this.log=b(`zeed:queue:${r}`),this.log.level=n!=null?n:xe.off}async performNext(){if(this.log("performNext, queue.length =",this.queue.length),this.currentTask!=null){this.log("performNext => skip while another task is running");return}if(this.isPaused){this.log("performNext => skip while is paused");return}for(;this.currentTask==null&&!this.isPaused;){let t=this.queue.shift();if(this.log(`performNext => ${t==null?void 0:t.name}`),t==null)break;let{name:r,task:n,resolve:i}=t;this.currentTask=n();let s;try{this.log.info(`start task ${r}`),s=await this.currentTask,this.log(`finished task ${r} with result =`,s)}catch(c){Jt.warn("Error performing task",c)}i(s),this.currentTask=void 0}for(;this.waitToFinish.length>0;)this.waitToFinish.shift()()}async enqueue(t,r={}){let{immediate:n=!1,name:i=z(this.name)}=r;return n?(this.log.info(`immediate execution ${i}`),await t()):(this.log(`enqueue ${i}`),new Promise(s=>{this.queue.push({name:i,task:t,resolve:s}),this.performNext()}))}async enqueueReentrant(t,r={}){return this.enqueue(t,{immediate:this.currentTask!=null,name:r.name})}async cancelAll(t=!0){this.log("cancelAll");let r=this.queue.map(n=>n.resolve);this.queue=[],r.forEach(n=>n(void 0)),await this.wait()}async pause(){this.log("pause"),this.isPaused=!0,await this.wait()}resume(){this.log("resume"),this.isPaused=!1,this.performNext()}async wait(){if(this.log("wait"),!(this.currentTask==null&&(this.queue.length===0||this.isPaused)))return new Promise(t=>{this.waitToFinish.push(t)})}};o(Ke,"SerialQueue");var ni=b("zeed:memstorage"),Ye=class{constructor(t={}){this.store={}}setItem(t,r){this.store[t]=me(r)}getItem(t){if(this.store.hasOwnProperty(t))return me(this.store[t])}removeItem(t){delete this.store[t]}clear(){this.store={}}allKeys(){return Object.keys(this.store)}};o(Ye,"MemStorage");var G=!1,j=G?b("zeed:throttle"):()=>{};function si(e,t={}){let{delay:r=100,trailing:n=!0,leading:i=!0}=t,s=0,c=0,a=0,u=Date.now();function f(){s&&(clearTimeout(s),s=void 0)}o(f,"clearExistingTimeout");function d(...m){let L=Date.now(),M=this,P=L-c;function x(){let g=Date.now();return`total ${(g-u).toFixed(1)}ms - elapsed ${(g-c).toFixed(1)}ms - visited ${a}x`}o(x,"debugElapsed");function y(){a=0,c=Date.now(),e.apply(M,m)}if(o(y,"exec"),P>r||!s){G&&j("elapsed",x()),i&&(P>r?(G&&j("\u{1F680} leading",x()),y()):++a);let g=P>r?r:r-P;j(`\u23F1 start timeout with ${g.toFixed(1)}ms}`,x()),f(),c=L,s=setTimeout(()=>{G&&j("\u23F1 reached timeout",x()),s=0,n&&(!i||a>0)&&(G&&j("\u{1F680} trailing",x()),y())},g)}else++a,G&&j("visited",x())}return o(d,"wrapper"),d.cancel=f,d.dispose=f,d}o(si,"throttle");export{we as a,Xe as b,U as c,Gt as d,jt as e,Wt as f,Ae as g,se as h,ae as i,Q as j,Zt as k,Kt as l,Ee as m,Le as n,Xt as o,ot as p,tr as q,ce as r,rr as s,fe as t,it as u,st as v,V as w,at as x,ir as y,sr as z,ar as A,Ue as B,ur as C,cr as D,ut as E,fr as F,ct as G,ke as H,lr as I,pr as J,dr as K,mr as L,yr as M,gr as N,I as O,wr as P,Ar as Q,Mr as R,Pr as S,Er as T,Lr as U,Cr as V,Ur as W,kr as X,Sr as Y,Ir as Z,pt as _,Or as $,Fr as aa,le as ba,$r as ca,Br as da,Nr as ea,mt as fa,yt as ga,gt as ha,pe as ia,zr as ja,Hr as ka,Jr as la,qr as ma,ht as na,jr as oa,Wr as pa,B as qa,O as ra,_ as sa,Ie as ta,_r as ua,Zr as va,Kr as wa,Yr as xa,Xr as ya,en as za,tn as Aa,rn as Ba,sn as Ca,an as Da,Fe as Ea,un as Fa,Re as Ga,cn as Ha,ve as Ia,fn as Ja,F as Ka,N as La,$e as Ma,w as Na,dn as Oa,mn as Pa,yn as Qa,Be as Ra,hn as Sa,bn as Ta,Tn as Ua,wn as Va,An as Wa,Pn as Xa,Ln as Ya,He as Za,Je as _a,Un as $a,Ut as ab,Dn as bb,St as cb,qe as db,In as eb,Fn as fb,Rn as gb,vn as hb,me as ib,$n as jb,Dt as kb,Hn as lb,Jn as mb,qn as nb,Gn as ob,Wn as pb,je as qb,Z as rb,Kn as sb,z as tb,Yn as ub,Xn as vb,$t as wb,eo as xb,to as yb,Bt as zb,R as Ab,so as Bb,ao as Cb,uo as Db,ge as Eb,ne as Fb,po as Gb,J as Hb,Qe as Ib,Ve as Jb,Po as Kb,he as Lb,Oo as Mb,Ro as Nb,_e as Ob,No as Pb,zo as Qb,Ho as Rb,Jo as Sb,Ze as Tb,Nt as Ub,Go as Vb,zt as Wb,Ht as Xb,jo as Yb,Wo as Zb,Vo as _b,Ke as $b,Ye as ac,si as bc};
|
|
5
|
+
//# sourceMappingURL=chunk-QHJAXTKB.js.map
|