@drincs/pixi-vn 1.5.13 → 1.5.18
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/README.md +8 -3
- package/dist/canvas.cjs +3 -2
- package/dist/canvas.d.cts +46 -105
- package/dist/canvas.d.ts +46 -105
- package/dist/canvas.mjs +3 -2
- package/dist/characters.cjs +2 -1
- package/dist/characters.mjs +2 -1
- package/dist/chunk-46QBDRUK.mjs +2 -0
- package/dist/chunk-52EK6LYW.mjs +2 -0
- package/dist/chunk-INJYRMJ3.mjs +2 -0
- package/dist/{chunk-TTRUPDAB.mjs → chunk-JJFD2BVW.mjs} +2 -1
- package/dist/chunk-JJFD2BVW.mjs.map +1 -0
- package/dist/chunk-OXRIVLY2.mjs +2 -0
- package/dist/chunk-SOFV7YZ5.mjs +2 -0
- package/dist/chunk-XZMYXKAY.mjs +2 -0
- package/dist/core.cjs +1 -0
- package/dist/core.d.cts +399 -0
- package/dist/core.d.ts +399 -0
- package/dist/core.mjs +1 -0
- package/dist/history.cjs +2 -1
- package/dist/history.d.cts +1 -1
- package/dist/history.d.ts +1 -1
- package/dist/history.mjs +2 -1
- package/dist/index.cjs +3 -2
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +9 -10
- package/dist/index.d.ts +9 -10
- package/dist/index.mjs +3 -2
- package/dist/index.mjs.map +1 -0
- package/dist/motion.cjs +2 -0
- package/dist/motion.cjs.map +1 -0
- package/dist/motion.d.cts +96 -0
- package/dist/motion.d.ts +96 -0
- package/dist/motion.mjs +2 -0
- package/dist/motion.mjs.map +1 -0
- package/dist/narration.cjs +3 -2
- package/dist/narration.mjs +3 -2
- package/dist/pixi/browser.js +170 -167
- package/dist/sound.cjs +2 -1
- package/dist/sound.mjs +2 -1
- package/dist/storage.cjs +2 -1
- package/dist/storage.mjs +2 -1
- package/dist/vite-listener.cjs +2 -1
- package/dist/vite-listener.cjs.map +1 -0
- package/dist/vite-listener.mjs +2 -1
- package/dist/vite-listener.mjs.map +1 -0
- package/dist/vite.cjs +2 -1
- package/dist/vite.cjs.map +1 -0
- package/dist/vite.mjs +2 -1
- package/dist/vite.mjs.map +1 -0
- package/package.json +27 -10
- package/dist/chunk-6GO4XVS7.mjs +0 -1
- package/dist/chunk-6IVCTY6P.mjs +0 -1
- package/dist/chunk-GNJIUFU2.mjs +0 -1
- package/dist/chunk-HVEJJGVC.mjs +0 -1
- package/dist/chunk-XDBHD3IV.mjs +0 -1
- package/dist/chunk-XSN6P5JL.mjs +0 -0
- package/dist/unifier.cjs +0 -1
- package/dist/unifier.mjs +0 -1
package/dist/narration.cjs
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
|
-
'use strict';var unifier=require('@drincs/pixi-vn/unifier');var bt=Object.create;var Ke=Object.defineProperty;var mt=Object.getOwnPropertyDescriptor;var St=Object.getOwnPropertyNames;var gt=Object.getPrototypeOf,yt=Object.prototype.hasOwnProperty;var Ze=h=>{throw TypeError(h)};var _t=(h,e,t)=>e in h?Ke(h,e,{enumerable:true,configurable:true,writable:true,value:t}):h[e]=t;var We=(h=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(h,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):h)(function(h){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+h+'" is not supported')});var et=(h,e)=>()=>(e||h((e={exports:{}}).exports,e),e.exports);var Lt=(h,e,t,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of St(e))!yt.call(h,n)&&n!==t&&Ke(h,n,{get:()=>e[n],enumerable:!(i=mt(e,n))||i.enumerable});return h};var Tt=(h,e,t)=>(t=h!=null?bt(gt(h)):{},Lt(Ke(t,"default",{value:h,enumerable:true}),h));var T=(h,e,t)=>_t(h,typeof e!="symbol"?e+"":e,t),Be=(h,e,t)=>e.has(h)||Ze("Cannot "+t);var r=(h,e,t)=>(Be(h,e,"read from private field"),t?t.call(h):e.get(h)),R=(h,e,t)=>e.has(h)?Ze("Cannot add the same private member more than once"):e instanceof WeakSet?e.add(h):e.set(h,t),S=(h,e,t,i)=>(Be(h,e,"write to private field"),e.set(h,t),t),f=(h,e,t)=>(Be(h,e,"access private method"),t);var Pe=(h,e,t,i)=>({set _(n){S(h,e,n);},get _(){return r(h,e,i)}});var ut=et((Ge,ht)=>{(function(h,e){typeof Ge=="object"?ht.exports=Ge=e():typeof define=="function"&&define.amd?define([],e):h.CryptoJS=e();})(Ge,function(){var h=h||(function(e,t){var i;if(typeof window<"u"&&window.crypto&&(i=window.crypto),typeof self<"u"&&self.crypto&&(i=self.crypto),typeof globalThis<"u"&&globalThis.crypto&&(i=globalThis.crypto),!i&&typeof window<"u"&&window.msCrypto&&(i=window.msCrypto),!i&&typeof global<"u"&&global.crypto&&(i=global.crypto),!i&&typeof We=="function")try{i=We("crypto");}catch{}var n=function(){if(i){if(typeof i.getRandomValues=="function")try{return i.getRandomValues(new Uint32Array(1))[0]}catch{}if(typeof i.randomBytes=="function")try{return i.randomBytes(4).readInt32LE()}catch{}}throw new Error("Native crypto module could not be used to get secure random number.")},a=Object.create||(function(){function o(){}return function(d){var v;return o.prototype=d,v=new o,o.prototype=null,v}})(),s={},l=s.lib={},p=l.Base=(function(){return {extend:function(o){var d=a(this);return o&&d.mixIn(o),(!d.hasOwnProperty("init")||this.init===d.init)&&(d.init=function(){d.$super.init.apply(this,arguments);}),d.init.prototype=d,d.$super=this,d},create:function(){var o=this.extend();return o.init.apply(o,arguments),o},init:function(){},mixIn:function(o){for(var d in o)o.hasOwnProperty(d)&&(this[d]=o[d]);o.hasOwnProperty("toString")&&(this.toString=o.toString);},clone:function(){return this.init.prototype.extend(this)}}})(),y=l.WordArray=p.extend({init:function(o,d){o=this.words=o||[],d!=t?this.sigBytes=d:this.sigBytes=o.length*4;},toString:function(o){return (o||E).stringify(this)},concat:function(o){var d=this.words,v=o.words,I=this.sigBytes,O=o.sigBytes;if(this.clamp(),I%4)for(var U=0;U<O;U++){var oe=v[U>>>2]>>>24-U%4*8&255;d[I+U>>>2]|=oe<<24-(I+U)%4*8;}else for(var z=0;z<O;z+=4)d[I+z>>>2]=v[z>>>2];return this.sigBytes+=O,this},clamp:function(){var o=this.words,d=this.sigBytes;o[d>>>2]&=4294967295<<32-d%4*8,o.length=e.ceil(d/4);},clone:function(){var o=p.clone.call(this);return o.words=this.words.slice(0),o},random:function(o){for(var d=[],v=0;v<o;v+=4)d.push(n());return new y.init(d,o)}}),c=s.enc={},E=c.Hex={stringify:function(o){for(var d=o.words,v=o.sigBytes,I=[],O=0;O<v;O++){var U=d[O>>>2]>>>24-O%4*8&255;I.push((U>>>4).toString(16)),I.push((U&15).toString(16));}return I.join("")},parse:function(o){for(var d=o.length,v=[],I=0;I<d;I+=2)v[I>>>3]|=parseInt(o.substr(I,2),16)<<24-I%8*4;return new y.init(v,d/2)}},N=c.Latin1={stringify:function(o){for(var d=o.words,v=o.sigBytes,I=[],O=0;O<v;O++){var U=d[O>>>2]>>>24-O%4*8&255;I.push(String.fromCharCode(U));}return I.join("")},parse:function(o){for(var d=o.length,v=[],I=0;I<d;I++)v[I>>>2]|=(o.charCodeAt(I)&255)<<24-I%4*8;return new y.init(v,d)}},D=c.Utf8={stringify:function(o){try{return decodeURIComponent(escape(N.stringify(o)))}catch{throw new Error("Malformed UTF-8 data")}},parse:function(o){return N.parse(unescape(encodeURIComponent(o)))}},P=l.BufferedBlockAlgorithm=p.extend({reset:function(){this._data=new y.init,this._nDataBytes=0;},_append:function(o){typeof o=="string"&&(o=D.parse(o)),this._data.concat(o),this._nDataBytes+=o.sigBytes;},_process:function(o){var d,v=this._data,I=v.words,O=v.sigBytes,U=this.blockSize,oe=U*4,z=O/oe;o?z=e.ceil(z):z=e.max((z|0)-this._minBufferSize,0);var J=z*U,_e=e.min(J*4,O);if(J){for(var He=0;He<J;He+=U)this._doProcessBlock(I,He);d=I.splice(0,J),v.sigBytes-=_e;}return new y.init(d,_e)},clone:function(){var o=p.clone.call(this);return o._data=this._data.clone(),o},_minBufferSize:0});l.Hasher=P.extend({cfg:p.extend(),init:function(o){this.cfg=this.cfg.extend(o),this.reset();},reset:function(){P.reset.call(this),this._doReset();},update:function(o){return this._append(o),this._process(),this},finalize:function(o){o&&this._append(o);var d=this._doFinalize();return d},blockSize:512/32,_createHelper:function(o){return function(d,v){return new o.init(v).finalize(d)}},_createHmacHelper:function(o){return function(d,v){return new C.HMAC.init(o,v).finalize(d)}}});var C=s.algo={};return s})(Math);return h});});var dt=et((ze,pt)=>{(function(h,e){typeof ze=="object"?pt.exports=ze=e(ut()):typeof define=="function"&&define.amd?define(["./core"],e):e(h.CryptoJS);})(ze,function(h){return (function(){var e=h,t=e.lib,i=t.WordArray,n=t.Hasher,a=e.algo,s=[],l=a.SHA1=n.extend({_doReset:function(){this._hash=new i.init([1732584193,4023233417,2562383102,271733878,3285377520]);},_doProcessBlock:function(p,y){for(var c=this._hash.words,E=c[0],N=c[1],D=c[2],P=c[3],x=c[4],C=0;C<80;C++){if(C<16)s[C]=p[y+C]|0;else {var o=s[C-3]^s[C-8]^s[C-14]^s[C-16];s[C]=o<<1|o>>>31;}var d=(E<<5|E>>>27)+x+s[C];C<20?d+=(N&D|~N&P)+1518500249:C<40?d+=(N^D^P)+1859775393:C<60?d+=(N&D|N&P|D&P)-1894007588:d+=(N^D^P)-899497514,x=P,P=D,D=N<<30|N>>>2,N=E,E=d;}c[0]=c[0]+E|0,c[1]=c[1]+N|0,c[2]=c[2]+D|0,c[3]=c[3]+P|0,c[4]=c[4]+x|0;},_doFinalize:function(){var p=this._data,y=p.words,c=this._nDataBytes*8,E=p.sigBytes*8;return y[E>>>5]|=128<<24-E%32,y[(E+64>>>9<<4)+14]=Math.floor(c/4294967296),y[(E+64>>>9<<4)+15]=c,p.sigBytes=y.length*4,this._process(),this._hash},clone:function(){var p=n.clone.call(this);return p._hash=this._hash.clone(),p}});e.SHA1=n._createHelper(l),e.HmacSHA1=n._createHmacHelper(l);})(),h.SHA1});});var w={CURRENT_DIALOGUE_MEMORY_KEY:"___current_dialogue_memory___",LAST_DIALOGUE_ADDED_IN_STEP_MEMORY_KEY:"___last_dialogue_added_in_step_memory___",CURRENT_MENU_OPTIONS_MEMORY_KEY:"___current_menu_options_memory___",LAST_MENU_OPTIONS_ADDED_IN_STEP_MEMORY_KEY:"___last_menu_options_added_in_step_memory___",CURRENT_INPUT_VALUE_MEMORY_KEY:"_input_value_",LAST_INPUT_ADDED_IN_STEP_MEMORY_KEY:"___last_input_added_in_step_memory___",CURRENT_INPUT_INFO_MEMORY_KEY:"___current_input_info_memory___",CHARACTER_CATEGORY_KEY:"___character___",ADD_NEXT_DIALOG_TEXT_INTO_THE_CURRENT_DIALOG_FLAG_KEY:"___glue___",OPENED_LABELS_COUNTER_KEY:"___opened_labels_counter___",ALL_CHOICES_MADE_KEY:"___all_choices_made___",CURRENT_STEP_TIMES_COUNTER_KEY:"___current_step_times_counter___",LAST_STEP_GLUED:"___last_step_glued___"};var _;(n=>(n.log=(a,...s)=>console.log(`[Pixi\u2019VN] ${a}`,...s),n.warn=(a,...s)=>console.warn(`[Pixi\u2019VN] ${a}`,...s),n.error=(a,...s)=>console.error(`[Pixi\u2019VN] ${a}`,...s),n.info=(a,...s)=>console.info(`[Pixi\u2019VN] ${a}`,...s)))(_||(_={}));function le(h){try{if(typeof h>"u")return h;let e=JSON.stringify(h);return JSON.parse(e)}catch(e){throw _.error("Error creating exportable element",h,e),new Error("[Pixi\u2019VN] Error creating exportable element")}}var Et=typeof performance=="object"&&performance&&typeof performance.now=="function"?performance:Date,nt=new Set,je=typeof process=="object"&&process?process:{},st=(h,e,t,i)=>{typeof je.emitWarning=="function"?je.emitWarning(h,e,t,i):console.error(`[${t}] ${e}: ${h}`);},Ve=globalThis.AbortController,tt=globalThis.AbortSignal;if(typeof Ve>"u"){tt=class{constructor(){T(this,"onabort");T(this,"_onabort",[]);T(this,"reason");T(this,"aborted",false);}addEventListener(t,i){this._onabort.push(i);}},Ve=class{constructor(){T(this,"signal",new tt);e();}abort(t){if(!this.signal.aborted){this.signal.reason=t,this.signal.aborted=true;for(let i of this.signal._onabort)i(t);this.signal.onabort?.(t);}}};let h=je.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",e=()=>{h&&(h=false,st("AbortController is not defined. If using lru-cache in node 14, load an AbortController polyfill from the `node-abort-controller` package. A minimal polyfill is provided for use by LRUCache.fetch(), but it should not be relied upon in other contexts (eg, passing it to other APIs that use AbortController/AbortSignal might have undesirable effects). You may disable this with LRU_CACHE_IGNORE_AC_WARNING=1 in the env.","NO_ABORT_CONTROLLER","ENOTSUP",e));};}var Ct=h=>!nt.has(h);var de=h=>h&&h===Math.floor(h)&&h>0&&isFinite(h),at=h=>de(h)?h<=Math.pow(2,8)?Uint8Array:h<=Math.pow(2,16)?Uint16Array:h<=Math.pow(2,32)?Uint32Array:h<=Number.MAX_SAFE_INTEGER?Ue:null:null,Ue=class extends Array{constructor(h){super(h),this.fill(0);}},he,Le,It=(he=class{constructor(e,t){T(this,"heap");T(this,"length");if(!r(he,Le))throw new TypeError("instantiate Stack using Stack.create(n)");this.heap=new t(e),this.length=0;}static create(e){let t=at(e);if(!t)return [];S(he,Le,true);let i=new he(e,t);return S(he,Le,false),i}push(e){this.heap[this.length++]=e;}pop(){return this.heap[--this.length]}},Le=new WeakMap,R(he,Le,false),he),rt,it,X,B,Q,Se,Z,Te,Ee,ee,F,te,Y,M,L,K,j,H,V,re,G,ie,ne,k,$,se,me,W,Ce,u,ke,ge,ue,Me,q,lt,ye,Ie,Ne,ce,fe,$e,Ye,Fe,A,qe,Ae,be,Xe,ve,ot=(ve=class{constructor(e){R(this,u);R(this,X);R(this,B);R(this,Q);R(this,Se);R(this,Z);R(this,Te);R(this,Ee);R(this,ee);T(this,"ttl");T(this,"ttlResolution");T(this,"ttlAutopurge");T(this,"updateAgeOnGet");T(this,"updateAgeOnHas");T(this,"allowStale");T(this,"noDisposeOnSet");T(this,"noUpdateTTL");T(this,"maxEntrySize");T(this,"sizeCalculation");T(this,"noDeleteOnFetchRejection");T(this,"noDeleteOnStaleGet");T(this,"allowStaleOnFetchAbort");T(this,"allowStaleOnFetchRejection");T(this,"ignoreFetchAbort");R(this,F);R(this,te);R(this,Y);R(this,M);R(this,L);R(this,K);R(this,j);R(this,H);R(this,V);R(this,re);R(this,G);R(this,ie);R(this,ne);R(this,k);R(this,$);R(this,se);R(this,me);R(this,W);R(this,Ce);R(this,ge,()=>{});R(this,ue,()=>{});R(this,Me,()=>{});R(this,q,()=>false);R(this,ye,e=>{});R(this,Ie,(e,t,i)=>{});R(this,Ne,(e,t,i,n)=>{if(i||n)throw new TypeError("cannot set size without setting maxSize or maxEntrySize on cache");return 0});T(this,rt,"LRUCache");let{max:t=0,ttl:i,ttlResolution:n=1,ttlAutopurge:a,updateAgeOnGet:s,updateAgeOnHas:l,allowStale:p,dispose:y,onInsert:c,disposeAfter:E,noDisposeOnSet:N,noUpdateTTL:D,maxSize:P=0,maxEntrySize:x=0,sizeCalculation:C,fetchMethod:o,memoMethod:d,noDeleteOnFetchRejection:v,noDeleteOnStaleGet:I,allowStaleOnFetchRejection:O,allowStaleOnFetchAbort:U,ignoreFetchAbort:oe,perf:z}=e;if(z!==void 0&&typeof z?.now!="function")throw new TypeError("perf option must have a now() method if specified");if(S(this,ee,z??Et),t!==0&&!de(t))throw new TypeError("max option must be a nonnegative integer");let J=t?at(t):Array;if(!J)throw new Error("invalid max value: "+t);if(S(this,X,t),S(this,B,P),this.maxEntrySize=x||r(this,B),this.sizeCalculation=C,this.sizeCalculation){if(!r(this,B)&&!this.maxEntrySize)throw new TypeError("cannot set sizeCalculation without setting maxSize or maxEntrySize");if(typeof this.sizeCalculation!="function")throw new TypeError("sizeCalculation set to non-function")}if(d!==void 0&&typeof d!="function")throw new TypeError("memoMethod must be a function if defined");if(S(this,Ee,d),o!==void 0&&typeof o!="function")throw new TypeError("fetchMethod must be a function if specified");if(S(this,Te,o),S(this,me,!!o),S(this,Y,new Map),S(this,M,new Array(t).fill(void 0)),S(this,L,new Array(t).fill(void 0)),S(this,K,new J(t)),S(this,j,new J(t)),S(this,H,0),S(this,V,0),S(this,re,It.create(t)),S(this,F,0),S(this,te,0),typeof y=="function"&&S(this,Q,y),typeof c=="function"&&S(this,Se,c),typeof E=="function"?(S(this,Z,E),S(this,G,[])):(S(this,Z,void 0),S(this,G,void 0)),S(this,se,!!r(this,Q)),S(this,Ce,!!r(this,Se)),S(this,W,!!r(this,Z)),this.noDisposeOnSet=!!N,this.noUpdateTTL=!!D,this.noDeleteOnFetchRejection=!!v,this.allowStaleOnFetchRejection=!!O,this.allowStaleOnFetchAbort=!!U,this.ignoreFetchAbort=!!oe,this.maxEntrySize!==0){if(r(this,B)!==0&&!de(r(this,B)))throw new TypeError("maxSize must be a positive integer if specified");if(!de(this.maxEntrySize))throw new TypeError("maxEntrySize must be a positive integer if specified");f(this,u,lt).call(this);}if(this.allowStale=!!p,this.noDeleteOnStaleGet=!!I,this.updateAgeOnGet=!!s,this.updateAgeOnHas=!!l,this.ttlResolution=de(n)||n===0?n:1,this.ttlAutopurge=!!a,this.ttl=i||0,this.ttl){if(!de(this.ttl))throw new TypeError("ttl must be a positive integer if specified");f(this,u,ke).call(this);}if(r(this,X)===0&&this.ttl===0&&r(this,B)===0)throw new TypeError("At least one of max, maxSize, or ttl is required");if(!this.ttlAutopurge&&!r(this,X)&&!r(this,B)){let _e="LRU_CACHE_UNBOUNDED";Ct(_e)&&(nt.add(_e),st("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning",_e,ve));}}get perf(){return r(this,ee)}static unsafeExposeInternals(e){return {starts:r(e,ne),ttls:r(e,k),autopurgeTimers:r(e,$),sizes:r(e,ie),keyMap:r(e,Y),keyList:r(e,M),valList:r(e,L),next:r(e,K),prev:r(e,j),get head(){return r(e,H)},get tail(){return r(e,V)},free:r(e,re),isBackgroundFetch:t=>{var i;return f(i=e,u,A).call(i,t)},backgroundFetch:(t,i,n,a)=>{var s;return f(s=e,u,Fe).call(s,t,i,n,a)},moveToTail:t=>{var i;return f(i=e,u,Ae).call(i,t)},indexes:t=>{var i;return f(i=e,u,ce).call(i,t)},rindexes:t=>{var i;return f(i=e,u,fe).call(i,t)},isStale:t=>{var i;return r(i=e,q).call(i,t)}}}get max(){return r(this,X)}get maxSize(){return r(this,B)}get calculatedSize(){return r(this,te)}get size(){return r(this,F)}get fetchMethod(){return r(this,Te)}get memoMethod(){return r(this,Ee)}get dispose(){return r(this,Q)}get onInsert(){return r(this,Se)}get disposeAfter(){return r(this,Z)}getRemainingTTL(e){return r(this,Y).has(e)?1/0:0}*entries(){for(let e of f(this,u,ce).call(this))r(this,L)[e]!==void 0&&r(this,M)[e]!==void 0&&!f(this,u,A).call(this,r(this,L)[e])&&(yield [r(this,M)[e],r(this,L)[e]]);}*rentries(){for(let e of f(this,u,fe).call(this))r(this,L)[e]!==void 0&&r(this,M)[e]!==void 0&&!f(this,u,A).call(this,r(this,L)[e])&&(yield [r(this,M)[e],r(this,L)[e]]);}*keys(){for(let e of f(this,u,ce).call(this)){let t=r(this,M)[e];t!==void 0&&!f(this,u,A).call(this,r(this,L)[e])&&(yield t);}}*rkeys(){for(let e of f(this,u,fe).call(this)){let t=r(this,M)[e];t!==void 0&&!f(this,u,A).call(this,r(this,L)[e])&&(yield t);}}*values(){for(let e of f(this,u,ce).call(this))r(this,L)[e]!==void 0&&!f(this,u,A).call(this,r(this,L)[e])&&(yield r(this,L)[e]);}*rvalues(){for(let e of f(this,u,fe).call(this))r(this,L)[e]!==void 0&&!f(this,u,A).call(this,r(this,L)[e])&&(yield r(this,L)[e]);}[(it=Symbol.iterator,rt=Symbol.toStringTag,it)](){return this.entries()}find(e,t={}){for(let i of f(this,u,ce).call(this)){let n=r(this,L)[i],a=f(this,u,A).call(this,n)?n.__staleWhileFetching:n;if(a!==void 0&&e(a,r(this,M)[i],this))return this.get(r(this,M)[i],t)}}forEach(e,t=this){for(let i of f(this,u,ce).call(this)){let n=r(this,L)[i],a=f(this,u,A).call(this,n)?n.__staleWhileFetching:n;a!==void 0&&e.call(t,a,r(this,M)[i],this);}}rforEach(e,t=this){for(let i of f(this,u,fe).call(this)){let n=r(this,L)[i],a=f(this,u,A).call(this,n)?n.__staleWhileFetching:n;a!==void 0&&e.call(t,a,r(this,M)[i],this);}}purgeStale(){let e=false;for(let t of f(this,u,fe).call(this,{allowStale:true}))r(this,q).call(this,t)&&(f(this,u,be).call(this,r(this,M)[t],"expire"),e=true);return e}info(e){let t=r(this,Y).get(e);if(t===void 0)return;let i=r(this,L)[t],n=f(this,u,A).call(this,i)?i.__staleWhileFetching:i;if(n===void 0)return;let a={value:n};if(r(this,k)&&r(this,ne)){let s=r(this,k)[t],l=r(this,ne)[t];if(s&&l){let p=s-(r(this,ee).now()-l);a.ttl=p,a.start=Date.now();}}return r(this,ie)&&(a.size=r(this,ie)[t]),a}dump(){let e=[];for(let t of f(this,u,ce).call(this,{allowStale:true})){let i=r(this,M)[t],n=r(this,L)[t],a=f(this,u,A).call(this,n)?n.__staleWhileFetching:n;if(a===void 0||i===void 0)continue;let s={value:a};if(r(this,k)&&r(this,ne)){s.ttl=r(this,k)[t];let l=r(this,ee).now()-r(this,ne)[t];s.start=Math.floor(Date.now()-l);}r(this,ie)&&(s.size=r(this,ie)[t]),e.unshift([i,s]);}return e}load(e){this.clear();for(let[t,i]of e){if(i.start){let n=Date.now()-i.start;i.start=r(this,ee).now()-n;}this.set(t,i.value,i);}}set(e,t,i={}){var N,D,P,x;if(t===void 0)return this.delete(e),this;let{ttl:n=this.ttl,start:a,noDisposeOnSet:s=this.noDisposeOnSet,sizeCalculation:l=this.sizeCalculation,status:p}=i,{noUpdateTTL:y=this.noUpdateTTL}=i,c=r(this,Ne).call(this,e,t,i.size||0,l);if(this.maxEntrySize&&c>this.maxEntrySize)return p&&(p.set="miss",p.maxEntrySizeExceeded=true),f(this,u,be).call(this,e,"set"),this;let E=r(this,F)===0?void 0:r(this,Y).get(e);if(E===void 0)E=r(this,F)===0?r(this,V):r(this,re).length!==0?r(this,re).pop():r(this,F)===r(this,X)?f(this,u,Ye).call(this,false):r(this,F),r(this,M)[E]=e,r(this,L)[E]=t,r(this,Y).set(e,E),r(this,K)[r(this,V)]=E,r(this,j)[E]=r(this,V),S(this,V,E),Pe(this,F)._++,r(this,Ie).call(this,E,c,p),p&&(p.set="add"),y=false,r(this,Ce)&&((N=r(this,Se))==null||N.call(this,t,e,"add"));else {f(this,u,Ae).call(this,E);let C=r(this,L)[E];if(t!==C){if(r(this,me)&&f(this,u,A).call(this,C)){C.__abortController.abort(new Error("replaced"));let{__staleWhileFetching:o}=C;o!==void 0&&!s&&(r(this,se)&&((D=r(this,Q))==null||D.call(this,o,e,"set")),r(this,W)&&r(this,G)?.push([o,e,"set"]));}else s||(r(this,se)&&((P=r(this,Q))==null||P.call(this,C,e,"set")),r(this,W)&&r(this,G)?.push([C,e,"set"]));if(r(this,ye).call(this,E),r(this,Ie).call(this,E,c,p),r(this,L)[E]=t,p){p.set="replace";let o=C&&f(this,u,A).call(this,C)?C.__staleWhileFetching:C;o!==void 0&&(p.oldValue=o);}}else p&&(p.set="update");r(this,Ce)&&this.onInsert?.(t,e,t===C?"update":"replace");}if(n!==0&&!r(this,k)&&f(this,u,ke).call(this),r(this,k)&&(y||r(this,Me).call(this,E,n,a),p&&r(this,ue).call(this,p,E)),!s&&r(this,W)&&r(this,G)){let C=r(this,G),o;for(;o=C?.shift();)(x=r(this,Z))==null||x.call(this,...o);}return this}pop(){var e;try{for(;r(this,F);){let t=r(this,L)[r(this,H)];if(f(this,u,Ye).call(this,!0),f(this,u,A).call(this,t)){if(t.__staleWhileFetching)return t.__staleWhileFetching}else if(t!==void 0)return t}}finally{if(r(this,W)&&r(this,G)){let t=r(this,G),i;for(;i=t?.shift();)(e=r(this,Z))==null||e.call(this,...i);}}}has(e,t={}){let{updateAgeOnHas:i=this.updateAgeOnHas,status:n}=t,a=r(this,Y).get(e);if(a!==void 0){let s=r(this,L)[a];if(f(this,u,A).call(this,s)&&s.__staleWhileFetching===void 0)return false;if(r(this,q).call(this,a))n&&(n.has="stale",r(this,ue).call(this,n,a));else return i&&r(this,ge).call(this,a),n&&(n.has="hit",r(this,ue).call(this,n,a)),true}else n&&(n.has="miss");return false}peek(e,t={}){let{allowStale:i=this.allowStale}=t,n=r(this,Y).get(e);if(n===void 0||!i&&r(this,q).call(this,n))return;let a=r(this,L)[n];return f(this,u,A).call(this,a)?a.__staleWhileFetching:a}async fetch(e,t={}){let{allowStale:i=this.allowStale,updateAgeOnGet:n=this.updateAgeOnGet,noDeleteOnStaleGet:a=this.noDeleteOnStaleGet,ttl:s=this.ttl,noDisposeOnSet:l=this.noDisposeOnSet,size:p=0,sizeCalculation:y=this.sizeCalculation,noUpdateTTL:c=this.noUpdateTTL,noDeleteOnFetchRejection:E=this.noDeleteOnFetchRejection,allowStaleOnFetchRejection:N=this.allowStaleOnFetchRejection,ignoreFetchAbort:D=this.ignoreFetchAbort,allowStaleOnFetchAbort:P=this.allowStaleOnFetchAbort,context:x,forceRefresh:C=false,status:o,signal:d}=t;if(!r(this,me))return o&&(o.fetch="get"),this.get(e,{allowStale:i,updateAgeOnGet:n,noDeleteOnStaleGet:a,status:o});let v={allowStale:i,updateAgeOnGet:n,noDeleteOnStaleGet:a,ttl:s,noDisposeOnSet:l,size:p,sizeCalculation:y,noUpdateTTL:c,noDeleteOnFetchRejection:E,allowStaleOnFetchRejection:N,allowStaleOnFetchAbort:P,ignoreFetchAbort:D,status:o,signal:d},I=r(this,Y).get(e);if(I===void 0){o&&(o.fetch="miss");let O=f(this,u,Fe).call(this,e,I,v,x);return O.__returned=O}else {let O=r(this,L)[I];if(f(this,u,A).call(this,O)){let J=i&&O.__staleWhileFetching!==void 0;return o&&(o.fetch="inflight",J&&(o.returnedStale=true)),J?O.__staleWhileFetching:O.__returned=O}let U=r(this,q).call(this,I);if(!C&&!U)return o&&(o.fetch="hit"),f(this,u,Ae).call(this,I),n&&r(this,ge).call(this,I),o&&r(this,ue).call(this,o,I),O;let oe=f(this,u,Fe).call(this,e,I,v,x),z=oe.__staleWhileFetching!==void 0&&i;return o&&(o.fetch=U?"stale":"refresh",z&&U&&(o.returnedStale=true)),z?oe.__staleWhileFetching:oe.__returned=oe}}async forceFetch(e,t={}){let i=await this.fetch(e,t);if(i===void 0)throw new Error("fetch() returned undefined");return i}memo(e,t={}){let i=r(this,Ee);if(!i)throw new Error("no memoMethod provided to constructor");let{context:n,forceRefresh:a,...s}=t,l=this.get(e,s);if(!a&&l!==void 0)return l;let p=i(e,l,{options:s,context:n});return this.set(e,p,s),p}get(e,t={}){let{allowStale:i=this.allowStale,updateAgeOnGet:n=this.updateAgeOnGet,noDeleteOnStaleGet:a=this.noDeleteOnStaleGet,status:s}=t,l=r(this,Y).get(e);if(l!==void 0){let p=r(this,L)[l],y=f(this,u,A).call(this,p);return s&&r(this,ue).call(this,s,l),r(this,q).call(this,l)?(s&&(s.get="stale"),y?(s&&i&&p.__staleWhileFetching!==void 0&&(s.returnedStale=true),i?p.__staleWhileFetching:void 0):(a||f(this,u,be).call(this,e,"expire"),s&&i&&(s.returnedStale=true),i?p:void 0)):(s&&(s.get="hit"),y?p.__staleWhileFetching:(f(this,u,Ae).call(this,l),n&&r(this,ge).call(this,l),p))}else s&&(s.get="miss");}delete(e){return f(this,u,be).call(this,e,"delete")}clear(){return f(this,u,Xe).call(this,"delete")}},X=new WeakMap,B=new WeakMap,Q=new WeakMap,Se=new WeakMap,Z=new WeakMap,Te=new WeakMap,Ee=new WeakMap,ee=new WeakMap,F=new WeakMap,te=new WeakMap,Y=new WeakMap,M=new WeakMap,L=new WeakMap,K=new WeakMap,j=new WeakMap,H=new WeakMap,V=new WeakMap,re=new WeakMap,G=new WeakMap,ie=new WeakMap,ne=new WeakMap,k=new WeakMap,$=new WeakMap,se=new WeakMap,me=new WeakMap,W=new WeakMap,Ce=new WeakMap,u=new WeakSet,ke=function(){let e=new Ue(r(this,X)),t=new Ue(r(this,X));S(this,k,e),S(this,ne,t);let i=this.ttlAutopurge?new Array(r(this,X)):void 0;S(this,$,i),S(this,Me,(s,l,p=r(this,ee).now())=>{if(t[s]=l!==0?p:0,e[s]=l,i?.[s]&&(clearTimeout(i[s]),i[s]=void 0),l!==0&&i){let y=setTimeout(()=>{r(this,q).call(this,s)&&f(this,u,be).call(this,r(this,M)[s],"expire");},l+1);y.unref&&y.unref(),i[s]=y;}}),S(this,ge,s=>{t[s]=e[s]!==0?r(this,ee).now():0;}),S(this,ue,(s,l)=>{if(e[l]){let p=e[l],y=t[l];if(!p||!y)return;s.ttl=p,s.start=y,s.now=n||a();let c=s.now-y;s.remainingTTL=p-c;}});let n=0,a=()=>{let s=r(this,ee).now();if(this.ttlResolution>0){n=s;let l=setTimeout(()=>n=0,this.ttlResolution);l.unref&&l.unref();}return s};this.getRemainingTTL=s=>{let l=r(this,Y).get(s);if(l===void 0)return 0;let p=e[l],y=t[l];if(!p||!y)return 1/0;let c=(n||a())-y;return p-c},S(this,q,s=>{let l=t[s],p=e[s];return !!p&&!!l&&(n||a())-l>p});},ge=new WeakMap,ue=new WeakMap,Me=new WeakMap,q=new WeakMap,lt=function(){let e=new Ue(r(this,X));S(this,te,0),S(this,ie,e),S(this,ye,t=>{S(this,te,r(this,te)-e[t]),e[t]=0;}),S(this,Ne,(t,i,n,a)=>{if(f(this,u,A).call(this,i))return 0;if(!de(n))if(a){if(typeof a!="function")throw new TypeError("sizeCalculation must be a function");if(n=a(i,t),!de(n))throw new TypeError("sizeCalculation return invalid (expect positive integer)")}else throw new TypeError("invalid size value (must be positive integer). When maxSize or maxEntrySize is used, sizeCalculation or size must be set.");return n}),S(this,Ie,(t,i,n)=>{if(e[t]=i,r(this,B)){let a=r(this,B)-e[t];for(;r(this,te)>a;)f(this,u,Ye).call(this,true);}S(this,te,r(this,te)+e[t]),n&&(n.entrySize=i,n.totalCalculatedSize=r(this,te));});},ye=new WeakMap,Ie=new WeakMap,Ne=new WeakMap,ce=function*({allowStale:e=this.allowStale}={}){if(r(this,F))for(let t=r(this,V);!(!f(this,u,$e).call(this,t)||((e||!r(this,q).call(this,t))&&(yield t),t===r(this,H)));)t=r(this,j)[t];},fe=function*({allowStale:e=this.allowStale}={}){if(r(this,F))for(let t=r(this,H);!(!f(this,u,$e).call(this,t)||((e||!r(this,q).call(this,t))&&(yield t),t===r(this,V)));)t=r(this,K)[t];},$e=function(e){return e!==void 0&&r(this,Y).get(r(this,M)[e])===e},Ye=function(e){var a;let t=r(this,H),i=r(this,M)[t],n=r(this,L)[t];return r(this,me)&&f(this,u,A).call(this,n)?n.__abortController.abort(new Error("evicted")):(r(this,se)||r(this,W))&&(r(this,se)&&((a=r(this,Q))==null||a.call(this,n,i,"evict")),r(this,W)&&r(this,G)?.push([n,i,"evict"])),r(this,ye).call(this,t),r(this,$)?.[t]&&(clearTimeout(r(this,$)[t]),r(this,$)[t]=void 0),e&&(r(this,M)[t]=void 0,r(this,L)[t]=void 0,r(this,re).push(t)),r(this,F)===1?(S(this,H,S(this,V,0)),r(this,re).length=0):S(this,H,r(this,K)[t]),r(this,Y).delete(i),Pe(this,F)._--,t},Fe=function(e,t,i,n){let a=t===void 0?void 0:r(this,L)[t];if(f(this,u,A).call(this,a))return a;let s=new Ve,{signal:l}=i;l?.addEventListener("abort",()=>s.abort(l.reason),{signal:s.signal});let p={signal:s.signal,options:i,context:n},y=(x,C=false)=>{let{aborted:o}=s.signal,d=i.ignoreFetchAbort&&x!==void 0,v=i.ignoreFetchAbort||!!(i.allowStaleOnFetchAbort&&x!==void 0);if(i.status&&(o&&!C?(i.status.fetchAborted=true,i.status.fetchError=s.signal.reason,d&&(i.status.fetchAbortIgnored=true)):i.status.fetchResolved=true),o&&!d&&!C)return E(s.signal.reason,v);let I=D,O=r(this,L)[t];return (O===D||d&&C&&O===void 0)&&(x===void 0?I.__staleWhileFetching!==void 0?r(this,L)[t]=I.__staleWhileFetching:f(this,u,be).call(this,e,"fetch"):(i.status&&(i.status.fetchUpdated=true),this.set(e,x,p.options))),x},c=x=>(i.status&&(i.status.fetchRejected=true,i.status.fetchError=x),E(x,false)),E=(x,C)=>{let{aborted:o}=s.signal,d=o&&i.allowStaleOnFetchAbort,v=d||i.allowStaleOnFetchRejection,I=v||i.noDeleteOnFetchRejection,O=D;if(r(this,L)[t]===D&&(!I||!C&&O.__staleWhileFetching===void 0?f(this,u,be).call(this,e,"fetch"):d||(r(this,L)[t]=O.__staleWhileFetching)),v)return i.status&&O.__staleWhileFetching!==void 0&&(i.status.returnedStale=true),O.__staleWhileFetching;if(O.__returned===O)throw x},N=(x,C)=>{var d;let o=(d=r(this,Te))==null?void 0:d.call(this,e,a,p);o&&o instanceof Promise&&o.then(v=>x(v===void 0?void 0:v),C),s.signal.addEventListener("abort",()=>{(!i.ignoreFetchAbort||i.allowStaleOnFetchAbort)&&(x(void 0),i.allowStaleOnFetchAbort&&(x=v=>y(v,true)));});};i.status&&(i.status.fetchDispatched=true);let D=new Promise(N).then(y,c),P=Object.assign(D,{__abortController:s,__staleWhileFetching:a,__returned:void 0});return t===void 0?(this.set(e,P,{...p.options,status:void 0}),t=r(this,Y).get(e)):r(this,L)[t]=P,P},A=function(e){if(!r(this,me))return false;let t=e;return !!t&&t instanceof Promise&&t.hasOwnProperty("__staleWhileFetching")&&t.__abortController instanceof Ve},qe=function(e,t){r(this,j)[t]=e,r(this,K)[e]=t;},Ae=function(e){e!==r(this,V)&&(e===r(this,H)?S(this,H,r(this,K)[e]):f(this,u,qe).call(this,r(this,j)[e],r(this,K)[e]),f(this,u,qe).call(this,r(this,V),e),S(this,V,e));},be=function(e,t){var n,a;let i=false;if(r(this,F)!==0){let s=r(this,Y).get(e);if(s!==void 0)if(r(this,$)?.[s]&&(clearTimeout(r(this,$)?.[s]),r(this,$)[s]=void 0),i=true,r(this,F)===1)f(this,u,Xe).call(this,t);else {r(this,ye).call(this,s);let l=r(this,L)[s];if(f(this,u,A).call(this,l)?l.__abortController.abort(new Error("deleted")):(r(this,se)||r(this,W))&&(r(this,se)&&((n=r(this,Q))==null||n.call(this,l,e,t)),r(this,W)&&r(this,G)?.push([l,e,t])),r(this,Y).delete(e),r(this,M)[s]=void 0,r(this,L)[s]=void 0,s===r(this,V))S(this,V,r(this,j)[s]);else if(s===r(this,H))S(this,H,r(this,K)[s]);else {let p=r(this,j)[s];r(this,K)[p]=r(this,K)[s];let y=r(this,K)[s];r(this,j)[y]=r(this,j)[s];}Pe(this,F)._--,r(this,re).push(s);}}if(r(this,W)&&r(this,G)?.length){let s=r(this,G),l;for(;l=s?.shift();)(a=r(this,Z))==null||a.call(this,...l);}return i},Xe=function(e){var t,i;for(let n of f(this,u,fe).call(this,{allowStale:true})){let a=r(this,L)[n];if(f(this,u,A).call(this,a))a.__abortController.abort(new Error("deleted"));else {let s=r(this,M)[n];r(this,se)&&((t=r(this,Q))==null||t.call(this,a,s,e)),r(this,W)&&r(this,G)?.push([a,s,e]);}}if(r(this,Y).clear(),r(this,L).fill(void 0),r(this,M).fill(void 0),r(this,k)&&r(this,ne)){r(this,k).fill(0),r(this,ne).fill(0);for(let n of r(this,$)??[])n!==void 0&&clearTimeout(n);r(this,$)?.fill(void 0);}if(r(this,ie)&&r(this,ie).fill(0),S(this,H,0),S(this,V,0),r(this,re).length=0,S(this,te,0),S(this,F,0),r(this,W)&&r(this,G)){let n=r(this,G),a;for(;a=n?.shift();)(i=r(this,Z))==null||i.call(this,...a);}},ve);var we=class{constructor(e){T(this,"cache");T(this,"map",new Map);this.cache=new ot({max:e.cacheSize}),this.map=new Map;}get[Symbol.iterator](){return this.map[Symbol.iterator]}get[Symbol.toStringTag](){return this.map[Symbol.toStringTag]}clear(){return this.cache.clear(),this.map.clear()}delete(e){let t=this.map.delete(e);return t&&this.cache.delete(e),t}get forEach(){return this.map.forEach}get(e){let t=this.cache.get(e);return t||this.map.get(e)}has(e){return this.map.has(e)}set(e,t){return this.map.set(e,t),this.cache.set(e,t),this}get size(){return this.map.size}entries(){return this.map.entries()}keys(){return this.map.keys()}values(){return this.map.values()}};var Oe=new we({cacheSize:10}),Je;(a=>{function h(s){let l=Oe.get(s);if(!l){_.error(`Label "${s}" not found`);return}return l}a.get=h;function e(s){if(Array.isArray(s)){s.forEach(l=>e(l));return}Oe.has(s.id)&&_.info(`Label "${s.id}" already exists, it will be overwritten`),Oe.set(s.id,s);}a.add=e;function t(){return Array.from(Oe.values())}a.values=t;function i(s){return Oe.has(s)}a.has=i;function n(){return Array.from(Oe.keys())}a.keys=n;})(Je||(Je={}));var ae=Je;var m=class m{constructor(){}static get allOpenedLabels(){return unifier.GameUnifier.getVariable(w.OPENED_LABELS_COUNTER_KEY)||{}}static set allOpenedLabels(e){unifier.GameUnifier.setVariable(w.OPENED_LABELS_COUNTER_KEY,e);}static getCurrentStepTimesCounterData(e=""){let t=m.currentLabelStepIndex;if(t===null)return _.error("currentLabelStepIndex is null"),null;let i=`${t}${e}`,n=m.currentLabelId,a=m._currentLabel;if(!n||t===null||!a)return _.error("currentLabelId or currentLabelStepIndex is null or currentLabel not found"),null;let s=a.getStepSha(t)||"error",l=unifier.GameUnifier.getVariable(w.CURRENT_STEP_TIMES_COUNTER_KEY)||{};return l[n]||(l[n]={}),(!l[n][i]||l[n][i].stepSha1!=s)&&(l[n][i]={stepSha1:s}),l[n][i]}static setCurrentStepTimesCounterData(e="",t){let i=m.currentLabelStepIndex,n=i+e,a=m.currentLabelId;if(!a||i===null){_.error("currentLabelId or currentLabelStepIndex is null");return}let s=unifier.GameUnifier.getVariable(w.CURRENT_STEP_TIMES_COUNTER_KEY)||{};s[a]||(s[a]={}),s[a][n]=t,unifier.GameUnifier.setVariable(w.CURRENT_STEP_TIMES_COUNTER_KEY,s);}static getCurrentStepTimesCounter(e=""){let t=m._stepCounter,i=m.getCurrentStepTimesCounterData(e);if(!i)return _.error("getCurrentStepTimesCounter obj is null"),0;let n=i.stepCounters||i.lastStepIndexs||[];return n.find(s=>s===t)||(n.push(t),delete i.lastStepIndexs,i.stepCounters=n,m.setCurrentStepTimesCounterData(e,i)),n.length}static getRandomNumber(e,t,i={}){let n=i.nestedId||"";if(i.onceOnly||false){let s=m.getCurrentStepTimesCounterData(n);if(!s)return;let l=s.usedRandomNumbers||{},p=Array.from({length:t-e+1},(E,N)=>N+e).filter(E=>!l[`${e}-${t}`]?.includes(E));if(p.length===0)return;let y=Math.floor(Math.random()*p.length),c=p[y];return l[`${e}-${t}`]||(l[`${e}-${t}`]=[]),l[`${e}-${t}`].push(c),s.usedRandomNumbers=l,m.setCurrentStepTimesCounterData(n,s),c}return Math.floor(Math.random()*(t-e+1))+e}static resetCurrentStepTimesCounter(e=""){let t=m.currentLabelStepIndex,i=t+e,n=m.currentLabelId;if(!n||t===null){_.error("currentLabelId or currentLabelStepIndex is null");return}let a=unifier.GameUnifier.getVariable(w.CURRENT_STEP_TIMES_COUNTER_KEY)||{};a[n]||(a[n]={}),a[n][i]={stepCounters:[],stepSha1:""},unifier.GameUnifier.setVariable(w.CURRENT_STEP_TIMES_COUNTER_KEY,a);}static get allChoicesMade(){return unifier.GameUnifier.getVariable(w.ALL_CHOICES_MADE_KEY)||[]}static set allChoicesMade(e){unifier.GameUnifier.setVariable(w.ALL_CHOICES_MADE_KEY,e);}static increaseStepCounter(){m._stepCounter++;}static get openedLabels(){return le(m._openedLabels)}static set openedLabels(e){m._openedLabels=le(e);}static get originalOpenedLabels(){return le(m._originalOpenedLabels)}static set originalOpenedLabels(e){m._originalOpenedLabels=le(e);}static get _currentLabel(){if(m.currentLabelId)return ae.get(m.currentLabelId)}static get currentLabelId(){if(m._openedLabels.length>0)return m._openedLabels[m._openedLabels.length-1].label}static get currentLabelStepIndex(){return m._openedLabels.length>0?m._openedLabels[m._openedLabels.length-1].currentStepIndex:null}static addLabelHistory(e,t){let i=m.allOpenedLabels,n=m.allOpenedLabels[e]?.biggestStep||0,a=m.allOpenedLabels[e]?.openCount||0;(!n||n<t)&&(i[e]={biggestStep:t,openCount:a},m.allOpenedLabels=i);}static addChoicesMade(e,t,i,n){let a=m.allChoicesMade,s=a.findIndex(l=>l.labelId===e&&l.stepIndex===t&&l.choiceIndex===n&&l.stepSha1===i);s<0?a.push({labelId:e,stepIndex:t,choiceIndex:n,stepSha1:i,madeTimes:1}):a[s].madeTimes++,m.allChoicesMade=a;}static pushNewLabel(e){if(!ae.get(e))throw new Error(`[Pixi\u2019VN] Label ${e} not found`);m._openedLabels.push({label:e,currentStepIndex:0});let i=m.allOpenedLabels,n=m.allOpenedLabels[e]?.biggestStep||0,a=m.allOpenedLabels[e]?.openCount||0;i[e]={biggestStep:n,openCount:a+1},m.allOpenedLabels=i;}static increaseCurrentStepIndex(){if(m._openedLabels.length>0){let e=m._openedLabels[m._openedLabels.length-1];m._openedLabels[m._openedLabels.length-1]={...e,currentStepIndex:e.currentStepIndex+1};}}static set onStepStart(e){m._onStepStart=e;}static get onStepStart(){return async(e,t)=>{let i=[];return m.onLoadingLabel&&e===0&&i.push(m.onLoadingLabel(e,t)),m._onStepStart&&i.push(m._onStepStart(e,t)),await Promise.all(i)}}};T(m,"choiceMadeTemp"),T(m,"lastHistoryStep",null),T(m,"_stepCounter",0),T(m,"_openedLabels",[]),T(m,"_originalOpenedLabels",[]),T(m,"_onStepStart"),T(m,"onLoadingLabel"),T(m,"onStepEnd");var b=m;var De=class{get currentStepTimesCounter(){return b.getCurrentStepTimesCounter()}set currentStepTimesCounter(e){b.resetCurrentStepTimesCounter();}getRandomNumber(e,t,i={}){return b.getRandomNumber(e,t,i)}get stepCounter(){return b._stepCounter}get openedLabels(){return b.openedLabels}get currentLabel(){return b._currentLabel}addStepHistory(e,t={}){let{choiceMade:i,ignoreSameStep:n}=t,a,s,l,p=unifier.GameUnifier.getVariable(w.LAST_STEP_GLUED)===this.stepCounter;unifier.GameUnifier.getVariable(w.LAST_DIALOGUE_ADDED_IN_STEP_MEMORY_KEY)===this.stepCounter&&(a=unifier.GameUnifier.getVariable(w.CURRENT_DIALOGUE_MEMORY_KEY)),unifier.GameUnifier.getVariable(w.LAST_MENU_OPTIONS_ADDED_IN_STEP_MEMORY_KEY)===this.stepCounter&&(s=unifier.GameUnifier.getVariable(w.CURRENT_MENU_OPTIONS_MEMORY_KEY)),unifier.GameUnifier.getVariable(w.LAST_INPUT_ADDED_IN_STEP_MEMORY_KEY)===this.stepCounter&&(l=unifier.GameUnifier.getVariable(w.CURRENT_INPUT_VALUE_MEMORY_KEY));let y=b.openedLabels,c={currentLabel:b.currentLabelId,dialogue:a,choices:s,stepSha1:e,index:this.stepCounter,labelStepIndex:b.currentLabelStepIndex,choiceIndexMade:i,inputValue:l,alreadyMadeChoices:this.alreadyCurrentStepMadeChoices,isGlued:p,openedLabels:y};b.originalOpenedLabels=y,unifier.GameUnifier.addHistoryItem(c,{ignoreSameStep:n}),b.lastHistoryStep=c,b.increaseStepCounter();}closeCurrentLabel(){if(!b.currentLabelId){_.warn("No label to close");return}if(!this.currentLabel){_.error("currentLabel not found");return}let e=b.openedLabels;e.pop(),b.openedLabels=e,unifier.GameUnifier.onLabelClosing(this.openedLabels.length);}closeAllLabels(){for(;b.openedLabels.length>0;)this.closeCurrentLabel(),unifier.GameUnifier.onLabelClosing(this.openedLabels.length);}isLabelAlreadyCompleted(e){let t;typeof e=="string"?t=e:t=e.id;let n=b.allOpenedLabels[t]?.biggestStep||0;if(n){let a=ae.get(t);if(a)return a.stepCount<=n}return false}get alreadyCurrentStepMadeChoicesObj(){let e=b.currentLabelStepIndex,t=this.currentLabel;if(e===null||!t)return;let i=t.getStepSha(e);return i||(_.warn("stepSha not found, setting to ERROR"),i="error"),b.allChoicesMade.filter(n=>n.labelId===t?.id&&n.stepIndex===e&&n.stepSha1===i)}get alreadyCurrentStepMadeChoices(){return this.alreadyCurrentStepMadeChoicesObj?.map(e=>e.choiceIndex)}get isCurrentStepAlreadyOpened(){let e=b.currentLabelId;if(e){let t=b.allOpenedLabels[e]?.openCount||0;if(b.currentLabelStepIndex&&t>=b.currentLabelStepIndex)return true}return false}getTimesLabelOpened(e){return b.allOpenedLabels[e]?.openCount||0}getTimesChoiceMade(e){return this.alreadyCurrentStepMadeChoicesObj?.find(t=>t.choiceIndex===e)?.madeTimes||0}addCurrentStepToHistory(){this.addStepHistory("dev",{ignoreSameStep:true});}getCanContinue(e){let t=e?.showWarn||false,i=this.choices;return i&&i.length>0?(t&&_.warn("The player must make a choice"),false):this.isRequiredInput?(t&&_.warn("The player must enter a value"),false):true}get canContinue(){return unifier.GameUnifier.runningStepsCount!==0?false:this.getCanContinue()}async onStepStart(e,t){let i=[];return e.onStepStart&&i.push(e.onStepStart(t,e)),b.onStepStart&&i.push(b.onStepStart(t,e)),await Promise.all(i)}async onStepEnd(e,t){let i=[];return e.onStepEnd&&i.push(e.onStepEnd(t,e)),b.onStepEnd&&i.push(b.onStepEnd(t,e)),await Promise.all(i)}async continue(e,t={}){let{runNow:i=false,steps:n=1}=t;if(!Number.isFinite(n)){_.warn(`[continue] The parameter steps must be a valid finite number, received: ${n}`);return}if(n<=0){_.warn(`[continue] The parameter steps must be greater than 0, received: ${n}`);return}if(!i&&!this.getCanContinue({showWarn:true}))return;if(!i&&unifier.GameUnifier.runningStepsCount!==0){unifier.GameUnifier.increaseContinueRequest(n);return}n>1&&unifier.GameUnifier.increaseContinueRequest(n-1),unifier.GameUnifier.runningStepsCount++;let a;try{unifier.GameUnifier.runningStepsCount===1&&await unifier.GameUnifier.onPreContinue(),b.increaseCurrentStepIndex(),a=await this.runCurrentStep(e,t);}catch(s){throw _.error("Error continuing",s),s}finally{unifier.GameUnifier.runningStepsCount--,a=await this.afterRunCurrentStep(e)||a;}return a}async afterRunCurrentStep(e){if(unifier.GameUnifier.runningStepsCount===0&&unifier.GameUnifier.continueRequestsCount!==0)return await unifier.GameUnifier.processNavigationRequests(e);if(this.openedLabels.length===0){if(unifier.GameUnifier.onEnd)return await unifier.GameUnifier.onEnd(e,{labelId:"end"});_.error("The end of the game is not managed, so the game is blocked. Read this documentation to know how to manage the end of the game: https://pixi-vn.web.app/start/other-narrative-features.html#how-manage-the-end-of-the-game");}}async runCurrentStep(e,t={}){let{choiceMade:i}=t;if(b.currentLabelId){let n=b.currentLabelStepIndex;if(n===null){_.error("currentLabelStepIndex is null");return}let a=b._currentLabel;if(!a){_.error("currentLabel not found");return}if(a.stepCount>n){try{await this.onStepStart(a,n);}catch(c){_.error("Error running onStepStart",c),this.onStepError&&await this.onStepError(c,e);return}let s=a.getStepById(n);if(!s){_.error("step not found");return}let l=a.getStepSha(n);l||(_.warn("stepSha not found, setting to ERROR"),l="error");let p,y;try{p=await s(e,{labelId:a.id});}catch(c){_.error("Error running step",c),y=c;}try{let c=this.choices;if(c?.length===1&&c[0].autoSelect){let E=c[0];p=await this.selectChoice(E,e);}}catch(c){_.error("Error auto-selecting choice",c),y===void 0&&(y=c);}try{let c=b.lastHistoryStep;i!==void 0&&c&&(l=c.stepSha1,l||(_.warn("stepSha not found, setting to ERROR"),l="error"),b.addChoicesMade(c.currentLabel||"error",typeof c.labelStepIndex=="number"?c.labelStepIndex:-1,c.stepSha1||"error",i),b.choiceMadeTemp=i);}catch(c){_.warn("Error adding choice made to history",c);}try{unifier.GameUnifier.runningStepsCount===1&&(b.addLabelHistory(a.id,n),this.addStepHistory(l,{...t,choiceMade:b.choiceMadeTemp}),b.choiceMadeTemp=void 0);}catch(c){_.warn("Error adding step to history",c);}try{this.currentLabel&&await this.onStepEnd(this.currentLabel,b.currentLabelStepIndex||0);}catch(c){_.warn("Error running onStepEnd",c);}return y&&this.onStepError&&await this.onStepError(y,e),p}else {if(this.openedLabels.length>1)return this.closeCurrentLabel(),await this.continue(e,t);if(this.openedLabels.length===1){b.openedLabels=[];return}}}else {if(this.openedLabels.length===0)return;_.error("currentLabelId not found");}}async call(e,t,i){let{choiceMade:n}=i||{},a;typeof e=="string"?a=e:a=e.id,unifier.GameUnifier.runningStepsCount++;let s;try{let l=ae.get(a);if(!l)throw new Error(`[Pixi\u2019VN] Label ${a} not found`);b.pushNewLabel(l.id),s=await this.runCurrentStep(t,{choiceMade:n});}catch(l){throw _.error("Error calling label",l),l}finally{unifier.GameUnifier.runningStepsCount--,s=await this.afterRunCurrentStep(t)||s;}return s}async jump(e,t,i){if(this.stepCounter===0)return await this.call(e,t,i);this.openedLabels.length>0&&this.closeCurrentLabel();let{choiceMade:n}=i||{},a;typeof e=="string"?a=e:a=e.id,unifier.GameUnifier.runningStepsCount++;let s;try{let l=ae.get(a);if(!l)throw new Error(`[Pixi\u2019VN] Label ${a} not found`);b.pushNewLabel(l.id),s=await this.runCurrentStep(t,{choiceMade:n});}catch(l){throw _.error("Error jumping to label",l),l}finally{unifier.GameUnifier.runningStepsCount--,s=await this.afterRunCurrentStep(t)||s;}return s}async selectChoice(e,t){this.choices=void 0;let i=e.type;switch(i){case "call":return await this.call(e.label,{...e.props,...t},{choiceMade:e.choiceIndex});case "jump":return await this.jump(e.label,{...e.props,...t},{choiceMade:e.choiceIndex});case "close":return await this.closeChoiceMenu(e,{...e.props,...t});default:throw _.error(`Type ${i} not found`),new Error(`[Pixi\u2019VN] Type ${i} not found`)}}async closeChoiceMenu(e,t){if(e.type!=="close")throw _.error("For closeChoiceMenu, the type must be close"),new Error("[Pixi\u2019VN] For closeChoiceMenu, the type must be close");let i;return typeof e.choiceIndex=="number"&&(i=e.choiceIndex),e.closeCurrentLabel&&this.closeCurrentLabel(),await this.continue(t,{choiceMade:i})}get onStepError(){let e=unifier.GameUnifier.onError;if(e)return async(t,i)=>{try{return await e("step",t,i)}catch(n){_.error("Error in onError handler",n);}}}set onStepError(e){unifier.GameUnifier.onError=(t,i,n)=>e(i,n);}get dialogue(){let e=unifier.GameUnifier.getVariable(w.CURRENT_DIALOGUE_MEMORY_KEY);if(e)return {...e,character:e.character?unifier.GameUnifier.getCharacter(e.character)||e.character:void 0}}set dialogue(e){if(e===void 0){unifier.GameUnifier.setVariable(w.CURRENT_DIALOGUE_MEMORY_KEY,void 0);return}if((typeof e=="string"||Array.isArray(e))&&(e={text:e}),this.dialogGlue){let t=unifier.GameUnifier.getVariable(w.CURRENT_DIALOGUE_MEMORY_KEY);if(t){let i=[];Array.isArray(t.text)?i=[...t.text]:i=[t.text],Array.isArray(e.text)?i=[...i,...e.text]:i=[...i,e.text],e.text=i,e.character=e.character||t.character;}unifier.GameUnifier.setVariable(w.LAST_STEP_GLUED,this.stepCounter),this.dialogGlue=false;}try{unifier.GameUnifier.setVariable(w.CURRENT_DIALOGUE_MEMORY_KEY,le({...e,character:typeof e.character=="string"?e.character:e.character?.id})),unifier.GameUnifier.setVariable(w.LAST_DIALOGUE_ADDED_IN_STEP_MEMORY_KEY,this.stepCounter);}catch(t){throw _.error("DialogueInterface cannot contain functions or classes"),t}}get choices(){let e=unifier.GameUnifier.getVariable(w.CURRENT_MENU_OPTIONS_MEMORY_KEY);if(e){let t=[],i=e.map((a,s)=>({...a,choiceIndex:s})),n=this.alreadyCurrentStepMadeChoices;if(i=i.filter((a,s)=>a.oneTime&&n&&n.includes(s)?false:a.onlyHaveNoChoice?(t.push(a),false):true),i.length>0)return i;if(t.length>0)return [t[0]]}}set choices(e){if(!e||e.length===0){unifier.GameUnifier.setVariable(w.CURRENT_MENU_OPTIONS_MEMORY_KEY,void 0);return}try{unifier.GameUnifier.setVariable(w.CURRENT_MENU_OPTIONS_MEMORY_KEY,le(e)),unifier.GameUnifier.setVariable(w.LAST_MENU_OPTIONS_ADDED_IN_STEP_MEMORY_KEY,this.stepCounter);}catch(t){throw _.error("ChoiceInterface cannot contain functions or classes"),t}}get dialogGlue(){return unifier.GameUnifier.getFlag(w.ADD_NEXT_DIALOG_TEXT_INTO_THE_CURRENT_DIALOG_FLAG_KEY)}set dialogGlue(e){unifier.GameUnifier.setFlag(w.ADD_NEXT_DIALOG_TEXT_INTO_THE_CURRENT_DIALOG_FLAG_KEY,e);}get inputValue(){return unifier.GameUnifier.getVariable(w.CURRENT_INPUT_VALUE_MEMORY_KEY)}set inputValue(e){this.removeInputRequest(),unifier.GameUnifier.setVariable(w.CURRENT_INPUT_VALUE_MEMORY_KEY,e),unifier.GameUnifier.setVariable(w.LAST_INPUT_ADDED_IN_STEP_MEMORY_KEY,this.stepCounter);}get isRequiredInput(){return unifier.GameUnifier.getVariable(w.CURRENT_INPUT_INFO_MEMORY_KEY)?.isRequired||false}get inputType(){return unifier.GameUnifier.getVariable(w.CURRENT_INPUT_INFO_MEMORY_KEY)?.type}requestInput(e,t){e.isRequired=true,unifier.GameUnifier.setVariable(w.CURRENT_INPUT_INFO_MEMORY_KEY,e),t!==void 0?unifier.GameUnifier.setVariable(w.CURRENT_INPUT_VALUE_MEMORY_KEY,t):unifier.GameUnifier.removeVariable(w.CURRENT_INPUT_VALUE_MEMORY_KEY);}removeInputRequest(){unifier.GameUnifier.removeVariable(w.CURRENT_INPUT_INFO_MEMORY_KEY),unifier.GameUnifier.removeVariable(w.CURRENT_INPUT_VALUE_MEMORY_KEY);}clear(){b.openedLabels=[],b._stepCounter=0;}export(){return {openedLabels:le(b.openedLabels),stepCounter:this.stepCounter}}async onLoadingLabel(e){let t=this.openedLabels.map(async i=>{let n=[],a=ae.get(i.label);return a&&(a.onLoadingLabel&&n.push(a.onLoadingLabel(e,a)),b.onLoadingLabel&&n.push(b.onLoadingLabel(e,a))),await Promise.all(n)});return await Promise.all(t)}async restore(e,t){this.clear();try{b.lastHistoryStep=t,e.hasOwnProperty("openedLabels")?(b.openedLabels=e.openedLabels,b.originalOpenedLabels=b.openedLabels):_.warn("Could not import openedLabels data, so will be ignored"),e.hasOwnProperty("stepCounter")?b._stepCounter=e.stepCounter:e.hasOwnProperty("lastStepIndex")?b._stepCounter=e.lastStepIndex:_.warn("Could not import stepCounter data, so will be ignored");try{await this.onLoadingLabel(b.currentLabelStepIndex||0);}catch(i){_.error("Error running onLoadingLabel",i);}}catch(i){_.error("Error importing data",i);}}};function wt(h,e,t,i){let n=typeof e=="string"?e:e.id;return {...i,label:n,props:t,text:h,type:i?.type||"call"}}var Qe="close";function Ot(h,e){return {...e,type:Qe,text:h}}var ct=Tt(dt());var Re=class{constructor(e,t){T(this,"id");T(this,"_onStepStart");T(this,"_onLoadingLabel");T(this,"_onStepEnd");this.id=e,this._onStepStart=t?.onStepStart,this._onLoadingLabel=t?.onLoadingLabel,this._onStepEnd=t?.onStepEnd;}get onStepStart(){return async(e,t)=>{if(this._onLoadingLabel&&e===0&&await this._onLoadingLabel(e,t),this._onStepStart)return await this._onStepStart(e,t)}}get onLoadingLabel(){return this._onLoadingLabel}get onStepEnd(){return this._onStepEnd}};var xe=class extends Re{constructor(t,i,n){super(t,n);T(this,"_steps");this._steps=i;}get stepCount(){return this.steps.length}getStepById(t){return this.steps[t]}get steps(){return typeof this._steps=="function"?this._steps():this._steps}getStepSha(t){if(t<0||t>=this.steps.length)return _.warn("stepSha not found, setting to ERROR"),"error";try{let i=this.steps[t];return (0,ct.default)(i.toString().toLocaleLowerCase()).toString()}catch(i){return _.warn("stepSha not found, setting to ERROR",i),"error"}}};function ft(h,e,t){let i=new xe(h,e,t);return ae.add(i),i}var Or=new De;
|
|
2
|
-
exports.Close=
|
|
1
|
+
'use strict';var core=require('@drincs/pixi-vn/core');var mt=Object.create;var We=Object.defineProperty;var St=Object.getOwnPropertyDescriptor;var gt=Object.getOwnPropertyNames;var yt=Object.getPrototypeOf,_t=Object.prototype.hasOwnProperty;var et=h=>{throw TypeError(h)};var Lt=(h,e,t)=>e in h?We(h,e,{enumerable:true,configurable:true,writable:true,value:t}):h[e]=t;var Be=(h=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(h,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):h)(function(h){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+h+'" is not supported')});var tt=(h,e)=>()=>(e||h((e={exports:{}}).exports,e),e.exports);var Tt=(h,e,t,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of gt(e))!_t.call(h,n)&&n!==t&&We(h,n,{get:()=>e[n],enumerable:!(i=St(e,n))||i.enumerable});return h};var Et=(h,e,t)=>(t=h!=null?mt(yt(h)):{},Tt(We(t,"default",{value:h,enumerable:true}),h));var E=(h,e,t)=>Lt(h,typeof e!="symbol"?e+"":e,t),je=(h,e,t)=>e.has(h)||et("Cannot "+t);var r=(h,e,t)=>(je(h,e,"read from private field"),t?t.call(h):e.get(h)),R=(h,e,t)=>e.has(h)?et("Cannot add the same private member more than once"):e instanceof WeakSet?e.add(h):e.set(h,t),g=(h,e,t,i)=>(je(h,e,"write to private field"),e.set(h,t),t),f=(h,e,t)=>(je(h,e,"access private method"),t);var Ue=(h,e,t,i)=>({set _(n){g(h,e,n);},get _(){return r(h,e,i)}});var pt=tt((Ve,ut)=>{(function(h,e){typeof Ve=="object"?ut.exports=Ve=e():typeof define=="function"&&define.amd?define([],e):h.CryptoJS=e();})(Ve,function(){var h=h||(function(e,t){var i;if(typeof window<"u"&&window.crypto&&(i=window.crypto),typeof self<"u"&&self.crypto&&(i=self.crypto),typeof globalThis<"u"&&globalThis.crypto&&(i=globalThis.crypto),!i&&typeof window<"u"&&window.msCrypto&&(i=window.msCrypto),!i&&typeof global<"u"&&global.crypto&&(i=global.crypto),!i&&typeof Be=="function")try{i=Be("crypto");}catch{}var n=function(){if(i){if(typeof i.getRandomValues=="function")try{return i.getRandomValues(new Uint32Array(1))[0]}catch{}if(typeof i.randomBytes=="function")try{return i.randomBytes(4).readInt32LE()}catch{}}throw new Error("Native crypto module could not be used to get secure random number.")},s=Object.create||(function(){function o(){}return function(c){var w;return o.prototype=c,w=new o,o.prototype=null,w}})(),a={},l=a.lib={},u=l.Base=(function(){return {extend:function(o){var c=s(this);return o&&c.mixIn(o),(!c.hasOwnProperty("init")||this.init===c.init)&&(c.init=function(){c.$super.init.apply(this,arguments);}),c.init.prototype=c,c.$super=this,c},create:function(){var o=this.extend();return o.init.apply(o,arguments),o},init:function(){},mixIn:function(o){for(var c in o)o.hasOwnProperty(c)&&(this[c]=o[c]);o.hasOwnProperty("toString")&&(this.toString=o.toString);},clone:function(){return this.init.prototype.extend(this)}}})(),S=l.WordArray=u.extend({init:function(o,c){o=this.words=o||[],c!=t?this.sigBytes=c:this.sigBytes=o.length*4;},toString:function(o){return (o||L).stringify(this)},concat:function(o){var c=this.words,w=o.words,I=this.sigBytes,O=o.sigBytes;if(this.clamp(),I%4)for(var U=0;U<O;U++){var oe=w[U>>>2]>>>24-U%4*8&255;c[I+U>>>2]|=oe<<24-(I+U)%4*8;}else for(var V=0;V<O;V+=4)c[I+V>>>2]=w[V>>>2];return this.sigBytes+=O,this},clamp:function(){var o=this.words,c=this.sigBytes;o[c>>>2]&=4294967295<<32-c%4*8,o.length=e.ceil(c/4);},clone:function(){var o=u.clone.call(this);return o.words=this.words.slice(0),o},random:function(o){for(var c=[],w=0;w<o;w+=4)c.push(n());return new S.init(c,o)}}),d=a.enc={},L=d.Hex={stringify:function(o){for(var c=o.words,w=o.sigBytes,I=[],O=0;O<w;O++){var U=c[O>>>2]>>>24-O%4*8&255;I.push((U>>>4).toString(16)),I.push((U&15).toString(16));}return I.join("")},parse:function(o){for(var c=o.length,w=[],I=0;I<c;I+=2)w[I>>>3]|=parseInt(o.substr(I,2),16)<<24-I%8*4;return new S.init(w,c/2)}},N=d.Latin1={stringify:function(o){for(var c=o.words,w=o.sigBytes,I=[],O=0;O<w;O++){var U=c[O>>>2]>>>24-O%4*8&255;I.push(String.fromCharCode(U));}return I.join("")},parse:function(o){for(var c=o.length,w=[],I=0;I<c;I++)w[I>>>2]|=(o.charCodeAt(I)&255)<<24-I%4*8;return new S.init(w,c)}},D=d.Utf8={stringify:function(o){try{return decodeURIComponent(escape(N.stringify(o)))}catch{throw new Error("Malformed UTF-8 data")}},parse:function(o){return N.parse(unescape(encodeURIComponent(o)))}},P=l.BufferedBlockAlgorithm=u.extend({reset:function(){this._data=new S.init,this._nDataBytes=0;},_append:function(o){typeof o=="string"&&(o=D.parse(o)),this._data.concat(o),this._nDataBytes+=o.sigBytes;},_process:function(o){var c,w=this._data,I=w.words,O=w.sigBytes,U=this.blockSize,oe=U*4,V=O/oe;o?V=e.ceil(V):V=e.max((V|0)-this._minBufferSize,0);var J=V*U,_e=e.min(J*4,O);if(J){for(var Ke=0;Ke<J;Ke+=U)this._doProcessBlock(I,Ke);c=I.splice(0,J),w.sigBytes-=_e;}return new S.init(c,_e)},clone:function(){var o=u.clone.call(this);return o._data=this._data.clone(),o},_minBufferSize:0});l.Hasher=P.extend({cfg:u.extend(),init:function(o){this.cfg=this.cfg.extend(o),this.reset();},reset:function(){P.reset.call(this),this._doReset();},update:function(o){return this._append(o),this._process(),this},finalize:function(o){o&&this._append(o);var c=this._doFinalize();return c},blockSize:512/32,_createHelper:function(o){return function(c,w){return new o.init(w).finalize(c)}},_createHmacHelper:function(o){return function(c,w){return new C.HMAC.init(o,w).finalize(c)}}});var C=a.algo={};return a})(Math);return h});});var ct=tt((He,dt)=>{(function(h,e){typeof He=="object"?dt.exports=He=e(pt()):typeof define=="function"&&define.amd?define(["./core"],e):e(h.CryptoJS);})(He,function(h){return (function(){var e=h,t=e.lib,i=t.WordArray,n=t.Hasher,s=e.algo,a=[],l=s.SHA1=n.extend({_doReset:function(){this._hash=new i.init([1732584193,4023233417,2562383102,271733878,3285377520]);},_doProcessBlock:function(u,S){for(var d=this._hash.words,L=d[0],N=d[1],D=d[2],P=d[3],x=d[4],C=0;C<80;C++){if(C<16)a[C]=u[S+C]|0;else {var o=a[C-3]^a[C-8]^a[C-14]^a[C-16];a[C]=o<<1|o>>>31;}var c=(L<<5|L>>>27)+x+a[C];C<20?c+=(N&D|~N&P)+1518500249:C<40?c+=(N^D^P)+1859775393:C<60?c+=(N&D|N&P|D&P)-1894007588:c+=(N^D^P)-899497514,x=P,P=D,D=N<<30|N>>>2,N=L,L=c;}d[0]=d[0]+L|0,d[1]=d[1]+N|0,d[2]=d[2]+D|0,d[3]=d[3]+P|0,d[4]=d[4]+x|0;},_doFinalize:function(){var u=this._data,S=u.words,d=this._nDataBytes*8,L=u.sigBytes*8;return S[L>>>5]|=128<<24-L%32,S[(L+64>>>9<<4)+14]=Math.floor(d/4294967296),S[(L+64>>>9<<4)+15]=d,u.sigBytes=S.length*4,this._process(),this._hash},clone:function(){var u=n.clone.call(this);return u._hash=this._hash.clone(),u}});e.SHA1=n._createHelper(l),e.HmacSHA1=n._createHmacHelper(l);})(),h.SHA1});});var v={CURRENT_DIALOGUE_MEMORY_KEY:"___current_dialogue_memory___",LAST_DIALOGUE_ADDED_IN_STEP_MEMORY_KEY:"___last_dialogue_added_in_step_memory___",CURRENT_MENU_OPTIONS_MEMORY_KEY:"___current_menu_options_memory___",LAST_MENU_OPTIONS_ADDED_IN_STEP_MEMORY_KEY:"___last_menu_options_added_in_step_memory___",CURRENT_INPUT_VALUE_MEMORY_KEY:"_input_value_",LAST_INPUT_ADDED_IN_STEP_MEMORY_KEY:"___last_input_added_in_step_memory___",CURRENT_INPUT_INFO_MEMORY_KEY:"___current_input_info_memory___",CHARACTER_CATEGORY_KEY:"___character___",ADD_NEXT_DIALOG_TEXT_INTO_THE_CURRENT_DIALOG_FLAG_KEY:"___glue___",OPENED_LABELS_COUNTER_KEY:"___opened_labels_counter___",ALL_CHOICES_MADE_KEY:"___all_choices_made___",CURRENT_STEP_TIMES_COUNTER_KEY:"___current_step_times_counter___",LAST_STEP_GLUED:"___last_step_glued___"};var _;(n=>(n.log=(s,...a)=>console.log(`[Pixi\u2019VN] ${s}`,...a),n.warn=(s,...a)=>console.warn(`[Pixi\u2019VN] ${s}`,...a),n.error=(s,...a)=>console.error(`[Pixi\u2019VN] ${s}`,...a),n.info=(s,...a)=>console.info(`[Pixi\u2019VN] ${s}`,...a)))(_||(_={}));function le(h){try{if(typeof h>"u")return h;let e=JSON.stringify(h);return JSON.parse(e)}catch(e){throw _.error("Error creating exportable element",h,e),new core.PixiError("not_json_serializable","Error creating exportable element")}}var It=typeof performance=="object"&&performance&&typeof performance.now=="function"?performance:Date,st=new Set,ke=typeof process=="object"&&process?process:{},at=(h,e,t,i)=>{typeof ke.emitWarning=="function"?ke.emitWarning(h,e,t,i):console.error(`[${t}] ${e}: ${h}`);},Ge=globalThis.AbortController,rt=globalThis.AbortSignal;if(typeof Ge>"u"){rt=class{constructor(){E(this,"onabort");E(this,"_onabort",[]);E(this,"reason");E(this,"aborted",false);}addEventListener(t,i){this._onabort.push(i);}},Ge=class{constructor(){E(this,"signal",new rt);e();}abort(t){if(!this.signal.aborted){this.signal.reason=t,this.signal.aborted=true;for(let i of this.signal._onabort)i(t);this.signal.onabort?.(t);}}};let h=ke.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",e=()=>{h&&(h=false,at("AbortController is not defined. If using lru-cache in node 14, load an AbortController polyfill from the `node-abort-controller` package. A minimal polyfill is provided for use by LRUCache.fetch(), but it should not be relied upon in other contexts (eg, passing it to other APIs that use AbortController/AbortSignal might have undesirable effects). You may disable this with LRU_CACHE_IGNORE_AC_WARNING=1 in the env.","NO_ABORT_CONTROLLER","ENOTSUP",e));};}var wt=h=>!st.has(h);var de=h=>h&&h===Math.floor(h)&&h>0&&isFinite(h),ot=h=>de(h)?h<=Math.pow(2,8)?Uint8Array:h<=Math.pow(2,16)?Uint16Array:h<=Math.pow(2,32)?Uint32Array:h<=Number.MAX_SAFE_INTEGER?Ye:null:null,Ye=class extends Array{constructor(h){super(h),this.fill(0);}},he,Le,vt=(he=class{constructor(e,t){E(this,"heap");E(this,"length");if(!r(he,Le))throw new TypeError("instantiate Stack using Stack.create(n)");this.heap=new t(e),this.length=0;}static create(e){let t=ot(e);if(!t)return [];g(he,Le,true);let i=new he(e,t);return g(he,Le,false),i}push(e){this.heap[this.length++]=e;}pop(){return this.heap[--this.length]}},Le=new WeakMap,R(he,Le,false),he),it,nt,X,B,Q,Se,Z,Te,Ee,ee,F,te,Y,M,T,K,j,H,z,re,G,ie,ne,k,$,se,me,W,Ce,p,$e,ge,ue,Ne,q,ht,ye,Ie,De,ce,fe,qe,Fe,ze,A,Xe,Me,be,Je,we,lt=(we=class{constructor(e){R(this,p);R(this,X);R(this,B);R(this,Q);R(this,Se);R(this,Z);R(this,Te);R(this,Ee);R(this,ee);E(this,"ttl");E(this,"ttlResolution");E(this,"ttlAutopurge");E(this,"updateAgeOnGet");E(this,"updateAgeOnHas");E(this,"allowStale");E(this,"noDisposeOnSet");E(this,"noUpdateTTL");E(this,"maxEntrySize");E(this,"sizeCalculation");E(this,"noDeleteOnFetchRejection");E(this,"noDeleteOnStaleGet");E(this,"allowStaleOnFetchAbort");E(this,"allowStaleOnFetchRejection");E(this,"ignoreFetchAbort");R(this,F);R(this,te);R(this,Y);R(this,M);R(this,T);R(this,K);R(this,j);R(this,H);R(this,z);R(this,re);R(this,G);R(this,ie);R(this,ne);R(this,k);R(this,$);R(this,se);R(this,me);R(this,W);R(this,Ce);R(this,ge,()=>{});R(this,ue,()=>{});R(this,Ne,()=>{});R(this,q,()=>false);R(this,ye,e=>{});R(this,Ie,(e,t,i)=>{});R(this,De,(e,t,i,n)=>{if(i||n)throw new TypeError("cannot set size without setting maxSize or maxEntrySize on cache");return 0});E(this,it,"LRUCache");let{max:t=0,ttl:i,ttlResolution:n=1,ttlAutopurge:s,updateAgeOnGet:a,updateAgeOnHas:l,allowStale:u,dispose:S,onInsert:d,disposeAfter:L,noDisposeOnSet:N,noUpdateTTL:D,maxSize:P=0,maxEntrySize:x=0,sizeCalculation:C,fetchMethod:o,memoMethod:c,noDeleteOnFetchRejection:w,noDeleteOnStaleGet:I,allowStaleOnFetchRejection:O,allowStaleOnFetchAbort:U,ignoreFetchAbort:oe,perf:V}=e;if(V!==void 0&&typeof V?.now!="function")throw new TypeError("perf option must have a now() method if specified");if(g(this,ee,V??It),t!==0&&!de(t))throw new TypeError("max option must be a nonnegative integer");let J=t?ot(t):Array;if(!J)throw new Error("invalid max value: "+t);if(g(this,X,t),g(this,B,P),this.maxEntrySize=x||r(this,B),this.sizeCalculation=C,this.sizeCalculation){if(!r(this,B)&&!this.maxEntrySize)throw new TypeError("cannot set sizeCalculation without setting maxSize or maxEntrySize");if(typeof this.sizeCalculation!="function")throw new TypeError("sizeCalculation set to non-function")}if(c!==void 0&&typeof c!="function")throw new TypeError("memoMethod must be a function if defined");if(g(this,Ee,c),o!==void 0&&typeof o!="function")throw new TypeError("fetchMethod must be a function if specified");if(g(this,Te,o),g(this,me,!!o),g(this,Y,new Map),g(this,M,new Array(t).fill(void 0)),g(this,T,new Array(t).fill(void 0)),g(this,K,new J(t)),g(this,j,new J(t)),g(this,H,0),g(this,z,0),g(this,re,vt.create(t)),g(this,F,0),g(this,te,0),typeof S=="function"&&g(this,Q,S),typeof d=="function"&&g(this,Se,d),typeof L=="function"?(g(this,Z,L),g(this,G,[])):(g(this,Z,void 0),g(this,G,void 0)),g(this,se,!!r(this,Q)),g(this,Ce,!!r(this,Se)),g(this,W,!!r(this,Z)),this.noDisposeOnSet=!!N,this.noUpdateTTL=!!D,this.noDeleteOnFetchRejection=!!w,this.allowStaleOnFetchRejection=!!O,this.allowStaleOnFetchAbort=!!U,this.ignoreFetchAbort=!!oe,this.maxEntrySize!==0){if(r(this,B)!==0&&!de(r(this,B)))throw new TypeError("maxSize must be a positive integer if specified");if(!de(this.maxEntrySize))throw new TypeError("maxEntrySize must be a positive integer if specified");f(this,p,ht).call(this);}if(this.allowStale=!!u,this.noDeleteOnStaleGet=!!I,this.updateAgeOnGet=!!a,this.updateAgeOnHas=!!l,this.ttlResolution=de(n)||n===0?n:1,this.ttlAutopurge=!!s,this.ttl=i||0,this.ttl){if(!de(this.ttl))throw new TypeError("ttl must be a positive integer if specified");f(this,p,$e).call(this);}if(r(this,X)===0&&this.ttl===0&&r(this,B)===0)throw new TypeError("At least one of max, maxSize, or ttl is required");if(!this.ttlAutopurge&&!r(this,X)&&!r(this,B)){let _e="LRU_CACHE_UNBOUNDED";wt(_e)&&(st.add(_e),at("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning",_e,we));}}get perf(){return r(this,ee)}static unsafeExposeInternals(e){return {starts:r(e,ne),ttls:r(e,k),autopurgeTimers:r(e,$),sizes:r(e,ie),keyMap:r(e,Y),keyList:r(e,M),valList:r(e,T),next:r(e,K),prev:r(e,j),get head(){return r(e,H)},get tail(){return r(e,z)},free:r(e,re),isBackgroundFetch:t=>{var i;return f(i=e,p,A).call(i,t)},backgroundFetch:(t,i,n,s)=>{var a;return f(a=e,p,ze).call(a,t,i,n,s)},moveToTail:t=>{var i;return f(i=e,p,Me).call(i,t)},indexes:t=>{var i;return f(i=e,p,ce).call(i,t)},rindexes:t=>{var i;return f(i=e,p,fe).call(i,t)},isStale:t=>{var i;return r(i=e,q).call(i,t)}}}get max(){return r(this,X)}get maxSize(){return r(this,B)}get calculatedSize(){return r(this,te)}get size(){return r(this,F)}get fetchMethod(){return r(this,Te)}get memoMethod(){return r(this,Ee)}get dispose(){return r(this,Q)}get onInsert(){return r(this,Se)}get disposeAfter(){return r(this,Z)}getRemainingTTL(e){return r(this,Y).has(e)?1/0:0}*entries(){for(let e of f(this,p,ce).call(this))r(this,T)[e]!==void 0&&r(this,M)[e]!==void 0&&!f(this,p,A).call(this,r(this,T)[e])&&(yield [r(this,M)[e],r(this,T)[e]]);}*rentries(){for(let e of f(this,p,fe).call(this))r(this,T)[e]!==void 0&&r(this,M)[e]!==void 0&&!f(this,p,A).call(this,r(this,T)[e])&&(yield [r(this,M)[e],r(this,T)[e]]);}*keys(){for(let e of f(this,p,ce).call(this)){let t=r(this,M)[e];t!==void 0&&!f(this,p,A).call(this,r(this,T)[e])&&(yield t);}}*rkeys(){for(let e of f(this,p,fe).call(this)){let t=r(this,M)[e];t!==void 0&&!f(this,p,A).call(this,r(this,T)[e])&&(yield t);}}*values(){for(let e of f(this,p,ce).call(this))r(this,T)[e]!==void 0&&!f(this,p,A).call(this,r(this,T)[e])&&(yield r(this,T)[e]);}*rvalues(){for(let e of f(this,p,fe).call(this))r(this,T)[e]!==void 0&&!f(this,p,A).call(this,r(this,T)[e])&&(yield r(this,T)[e]);}[(nt=Symbol.iterator,it=Symbol.toStringTag,nt)](){return this.entries()}find(e,t={}){for(let i of f(this,p,ce).call(this)){let n=r(this,T)[i],s=f(this,p,A).call(this,n)?n.__staleWhileFetching:n;if(s!==void 0&&e(s,r(this,M)[i],this))return this.get(r(this,M)[i],t)}}forEach(e,t=this){for(let i of f(this,p,ce).call(this)){let n=r(this,T)[i],s=f(this,p,A).call(this,n)?n.__staleWhileFetching:n;s!==void 0&&e.call(t,s,r(this,M)[i],this);}}rforEach(e,t=this){for(let i of f(this,p,fe).call(this)){let n=r(this,T)[i],s=f(this,p,A).call(this,n)?n.__staleWhileFetching:n;s!==void 0&&e.call(t,s,r(this,M)[i],this);}}purgeStale(){let e=false;for(let t of f(this,p,fe).call(this,{allowStale:true}))r(this,q).call(this,t)&&(f(this,p,be).call(this,r(this,M)[t],"expire"),e=true);return e}info(e){let t=r(this,Y).get(e);if(t===void 0)return;let i=r(this,T)[t],n=f(this,p,A).call(this,i)?i.__staleWhileFetching:i;if(n===void 0)return;let s={value:n};if(r(this,k)&&r(this,ne)){let a=r(this,k)[t],l=r(this,ne)[t];if(a&&l){let u=a-(r(this,ee).now()-l);s.ttl=u,s.start=Date.now();}}return r(this,ie)&&(s.size=r(this,ie)[t]),s}dump(){let e=[];for(let t of f(this,p,ce).call(this,{allowStale:true})){let i=r(this,M)[t],n=r(this,T)[t],s=f(this,p,A).call(this,n)?n.__staleWhileFetching:n;if(s===void 0||i===void 0)continue;let a={value:s};if(r(this,k)&&r(this,ne)){a.ttl=r(this,k)[t];let l=r(this,ee).now()-r(this,ne)[t];a.start=Math.floor(Date.now()-l);}r(this,ie)&&(a.size=r(this,ie)[t]),e.unshift([i,a]);}return e}load(e){this.clear();for(let[t,i]of e){if(i.start){let n=Date.now()-i.start;i.start=r(this,ee).now()-n;}this.set(t,i.value,i);}}set(e,t,i={}){var N,D,P,x;if(t===void 0)return this.delete(e),this;let{ttl:n=this.ttl,start:s,noDisposeOnSet:a=this.noDisposeOnSet,sizeCalculation:l=this.sizeCalculation,status:u}=i,{noUpdateTTL:S=this.noUpdateTTL}=i,d=r(this,De).call(this,e,t,i.size||0,l);if(this.maxEntrySize&&d>this.maxEntrySize)return u&&(u.set="miss",u.maxEntrySizeExceeded=true),f(this,p,be).call(this,e,"set"),this;let L=r(this,F)===0?void 0:r(this,Y).get(e);if(L===void 0)L=r(this,F)===0?r(this,z):r(this,re).length!==0?r(this,re).pop():r(this,F)===r(this,X)?f(this,p,Fe).call(this,false):r(this,F),r(this,M)[L]=e,r(this,T)[L]=t,r(this,Y).set(e,L),r(this,K)[r(this,z)]=L,r(this,j)[L]=r(this,z),g(this,z,L),Ue(this,F)._++,r(this,Ie).call(this,L,d,u),u&&(u.set="add"),S=false,r(this,Ce)&&((N=r(this,Se))==null||N.call(this,t,e,"add"));else {f(this,p,Me).call(this,L);let C=r(this,T)[L];if(t!==C){if(r(this,me)&&f(this,p,A).call(this,C)){C.__abortController.abort(new Error("replaced"));let{__staleWhileFetching:o}=C;o!==void 0&&!a&&(r(this,se)&&((D=r(this,Q))==null||D.call(this,o,e,"set")),r(this,W)&&r(this,G)?.push([o,e,"set"]));}else a||(r(this,se)&&((P=r(this,Q))==null||P.call(this,C,e,"set")),r(this,W)&&r(this,G)?.push([C,e,"set"]));if(r(this,ye).call(this,L),r(this,Ie).call(this,L,d,u),r(this,T)[L]=t,u){u.set="replace";let o=C&&f(this,p,A).call(this,C)?C.__staleWhileFetching:C;o!==void 0&&(u.oldValue=o);}}else u&&(u.set="update");r(this,Ce)&&this.onInsert?.(t,e,t===C?"update":"replace");}if(n!==0&&!r(this,k)&&f(this,p,$e).call(this),r(this,k)&&(S||r(this,Ne).call(this,L,n,s),u&&r(this,ue).call(this,u,L)),!a&&r(this,W)&&r(this,G)){let C=r(this,G),o;for(;o=C?.shift();)(x=r(this,Z))==null||x.call(this,...o);}return this}pop(){var e;try{for(;r(this,F);){let t=r(this,T)[r(this,H)];if(f(this,p,Fe).call(this,!0),f(this,p,A).call(this,t)){if(t.__staleWhileFetching)return t.__staleWhileFetching}else if(t!==void 0)return t}}finally{if(r(this,W)&&r(this,G)){let t=r(this,G),i;for(;i=t?.shift();)(e=r(this,Z))==null||e.call(this,...i);}}}has(e,t={}){let{updateAgeOnHas:i=this.updateAgeOnHas,status:n}=t,s=r(this,Y).get(e);if(s!==void 0){let a=r(this,T)[s];if(f(this,p,A).call(this,a)&&a.__staleWhileFetching===void 0)return false;if(r(this,q).call(this,s))n&&(n.has="stale",r(this,ue).call(this,n,s));else return i&&r(this,ge).call(this,s),n&&(n.has="hit",r(this,ue).call(this,n,s)),true}else n&&(n.has="miss");return false}peek(e,t={}){let{allowStale:i=this.allowStale}=t,n=r(this,Y).get(e);if(n===void 0||!i&&r(this,q).call(this,n))return;let s=r(this,T)[n];return f(this,p,A).call(this,s)?s.__staleWhileFetching:s}async fetch(e,t={}){let{allowStale:i=this.allowStale,updateAgeOnGet:n=this.updateAgeOnGet,noDeleteOnStaleGet:s=this.noDeleteOnStaleGet,ttl:a=this.ttl,noDisposeOnSet:l=this.noDisposeOnSet,size:u=0,sizeCalculation:S=this.sizeCalculation,noUpdateTTL:d=this.noUpdateTTL,noDeleteOnFetchRejection:L=this.noDeleteOnFetchRejection,allowStaleOnFetchRejection:N=this.allowStaleOnFetchRejection,ignoreFetchAbort:D=this.ignoreFetchAbort,allowStaleOnFetchAbort:P=this.allowStaleOnFetchAbort,context:x,forceRefresh:C=false,status:o,signal:c}=t;if(!r(this,me))return o&&(o.fetch="get"),this.get(e,{allowStale:i,updateAgeOnGet:n,noDeleteOnStaleGet:s,status:o});let w={allowStale:i,updateAgeOnGet:n,noDeleteOnStaleGet:s,ttl:a,noDisposeOnSet:l,size:u,sizeCalculation:S,noUpdateTTL:d,noDeleteOnFetchRejection:L,allowStaleOnFetchRejection:N,allowStaleOnFetchAbort:P,ignoreFetchAbort:D,status:o,signal:c},I=r(this,Y).get(e);if(I===void 0){o&&(o.fetch="miss");let O=f(this,p,ze).call(this,e,I,w,x);return O.__returned=O}else {let O=r(this,T)[I];if(f(this,p,A).call(this,O)){let J=i&&O.__staleWhileFetching!==void 0;return o&&(o.fetch="inflight",J&&(o.returnedStale=true)),J?O.__staleWhileFetching:O.__returned=O}let U=r(this,q).call(this,I);if(!C&&!U)return o&&(o.fetch="hit"),f(this,p,Me).call(this,I),n&&r(this,ge).call(this,I),o&&r(this,ue).call(this,o,I),O;let oe=f(this,p,ze).call(this,e,I,w,x),V=oe.__staleWhileFetching!==void 0&&i;return o&&(o.fetch=U?"stale":"refresh",V&&U&&(o.returnedStale=true)),V?oe.__staleWhileFetching:oe.__returned=oe}}async forceFetch(e,t={}){let i=await this.fetch(e,t);if(i===void 0)throw new Error("fetch() returned undefined");return i}memo(e,t={}){let i=r(this,Ee);if(!i)throw new Error("no memoMethod provided to constructor");let{context:n,forceRefresh:s,...a}=t,l=this.get(e,a);if(!s&&l!==void 0)return l;let u=i(e,l,{options:a,context:n});return this.set(e,u,a),u}get(e,t={}){let{allowStale:i=this.allowStale,updateAgeOnGet:n=this.updateAgeOnGet,noDeleteOnStaleGet:s=this.noDeleteOnStaleGet,status:a}=t,l=r(this,Y).get(e);if(l!==void 0){let u=r(this,T)[l],S=f(this,p,A).call(this,u);return a&&r(this,ue).call(this,a,l),r(this,q).call(this,l)?(a&&(a.get="stale"),S?(a&&i&&u.__staleWhileFetching!==void 0&&(a.returnedStale=true),i?u.__staleWhileFetching:void 0):(s||f(this,p,be).call(this,e,"expire"),a&&i&&(a.returnedStale=true),i?u:void 0)):(a&&(a.get="hit"),S?u.__staleWhileFetching:(f(this,p,Me).call(this,l),n&&r(this,ge).call(this,l),u))}else a&&(a.get="miss");}delete(e){return f(this,p,be).call(this,e,"delete")}clear(){return f(this,p,Je).call(this,"delete")}},X=new WeakMap,B=new WeakMap,Q=new WeakMap,Se=new WeakMap,Z=new WeakMap,Te=new WeakMap,Ee=new WeakMap,ee=new WeakMap,F=new WeakMap,te=new WeakMap,Y=new WeakMap,M=new WeakMap,T=new WeakMap,K=new WeakMap,j=new WeakMap,H=new WeakMap,z=new WeakMap,re=new WeakMap,G=new WeakMap,ie=new WeakMap,ne=new WeakMap,k=new WeakMap,$=new WeakMap,se=new WeakMap,me=new WeakMap,W=new WeakMap,Ce=new WeakMap,p=new WeakSet,$e=function(){let e=new Ye(r(this,X)),t=new Ye(r(this,X));g(this,k,e),g(this,ne,t);let i=this.ttlAutopurge?new Array(r(this,X)):void 0;g(this,$,i),g(this,Ne,(l,u,S=r(this,ee).now())=>{t[l]=u!==0?S:0,e[l]=u,n(l,u);}),g(this,ge,l=>{t[l]=e[l]!==0?r(this,ee).now():0,n(l,e[l]);});let n=this.ttlAutopurge?(l,u)=>{if(i?.[l]&&(clearTimeout(i[l]),i[l]=void 0),u&&u!==0&&i){let S=setTimeout(()=>{r(this,q).call(this,l)&&f(this,p,be).call(this,r(this,M)[l],"expire");},u+1);S.unref&&S.unref(),i[l]=S;}}:()=>{};g(this,ue,(l,u)=>{if(e[u]){let S=e[u],d=t[u];if(!S||!d)return;l.ttl=S,l.start=d,l.now=s||a();let L=l.now-d;l.remainingTTL=S-L;}});let s=0,a=()=>{let l=r(this,ee).now();if(this.ttlResolution>0){s=l;let u=setTimeout(()=>s=0,this.ttlResolution);u.unref&&u.unref();}return l};this.getRemainingTTL=l=>{let u=r(this,Y).get(l);if(u===void 0)return 0;let S=e[u],d=t[u];if(!S||!d)return 1/0;let L=(s||a())-d;return S-L},g(this,q,l=>{let u=t[l],S=e[l];return !!S&&!!u&&(s||a())-u>S});},ge=new WeakMap,ue=new WeakMap,Ne=new WeakMap,q=new WeakMap,ht=function(){let e=new Ye(r(this,X));g(this,te,0),g(this,ie,e),g(this,ye,t=>{g(this,te,r(this,te)-e[t]),e[t]=0;}),g(this,De,(t,i,n,s)=>{if(f(this,p,A).call(this,i))return 0;if(!de(n))if(s){if(typeof s!="function")throw new TypeError("sizeCalculation must be a function");if(n=s(i,t),!de(n))throw new TypeError("sizeCalculation return invalid (expect positive integer)")}else throw new TypeError("invalid size value (must be positive integer). When maxSize or maxEntrySize is used, sizeCalculation or size must be set.");return n}),g(this,Ie,(t,i,n)=>{if(e[t]=i,r(this,B)){let s=r(this,B)-e[t];for(;r(this,te)>s;)f(this,p,Fe).call(this,true);}g(this,te,r(this,te)+e[t]),n&&(n.entrySize=i,n.totalCalculatedSize=r(this,te));});},ye=new WeakMap,Ie=new WeakMap,De=new WeakMap,ce=function*({allowStale:e=this.allowStale}={}){if(r(this,F))for(let t=r(this,z);!(!f(this,p,qe).call(this,t)||((e||!r(this,q).call(this,t))&&(yield t),t===r(this,H)));)t=r(this,j)[t];},fe=function*({allowStale:e=this.allowStale}={}){if(r(this,F))for(let t=r(this,H);!(!f(this,p,qe).call(this,t)||((e||!r(this,q).call(this,t))&&(yield t),t===r(this,z)));)t=r(this,K)[t];},qe=function(e){return e!==void 0&&r(this,Y).get(r(this,M)[e])===e},Fe=function(e){var s;let t=r(this,H),i=r(this,M)[t],n=r(this,T)[t];return r(this,me)&&f(this,p,A).call(this,n)?n.__abortController.abort(new Error("evicted")):(r(this,se)||r(this,W))&&(r(this,se)&&((s=r(this,Q))==null||s.call(this,n,i,"evict")),r(this,W)&&r(this,G)?.push([n,i,"evict"])),r(this,ye).call(this,t),r(this,$)?.[t]&&(clearTimeout(r(this,$)[t]),r(this,$)[t]=void 0),e&&(r(this,M)[t]=void 0,r(this,T)[t]=void 0,r(this,re).push(t)),r(this,F)===1?(g(this,H,g(this,z,0)),r(this,re).length=0):g(this,H,r(this,K)[t]),r(this,Y).delete(i),Ue(this,F)._--,t},ze=function(e,t,i,n){let s=t===void 0?void 0:r(this,T)[t];if(f(this,p,A).call(this,s))return s;let a=new Ge,{signal:l}=i;l?.addEventListener("abort",()=>a.abort(l.reason),{signal:a.signal});let u={signal:a.signal,options:i,context:n},S=(x,C=false)=>{let{aborted:o}=a.signal,c=i.ignoreFetchAbort&&x!==void 0,w=i.ignoreFetchAbort||!!(i.allowStaleOnFetchAbort&&x!==void 0);if(i.status&&(o&&!C?(i.status.fetchAborted=true,i.status.fetchError=a.signal.reason,c&&(i.status.fetchAbortIgnored=true)):i.status.fetchResolved=true),o&&!c&&!C)return L(a.signal.reason,w);let I=D,O=r(this,T)[t];return (O===D||c&&C&&O===void 0)&&(x===void 0?I.__staleWhileFetching!==void 0?r(this,T)[t]=I.__staleWhileFetching:f(this,p,be).call(this,e,"fetch"):(i.status&&(i.status.fetchUpdated=true),this.set(e,x,u.options))),x},d=x=>(i.status&&(i.status.fetchRejected=true,i.status.fetchError=x),L(x,false)),L=(x,C)=>{let{aborted:o}=a.signal,c=o&&i.allowStaleOnFetchAbort,w=c||i.allowStaleOnFetchRejection,I=w||i.noDeleteOnFetchRejection,O=D;if(r(this,T)[t]===D&&(!I||!C&&O.__staleWhileFetching===void 0?f(this,p,be).call(this,e,"fetch"):c||(r(this,T)[t]=O.__staleWhileFetching)),w)return i.status&&O.__staleWhileFetching!==void 0&&(i.status.returnedStale=true),O.__staleWhileFetching;if(O.__returned===O)throw x},N=(x,C)=>{var c;let o=(c=r(this,Te))==null?void 0:c.call(this,e,s,u);o&&o instanceof Promise&&o.then(w=>x(w===void 0?void 0:w),C),a.signal.addEventListener("abort",()=>{(!i.ignoreFetchAbort||i.allowStaleOnFetchAbort)&&(x(void 0),i.allowStaleOnFetchAbort&&(x=w=>S(w,true)));});};i.status&&(i.status.fetchDispatched=true);let D=new Promise(N).then(S,d),P=Object.assign(D,{__abortController:a,__staleWhileFetching:s,__returned:void 0});return t===void 0?(this.set(e,P,{...u.options,status:void 0}),t=r(this,Y).get(e)):r(this,T)[t]=P,P},A=function(e){if(!r(this,me))return false;let t=e;return !!t&&t instanceof Promise&&t.hasOwnProperty("__staleWhileFetching")&&t.__abortController instanceof Ge},Xe=function(e,t){r(this,j)[t]=e,r(this,K)[e]=t;},Me=function(e){e!==r(this,z)&&(e===r(this,H)?g(this,H,r(this,K)[e]):f(this,p,Xe).call(this,r(this,j)[e],r(this,K)[e]),f(this,p,Xe).call(this,r(this,z),e),g(this,z,e));},be=function(e,t){var n,s;let i=false;if(r(this,F)!==0){let a=r(this,Y).get(e);if(a!==void 0)if(r(this,$)?.[a]&&(clearTimeout(r(this,$)?.[a]),r(this,$)[a]=void 0),i=true,r(this,F)===1)f(this,p,Je).call(this,t);else {r(this,ye).call(this,a);let l=r(this,T)[a];if(f(this,p,A).call(this,l)?l.__abortController.abort(new Error("deleted")):(r(this,se)||r(this,W))&&(r(this,se)&&((n=r(this,Q))==null||n.call(this,l,e,t)),r(this,W)&&r(this,G)?.push([l,e,t])),r(this,Y).delete(e),r(this,M)[a]=void 0,r(this,T)[a]=void 0,a===r(this,z))g(this,z,r(this,j)[a]);else if(a===r(this,H))g(this,H,r(this,K)[a]);else {let u=r(this,j)[a];r(this,K)[u]=r(this,K)[a];let S=r(this,K)[a];r(this,j)[S]=r(this,j)[a];}Ue(this,F)._--,r(this,re).push(a);}}if(r(this,W)&&r(this,G)?.length){let a=r(this,G),l;for(;l=a?.shift();)(s=r(this,Z))==null||s.call(this,...l);}return i},Je=function(e){var t,i;for(let n of f(this,p,fe).call(this,{allowStale:true})){let s=r(this,T)[n];if(f(this,p,A).call(this,s))s.__abortController.abort(new Error("deleted"));else {let a=r(this,M)[n];r(this,se)&&((t=r(this,Q))==null||t.call(this,s,a,e)),r(this,W)&&r(this,G)?.push([s,a,e]);}}if(r(this,Y).clear(),r(this,T).fill(void 0),r(this,M).fill(void 0),r(this,k)&&r(this,ne)){r(this,k).fill(0),r(this,ne).fill(0);for(let n of r(this,$)??[])n!==void 0&&clearTimeout(n);r(this,$)?.fill(void 0);}if(r(this,ie)&&r(this,ie).fill(0),g(this,H,0),g(this,z,0),r(this,re).length=0,g(this,te,0),g(this,F,0),r(this,W)&&r(this,G)){let n=r(this,G),s;for(;s=n?.shift();)(i=r(this,Z))==null||i.call(this,...s);}},we);var ve=class{constructor(e){E(this,"cache");E(this,"map",new Map);this.cache=new lt({max:e.cacheSize}),this.map=new Map;}get[Symbol.iterator](){return this.map[Symbol.iterator]}get[Symbol.toStringTag](){return this.map[Symbol.toStringTag]}clear(){return this.cache.clear(),this.map.clear()}delete(e){let t=this.map.delete(e);return t&&this.cache.delete(e),t}get forEach(){return this.map.forEach}get(e){let t=this.cache.get(e);return t||this.map.get(e)}has(e){return this.map.has(e)}set(e,t){return this.map.set(e,t),this.cache.set(e,t),this}get size(){return this.map.size}entries(){return this.map.entries()}keys(){return this.map.keys()}values(){return this.map.values()}};var Oe=new ve({cacheSize:10}),Qe;(s=>{function h(a){let l=Oe.get(a);if(!l){_.error(`Label "${a}" not found`);return}return l}s.get=h;function e(a){if(Array.isArray(a)){a.forEach(l=>e(l));return}Oe.has(a.id)&&_.info(`Label "${a.id}" already exists, it will be overwritten`),Oe.set(a.id,a);}s.add=e;function t(){return Array.from(Oe.values())}s.values=t;function i(a){return Oe.has(a)}s.has=i;function n(){return Array.from(Oe.keys())}s.keys=n;})(Qe||(Qe={}));var ae=Qe;var m=class m{constructor(){}static get allOpenedLabels(){return core.GameUnifier.getVariable(v.OPENED_LABELS_COUNTER_KEY)||{}}static set allOpenedLabels(e){core.GameUnifier.setVariable(v.OPENED_LABELS_COUNTER_KEY,e);}static getCurrentStepTimesCounterData(e=""){let t=m.currentLabelStepIndex;if(t===null)return _.error("currentLabelStepIndex is null"),null;let i=`${t}${e}`,n=m.currentLabelId,s=m._currentLabel;if(!n||t===null||!s)return _.error("currentLabelId or currentLabelStepIndex is null or currentLabel not found"),null;let a=s.getStepSha(t)||"error",l=core.GameUnifier.getVariable(v.CURRENT_STEP_TIMES_COUNTER_KEY)||{};return l[n]||(l[n]={}),(!l[n][i]||l[n][i].stepSha1!=a)&&(l[n][i]={stepSha1:a}),l[n][i]}static setCurrentStepTimesCounterData(e="",t){let i=m.currentLabelStepIndex,n=i+e,s=m.currentLabelId;if(!s||i===null){_.error("currentLabelId or currentLabelStepIndex is null");return}let a=core.GameUnifier.getVariable(v.CURRENT_STEP_TIMES_COUNTER_KEY)||{};a[s]||(a[s]={}),a[s][n]=t,core.GameUnifier.setVariable(v.CURRENT_STEP_TIMES_COUNTER_KEY,a);}static getCurrentStepTimesCounter(e=""){let t=m._stepCounter,i=m.getCurrentStepTimesCounterData(e);if(!i)return _.error("getCurrentStepTimesCounter obj is null"),0;let n=i.stepCounters||i.lastStepIndexs||[];return n.find(a=>a===t)||(n.push(t),delete i.lastStepIndexs,i.stepCounters=n,m.setCurrentStepTimesCounterData(e,i)),n.length}static getRandomNumber(e,t,i={}){let n=i.nestedId||"";if(i.onceOnly||false){let a=m.getCurrentStepTimesCounterData(n);if(!a)return;let l=a.usedRandomNumbers||{},u=Array.from({length:t-e+1},(L,N)=>N+e).filter(L=>!l[`${e}-${t}`]?.includes(L));if(u.length===0)return;let S=Math.floor(Math.random()*u.length),d=u[S];return l[`${e}-${t}`]||(l[`${e}-${t}`]=[]),l[`${e}-${t}`].push(d),a.usedRandomNumbers=l,m.setCurrentStepTimesCounterData(n,a),d}return Math.floor(Math.random()*(t-e+1))+e}static resetCurrentStepTimesCounter(e=""){let t=m.currentLabelStepIndex,i=t+e,n=m.currentLabelId;if(!n||t===null){_.error("currentLabelId or currentLabelStepIndex is null");return}let s=core.GameUnifier.getVariable(v.CURRENT_STEP_TIMES_COUNTER_KEY)||{};s[n]||(s[n]={}),s[n][i]={stepCounters:[],stepSha1:""},core.GameUnifier.setVariable(v.CURRENT_STEP_TIMES_COUNTER_KEY,s);}static get allChoicesMade(){return core.GameUnifier.getVariable(v.ALL_CHOICES_MADE_KEY)||[]}static set allChoicesMade(e){core.GameUnifier.setVariable(v.ALL_CHOICES_MADE_KEY,e);}static increaseStepCounter(){m._stepCounter++;}static get openedLabels(){return le(m._openedLabels)}static set openedLabels(e){m._openedLabels=le(e);}static get originalOpenedLabels(){return le(m._originalOpenedLabels)}static set originalOpenedLabels(e){m._originalOpenedLabels=le(e);}static get _currentLabel(){if(m.currentLabelId)return ae.get(m.currentLabelId)}static get currentLabelId(){if(m._openedLabels.length>0)return m._openedLabels[m._openedLabels.length-1].label}static get currentLabelStepIndex(){return m._openedLabels.length>0?m._openedLabels[m._openedLabels.length-1].currentStepIndex:null}static addLabelHistory(e,t){let i=m.allOpenedLabels,n=m.allOpenedLabels[e]?.biggestStep||0,s=m.allOpenedLabels[e]?.openCount||0;(!n||n<t)&&(i[e]={biggestStep:t,openCount:s},m.allOpenedLabels=i);}static addChoicesMade(e,t,i,n){let s=m.allChoicesMade,a=s.findIndex(l=>l.labelId===e&&l.stepIndex===t&&l.choiceIndex===n&&l.stepSha1===i);a<0?s.push({labelId:e,stepIndex:t,choiceIndex:n,stepSha1:i,madeTimes:1}):s[a].madeTimes++,m.allChoicesMade=s;}static pushNewLabel(e){if(!ae.get(e))throw new core.PixiError("unregistered_element",`Label ${e} not found`);m._openedLabels.push({label:e,currentStepIndex:0});let i=m.allOpenedLabels,n=m.allOpenedLabels[e]?.biggestStep||0,s=m.allOpenedLabels[e]?.openCount||0;i[e]={biggestStep:n,openCount:s+1},m.allOpenedLabels=i;}static increaseCurrentStepIndex(){if(m._openedLabels.length>0){let e=m._openedLabels[m._openedLabels.length-1];m._openedLabels[m._openedLabels.length-1]={...e,currentStepIndex:e.currentStepIndex+1};}}static set onStepStart(e){m._onStepStart=e;}static get onStepStart(){return async(e,t)=>{let i=[];return m.onLoadingLabel&&e===0&&i.push(m.onLoadingLabel(e,t)),m._onStepStart&&i.push(m._onStepStart(e,t)),await Promise.all(i)}}};E(m,"choiceMadeTemp"),E(m,"lastHistoryStep",null),E(m,"_stepCounter",0),E(m,"_openedLabels",[]),E(m,"_originalOpenedLabels",[]),E(m,"_onStepStart"),E(m,"onLoadingLabel"),E(m,"onStepEnd");var b=m;var Pe=class{get currentStepTimesCounter(){return b.getCurrentStepTimesCounter()}set currentStepTimesCounter(e){b.resetCurrentStepTimesCounter();}getRandomNumber(e,t,i={}){return b.getRandomNumber(e,t,i)}get stepCounter(){return b._stepCounter}get openedLabels(){return b.openedLabels}get currentLabel(){return b._currentLabel}addStepHistory(e,t={}){let{choiceMade:i,ignoreSameStep:n}=t,s,a,l,u=core.GameUnifier.getVariable(v.LAST_STEP_GLUED)===this.stepCounter;core.GameUnifier.getVariable(v.LAST_DIALOGUE_ADDED_IN_STEP_MEMORY_KEY)===this.stepCounter&&(s=core.GameUnifier.getVariable(v.CURRENT_DIALOGUE_MEMORY_KEY)),core.GameUnifier.getVariable(v.LAST_MENU_OPTIONS_ADDED_IN_STEP_MEMORY_KEY)===this.stepCounter&&(a=core.GameUnifier.getVariable(v.CURRENT_MENU_OPTIONS_MEMORY_KEY)),core.GameUnifier.getVariable(v.LAST_INPUT_ADDED_IN_STEP_MEMORY_KEY)===this.stepCounter&&(l=core.GameUnifier.getVariable(v.CURRENT_INPUT_VALUE_MEMORY_KEY));let S=b.openedLabels,d={currentLabel:b.currentLabelId,dialogue:s,choices:a,stepSha1:e,index:this.stepCounter,labelStepIndex:b.currentLabelStepIndex,choiceIndexMade:i,inputValue:l,alreadyMadeChoices:this.alreadyCurrentStepMadeChoices,isGlued:u,openedLabels:S};b.originalOpenedLabels=S,core.GameUnifier.addHistoryItem(d,{ignoreSameStep:n}),b.lastHistoryStep=d,b.increaseStepCounter();}closeCurrentLabel(){if(!b.currentLabelId){_.warn("No label to close");return}if(!this.currentLabel){_.error("currentLabel not found");return}let e=b.openedLabels;e.pop(),b.openedLabels=e,core.GameUnifier.onLabelClosing(this.openedLabels.length);}closeAllLabels(){for(;b.openedLabels.length>0;)this.closeCurrentLabel(),core.GameUnifier.onLabelClosing(this.openedLabels.length);}isLabelAlreadyCompleted(e){let t;typeof e=="string"?t=e:t=e.id;let n=b.allOpenedLabels[t]?.biggestStep||0;if(n){let s=ae.get(t);if(s)return s.stepCount<=n}return false}get alreadyCurrentStepMadeChoicesObj(){let e=b.currentLabelStepIndex,t=this.currentLabel;if(e===null||!t)return;let i=t.getStepSha(e);return i||(_.warn("stepSha not found, setting to ERROR"),i="error"),b.allChoicesMade.filter(n=>n.labelId===t?.id&&n.stepIndex===e&&n.stepSha1===i)}get alreadyCurrentStepMadeChoices(){return this.alreadyCurrentStepMadeChoicesObj?.map(e=>e.choiceIndex)}get isCurrentStepAlreadyOpened(){let e=b.currentLabelId;if(e){let t=b.allOpenedLabels[e]?.openCount||0;if(b.currentLabelStepIndex&&t>=b.currentLabelStepIndex)return true}return false}getTimesLabelOpened(e){return b.allOpenedLabels[e]?.openCount||0}getTimesChoiceMade(e){return this.alreadyCurrentStepMadeChoicesObj?.find(t=>t.choiceIndex===e)?.madeTimes||0}addCurrentStepToHistory(){this.addStepHistory("dev",{ignoreSameStep:true});}getCanContinue(e){let t=e?.showWarn||false,i=this.choices;return i&&i.length>0?(t&&_.warn("The player must make a choice"),false):this.isRequiredInput?(t&&_.warn("The player must enter a value"),false):true}get canContinue(){return core.GameUnifier.runningStepsCount!==0?false:this.getCanContinue()}async onStepStart(e,t){let i=[];return e.onStepStart&&i.push(e.onStepStart(t,e)),b.onStepStart&&i.push(b.onStepStart(t,e)),await Promise.all(i)}async onStepEnd(e,t){let i=[];return e.onStepEnd&&i.push(e.onStepEnd(t,e)),b.onStepEnd&&i.push(b.onStepEnd(t,e)),await Promise.all(i)}async continue(e,t={}){let{runNow:i=false,steps:n=1}=t;if(!Number.isFinite(n)){_.warn(`[continue] The parameter steps must be a valid finite number, received: ${n}`);return}if(n<=0){_.warn(`[continue] The parameter steps must be greater than 0, received: ${n}`);return}if(!i&&!this.getCanContinue({showWarn:true}))return;if(!i&&core.GameUnifier.runningStepsCount!==0){core.GameUnifier.increaseContinueRequest(n);return}n>1&&core.GameUnifier.increaseContinueRequest(n-1),core.GameUnifier.runningStepsCount++;let s;try{core.GameUnifier.runningStepsCount===1&&await core.GameUnifier.onPreContinue(),b.increaseCurrentStepIndex(),s=await this.runCurrentStep(e,t);}catch(a){throw _.error("Error continuing",a),a}finally{core.GameUnifier.runningStepsCount--,s=await this.afterRunCurrentStep(e)||s;}return s}async afterRunCurrentStep(e){if(core.GameUnifier.runningStepsCount===0&&core.GameUnifier.continueRequestsCount!==0)return await core.GameUnifier.processNavigationRequests(e);if(this.openedLabels.length===0){if(core.GameUnifier.onEnd)return await core.GameUnifier.onEnd(e,{labelId:"end"});_.error("The end of the game is not managed, so the game is blocked. Read this documentation to know how to manage the end of the game: https://pixi-vn.web.app/start/other-narrative-features.html#how-manage-the-end-of-the-game");}}async runCurrentStep(e,t={}){let{choiceMade:i}=t;if(b.currentLabelId){let n=b.currentLabelStepIndex;if(n===null){_.error("currentLabelStepIndex is null");return}let s=b._currentLabel;if(!s){_.error("currentLabel not found");return}if(s.stepCount>n){try{await this.onStepStart(s,n);}catch(d){_.error("Error running onStepStart",d),this.onStepError&&await this.onStepError(d,e);return}let a=s.getStepById(n);if(!a){_.error("step not found");return}let l=s.getStepSha(n);l||(_.warn("stepSha not found, setting to ERROR"),l="error");let u,S;try{u=await a(e,{labelId:s.id});}catch(d){_.error("Error running step",d),S=d;}try{let d=this.choices;if(d?.length===1&&d[0].autoSelect){let L=d[0];u=await this.selectChoice(L,e);}}catch(d){_.error("Error auto-selecting choice",d),S===void 0&&(S=d);}try{let d=b.lastHistoryStep;i!==void 0&&d&&(l=d.stepSha1,l||(_.warn("stepSha not found, setting to ERROR"),l="error"),b.addChoicesMade(d.currentLabel||"error",typeof d.labelStepIndex=="number"?d.labelStepIndex:-1,d.stepSha1||"error",i),b.choiceMadeTemp=i);}catch(d){_.warn("Error adding choice made to history",d);}try{core.GameUnifier.runningStepsCount===1&&(b.addLabelHistory(s.id,n),this.addStepHistory(l,{...t,choiceMade:b.choiceMadeTemp}),b.choiceMadeTemp=void 0);}catch(d){_.warn("Error adding step to history",d);}try{this.currentLabel&&await this.onStepEnd(this.currentLabel,b.currentLabelStepIndex||0);}catch(d){_.warn("Error running onStepEnd",d);}return S&&this.onStepError&&await this.onStepError(S,e),u}else {if(this.openedLabels.length>1)return this.closeCurrentLabel(),await this.continue(e,t);if(this.openedLabels.length===1){b.openedLabels=[];return}}}else {if(this.openedLabels.length===0)return;_.error("currentLabelId not found");}}async call(e,t,i){let{choiceMade:n}=i||{},s;typeof e=="string"?s=e:s=e.id,core.GameUnifier.runningStepsCount++;let a;try{let l=ae.get(s);if(!l)throw new core.PixiError("unregistered_element",`Label ${s} not found`);b.pushNewLabel(l.id),a=await this.runCurrentStep(t,{choiceMade:n});}catch(l){throw _.error("Error calling label",l),l}finally{core.GameUnifier.runningStepsCount--,a=await this.afterRunCurrentStep(t)||a;}return a}async jump(e,t,i){if(this.stepCounter===0)return await this.call(e,t,i);this.openedLabels.length>0&&this.closeCurrentLabel();let{choiceMade:n}=i||{},s;typeof e=="string"?s=e:s=e.id,core.GameUnifier.runningStepsCount++;let a;try{let l=ae.get(s);if(!l)throw new core.PixiError("unregistered_element",`Label ${s} not found`);b.pushNewLabel(l.id),a=await this.runCurrentStep(t,{choiceMade:n});}catch(l){throw _.error("Error jumping to label",l),l}finally{core.GameUnifier.runningStepsCount--,a=await this.afterRunCurrentStep(t)||a;}return a}async selectChoice(e,t){this.choices=void 0;let i=e.type;switch(i){case "call":return await this.call(e.label,{...e.props,...t},{choiceMade:e.choiceIndex});case "jump":return await this.jump(e.label,{...e.props,...t},{choiceMade:e.choiceIndex});case "close":return await this.closeChoiceMenu(e,{...e.props,...t});default:throw _.error(`Type ${i} not found`),new core.PixiError("invalid_usage",`Type ${i} not found`)}}async closeChoiceMenu(e,t){if(e.type!=="close")throw _.error("For closeChoiceMenu, the type must be close"),new core.PixiError("invalid_usage","For closeChoiceMenu, the type must be close");let i;return typeof e.choiceIndex=="number"&&(i=e.choiceIndex),e.closeCurrentLabel&&this.closeCurrentLabel(),await this.continue(t,{choiceMade:i})}get onStepError(){let e=core.GameUnifier.onError;if(e)return async(t,i)=>{try{return await e("step",t,i)}catch(n){_.error("Error in onError handler",n);}}}set onStepError(e){core.GameUnifier.onError=(t,i,n)=>e(i,n);}get dialogue(){let e=core.GameUnifier.getVariable(v.CURRENT_DIALOGUE_MEMORY_KEY);if(e)return {...e,character:e.character?core.GameUnifier.getCharacter(e.character)||e.character:void 0}}set dialogue(e){if(e===void 0){core.GameUnifier.setVariable(v.CURRENT_DIALOGUE_MEMORY_KEY,void 0);return}if((typeof e=="string"||Array.isArray(e))&&(e={text:e}),this.dialogGlue){let t=core.GameUnifier.getVariable(v.CURRENT_DIALOGUE_MEMORY_KEY);if(t){let i=[];Array.isArray(t.text)?i=[...t.text]:i=[t.text],Array.isArray(e.text)?i=[...i,...e.text]:i=[...i,e.text],e.text=i,e.character=e.character||t.character;}core.GameUnifier.setVariable(v.LAST_STEP_GLUED,this.stepCounter),this.dialogGlue=false;}try{core.GameUnifier.setVariable(v.CURRENT_DIALOGUE_MEMORY_KEY,le({...e,character:typeof e.character=="string"?e.character:e.character?.id})),core.GameUnifier.setVariable(v.LAST_DIALOGUE_ADDED_IN_STEP_MEMORY_KEY,this.stepCounter);}catch{throw _.error("DialogueInterface cannot contain functions or classes"),new core.PixiError("not_json_serializable","ChoiceInterface cannot contain functions or classes")}}get choices(){let e=core.GameUnifier.getVariable(v.CURRENT_MENU_OPTIONS_MEMORY_KEY);if(e){let t=[],i=e.map((s,a)=>({...s,choiceIndex:a})),n=this.alreadyCurrentStepMadeChoices;if(i=i.filter((s,a)=>s.oneTime&&n&&n.includes(a)?false:s.onlyHaveNoChoice?(t.push(s),false):true),i.length>0)return i;if(t.length>0)return [t[0]]}}set choices(e){if(!e||e.length===0){core.GameUnifier.setVariable(v.CURRENT_MENU_OPTIONS_MEMORY_KEY,void 0);return}try{core.GameUnifier.setVariable(v.CURRENT_MENU_OPTIONS_MEMORY_KEY,le(e)),core.GameUnifier.setVariable(v.LAST_MENU_OPTIONS_ADDED_IN_STEP_MEMORY_KEY,this.stepCounter);}catch{throw _.error("ChoiceInterface cannot contain functions or classes"),new core.PixiError("not_json_serializable","ChoiceInterface cannot contain functions or classes")}}get dialogGlue(){return core.GameUnifier.getFlag(v.ADD_NEXT_DIALOG_TEXT_INTO_THE_CURRENT_DIALOG_FLAG_KEY)}set dialogGlue(e){core.GameUnifier.setFlag(v.ADD_NEXT_DIALOG_TEXT_INTO_THE_CURRENT_DIALOG_FLAG_KEY,e);}get inputValue(){return core.GameUnifier.getVariable(v.CURRENT_INPUT_VALUE_MEMORY_KEY)}set inputValue(e){this.removeInputRequest(),core.GameUnifier.setVariable(v.CURRENT_INPUT_VALUE_MEMORY_KEY,e),core.GameUnifier.setVariable(v.LAST_INPUT_ADDED_IN_STEP_MEMORY_KEY,this.stepCounter);}get isRequiredInput(){return core.GameUnifier.getVariable(v.CURRENT_INPUT_INFO_MEMORY_KEY)?.isRequired||false}get inputType(){return core.GameUnifier.getVariable(v.CURRENT_INPUT_INFO_MEMORY_KEY)?.type}requestInput(e,t){e.isRequired=true,core.GameUnifier.setVariable(v.CURRENT_INPUT_INFO_MEMORY_KEY,e),t!==void 0?core.GameUnifier.setVariable(v.CURRENT_INPUT_VALUE_MEMORY_KEY,t):core.GameUnifier.removeVariable(v.CURRENT_INPUT_VALUE_MEMORY_KEY);}removeInputRequest(){core.GameUnifier.removeVariable(v.CURRENT_INPUT_INFO_MEMORY_KEY),core.GameUnifier.removeVariable(v.CURRENT_INPUT_VALUE_MEMORY_KEY);}clear(){b.openedLabels=[],b._stepCounter=0;}export(){return {openedLabels:le(b.openedLabels),stepCounter:this.stepCounter}}async onLoadingLabel(e){let t=this.openedLabels.map(async i=>{let n=[],s=ae.get(i.label);return s&&(s.onLoadingLabel&&n.push(s.onLoadingLabel(e,s)),b.onLoadingLabel&&n.push(b.onLoadingLabel(e,s))),await Promise.all(n)});return await Promise.all(t)}async restore(e,t){this.clear();try{b.lastHistoryStep=t,e.hasOwnProperty("openedLabels")?(b.openedLabels=e.openedLabels,b.originalOpenedLabels=b.openedLabels):_.warn("Could not import openedLabels data, so will be ignored"),e.hasOwnProperty("stepCounter")?b._stepCounter=e.stepCounter:e.hasOwnProperty("lastStepIndex")?b._stepCounter=e.lastStepIndex:_.warn("Could not import stepCounter data, so will be ignored");try{await this.onLoadingLabel(b.currentLabelStepIndex||0);}catch(i){_.error("Error running onLoadingLabel",i);}}catch(i){_.error("Error importing data",i);}}};function xt(h,e,t,i){let n=typeof e=="string"?e:e.id;return {...i,label:n,props:t,text:h,type:i?.type||"call"}}var Ze="close";function At(h,e){return {...e,type:Ze,text:h}}var ft=Et(ct());var xe=class{constructor(e,t){E(this,"id");E(this,"_onStepStart");E(this,"_onLoadingLabel");E(this,"_onStepEnd");this.id=e,this._onStepStart=t?.onStepStart,this._onLoadingLabel=t?.onLoadingLabel,this._onStepEnd=t?.onStepEnd;}get onStepStart(){return async(e,t)=>{if(this._onLoadingLabel&&e===0&&await this._onLoadingLabel(e,t),this._onStepStart)return await this._onStepStart(e,t)}}get onLoadingLabel(){return this._onLoadingLabel}get onStepEnd(){return this._onStepEnd}};var Ae=class extends xe{constructor(t,i,n){super(t,n);E(this,"_steps");this._steps=i;}get stepCount(){return this.steps.length}getStepById(t){return this.steps[t]}get steps(){return typeof this._steps=="function"?this._steps():this._steps}getStepSha(t){if(t<0||t>=this.steps.length)return _.warn("stepSha not found, setting to ERROR"),"error";try{let i=this.steps[t];return (0,ft.default)(i.toString().toLocaleLowerCase()).toString()}catch(i){return _.warn("stepSha not found, setting to ERROR",i),"error"}}};function bt(h,e,t){let i=new Ae(h,e,t);return ae.add(i),i}var Mr=new Pe;
|
|
2
|
+
exports.Close=Ze;exports.Label=Ae;exports.LabelAbstract=xe;exports.NarrationManagerStatic=b;exports.RegisteredLabels=ae;exports.narration=Mr;exports.newChoiceOption=xt;exports.newCloseChoiceOption=At;exports.newLabel=bt;//# sourceMappingURL=narration.cjs.map
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../node_modules/crypto-js/core.js","../node_modules/crypto-js/sha1.js","../src/storage/constants.ts","../src/utils/log-utility.ts","../src/utils/export-utility.ts","../node_modules/lru-cache/src/index.ts","../src/classes/CachedMap.ts","../src/narration/decorators/RegisteredLabels.ts","../src/narration/NarrationManagerStatic.ts","../src/narration/NarrationManager.ts","../src/narration/classes/ChoiceMenuOption.ts","../src/narration/types/CloseType.ts","../src/narration/classes/CloseChoiceOption.ts","../src/narration/classes/Label.ts","../src/narration/classes/LabelAbstract.ts","../src/narration/decorators/newLabel.ts","../src/narration/index.ts"],"names":["require_core","__commonJSMin","exports","module","root","factory","CryptoJS","Math","undefined","crypto","__require","cryptoSecureRandomInt","create","F","obj","subtype","C","C_lib","Base","overrides","instance","properties","propertyName","WordArray","words","sigBytes","encoder","Hex","wordArray","thisWords","thatWords","thisSigBytes","thatSigBytes","i","thatByte","j","clone","nBytes","C_enc","hexChars","bite","hexStr","hexStrLength","Latin1","latin1Chars","latin1Str","latin1StrLength","Utf8","utf8Str","BufferedBlockAlgorithm","data","doFlush","processedWords","dataWords","dataSigBytes","blockSize","blockSizeBytes","nBlocksReady","nWordsReady","nBytesReady","offset","cfg","messageUpdate","hash","hasher","message","key","C_algo","require_sha1","Hasher","W","SHA1","M","H","a","b","c","d","e","n","t","nBitsTotal","nBitsLeft","SYSTEM_RESERVED_STORAGE_KEYS","logger","optionalParams","createExportableElement","element","elementString","PixiError","defaultPerf","warned","PROCESS","emitWarning","msg","type","code","fn","AC","AS","__publicField","_","warnACPolyfill","reason","printACPolyfillWarning","shouldWarn","isPosInt","getUintArray","max","ZeroArray","size","_a","_o","Stack","HeapCls","_Stack","#constructing","s","__privateAdd","_b","_c","_w","_C","_S","_L","_I","_m","_n","__","_s","_i","_t","_u","_l","_h","_r","_y","_A","_d","_g","_T","_v","_f","_U","_c_instances","j_fn","_R","_z","_N","_p","B_fn","_W","_M","_P","F_fn","O_fn","H_fn","x_fn","G_fn","e_fn","k_fn","D_fn","E_fn","V_fn","LRUCache","options","#max","#maxSize","#dispose","#onInsert","#disposeAfter","#fetchMethod","#memoMethod","#perf","#size","#calculatedSize","#keyMap","#keyList","#valList","#next","#prev","#head","#tail","#free","#disposed","#sizes","#starts","#ttls","#autopurgeTimers","#hasDispose","#hasFetchMethod","#hasDisposeAfter","#hasOnInsert","#updateItemAge","#statusTTL","#setItemTTL","#isStale","#removeItemSize","#addItemSize","_st","#requireSize","_k","sizeCalculation","ttl","ttlResolution","ttlAutopurge","updateAgeOnGet","updateAgeOnHas","allowStale","dispose","onInsert","disposeAfter","noDisposeOnSet","noUpdateTTL","maxSize","maxEntrySize","fetchMethod","memoMethod","noDeleteOnFetchRejection","noDeleteOnStaleGet","allowStaleOnFetchRejection","allowStaleOnFetchAbort","ignoreFetchAbort","perf","__privateSet","UintArray","__privateGet","__privateMethod","#initializeSizeTracking","#initializeTTLTracking","_LRUCache","p","#isBackgroundFetch","k","index","context","#backgroundFetch","#moveToTail","#indexes","#rindexes","getOptions","v","value","thisp","deleted","#delete","entry","start","remain","arr","age","setOptions","status","#evict","__privateWrapper","oldVal","oldValue","dt","task","val","hasOptions","peekOptions","fetchOptions","forceRefresh","signal","stale","isStale","staleVal","memoOptions","vv","fetching","#clear","ttls","starts","purgeTimers","setPurgetTimer","cachedNow","getNow","sizes","#isValidIndex","free","head","ac","fetchOpts","cb","updateCache","aborted","ignoreAbort","proceed","fetchFail","bf","vl","eb","er","allowStaleAborted","noDelete","pcall","res","rej","fmp","#connect","pi","ni","CachedMap","L","cachedValue","registeredLabels","RegisteredLabels","get","id","label","add","values","has","keys","RegisteredLabels_default","_NarrationManagerStatic","GameUnifier","nestedId","currentLabelStepIndex","currentLabelStepIndexId","labelId","currentLabel","stepSha1","lastStep","list","item","min","usedRandomNumbers","allNumbers","randomIndex","randomNumber","stepIndex","allOpenedLabels","oldStepIndex","openCount","stepSha","choiceMade","allChoicesMade","alredyMade","biggestStep","stepId","NarrationManagerStatic","NarrationManager","ignoreSameStep","dialogue","choices","inputValue","isGlued","openedLabels","historyInfo","choice","showWarn","choiceMenuOptions","props","runNow","steps","result","step","err","lastHistoryStep","tempLabel","onError","error","glueDialogue","newText","onlyHaveNoChoice","option","alreadyChoices","info","defaultValue","promise","labelInfo","newChoiceOption","text","Close","newCloseChoiceOption","import_sha1","LabelAbstract","Label","sha1","newLabel","narration"],"mappings":"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","file":"narration.cjs","sourcesContent":[";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory();\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\troot.CryptoJS = factory();\n\t}\n}(this, function () {\n\n\t/*globals window, global, require*/\n\n\t/**\n\t * CryptoJS core components.\n\t */\n\tvar CryptoJS = CryptoJS || (function (Math, undefined) {\n\n\t    var crypto;\n\n\t    // Native crypto from window (Browser)\n\t    if (typeof window !== 'undefined' && window.crypto) {\n\t        crypto = window.crypto;\n\t    }\n\n\t    // Native crypto in web worker (Browser)\n\t    if (typeof self !== 'undefined' && self.crypto) {\n\t        crypto = self.crypto;\n\t    }\n\n\t    // Native crypto from worker\n\t    if (typeof globalThis !== 'undefined' && globalThis.crypto) {\n\t        crypto = globalThis.crypto;\n\t    }\n\n\t    // Native (experimental IE 11) crypto from window (Browser)\n\t    if (!crypto && typeof window !== 'undefined' && window.msCrypto) {\n\t        crypto = window.msCrypto;\n\t    }\n\n\t    // Native crypto from global (NodeJS)\n\t    if (!crypto && typeof global !== 'undefined' && global.crypto) {\n\t        crypto = global.crypto;\n\t    }\n\n\t    // Native crypto import via require (NodeJS)\n\t    if (!crypto && typeof require === 'function') {\n\t        try {\n\t            crypto = require('crypto');\n\t        } catch (err) {}\n\t    }\n\n\t    /*\n\t     * Cryptographically secure pseudorandom number generator\n\t     *\n\t     * As Math.random() is cryptographically not safe to use\n\t     */\n\t    var cryptoSecureRandomInt = function () {\n\t        if (crypto) {\n\t            // Use getRandomValues method (Browser)\n\t            if (typeof crypto.getRandomValues === 'function') {\n\t                try {\n\t                    return crypto.getRandomValues(new Uint32Array(1))[0];\n\t                } catch (err) {}\n\t            }\n\n\t            // Use randomBytes method (NodeJS)\n\t            if (typeof crypto.randomBytes === 'function') {\n\t                try {\n\t                    return crypto.randomBytes(4).readInt32LE();\n\t                } catch (err) {}\n\t            }\n\t        }\n\n\t        throw new Error('Native crypto module could not be used to get secure random number.');\n\t    };\n\n\t    /*\n\t     * Local polyfill of Object.create\n\n\t     */\n\t    var create = Object.create || (function () {\n\t        function F() {}\n\n\t        return function (obj) {\n\t            var subtype;\n\n\t            F.prototype = obj;\n\n\t            subtype = new F();\n\n\t            F.prototype = null;\n\n\t            return subtype;\n\t        };\n\t    }());\n\n\t    /**\n\t     * CryptoJS namespace.\n\t     */\n\t    var C = {};\n\n\t    /**\n\t     * Library namespace.\n\t     */\n\t    var C_lib = C.lib = {};\n\n\t    /**\n\t     * Base object for prototypal inheritance.\n\t     */\n\t    var Base = C_lib.Base = (function () {\n\n\n\t        return {\n\t            /**\n\t             * Creates a new object that inherits from this object.\n\t             *\n\t             * @param {Object} overrides Properties to copy into the new object.\n\t             *\n\t             * @return {Object} The new object.\n\t             *\n\t             * @static\n\t             *\n\t             * @example\n\t             *\n\t             *     var MyType = CryptoJS.lib.Base.extend({\n\t             *         field: 'value',\n\t             *\n\t             *         method: function () {\n\t             *         }\n\t             *     });\n\t             */\n\t            extend: function (overrides) {\n\t                // Spawn\n\t                var subtype = create(this);\n\n\t                // Augment\n\t                if (overrides) {\n\t                    subtype.mixIn(overrides);\n\t                }\n\n\t                // Create default initializer\n\t                if (!subtype.hasOwnProperty('init') || this.init === subtype.init) {\n\t                    subtype.init = function () {\n\t                        subtype.$super.init.apply(this, arguments);\n\t                    };\n\t                }\n\n\t                // Initializer's prototype is the subtype object\n\t                subtype.init.prototype = subtype;\n\n\t                // Reference supertype\n\t                subtype.$super = this;\n\n\t                return subtype;\n\t            },\n\n\t            /**\n\t             * Extends this object and runs the init method.\n\t             * Arguments to create() will be passed to init().\n\t             *\n\t             * @return {Object} The new object.\n\t             *\n\t             * @static\n\t             *\n\t             * @example\n\t             *\n\t             *     var instance = MyType.create();\n\t             */\n\t            create: function () {\n\t                var instance = this.extend();\n\t                instance.init.apply(instance, arguments);\n\n\t                return instance;\n\t            },\n\n\t            /**\n\t             * Initializes a newly created object.\n\t             * Override this method to add some logic when your objects are created.\n\t             *\n\t             * @example\n\t             *\n\t             *     var MyType = CryptoJS.lib.Base.extend({\n\t             *         init: function () {\n\t             *             // ...\n\t             *         }\n\t             *     });\n\t             */\n\t            init: function () {\n\t            },\n\n\t            /**\n\t             * Copies properties into this object.\n\t             *\n\t             * @param {Object} properties The properties to mix in.\n\t             *\n\t             * @example\n\t             *\n\t             *     MyType.mixIn({\n\t             *         field: 'value'\n\t             *     });\n\t             */\n\t            mixIn: function (properties) {\n\t                for (var propertyName in properties) {\n\t                    if (properties.hasOwnProperty(propertyName)) {\n\t                        this[propertyName] = properties[propertyName];\n\t                    }\n\t                }\n\n\t                // IE won't copy toString using the loop above\n\t                if (properties.hasOwnProperty('toString')) {\n\t                    this.toString = properties.toString;\n\t                }\n\t            },\n\n\t            /**\n\t             * Creates a copy of this object.\n\t             *\n\t             * @return {Object} The clone.\n\t             *\n\t             * @example\n\t             *\n\t             *     var clone = instance.clone();\n\t             */\n\t            clone: function () {\n\t                return this.init.prototype.extend(this);\n\t            }\n\t        };\n\t    }());\n\n\t    /**\n\t     * An array of 32-bit words.\n\t     *\n\t     * @property {Array} words The array of 32-bit words.\n\t     * @property {number} sigBytes The number of significant bytes in this word array.\n\t     */\n\t    var WordArray = C_lib.WordArray = Base.extend({\n\t        /**\n\t         * Initializes a newly created word array.\n\t         *\n\t         * @param {Array} words (Optional) An array of 32-bit words.\n\t         * @param {number} sigBytes (Optional) The number of significant bytes in the words.\n\t         *\n\t         * @example\n\t         *\n\t         *     var wordArray = CryptoJS.lib.WordArray.create();\n\t         *     var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607]);\n\t         *     var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607], 6);\n\t         */\n\t        init: function (words, sigBytes) {\n\t            words = this.words = words || [];\n\n\t            if (sigBytes != undefined) {\n\t                this.sigBytes = sigBytes;\n\t            } else {\n\t                this.sigBytes = words.length * 4;\n\t            }\n\t        },\n\n\t        /**\n\t         * Converts this word array to a string.\n\t         *\n\t         * @param {Encoder} encoder (Optional) The encoding strategy to use. Default: CryptoJS.enc.Hex\n\t         *\n\t         * @return {string} The stringified word array.\n\t         *\n\t         * @example\n\t         *\n\t         *     var string = wordArray + '';\n\t         *     var string = wordArray.toString();\n\t         *     var string = wordArray.toString(CryptoJS.enc.Utf8);\n\t         */\n\t        toString: function (encoder) {\n\t            return (encoder || Hex).stringify(this);\n\t        },\n\n\t        /**\n\t         * Concatenates a word array to this word array.\n\t         *\n\t         * @param {WordArray} wordArray The word array to append.\n\t         *\n\t         * @return {WordArray} This word array.\n\t         *\n\t         * @example\n\t         *\n\t         *     wordArray1.concat(wordArray2);\n\t         */\n\t        concat: function (wordArray) {\n\t            // Shortcuts\n\t            var thisWords = this.words;\n\t            var thatWords = wordArray.words;\n\t            var thisSigBytes = this.sigBytes;\n\t            var thatSigBytes = wordArray.sigBytes;\n\n\t            // Clamp excess bits\n\t            this.clamp();\n\n\t            // Concat\n\t            if (thisSigBytes % 4) {\n\t                // Copy one byte at a time\n\t                for (var i = 0; i < thatSigBytes; i++) {\n\t                    var thatByte = (thatWords[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t                    thisWords[(thisSigBytes + i) >>> 2] |= thatByte << (24 - ((thisSigBytes + i) % 4) * 8);\n\t                }\n\t            } else {\n\t                // Copy one word at a time\n\t                for (var j = 0; j < thatSigBytes; j += 4) {\n\t                    thisWords[(thisSigBytes + j) >>> 2] = thatWords[j >>> 2];\n\t                }\n\t            }\n\t            this.sigBytes += thatSigBytes;\n\n\t            // Chainable\n\t            return this;\n\t        },\n\n\t        /**\n\t         * Removes insignificant bits.\n\t         *\n\t         * @example\n\t         *\n\t         *     wordArray.clamp();\n\t         */\n\t        clamp: function () {\n\t            // Shortcuts\n\t            var words = this.words;\n\t            var sigBytes = this.sigBytes;\n\n\t            // Clamp\n\t            words[sigBytes >>> 2] &= 0xffffffff << (32 - (sigBytes % 4) * 8);\n\t            words.length = Math.ceil(sigBytes / 4);\n\t        },\n\n\t        /**\n\t         * Creates a copy of this word array.\n\t         *\n\t         * @return {WordArray} The clone.\n\t         *\n\t         * @example\n\t         *\n\t         *     var clone = wordArray.clone();\n\t         */\n\t        clone: function () {\n\t            var clone = Base.clone.call(this);\n\t            clone.words = this.words.slice(0);\n\n\t            return clone;\n\t        },\n\n\t        /**\n\t         * Creates a word array filled with random bytes.\n\t         *\n\t         * @param {number} nBytes The number of random bytes to generate.\n\t         *\n\t         * @return {WordArray} The random word array.\n\t         *\n\t         * @static\n\t         *\n\t         * @example\n\t         *\n\t         *     var wordArray = CryptoJS.lib.WordArray.random(16);\n\t         */\n\t        random: function (nBytes) {\n\t            var words = [];\n\n\t            for (var i = 0; i < nBytes; i += 4) {\n\t                words.push(cryptoSecureRandomInt());\n\t            }\n\n\t            return new WordArray.init(words, nBytes);\n\t        }\n\t    });\n\n\t    /**\n\t     * Encoder namespace.\n\t     */\n\t    var C_enc = C.enc = {};\n\n\t    /**\n\t     * Hex encoding strategy.\n\t     */\n\t    var Hex = C_enc.Hex = {\n\t        /**\n\t         * Converts a word array to a hex string.\n\t         *\n\t         * @param {WordArray} wordArray The word array.\n\t         *\n\t         * @return {string} The hex string.\n\t         *\n\t         * @static\n\t         *\n\t         * @example\n\t         *\n\t         *     var hexString = CryptoJS.enc.Hex.stringify(wordArray);\n\t         */\n\t        stringify: function (wordArray) {\n\t            // Shortcuts\n\t            var words = wordArray.words;\n\t            var sigBytes = wordArray.sigBytes;\n\n\t            // Convert\n\t            var hexChars = [];\n\t            for (var i = 0; i < sigBytes; i++) {\n\t                var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t                hexChars.push((bite >>> 4).toString(16));\n\t                hexChars.push((bite & 0x0f).toString(16));\n\t            }\n\n\t            return hexChars.join('');\n\t        },\n\n\t        /**\n\t         * Converts a hex string to a word array.\n\t         *\n\t         * @param {string} hexStr The hex string.\n\t         *\n\t         * @return {WordArray} The word array.\n\t         *\n\t         * @static\n\t         *\n\t         * @example\n\t         *\n\t         *     var wordArray = CryptoJS.enc.Hex.parse(hexString);\n\t         */\n\t        parse: function (hexStr) {\n\t            // Shortcut\n\t            var hexStrLength = hexStr.length;\n\n\t            // Convert\n\t            var words = [];\n\t            for (var i = 0; i < hexStrLength; i += 2) {\n\t                words[i >>> 3] |= parseInt(hexStr.substr(i, 2), 16) << (24 - (i % 8) * 4);\n\t            }\n\n\t            return new WordArray.init(words, hexStrLength / 2);\n\t        }\n\t    };\n\n\t    /**\n\t     * Latin1 encoding strategy.\n\t     */\n\t    var Latin1 = C_enc.Latin1 = {\n\t        /**\n\t         * Converts a word array to a Latin1 string.\n\t         *\n\t         * @param {WordArray} wordArray The word array.\n\t         *\n\t         * @return {string} The Latin1 string.\n\t         *\n\t         * @static\n\t         *\n\t         * @example\n\t         *\n\t         *     var latin1String = CryptoJS.enc.Latin1.stringify(wordArray);\n\t         */\n\t        stringify: function (wordArray) {\n\t            // Shortcuts\n\t            var words = wordArray.words;\n\t            var sigBytes = wordArray.sigBytes;\n\n\t            // Convert\n\t            var latin1Chars = [];\n\t            for (var i = 0; i < sigBytes; i++) {\n\t                var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t                latin1Chars.push(String.fromCharCode(bite));\n\t            }\n\n\t            return latin1Chars.join('');\n\t        },\n\n\t        /**\n\t         * Converts a Latin1 string to a word array.\n\t         *\n\t         * @param {string} latin1Str The Latin1 string.\n\t         *\n\t         * @return {WordArray} The word array.\n\t         *\n\t         * @static\n\t         *\n\t         * @example\n\t         *\n\t         *     var wordArray = CryptoJS.enc.Latin1.parse(latin1String);\n\t         */\n\t        parse: function (latin1Str) {\n\t            // Shortcut\n\t            var latin1StrLength = latin1Str.length;\n\n\t            // Convert\n\t            var words = [];\n\t            for (var i = 0; i < latin1StrLength; i++) {\n\t                words[i >>> 2] |= (latin1Str.charCodeAt(i) & 0xff) << (24 - (i % 4) * 8);\n\t            }\n\n\t            return new WordArray.init(words, latin1StrLength);\n\t        }\n\t    };\n\n\t    /**\n\t     * UTF-8 encoding strategy.\n\t     */\n\t    var Utf8 = C_enc.Utf8 = {\n\t        /**\n\t         * Converts a word array to a UTF-8 string.\n\t         *\n\t         * @param {WordArray} wordArray The word array.\n\t         *\n\t         * @return {string} The UTF-8 string.\n\t         *\n\t         * @static\n\t         *\n\t         * @example\n\t         *\n\t         *     var utf8String = CryptoJS.enc.Utf8.stringify(wordArray);\n\t         */\n\t        stringify: function (wordArray) {\n\t            try {\n\t                return decodeURIComponent(escape(Latin1.stringify(wordArray)));\n\t            } catch (e) {\n\t                throw new Error('Malformed UTF-8 data');\n\t            }\n\t        },\n\n\t        /**\n\t         * Converts a UTF-8 string to a word array.\n\t         *\n\t         * @param {string} utf8Str The UTF-8 string.\n\t         *\n\t         * @return {WordArray} The word array.\n\t         *\n\t         * @static\n\t         *\n\t         * @example\n\t         *\n\t         *     var wordArray = CryptoJS.enc.Utf8.parse(utf8String);\n\t         */\n\t        parse: function (utf8Str) {\n\t            return Latin1.parse(unescape(encodeURIComponent(utf8Str)));\n\t        }\n\t    };\n\n\t    /**\n\t     * Abstract buffered block algorithm template.\n\t     *\n\t     * The property blockSize must be implemented in a concrete subtype.\n\t     *\n\t     * @property {number} _minBufferSize The number of blocks that should be kept unprocessed in the buffer. Default: 0\n\t     */\n\t    var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm = Base.extend({\n\t        /**\n\t         * Resets this block algorithm's data buffer to its initial state.\n\t         *\n\t         * @example\n\t         *\n\t         *     bufferedBlockAlgorithm.reset();\n\t         */\n\t        reset: function () {\n\t            // Initial values\n\t            this._data = new WordArray.init();\n\t            this._nDataBytes = 0;\n\t        },\n\n\t        /**\n\t         * Adds new data to this block algorithm's buffer.\n\t         *\n\t         * @param {WordArray|string} data The data to append. Strings are converted to a WordArray using UTF-8.\n\t         *\n\t         * @example\n\t         *\n\t         *     bufferedBlockAlgorithm._append('data');\n\t         *     bufferedBlockAlgorithm._append(wordArray);\n\t         */\n\t        _append: function (data) {\n\t            // Convert string to WordArray, else assume WordArray already\n\t            if (typeof data == 'string') {\n\t                data = Utf8.parse(data);\n\t            }\n\n\t            // Append\n\t            this._data.concat(data);\n\t            this._nDataBytes += data.sigBytes;\n\t        },\n\n\t        /**\n\t         * Processes available data blocks.\n\t         *\n\t         * This method invokes _doProcessBlock(offset), which must be implemented by a concrete subtype.\n\t         *\n\t         * @param {boolean} doFlush Whether all blocks and partial blocks should be processed.\n\t         *\n\t         * @return {WordArray} The processed data.\n\t         *\n\t         * @example\n\t         *\n\t         *     var processedData = bufferedBlockAlgorithm._process();\n\t         *     var processedData = bufferedBlockAlgorithm._process(!!'flush');\n\t         */\n\t        _process: function (doFlush) {\n\t            var processedWords;\n\n\t            // Shortcuts\n\t            var data = this._data;\n\t            var dataWords = data.words;\n\t            var dataSigBytes = data.sigBytes;\n\t            var blockSize = this.blockSize;\n\t            var blockSizeBytes = blockSize * 4;\n\n\t            // Count blocks ready\n\t            var nBlocksReady = dataSigBytes / blockSizeBytes;\n\t            if (doFlush) {\n\t                // Round up to include partial blocks\n\t                nBlocksReady = Math.ceil(nBlocksReady);\n\t            } else {\n\t                // Round down to include only full blocks,\n\t                // less the number of blocks that must remain in the buffer\n\t                nBlocksReady = Math.max((nBlocksReady | 0) - this._minBufferSize, 0);\n\t            }\n\n\t            // Count words ready\n\t            var nWordsReady = nBlocksReady * blockSize;\n\n\t            // Count bytes ready\n\t            var nBytesReady = Math.min(nWordsReady * 4, dataSigBytes);\n\n\t            // Process blocks\n\t            if (nWordsReady) {\n\t                for (var offset = 0; offset < nWordsReady; offset += blockSize) {\n\t                    // Perform concrete-algorithm logic\n\t                    this._doProcessBlock(dataWords, offset);\n\t                }\n\n\t                // Remove processed words\n\t                processedWords = dataWords.splice(0, nWordsReady);\n\t                data.sigBytes -= nBytesReady;\n\t            }\n\n\t            // Return processed words\n\t            return new WordArray.init(processedWords, nBytesReady);\n\t        },\n\n\t        /**\n\t         * Creates a copy of this object.\n\t         *\n\t         * @return {Object} The clone.\n\t         *\n\t         * @example\n\t         *\n\t         *     var clone = bufferedBlockAlgorithm.clone();\n\t         */\n\t        clone: function () {\n\t            var clone = Base.clone.call(this);\n\t            clone._data = this._data.clone();\n\n\t            return clone;\n\t        },\n\n\t        _minBufferSize: 0\n\t    });\n\n\t    /**\n\t     * Abstract hasher template.\n\t     *\n\t     * @property {number} blockSize The number of 32-bit words this hasher operates on. Default: 16 (512 bits)\n\t     */\n\t    var Hasher = C_lib.Hasher = BufferedBlockAlgorithm.extend({\n\t        /**\n\t         * Configuration options.\n\t         */\n\t        cfg: Base.extend(),\n\n\t        /**\n\t         * Initializes a newly created hasher.\n\t         *\n\t         * @param {Object} cfg (Optional) The configuration options to use for this hash computation.\n\t         *\n\t         * @example\n\t         *\n\t         *     var hasher = CryptoJS.algo.SHA256.create();\n\t         */\n\t        init: function (cfg) {\n\t            // Apply config defaults\n\t            this.cfg = this.cfg.extend(cfg);\n\n\t            // Set initial values\n\t            this.reset();\n\t        },\n\n\t        /**\n\t         * Resets this hasher to its initial state.\n\t         *\n\t         * @example\n\t         *\n\t         *     hasher.reset();\n\t         */\n\t        reset: function () {\n\t            // Reset data buffer\n\t            BufferedBlockAlgorithm.reset.call(this);\n\n\t            // Perform concrete-hasher logic\n\t            this._doReset();\n\t        },\n\n\t        /**\n\t         * Updates this hasher with a message.\n\t         *\n\t         * @param {WordArray|string} messageUpdate The message to append.\n\t         *\n\t         * @return {Hasher} This hasher.\n\t         *\n\t         * @example\n\t         *\n\t         *     hasher.update('message');\n\t         *     hasher.update(wordArray);\n\t         */\n\t        update: function (messageUpdate) {\n\t            // Append\n\t            this._append(messageUpdate);\n\n\t            // Update the hash\n\t            this._process();\n\n\t            // Chainable\n\t            return this;\n\t        },\n\n\t        /**\n\t         * Finalizes the hash computation.\n\t         * Note that the finalize operation is effectively a destructive, read-once operation.\n\t         *\n\t         * @param {WordArray|string} messageUpdate (Optional) A final message update.\n\t         *\n\t         * @return {WordArray} The hash.\n\t         *\n\t         * @example\n\t         *\n\t         *     var hash = hasher.finalize();\n\t         *     var hash = hasher.finalize('message');\n\t         *     var hash = hasher.finalize(wordArray);\n\t         */\n\t        finalize: function (messageUpdate) {\n\t            // Final message update\n\t            if (messageUpdate) {\n\t                this._append(messageUpdate);\n\t            }\n\n\t            // Perform concrete-hasher logic\n\t            var hash = this._doFinalize();\n\n\t            return hash;\n\t        },\n\n\t        blockSize: 512/32,\n\n\t        /**\n\t         * Creates a shortcut function to a hasher's object interface.\n\t         *\n\t         * @param {Hasher} hasher The hasher to create a helper for.\n\t         *\n\t         * @return {Function} The shortcut function.\n\t         *\n\t         * @static\n\t         *\n\t         * @example\n\t         *\n\t         *     var SHA256 = CryptoJS.lib.Hasher._createHelper(CryptoJS.algo.SHA256);\n\t         */\n\t        _createHelper: function (hasher) {\n\t            return function (message, cfg) {\n\t                return new hasher.init(cfg).finalize(message);\n\t            };\n\t        },\n\n\t        /**\n\t         * Creates a shortcut function to the HMAC's object interface.\n\t         *\n\t         * @param {Hasher} hasher The hasher to use in this HMAC helper.\n\t         *\n\t         * @return {Function} The shortcut function.\n\t         *\n\t         * @static\n\t         *\n\t         * @example\n\t         *\n\t         *     var HmacSHA256 = CryptoJS.lib.Hasher._createHmacHelper(CryptoJS.algo.SHA256);\n\t         */\n\t        _createHmacHelper: function (hasher) {\n\t            return function (message, key) {\n\t                return new C_algo.HMAC.init(hasher, key).finalize(message);\n\t            };\n\t        }\n\t    });\n\n\t    /**\n\t     * Algorithm namespace.\n\t     */\n\t    var C_algo = C.algo = {};\n\n\t    return C;\n\t}(Math));\n\n\n\treturn CryptoJS;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t    // Shortcuts\n\t    var C = CryptoJS;\n\t    var C_lib = C.lib;\n\t    var WordArray = C_lib.WordArray;\n\t    var Hasher = C_lib.Hasher;\n\t    var C_algo = C.algo;\n\n\t    // Reusable object\n\t    var W = [];\n\n\t    /**\n\t     * SHA-1 hash algorithm.\n\t     */\n\t    var SHA1 = C_algo.SHA1 = Hasher.extend({\n\t        _doReset: function () {\n\t            this._hash = new WordArray.init([\n\t                0x67452301, 0xefcdab89,\n\t                0x98badcfe, 0x10325476,\n\t                0xc3d2e1f0\n\t            ]);\n\t        },\n\n\t        _doProcessBlock: function (M, offset) {\n\t            // Shortcut\n\t            var H = this._hash.words;\n\n\t            // Working variables\n\t            var a = H[0];\n\t            var b = H[1];\n\t            var c = H[2];\n\t            var d = H[3];\n\t            var e = H[4];\n\n\t            // Computation\n\t            for (var i = 0; i < 80; i++) {\n\t                if (i < 16) {\n\t                    W[i] = M[offset + i] | 0;\n\t                } else {\n\t                    var n = W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16];\n\t                    W[i] = (n << 1) | (n >>> 31);\n\t                }\n\n\t                var t = ((a << 5) | (a >>> 27)) + e + W[i];\n\t                if (i < 20) {\n\t                    t += ((b & c) | (~b & d)) + 0x5a827999;\n\t                } else if (i < 40) {\n\t                    t += (b ^ c ^ d) + 0x6ed9eba1;\n\t                } else if (i < 60) {\n\t                    t += ((b & c) | (b & d) | (c & d)) - 0x70e44324;\n\t                } else /* if (i < 80) */ {\n\t                    t += (b ^ c ^ d) - 0x359d3e2a;\n\t                }\n\n\t                e = d;\n\t                d = c;\n\t                c = (b << 30) | (b >>> 2);\n\t                b = a;\n\t                a = t;\n\t            }\n\n\t            // Intermediate hash value\n\t            H[0] = (H[0] + a) | 0;\n\t            H[1] = (H[1] + b) | 0;\n\t            H[2] = (H[2] + c) | 0;\n\t            H[3] = (H[3] + d) | 0;\n\t            H[4] = (H[4] + e) | 0;\n\t        },\n\n\t        _doFinalize: function () {\n\t            // Shortcuts\n\t            var data = this._data;\n\t            var dataWords = data.words;\n\n\t            var nBitsTotal = this._nDataBytes * 8;\n\t            var nBitsLeft = data.sigBytes * 8;\n\n\t            // Add padding\n\t            dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\t            dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = Math.floor(nBitsTotal / 0x100000000);\n\t            dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = nBitsTotal;\n\t            data.sigBytes = dataWords.length * 4;\n\n\t            // Hash final blocks\n\t            this._process();\n\n\t            // Return final computed hash\n\t            return this._hash;\n\t        },\n\n\t        clone: function () {\n\t            var clone = Hasher.clone.call(this);\n\t            clone._hash = this._hash.clone();\n\n\t            return clone;\n\t        }\n\t    });\n\n\t    /**\n\t     * Shortcut function to the hasher's object interface.\n\t     *\n\t     * @param {WordArray|string} message The message to hash.\n\t     *\n\t     * @return {WordArray} The hash.\n\t     *\n\t     * @static\n\t     *\n\t     * @example\n\t     *\n\t     *     var hash = CryptoJS.SHA1('message');\n\t     *     var hash = CryptoJS.SHA1(wordArray);\n\t     */\n\t    C.SHA1 = Hasher._createHelper(SHA1);\n\n\t    /**\n\t     * Shortcut function to the HMAC's object interface.\n\t     *\n\t     * @param {WordArray|string} message The message to hash.\n\t     * @param {WordArray|string} key The secret key.\n\t     *\n\t     * @return {WordArray} The HMAC.\n\t     *\n\t     * @static\n\t     *\n\t     * @example\n\t     *\n\t     *     var hmac = CryptoJS.HmacSHA1(message, key);\n\t     */\n\t    C.HmacSHA1 = Hasher._createHmacHelper(SHA1);\n\t}());\n\n\n\treturn CryptoJS.SHA1;\n\n}));","export const SYSTEM_RESERVED_STORAGE_KEYS = {\n    /**\n     * The key of the current dialogue memory\n     */\n    CURRENT_DIALOGUE_MEMORY_KEY: \"___current_dialogue_memory___\",\n    /**\n     * The key of the last dialogue added in the step memory\n     */\n    LAST_DIALOGUE_ADDED_IN_STEP_MEMORY_KEY: \"___last_dialogue_added_in_step_memory___\",\n    /**\n     * The key of the current menu options memory\n     */\n    CURRENT_MENU_OPTIONS_MEMORY_KEY: \"___current_menu_options_memory___\",\n    /**\n     * The key of the last menu options added in the step memory\n     */\n    LAST_MENU_OPTIONS_ADDED_IN_STEP_MEMORY_KEY: \"___last_menu_options_added_in_step_memory___\",\n    /**\n     * The key of the input memory. This value can be read by pixi-vn json importer\n     */\n    CURRENT_INPUT_VALUE_MEMORY_KEY: \"_input_value_\",\n    /**\n     * The key of the last input added in the step memory\n     */\n    LAST_INPUT_ADDED_IN_STEP_MEMORY_KEY: \"___last_input_added_in_step_memory___\",\n    /**\n     * The key of the current input info\n     */\n    CURRENT_INPUT_INFO_MEMORY_KEY: \"___current_input_info_memory___\",\n    /**\n     * The key of the characters memory\n     */\n    CHARACTER_CATEGORY_KEY: \"___character___\",\n    /**\n     * This variable is used to add the next dialog text into the current dialog memory.\n     * This value was added to introduce Ink Glue functionality https://github.com/inkle/ink/blob/master/Documentation/WritingWithInk.md#glue\n     */\n    ADD_NEXT_DIALOG_TEXT_INTO_THE_CURRENT_DIALOG_FLAG_KEY: \"___glue___\",\n    /**\n     * The key of a list of all labels that have been opened during the progression of the steps.\n     */\n    OPENED_LABELS_COUNTER_KEY: \"___opened_labels_counter___\",\n    /**\n     * The key of a list of all choices that have been made during the progression of the steps.\n     */\n    ALL_CHOICES_MADE_KEY: \"___all_choices_made___\",\n    /**\n     * The key of the current step times counter.\n     * This value was added to introduce Ink Sequences, cycles and other alternatives https://github.com/inkle/ink/blob/master/Documentation/WritingWithInk.md#sequences-cycles-and-other-alternatives\n     */\n    CURRENT_STEP_TIMES_COUNTER_KEY: \"___current_step_times_counter___\",\n    /**\n     * The key of the last dialogue step glued in the step memory\n     */\n    LAST_STEP_GLUED: \"___last_step_glued___\",\n};\n","export namespace logger {\n    export const log = (message?: any, ...optionalParams: any[]) =>\n        console.log(`[Pixi’VN] ${message}`, ...optionalParams);\n    export const warn = (message?: any, ...optionalParams: any[]) =>\n        console.warn(`[Pixi’VN] ${message}`, ...optionalParams);\n    export const error = (message?: any, ...optionalParams: any[]) =>\n        console.error(`[Pixi’VN] ${message}`, ...optionalParams);\n    export const info = (message?: any, ...optionalParams: any[]) =>\n        console.info(`[Pixi’VN] ${message}`, ...optionalParams);\n}\n","import { PixiError } from \"@drincs/pixi-vn/core\";\nimport { logger } from \"./log-utility\";\n\n/**\n * This function is used to create a deep copy of the element\n * @param element The element to be copied\n * @returns The copied element\n */\nexport function createExportableElement<T>(element: T): T {\n    try {\n        if (typeof element === \"undefined\") {\n            return element;\n        }\n        let elementString = JSON.stringify(element);\n        return JSON.parse(elementString);\n    } catch (e) {\n        logger.error(\"Error creating exportable element\", element, e);\n        throw new PixiError(\"not_json_serializable\", \"Error creating exportable element\");\n    }\n}\n","/**\n * @module LRUCache\n */\n\n// module-private names and types\n// this provides the default Perf object source.\n// it can be passed in via configuration to override it\n// for a single LRU object.\nexport type Perf = { now: () => number }\nconst defaultPerf: Perf =\n  (\n    typeof performance === 'object' &&\n    performance &&\n    typeof performance.now === 'function'\n  ) ?\n    performance\n  : Date\n\nconst warned = new Set<string>()\n\n// either a function or a class\ntype ForC = ((...a: any[]) => any) | { new (...a: any[]): any }\n\n/* c8 ignore start */\nconst PROCESS = (\n  typeof process === 'object' && !!process ?\n    process\n  : {}) as { [k: string]: any }\n/* c8 ignore start */\n\nconst emitWarning = (\n  msg: string,\n  type: string,\n  code: string,\n  fn: ForC,\n) => {\n  typeof PROCESS.emitWarning === 'function' ?\n    PROCESS.emitWarning(msg, type, code, fn)\n  : console.error(`[${code}] ${type}: ${msg}`)\n}\n\nlet AC = globalThis.AbortController\nlet AS = globalThis.AbortSignal\n\n/* c8 ignore start */\nif (typeof AC === 'undefined') {\n  //@ts-ignore\n  AS = class AbortSignal {\n    onabort?: (...a: any[]) => any\n    _onabort: ((...a: any[]) => any)[] = []\n    reason?: any\n    aborted: boolean = false\n    addEventListener(_: string, fn: (...a: any[]) => any) {\n      this._onabort.push(fn)\n    }\n  }\n  //@ts-ignore\n  AC = class AbortController {\n    constructor() {\n      warnACPolyfill()\n    }\n    signal = new AS()\n    abort(reason: any) {\n      if (this.signal.aborted) return\n      //@ts-ignore\n      this.signal.reason = reason\n      //@ts-ignore\n      this.signal.aborted = true\n      //@ts-ignore\n      for (const fn of this.signal._onabort) {\n        fn(reason)\n      }\n      this.signal.onabort?.(reason)\n    }\n  }\n  let printACPolyfillWarning =\n    PROCESS.env?.LRU_CACHE_IGNORE_AC_WARNING !== '1'\n  const warnACPolyfill = () => {\n    if (!printACPolyfillWarning) return\n    printACPolyfillWarning = false\n    emitWarning(\n      'AbortController is not defined. If using lru-cache in ' +\n        'node 14, load an AbortController polyfill from the ' +\n        '`node-abort-controller` package. A minimal polyfill is ' +\n        'provided for use by LRUCache.fetch(), but it should not be ' +\n        'relied upon in other contexts (eg, passing it to other APIs that ' +\n        'use AbortController/AbortSignal might have undesirable effects). ' +\n        'You may disable this with LRU_CACHE_IGNORE_AC_WARNING=1 in the env.',\n      'NO_ABORT_CONTROLLER',\n      'ENOTSUP',\n      warnACPolyfill,\n    )\n  }\n}\n/* c8 ignore stop */\n\nconst shouldWarn = (code: string) => !warned.has(code)\n\nconst TYPE = Symbol('type')\nexport type PosInt = number & { [TYPE]: 'Positive Integer' }\nexport type Index = number & { [TYPE]: 'LRUCache Index' }\n\nconst isPosInt = (n: any): n is PosInt =>\n  n && n === Math.floor(n) && n > 0 && isFinite(n)\n\nexport type UintArray = Uint8Array | Uint16Array | Uint32Array\nexport type NumberArray = UintArray | number[]\n\n/* c8 ignore start */\n// This is a little bit ridiculous, tbh.\n// The maximum array length is 2^32-1 or thereabouts on most JS impls.\n// And well before that point, you're caching the entire world, I mean,\n// that's ~32GB of just integers for the next/prev links, plus whatever\n// else to hold that many keys and values.  Just filling the memory with\n// zeroes at init time is brutal when you get that big.\n// But why not be complete?\n// Maybe in the future, these limits will have expanded.\nconst getUintArray = (max: number) =>\n  !isPosInt(max) ? null\n  : max <= Math.pow(2, 8) ? Uint8Array\n  : max <= Math.pow(2, 16) ? Uint16Array\n  : max <= Math.pow(2, 32) ? Uint32Array\n  : max <= Number.MAX_SAFE_INTEGER ? ZeroArray\n  : null\n/* c8 ignore stop */\n\nclass ZeroArray extends Array<number> {\n  constructor(size: number) {\n    super(size)\n    this.fill(0)\n  }\n}\nexport type { ZeroArray }\nexport type { Stack }\n\nexport type StackLike = Stack | Index[]\nclass Stack {\n  heap: NumberArray\n  length: number\n  // private constructor\n  static #constructing: boolean = false\n  static create(max: number): StackLike {\n    const HeapCls = getUintArray(max)\n    if (!HeapCls) return []\n    Stack.#constructing = true\n    const s = new Stack(max, HeapCls)\n    Stack.#constructing = false\n    return s\n  }\n  constructor(max: number, HeapCls: { new (n: number): NumberArray }) {\n    /* c8 ignore start */\n    if (!Stack.#constructing) {\n      throw new TypeError('instantiate Stack using Stack.create(n)')\n    }\n    /* c8 ignore stop */\n    this.heap = new HeapCls(max)\n    this.length = 0\n  }\n  push(n: Index) {\n    this.heap[this.length++] = n\n  }\n  pop(): Index {\n    return this.heap[--this.length] as Index\n  }\n}\n\n/**\n * Promise representing an in-progress {@link LRUCache#fetch} call\n */\nexport type BackgroundFetch<V> = Promise<V | undefined> & {\n  __returned: BackgroundFetch<V> | undefined\n  __abortController: AbortController\n  __staleWhileFetching: V | undefined\n}\n\nexport type DisposeTask<K, V> = [\n  value: V,\n  key: K,\n  reason: LRUCache.DisposeReason,\n]\n\nexport namespace LRUCache {\n  /**\n   * An integer greater than 0, reflecting the calculated size of items\n   */\n  export type Size = number\n\n  /**\n   * Integer greater than 0, representing some number of milliseconds, or the\n   * time at which a TTL started counting from.\n   */\n  export type Milliseconds = number\n\n  /**\n   * An integer greater than 0, reflecting a number of items\n   */\n  export type Count = number\n\n  /**\n   * The reason why an item was removed from the cache, passed\n   * to the {@link Disposer} methods.\n   *\n   * - `evict`: The item was evicted because it is the least recently used,\n   *   and the cache is full.\n   * - `set`: A new value was set, overwriting the old value being disposed.\n   * - `delete`: The item was explicitly deleted, either by calling\n   *   {@link LRUCache#delete}, {@link LRUCache#clear}, or\n   *   {@link LRUCache#set} with an undefined value.\n   * - `expire`: The item was removed due to exceeding its TTL.\n   * - `fetch`: A {@link OptionsBase#fetchMethod} operation returned\n   *   `undefined` or was aborted, causing the item to be deleted.\n   */\n  export type DisposeReason =\n    | 'evict'\n    | 'set'\n    | 'delete'\n    | 'expire'\n    | 'fetch'\n  /**\n   * A method called upon item removal, passed as the\n   * {@link OptionsBase.dispose} and/or\n   * {@link OptionsBase.disposeAfter} options.\n   */\n  export type Disposer<K, V> = (\n    value: V,\n    key: K,\n    reason: DisposeReason,\n  ) => void\n\n  /**\n   * The reason why an item was added to the cache, passed\n   * to the {@link Inserter} methods.\n   *\n   * - `add`: the item was not found in the cache, and was added\n   * - `update`: the item was in the cache, with the same value provided\n   * - `replace`: the item was in the cache, and replaced\n   */\n  export type InsertReason = 'add' | 'update' | 'replace'\n\n  /**\n   * A method called upon item insertion, passed as the\n   * {@link OptionsBase.insert}\n   */\n  export type Inserter<K, V> = (\n    value: V,\n    key: K,\n    reason: InsertReason,\n  ) => void\n\n  /**\n   * A function that returns the effective calculated size\n   * of an entry in the cache.\n   */\n  export type SizeCalculator<K, V> = (value: V, key: K) => Size\n\n  /**\n   * Options provided to the\n   * {@link OptionsBase.fetchMethod} function.\n   */\n  export interface FetcherOptions<K, V, FC = unknown> {\n    signal: AbortSignal\n    options: FetcherFetchOptions<K, V, FC>\n    /**\n     * Object provided in the {@link FetchOptions.context} option to\n     * {@link LRUCache#fetch}\n     */\n    context: FC\n  }\n\n  /**\n   * Occasionally, it may be useful to track the internal behavior of the\n   * cache, particularly for logging, debugging, or for behavior within the\n   * `fetchMethod`. To do this, you can pass a `status` object to the\n   * {@link LRUCache#fetch}, {@link LRUCache#get}, {@link LRUCache#set},\n   * {@link LRUCache#memo}, and {@link LRUCache#has} methods.\n   *\n   * The `status` option should be a plain JavaScript object. The following\n   * fields will be set on it appropriately, depending on the situation.\n   */\n  export interface Status<V> {\n    /**\n     * The status of a set() operation.\n     *\n     * - add: the item was not found in the cache, and was added\n     * - update: the item was in the cache, with the same value provided\n     * - replace: the item was in the cache, and replaced\n     * - miss: the item was not added to the cache for some reason\n     */\n    set?: 'add' | 'update' | 'replace' | 'miss'\n\n    /**\n     * the ttl stored for the item, or undefined if ttls are not used.\n     */\n    ttl?: Milliseconds\n\n    /**\n     * the start time for the item, or undefined if ttls are not used.\n     */\n    start?: Milliseconds\n\n    /**\n     * The timestamp used for TTL calculation\n     */\n    now?: Milliseconds\n\n    /**\n     * the remaining ttl for the item, or undefined if ttls are not used.\n     */\n    remainingTTL?: Milliseconds\n\n    /**\n     * The calculated size for the item, if sizes are used.\n     */\n    entrySize?: Size\n\n    /**\n     * The total calculated size of the cache, if sizes are used.\n     */\n    totalCalculatedSize?: Size\n\n    /**\n     * A flag indicating that the item was not stored, due to exceeding the\n     * {@link OptionsBase.maxEntrySize}\n     */\n    maxEntrySizeExceeded?: true\n\n    /**\n     * The old value, specified in the case of `set:'update'` or\n     * `set:'replace'`\n     */\n    oldValue?: V\n\n    /**\n     * The results of a {@link LRUCache#has} operation\n     *\n     * - hit: the item was found in the cache\n     * - stale: the item was found in the cache, but is stale\n     * - miss: the item was not found in the cache\n     */\n    has?: 'hit' | 'stale' | 'miss'\n\n    /**\n     * The status of a {@link LRUCache#fetch} operation.\n     * Note that this can change as the underlying fetch() moves through\n     * various states.\n     *\n     * - inflight: there is another fetch() for this key which is in process\n     * - get: there is no {@link OptionsBase.fetchMethod}, so\n     *   {@link LRUCache#get} was called.\n     * - miss: the item is not in cache, and will be fetched.\n     * - hit: the item is in the cache, and was resolved immediately.\n     * - stale: the item is in the cache, but stale.\n     * - refresh: the item is in the cache, and not stale, but\n     *   {@link FetchOptions.forceRefresh} was specified.\n     */\n    fetch?: 'get' | 'inflight' | 'miss' | 'hit' | 'stale' | 'refresh'\n\n    /**\n     * The {@link OptionsBase.fetchMethod} was called\n     */\n    fetchDispatched?: true\n\n    /**\n     * The cached value was updated after a successful call to\n     * {@link OptionsBase.fetchMethod}\n     */\n    fetchUpdated?: true\n\n    /**\n     * The reason for a fetch() rejection.  Either the error raised by the\n     * {@link OptionsBase.fetchMethod}, or the reason for an\n     * AbortSignal.\n     */\n    fetchError?: Error\n\n    /**\n     * The fetch received an abort signal\n     */\n    fetchAborted?: true\n\n    /**\n     * The abort signal received was ignored, and the fetch was allowed to\n     * continue.\n     */\n    fetchAbortIgnored?: true\n\n    /**\n     * The fetchMethod promise resolved successfully\n     */\n    fetchResolved?: true\n\n    /**\n     * The fetchMethod promise was rejected\n     */\n    fetchRejected?: true\n\n    /**\n     * The status of a {@link LRUCache#get} operation.\n     *\n     * - fetching: The item is currently being fetched.  If a previous value\n     *   is present and allowed, that will be returned.\n     * - stale: The item is in the cache, and is stale.\n     * - hit: the item is in the cache\n     * - miss: the item is not in the cache\n     */\n    get?: 'stale' | 'hit' | 'miss'\n\n    /**\n     * A fetch or get operation returned a stale value.\n     */\n    returnedStale?: true\n  }\n\n  /**\n   * options which override the options set in the LRUCache constructor\n   * when calling {@link LRUCache#fetch}.\n   *\n   * This is the union of {@link GetOptions} and {@link SetOptions}, plus\n   * {@link OptionsBase.noDeleteOnFetchRejection},\n   * {@link OptionsBase.allowStaleOnFetchRejection},\n   * {@link FetchOptions.forceRefresh}, and\n   * {@link FetcherOptions.context}\n   *\n   * Any of these may be modified in the {@link OptionsBase.fetchMethod}\n   * function, but the {@link GetOptions} fields will of course have no\n   * effect, as the {@link LRUCache#get} call already happened by the time\n   * the fetchMethod is called.\n   */\n  export interface FetcherFetchOptions<K, V, FC = unknown>\n    extends Pick<\n      OptionsBase<K, V, FC>,\n      | 'allowStale'\n      | 'updateAgeOnGet'\n      | 'noDeleteOnStaleGet'\n      | 'sizeCalculation'\n      | 'ttl'\n      | 'noDisposeOnSet'\n      | 'noUpdateTTL'\n      | 'noDeleteOnFetchRejection'\n      | 'allowStaleOnFetchRejection'\n      | 'ignoreFetchAbort'\n      | 'allowStaleOnFetchAbort'\n    > {\n    status?: Status<V>\n    size?: Size\n  }\n\n  /**\n   * Options that may be passed to the {@link LRUCache#fetch} method.\n   */\n  export interface FetchOptions<K, V, FC>\n    extends FetcherFetchOptions<K, V, FC> {\n    /**\n     * Set to true to force a re-load of the existing data, even if it\n     * is not yet stale.\n     */\n    forceRefresh?: boolean\n    /**\n     * Context provided to the {@link OptionsBase.fetchMethod} as\n     * the {@link FetcherOptions.context} param.\n     *\n     * If the FC type is specified as unknown (the default),\n     * undefined or void, then this is optional.  Otherwise, it will\n     * be required.\n     */\n    context?: FC\n    signal?: AbortSignal\n    status?: Status<V>\n  }\n  /**\n   * Options provided to {@link LRUCache#fetch} when the FC type is something\n   * other than `unknown`, `undefined`, or `void`\n   */\n  export interface FetchOptionsWithContext<K, V, FC>\n    extends FetchOptions<K, V, FC> {\n    context: FC\n  }\n  /**\n   * Options provided to {@link LRUCache#fetch} when the FC type is\n   * `undefined` or `void`\n   */\n  export interface FetchOptionsNoContext<K, V>\n    extends FetchOptions<K, V, undefined> {\n    context?: undefined\n  }\n\n  export interface MemoOptions<K, V, FC = unknown>\n    extends Pick<\n      OptionsBase<K, V, FC>,\n      | 'allowStale'\n      | 'updateAgeOnGet'\n      | 'noDeleteOnStaleGet'\n      | 'sizeCalculation'\n      | 'ttl'\n      | 'noDisposeOnSet'\n      | 'noUpdateTTL'\n      | 'noDeleteOnFetchRejection'\n      | 'allowStaleOnFetchRejection'\n      | 'ignoreFetchAbort'\n      | 'allowStaleOnFetchAbort'\n    > {\n    /**\n     * Set to true to force a re-load of the existing data, even if it\n     * is not yet stale.\n     */\n    forceRefresh?: boolean\n    /**\n     * Context provided to the {@link OptionsBase.memoMethod} as\n     * the {@link MemoizerOptions.context} param.\n     *\n     * If the FC type is specified as unknown (the default),\n     * undefined or void, then this is optional.  Otherwise, it will\n     * be required.\n     */\n    context?: FC\n    status?: Status<V>\n  }\n  /**\n   * Options provided to {@link LRUCache#memo} when the FC type is something\n   * other than `unknown`, `undefined`, or `void`\n   */\n  export interface MemoOptionsWithContext<K, V, FC>\n    extends MemoOptions<K, V, FC> {\n    context: FC\n  }\n  /**\n   * Options provided to {@link LRUCache#memo} when the FC type is\n   * `undefined` or `void`\n   */\n  export interface MemoOptionsNoContext<K, V>\n    extends MemoOptions<K, V, undefined> {\n    context?: undefined\n  }\n\n  /**\n   * Options provided to the\n   * {@link OptionsBase.memoMethod} function.\n   */\n  export interface MemoizerOptions<K, V, FC = unknown> {\n    options: MemoizerMemoOptions<K, V, FC>\n    /**\n     * Object provided in the {@link MemoOptions.context} option to\n     * {@link LRUCache#memo}\n     */\n    context: FC\n  }\n\n  /**\n   * options which override the options set in the LRUCache constructor\n   * when calling {@link LRUCache#memo}.\n   *\n   * This is the union of {@link GetOptions} and {@link SetOptions}, plus\n   * {@link MemoOptions.forceRefresh}, and\n   * {@link MemoOptions.context}\n   *\n   * Any of these may be modified in the {@link OptionsBase.memoMethod}\n   * function, but the {@link GetOptions} fields will of course have no\n   * effect, as the {@link LRUCache#get} call already happened by the time\n   * the memoMethod is called.\n   */\n  export interface MemoizerMemoOptions<K, V, FC = unknown>\n    extends Pick<\n      OptionsBase<K, V, FC>,\n      | 'allowStale'\n      | 'updateAgeOnGet'\n      | 'noDeleteOnStaleGet'\n      | 'sizeCalculation'\n      | 'ttl'\n      | 'noDisposeOnSet'\n      | 'noUpdateTTL'\n    > {\n    status?: Status<V>\n    size?: Size\n    start?: Milliseconds\n  }\n\n  /**\n   * Options that may be passed to the {@link LRUCache#has} method.\n   */\n  export interface HasOptions<K, V, FC>\n    extends Pick<OptionsBase<K, V, FC>, 'updateAgeOnHas'> {\n    status?: Status<V>\n  }\n\n  /**\n   * Options that may be passed to the {@link LRUCache#get} method.\n   */\n  export interface GetOptions<K, V, FC>\n    extends Pick<\n      OptionsBase<K, V, FC>,\n      'allowStale' | 'updateAgeOnGet' | 'noDeleteOnStaleGet'\n    > {\n    status?: Status<V>\n  }\n\n  /**\n   * Options that may be passed to the {@link LRUCache#peek} method.\n   */\n  export interface PeekOptions<K, V, FC>\n    extends Pick<OptionsBase<K, V, FC>, 'allowStale'> {}\n\n  /**\n   * Options that may be passed to the {@link LRUCache#set} method.\n   */\n  export interface SetOptions<K, V, FC>\n    extends Pick<\n      OptionsBase<K, V, FC>,\n      'sizeCalculation' | 'ttl' | 'noDisposeOnSet' | 'noUpdateTTL'\n    > {\n    /**\n     * If size tracking is enabled, then setting an explicit size\n     * in the {@link LRUCache#set} call will prevent calling the\n     * {@link OptionsBase.sizeCalculation} function.\n     */\n    size?: Size\n    /**\n     * If TTL tracking is enabled, then setting an explicit start\n     * time in the {@link LRUCache#set} call will override the\n     * default time from `performance.now()` or `Date.now()`.\n     *\n     * Note that it must be a valid value for whichever time-tracking\n     * method is in use.\n     */\n    start?: Milliseconds\n    status?: Status<V>\n  }\n\n  /**\n   * The type signature for the {@link OptionsBase.fetchMethod} option.\n   */\n  export type Fetcher<K, V, FC = unknown> = (\n    key: K,\n    staleValue: V | undefined,\n    options: FetcherOptions<K, V, FC>,\n  ) => Promise<V | undefined | void> | V | undefined | void\n\n  /**\n   * the type signature for the {@link OptionsBase.memoMethod} option.\n   */\n  export type Memoizer<K, V, FC = unknown> = (\n    key: K,\n    staleValue: V | undefined,\n    options: MemoizerOptions<K, V, FC>,\n  ) => V\n\n  /**\n   * Options which may be passed to the {@link LRUCache} constructor.\n   *\n   * Most of these may be overridden in the various options that use\n   * them.\n   *\n   * Despite all being technically optional, the constructor requires that\n   * a cache is at minimum limited by one or more of {@link OptionsBase.max},\n   * {@link OptionsBase.ttl}, or {@link OptionsBase.maxSize}.\n   *\n   * If {@link OptionsBase.ttl} is used alone, then it is strongly advised\n   * (and in fact required by the type definitions here) that the cache\n   * also set {@link OptionsBase.ttlAutopurge}, to prevent potentially\n   * unbounded storage.\n   *\n   * All options are also available on the {@link LRUCache} instance, making\n   * it safe to pass an LRUCache instance as the options argumemnt to\n   * make another empty cache of the same type.\n   *\n   * Some options are marked as read-only, because changing them after\n   * instantiation is not safe. Changing any of the other options will of\n   * course only have an effect on subsequent method calls.\n   */\n  export interface OptionsBase<K, V, FC> {\n    /**\n     * The maximum number of items to store in the cache before evicting\n     * old entries. This is read-only on the {@link LRUCache} instance,\n     * and may not be overridden.\n     *\n     * If set, then storage space will be pre-allocated at construction\n     * time, and the cache will perform significantly faster.\n     *\n     * Note that significantly fewer items may be stored, if\n     * {@link OptionsBase.maxSize} and/or {@link OptionsBase.ttl} are also\n     * set.\n     *\n     * **It is strongly recommended to set a `max` to prevent unbounded growth\n     * of the cache.**\n     */\n    max?: Count\n\n    /**\n     * Max time in milliseconds for items to live in cache before they are\n     * considered stale.  Note that stale items are NOT preemptively removed by\n     * default, and MAY live in the cache, contributing to its LRU max, long\n     * after they have expired, unless {@link OptionsBase.ttlAutopurge} is\n     * set.\n     *\n     * If set to `0` (the default value), then that means \"do not track\n     * TTL\", not \"expire immediately\".\n     *\n     * Also, as this cache is optimized for LRU/MRU operations, some of\n     * the staleness/TTL checks will reduce performance, as they will incur\n     * overhead by deleting items.\n     *\n     * This is not primarily a TTL cache, and does not make strong TTL\n     * guarantees. There is no pre-emptive pruning of expired items, but you\n     * _may_ set a TTL on the cache, and it will treat expired items as missing\n     * when they are fetched, and delete them.\n     *\n     * Optional, but must be a non-negative integer in ms if specified.\n     *\n     * This may be overridden by passing an options object to `cache.set()`.\n     *\n     * At least one of `max`, `maxSize`, or `TTL` is required. This must be a\n     * positive integer if set.\n     *\n     * Even if ttl tracking is enabled, **it is strongly recommended to set a\n     * `max` to prevent unbounded growth of the cache.**\n     *\n     * If ttl tracking is enabled, and `max` and `maxSize` are not set,\n     * and `ttlAutopurge` is not set, then a warning will be emitted\n     * cautioning about the potential for unbounded memory consumption.\n     * (The TypeScript definitions will also discourage this.)\n     */\n    ttl?: Milliseconds\n\n    /**\n     * Minimum amount of time in ms in which to check for staleness.\n     * Defaults to 1, which means that the current time is checked\n     * at most once per millisecond.\n     *\n     * Set to 0 to check the current time every time staleness is tested.\n     * (This reduces performance, and is theoretically unnecessary.)\n     *\n     * Setting this to a higher value will improve performance somewhat\n     * while using ttl tracking, albeit at the expense of keeping stale\n     * items around a bit longer than their TTLs would indicate.\n     *\n     * @default 1\n     */\n    ttlResolution?: Milliseconds\n\n    /**\n     * Preemptively remove stale items from the cache.\n     *\n     * Note that this may *significantly* degrade performance, especially if\n     * the cache is storing a large number of items. It is almost always best\n     * to just leave the stale items in the cache, and let them fall out as new\n     * items are added.\n     *\n     * Note that this means that {@link OptionsBase.allowStale} is a bit\n     * pointless, as stale items will be deleted almost as soon as they\n     * expire.\n     *\n     * Use with caution!\n     */\n    ttlAutopurge?: boolean\n\n    /**\n     * When using time-expiring entries with `ttl`, setting this to `true` will\n     * make each item's age reset to 0 whenever it is retrieved from cache with\n     * {@link LRUCache#get}, causing it to not expire. (It can still fall out\n     * of cache based on recency of use, of course.)\n     *\n     * Has no effect if {@link OptionsBase.ttl} is not set.\n     *\n     * This may be overridden by passing an options object to `cache.get()`.\n     */\n    updateAgeOnGet?: boolean\n\n    /**\n     * When using time-expiring entries with `ttl`, setting this to `true` will\n     * make each item's age reset to 0 whenever its presence in the cache is\n     * checked with {@link LRUCache#has}, causing it to not expire. (It can\n     * still fall out of cache based on recency of use, of course.)\n     *\n     * Has no effect if {@link OptionsBase.ttl} is not set.\n     */\n    updateAgeOnHas?: boolean\n\n    /**\n     * Allow {@link LRUCache#get} and {@link LRUCache#fetch} calls to return\n     * stale data, if available.\n     *\n     * By default, if you set `ttl`, stale items will only be deleted from the\n     * cache when you `get(key)`. That is, it's not preemptively pruning items,\n     * unless {@link OptionsBase.ttlAutopurge} is set.\n     *\n     * If you set `allowStale:true`, it'll return the stale value *as well as*\n     * deleting it. If you don't set this, then it'll return `undefined` when\n     * you try to get a stale entry.\n     *\n     * Note that when a stale entry is fetched, _even if it is returned due to\n     * `allowStale` being set_, it is removed from the cache immediately. You\n     * can suppress this behavior by setting\n     * {@link OptionsBase.noDeleteOnStaleGet}, either in the constructor, or in\n     * the options provided to {@link LRUCache#get}.\n     *\n     * This may be overridden by passing an options object to `cache.get()`.\n     * The `cache.has()` method will always return `false` for stale items.\n     *\n     * Only relevant if a ttl is set.\n     */\n    allowStale?: boolean\n\n    /**\n     * Function that is called on items when they are dropped from the\n     * cache, as `dispose(value, key, reason)`.\n     *\n     * This can be handy if you want to close file descriptors or do\n     * other cleanup tasks when items are no longer stored in the cache.\n     *\n     * **NOTE**: It is called _before_ the item has been fully removed\n     * from the cache, so if you want to put it right back in, you need\n     * to wait until the next tick. If you try to add it back in during\n     * the `dispose()` function call, it will break things in subtle and\n     * weird ways.\n     *\n     * Unlike several other options, this may _not_ be overridden by\n     * passing an option to `set()`, for performance reasons.\n     *\n     * The `reason` will be one of the following strings, corresponding\n     * to the reason for the item's deletion:\n     *\n     * - `evict` Item was evicted to make space for a new addition\n     * - `set` Item was overwritten by a new value\n     * - `expire` Item expired its TTL\n     * - `fetch` Item was deleted due to a failed or aborted fetch, or a\n     *   fetchMethod returning `undefined.\n     * - `delete` Item was removed by explicit `cache.delete(key)`,\n     *   `cache.clear()`, or `cache.set(key, undefined)`.\n     */\n    dispose?: Disposer<K, V>\n\n    /**\n     * Function that is called when new items are inserted into the cache,\n     * as `onInsert(value, key, reason)`.\n     *\n     * This can be useful if you need to perform actions when an item is\n     * added, such as logging or tracking insertions.\n     *\n     * Unlike some other options, this may _not_ be overridden by passing\n     * an option to `set()`, for performance and consistency reasons.\n     */\n    onInsert?: Inserter<K, V>\n\n    /**\n     * The same as {@link OptionsBase.dispose}, but called *after* the entry\n     * is completely removed and the cache is once again in a clean state.\n     *\n     * It is safe to add an item right back into the cache at this point.\n     * However, note that it is *very* easy to inadvertently create infinite\n     * recursion this way.\n     */\n    disposeAfter?: Disposer<K, V>\n\n    /**\n     * Set to true to suppress calling the\n     * {@link OptionsBase.dispose} function if the entry key is\n     * still accessible within the cache.\n     *\n     * This may be overridden by passing an options object to\n     * {@link LRUCache#set}.\n     *\n     * Only relevant if `dispose` or `disposeAfter` are set.\n     */\n    noDisposeOnSet?: boolean\n\n    /**\n     * Boolean flag to tell the cache to not update the TTL when setting a new\n     * value for an existing key (ie, when updating a value rather than\n     * inserting a new value).  Note that the TTL value is _always_ set (if\n     * provided) when adding a new entry into the cache.\n     *\n     * Has no effect if a {@link OptionsBase.ttl} is not set.\n     *\n     * May be passed as an option to {@link LRUCache#set}.\n     */\n    noUpdateTTL?: boolean\n\n    /**\n     * Set to a positive integer to track the sizes of items added to the\n     * cache, and automatically evict items in order to stay below this size.\n     * Note that this may result in fewer than `max` items being stored.\n     *\n     * Attempting to add an item to the cache whose calculated size is greater\n     * that this amount will be a no-op. The item will not be cached, and no\n     * other items will be evicted.\n     *\n     * Optional, must be a positive integer if provided.\n     *\n     * Sets `maxEntrySize` to the same value, unless a different value is\n     * provided for `maxEntrySize`.\n     *\n     * At least one of `max`, `maxSize`, or `TTL` is required. This must be a\n     * positive integer if set.\n     *\n     * Even if size tracking is enabled, **it is strongly recommended to set a\n     * `max` to prevent unbounded growth of the cache.**\n     *\n     * Note also that size tracking can negatively impact performance,\n     * though for most cases, only minimally.\n     */\n    maxSize?: Size\n\n    /**\n     * The maximum allowed size for any single item in the cache.\n     *\n     * If a larger item is passed to {@link LRUCache#set} or returned by a\n     * {@link OptionsBase.fetchMethod} or {@link OptionsBase.memoMethod}, then\n     * it will not be stored in the cache.\n     *\n     * Attempting to add an item whose calculated size is greater than\n     * this amount will not cache the item or evict any old items, but\n     * WILL delete an existing value if one is already present.\n     *\n     * Optional, must be a positive integer if provided. Defaults to\n     * the value of `maxSize` if provided.\n     */\n    maxEntrySize?: Size\n\n    /**\n     * A function that returns a number indicating the item's size.\n     *\n     * Requires {@link OptionsBase.maxSize} to be set.\n     *\n     * If not provided, and {@link OptionsBase.maxSize} or\n     * {@link OptionsBase.maxEntrySize} are set, then all\n     * {@link LRUCache#set} calls **must** provide an explicit\n     * {@link SetOptions.size} or sizeCalculation param.\n     */\n    sizeCalculation?: SizeCalculator<K, V>\n\n    /**\n     * Method that provides the implementation for {@link LRUCache#fetch}\n     *\n     * ```ts\n     * fetchMethod(key, staleValue, { signal, options, context })\n     * ```\n     *\n     * If `fetchMethod` is not provided, then `cache.fetch(key)` is equivalent\n     * to `Promise.resolve(cache.get(key))`.\n     *\n     * If at any time, `signal.aborted` is set to `true`, or if the\n     * `signal.onabort` method is called, or if it emits an `'abort'` event\n     * which you can listen to with `addEventListener`, then that means that\n     * the fetch should be abandoned. This may be passed along to async\n     * functions aware of AbortController/AbortSignal behavior.\n     *\n     * The `fetchMethod` should **only** return `undefined` or a Promise\n     * resolving to `undefined` if the AbortController signaled an `abort`\n     * event. In all other cases, it should return or resolve to a value\n     * suitable for adding to the cache.\n     *\n     * The `options` object is a union of the options that may be provided to\n     * `set()` and `get()`. If they are modified, then that will result in\n     * modifying the settings to `cache.set()` when the value is resolved, and\n     * in the case of\n     * {@link OptionsBase.noDeleteOnFetchRejection} and\n     * {@link OptionsBase.allowStaleOnFetchRejection}, the handling of\n     * `fetchMethod` failures.\n     *\n     * For example, a DNS cache may update the TTL based on the value returned\n     * from a remote DNS server by changing `options.ttl` in the `fetchMethod`.\n     */\n    fetchMethod?: Fetcher<K, V, FC>\n\n    /**\n     * Method that provides the implementation for {@link LRUCache#memo}\n     */\n    memoMethod?: Memoizer<K, V, FC>\n\n    /**\n     * Set to true to suppress the deletion of stale data when a\n     * {@link OptionsBase.fetchMethod} returns a rejected promise.\n     */\n    noDeleteOnFetchRejection?: boolean\n\n    /**\n     * Do not delete stale items when they are retrieved with\n     * {@link LRUCache#get}.\n     *\n     * Note that the `get` return value will still be `undefined`\n     * unless {@link OptionsBase.allowStale} is true.\n     *\n     * When using time-expiring entries with `ttl`, by default stale\n     * items will be removed from the cache when the key is accessed\n     * with `cache.get()`.\n     *\n     * Setting this option will cause stale items to remain in the cache, until\n     * they are explicitly deleted with `cache.delete(key)`, or retrieved with\n     * `noDeleteOnStaleGet` set to `false`.\n     *\n     * This may be overridden by passing an options object to `cache.get()`.\n     *\n     * Only relevant if a ttl is used.\n     */\n    noDeleteOnStaleGet?: boolean\n\n    /**\n     * Set to true to allow returning stale data when a\n     * {@link OptionsBase.fetchMethod} throws an error or returns a rejected\n     * promise.\n     *\n     * This differs from using {@link OptionsBase.allowStale} in that stale\n     * data will ONLY be returned in the case that the {@link LRUCache#fetch}\n     * fails, not any other times.\n     *\n     * If a `fetchMethod` fails, and there is no stale value available, the\n     * `fetch()` will resolve to `undefined`. Ie, all `fetchMethod` errors are\n     * suppressed.\n     *\n     * Implies `noDeleteOnFetchRejection`.\n     *\n     * This may be set in calls to `fetch()`, or defaulted on the constructor,\n     * or overridden by modifying the options object in the `fetchMethod`.\n     */\n    allowStaleOnFetchRejection?: boolean\n\n    /**\n     * Set to true to return a stale value from the cache when the\n     * `AbortSignal` passed to the {@link OptionsBase.fetchMethod} dispatches\n     * an `'abort'` event, whether user-triggered, or due to internal cache\n     * behavior.\n     *\n     * Unless {@link OptionsBase.ignoreFetchAbort} is also set, the underlying\n     * {@link OptionsBase.fetchMethod} will still be considered canceled, and\n     * any value it returns will be ignored and not cached.\n     *\n     * Caveat: since fetches are aborted when a new value is explicitly\n     * set in the cache, this can lead to fetch returning a stale value,\n     * since that was the fallback value _at the moment the `fetch()` was\n     * initiated_, even though the new updated value is now present in\n     * the cache.\n     *\n     * For example:\n     *\n     * ```ts\n     * const cache = new LRUCache<string, any>({\n     *   ttl: 100,\n     *   fetchMethod: async (url, oldValue, { signal }) =>  {\n     *     const res = await fetch(url, { signal })\n     *     return await res.json()\n     *   }\n     * })\n     * cache.set('https://example.com/', { some: 'data' })\n     * // 100ms go by...\n     * const result = cache.fetch('https://example.com/')\n     * cache.set('https://example.com/', { other: 'thing' })\n     * console.log(await result) // { some: 'data' }\n     * console.log(cache.get('https://example.com/')) // { other: 'thing' }\n     * ```\n     */\n    allowStaleOnFetchAbort?: boolean\n\n    /**\n     * Set to true to ignore the `abort` event emitted by the `AbortSignal`\n     * object passed to {@link OptionsBase.fetchMethod}, and still cache the\n     * resulting resolution value, as long as it is not `undefined`.\n     *\n     * When used on its own, this means aborted {@link LRUCache#fetch} calls\n     * are not immediately resolved or rejected when they are aborted, and\n     * instead take the full time to await.\n     *\n     * When used with {@link OptionsBase.allowStaleOnFetchAbort}, aborted\n     * {@link LRUCache#fetch} calls will resolve immediately to their stale\n     * cached value or `undefined`, and will continue to process and eventually\n     * update the cache when they resolve, as long as the resulting value is\n     * not `undefined`, thus supporting a \"return stale on timeout while\n     * refreshing\" mechanism by passing `AbortSignal.timeout(n)` as the signal.\n     *\n     * For example:\n     *\n     * ```ts\n     * const c = new LRUCache({\n     *   ttl: 100,\n     *   ignoreFetchAbort: true,\n     *   allowStaleOnFetchAbort: true,\n     *   fetchMethod: async (key, oldValue, { signal }) => {\n     *     // note: do NOT pass the signal to fetch()!\n     *     // let's say this fetch can take a long time.\n     *     const res = await fetch(`https://slow-backend-server/${key}`)\n     *     return await res.json()\n     *   },\n     * })\n     *\n     * // this will return the stale value after 100ms, while still\n     * // updating in the background for next time.\n     * const val = await c.fetch('key', { signal: AbortSignal.timeout(100) })\n     * ```\n     *\n     * **Note**: regardless of this setting, an `abort` event _is still\n     * emitted on the `AbortSignal` object_, so may result in invalid results\n     * when passed to other underlying APIs that use AbortSignals.\n     *\n     * This may be overridden in the {@link OptionsBase.fetchMethod} or the\n     * call to {@link LRUCache#fetch}.\n     */\n    ignoreFetchAbort?: boolean\n\n    /**\n     * In some cases, you may want to swap out the performance/Date object\n     * used for TTL tracking. This should almost certainly NOT be done in\n     * production environments!\n     *\n     * This value defaults to `global.performance` if it has a `now()` method,\n     * or the `global.Date` object otherwise.\n     */\n    perf?: Perf\n  }\n\n  export interface OptionsMaxLimit<K, V, FC>\n    extends OptionsBase<K, V, FC> {\n    max: Count\n  }\n  export interface OptionsTTLLimit<K, V, FC>\n    extends OptionsBase<K, V, FC> {\n    ttl: Milliseconds\n    ttlAutopurge: boolean\n  }\n  export interface OptionsSizeLimit<K, V, FC>\n    extends OptionsBase<K, V, FC> {\n    maxSize: Size\n  }\n\n  /**\n   * The valid safe options for the {@link LRUCache} constructor\n   */\n  export type Options<K, V, FC> =\n    | OptionsMaxLimit<K, V, FC>\n    | OptionsSizeLimit<K, V, FC>\n    | OptionsTTLLimit<K, V, FC>\n\n  /**\n   * Entry objects used by {@link LRUCache#load} and {@link LRUCache#dump},\n   * and returned by {@link LRUCache#info}.\n   */\n  export interface Entry<V> {\n    value: V\n    ttl?: Milliseconds\n    size?: Size\n    start?: Milliseconds\n  }\n}\n\n/**\n * Default export, the thing you're using this module to get.\n *\n * The `K` and `V` types define the key and value types, respectively. The\n * optional `FC` type defines the type of the `context` object passed to\n * `cache.fetch()` and `cache.memo()`.\n *\n * Keys and values **must not** be `null` or `undefined`.\n *\n * All properties from the options object (with the exception of `max`,\n * `maxSize`, `fetchMethod`, `memoMethod`, `dispose` and `disposeAfter`) are\n * added as normal public members. (The listed options are read-only getters.)\n *\n * Changing any of these will alter the defaults for subsequent method calls.\n */\nexport class LRUCache<K extends {}, V extends {}, FC = unknown> {\n  // options that cannot be changed without disaster\n  readonly #max: LRUCache.Count\n  readonly #maxSize: LRUCache.Size\n  readonly #dispose?: LRUCache.Disposer<K, V>\n  readonly #onInsert?: LRUCache.Inserter<K, V>\n  readonly #disposeAfter?: LRUCache.Disposer<K, V>\n  readonly #fetchMethod?: LRUCache.Fetcher<K, V, FC>\n  readonly #memoMethod?: LRUCache.Memoizer<K, V, FC>\n  readonly #perf: Perf\n\n  /**\n   * {@link LRUCache.OptionsBase.perf}\n   */\n  get perf() {\n    return this.#perf\n  }\n\n  /**\n   * {@link LRUCache.OptionsBase.ttl}\n   */\n  ttl: LRUCache.Milliseconds\n\n  /**\n   * {@link LRUCache.OptionsBase.ttlResolution}\n   */\n  ttlResolution: LRUCache.Milliseconds\n  /**\n   * {@link LRUCache.OptionsBase.ttlAutopurge}\n   */\n  ttlAutopurge: boolean\n  /**\n   * {@link LRUCache.OptionsBase.updateAgeOnGet}\n   */\n  updateAgeOnGet: boolean\n  /**\n   * {@link LRUCache.OptionsBase.updateAgeOnHas}\n   */\n  updateAgeOnHas: boolean\n  /**\n   * {@link LRUCache.OptionsBase.allowStale}\n   */\n  allowStale: boolean\n\n  /**\n   * {@link LRUCache.OptionsBase.noDisposeOnSet}\n   */\n  noDisposeOnSet: boolean\n  /**\n   * {@link LRUCache.OptionsBase.noUpdateTTL}\n   */\n  noUpdateTTL: boolean\n  /**\n   * {@link LRUCache.OptionsBase.maxEntrySize}\n   */\n  maxEntrySize: LRUCache.Size\n  /**\n   * {@link LRUCache.OptionsBase.sizeCalculation}\n   */\n  sizeCalculation?: LRUCache.SizeCalculator<K, V>\n  /**\n   * {@link LRUCache.OptionsBase.noDeleteOnFetchRejection}\n   */\n  noDeleteOnFetchRejection: boolean\n  /**\n   * {@link LRUCache.OptionsBase.noDeleteOnStaleGet}\n   */\n  noDeleteOnStaleGet: boolean\n  /**\n   * {@link LRUCache.OptionsBase.allowStaleOnFetchAbort}\n   */\n  allowStaleOnFetchAbort: boolean\n  /**\n   * {@link LRUCache.OptionsBase.allowStaleOnFetchRejection}\n   */\n  allowStaleOnFetchRejection: boolean\n  /**\n   * {@link LRUCache.OptionsBase.ignoreFetchAbort}\n   */\n  ignoreFetchAbort: boolean\n\n  // computed properties\n  #size: LRUCache.Count\n  #calculatedSize: LRUCache.Size\n  #keyMap: Map<K, Index>\n  #keyList: (K | undefined)[]\n  #valList: (V | BackgroundFetch<V> | undefined)[]\n  #next: NumberArray\n  #prev: NumberArray\n  #head: Index\n  #tail: Index\n  #free: StackLike\n  #disposed?: DisposeTask<K, V>[]\n  #sizes?: ZeroArray\n  #starts?: ZeroArray\n  #ttls?: ZeroArray\n  #autopurgeTimers?: (undefined | ReturnType<typeof setTimeout>)[]\n\n  #hasDispose: boolean\n  #hasFetchMethod: boolean\n  #hasDisposeAfter: boolean\n  #hasOnInsert: boolean\n\n  /**\n   * Do not call this method unless you need to inspect the\n   * inner workings of the cache.  If anything returned by this\n   * object is modified in any way, strange breakage may occur.\n   *\n   * These fields are private for a reason!\n   *\n   * @internal\n   */\n  static unsafeExposeInternals<\n    K extends {},\n    V extends {},\n    FC extends unknown = unknown,\n  >(c: LRUCache<K, V, FC>) {\n    return {\n      // properties\n      starts: c.#starts,\n      ttls: c.#ttls,\n      autopurgeTimers: c.#autopurgeTimers,\n      sizes: c.#sizes,\n      keyMap: c.#keyMap as Map<K, number>,\n      keyList: c.#keyList,\n      valList: c.#valList,\n      next: c.#next,\n      prev: c.#prev,\n      get head() {\n        return c.#head\n      },\n      get tail() {\n        return c.#tail\n      },\n      free: c.#free,\n      // methods\n      isBackgroundFetch: (p: any) => c.#isBackgroundFetch(p),\n      backgroundFetch: (\n        k: K,\n        index: number | undefined,\n        options: LRUCache.FetchOptions<K, V, FC>,\n        context: any,\n      ): BackgroundFetch<V> =>\n        c.#backgroundFetch(\n          k,\n          index as Index | undefined,\n          options,\n          context,\n        ),\n      moveToTail: (index: number): void => c.#moveToTail(index as Index),\n      indexes: (options?: { allowStale: boolean }) => c.#indexes(options),\n      rindexes: (options?: { allowStale: boolean }) =>\n        c.#rindexes(options),\n      isStale: (index: number | undefined) => c.#isStale(index as Index),\n    }\n  }\n\n  // Protected read-only members\n\n  /**\n   * {@link LRUCache.OptionsBase.max} (read-only)\n   */\n  get max(): LRUCache.Count {\n    return this.#max\n  }\n  /**\n   * {@link LRUCache.OptionsBase.maxSize} (read-only)\n   */\n  get maxSize(): LRUCache.Count {\n    return this.#maxSize\n  }\n  /**\n   * The total computed size of items in the cache (read-only)\n   */\n  get calculatedSize(): LRUCache.Size {\n    return this.#calculatedSize\n  }\n  /**\n   * The number of items stored in the cache (read-only)\n   */\n  get size(): LRUCache.Count {\n    return this.#size\n  }\n  /**\n   * {@link LRUCache.OptionsBase.fetchMethod} (read-only)\n   */\n  get fetchMethod(): LRUCache.Fetcher<K, V, FC> | undefined {\n    return this.#fetchMethod\n  }\n  get memoMethod(): LRUCache.Memoizer<K, V, FC> | undefined {\n    return this.#memoMethod\n  }\n  /**\n   * {@link LRUCache.OptionsBase.dispose} (read-only)\n   */\n  get dispose() {\n    return this.#dispose\n  }\n  /**\n   * {@link LRUCache.OptionsBase.onInsert} (read-only)\n   */\n  get onInsert() {\n    return this.#onInsert\n  }\n  /**\n   * {@link LRUCache.OptionsBase.disposeAfter} (read-only)\n   */\n  get disposeAfter() {\n    return this.#disposeAfter\n  }\n\n  constructor(options: LRUCache.Options<K, V, FC> | LRUCache<K, V, FC>) {\n    const {\n      max = 0,\n      ttl,\n      ttlResolution = 1,\n      ttlAutopurge,\n      updateAgeOnGet,\n      updateAgeOnHas,\n      allowStale,\n      dispose,\n      onInsert,\n      disposeAfter,\n      noDisposeOnSet,\n      noUpdateTTL,\n      maxSize = 0,\n      maxEntrySize = 0,\n      sizeCalculation,\n      fetchMethod,\n      memoMethod,\n      noDeleteOnFetchRejection,\n      noDeleteOnStaleGet,\n      allowStaleOnFetchRejection,\n      allowStaleOnFetchAbort,\n      ignoreFetchAbort,\n      perf,\n    } = options\n\n    if (perf !== undefined) {\n      if (typeof perf?.now !== 'function') {\n        throw new TypeError(\n          'perf option must have a now() method if specified',\n        )\n      }\n    }\n\n    this.#perf = perf ?? defaultPerf\n\n    if (max !== 0 && !isPosInt(max)) {\n      throw new TypeError('max option must be a nonnegative integer')\n    }\n\n    const UintArray = max ? getUintArray(max) : Array\n    if (!UintArray) {\n      throw new Error('invalid max value: ' + max)\n    }\n\n    this.#max = max\n    this.#maxSize = maxSize\n    this.maxEntrySize = maxEntrySize || this.#maxSize\n    this.sizeCalculation = sizeCalculation\n    if (this.sizeCalculation) {\n      if (!this.#maxSize && !this.maxEntrySize) {\n        throw new TypeError(\n          'cannot set sizeCalculation without setting maxSize or maxEntrySize',\n        )\n      }\n      if (typeof this.sizeCalculation !== 'function') {\n        throw new TypeError('sizeCalculation set to non-function')\n      }\n    }\n\n    if (memoMethod !== undefined && typeof memoMethod !== 'function') {\n      throw new TypeError('memoMethod must be a function if defined')\n    }\n    this.#memoMethod = memoMethod\n\n    if (fetchMethod !== undefined && typeof fetchMethod !== 'function') {\n      throw new TypeError('fetchMethod must be a function if specified')\n    }\n    this.#fetchMethod = fetchMethod\n    this.#hasFetchMethod = !!fetchMethod\n\n    this.#keyMap = new Map()\n    this.#keyList = new Array(max).fill(undefined)\n    this.#valList = new Array(max).fill(undefined)\n    this.#next = new UintArray(max)\n    this.#prev = new UintArray(max)\n    this.#head = 0 as Index\n    this.#tail = 0 as Index\n    this.#free = Stack.create(max)\n    this.#size = 0\n    this.#calculatedSize = 0\n\n    if (typeof dispose === 'function') {\n      this.#dispose = dispose\n    }\n    if (typeof onInsert === 'function') {\n      this.#onInsert = onInsert\n    }\n    if (typeof disposeAfter === 'function') {\n      this.#disposeAfter = disposeAfter\n      this.#disposed = []\n    } else {\n      this.#disposeAfter = undefined\n      this.#disposed = undefined\n    }\n    this.#hasDispose = !!this.#dispose\n    this.#hasOnInsert = !!this.#onInsert\n    this.#hasDisposeAfter = !!this.#disposeAfter\n\n    this.noDisposeOnSet = !!noDisposeOnSet\n    this.noUpdateTTL = !!noUpdateTTL\n    this.noDeleteOnFetchRejection = !!noDeleteOnFetchRejection\n    this.allowStaleOnFetchRejection = !!allowStaleOnFetchRejection\n    this.allowStaleOnFetchAbort = !!allowStaleOnFetchAbort\n    this.ignoreFetchAbort = !!ignoreFetchAbort\n\n    // NB: maxEntrySize is set to maxSize if it's set\n    if (this.maxEntrySize !== 0) {\n      if (this.#maxSize !== 0) {\n        if (!isPosInt(this.#maxSize)) {\n          throw new TypeError(\n            'maxSize must be a positive integer if specified',\n          )\n        }\n      }\n      if (!isPosInt(this.maxEntrySize)) {\n        throw new TypeError(\n          'maxEntrySize must be a positive integer if specified',\n        )\n      }\n      this.#initializeSizeTracking()\n    }\n\n    this.allowStale = !!allowStale\n    this.noDeleteOnStaleGet = !!noDeleteOnStaleGet\n    this.updateAgeOnGet = !!updateAgeOnGet\n    this.updateAgeOnHas = !!updateAgeOnHas\n    this.ttlResolution =\n      isPosInt(ttlResolution) || ttlResolution === 0 ? ttlResolution : 1\n    this.ttlAutopurge = !!ttlAutopurge\n    this.ttl = ttl || 0\n    if (this.ttl) {\n      if (!isPosInt(this.ttl)) {\n        throw new TypeError('ttl must be a positive integer if specified')\n      }\n      this.#initializeTTLTracking()\n    }\n\n    // do not allow completely unbounded caches\n    if (this.#max === 0 && this.ttl === 0 && this.#maxSize === 0) {\n      throw new TypeError(\n        'At least one of max, maxSize, or ttl is required',\n      )\n    }\n    if (!this.ttlAutopurge && !this.#max && !this.#maxSize) {\n      const code = 'LRU_CACHE_UNBOUNDED'\n      if (shouldWarn(code)) {\n        warned.add(code)\n        const msg =\n          'TTL caching without ttlAutopurge, max, or maxSize can ' +\n          'result in unbounded memory consumption.'\n        emitWarning(msg, 'UnboundedCacheWarning', code, LRUCache)\n      }\n    }\n  }\n\n  /**\n   * Return the number of ms left in the item's TTL. If item is not in cache,\n   * returns `0`. Returns `Infinity` if item is in cache without a defined TTL.\n   */\n  getRemainingTTL(key: K) {\n    return this.#keyMap.has(key) ? Infinity : 0\n  }\n\n  #initializeTTLTracking() {\n    const ttls = new ZeroArray(this.#max)\n    const starts = new ZeroArray(this.#max)\n    this.#ttls = ttls\n    this.#starts = starts\n    const purgeTimers =\n      this.ttlAutopurge ?\n        new Array<undefined | ReturnType<typeof setTimeout>>(this.#max)\n      : undefined\n    this.#autopurgeTimers = purgeTimers\n\n    this.#setItemTTL = (index, ttl, start = this.#perf.now()) => {\n      starts[index] = ttl !== 0 ? start : 0\n      ttls[index] = ttl\n      setPurgetTimer(index, ttl)\n    }\n\n    this.#updateItemAge = index => {\n      starts[index] = ttls[index] !== 0 ? this.#perf.now() : 0\n      setPurgetTimer(index, ttls[index])\n    }\n\n    // clear out the purge timer if we're setting TTL to 0, and\n    // previously had a ttl purge timer running, so it doesn't\n    // fire unnecessarily. Don't need to do this if we're not doing\n    // autopurge.\n    const setPurgetTimer =\n      !this.ttlAutopurge ?\n        () => {}\n      : (index: Index, ttl?: number) => {\n          if (purgeTimers?.[index]) {\n            clearTimeout(purgeTimers[index])\n            purgeTimers[index] = undefined\n          }\n          if (ttl && ttl !== 0 && purgeTimers) {\n            const t = setTimeout(() => {\n              if (this.#isStale(index)) {\n                this.#delete(this.#keyList[index] as K, 'expire')\n              }\n            }, ttl + 1)\n            // unref() not supported on all platforms\n            /* c8 ignore start */\n            if (t.unref) {\n              t.unref()\n            }\n            /* c8 ignore stop */\n            purgeTimers[index] = t\n          }\n        }\n\n    this.#statusTTL = (status, index) => {\n      if (ttls[index]) {\n        const ttl = ttls[index]\n        const start = starts[index]\n        /* c8 ignore next */\n        if (!ttl || !start) return\n        status.ttl = ttl\n        status.start = start\n        status.now = cachedNow || getNow()\n        const age = status.now - start\n        status.remainingTTL = ttl - age\n      }\n    }\n\n    // debounce calls to perf.now() to 1s so we're not hitting\n    // that costly call repeatedly.\n    let cachedNow = 0\n    const getNow = () => {\n      const n = this.#perf.now()\n      if (this.ttlResolution > 0) {\n        cachedNow = n\n        const t = setTimeout(() => (cachedNow = 0), this.ttlResolution)\n        // not available on all platforms\n        /* c8 ignore start */\n        if (t.unref) {\n          t.unref()\n        }\n        /* c8 ignore stop */\n      }\n      return n\n    }\n\n    this.getRemainingTTL = key => {\n      const index = this.#keyMap.get(key)\n      if (index === undefined) {\n        return 0\n      }\n      const ttl = ttls[index]\n      const start = starts[index]\n      if (!ttl || !start) {\n        return Infinity\n      }\n      const age = (cachedNow || getNow()) - start\n      return ttl - age\n    }\n\n    this.#isStale = index => {\n      const s = starts[index]\n      const t = ttls[index]\n      return !!t && !!s && (cachedNow || getNow()) - s > t\n    }\n  }\n\n  // conditionally set private methods related to TTL\n  #updateItemAge: (index: Index) => void = () => {}\n  #statusTTL: (status: LRUCache.Status<V>, index: Index) => void = () => {}\n  #setItemTTL: (\n    index: Index,\n    ttl: LRUCache.Milliseconds,\n    start?: LRUCache.Milliseconds,\n    // ignore because we never call this if we're not already in TTL mode\n    /* c8 ignore start */\n  ) => void = () => {}\n  /* c8 ignore stop */\n\n  #isStale: (index: Index) => boolean = () => false\n\n  #initializeSizeTracking() {\n    const sizes = new ZeroArray(this.#max)\n    this.#calculatedSize = 0\n    this.#sizes = sizes\n    this.#removeItemSize = index => {\n      this.#calculatedSize -= sizes[index] as number\n      sizes[index] = 0\n    }\n    this.#requireSize = (k, v, size, sizeCalculation) => {\n      // provisionally accept background fetches.\n      // actual value size will be checked when they return.\n      if (this.#isBackgroundFetch(v)) {\n        return 0\n      }\n      if (!isPosInt(size)) {\n        if (sizeCalculation) {\n          if (typeof sizeCalculation !== 'function') {\n            throw new TypeError('sizeCalculation must be a function')\n          }\n          size = sizeCalculation(v, k)\n          if (!isPosInt(size)) {\n            throw new TypeError(\n              'sizeCalculation return invalid (expect positive integer)',\n            )\n          }\n        } else {\n          throw new TypeError(\n            'invalid size value (must be positive integer). ' +\n              'When maxSize or maxEntrySize is used, sizeCalculation ' +\n              'or size must be set.',\n          )\n        }\n      }\n      return size\n    }\n    this.#addItemSize = (\n      index: Index,\n      size: LRUCache.Size,\n      status?: LRUCache.Status<V>,\n    ) => {\n      sizes[index] = size\n      if (this.#maxSize) {\n        const maxSize = this.#maxSize - (sizes[index] as number)\n        while (this.#calculatedSize > maxSize) {\n          this.#evict(true)\n        }\n      }\n      this.#calculatedSize += sizes[index] as number\n      if (status) {\n        status.entrySize = size\n        status.totalCalculatedSize = this.#calculatedSize\n      }\n    }\n  }\n\n  #removeItemSize: (index: Index) => void = _i => {}\n  #addItemSize: (\n    index: Index,\n    size: LRUCache.Size,\n    status?: LRUCache.Status<V>,\n  ) => void = (_i, _s, _st) => {}\n  #requireSize: (\n    k: K,\n    v: V | BackgroundFetch<V>,\n    size?: LRUCache.Size,\n    sizeCalculation?: LRUCache.SizeCalculator<K, V>,\n  ) => LRUCache.Size = (\n    _k: K,\n    _v: V | BackgroundFetch<V>,\n    size?: LRUCache.Size,\n    sizeCalculation?: LRUCache.SizeCalculator<K, V>,\n  ) => {\n    if (size || sizeCalculation) {\n      throw new TypeError(\n        'cannot set size without setting maxSize or maxEntrySize on cache',\n      )\n    }\n    return 0\n  };\n\n  *#indexes({ allowStale = this.allowStale } = {}) {\n    if (this.#size) {\n      for (let i = this.#tail; true; ) {\n        if (!this.#isValidIndex(i)) {\n          break\n        }\n        if (allowStale || !this.#isStale(i)) {\n          yield i\n        }\n        if (i === this.#head) {\n          break\n        } else {\n          i = this.#prev[i] as Index\n        }\n      }\n    }\n  }\n\n  *#rindexes({ allowStale = this.allowStale } = {}) {\n    if (this.#size) {\n      for (let i = this.#head; true; ) {\n        if (!this.#isValidIndex(i)) {\n          break\n        }\n        if (allowStale || !this.#isStale(i)) {\n          yield i\n        }\n        if (i === this.#tail) {\n          break\n        } else {\n          i = this.#next[i] as Index\n        }\n      }\n    }\n  }\n\n  #isValidIndex(index: Index) {\n    return (\n      index !== undefined &&\n      this.#keyMap.get(this.#keyList[index] as K) === index\n    )\n  }\n\n  /**\n   * Return a generator yielding `[key, value]` pairs,\n   * in order from most recently used to least recently used.\n   */\n  *entries() {\n    for (const i of this.#indexes()) {\n      if (\n        this.#valList[i] !== undefined &&\n        this.#keyList[i] !== undefined &&\n        !this.#isBackgroundFetch(this.#valList[i])\n      ) {\n        yield [this.#keyList[i], this.#valList[i]] as [K, V]\n      }\n    }\n  }\n\n  /**\n   * Inverse order version of {@link LRUCache.entries}\n   *\n   * Return a generator yielding `[key, value]` pairs,\n   * in order from least recently used to most recently used.\n   */\n  *rentries() {\n    for (const i of this.#rindexes()) {\n      if (\n        this.#valList[i] !== undefined &&\n        this.#keyList[i] !== undefined &&\n        !this.#isBackgroundFetch(this.#valList[i])\n      ) {\n        yield [this.#keyList[i], this.#valList[i]]\n      }\n    }\n  }\n\n  /**\n   * Return a generator yielding the keys in the cache,\n   * in order from most recently used to least recently used.\n   */\n  *keys() {\n    for (const i of this.#indexes()) {\n      const k = this.#keyList[i]\n      if (k !== undefined && !this.#isBackgroundFetch(this.#valList[i])) {\n        yield k\n      }\n    }\n  }\n\n  /**\n   * Inverse order version of {@link LRUCache.keys}\n   *\n   * Return a generator yielding the keys in the cache,\n   * in order from least recently used to most recently used.\n   */\n  *rkeys() {\n    for (const i of this.#rindexes()) {\n      const k = this.#keyList[i]\n      if (k !== undefined && !this.#isBackgroundFetch(this.#valList[i])) {\n        yield k\n      }\n    }\n  }\n\n  /**\n   * Return a generator yielding the values in the cache,\n   * in order from most recently used to least recently used.\n   */\n  *values() {\n    for (const i of this.#indexes()) {\n      const v = this.#valList[i]\n      if (v !== undefined && !this.#isBackgroundFetch(this.#valList[i])) {\n        yield this.#valList[i] as V\n      }\n    }\n  }\n\n  /**\n   * Inverse order version of {@link LRUCache.values}\n   *\n   * Return a generator yielding the values in the cache,\n   * in order from least recently used to most recently used.\n   */\n  *rvalues() {\n    for (const i of this.#rindexes()) {\n      const v = this.#valList[i]\n      if (v !== undefined && !this.#isBackgroundFetch(this.#valList[i])) {\n        yield this.#valList[i]\n      }\n    }\n  }\n\n  /**\n   * Iterating over the cache itself yields the same results as\n   * {@link LRUCache.entries}\n   */\n  [Symbol.iterator]() {\n    return this.entries()\n  }\n\n  /**\n   * A String value that is used in the creation of the default string\n   * description of an object. Called by the built-in method\n   * `Object.prototype.toString`.\n   */\n  [Symbol.toStringTag] = 'LRUCache'\n\n  /**\n   * Find a value for which the supplied fn method returns a truthy value,\n   * similar to `Array.find()`. fn is called as `fn(value, key, cache)`.\n   */\n  find(\n    fn: (v: V, k: K, self: LRUCache<K, V, FC>) => boolean,\n    getOptions: LRUCache.GetOptions<K, V, FC> = {},\n  ) {\n    for (const i of this.#indexes()) {\n      const v = this.#valList[i]\n      const value = this.#isBackgroundFetch(v) ? v.__staleWhileFetching : v\n      if (value === undefined) continue\n      if (fn(value, this.#keyList[i] as K, this)) {\n        return this.get(this.#keyList[i] as K, getOptions)\n      }\n    }\n  }\n\n  /**\n   * Call the supplied function on each item in the cache, in order from most\n   * recently used to least recently used.\n   *\n   * `fn` is called as `fn(value, key, cache)`.\n   *\n   * If `thisp` is provided, function will be called in the `this`-context of\n   * the provided object, or the cache if no `thisp` object is provided.\n   *\n   * Does not update age or recenty of use, or iterate over stale values.\n   */\n  forEach(\n    fn: (v: V, k: K, self: LRUCache<K, V, FC>) => any,\n    thisp: any = this,\n  ) {\n    for (const i of this.#indexes()) {\n      const v = this.#valList[i]\n      const value = this.#isBackgroundFetch(v) ? v.__staleWhileFetching : v\n      if (value === undefined) continue\n      fn.call(thisp, value, this.#keyList[i] as K, this)\n    }\n  }\n\n  /**\n   * The same as {@link LRUCache.forEach} but items are iterated over in\n   * reverse order.  (ie, less recently used items are iterated over first.)\n   */\n  rforEach(\n    fn: (v: V, k: K, self: LRUCache<K, V, FC>) => any,\n    thisp: any = this,\n  ) {\n    for (const i of this.#rindexes()) {\n      const v = this.#valList[i]\n      const value = this.#isBackgroundFetch(v) ? v.__staleWhileFetching : v\n      if (value === undefined) continue\n      fn.call(thisp, value, this.#keyList[i] as K, this)\n    }\n  }\n\n  /**\n   * Delete any stale entries. Returns true if anything was removed,\n   * false otherwise.\n   */\n  purgeStale() {\n    let deleted = false\n    for (const i of this.#rindexes({ allowStale: true })) {\n      if (this.#isStale(i)) {\n        this.#delete(this.#keyList[i] as K, 'expire')\n        deleted = true\n      }\n    }\n    return deleted\n  }\n\n  /**\n   * Get the extended info about a given entry, to get its value, size, and\n   * TTL info simultaneously. Returns `undefined` if the key is not present.\n   *\n   * Unlike {@link LRUCache#dump}, which is designed to be portable and survive\n   * serialization, the `start` value is always the current timestamp, and the\n   * `ttl` is a calculated remaining time to live (negative if expired).\n   *\n   * Always returns stale values, if their info is found in the cache, so be\n   * sure to check for expirations (ie, a negative {@link LRUCache.Entry#ttl})\n   * if relevant.\n   */\n  info(key: K): LRUCache.Entry<V> | undefined {\n    const i = this.#keyMap.get(key)\n    if (i === undefined) return undefined\n    const v = this.#valList[i]\n    /* c8 ignore start - this isn't tested for the info function,\n     * but it's the same logic as found in other places. */\n    const value: V | undefined =\n      this.#isBackgroundFetch(v) ? v.__staleWhileFetching : v\n    if (value === undefined) return undefined\n    /* c8 ignore end */\n    const entry: LRUCache.Entry<V> = { value }\n    if (this.#ttls && this.#starts) {\n      const ttl = this.#ttls[i]\n      const start = this.#starts[i]\n      if (ttl && start) {\n        const remain = ttl - (this.#perf.now() - start)\n        entry.ttl = remain\n        entry.start = Date.now()\n      }\n    }\n    if (this.#sizes) {\n      entry.size = this.#sizes[i]\n    }\n    return entry\n  }\n\n  /**\n   * Return an array of [key, {@link LRUCache.Entry}] tuples which can be\n   * passed to {@link LRUCache#load}.\n   *\n   * The `start` fields are calculated relative to a portable `Date.now()`\n   * timestamp, even if `performance.now()` is available.\n   *\n   * Stale entries are always included in the `dump`, even if\n   * {@link LRUCache.OptionsBase.allowStale} is false.\n   *\n   * Note: this returns an actual array, not a generator, so it can be more\n   * easily passed around.\n   */\n  dump() {\n    const arr: [K, LRUCache.Entry<V>][] = []\n    for (const i of this.#indexes({ allowStale: true })) {\n      const key = this.#keyList[i]\n      const v = this.#valList[i]\n      const value: V | undefined =\n        this.#isBackgroundFetch(v) ? v.__staleWhileFetching : v\n      if (value === undefined || key === undefined) continue\n      const entry: LRUCache.Entry<V> = { value }\n      if (this.#ttls && this.#starts) {\n        entry.ttl = this.#ttls[i]\n        // always dump the start relative to a portable timestamp\n        // it's ok for this to be a bit slow, it's a rare operation.\n        const age = this.#perf.now() - (this.#starts[i] as number)\n        entry.start = Math.floor(Date.now() - age)\n      }\n      if (this.#sizes) {\n        entry.size = this.#sizes[i]\n      }\n      arr.unshift([key, entry])\n    }\n    return arr\n  }\n\n  /**\n   * Reset the cache and load in the items in entries in the order listed.\n   *\n   * The shape of the resulting cache may be different if the same options are\n   * not used in both caches.\n   *\n   * The `start` fields are assumed to be calculated relative to a portable\n   * `Date.now()` timestamp, even if `performance.now()` is available.\n   */\n  load(arr: [K, LRUCache.Entry<V>][]) {\n    this.clear()\n    for (const [key, entry] of arr) {\n      if (entry.start) {\n        // entry.start is a portable timestamp, but we may be using\n        // node's performance.now(), so calculate the offset, so that\n        // we get the intended remaining TTL, no matter how long it's\n        // been on ice.\n        //\n        // it's ok for this to be a bit slow, it's a rare operation.\n        const age = Date.now() - entry.start\n        entry.start = this.#perf.now() - age\n      }\n      this.set(key, entry.value, entry)\n    }\n  }\n\n  /**\n   * Add a value to the cache.\n   *\n   * Note: if `undefined` is specified as a value, this is an alias for\n   * {@link LRUCache#delete}\n   *\n   * Fields on the {@link LRUCache.SetOptions} options param will override\n   * their corresponding values in the constructor options for the scope\n   * of this single `set()` operation.\n   *\n   * If `start` is provided, then that will set the effective start\n   * time for the TTL calculation. Note that this must be a previous\n   * value of `performance.now()` if supported, or a previous value of\n   * `Date.now()` if not.\n   *\n   * Options object may also include `size`, which will prevent\n   * calling the `sizeCalculation` function and just use the specified\n   * number if it is a positive integer, and `noDisposeOnSet` which\n   * will prevent calling a `dispose` function in the case of\n   * overwrites.\n   *\n   * If the `size` (or return value of `sizeCalculation`) for a given\n   * entry is greater than `maxEntrySize`, then the item will not be\n   * added to the cache.\n   *\n   * Will update the recency of the entry.\n   *\n   * If the value is `undefined`, then this is an alias for\n   * `cache.delete(key)`. `undefined` is never stored in the cache.\n   */\n  set(\n    k: K,\n    v: V | BackgroundFetch<V> | undefined,\n    setOptions: LRUCache.SetOptions<K, V, FC> = {},\n  ) {\n    if (v === undefined) {\n      this.delete(k)\n      return this\n    }\n    const {\n      ttl = this.ttl,\n      start,\n      noDisposeOnSet = this.noDisposeOnSet,\n      sizeCalculation = this.sizeCalculation,\n      status,\n    } = setOptions\n    let { noUpdateTTL = this.noUpdateTTL } = setOptions\n\n    const size = this.#requireSize(\n      k,\n      v,\n      setOptions.size || 0,\n      sizeCalculation,\n    )\n    // if the item doesn't fit, don't do anything\n    // NB: maxEntrySize set to maxSize by default\n    if (this.maxEntrySize && size > this.maxEntrySize) {\n      if (status) {\n        status.set = 'miss'\n        status.maxEntrySizeExceeded = true\n      }\n      // have to delete, in case something is there already.\n      this.#delete(k, 'set')\n      return this\n    }\n    let index = this.#size === 0 ? undefined : this.#keyMap.get(k)\n    if (index === undefined) {\n      // addition\n      index = (\n        this.#size === 0 ? this.#tail\n        : this.#free.length !== 0 ? this.#free.pop()\n        : this.#size === this.#max ? this.#evict(false)\n        : this.#size) as Index\n      this.#keyList[index] = k\n      this.#valList[index] = v\n      this.#keyMap.set(k, index)\n      this.#next[this.#tail] = index\n      this.#prev[index] = this.#tail\n      this.#tail = index\n      this.#size++\n      this.#addItemSize(index, size, status)\n      if (status) status.set = 'add'\n      noUpdateTTL = false\n      if (this.#hasOnInsert) {\n        this.#onInsert?.(v as V, k, 'add')\n      }\n    } else {\n      // update\n      this.#moveToTail(index)\n      const oldVal = this.#valList[index] as V | BackgroundFetch<V>\n      if (v !== oldVal) {\n        if (this.#hasFetchMethod && this.#isBackgroundFetch(oldVal)) {\n          oldVal.__abortController.abort(new Error('replaced'))\n          const { __staleWhileFetching: s } = oldVal\n          if (s !== undefined && !noDisposeOnSet) {\n            if (this.#hasDispose) {\n              this.#dispose?.(s as V, k, 'set')\n            }\n            if (this.#hasDisposeAfter) {\n              this.#disposed?.push([s as V, k, 'set'])\n            }\n          }\n        } else if (!noDisposeOnSet) {\n          if (this.#hasDispose) {\n            this.#dispose?.(oldVal as V, k, 'set')\n          }\n          if (this.#hasDisposeAfter) {\n            this.#disposed?.push([oldVal as V, k, 'set'])\n          }\n        }\n        this.#removeItemSize(index)\n        this.#addItemSize(index, size, status)\n        this.#valList[index] = v\n        if (status) {\n          status.set = 'replace'\n          const oldValue =\n            oldVal && this.#isBackgroundFetch(oldVal) ?\n              oldVal.__staleWhileFetching\n            : oldVal\n          if (oldValue !== undefined) status.oldValue = oldValue\n        }\n      } else if (status) {\n        status.set = 'update'\n      }\n\n      if (this.#hasOnInsert) {\n        this.onInsert?.(v as V, k, v === oldVal ? 'update' : 'replace')\n      }\n    }\n    if (ttl !== 0 && !this.#ttls) {\n      this.#initializeTTLTracking()\n    }\n    if (this.#ttls) {\n      if (!noUpdateTTL) {\n        this.#setItemTTL(index, ttl, start)\n      }\n      if (status) this.#statusTTL(status, index)\n    }\n    if (!noDisposeOnSet && this.#hasDisposeAfter && this.#disposed) {\n      const dt = this.#disposed\n      let task: DisposeTask<K, V> | undefined\n      while ((task = dt?.shift())) {\n        this.#disposeAfter?.(...task)\n      }\n    }\n    return this\n  }\n\n  /**\n   * Evict the least recently used item, returning its value or\n   * `undefined` if cache is empty.\n   */\n  pop(): V | undefined {\n    try {\n      while (this.#size) {\n        const val = this.#valList[this.#head]\n        this.#evict(true)\n        if (this.#isBackgroundFetch(val)) {\n          if (val.__staleWhileFetching) {\n            return val.__staleWhileFetching\n          }\n        } else if (val !== undefined) {\n          return val\n        }\n      }\n    } finally {\n      if (this.#hasDisposeAfter && this.#disposed) {\n        const dt = this.#disposed\n        let task: DisposeTask<K, V> | undefined\n        while ((task = dt?.shift())) {\n          this.#disposeAfter?.(...task)\n        }\n      }\n    }\n  }\n\n  #evict(free: boolean) {\n    const head = this.#head\n    const k = this.#keyList[head] as K\n    const v = this.#valList[head] as V\n    if (this.#hasFetchMethod && this.#isBackgroundFetch(v)) {\n      v.__abortController.abort(new Error('evicted'))\n    } else if (this.#hasDispose || this.#hasDisposeAfter) {\n      if (this.#hasDispose) {\n        this.#dispose?.(v, k, 'evict')\n      }\n      if (this.#hasDisposeAfter) {\n        this.#disposed?.push([v, k, 'evict'])\n      }\n    }\n    this.#removeItemSize(head)\n    if (this.#autopurgeTimers?.[head]) {\n      clearTimeout(this.#autopurgeTimers[head])\n      this.#autopurgeTimers[head] = undefined\n    }\n    // if we aren't about to use the index, then null these out\n    if (free) {\n      this.#keyList[head] = undefined\n      this.#valList[head] = undefined\n      this.#free.push(head)\n    }\n    if (this.#size === 1) {\n      this.#head = this.#tail = 0 as Index\n      this.#free.length = 0\n    } else {\n      this.#head = this.#next[head] as Index\n    }\n    this.#keyMap.delete(k)\n    this.#size--\n    return head\n  }\n\n  /**\n   * Check if a key is in the cache, without updating the recency of use.\n   * Will return false if the item is stale, even though it is technically\n   * in the cache.\n   *\n   * Check if a key is in the cache, without updating the recency of\n   * use. Age is updated if {@link LRUCache.OptionsBase.updateAgeOnHas} is set\n   * to `true` in either the options or the constructor.\n   *\n   * Will return `false` if the item is stale, even though it is technically in\n   * the cache. The difference can be determined (if it matters) by using a\n   * `status` argument, and inspecting the `has` field.\n   *\n   * Will not update item age unless\n   * {@link LRUCache.OptionsBase.updateAgeOnHas} is set.\n   */\n  has(k: K, hasOptions: LRUCache.HasOptions<K, V, FC> = {}) {\n    const { updateAgeOnHas = this.updateAgeOnHas, status } = hasOptions\n    const index = this.#keyMap.get(k)\n    if (index !== undefined) {\n      const v = this.#valList[index]\n      if (\n        this.#isBackgroundFetch(v) &&\n        v.__staleWhileFetching === undefined\n      ) {\n        return false\n      }\n      if (!this.#isStale(index)) {\n        if (updateAgeOnHas) {\n          this.#updateItemAge(index)\n        }\n        if (status) {\n          status.has = 'hit'\n          this.#statusTTL(status, index)\n        }\n        return true\n      } else if (status) {\n        status.has = 'stale'\n        this.#statusTTL(status, index)\n      }\n    } else if (status) {\n      status.has = 'miss'\n    }\n    return false\n  }\n\n  /**\n   * Like {@link LRUCache#get} but doesn't update recency or delete stale\n   * items.\n   *\n   * Returns `undefined` if the item is stale, unless\n   * {@link LRUCache.OptionsBase.allowStale} is set.\n   */\n  peek(k: K, peekOptions: LRUCache.PeekOptions<K, V, FC> = {}) {\n    const { allowStale = this.allowStale } = peekOptions\n    const index = this.#keyMap.get(k)\n    if (index === undefined || (!allowStale && this.#isStale(index))) {\n      return\n    }\n    const v = this.#valList[index]\n    // either stale and allowed, or forcing a refresh of non-stale value\n    return this.#isBackgroundFetch(v) ? v.__staleWhileFetching : v\n  }\n\n  #backgroundFetch(\n    k: K,\n    index: Index | undefined,\n    options: LRUCache.FetchOptions<K, V, FC>,\n    context: any,\n  ): BackgroundFetch<V> {\n    const v = index === undefined ? undefined : this.#valList[index]\n    if (this.#isBackgroundFetch(v)) {\n      return v\n    }\n\n    const ac = new AC()\n    const { signal } = options\n    // when/if our AC signals, then stop listening to theirs.\n    signal?.addEventListener('abort', () => ac.abort(signal.reason), {\n      signal: ac.signal,\n    })\n\n    const fetchOpts = {\n      signal: ac.signal,\n      options,\n      context,\n    }\n\n    const cb = (v: V | undefined, updateCache = false): V | undefined => {\n      const { aborted } = ac.signal\n      const ignoreAbort = options.ignoreFetchAbort && v !== undefined\n      const proceed =\n        options.ignoreFetchAbort ||\n        !!(options.allowStaleOnFetchAbort && v !== undefined)\n      if (options.status) {\n        if (aborted && !updateCache) {\n          options.status.fetchAborted = true\n          options.status.fetchError = ac.signal.reason\n          if (ignoreAbort) options.status.fetchAbortIgnored = true\n        } else {\n          options.status.fetchResolved = true\n        }\n      }\n      if (aborted && !ignoreAbort && !updateCache) {\n        return fetchFail(ac.signal.reason, proceed)\n      }\n      // either we didn't abort, and are still here, or we did, and ignored\n      const bf = p as BackgroundFetch<V>\n      // if nothing else has been written there but we're set to update the\n      // cache and ignore the abort, or if it's still pending on this specific\n      // background request, then write it to the cache.\n      const vl = this.#valList[index as Index]\n      if (vl === p || (ignoreAbort && updateCache && vl === undefined)) {\n        if (v === undefined) {\n          if (bf.__staleWhileFetching !== undefined) {\n            this.#valList[index as Index] = bf.__staleWhileFetching\n          } else {\n            this.#delete(k, 'fetch')\n          }\n        } else {\n          if (options.status) options.status.fetchUpdated = true\n          this.set(k, v, fetchOpts.options)\n        }\n      }\n      return v\n    }\n\n    const eb = (er: any) => {\n      if (options.status) {\n        options.status.fetchRejected = true\n        options.status.fetchError = er\n      }\n      // do not pass go, do not collect $200\n      return fetchFail(er, false)\n    }\n\n    const fetchFail = (er: any, proceed: boolean): V | undefined => {\n      const { aborted } = ac.signal\n      const allowStaleAborted = aborted && options.allowStaleOnFetchAbort\n      const allowStale =\n        allowStaleAborted || options.allowStaleOnFetchRejection\n      const noDelete = allowStale || options.noDeleteOnFetchRejection\n      const bf = p as BackgroundFetch<V>\n      if (this.#valList[index as Index] === p) {\n        // if we allow stale on fetch rejections, then we need to ensure that\n        // the stale value is not removed from the cache when the fetch fails.\n        const del =\n          !noDelete || (!proceed && bf.__staleWhileFetching === undefined)\n        if (del) {\n          this.#delete(k, 'fetch')\n        } else if (!allowStaleAborted) {\n          // still replace the *promise* with the stale value,\n          // since we are done with the promise at this point.\n          // leave it untouched if we're still waiting for an\n          // aborted background fetch that hasn't yet returned.\n          this.#valList[index as Index] = bf.__staleWhileFetching\n        }\n      }\n      if (allowStale) {\n        if (options.status && bf.__staleWhileFetching !== undefined) {\n          options.status.returnedStale = true\n        }\n        return bf.__staleWhileFetching\n      } else if (bf.__returned === bf) {\n        throw er\n      }\n    }\n\n    const pcall = (\n      res: (v: V | undefined) => void,\n      rej: (e: any) => void,\n    ) => {\n      const fmp = this.#fetchMethod?.(k, v, fetchOpts)\n      if (fmp && fmp instanceof Promise) {\n        fmp.then(v => res(v === undefined ? undefined : v), rej)\n      }\n      // ignored, we go until we finish, regardless.\n      // defer check until we are actually aborting,\n      // so fetchMethod can override.\n      ac.signal.addEventListener('abort', () => {\n        if (!options.ignoreFetchAbort || options.allowStaleOnFetchAbort) {\n          res(undefined)\n          // when it eventually resolves, update the cache.\n          if (options.allowStaleOnFetchAbort) {\n            res = v => cb(v, true)\n          }\n        }\n      })\n    }\n\n    if (options.status) options.status.fetchDispatched = true\n    const p = new Promise(pcall).then(cb, eb)\n    const bf: BackgroundFetch<V> = Object.assign(p, {\n      __abortController: ac,\n      __staleWhileFetching: v,\n      __returned: undefined,\n    })\n\n    if (index === undefined) {\n      // internal, don't expose status.\n      this.set(k, bf, { ...fetchOpts.options, status: undefined })\n      index = this.#keyMap.get(k)\n    } else {\n      this.#valList[index] = bf\n    }\n    return bf\n  }\n\n  #isBackgroundFetch(p: any): p is BackgroundFetch<V> {\n    if (!this.#hasFetchMethod) return false\n    const b = p as BackgroundFetch<V>\n    return (\n      !!b &&\n      b instanceof Promise &&\n      b.hasOwnProperty('__staleWhileFetching') &&\n      b.__abortController instanceof AC\n    )\n  }\n\n  /**\n   * Make an asynchronous cached fetch using the\n   * {@link LRUCache.OptionsBase.fetchMethod} function.\n   *\n   * If the value is in the cache and not stale, then the returned\n   * Promise resolves to the value.\n   *\n   * If not in the cache, or beyond its TTL staleness, then\n   * `fetchMethod(key, staleValue, { options, signal, context })` is\n   * called, and the value returned will be added to the cache once\n   * resolved.\n   *\n   * If called with `allowStale`, and an asynchronous fetch is\n   * currently in progress to reload a stale value, then the former\n   * stale value will be returned.\n   *\n   * If called with `forceRefresh`, then the cached item will be\n   * re-fetched, even if it is not stale. However, if `allowStale` is also\n   * set, then the old value will still be returned. This is useful\n   * in cases where you want to force a reload of a cached value. If\n   * a background fetch is already in progress, then `forceRefresh`\n   * has no effect.\n   *\n   * If multiple fetches for the same key are issued, then they will all be\n   * coalesced into a single call to fetchMethod.\n   *\n   * Note that this means that handling options such as\n   * {@link LRUCache.OptionsBase.allowStaleOnFetchAbort},\n   * {@link LRUCache.FetchOptions.signal},\n   * and {@link LRUCache.OptionsBase.allowStaleOnFetchRejection} will be\n   * determined by the FIRST fetch() call for a given key.\n   *\n   * This is a known (fixable) shortcoming which will be addresed on when\n   * someone complains about it, as the fix would involve added complexity and\n   * may not be worth the costs for this edge case.\n   *\n   * If {@link LRUCache.OptionsBase.fetchMethod} is not specified, then this is\n   * effectively an alias for `Promise.resolve(cache.get(key))`.\n   *\n   * When the fetch method resolves to a value, if the fetch has not\n   * been aborted due to deletion, eviction, or being overwritten,\n   * then it is added to the cache using the options provided.\n   *\n   * If the key is evicted or deleted before the `fetchMethod`\n   * resolves, then the AbortSignal passed to the `fetchMethod` will\n   * receive an `abort` event, and the promise returned by `fetch()`\n   * will reject with the reason for the abort.\n   *\n   * If a `signal` is passed to the `fetch()` call, then aborting the\n   * signal will abort the fetch and cause the `fetch()` promise to\n   * reject with the reason provided.\n   *\n   * **Setting `context`**\n   *\n   * If an `FC` type is set to a type other than `unknown`, `void`, or\n   * `undefined` in the {@link LRUCache} constructor, then all\n   * calls to `cache.fetch()` _must_ provide a `context` option. If\n   * set to `undefined` or `void`, then calls to fetch _must not_\n   * provide a `context` option.\n   *\n   * The `context` param allows you to provide arbitrary data that\n   * might be relevant in the course of fetching the data. It is only\n   * relevant for the course of a single `fetch()` operation, and\n   * discarded afterwards.\n   *\n   * **Note: `fetch()` calls are inflight-unique**\n   *\n   * If you call `fetch()` multiple times with the same key value,\n   * then every call after the first will resolve on the same\n   * promise<sup>1</sup>,\n   * _even if they have different settings that would otherwise change\n   * the behavior of the fetch_, such as `noDeleteOnFetchRejection`\n   * or `ignoreFetchAbort`.\n   *\n   * In most cases, this is not a problem (in fact, only fetching\n   * something once is what you probably want, if you're caching in\n   * the first place). If you are changing the fetch() options\n   * dramatically between runs, there's a good chance that you might\n   * be trying to fit divergent semantics into a single object, and\n   * would be better off with multiple cache instances.\n   *\n   * **1**: Ie, they're not the \"same Promise\", but they resolve at\n   * the same time, because they're both waiting on the same\n   * underlying fetchMethod response.\n   */\n\n  fetch(\n    k: K,\n    fetchOptions: unknown extends FC ? LRUCache.FetchOptions<K, V, FC>\n    : FC extends undefined | void ? LRUCache.FetchOptionsNoContext<K, V>\n    : LRUCache.FetchOptionsWithContext<K, V, FC>,\n  ): Promise<undefined | V>\n\n  // this overload not allowed if context is required\n  fetch(\n    k: unknown extends FC ? K\n    : FC extends undefined | void ? K\n    : never,\n    fetchOptions?: unknown extends FC ? LRUCache.FetchOptions<K, V, FC>\n    : FC extends undefined | void ? LRUCache.FetchOptionsNoContext<K, V>\n    : never,\n  ): Promise<undefined | V>\n\n  async fetch(\n    k: K,\n    fetchOptions: LRUCache.FetchOptions<K, V, FC> = {},\n  ): Promise<undefined | V> {\n    const {\n      // get options\n      allowStale = this.allowStale,\n      updateAgeOnGet = this.updateAgeOnGet,\n      noDeleteOnStaleGet = this.noDeleteOnStaleGet,\n      // set options\n      ttl = this.ttl,\n      noDisposeOnSet = this.noDisposeOnSet,\n      size = 0,\n      sizeCalculation = this.sizeCalculation,\n      noUpdateTTL = this.noUpdateTTL,\n      // fetch exclusive options\n      noDeleteOnFetchRejection = this.noDeleteOnFetchRejection,\n      allowStaleOnFetchRejection = this.allowStaleOnFetchRejection,\n      ignoreFetchAbort = this.ignoreFetchAbort,\n      allowStaleOnFetchAbort = this.allowStaleOnFetchAbort,\n      context,\n      forceRefresh = false,\n      status,\n      signal,\n    } = fetchOptions\n\n    if (!this.#hasFetchMethod) {\n      if (status) status.fetch = 'get'\n      return this.get(k, {\n        allowStale,\n        updateAgeOnGet,\n        noDeleteOnStaleGet,\n        status,\n      })\n    }\n\n    const options = {\n      allowStale,\n      updateAgeOnGet,\n      noDeleteOnStaleGet,\n      ttl,\n      noDisposeOnSet,\n      size,\n      sizeCalculation,\n      noUpdateTTL,\n      noDeleteOnFetchRejection,\n      allowStaleOnFetchRejection,\n      allowStaleOnFetchAbort,\n      ignoreFetchAbort,\n      status,\n      signal,\n    }\n\n    let index = this.#keyMap.get(k)\n    if (index === undefined) {\n      if (status) status.fetch = 'miss'\n      const p = this.#backgroundFetch(k, index, options, context)\n      return (p.__returned = p)\n    } else {\n      // in cache, maybe already fetching\n      const v = this.#valList[index]\n      if (this.#isBackgroundFetch(v)) {\n        const stale = allowStale && v.__staleWhileFetching !== undefined\n        if (status) {\n          status.fetch = 'inflight'\n          if (stale) status.returnedStale = true\n        }\n        return stale ? v.__staleWhileFetching : (v.__returned = v)\n      }\n\n      // if we force a refresh, that means do NOT serve the cached value,\n      // unless we are already in the process of refreshing the cache.\n      const isStale = this.#isStale(index)\n      if (!forceRefresh && !isStale) {\n        if (status) status.fetch = 'hit'\n        this.#moveToTail(index)\n        if (updateAgeOnGet) {\n          this.#updateItemAge(index)\n        }\n        if (status) this.#statusTTL(status, index)\n        return v\n      }\n\n      // ok, it is stale or a forced refresh, and not already fetching.\n      // refresh the cache.\n      const p = this.#backgroundFetch(k, index, options, context)\n      const hasStale = p.__staleWhileFetching !== undefined\n      const staleVal = hasStale && allowStale\n      if (status) {\n        status.fetch = isStale ? 'stale' : 'refresh'\n        if (staleVal && isStale) status.returnedStale = true\n      }\n      return staleVal ? p.__staleWhileFetching : (p.__returned = p)\n    }\n  }\n\n  /**\n   * In some cases, `cache.fetch()` may resolve to `undefined`, either because\n   * a {@link LRUCache.OptionsBase#fetchMethod} was not provided (turning\n   * `cache.fetch(k)` into just an async wrapper around `cache.get(k)`) or\n   * because `ignoreFetchAbort` was specified (either to the constructor or\n   * in the {@link LRUCache.FetchOptions}). Also, the\n   * {@link LRUCache.OptionsBase.fetchMethod} may return `undefined` or `void`, making\n   * the test even more complicated.\n   *\n   * Because inferring the cases where `undefined` might be returned are so\n   * cumbersome, but testing for `undefined` can also be annoying, this method\n   * can be used, which will reject if `this.fetch()` resolves to undefined.\n   */\n  forceFetch(\n    k: K,\n    fetchOptions: unknown extends FC ? LRUCache.FetchOptions<K, V, FC>\n    : FC extends undefined | void ? LRUCache.FetchOptionsNoContext<K, V>\n    : LRUCache.FetchOptionsWithContext<K, V, FC>,\n  ): Promise<V>\n  // this overload not allowed if context is required\n  forceFetch(\n    k: unknown extends FC ? K\n    : FC extends undefined | void ? K\n    : never,\n    fetchOptions?: unknown extends FC ? LRUCache.FetchOptions<K, V, FC>\n    : FC extends undefined | void ? LRUCache.FetchOptionsNoContext<K, V>\n    : never,\n  ): Promise<V>\n  async forceFetch(\n    k: K,\n    fetchOptions: LRUCache.FetchOptions<K, V, FC> = {},\n  ): Promise<V> {\n    const v = await this.fetch(\n      k,\n      fetchOptions as unknown extends FC ? LRUCache.FetchOptions<K, V, FC>\n      : FC extends undefined | void ? LRUCache.FetchOptionsNoContext<K, V>\n      : LRUCache.FetchOptionsWithContext<K, V, FC>,\n    )\n    if (v === undefined) throw new Error('fetch() returned undefined')\n    return v\n  }\n\n  /**\n   * If the key is found in the cache, then this is equivalent to\n   * {@link LRUCache#get}. If not, in the cache, then calculate the value using\n   * the {@link LRUCache.OptionsBase.memoMethod}, and add it to the cache.\n   *\n   * If an `FC` type is set to a type other than `unknown`, `void`, or\n   * `undefined` in the LRUCache constructor, then all calls to `cache.memo()`\n   * _must_ provide a `context` option. If set to `undefined` or `void`, then\n   * calls to memo _must not_ provide a `context` option.\n   *\n   * The `context` param allows you to provide arbitrary data that might be\n   * relevant in the course of fetching the data. It is only relevant for the\n   * course of a single `memo()` operation, and discarded afterwards.\n   */\n  memo(\n    k: K,\n    memoOptions: unknown extends FC ? LRUCache.MemoOptions<K, V, FC>\n    : FC extends undefined | void ? LRUCache.MemoOptionsNoContext<K, V>\n    : LRUCache.MemoOptionsWithContext<K, V, FC>,\n  ): V\n  // this overload not allowed if context is required\n  memo(\n    k: unknown extends FC ? K\n    : FC extends undefined | void ? K\n    : never,\n    memoOptions?: unknown extends FC ? LRUCache.MemoOptions<K, V, FC>\n    : FC extends undefined | void ? LRUCache.MemoOptionsNoContext<K, V>\n    : never,\n  ): V\n  memo(k: K, memoOptions: LRUCache.MemoOptions<K, V, FC> = {}) {\n    const memoMethod = this.#memoMethod\n    if (!memoMethod) {\n      throw new Error('no memoMethod provided to constructor')\n    }\n    const { context, forceRefresh, ...options } = memoOptions\n    const v = this.get(k, options)\n    if (!forceRefresh && v !== undefined) return v\n    const vv = memoMethod(k, v, {\n      options,\n      context,\n    } as LRUCache.MemoizerOptions<K, V, FC>)\n    this.set(k, vv, options)\n    return vv\n  }\n\n  /**\n   * Return a value from the cache. Will update the recency of the cache\n   * entry found.\n   *\n   * If the key is not found, get() will return `undefined`.\n   */\n  get(k: K, getOptions: LRUCache.GetOptions<K, V, FC> = {}) {\n    const {\n      allowStale = this.allowStale,\n      updateAgeOnGet = this.updateAgeOnGet,\n      noDeleteOnStaleGet = this.noDeleteOnStaleGet,\n      status,\n    } = getOptions\n    const index = this.#keyMap.get(k)\n    if (index !== undefined) {\n      const value = this.#valList[index]\n      const fetching = this.#isBackgroundFetch(value)\n      if (status) this.#statusTTL(status, index)\n      if (this.#isStale(index)) {\n        if (status) status.get = 'stale'\n        // delete only if not an in-flight background fetch\n        if (!fetching) {\n          if (!noDeleteOnStaleGet) {\n            this.#delete(k, 'expire')\n          }\n          if (status && allowStale) status.returnedStale = true\n          return allowStale ? value : undefined\n        } else {\n          if (\n            status &&\n            allowStale &&\n            value.__staleWhileFetching !== undefined\n          ) {\n            status.returnedStale = true\n          }\n          return allowStale ? value.__staleWhileFetching : undefined\n        }\n      } else {\n        if (status) status.get = 'hit'\n        // if we're currently fetching it, we don't actually have it yet\n        // it's not stale, which means this isn't a staleWhileRefetching.\n        // If it's not stale, and fetching, AND has a __staleWhileFetching\n        // value, then that means the user fetched with {forceRefresh:true},\n        // so it's safe to return that value.\n        if (fetching) {\n          return value.__staleWhileFetching\n        }\n        this.#moveToTail(index)\n        if (updateAgeOnGet) {\n          this.#updateItemAge(index)\n        }\n        return value\n      }\n    } else if (status) {\n      status.get = 'miss'\n    }\n  }\n\n  #connect(p: Index, n: Index) {\n    this.#prev[n] = p\n    this.#next[p] = n\n  }\n\n  #moveToTail(index: Index): void {\n    // if tail already, nothing to do\n    // if head, move head to next[index]\n    // else\n    //   move next[prev[index]] to next[index] (head has no prev)\n    //   move prev[next[index]] to prev[index]\n    // prev[index] = tail\n    // next[tail] = index\n    // tail = index\n    if (index !== this.#tail) {\n      if (index === this.#head) {\n        this.#head = this.#next[index] as Index\n      } else {\n        this.#connect(\n          this.#prev[index] as Index,\n          this.#next[index] as Index,\n        )\n      }\n      this.#connect(this.#tail, index)\n      this.#tail = index\n    }\n  }\n\n  /**\n   * Deletes a key out of the cache.\n   *\n   * Returns true if the key was deleted, false otherwise.\n   */\n  delete(k: K) {\n    return this.#delete(k, 'delete')\n  }\n\n  #delete(k: K, reason: LRUCache.DisposeReason) {\n    let deleted = false\n    if (this.#size !== 0) {\n      const index = this.#keyMap.get(k)\n      if (index !== undefined) {\n        if (this.#autopurgeTimers?.[index]) {\n          clearTimeout(this.#autopurgeTimers?.[index])\n          this.#autopurgeTimers[index] = undefined\n        }\n        deleted = true\n        if (this.#size === 1) {\n          this.#clear(reason)\n        } else {\n          this.#removeItemSize(index)\n          const v = this.#valList[index]\n          if (this.#isBackgroundFetch(v)) {\n            v.__abortController.abort(new Error('deleted'))\n          } else if (this.#hasDispose || this.#hasDisposeAfter) {\n            if (this.#hasDispose) {\n              this.#dispose?.(v as V, k, reason)\n            }\n            if (this.#hasDisposeAfter) {\n              this.#disposed?.push([v as V, k, reason])\n            }\n          }\n          this.#keyMap.delete(k)\n          this.#keyList[index] = undefined\n          this.#valList[index] = undefined\n          if (index === this.#tail) {\n            this.#tail = this.#prev[index] as Index\n          } else if (index === this.#head) {\n            this.#head = this.#next[index] as Index\n          } else {\n            const pi = this.#prev[index] as number\n            this.#next[pi] = this.#next[index] as number\n            const ni = this.#next[index] as number\n            this.#prev[ni] = this.#prev[index] as number\n          }\n          this.#size--\n          this.#free.push(index)\n        }\n      }\n    }\n    if (this.#hasDisposeAfter && this.#disposed?.length) {\n      const dt = this.#disposed\n      let task: DisposeTask<K, V> | undefined\n      while ((task = dt?.shift())) {\n        this.#disposeAfter?.(...task)\n      }\n    }\n    return deleted\n  }\n\n  /**\n   * Clear the cache entirely, throwing away all values.\n   */\n  clear() {\n    return this.#clear('delete')\n  }\n  #clear(reason: LRUCache.DisposeReason) {\n    for (const index of this.#rindexes({ allowStale: true })) {\n      const v = this.#valList[index]\n      if (this.#isBackgroundFetch(v)) {\n        v.__abortController.abort(new Error('deleted'))\n      } else {\n        const k = this.#keyList[index]\n        if (this.#hasDispose) {\n          this.#dispose?.(v as V, k as K, reason)\n        }\n        if (this.#hasDisposeAfter) {\n          this.#disposed?.push([v as V, k as K, reason])\n        }\n      }\n    }\n\n    this.#keyMap.clear()\n    this.#valList.fill(undefined)\n    this.#keyList.fill(undefined)\n    if (this.#ttls && this.#starts) {\n      this.#ttls.fill(0)\n      this.#starts.fill(0)\n      for (const t of this.#autopurgeTimers ?? []) {\n        if (t !== undefined) clearTimeout(t)\n      }\n      this.#autopurgeTimers?.fill(undefined)\n    }\n    if (this.#sizes) {\n      this.#sizes.fill(0)\n    }\n    this.#head = 0 as Index\n    this.#tail = 0 as Index\n    this.#free.length = 0\n    this.#calculatedSize = 0\n    this.#size = 0\n    if (this.#hasDisposeAfter && this.#disposed) {\n      const dt = this.#disposed\n      let task: DisposeTask<K, V> | undefined\n      while ((task = dt?.shift())) {\n        this.#disposeAfter?.(...task)\n      }\n    }\n  }\n}\n","import { LRUCache } from \"lru-cache\";\n\nexport default class CachedMap<K extends {}, V extends {}> implements Map<K, V> {\n    readonly cache: LRUCache<K, V>;\n    readonly map: Map<K, V> = new Map();\n    constructor(options: { cacheSize: number }) {\n        this.cache = new LRUCache<K, V>({\n            max: options.cacheSize,\n        });\n        this.map = new Map();\n    }\n    get [Symbol.iterator]() {\n        return this.map[Symbol.iterator];\n    }\n    get [Symbol.toStringTag]() {\n        return this.map[Symbol.toStringTag];\n    }\n    clear(): void {\n        this.cache.clear();\n        return this.map.clear();\n    }\n    delete(key: K): boolean {\n        const deleted = this.map.delete(key);\n        if (deleted) {\n            this.cache.delete(key);\n        }\n        return deleted;\n    }\n    get forEach() {\n        return this.map.forEach;\n    }\n    get(key: K): V | undefined {\n        const cachedValue = this.cache.get(key);\n        if (cachedValue) {\n            return cachedValue;\n        }\n        return this.map.get(key);\n    }\n    has(key: K): boolean {\n        return this.map.has(key);\n    }\n    set(key: K, value: V): this {\n        this.map.set(key, value);\n        this.cache.set(key, value);\n        return this;\n    }\n    get size() {\n        return this.map.size;\n    }\n    entries() {\n        return this.map.entries();\n    }\n    keys() {\n        return this.map.keys();\n    }\n    values() {\n        return this.map.values();\n    }\n}\n","import { CachedMap } from \"../../classes\";\nimport { logger } from \"../../utils/log-utility\";\nimport Label from \"../classes/Label\";\nimport LabelAbstract from \"../classes/LabelAbstract\";\nimport { LabelIdType } from \"../types/LabelIdType\";\n\n/**\n * A Map that contains all labels registered and available to be used.\n * The key is the id of the label and the value is the label itself.\n */\nconst registeredLabels = new CachedMap<LabelIdType, LabelAbstract<any> | Label<any>>({ cacheSize: 10 });\n\nnamespace RegisteredLabels {\n    /**\n     * Gets a label by its id\n     * @param id The id of the label\n     * @returns The label or undefined if it does not exist\n     */\n    export function get<T = LabelAbstract<any>>(id: LabelIdType): T | undefined {\n        let label = registeredLabels.get(id);\n        if (!label) {\n            logger.error(`Label \"${id}\" not found`);\n            return;\n        }\n        return label as T;\n    }\n\n    /**\n     * Saves a label in the system\n     * @param label The label to be saved\n     */\n    export function add(label: LabelAbstract<any, any> | LabelAbstract<any, any>[]) {\n        if (Array.isArray(label)) {\n            label.forEach((l) => add(l));\n            return;\n        }\n        if (registeredLabels.has(label.id)) {\n            logger.info(`Label \"${label.id}\" already exists, it will be overwritten`);\n        }\n        registeredLabels.set(label.id, label);\n    }\n\n    /**\n     * Get a list of all labels registered.\n     * @returns An array of labels.\n     */\n    export function values(): LabelAbstract<any>[] {\n        return Array.from(registeredLabels.values());\n    }\n\n    /**\n     * Check if a label is registered\n     * @param id The id of the label\n     * @returns True if the label is registered, false otherwise\n     */\n    export function has(id: string): boolean {\n        return registeredLabels.has(id);\n    }\n\n    /**\n     * Get a list of all label ids registered.\n     * @returns An array of label ids.\n     */\n    export function keys(): string[] {\n        return Array.from(registeredLabels.keys());\n    }\n}\nexport default RegisteredLabels;\n","import { GameUnifier, PixiError } from \"@drincs/pixi-vn/core\";\nimport { LabelAbstract } from \".\";\nimport { SYSTEM_RESERVED_STORAGE_KEYS } from \"../storage/constants\";\nimport { createExportableElement } from \"../utils\";\nimport { logger } from \"../utils/log-utility\";\nimport Label from \"./classes/Label\";\nimport RegisteredLabels from \"./decorators/RegisteredLabels\";\nimport HistoryStep from \"./interfaces/HistoryStep\";\nimport OpenedLabel from \"./interfaces/OpenedLabel\";\nimport ChoicesMadeType from \"./types/ChoicesMadeType\";\nimport { LabelIdType } from \"./types/LabelIdType\";\n\ntype AllOpenedLabelsType = { [key: LabelIdType]: { biggestStep: number; openCount: number } };\n\ntype CurrentStepTimesCounterMemotyData = {\n    /**\n     * @deprecated use stepIndexs\n     */\n    lastStepIndexs?: number[];\n    stepCounters?: number[];\n    usedRandomNumbers?: { [minmaxkey: string]: number[] };\n    stepSha1: string;\n};\ntype CurrentStepTimesCounterMemoty = {\n    [key: LabelIdType]: {\n        [key: string]: CurrentStepTimesCounterMemotyData;\n    };\n};\n\nexport default class NarrationManagerStatic {\n    private constructor() {}\n    static choiceMadeTemp: undefined | number = undefined;\n    static lastHistoryStep: Omit<HistoryStep, \"diff\"> | null = null;\n    /**\n     * is a list of all labels that have been opened during the progression of the steps.\n     * the key is the label id and the biggest step opened.\n     */\n    static get allOpenedLabels() {\n        return (\n            GameUnifier.getVariable<AllOpenedLabelsType>(SYSTEM_RESERVED_STORAGE_KEYS.OPENED_LABELS_COUNTER_KEY) || {}\n        );\n    }\n    static set allOpenedLabels(value: AllOpenedLabelsType) {\n        GameUnifier.setVariable(SYSTEM_RESERVED_STORAGE_KEYS.OPENED_LABELS_COUNTER_KEY, value);\n    }\n    static getCurrentStepTimesCounterData(nestedId: string = \"\"): CurrentStepTimesCounterMemotyData | null {\n        let currentLabelStepIndex = NarrationManagerStatic.currentLabelStepIndex;\n        if (currentLabelStepIndex === null) {\n            logger.error(\"currentLabelStepIndex is null\");\n            return null;\n        }\n        let currentLabelStepIndexId = `${currentLabelStepIndex}${nestedId}`;\n        let labelId = NarrationManagerStatic.currentLabelId;\n        let currentLabel = NarrationManagerStatic._currentLabel;\n        if (!labelId || currentLabelStepIndex === null || !currentLabel) {\n            logger.error(\"currentLabelId or currentLabelStepIndex is null or currentLabel not found\");\n            return null;\n        }\n        let stepSha1 = currentLabel.getStepSha(currentLabelStepIndex) || \"error\";\n        let obj =\n            GameUnifier.getVariable<CurrentStepTimesCounterMemoty>(\n                SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_STEP_TIMES_COUNTER_KEY,\n            ) || {};\n        if (!obj[labelId]) {\n            obj[labelId] = {};\n        }\n        if (!obj[labelId][currentLabelStepIndexId] || obj[labelId][currentLabelStepIndexId].stepSha1 != stepSha1) {\n            obj[labelId][currentLabelStepIndexId] = { stepSha1: stepSha1 };\n        }\n        return obj[labelId][currentLabelStepIndexId];\n    }\n    private static setCurrentStepTimesCounterData(nestedId: string = \"\", data: CurrentStepTimesCounterMemotyData) {\n        let currentLabelStepIndex = NarrationManagerStatic.currentLabelStepIndex;\n        let currentLabelStepIndexId = currentLabelStepIndex + nestedId;\n        let labelId = NarrationManagerStatic.currentLabelId;\n        if (!labelId || currentLabelStepIndex === null) {\n            logger.error(\"currentLabelId or currentLabelStepIndex is null\");\n            return;\n        }\n        let obj =\n            GameUnifier.getVariable<CurrentStepTimesCounterMemoty>(\n                SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_STEP_TIMES_COUNTER_KEY,\n            ) || {};\n        if (!obj[labelId]) {\n            obj[labelId] = {};\n        }\n        obj[labelId][currentLabelStepIndexId] = data;\n        GameUnifier.setVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_STEP_TIMES_COUNTER_KEY, obj);\n    }\n    static getCurrentStepTimesCounter(nestedId: string = \"\"): number {\n        let lastStep = NarrationManagerStatic._stepCounter;\n        let obj = NarrationManagerStatic.getCurrentStepTimesCounterData(nestedId);\n        if (!obj) {\n            logger.error(\"getCurrentStepTimesCounter obj is null\");\n            return 0;\n        }\n        let list = obj.stepCounters || obj.lastStepIndexs || [];\n        let listContainLastStep = list.find((item) => item === lastStep);\n        if (!listContainLastStep) {\n            list.push(lastStep);\n            delete obj.lastStepIndexs;\n            obj.stepCounters = list;\n            NarrationManagerStatic.setCurrentStepTimesCounterData(nestedId, obj);\n        }\n        return list.length;\n    }\n    static getRandomNumber(\n        min: number,\n        max: number,\n        options: {\n            onceOnly?: boolean;\n            nestedId?: string;\n        } = {},\n    ): number | undefined {\n        let nestedId = options.nestedId || \"\";\n        let onceonly = options.onceOnly || false;\n        if (onceonly) {\n            let obj = NarrationManagerStatic.getCurrentStepTimesCounterData(nestedId);\n            if (!obj) {\n                return undefined;\n            }\n            let usedRandomNumbers = obj.usedRandomNumbers || {};\n            // get a random number between min and max and not in the usedRandomNumbers, if all numbers are in the usedRandomNumbers, return null\n            let allNumbers = Array.from({ length: max - min + 1 }, (_, i) => i + min).filter(\n                (item) => !usedRandomNumbers[`${min}-${max}`]?.includes(item),\n            );\n            if (allNumbers.length === 0) {\n                return undefined;\n            }\n            let randomIndex = Math.floor(Math.random() * allNumbers.length);\n            let randomNumber = allNumbers[randomIndex];\n            if (!usedRandomNumbers[`${min}-${max}`]) {\n                usedRandomNumbers[`${min}-${max}`] = [];\n            }\n            usedRandomNumbers[`${min}-${max}`].push(randomNumber);\n            obj.usedRandomNumbers = usedRandomNumbers;\n            NarrationManagerStatic.setCurrentStepTimesCounterData(nestedId, obj);\n            return randomNumber;\n        }\n        return Math.floor(Math.random() * (max - min + 1)) + min;\n    }\n    static resetCurrentStepTimesCounter(nestedId: string = \"\") {\n        let currentLabelStepIndex = NarrationManagerStatic.currentLabelStepIndex;\n        let currentLabelStepIndexId = currentLabelStepIndex + nestedId;\n        let labelId = NarrationManagerStatic.currentLabelId;\n        if (!labelId || currentLabelStepIndex === null) {\n            logger.error(\"currentLabelId or currentLabelStepIndex is null\");\n            return;\n        }\n        let obj =\n            GameUnifier.getVariable<CurrentStepTimesCounterMemoty>(\n                SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_STEP_TIMES_COUNTER_KEY,\n            ) || {};\n        if (!obj[labelId]) {\n            obj[labelId] = {};\n        }\n        obj[labelId][currentLabelStepIndexId] = { stepCounters: [], stepSha1: \"\" };\n        GameUnifier.setVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_STEP_TIMES_COUNTER_KEY, obj);\n    }\n    /**\n     * is a list of all choices made by the player during the progression of the steps.\n     */\n    static get allChoicesMade() {\n        return GameUnifier.getVariable<ChoicesMadeType[]>(SYSTEM_RESERVED_STORAGE_KEYS.ALL_CHOICES_MADE_KEY) || [];\n    }\n    static set allChoicesMade(value: ChoicesMadeType[]) {\n        GameUnifier.setVariable(SYSTEM_RESERVED_STORAGE_KEYS.ALL_CHOICES_MADE_KEY, value);\n    }\n    static _stepCounter: number = 0;\n    /**\n     * Increase the last step index that occurred during the progression of the steps.\n     */\n    static increaseStepCounter() {\n        NarrationManagerStatic._stepCounter++;\n    }\n    private static _openedLabels: OpenedLabel[] = [];\n    static get openedLabels(): OpenedLabel[] {\n        return createExportableElement(NarrationManagerStatic._openedLabels);\n    }\n    static set openedLabels(value: OpenedLabel[]) {\n        NarrationManagerStatic._openedLabels = createExportableElement(value);\n    }\n    private static _originalOpenedLabels: OpenedLabel[] = [];\n    static get originalOpenedLabels(): OpenedLabel[] {\n        return createExportableElement(NarrationManagerStatic._originalOpenedLabels);\n    }\n    static set originalOpenedLabels(value: OpenedLabel[]) {\n        NarrationManagerStatic._originalOpenedLabels = createExportableElement(value);\n    }\n    static get _currentLabel(): Label | undefined {\n        if (NarrationManagerStatic.currentLabelId) {\n            return RegisteredLabels.get(NarrationManagerStatic.currentLabelId);\n        }\n    }\n    /**\n     * currentLabelId is the current label id that occurred during the progression of the steps.\n     */\n    static get currentLabelId(): LabelIdType | undefined {\n        if (NarrationManagerStatic._openedLabels.length > 0) {\n            let item = NarrationManagerStatic._openedLabels[NarrationManagerStatic._openedLabels.length - 1];\n            return item.label;\n        }\n        return undefined;\n    }\n    static get currentLabelStepIndex(): number | null {\n        if (NarrationManagerStatic._openedLabels.length > 0) {\n            let item = NarrationManagerStatic._openedLabels[NarrationManagerStatic._openedLabels.length - 1];\n            return item.currentStepIndex;\n        }\n        return null;\n    }\n\n    /* Edit History Methods */\n\n    /**\n     * Add a label to the history.\n     * @param label The label to add to the history.\n     * @param stepIndex The step index of the label.\n     */\n    static addLabelHistory(label: LabelIdType, stepIndex: number) {\n        let allOpenedLabels = NarrationManagerStatic.allOpenedLabels;\n        let oldStepIndex = NarrationManagerStatic.allOpenedLabels[label]?.biggestStep || 0;\n        let openCount = NarrationManagerStatic.allOpenedLabels[label]?.openCount || 0;\n        if (!oldStepIndex || oldStepIndex < stepIndex) {\n            allOpenedLabels[label] = { biggestStep: stepIndex, openCount: openCount };\n            NarrationManagerStatic.allOpenedLabels = allOpenedLabels;\n        }\n    }\n    static addChoicesMade(label: LabelIdType, stepIndex: number, stepSha: string, choiceMade: number) {\n        let allChoicesMade = NarrationManagerStatic.allChoicesMade;\n        let alredyMade = allChoicesMade.findIndex(\n            (item) =>\n                item.labelId === label &&\n                item.stepIndex === stepIndex &&\n                item.choiceIndex === choiceMade &&\n                item.stepSha1 === stepSha,\n        );\n        if (alredyMade < 0) {\n            allChoicesMade.push({\n                labelId: label,\n                stepIndex: stepIndex,\n                choiceIndex: choiceMade,\n                stepSha1: stepSha,\n                madeTimes: 1,\n            });\n        } else {\n            allChoicesMade[alredyMade].madeTimes++;\n        }\n        NarrationManagerStatic.allChoicesMade = allChoicesMade;\n    }\n    /**\n     * Add a label to the history.\n     * @param label The label to add to the history.\n     */\n    static pushNewLabel(label: LabelIdType) {\n        let currentLabel = RegisteredLabels.get(label);\n        if (!currentLabel) {\n            throw new PixiError(\"unregistered_element\", `Label ${label} not found`);\n        }\n        NarrationManagerStatic._openedLabels.push({\n            label: label,\n            currentStepIndex: 0,\n        });\n        let allOpenedLabels = NarrationManagerStatic.allOpenedLabels;\n        let biggestStep = NarrationManagerStatic.allOpenedLabels[label]?.biggestStep || 0;\n        let openCount = NarrationManagerStatic.allOpenedLabels[label]?.openCount || 0;\n        allOpenedLabels[label] = { biggestStep: biggestStep, openCount: openCount + 1 };\n        NarrationManagerStatic.allOpenedLabels = allOpenedLabels;\n    }\n    /**\n     * Increase the current step index of the current label.\n     */\n    static increaseCurrentStepIndex() {\n        if (NarrationManagerStatic._openedLabels.length > 0) {\n            let item = NarrationManagerStatic._openedLabels[NarrationManagerStatic._openedLabels.length - 1];\n            NarrationManagerStatic._openedLabels[NarrationManagerStatic._openedLabels.length - 1] = {\n                ...item,\n                currentStepIndex: item.currentStepIndex + 1,\n            };\n        }\n    }\n\n    private static _onStepStart?: (stepId: number, label: LabelAbstract<any>) => void | Promise<void>;\n    static set onStepStart(value: (stepId: number, label: LabelAbstract<any>) => void | Promise<void>) {\n        NarrationManagerStatic._onStepStart = value;\n    }\n    static get onStepStart(): ((stepId: number, label: LabelAbstract<any>) => Promise<void[]>) | undefined {\n        return async (stepId: number, label: LabelAbstract<any>) => {\n            let res: (Promise<void> | void)[] = [];\n            if (NarrationManagerStatic.onLoadingLabel && stepId === 0) {\n                res.push(NarrationManagerStatic.onLoadingLabel(stepId, label));\n            }\n            if (NarrationManagerStatic._onStepStart) {\n                res.push(NarrationManagerStatic._onStepStart(stepId, label));\n            }\n            return await Promise.all(res);\n        };\n    }\n    static onLoadingLabel?: (stepId: number, label: LabelAbstract<any>) => void | Promise<void>;\n    static onStepEnd?: (stepId: number, label: LabelAbstract<any>) => void | Promise<void>;\n}\n","import { CharacterInterface, DialogueInterface } from \"@drincs/pixi-vn\";\nimport { GameUnifier, PixiError } from \"@drincs/pixi-vn/core\";\nimport type { StorageElementType } from \"../storage\";\nimport { SYSTEM_RESERVED_STORAGE_KEYS } from \"../storage/constants\";\nimport { createExportableElement } from \"../utils\";\nimport { logger } from \"../utils/log-utility\";\nimport LabelAbstract from \"./classes/LabelAbstract\";\nimport RegisteredLabels from \"./decorators/RegisteredLabels\";\nimport { StoredDialogue } from \"./interfaces/DialogueInterface\";\nimport HistoryStep, { AdditionalShaSpetsEnum } from \"./interfaces/HistoryStep\";\nimport NarrationGameState from \"./interfaces/NarrationGameState\";\nimport NarrationManagerInterface from \"./interfaces/NarrationManagerInterface\";\nimport StoredChoiceInterface, { StoredIndexedChoiceInterface } from \"./interfaces/StoredChoiceInterface\";\nimport NarrationManagerStatic from \"./NarrationManagerStatic\";\nimport ChoicesMadeType from \"./types/ChoicesMadeType\";\nimport { InputInfo } from \"./types/InputInfo\";\nimport { LabelIdType } from \"./types/LabelIdType\";\nimport { StepLabelPropsType, StepLabelResultType } from \"./types/StepLabelType\";\n\n/**\n * This class is a class that manages the steps and labels of the game.\n */\nexport default class NarrationManager implements NarrationManagerInterface {\n    get currentStepTimesCounter(): number {\n        return NarrationManagerStatic.getCurrentStepTimesCounter();\n    }\n    set currentStepTimesCounter(_: 0) {\n        NarrationManagerStatic.resetCurrentStepTimesCounter();\n    }\n    getRandomNumber(min: number, max: number, options: { onceOnly?: boolean } = {}): number | undefined {\n        return NarrationManagerStatic.getRandomNumber(min, max, options);\n    }\n    get stepCounter() {\n        return NarrationManagerStatic._stepCounter;\n    }\n    get openedLabels() {\n        return NarrationManagerStatic.openedLabels;\n    }\n    get currentLabel(): LabelAbstract<any> | undefined {\n        return NarrationManagerStatic._currentLabel;\n    }\n\n    /* Edit History Methods */\n\n    /**\n     * Add a label to the history.\n     * @param stepSha The sha1 of the step.\n     * @param options The options.\n     */\n    private addStepHistory(\n        stepSha: string,\n        options: {\n            choiceMade?: number;\n            ignoreSameStep?: boolean;\n        } = {},\n    ) {\n        const { choiceMade, ignoreSameStep } = options;\n        let dialogue: StoredDialogue | undefined = undefined;\n        let choices: StoredChoiceInterface[] | undefined = undefined;\n        let inputValue: StorageElementType | undefined = undefined;\n        let isGlued = GameUnifier.getVariable(SYSTEM_RESERVED_STORAGE_KEYS.LAST_STEP_GLUED) === this.stepCounter;\n        if (\n            GameUnifier.getVariable<number>(SYSTEM_RESERVED_STORAGE_KEYS.LAST_DIALOGUE_ADDED_IN_STEP_MEMORY_KEY) ===\n            this.stepCounter\n        ) {\n            dialogue = GameUnifier.getVariable<StoredDialogue>(\n                SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_DIALOGUE_MEMORY_KEY,\n            );\n        }\n        if (\n            GameUnifier.getVariable<number>(SYSTEM_RESERVED_STORAGE_KEYS.LAST_MENU_OPTIONS_ADDED_IN_STEP_MEMORY_KEY) ===\n            this.stepCounter\n        ) {\n            choices = GameUnifier.getVariable<any>(\n                SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_MENU_OPTIONS_MEMORY_KEY,\n            ) as StoredChoiceInterface[];\n        }\n        if (\n            GameUnifier.getVariable<StorageElementType>(\n                SYSTEM_RESERVED_STORAGE_KEYS.LAST_INPUT_ADDED_IN_STEP_MEMORY_KEY,\n            ) === this.stepCounter\n        ) {\n            inputValue = GameUnifier.getVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_INPUT_VALUE_MEMORY_KEY);\n        }\n        const openedLabels = NarrationManagerStatic.openedLabels;\n        let historyInfo: Omit<HistoryStep, \"diff\"> = {\n            currentLabel: NarrationManagerStatic.currentLabelId,\n            dialogue: dialogue,\n            choices: choices,\n            stepSha1: stepSha,\n            index: this.stepCounter,\n            labelStepIndex: NarrationManagerStatic.currentLabelStepIndex,\n            choiceIndexMade: choiceMade,\n            inputValue: inputValue,\n            alreadyMadeChoices: this.alreadyCurrentStepMadeChoices,\n            isGlued: isGlued,\n            openedLabels: openedLabels,\n        };\n        NarrationManagerStatic.originalOpenedLabels = openedLabels;\n        GameUnifier.addHistoryItem(historyInfo, { ignoreSameStep });\n        NarrationManagerStatic.lastHistoryStep = historyInfo;\n        NarrationManagerStatic.increaseStepCounter();\n    }\n    closeCurrentLabel() {\n        if (!NarrationManagerStatic.currentLabelId) {\n            logger.warn(\"No label to close\");\n            return;\n        }\n        if (!this.currentLabel) {\n            logger.error(\"currentLabel not found\");\n            return;\n        }\n        let openedLabels = NarrationManagerStatic.openedLabels;\n        openedLabels.pop();\n        NarrationManagerStatic.openedLabels = openedLabels;\n        GameUnifier.onLabelClosing(this.openedLabels.length);\n    }\n    closeAllLabels() {\n        while (NarrationManagerStatic.openedLabels.length > 0) {\n            this.closeCurrentLabel();\n            GameUnifier.onLabelClosing(this.openedLabels.length);\n        }\n    }\n    public isLabelAlreadyCompleted(label: LabelIdType | LabelAbstract<any>): boolean {\n        let labelId: LabelIdType;\n        if (typeof label === \"string\") {\n            labelId = label;\n        } else {\n            labelId = label.id;\n        }\n        let allOpenedLabels = NarrationManagerStatic.allOpenedLabels;\n        let lastStep = allOpenedLabels[labelId]?.biggestStep || 0;\n        if (lastStep) {\n            let currentLabel = RegisteredLabels.get(labelId);\n            if (currentLabel) {\n                return currentLabel.stepCount <= lastStep;\n            }\n        }\n        return false;\n    }\n    private get alreadyCurrentStepMadeChoicesObj(): ChoicesMadeType[] | undefined {\n        let currentLabelStepIndex = NarrationManagerStatic.currentLabelStepIndex;\n        let currentLabel = this.currentLabel;\n        if (currentLabelStepIndex === null || !currentLabel) {\n            return;\n        }\n        let stepSha = currentLabel.getStepSha(currentLabelStepIndex);\n        if (!stepSha) {\n            logger.warn(\"stepSha not found, setting to ERROR\");\n            stepSha = AdditionalShaSpetsEnum.ERROR;\n        }\n        return NarrationManagerStatic.allChoicesMade.filter((choice) => {\n            return (\n                choice.labelId === currentLabel?.id &&\n                choice.stepIndex === currentLabelStepIndex &&\n                choice.stepSha1 === stepSha\n            );\n        });\n    }\n    get alreadyCurrentStepMadeChoices(): number[] | undefined {\n        return this.alreadyCurrentStepMadeChoicesObj?.map((choice) => choice.choiceIndex);\n    }\n    get isCurrentStepAlreadyOpened(): boolean {\n        let currentLabel = NarrationManagerStatic.currentLabelId;\n        if (currentLabel) {\n            let lastStep = NarrationManagerStatic.allOpenedLabels[currentLabel]?.openCount || 0;\n            if (\n                NarrationManagerStatic.currentLabelStepIndex &&\n                lastStep >= NarrationManagerStatic.currentLabelStepIndex\n            ) {\n                return true;\n            }\n        }\n        return false;\n    }\n    public getTimesLabelOpened(label: LabelIdType): number {\n        return NarrationManagerStatic.allOpenedLabels[label]?.openCount || 0;\n    }\n    public getTimesChoiceMade(index: number): number {\n        return this.alreadyCurrentStepMadeChoicesObj?.find((choice) => choice.choiceIndex === index)?.madeTimes || 0;\n    }\n    addCurrentStepToHistory(): void {\n        this.addStepHistory(AdditionalShaSpetsEnum.DEVELOPER, { ignoreSameStep: true });\n    }\n\n    /* Run Methods */\n\n    private getCanContinue(options?: {\n        /**\n         * If true, show a warning in the console.\n         * @default false\n         */\n        showWarn?: boolean;\n    }): boolean {\n        let showWarn = options?.showWarn || false;\n        let choiceMenuOptions = this.choices;\n        if (choiceMenuOptions && choiceMenuOptions.length > 0) {\n            showWarn && logger.warn(\"The player must make a choice\");\n            return false;\n        }\n        if (this.isRequiredInput) {\n            showWarn && logger.warn(\"The player must enter a value\");\n            return false;\n        }\n        return true;\n    }\n    get canContinue(): boolean {\n        if (GameUnifier.runningStepsCount !== 0) {\n            return false;\n        }\n        return this.getCanContinue();\n    }\n    private async onStepStart(label: LabelAbstract<any, any>, stepId: number) {\n        let res: (void | Promise<void> | Promise<void[]>)[] = [];\n        if (label.onStepStart) {\n            res.push(label.onStepStart(stepId, label));\n        }\n        if (NarrationManagerStatic.onStepStart) {\n            res.push(NarrationManagerStatic.onStepStart(stepId, label));\n        }\n        return await Promise.all(res);\n    }\n    private async onStepEnd(label: LabelAbstract<any, any>, stepId: number) {\n        let res: (void | Promise<void>)[] = [];\n        if (label.onStepEnd) {\n            res.push(label.onStepEnd(stepId, label));\n        }\n        if (NarrationManagerStatic.onStepEnd) {\n            res.push(NarrationManagerStatic.onStepEnd(stepId, label));\n        }\n        return await Promise.all(res);\n    }\n    public async continue(\n        props: StepLabelPropsType,\n        options: { steps?: number; runNow?: boolean; choiceMade?: number } = {},\n    ) {\n        const { runNow = false, steps = 1 } = options;\n        if (!Number.isFinite(steps)) {\n            logger.warn(`[continue] The parameter steps must be a valid finite number, received: ${steps}`);\n            return;\n        }\n        if (steps <= 0) {\n            logger.warn(`[continue] The parameter steps must be greater than 0, received: ${steps}`);\n            return;\n        }\n        if (!runNow && !this.getCanContinue({ showWarn: true })) {\n            return;\n        }\n        if (!runNow && GameUnifier.runningStepsCount !== 0) {\n            GameUnifier.increaseContinueRequest(steps);\n            return;\n        }\n        if (steps > 1) {\n            GameUnifier.increaseContinueRequest(steps - 1);\n        }\n        GameUnifier.runningStepsCount++;\n        let result: StepLabelResultType = undefined;\n        try {\n            if (GameUnifier.runningStepsCount === 1) {\n                await GameUnifier.onPreContinue();\n            }\n            NarrationManagerStatic.increaseCurrentStepIndex();\n            result = await this.runCurrentStep(props, options);\n        } catch (e) {\n            logger.error(\"Error continuing\", e);\n            throw e;\n        } finally {\n            GameUnifier.runningStepsCount--;\n            result = (await this.afterRunCurrentStep(props)) || result;\n        }\n        return result;\n    }\n    private async afterRunCurrentStep(props: StepLabelPropsType<any>) {\n        if (GameUnifier.runningStepsCount === 0 && GameUnifier.continueRequestsCount !== 0) {\n            return await GameUnifier.processNavigationRequests(props);\n        }\n        if (this.openedLabels.length === 0) {\n            if (GameUnifier.onEnd) {\n                return await GameUnifier.onEnd(props, { labelId: \"end\" });\n            } else {\n                logger.error(\n                    \"The end of the game is not managed, so the game is blocked. Read this documentation to know how to manage the end of the game: https://pixi-vn.web.app/start/other-narrative-features.html#how-manage-the-end-of-the-game\",\n                );\n            }\n        }\n    }\n    /**\n     * Execute the current step and add it to the history.\n     * @param props The props to pass to the step.\n     * @param options The options.\n     * @returns StepLabelResultType or undefined.\n     */\n    private async runCurrentStep<T extends {}>(\n        props: StepLabelPropsType<T>,\n        options: {\n            /**\n             * The index of the choice made by the player. (This params is used in the choice menu)\n             */\n            choiceMade?: number;\n        } = {},\n    ): Promise<StepLabelResultType> {\n        const { choiceMade } = options;\n        if (NarrationManagerStatic.currentLabelId) {\n            let currentLabelStepIndex = NarrationManagerStatic.currentLabelStepIndex;\n            if (currentLabelStepIndex === null) {\n                logger.error(\"currentLabelStepIndex is null\");\n                return;\n            }\n            let currentLabel = NarrationManagerStatic._currentLabel as LabelAbstract<any, T> | undefined;\n            if (!currentLabel) {\n                logger.error(\"currentLabel not found\");\n                return;\n            }\n            if (currentLabel.stepCount > currentLabelStepIndex) {\n                try {\n                    await this.onStepStart(currentLabel, currentLabelStepIndex);\n                } catch (e) {\n                    logger.error(\"Error running onStepStart\", e);\n                    if (this.onStepError) {\n                        await this.onStepError(e, props);\n                    }\n                    return;\n                }\n                let step = currentLabel.getStepById(currentLabelStepIndex);\n                if (!step) {\n                    logger.error(\"step not found\");\n                    return;\n                }\n                let stepSha = currentLabel.getStepSha(currentLabelStepIndex);\n                if (!stepSha) {\n                    logger.warn(\"stepSha not found, setting to ERROR\");\n                    stepSha = AdditionalShaSpetsEnum.ERROR;\n                }\n                let result;\n                let err = undefined;\n                try {\n                    result = await step(props, { labelId: currentLabel.id });\n                } catch (e) {\n                    logger.error(\"Error running step\", e);\n                    err = e;\n                }\n\n                try {\n                    let choiceMenuOptions = this.choices;\n                    if (choiceMenuOptions?.length === 1 && choiceMenuOptions[0].autoSelect) {\n                        let choice = choiceMenuOptions[0];\n                        result = await this.selectChoice(choice, props);\n                    }\n                } catch (e) {\n                    logger.error(\"Error auto-selecting choice\", e);\n                    if (err === undefined) {\n                        err = e as any;\n                    }\n                }\n\n                try {\n                    let lastHistoryStep = NarrationManagerStatic.lastHistoryStep;\n                    if (choiceMade !== undefined && lastHistoryStep) {\n                        stepSha = lastHistoryStep.stepSha1;\n                        if (!stepSha) {\n                            logger.warn(\"stepSha not found, setting to ERROR\");\n                            stepSha = AdditionalShaSpetsEnum.ERROR;\n                        }\n                        NarrationManagerStatic.addChoicesMade(\n                            lastHistoryStep.currentLabel || \"error\",\n                            typeof lastHistoryStep.labelStepIndex === \"number\" ? lastHistoryStep.labelStepIndex : -1,\n                            lastHistoryStep.stepSha1 || AdditionalShaSpetsEnum.ERROR,\n                            choiceMade,\n                        );\n                        NarrationManagerStatic.choiceMadeTemp = choiceMade;\n                    }\n                } catch (e) {\n                    logger.warn(\"Error adding choice made to history\", e);\n                }\n\n                try {\n                    // Only add to history if is the main step (not a nested call/jump)\n                    if (GameUnifier.runningStepsCount === 1) {\n                        NarrationManagerStatic.addLabelHistory(currentLabel.id, currentLabelStepIndex);\n                        this.addStepHistory(stepSha, {\n                            ...options,\n                            choiceMade: NarrationManagerStatic.choiceMadeTemp,\n                        });\n                        NarrationManagerStatic.choiceMadeTemp = undefined;\n                    }\n                } catch (e) {\n                    logger.warn(\"Error adding step to history\", e);\n                }\n\n                try {\n                    this.currentLabel &&\n                        (await this.onStepEnd(this.currentLabel, NarrationManagerStatic.currentLabelStepIndex || 0));\n                } catch (e) {\n                    logger.warn(\"Error running onStepEnd\", e);\n                }\n\n                if (err && this.onStepError) {\n                    await this.onStepError(err, props);\n                }\n                return result;\n            } else if (this.openedLabels.length > 1) {\n                this.closeCurrentLabel();\n                return await this.continue(props, options);\n            } else if (this.openedLabels.length === 1) {\n                NarrationManagerStatic.openedLabels = [];\n                return;\n            }\n        } else if (this.openedLabels.length === 0) {\n            return;\n        } else {\n            logger.error(\"currentLabelId not found\");\n        }\n    }\n    public async call<T extends {} = {}>(\n        label: LabelAbstract<any, T> | LabelIdType,\n        props: StepLabelPropsType<T>,\n        options?: {\n            /**\n             * The index of the choice made by the player. (This params is used in the choice menu)\n             */\n            choiceMade?: number;\n        },\n    ): Promise<StepLabelResultType> {\n        const { choiceMade } = options || {};\n        let labelId: LabelIdType;\n        if (typeof label === \"string\") {\n            labelId = label;\n        } else {\n            labelId = label.id;\n        }\n        GameUnifier.runningStepsCount++;\n        let result: StepLabelResultType = undefined;\n        try {\n            let tempLabel = RegisteredLabels.get<LabelAbstract<any, T>>(labelId);\n            if (!tempLabel) {\n                throw new PixiError(\"unregistered_element\", `Label ${labelId} not found`);\n            }\n\n            NarrationManagerStatic.pushNewLabel(tempLabel.id);\n            result = await this.runCurrentStep<T>(props, { choiceMade: choiceMade });\n        } catch (e) {\n            logger.error(\"Error calling label\", e);\n            throw e;\n        } finally {\n            GameUnifier.runningStepsCount--;\n            result = (await this.afterRunCurrentStep(props)) || result;\n        }\n        return result;\n    }\n    public async jump<T extends {}>(\n        label: LabelAbstract<any, T> | LabelIdType,\n        props: StepLabelPropsType<T>,\n        options?: {\n            /**\n             * The index of the choice made by the player. (This params is used in the choice menu)\n             */\n            choiceMade?: number;\n        },\n    ): Promise<StepLabelResultType> {\n        if (this.stepCounter === 0) {\n            return await this.call(label, props, options);\n        }\n        if (this.openedLabels.length > 0) this.closeCurrentLabel();\n        const { choiceMade } = options || {};\n        let labelId: LabelIdType;\n        if (typeof label === \"string\") {\n            labelId = label;\n        } else {\n            labelId = label.id;\n        }\n        GameUnifier.runningStepsCount++;\n        let result: StepLabelResultType = undefined;\n        try {\n            let tempLabel = RegisteredLabels.get<LabelAbstract<any, T>>(labelId);\n            if (!tempLabel) {\n                throw new PixiError(\"unregistered_element\", `Label ${labelId} not found`);\n            }\n\n            NarrationManagerStatic.pushNewLabel(tempLabel.id);\n            result = await this.runCurrentStep<T>(props, { choiceMade: choiceMade });\n        } catch (e) {\n            logger.error(\"Error jumping to label\", e);\n            throw e;\n        } finally {\n            GameUnifier.runningStepsCount--;\n            result = (await this.afterRunCurrentStep(props)) || result;\n        }\n        return result;\n    }\n    public async selectChoice<T extends {}>(\n        item: StoredIndexedChoiceInterface,\n        props: StepLabelPropsType<T>,\n    ): Promise<StepLabelResultType> {\n        this.choices = undefined;\n        const type = item.type;\n        switch (type) {\n            case \"call\":\n                return await this.call(\n                    item.label,\n                    { ...item.props, ...props },\n                    {\n                        choiceMade: item.choiceIndex,\n                    },\n                );\n            case \"jump\":\n                return await this.jump(\n                    item.label,\n                    { ...item.props, ...props },\n                    {\n                        choiceMade: item.choiceIndex,\n                    },\n                );\n            case \"close\":\n                return await this.closeChoiceMenu(item, { ...item.props, ...props });\n            default:\n                logger.error(`Type ${type} not found`);\n                throw new PixiError(\"invalid_usage\", `Type ${type} not found`);\n        }\n    }\n    /**\n     * When the player is in a choice menu, can use this function to exit to the choice menu.\n     * @param choice\n     * @param props\n     * @returns StepLabelResultType or undefined.\n     * @example\n     * ```typescript\n     * narration.closeChoiceMenu(yourParams).then((result) => {\n     *     if (result) {\n     *         // your code\n     *     }\n     * })\n     * ```\n     */\n    public async closeChoiceMenu<T extends {} = {}>(\n        choice: StoredIndexedChoiceInterface,\n        props: StepLabelPropsType<T>,\n    ): Promise<StepLabelResultType> {\n        if (choice.type !== \"close\") {\n            logger.error(\"For closeChoiceMenu, the type must be close\");\n            throw new PixiError(\"invalid_usage\", \"For closeChoiceMenu, the type must be close\");\n        }\n        let choiceMade: number | undefined = undefined;\n        if (typeof choice.choiceIndex === \"number\") {\n            choiceMade = choice.choiceIndex;\n        }\n        if (choice.closeCurrentLabel) {\n            this.closeCurrentLabel();\n        }\n        return await this.continue(props, { choiceMade });\n    }\n\n    /* Go Back & Refresh Methods */\n\n    private get onStepError(): ((error: any, props: StepLabelPropsType) => void | Promise<void>) | undefined {\n        const onError = GameUnifier.onError;\n        if (!onError) {\n            return undefined;\n        }\n        return async (error: any, props: StepLabelPropsType) => {\n            try {\n                return await onError(\"step\", error, props);\n            } catch (e) {\n                logger.error(\"Error in onError handler\", e);\n            }\n        };\n    }\n    private set onStepError(value: (error: any, props: StepLabelPropsType) => void) {\n        GameUnifier.onError = (type: string, error: any, props: StepLabelPropsType) => {\n            return value(error, props);\n        };\n    }\n\n    public get dialogue():\n        | (Partial<DialogueInterface> & {\n              text: string | string[];\n              character?: CharacterInterface | string;\n          })\n        | undefined {\n        const dialogue = GameUnifier.getVariable<StoredDialogue>(\n            SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_DIALOGUE_MEMORY_KEY,\n        );\n        if (!dialogue) {\n            return undefined;\n        }\n        return {\n            ...dialogue,\n            character: dialogue.character\n                ? GameUnifier.getCharacter(dialogue.character) || dialogue.character\n                : undefined,\n        };\n    }\n    public set dialogue(dialogue: DialogueInterface | string | string[] | undefined) {\n        if (dialogue === undefined) {\n            GameUnifier.setVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_DIALOGUE_MEMORY_KEY, undefined);\n            return;\n        }\n\n        if (typeof dialogue === \"string\" || Array.isArray(dialogue)) {\n            dialogue = { text: dialogue };\n        }\n\n        if (this.dialogGlue) {\n            let glueDialogue = GameUnifier.getVariable<StoredDialogue>(\n                SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_DIALOGUE_MEMORY_KEY,\n            );\n            if (glueDialogue) {\n                let newText = [];\n                if (Array.isArray(glueDialogue.text)) {\n                    newText = [...glueDialogue.text];\n                } else {\n                    newText = [glueDialogue.text];\n                }\n                if (Array.isArray(dialogue.text)) {\n                    newText = [...newText, ...dialogue.text];\n                } else {\n                    newText = [...newText, dialogue.text];\n                }\n                dialogue.text = newText;\n                dialogue.character = dialogue.character || glueDialogue.character;\n            }\n            GameUnifier.setVariable(SYSTEM_RESERVED_STORAGE_KEYS.LAST_STEP_GLUED, this.stepCounter);\n            this.dialogGlue = false;\n        }\n        try {\n            GameUnifier.setVariable(\n                SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_DIALOGUE_MEMORY_KEY,\n                createExportableElement({\n                    ...dialogue,\n                    character: typeof dialogue.character === \"string\" ? dialogue.character : dialogue.character?.id,\n                }),\n            );\n            GameUnifier.setVariable(\n                SYSTEM_RESERVED_STORAGE_KEYS.LAST_DIALOGUE_ADDED_IN_STEP_MEMORY_KEY,\n                this.stepCounter,\n            );\n        } catch (e) {\n            logger.error(\"DialogueInterface cannot contain functions or classes\");\n            throw new PixiError(\"not_json_serializable\", \"ChoiceInterface cannot contain functions or classes\");\n        }\n    }\n    public get choices(): StoredIndexedChoiceInterface[] | undefined {\n        let d = GameUnifier.getVariable<any>(\n            SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_MENU_OPTIONS_MEMORY_KEY,\n        ) as StoredChoiceInterface[];\n        if (d) {\n            let onlyHaveNoChoice: StoredIndexedChoiceInterface[] = [];\n            let options: StoredIndexedChoiceInterface[] = d.map((option, index) => {\n                return {\n                    ...option,\n                    choiceIndex: index,\n                };\n            });\n            let alreadyChoices = this.alreadyCurrentStepMadeChoices;\n            options = options.filter((option, index) => {\n                if (option.oneTime) {\n                    if (alreadyChoices && alreadyChoices.includes(index)) {\n                        return false;\n                    }\n                }\n                if (option.onlyHaveNoChoice) {\n                    onlyHaveNoChoice.push(option);\n                    return false;\n                }\n                return true;\n            });\n            if (options.length > 0) {\n                return options;\n            } else if (onlyHaveNoChoice.length > 0) {\n                let firstOption = onlyHaveNoChoice[0];\n                return [firstOption];\n            }\n        }\n        return undefined;\n    }\n    public set choices(options: StoredChoiceInterface[] | undefined) {\n        if (!options || options.length === 0) {\n            GameUnifier.setVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_MENU_OPTIONS_MEMORY_KEY, undefined);\n            return;\n        }\n        try {\n            GameUnifier.setVariable(\n                SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_MENU_OPTIONS_MEMORY_KEY,\n                createExportableElement(options) as any,\n            );\n            GameUnifier.setVariable(\n                SYSTEM_RESERVED_STORAGE_KEYS.LAST_MENU_OPTIONS_ADDED_IN_STEP_MEMORY_KEY,\n                this.stepCounter,\n            );\n        } catch (e) {\n            logger.error(\"ChoiceInterface cannot contain functions or classes\");\n            throw new PixiError(\"not_json_serializable\", \"ChoiceInterface cannot contain functions or classes\");\n        }\n    }\n    public get dialogGlue(): boolean {\n        return GameUnifier.getFlag(SYSTEM_RESERVED_STORAGE_KEYS.ADD_NEXT_DIALOG_TEXT_INTO_THE_CURRENT_DIALOG_FLAG_KEY);\n    }\n    public set dialogGlue(value: boolean) {\n        GameUnifier.setFlag(SYSTEM_RESERVED_STORAGE_KEYS.ADD_NEXT_DIALOG_TEXT_INTO_THE_CURRENT_DIALOG_FLAG_KEY, value);\n    }\n    public get inputValue(): StorageElementType {\n        return GameUnifier.getVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_INPUT_VALUE_MEMORY_KEY);\n    }\n    public set inputValue(value: StorageElementType) {\n        this.removeInputRequest();\n        GameUnifier.setVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_INPUT_VALUE_MEMORY_KEY, value);\n        GameUnifier.setVariable(SYSTEM_RESERVED_STORAGE_KEYS.LAST_INPUT_ADDED_IN_STEP_MEMORY_KEY, this.stepCounter);\n    }\n    public get isRequiredInput(): boolean {\n        return (\n            GameUnifier.getVariable<InputInfo>(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_INPUT_INFO_MEMORY_KEY)\n                ?.isRequired || false\n        );\n    }\n    public get inputType(): string | undefined {\n        return GameUnifier.getVariable<InputInfo>(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_INPUT_INFO_MEMORY_KEY)?.type;\n    }\n    public requestInput(info: Omit<InputInfo, \"isRequired\">, defaultValue?: StorageElementType) {\n        (info as InputInfo).isRequired = true;\n        GameUnifier.setVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_INPUT_INFO_MEMORY_KEY, info);\n        if (defaultValue !== undefined) {\n            GameUnifier.setVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_INPUT_VALUE_MEMORY_KEY, defaultValue);\n        } else {\n            GameUnifier.removeVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_INPUT_VALUE_MEMORY_KEY);\n        }\n    }\n    public removeInputRequest() {\n        GameUnifier.removeVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_INPUT_INFO_MEMORY_KEY);\n        GameUnifier.removeVariable(SYSTEM_RESERVED_STORAGE_KEYS.CURRENT_INPUT_VALUE_MEMORY_KEY);\n    }\n\n    public clear() {\n        NarrationManagerStatic.openedLabels = [];\n        NarrationManagerStatic._stepCounter = 0;\n    }\n\n    /* Export and Import Methods */\n\n    public export(): NarrationGameState {\n        return {\n            openedLabels: createExportableElement(NarrationManagerStatic.openedLabels),\n            stepCounter: this.stepCounter,\n        };\n    }\n\n    private async onLoadingLabel(currentLabelStepIndex: number) {\n        const promise = this.openedLabels.map(async (labelInfo) => {\n            let res: (void | Promise<void>)[] = [];\n            let label = RegisteredLabels.get(labelInfo.label);\n            if (label) {\n                if (label.onLoadingLabel) {\n                    res.push(label.onLoadingLabel(currentLabelStepIndex, label));\n                }\n                if (NarrationManagerStatic.onLoadingLabel) {\n                    res.push(NarrationManagerStatic.onLoadingLabel(currentLabelStepIndex, label));\n                }\n            }\n            return await Promise.all(res);\n        });\n        return await Promise.all(promise);\n    }\n    public async restore(data: object, lastHistoryStep: Omit<HistoryStep, \"diff\"> | null) {\n        this.clear();\n        try {\n            NarrationManagerStatic.lastHistoryStep = lastHistoryStep;\n            if (data.hasOwnProperty(\"openedLabels\")) {\n                NarrationManagerStatic.openedLabels = (data as NarrationGameState)[\"openedLabels\"];\n                NarrationManagerStatic.originalOpenedLabels = NarrationManagerStatic.openedLabels;\n            } else {\n                logger.warn(\"Could not import openedLabels data, so will be ignored\");\n            }\n            if (data.hasOwnProperty(\"stepCounter\")) {\n                NarrationManagerStatic._stepCounter = (data as NarrationGameState)[\"stepCounter\"];\n            } else if (data.hasOwnProperty(\"lastStepIndex\")) {\n                NarrationManagerStatic._stepCounter = (data as NarrationGameState)[\"lastStepIndex\"] as number;\n            } else {\n                logger.warn(\"Could not import stepCounter data, so will be ignored\");\n            }\n\n            try {\n                await this.onLoadingLabel(NarrationManagerStatic.currentLabelStepIndex || 0);\n            } catch (e) {\n                logger.error(\"Error running onLoadingLabel\", e);\n            }\n        } catch (e) {\n            logger.error(\"Error importing data\", e);\n        }\n    }\n}\n","import { ChoiceInterface } from \"@drincs/pixi-vn\";\nimport { StorageObjectType } from \"../../storage\";\nimport { ChoiceOptionInterface } from \"../interfaces/StoredChoiceInterface\";\nimport { LabelIdType } from \"../types/LabelIdType\";\nimport LabelRunModeType from \"../types/LabelRunModeType\";\nimport Label from \"./Label\";\nimport LabelAbstract from \"./LabelAbstract\";\n\ninterface ChoiceMenuOptionOptions\n    extends Omit<ChoiceInterface, \"text\" | \"label\" | \"type\" | \"props\" | \"closeCurrentLabel\"> {\n    /**\n     * Type of the label to be opened. @default \"call\"\n     */\n    type?: LabelRunModeType;\n}\n\n/**\n * Function to create a new choice menu option.\n * @example\n * ```typescript\n * newChoiceOption(\"Hello\", HelloLabel, {})\n * ```\n */\nexport function newChoiceOption<T extends StorageObjectType>(\n    text: ChoiceInterface[\"text\"],\n    label: Label<T> | LabelAbstract<any, T> | LabelIdType,\n    props: T,\n    options?: ChoiceMenuOptionOptions\n): ChoiceOptionInterface {\n    const labelId = typeof label === \"string\" ? label : label.id;\n    return {\n        ...options,\n        label: labelId,\n        props: props,\n        text,\n        type: options?.type || \"call\",\n    };\n}\n","export type CloseType = \"close\"\nexport const Close: CloseType = \"close\"","import { ChoiceInterface } from \"@drincs/pixi-vn\";\nimport { CloseChoiceOptionInterface } from \"../interfaces/StoredChoiceInterface\";\nimport { Close } from \"../types/CloseType\";\n\ninterface ChoiceMenuOptionCloseOptions\n    extends Omit<ChoiceInterface, \"text\" | \"label\" | \"type\" | \"props\" | \"closeCurrentLabel\"> {\n    /**\n     * If true, the current label will be closed. @default false\n     */\n    closeCurrentLabel?: boolean;\n}\n\n/**\n * Function to create a new choice menu option that will close the menu.\n * @example\n * ```typescript\n * newCloseChoiceOption(\"Return\")\n * ```\n */\nexport function newCloseChoiceOption(\n    text: ChoiceInterface[\"text\"],\n    options?: ChoiceMenuOptionCloseOptions\n): CloseChoiceOptionInterface {\n    return {\n        ...options,\n        type: Close,\n        text,\n    };\n}\n","import sha1 from \"crypto-js/sha1\";\nimport { LabelProps } from \"../..\";\nimport { logger } from \"../../utils/log-utility\";\nimport { AdditionalShaSpetsEnum } from \"../interfaces/HistoryStep\";\nimport { LabelIdType } from \"../types/LabelIdType\";\nimport { StepLabelType } from \"../types/StepLabelType\";\nimport LabelAbstract from \"./LabelAbstract\";\n\n/**\n * Label is a class that contains a list of steps, which will be performed as the game continues.\n * For Ren'py this is the equivalent of a label.\n * @example\n * ```typescript\n * const START_LABEL_ID = \"StartLabel\"\n *\n * export const startLabel = newLabel(START_LABEL_ID,\n *     [\n *         (props) => {\n *             canvas.clear()\n *             narration.dialogue = { character: liam, text: \"Which test do you want to perform?\" }\n *             narration.choices = [\n *                 newChoiceOption(\"Events Test\", eventsTestLabel),\n *                 newChoiceOption(\"Show Image Test\", showImageTest),\n *             ]\n *         },\n *         (props) => narration.jump(START_LABEL_ID, props),\n *     ]\n * )\n *\n * narration.call(StartLabel)\n * ```\n */\nexport default class Label<T extends {} = {}> extends LabelAbstract<Label<T>, T> {\n    public get stepCount(): number {\n        return this.steps.length;\n    }\n    public getStepById(stepId: number): StepLabelType<T> | undefined {\n        return this.steps[stepId];\n    }\n    /**\n     * @param id is the id of the label\n     * @param steps is the list of steps that the label will perform\n     * @param props is the properties of the label\n     */\n    constructor(id: LabelIdType, steps: StepLabelType<T>[] | (() => StepLabelType<T>[]), props?: LabelProps<Label<T>>) {\n        super(id, props);\n        this._steps = steps;\n    }\n\n    private _steps: StepLabelType<T>[] | (() => StepLabelType<T>[]);\n    /**\n     * Get the steps of the label.\n     */\n    public get steps(): StepLabelType<T>[] {\n        if (typeof this._steps === \"function\") {\n            return this._steps();\n        }\n        return this._steps;\n    }\n\n    public getStepSha(index: number): string {\n        if (index < 0 || index >= this.steps.length) {\n            logger.warn(\"stepSha not found, setting to ERROR\");\n            return AdditionalShaSpetsEnum.ERROR;\n        }\n        try {\n            let step = this.steps[index];\n            let sha1String = sha1(step.toString().toLocaleLowerCase());\n            return sha1String.toString();\n        } catch (e) {\n            logger.warn(\"stepSha not found, setting to ERROR\", e);\n            return AdditionalShaSpetsEnum.ERROR;\n        }\n    }\n}\n","import RegisteredLabels from \"../decorators/RegisteredLabels\";\nimport LabelProps from \"../interfaces/LabelProps\";\nimport { LabelIdType } from \"../types/LabelIdType\";\nimport { StepLabelType } from \"../types/StepLabelType\";\n\nexport default abstract class LabelAbstract<TLabel, TProps extends {} = {}, StepIdType = number>\n    implements LabelProps<TLabel, StepIdType>\n{\n    /**\n     * @param id is the id of the label\n     * @param props is the properties of the label\n     */\n    constructor(id: LabelIdType, props?: LabelProps<TLabel, StepIdType>) {\n        this.id = id;\n        this._onStepStart = props?.onStepStart;\n        this._onLoadingLabel = props?.onLoadingLabel;\n        this._onStepEnd = props?.onStepEnd;\n    }\n\n    /**\n     * Get the id of the label. This variable is used in the system to get the label by id, {@link RegisteredLabels.get}\n     */\n    readonly id: LabelIdType;\n\n    /**\n     * Get the number of steps in the label. This variable is used in the system to get the number of steps in the label.\n     * @returns The number of steps in the label\n     */\n    public abstract get stepCount(): number;\n\n    /**\n     * Get the sha of the step\n     * @param index Index of the step\n     */\n    public abstract getStepSha(stepId: StepIdType): string | undefined;\n\n    /**\n     * Get the step by id\n     * @param stepId Id of the step\n     * @return The step or undefined if it does not exist\n     */\n    public abstract getStepById(stepId: StepIdType): StepLabelType<TProps> | undefined;\n\n    private _onStepStart: ((stepId: StepIdType, label: TLabel) => void | Promise<void>) | undefined;\n    public get onStepStart(): ((stepId: StepIdType, label: TLabel) => void | Promise<void>) | undefined {\n        return async (stepId: StepIdType, label: TLabel) => {\n            if (this._onLoadingLabel && stepId === 0) {\n                await this._onLoadingLabel(stepId, label);\n            }\n            if (this._onStepStart) {\n                return await this._onStepStart(stepId, label);\n            }\n        };\n    }\n\n    private _onLoadingLabel: ((stepId: StepIdType, label: TLabel) => void | Promise<void>) | undefined;\n    public get onLoadingLabel(): ((stepId: StepIdType, label: TLabel) => void | Promise<void>) | undefined {\n        return this._onLoadingLabel;\n    }\n\n    private _onStepEnd: ((stepId: StepIdType, label: TLabel) => void | Promise<void>) | undefined;\n    public get onStepEnd(): ((stepId: StepIdType, label: TLabel) => void | Promise<void>) | undefined {\n        return this._onStepEnd;\n    }\n}\n","import Label from \"../classes/Label\";\nimport LabelProps from \"../interfaces/LabelProps\";\nimport { LabelIdType } from \"../types/LabelIdType\";\nimport LabelSteps from \"../types/LabelSteps\";\nimport RegisteredLabels from \"./RegisteredLabels\";\n\n/**\n * Creates a new label and registers it in the system.\n * **This function must be called at least once at system startup to register the label, otherwise the system cannot be used.**\n * @param id The id of the label, it must be unique\n * @param steps The steps of the label\n * @param props The properties of the label\n * @returns The created label\n */\nexport default function newLabel<T extends {} = {}>(\n    id: LabelIdType,\n    steps: LabelSteps<T> | (() => LabelSteps<T>),\n    props?: LabelProps<Label<T>>\n): Label<T> {\n    let label = new Label<T>(id, steps, props);\n    RegisteredLabels.add(label);\n    return label;\n}\n","import { NarrationManagerInterface } from \"..\";\nimport NarrationManager from \"./NarrationManager\";\n\nexport { newChoiceOption } from \"./classes/ChoiceMenuOption\";\nexport { newCloseChoiceOption } from \"./classes/CloseChoiceOption\";\nexport { default as Label } from \"./classes/Label\";\nexport { default as LabelAbstract } from \"./classes/LabelAbstract\";\nexport { default as newLabel } from \"./decorators/newLabel\";\nexport { default as RegisteredLabels } from \"./decorators/RegisteredLabels\";\nexport type { default as ChoiceInterface } from \"./interfaces/ChoiceInterface\";\nexport type { default as DialogueInterface } from \"./interfaces/DialogueInterface\";\nexport type { default as HistoryStep } from \"./interfaces/HistoryStep\";\nexport type { default as LabelProps } from \"./interfaces/LabelProps\";\nexport type { default as NarrationGameState } from \"./interfaces/NarrationGameState\";\nexport type { default as NarrationHistory } from \"./interfaces/NarrationHistory\";\nexport type { default as NarrationManagerInterface } from \"./interfaces/NarrationManagerInterface\";\nexport type { default as OpenedLabel } from \"./interfaces/OpenedLabel\";\nexport type { default as StepLabelProps } from \"./interfaces/StepLabelProps\";\nexport type { default as StepLabelResult } from \"./interfaces/StepLabelResult\";\nexport type {\n    ChoiceOptionInterface,\n    CloseChoiceOptionInterface,\n    default as StoredChoiceInterface,\n    StoredIndexedChoiceInterface,\n} from \"./interfaces/StoredChoiceInterface\";\nexport { default as NarrationManagerStatic } from \"./NarrationManagerStatic\";\nexport { Close } from \"./types/CloseType\";\nexport type { CloseType } from \"./types/CloseType\";\nexport type { default as HistoryChoiceMenuOption } from \"./types/HistoryChoiceMenuOption\";\nexport type { InputInfo } from \"./types/InputInfo\";\nexport type { default as LabelRunModeType } from \"./types/LabelRunModeType\";\nexport type { default as LabelSteps } from \"./types/LabelSteps\";\nexport type { StepLabelPropsType, StepLabelResultType, StepLabelType } from \"./types/StepLabelType\";\nexport { narration };\n\nconst narration: NarrationManagerInterface = new NarrationManager();\n"]}
|