desi76-uis 0.1.7 → 0.1.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/dist/public/_app/immutable/chunks/{Bbk9uUlk.js → BgfbgXZ9.js} +1 -1
  2. package/dist/public/_app/immutable/chunks/BwA_oMhs.js +1 -0
  3. package/dist/public/_app/immutable/chunks/{DDoninhU.js → CusxQnB0.js} +1 -1
  4. package/dist/public/_app/immutable/chunks/{BcUYpzlG.js → D9O-A4wC.js} +1 -1
  5. package/dist/public/_app/immutable/chunks/DRAkVTUy.js +212 -0
  6. package/dist/public/_app/immutable/chunks/DUQjBwn-.js +1 -0
  7. package/dist/public/_app/immutable/chunks/DeoNb9WI.js +23 -0
  8. package/dist/public/_app/immutable/chunks/{B82hJb5h.js → MRLfPvID.js} +1 -1
  9. package/dist/public/_app/immutable/chunks/UeA63eZQ.js +1 -0
  10. package/dist/public/_app/immutable/chunks/WZE-BXCA.js +2 -0
  11. package/dist/public/_app/immutable/entry/app.BEgdX3uB.js +2 -0
  12. package/dist/public/_app/immutable/entry/start.D_hGS7wv.js +1 -0
  13. package/dist/public/_app/immutable/nodes/{0.Bl-ihXml.js → 0.ClGUQQPx.js} +1 -1
  14. package/dist/public/_app/immutable/nodes/{1.DGWGDN6J.js → 1.DThASG9M.js} +1 -1
  15. package/dist/public/_app/immutable/nodes/{2.u63dEdKk.js → 2.gx4qb0Nc.js} +1 -1
  16. package/dist/public/_app/immutable/nodes/{3.C9uWYBmh.js → 3.BDZKEK0j.js} +1 -1
  17. package/dist/public/_app/version.json +1 -1
  18. package/dist/public/desi76/abri.html +19 -19
  19. package/dist/public/desi76/catamaran.html +19 -19
  20. package/dist/public/desi76/stairs.html +19 -19
  21. package/dist/public/desi76/voila.html +19 -19
  22. package/dist/public/index.html +17 -17
  23. package/package.json +6 -6
  24. package/dist/public/_app/immutable/chunks/BC_wPopp.js +0 -23
  25. package/dist/public/_app/immutable/chunks/B_L8QMBJ.js +0 -2
  26. package/dist/public/_app/immutable/chunks/CC6euELd.js +0 -1
  27. package/dist/public/_app/immutable/chunks/CYBeyg6A.js +0 -212
  28. package/dist/public/_app/immutable/chunks/DfkC6-Nm.js +0 -1
  29. package/dist/public/_app/immutable/chunks/q-tDN8N5.js +0 -1
  30. package/dist/public/_app/immutable/entry/app.237DtHV7.js +0 -2
  31. package/dist/public/_app/immutable/entry/start.9d49d7kI.js +0 -1
@@ -1,212 +0,0 @@
1
- import{L as zA,R as ci,aw as VA,a4 as zn,N as oe,X as gi,S as li,G as Zs,ad as di,a1 as fi,a2 as Bi,a3 as tA,a5 as Vn,O as We,ax as Ei,ay as hi,M as us,Q as pi,az as kn,aA as _n,H as Di,aB as eA,ap as Ci,aC as nA,aD as jA,j as mi,I as $A,K as Ii,aE as wi,aF as jn,a8 as XA,J as ZA,aG as Fi,aH as xi,aI as yi,aJ as Si,aK as Qi,ah as vi,aL as bi,aM as Mi,aN as Ti,aO as Yi,aP as Pi}from"./B_L8QMBJ.js";function Ug(e,t){return t}function Ri(e,t,n){for(var s=e.items,A=[],r=t.length,o=0;o<r;o++)yi(t[o].e,A,!0);var i=r>0&&A.length===0&&n!==null;if(i){var a=n.parentNode;Si(a),a.append(n),s.clear(),jt(e,t[0].prev,t[r-1].next)}Qi(A,()=>{for(var u=0;u<r;u++){var c=t[u];i||(s.delete(c.k),jt(e,c.prev,c.next)),ZA(c.e,!i)}})}function Hg(e,t,n,s,A,r=null){var o=e,i={flags:t,items:new Map,first:null},a=(t&VA)!==0;if(a){var u=e;o=oe?zn(gi(u)):u.appendChild(zA())}oe&&li();var c=null,g=!1,l=new Map,B=di(()=>{var p=n();return mi(p)?p:p==null?[]:jA(p)}),d,f;function h(){Oi(f,d,i,l,o,A,t,s,n),r!==null&&(d.length===0?c?$A(c):c=us(()=>r(o)):c!==null&&Ii(c,()=>{c=null}))}ci(()=>{f??=vi,d=Zs(B);var p=d.length;if(g&&p===0)return;g=p===0;let E=!1;if(oe){var C=fi(o)===Bi;C!==(p===0)&&(o=tA(),zn(o),Vn(!1),E=!0)}if(oe){for(var I=null,w,m=0;m<p;m++){if(We.nodeType===Ei&&We.data===hi){o=We,E=!0,Vn(!1);break}var x=d[m],y=s(x,m);w=cs(We,i,I,null,x,y,m,A,t,n),i.items.set(y,w),I=w}p>0&&zn(tA())}if(oe)p===0&&r&&(c=us(()=>r(o)));else if(pi()){var G=new Set,Y=Di;for(m=0;m<p;m+=1){x=d[m],y=s(x,m);var Q=i.items.get(y)??l.get(y);Q?(t&(kn|_n))!==0&&tr(Q,x,m,t):(w=cs(null,i,null,null,x,y,m,A,t,n,!0),l.set(y,w)),G.add(y)}for(const[_,b]of i.items)G.has(_)||Y.skipped_effects.add(b.e);Y.oncommit(h)}else h();E&&Vn(!0),Zs(B)}),oe&&(o=We)}function Oi(e,t,n,s,A,r,o,i,a){var u=(o&Fi)!==0,c=(o&(kn|_n))!==0,g=t.length,l=n.items,B=n.first,d=B,f,h=null,p,E=[],C=[],I,w,m,x;if(u)for(x=0;x<g;x+=1)I=t[x],w=i(I,x),m=l.get(w),m!==void 0&&(m.a?.measure(),(p??=new Set).add(m));for(x=0;x<g;x+=1){if(I=t[x],w=i(I,x),m=l.get(w),m===void 0){var y=s.get(w);if(y!==void 0){s.delete(w),l.set(w,y);var G=h?h.next:d;jt(n,h,y),jt(n,y,G),$n(y,G,A),h=y}else{var Y=d?d.e.nodes_start:A;h=cs(Y,n,h,h===null?n.first:h.next,I,w,x,r,o,a)}l.set(w,h),E=[],C=[],d=h.next;continue}if(c&&tr(m,I,x,o),(m.e.f&jn)!==0&&($A(m.e),u&&(m.a?.unfix(),(p??=new Set).delete(m))),m!==d){if(f!==void 0&&f.has(m)){if(E.length<C.length){var Q=C[0],_;h=Q.prev;var b=E[0],M=E[E.length-1];for(_=0;_<E.length;_+=1)$n(E[_],Q,A);for(_=0;_<C.length;_+=1)f.delete(C[_]);jt(n,b.prev,M.next),jt(n,h,b),jt(n,M,Q),d=Q,h=M,x-=1,E=[],C=[]}else f.delete(m),$n(m,d,A),jt(n,m.prev,m.next),jt(n,m,h===null?n.first:h.next),jt(n,h,m),h=m;continue}for(E=[],C=[];d!==null&&d.k!==w;)(d.e.f&jn)===0&&(f??=new Set).add(d),C.push(d),d=d.next;if(d===null)continue;m=d}E.push(m),h=m,d=m.next}if(d!==null||f!==void 0){for(var v=f===void 0?[]:jA(f);d!==null;)(d.e.f&jn)===0&&v.push(d),d=d.next;var W=v.length;if(W>0){var z=(o&VA)!==0&&g===0?A:null;if(u){for(x=0;x<W;x+=1)v[x].a?.measure();for(x=0;x<W;x+=1)v[x].a?.fix()}Ri(n,v,z)}}u&&XA(()=>{if(p!==void 0)for(m of p)m.a?.apply()}),e.first=n.first&&n.first.e,e.last=h&&h.e;for(var gt of s.values())ZA(gt.e);s.clear()}function tr(e,t,n,s){(s&kn)!==0&&eA(e.v,t),(s&_n)!==0?eA(e.i,n):e.i=n}function cs(e,t,n,s,A,r,o,i,a,u,c){var g=(a&kn)!==0,l=(a&wi)===0,B=g?l?Ci(A,!1,!1):nA(A):A,d=(a&_n)===0?o:nA(o),f={i:d,v:B,k:r,a:null,e:null,prev:n,next:s};try{if(e===null){var h=document.createDocumentFragment();h.append(e=zA())}return f.e=us(()=>i(e,B,d,u),oe),f.e.prev=n&&n.e,f.e.next=s&&s.e,n===null?c||(t.first=f):(n.next=f,n.e.next=f.e),s!==null&&(s.prev=f,s.e.prev=f.e),f}finally{}}function $n(e,t,n){for(var s=e.next?e.next.e.nodes_start:n,A=t?t.e.nodes_start:n,r=e.e.nodes_start;r!==null&&r!==s;){var o=xi(r);A.before(r),r=o}}function jt(e,t,n){t===null?e.first=n:(t.next=n,t.e.next=n&&n.e),n!==null&&(n.prev=t,n.e.prev=t&&t.e)}const ki=Symbol("is custom element"),_i=Symbol("is html");function Kg(e){if(oe){var t=!1,n=()=>{if(!t){if(t=!0,e.hasAttribute("value")){var s=e.value;sA(e,"value",null),e.value=s}if(e.hasAttribute("checked")){var A=e.checked;sA(e,"checked",null),e.checked=A}}};e.__on_r=n,XA(n),Pi()}}function Jg(e,t){var n=Ts(e);n.value===(n.value=t??void 0)||e.value===t&&(t!==0||e.nodeName!=="PROGRESS")||(e.value=t??"")}function Wg(e,t){var n=Ts(e);n.checked!==(n.checked=t)&&(e.checked=t)}function sA(e,t,n,s){var A=Ts(e);oe&&(A[t]=e.getAttribute(t),t==="src"||t==="srcset"||t==="href"&&e.nodeName==="LINK")||A[t]!==(A[t]=n)&&(t==="loading"&&(e[bi]=n),n==null?e.removeAttribute(t):typeof n!="string"&&Li(e).includes(t)?e[t]=n:e.setAttribute(t,n))}function Ts(e){return e.__attributes??={[ki]:e.nodeName.includes("-"),[_i]:e.namespaceURI===Mi}}var AA=new Map;function Li(e){var t=e.getAttribute("is")||e.nodeName,n=AA.get(t);if(n)return n;AA.set(t,n=[]);for(var s,A=e,r=Element.prototype;r!==A;){s=Yi(A);for(var o in s)s[o].set&&n.push(o);A=Ti(A)}return n}const nt=4294967295,q=65535,Zt=255,Ys=8,gs=9,er=0,nr=99,sr=67324752,Ps=134695760,Ar=Ps,ls=33639248,rr=101010256,ds=101075792,or=117853008,ie=22,je=20,$e=56,Gi=ie+je+$e,ir=12,ar=20,wn=4,ur=1,cr=39169,gr=10,lr=1,Rs=21589,Ni=28789,Ui=25461,dr=6534,fr=30837,Br=30805,fs=1,Hi=6,Ki=2,Ji=4,Wi=6,Bs=8,Es=2048,Fn=16,hs=1,ps=2,Ds=4,Cs=32,rA=61440,Xe=16384,Ze=73,En=420,xn=2048,yn=1024,Sn=512,qi=20,oA=45,iA=51,hn="/",Qe=30,Os=10,Ue=14,He=18,aA=new Date(2107,11,31),uA=new Date(1980,0,1),F=void 0,pe="undefined",Me="function",zi="object",Vi=64;let Er=2;try{typeof navigator!=pe&&navigator.hardwareConcurrency&&(Er=navigator.hardwareConcurrency)}catch{}const ji={workerURI:"./core/web-worker-wasm.js",wasmURI:"./core/streams/zlib-wasm/zlib-streams.wasm",chunkSize:64*1024,maxWorkers:Er,terminateWorkerTimeout:5e3,useWebWorkers:!0,useCompressionStream:!0,CompressionStream:typeof CompressionStream!=pe&&CompressionStream,DecompressionStream:typeof DecompressionStream!=pe&&DecompressionStream},hr=Object.assign({},ji);function pr(){return hr}function Dr(e){return Math.max(e.chunkSize,Vi)}function Ln(e){const{baseURI:t,chunkSize:n,maxWorkers:s,terminateWorkerTimeout:A,useCompressionStream:r,useWebWorkers:o,CompressionStream:i,DecompressionStream:a,CompressionStreamZlib:u,DecompressionStreamZlib:c,workerURI:g,wasmURI:l}=e;Lt("baseURI",t),Lt("wasmURI",l),Lt("workerURI",g),Lt("chunkSize",n),Lt("maxWorkers",s),Lt("terminateWorkerTimeout",A),Lt("useCompressionStream",r),Lt("useWebWorkers",o),Lt("CompressionStream",i),Lt("DecompressionStream",a),Lt("CompressionStreamZlib",u),Lt("DecompressionStreamZlib",c)}function Lt(e,t){t!==F&&(hr[e]=t)}function $i(e){let t;e({workerURI:()=>(t||(t="data:text/javascript,"+encodeURIComponent(`(t=>{"function"==typeof define&&define.amd?define(t):t()})(function(){"use strict";const{Array:t,Object:e,Number:n,Math:s,Error:r,Uint8Array:o,Uint16Array:i,Uint32Array:c,Int32Array:a,Map:h,DataView:f,Promise:l,TextEncoder:u,crypto:w,postMessage:p,TransformStream:d,ReadableStream:y,WritableStream:m,CompressionStream:g,DecompressionStream:S}=self,b=void 0,v="undefined",k="function",z=[];for(let t=0;256>t;t++){let e=t;for(let t=0;8>t;t++)1&e?e=e>>>1^3988292384:e>>>=1;z[t]=e}class C{constructor(t){this.t=t||-1}append(t){let e=0|this.t;for(let n=0,s=0|t.length;s>n;n++)e=e>>>8^z[255&(e^t[n])];this.t=e}get(){return~this.t}}class A extends d{constructor(){let t;const e=new C;super({transform(t,n){e.append(t),n.enqueue(t)},flush(){const n=new o(4);new f(n.buffer).setUint32(0,e.get()),t.value=n}}),t=this}}const x={concat(t,e){if(0===t.length||0===e.length)return t.concat(e);const n=t[t.length-1],s=x.o(n);return 32===s?t.concat(e):x.i(e,s,0|n,t.slice(0,t.length-1))},h(t){const e=t.length;if(0===e)return 0;const n=t[e-1];return 32*(e-1)+x.o(n)},l(t,e){if(32*t.length<e)return t;const n=(t=t.slice(0,s.ceil(e/32))).length;return e&=31,n>0&&e&&(t[n-1]=x.u(e,t[n-1]&2147483648>>e-1,1)),t},u:(t,e,n)=>32===t?e:(n?0|e:e<<32-t)+1099511627776*t,o:t=>s.round(t/1099511627776)||32,i(t,e,n,s){for(void 0===s&&(s=[]);e>=32;e-=32)s.push(n),n=0;if(0===e)return s.concat(t);for(let r=0;r<t.length;r++)s.push(n|t[r]>>>e),n=t[r]<<32-e;const r=t.length?t[t.length-1]:0,o=x.o(r);return s.push(x.u(e+o&31,e+o>32?n:s.pop(),1)),s}},I={bytes:{p(t){const e=x.h(t)/8,n=new o(e);let s;for(let r=0;e>r;r++)3&r||(s=t[r/4]),n[r]=s>>>24,s<<=8;return n},m(t){const e=[];let n,s=0;for(n=0;n<t.length;n++)s=s<<8|t[n],3&~n||(e.push(s),s=0);return 3&n&&e.push(x.u(8*(3&n),s)),e}}},R=class{constructor(t){const e=this;e.blockSize=512,e.S=[1732584193,4023233417,2562383102,271733878,3285377520],e.v=[1518500249,1859775393,2400959708,3395469782],t?(e.k=t.k.slice(0),e.C=t.C.slice(0),e.A=t.A):e.reset()}reset(){const t=this;return t.k=t.S.slice(0),t.C=[],t.A=0,t}update(t){const e=this;"string"==typeof t&&(t=I.I.m(t));const n=e.C=x.concat(e.C,t),s=e.A,o=e.A=s+x.h(t);if(o>9007199254740991)throw new r("Cannot hash more than 2^53 - 1 bits");const i=new c(n);let a=0;for(let t=e.blockSize+s-(e.blockSize+s&e.blockSize-1);o>=t;t+=e.blockSize)e.R(i.subarray(16*a,16*(a+1))),a+=1;return n.splice(0,16*a),e}P(){const t=this;let e=t.C;const n=t.k;e=x.concat(e,[x.u(1,1)]);for(let t=e.length+2;15&t;t++)e.push(0);for(e.push(s.floor(t.A/4294967296)),e.push(0|t.A);e.length;)t.R(e.splice(0,16));return t.reset(),n}U(t,e,n,s){return t>19?t>39?t>59?t>79?void 0:e^n^s:e&n|e&s|n&s:e^n^s:e&n|~e&s}V(t,e){return e<<t|e>>>32-t}R(e){const n=this,r=n.k,o=t(80);for(let t=0;16>t;t++)o[t]=e[t];let i=r[0],c=r[1],a=r[2],h=r[3],f=r[4];for(let t=0;79>=t;t++){16>t||(o[t]=n.V(1,o[t-3]^o[t-8]^o[t-14]^o[t-16]));const e=n.V(5,i)+n.U(t,c,a,h)+f+o[t]+n.v[s.floor(t/20)]|0;f=h,h=a,a=n.V(30,c),c=i,i=e}r[0]=r[0]+i|0,r[1]=r[1]+c|0,r[2]=r[2]+a|0,r[3]=r[3]+h|0,r[4]=r[4]+f|0}},P={getRandomValues(t){const e=new c(t.buffer),n=t=>{let e=987654321;const n=4294967295;return()=>(e=36969*(65535&e)+(e>>16)&n,(((e<<16)+(t=18e3*(65535&t)+(t>>16)&n)&n)/4294967296+.5)*(s.random()>.5?1:-1))};for(let r,o=0;o<t.length;o+=4){const t=n(4294967296*(r||s.random()));r=987654071*t(),e[o/4]=4294967296*t()|0}return t}},U={importKey:t=>new U.M(I.bytes.m(t)),_(t,e,n,s){if(n=n||1e4,0>s||0>n)throw new r("invalid params to pbkdf2");const o=1+(s>>5)<<2;let i,c,a,h,l;const u=new ArrayBuffer(o),w=new f(u);let p=0;const d=x;for(e=I.bytes.m(e),l=1;(o||1)>p;l++){for(i=c=t.encrypt(d.concat(e,[l])),a=1;n>a;a++)for(c=t.encrypt(c),h=0;h<c.length;h++)i[h]^=c[h];for(a=0;(o||1)>p&&a<i.length;a++)w.setInt32(p,i[a]),p+=4}return u.slice(0,s/8)},M:class{constructor(t){const e=this,n=e.B=R,s=[[],[]];e.D=[new n,new n];const r=e.D[0].blockSize/32;t.length>r&&(t=(new n).update(t).P());for(let e=0;r>e;e++)s[0][e]=909522486^t[e],s[1][e]=1549556828^t[e];e.D[0].update(s[0]),e.D[1].update(s[1]),e.W=new n(e.D[0])}reset(){const t=this;t.W=new t.B(t.D[0]),t.K=!1}update(t){this.K=!0,this.W.update(t)}digest(){const t=this,e=t.W.P(),n=new t.B(t.D[1]).update(e).P();return t.reset(),n}encrypt(t){if(this.K)throw new r("encrypt on already updated hmac called!");return this.update(t),this.digest(t)}}},V=typeof w!=v&&typeof w.getRandomValues==k,M="Invalid password",_="Invalid signature",B="zipjs-abort-check-password";function D(t){return V?w.getRandomValues(t):P.getRandomValues(t)}const W=16,K={name:"PBKDF2"},E=e.assign({hash:{name:"HMAC"}},K),L=e.assign({iterations:1e3,hash:{name:"SHA-1"}},K),O=["deriveBits"],T=[8,12,16],j=[16,24,32],H=10,Z=[0,0,0,0],F=typeof w!=v,N=F&&w.subtle,q=F&&typeof N!=v,G=I.bytes,J=class{constructor(t){const e=this;e.L=[[[],[],[],[],[]],[[],[],[],[],[]]],e.L[0][0][0]||e.O();const n=e.L[0][4],s=e.L[1],o=t.length;let i,c,a,h=1;if(4!==o&&6!==o&&8!==o)throw new r("invalid aes key size");for(e.v=[c=t.slice(0),a=[]],i=o;4*o+28>i;i++){let t=c[i-1];(i%o===0||8===o&&i%o===4)&&(t=n[t>>>24]<<24^n[t>>16&255]<<16^n[t>>8&255]<<8^n[255&t],i%o===0&&(t=t<<8^t>>>24^h<<24,h=h<<1^283*(h>>7))),c[i]=c[i-o]^t}for(let t=0;i;t++,i--){const e=c[3&t?i:i-4];a[t]=4>=i||4>t?e:s[0][n[e>>>24]]^s[1][n[e>>16&255]]^s[2][n[e>>8&255]]^s[3][n[255&e]]}}encrypt(t){return this.T(t,0)}decrypt(t){return this.T(t,1)}O(){const t=this.L[0],e=this.L[1],n=t[4],s=e[4],r=[],o=[];let i,c,a,h;for(let t=0;256>t;t++)o[(r[t]=t<<1^283*(t>>7))^t]=t;for(let f=i=0;!n[f];f^=c||1,i=o[i]||1){let o=i^i<<1^i<<2^i<<3^i<<4;o=o>>8^255&o^99,n[f]=o,s[o]=f,h=r[a=r[c=r[f]]];let l=16843009*h^65537*a^257*c^16843008*f,u=257*r[o]^16843008*o;for(let n=0;4>n;n++)t[n][f]=u=u<<24^u>>>8,e[n][o]=l=l<<24^l>>>8}for(let n=0;5>n;n++)t[n]=t[n].slice(0),e[n]=e[n].slice(0)}T(t,e){if(4!==t.length)throw new r("invalid aes block size");const n=this.v[e],s=n.length/4-2,o=[0,0,0,0],i=this.L[e],c=i[0],a=i[1],h=i[2],f=i[3],l=i[4];let u,w,p,d=t[0]^n[0],y=t[e?3:1]^n[1],m=t[2]^n[2],g=t[e?1:3]^n[3],S=4;for(let t=0;s>t;t++)u=c[d>>>24]^a[y>>16&255]^h[m>>8&255]^f[255&g]^n[S],w=c[y>>>24]^a[m>>16&255]^h[g>>8&255]^f[255&d]^n[S+1],p=c[m>>>24]^a[g>>16&255]^h[d>>8&255]^f[255&y]^n[S+2],g=c[g>>>24]^a[d>>16&255]^h[y>>8&255]^f[255&m]^n[S+3],S+=4,d=u,y=w,m=p;for(let t=0;4>t;t++)o[e?3&-t:t]=l[d>>>24]<<24^l[y>>16&255]<<16^l[m>>8&255]<<8^l[255&g]^n[S++],u=d,d=y,y=m,m=g,g=u;return o}},Q=class{constructor(t,e){this.j=t,this.H=e,this.Z=e}reset(){this.Z=this.H}update(t){return this.F(this.j,t,this.Z)}N(t){if(255&~(t>>24))t+=1<<24;else{let e=t>>16&255,n=t>>8&255,s=255&t;255===e?(e=0,255===n?(n=0,255===s?s=0:++s):++n):++e,t=0,t+=e<<16,t+=n<<8,t+=s}return t}q(t){0===(t[0]=this.N(t[0]))&&(t[1]=this.N(t[1]))}F(t,e,n){let s;if(!(s=e.length))return[];const r=x.h(e);for(let r=0;s>r;r+=4){this.q(n);const s=t.encrypt(n);e[r]^=s[0],e[r+1]^=s[1],e[r+2]^=s[2],e[r+3]^=s[3]}return x.l(e,r)}},X=U.M;let Y=F&&q&&typeof N.importKey==k,$=F&&q&&typeof N.deriveBits==k;class tt extends d{constructor({password:t,rawPassword:n,signed:s,encryptionStrength:i,checkPasswordOnly:c}){super({start(){e.assign(this,{ready:new l(t=>this.G=t),password:rt(t,n),signed:s,J:i-1,pending:new o})},async transform(t,e){const n=this,{password:s,J:i,G:a,ready:h}=n;s?(await(async(t,e,n,s)=>{const o=await st(t,e,n,it(s,0,T[e])),i=it(s,T[e]);if(o[0]!=i[0]||o[1]!=i[1])throw new r(M)})(n,i,s,it(t,0,T[i]+2)),t=it(t,T[i]+2),c?e.error(new r(B)):a()):await h;const f=new o(t.length-H-(t.length-H)%W);e.enqueue(nt(n,t,f,0,H,!0))},async flush(t){const{signed:e,X:n,Y:s,pending:i,ready:c}=this;if(s&&n){await c;const a=it(i,0,i.length-H),h=it(i,i.length-H);let f=new o;if(a.length){const t=at(G,a);s.update(t);const e=n.update(t);f=ct(G,e)}if(e){const t=it(ct(G,s.digest()),0,H);for(let e=0;H>e;e++)if(t[e]!=h[e])throw new r(_)}t.enqueue(f)}}})}}class et extends d{constructor({password:t,rawPassword:n,encryptionStrength:s}){let r;super({start(){e.assign(this,{ready:new l(t=>this.G=t),password:rt(t,n),J:s-1,pending:new o})},async transform(t,e){const n=this,{password:s,J:r,G:i,ready:c}=n;let a=new o;s?(a=await(async(t,e,n)=>{const s=D(new o(T[e]));return ot(s,await st(t,e,n,s))})(n,r,s),i()):await c;const h=new o(a.length+t.length-t.length%W);h.set(a,0),e.enqueue(nt(n,t,h,a.length,0))},async flush(t){const{X:e,Y:n,pending:s,ready:i}=this;if(n&&e){await i;let c=new o;if(s.length){const t=e.update(at(G,s));n.update(t),c=ct(G,t)}r.signature=ct(G,n.digest()).slice(0,H),t.enqueue(ot(c,r.signature))}}}),r=this}}function nt(t,e,n,s,r,i){const{X:c,Y:a,pending:h}=t,f=e.length-r;let l;for(h.length&&(e=ot(h,e),n=((t,e)=>{if(e&&e>t.length){const n=t;(t=new o(e)).set(n,0)}return t})(n,f-f%W)),l=0;f-W>=l;l+=W){const t=at(G,it(e,l,l+W));i&&a.update(t);const r=c.update(t);i||a.update(r),n.set(ct(G,r),l+s)}return t.pending=it(e,l),n}async function st(n,s,r,i){n.password=null;const c=await(async(t,e,n,s,r)=>{if(!Y)return U.importKey(e);try{return await N.importKey("raw",e,n,!1,r)}catch{return Y=!1,U.importKey(e)}})(0,r,E,0,O),a=await(async(t,e,n)=>{if(!$)return U._(e,t.salt,L.iterations,n);try{return await N.deriveBits(t,e,n)}catch{return $=!1,U._(e,t.salt,L.iterations,n)}})(e.assign({salt:i},L),c,8*(2*j[s]+2)),h=new o(a),f=at(G,it(h,0,j[s])),l=at(G,it(h,j[s],2*j[s])),u=it(h,2*j[s]);return e.assign(n,{keys:{key:f,$:l,passwordVerification:u},X:new Q(new J(f),t.from(Z)),Y:new X(l)}),u}function rt(t,e){return e===b?(t=>{if(typeof u==v){const e=new o((t=unescape(encodeURIComponent(t))).length);for(let n=0;n<e.length;n++)e[n]=t.charCodeAt(n);return e}return(new u).encode(t)})(t):e}function ot(t,e){let n=t;return t.length+e.length&&(n=new o(t.length+e.length),n.set(t,0),n.set(e,t.length)),n}function it(t,e,n){return t.subarray(e,n)}function ct(t,e){return t.p(e)}function at(t,e){return t.m(e)}class ht extends d{constructor({password:t,passwordVerification:n,checkPasswordOnly:s}){super({start(){e.assign(this,{password:t,passwordVerification:n}),wt(this,t)},transform(t,e){const n=this;if(n.password){const e=lt(n,t.subarray(0,12));if(n.password=null,e.at(-1)!=n.passwordVerification)throw new r(M);t=t.subarray(12)}s?e.error(new r(B)):e.enqueue(lt(n,t))}})}}class ft extends d{constructor({password:t,passwordVerification:n}){super({start(){e.assign(this,{password:t,passwordVerification:n}),wt(this,t)},transform(t,e){const n=this;let s,r;if(n.password){n.password=null;const e=D(new o(12));e[11]=n.passwordVerification,s=new o(t.length+e.length),s.set(ut(n,e),0),r=12}else s=new o(t.length),r=0;s.set(ut(n,t),r),e.enqueue(s)}})}}function lt(t,e){const n=new o(e.length);for(let s=0;s<e.length;s++)n[s]=dt(t)^e[s],pt(t,n[s]);return n}function ut(t,e){const n=new o(e.length);for(let s=0;s<e.length;s++)n[s]=dt(t)^e[s],pt(t,e[s]);return n}function wt(t,n){const s=[305419896,591751049,878082192];e.assign(t,{keys:s,tt:new C(s[0]),et:new C(s[2])});for(let e=0;e<n.length;e++)pt(t,n.charCodeAt(e))}function pt(t,e){let[n,r,o]=t.keys;t.tt.append([e]),n=~t.tt.get(),r=mt(s.imul(mt(r+yt(n)),134775813)+1),t.et.append([r>>>24]),o=~t.et.get(),t.keys=[n,r,o]}function dt(t){const e=2|t.keys[2];return yt(s.imul(e,1^e)>>>8)}function yt(t){return 255&t}function mt(t){return 4294967295&t}class gt extends d{constructor(t,{chunkSize:e,nt:n,CompressionStream:s}){super({});const{compressed:r,encrypted:o,useCompressionStream:i,zipCrypto:c,signed:a,level:h}=t,l=this;let u,w,p=super.readable;o&&!c||!a||(u=new A,p=kt(p,u)),r&&(p=vt(p,i,{level:h,chunkSize:e},s,n,s)),o&&(c?p=kt(p,new ft(t)):(w=new et(t),p=kt(p,w))),bt(l,p,()=>{let t;o&&!c&&(t=w.signature),o&&!c||!a||(t=new f(u.value.buffer).getUint32(0)),l.signature=t})}}class St extends d{constructor(t,{chunkSize:e,st:n,DecompressionStream:s}){super({});const{zipCrypto:o,encrypted:i,signed:c,signature:a,compressed:h,useCompressionStream:l,rt:u}=t;let w,p,d=super.readable;i&&(o?d=kt(d,new ht(t)):(p=new tt(t),d=kt(d,p))),h&&(d=vt(d,l,{chunkSize:e,rt:u},s,n,s)),i&&!o||!c||(w=new A,d=kt(d,w)),bt(this,d,()=>{if((!i||o)&&c){const t=new f(w.value.buffer);if(a!=t.getUint32(0,!1))throw new r(_)}})}}function bt(t,n,s){n=kt(n,new d({flush:s})),e.defineProperty(t,"readable",{get:()=>n})}function vt(t,e,n,s,r,o){const i=e&&s?s:r||o,c=n.rt?"deflate64-raw":"deflate-raw";try{t=kt(t,new i(c,n))}catch(s){if(!e)throw s;if(r)t=kt(t,new r(c,n));else{if(!o)throw s;t=kt(t,new o(c,n))}}return t}function kt(t,e){return t.pipeThrough(e)}const zt="data",Ct="close";class At extends d{constructor(t,n){super({});const s=this,{codecType:o}=t;let i;o.startsWith("deflate")?i=gt:o.startsWith("inflate")&&(i=St),s.outputSize=0;let c=0;const a=new i(t,n),h=super.readable,f=new d({transform(t,e){t&&t.length&&(c+=t.length,e.enqueue(t))},flush(){e.assign(s,{inputSize:c})}}),l=new d({transform(e,n){if(e&&e.length&&(n.enqueue(e),s.outputSize+=e.length,t.outputSize!==b&&s.outputSize>t.outputSize))throw new r("Invalid uncompressed size")},flush(){const{signature:t}=a;e.assign(s,{signature:t,inputSize:c})}});e.defineProperty(s,"readable",{get:()=>h.pipeThrough(f).pipeThrough(a).pipeThrough(l)})}}class xt extends d{constructor(t){let e;super({transform:function n(s,r){if(e){const t=new o(e.length+s.length);t.set(e),t.set(s,e.length),s=t,e=null}s.length>t?(r.enqueue(s.slice(0,t)),n(s.slice(t),r)):e=s},flush(t){e&&e.length&&t.enqueue(e)}})}}const It=new h,Rt=new h;let Pt,Ut,Vt,Mt,_t,Bt=0;async function Dt(t){try{const{options:e,config:s}=t;if(!e.useCompressionStream)try{await self.initModule(t.config)}catch{e.useCompressionStream=!0}s.CompressionStream=self.CompressionStream,s.DecompressionStream=self.DecompressionStream;const r={highWaterMark:1},o=t.readable||new y({async pull(t){const e=new l(t=>It.set(Bt,t));Wt({type:"pull",messageId:Bt}),Bt=(Bt+1)%n.MAX_SAFE_INTEGER;const{value:s,done:r}=await e;t.enqueue(s),r&&t.close()}},r),i=t.writable||new m({async write(t){let e;const s=new l(t=>e=t);Rt.set(Bt,e),Wt({type:zt,value:t,messageId:Bt}),Bt=(Bt+1)%n.MAX_SAFE_INTEGER,await s}},r),c=new At(e,s);Pt=new AbortController;const{signal:a}=Pt;await o.pipeThrough(c).pipeThrough(new xt(s.chunkSize)).pipeTo(i,{signal:a,preventClose:!0,preventAbort:!0}),await i.getWriter().close();const{signature:h,inputSize:f,outputSize:u}=c;Wt({type:Ct,result:{signature:h,inputSize:f,outputSize:u}})}catch(t){t.outputSize=0,Kt(t)}}function Wt(t){let{value:e}=t;if(e)if(e.length)try{e=new o(e),t.value=e.buffer,p(t,[t.value])}catch{p(t)}else p(t);else p(t)}function Kt(t=new r("Unknown error")){const{message:e,stack:n,code:s,name:o,outputSize:i}=t;p({error:{message:e,stack:n,code:s,name:o,outputSize:i}})}function Et(t,e,n={}){const i="number"==typeof n.level?n.level:-1,c="number"==typeof n.ot?n.ot:65536,a="number"==typeof n.it?n.it:65536;return new d({start(){let n;if(this.ct=Vt(c),this.in=Vt(a),this.it=a,this.ht=new o(c),t?(this.ft=Ut.deflate_process,this.lt=Ut.deflate_last_consumed,this.ut=Ut.deflate_end,this.wt=Ut.deflate_new(),n="gzip"===e?Ut.deflate_init_gzip(this.wt,i):"deflate-raw"===e?Ut.deflate_init_raw(this.wt,i):Ut.deflate_init(this.wt,i)):"deflate64-raw"===e?(this.ft=Ut.inflate9_process,this.lt=Ut.inflate9_last_consumed,this.ut=Ut.inflate9_end,this.wt=Ut.inflate9_new(),n=Ut.inflate9_init_raw(this.wt)):(this.ft=Ut.inflate_process,this.lt=Ut.inflate_last_consumed,this.ut=Ut.inflate_end,this.wt=Ut.inflate_new(),n="deflate-raw"===e?Ut.inflate_init_raw(this.wt):"gzip"===e?Ut.inflate_init_gzip(this.wt):Ut.inflate_init(this.wt)),0!==n)throw new r("init failed:"+n)},transform(e,n){try{const i=e,a=new o(_t.buffer),h=this.ft,f=this.lt,l=this.ct,u=this.ht;let w=0;for(;w<i.length;){const e=s.min(i.length-w,32768);this.in&&this.it>=e||(this.in&&Mt&&Mt(this.in),this.in=Vt(e),this.it=e),a.set(i.subarray(w,w+e),this.in);const o=h(this.wt,this.in,e,l,c,0);if(!t&&0>o)throw new r("process error:"+o);const p=16777215&o;p&&(u.set(a.subarray(l,l+p),0),n.enqueue(u.slice(0,p)));const d=f(this.wt);if(0===d)break;w+=d}}catch(t){this.ut&&this.wt&&this.ut(this.wt),this.in&&Mt&&Mt(this.in),this.ct&&Mt&&Mt(this.ct),n.error(t)}},flush(e){try{const n=new o(_t.buffer),s=this.ft,i=this.ct,a=this.ht;for(;;){const o=s(this.wt,0,0,i,c,4);if(!t&&0>o)throw new r("process error:"+o);const h=16777215&o,f=o>>24&255;if(h&&(a.set(n.subarray(i,i+h),0),e.enqueue(a.slice(0,h))),1===f||0===h)break}}catch(t){e.error(t)}finally{if(this.ut&&this.wt){const t=this.ut(this.wt);0!==t&&e.error(new r("end error:"+t))}this.in&&Mt&&Mt(this.in),this.ct&&Mt&&Mt(this.ct)}}})}addEventListener("message",({data:t})=>{const{type:e,messageId:n,value:s,done:r}=t;try{if("start"==e&&Dt(t),e==zt){const t=It.get(n);It.delete(n),t({value:new o(s),done:r})}if("ack"==e){const t=Rt.get(n);Rt.delete(n),t()}e==Ct&&Pt.abort()}catch(t){Kt(t)}});class Lt{constructor(t="deflate",e){return Et(!0,t,e)}}class Ot{constructor(t="deflate",e){return Et(!1,t,e)}}let Tt=!1;self.initModule=async t=>{try{const e=await(async(t,{baseURI:e})=>{if(!Tt){let n,s;try{try{s=new URL(t,e)}catch{}const r=await fetch(s);n=await r.arrayBuffer()}catch(e){if(!t.startsWith("data:application/wasm;base64,"))throw e;n=(t=>{const e=t.split(",")[1],n=atob(e),s=n.length,r=new o(s);for(let t=0;s>t;++t)r[t]=n.charCodeAt(t);return r.buffer})(t)}(t=>{if(Ut=t,({malloc:Vt,free:Mt,memory:_t}=Ut),"function"!=typeof Vt||"function"!=typeof Mt||!_t)throw Ut=Vt=Mt=_t=null,new r("Invalid WASM module")})((await WebAssembly.instantiate(n)).instance.exports),Tt=!0}})(t.wasmURI,t);return t.nt=Lt,t.st=Ot,e}catch{}}});
2
- `)),t)})}const Cr=[];for(let e=0;e<256;e++){let t=e;for(let n=0;n<8;n++)t&1?t=t>>>1^3988292384:t=t>>>1;Cr[e]=t}class Qn{constructor(t){this.crc=t||-1}append(t){let n=this.crc|0;for(let s=0,A=t.length|0;s<A;s++)n=n>>>8^Cr[(n^t[s])&255];this.crc=n}get(){return~this.crc}}class mr extends TransformStream{constructor(){let t;const n=new Qn;super({transform(s,A){n.append(s),A.enqueue(s)},flush(){const s=new Uint8Array(4);new DataView(s.buffer).setUint32(0,n.get()),t.value=s}}),t=this}}function pn(e){if(typeof TextEncoder==pe){e=unescape(encodeURIComponent(e));const t=new Uint8Array(e.length);for(let n=0;n<t.length;n++)t[n]=e.charCodeAt(n);return t}else return new TextEncoder().encode(e)}const St={concat(e,t){if(e.length===0||t.length===0)return e.concat(t);const n=e[e.length-1],s=St.getPartial(n);return s===32?e.concat(t):St._shiftRight(t,s,n|0,e.slice(0,e.length-1))},bitLength(e){const t=e.length;if(t===0)return 0;const n=e[t-1];return(t-1)*32+St.getPartial(n)},clamp(e,t){if(e.length*32<t)return e;e=e.slice(0,Math.ceil(t/32));const n=e.length;return t=t&31,n>0&&t&&(e[n-1]=St.partial(t,e[n-1]&2147483648>>t-1,1)),e},partial(e,t,n){return e===32?t:(n?t|0:t<<32-e)+e*1099511627776},getPartial(e){return Math.round(e/1099511627776)||32},_shiftRight(e,t,n,s){for(s===void 0&&(s=[]);t>=32;t-=32)s.push(n),n=0;if(t===0)return s.concat(e);for(let o=0;o<e.length;o++)s.push(n|e[o]>>>t),n=e[o]<<32-t;const A=e.length?e[e.length-1]:0,r=St.getPartial(A);return s.push(St.partial(t+r&31,t+r>32?n:s.pop(),1)),s}},vn={bytes:{fromBits(e){const n=St.bitLength(e)/8,s=new Uint8Array(n);let A;for(let r=0;r<n;r++)(r&3)===0&&(A=e[r/4]),s[r]=A>>>24,A<<=8;return s},toBits(e){const t=[];let n,s=0;for(n=0;n<e.length;n++)s=s<<8|e[n],(n&3)===3&&(t.push(s),s=0);return n&3&&t.push(St.partial(8*(n&3),s)),t}}},Ir={};Ir.sha1=class{constructor(e){const t=this;t.blockSize=512,t._init=[1732584193,4023233417,2562383102,271733878,3285377520],t._key=[1518500249,1859775393,2400959708,3395469782],e?(t._h=e._h.slice(0),t._buffer=e._buffer.slice(0),t._length=e._length):t.reset()}reset(){const e=this;return e._h=e._init.slice(0),e._buffer=[],e._length=0,e}update(e){const t=this;typeof e=="string"&&(e=vn.utf8String.toBits(e));const n=t._buffer=St.concat(t._buffer,e),s=t._length,A=t._length=s+St.bitLength(e);if(A>9007199254740991)throw new Error("Cannot hash more than 2^53 - 1 bits");const r=new Uint32Array(n);let o=0;for(let i=t.blockSize+s-(t.blockSize+s&t.blockSize-1);i<=A;i+=t.blockSize)t._block(r.subarray(16*o,16*(o+1))),o+=1;return n.splice(0,16*o),t}finalize(){const e=this;let t=e._buffer;const n=e._h;t=St.concat(t,[St.partial(1,1)]);for(let s=t.length+2;s&15;s++)t.push(0);for(t.push(Math.floor(e._length/4294967296)),t.push(e._length|0);t.length;)e._block(t.splice(0,16));return e.reset(),n}_f(e,t,n,s){if(e<=19)return t&n|~t&s;if(e<=39)return t^n^s;if(e<=59)return t&n|t&s|n&s;if(e<=79)return t^n^s}_S(e,t){return t<<e|t>>>32-e}_block(e){const t=this,n=t._h,s=Array(80);for(let u=0;u<16;u++)s[u]=e[u];let A=n[0],r=n[1],o=n[2],i=n[3],a=n[4];for(let u=0;u<=79;u++){u>=16&&(s[u]=t._S(1,s[u-3]^s[u-8]^s[u-14]^s[u-16]));const c=t._S(5,A)+t._f(u,r,o,i)+a+s[u]+t._key[Math.floor(u/20)]|0;a=i,i=o,o=t._S(30,r),r=A,A=c}n[0]=n[0]+A|0,n[1]=n[1]+r|0,n[2]=n[2]+o|0,n[3]=n[3]+i|0,n[4]=n[4]+a|0}};const wr={};wr.aes=class{constructor(e){const t=this;t._tables=[[[],[],[],[],[]],[[],[],[],[],[]]],t._tables[0][0][0]||t._precompute();const n=t._tables[0][4],s=t._tables[1],A=e.length;let r,o,i,a=1;if(A!==4&&A!==6&&A!==8)throw new Error("invalid aes key size");for(t._key=[o=e.slice(0),i=[]],r=A;r<4*A+28;r++){let u=o[r-1];(r%A===0||A===8&&r%A===4)&&(u=n[u>>>24]<<24^n[u>>16&255]<<16^n[u>>8&255]<<8^n[u&255],r%A===0&&(u=u<<8^u>>>24^a<<24,a=a<<1^(a>>7)*283)),o[r]=o[r-A]^u}for(let u=0;r;u++,r--){const c=o[u&3?r:r-4];r<=4||u<4?i[u]=c:i[u]=s[0][n[c>>>24]]^s[1][n[c>>16&255]]^s[2][n[c>>8&255]]^s[3][n[c&255]]}}encrypt(e){return this._crypt(e,0)}decrypt(e){return this._crypt(e,1)}_precompute(){const e=this._tables[0],t=this._tables[1],n=e[4],s=t[4],A=[],r=[];let o,i,a,u;for(let c=0;c<256;c++)r[(A[c]=c<<1^(c>>7)*283)^c]=c;for(let c=o=0;!n[c];c^=i||1,o=r[o]||1){let g=o^o<<1^o<<2^o<<3^o<<4;g=g>>8^g&255^99,n[c]=g,s[g]=c,u=A[a=A[i=A[c]]];let l=u*16843009^a*65537^i*257^c*16843008,B=A[g]*257^g*16843008;for(let d=0;d<4;d++)e[d][c]=B=B<<24^B>>>8,t[d][g]=l=l<<24^l>>>8}for(let c=0;c<5;c++)e[c]=e[c].slice(0),t[c]=t[c].slice(0)}_crypt(e,t){if(e.length!==4)throw new Error("invalid aes block size");const n=this._key[t],s=n.length/4-2,A=[0,0,0,0],r=this._tables[t],o=r[0],i=r[1],a=r[2],u=r[3],c=r[4];let g=e[0]^n[0],l=e[t?3:1]^n[1],B=e[2]^n[2],d=e[t?1:3]^n[3],f=4,h,p,E;for(let C=0;C<s;C++)h=o[g>>>24]^i[l>>16&255]^a[B>>8&255]^u[d&255]^n[f],p=o[l>>>24]^i[B>>16&255]^a[d>>8&255]^u[g&255]^n[f+1],E=o[B>>>24]^i[d>>16&255]^a[g>>8&255]^u[l&255]^n[f+2],d=o[d>>>24]^i[g>>16&255]^a[l>>8&255]^u[B&255]^n[f+3],f+=4,g=h,l=p,B=E;for(let C=0;C<4;C++)A[t?3&-C:C]=c[g>>>24]<<24^c[l>>16&255]<<16^c[B>>8&255]<<8^c[d&255]^n[f++],h=g,g=l,l=B,B=d,d=h;return A}};const Xi={getRandomValues(e){const t=new Uint32Array(e.buffer),n=s=>{let A=987654321;const r=4294967295;return function(){return A=36969*(A&65535)+(A>>16)&r,s=18e3*(s&65535)+(s>>16)&r,(((A<<16)+s&r)/4294967296+.5)*(Math.random()>.5?1:-1)}};for(let s=0,A;s<e.length;s+=4){const r=n((A||Math.random())*4294967296);A=r()*987654071,t[s/4]=r()*4294967296|0}return e}},Fr={};Fr.ctrGladman=class{constructor(e,t){this._prf=e,this._initIv=t,this._iv=t}reset(){this._iv=this._initIv}update(e){return this.calculate(this._prf,e,this._iv)}incWord(e){if((e>>24&255)===255){let t=e>>16&255,n=e>>8&255,s=e&255;t===255?(t=0,n===255?(n=0,s===255?s=0:++s):++n):++t,e=0,e+=t<<16,e+=n<<8,e+=s}else e+=1<<24;return e}incCounter(e){(e[0]=this.incWord(e[0]))===0&&(e[1]=this.incWord(e[1]))}calculate(e,t,n){let s;if(!(s=t.length))return[];const A=St.bitLength(t);for(let r=0;r<s;r+=4){this.incCounter(n);const o=e.encrypt(n);t[r]^=o[0],t[r+1]^=o[1],t[r+2]^=o[2],t[r+3]^=o[3]}return St.clamp(t,A)}};const be={importKey(e){return new be.hmacSha1(vn.bytes.toBits(e))},pbkdf2(e,t,n,s){if(n=n||1e4,s<0||n<0)throw new Error("invalid params to pbkdf2");const A=(s>>5)+1<<2;let r,o,i,a,u;const c=new ArrayBuffer(A),g=new DataView(c);let l=0;const B=St;for(t=vn.bytes.toBits(t),u=1;l<(A||1);u++){for(r=o=e.encrypt(B.concat(t,[u])),i=1;i<n;i++)for(o=e.encrypt(o),a=0;a<o.length;a++)r[a]^=o[a];for(i=0;l<(A||1)&&i<r.length;i++)g.setInt32(l,r[i]),l+=4}return c.slice(0,s/8)}};be.hmacSha1=class{constructor(e){const t=this,n=t._hash=Ir.sha1,s=[[],[]];t._baseHash=[new n,new n];const A=t._baseHash[0].blockSize/32;e.length>A&&(e=new n().update(e).finalize());for(let r=0;r<A;r++)s[0][r]=e[r]^909522486,s[1][r]=e[r]^1549556828;t._baseHash[0].update(s[0]),t._baseHash[1].update(s[1]),t._resultHash=new n(t._baseHash[0])}reset(){const e=this;e._resultHash=new e._hash(e._baseHash[0]),e._updated=!1}update(e){const t=this;t._updated=!0,t._resultHash.update(e)}digest(){const e=this,t=e._resultHash.finalize(),n=new e._hash(e._baseHash[1]).update(t).finalize();return e.reset(),n}encrypt(e){if(this._updated)throw new Error("encrypt on already updated hmac called!");return this.update(e),this.digest(e)}};const Zi=typeof crypto!=pe&&typeof crypto.getRandomValues==Me,xr="Invalid password",yr="Invalid signature",ks="zipjs-abort-check-password";function Sr(e){return Zi?crypto.getRandomValues(e):Xi.getRandomValues(e)}const _e=16,ta="raw",Qr={name:"PBKDF2"},ea={name:"HMAC"},na="SHA-1",sa=Object.assign({hash:ea},Qr),ms=Object.assign({iterations:1e3,hash:{name:na}},Qr),Aa=["deriveBits"],sn=[8,12,16],qe=[16,24,32],de=10,ra=[0,0,0,0],Gn=typeof crypto!=pe,on=Gn&&crypto.subtle,vr=Gn&&typeof on!=pe,ee=vn.bytes,oa=wr.aes,ia=Fr.ctrGladman,aa=be.hmacSha1;let cA=Gn&&vr&&typeof on.importKey==Me,gA=Gn&&vr&&typeof on.deriveBits==Me;class ua extends TransformStream{constructor({password:t,rawPassword:n,signed:s,encryptionStrength:A,checkPasswordOnly:r}){super({start(){Object.assign(this,{ready:new Promise(o=>this.resolveReady=o),password:Tr(t,n),signed:s,strength:A-1,pending:new Uint8Array})},async transform(o,i){const a=this,{password:u,strength:c,resolveReady:g,ready:l}=a;u?(await ga(a,c,u,Ht(o,0,sn[c]+2)),o=Ht(o,sn[c]+2),r?i.error(new Error(ks)):g()):await l;const B=new Uint8Array(o.length-de-(o.length-de)%_e);i.enqueue(br(a,o,B,0,de,!0))},async flush(o){const{signed:i,ctr:a,hmac:u,pending:c,ready:g}=this;if(u&&a){await g;const l=Ht(c,0,c.length-de),B=Ht(c,c.length-de);let d=new Uint8Array;if(l.length){const f=rn(ee,l);u.update(f);const h=a.update(f);d=An(ee,h)}if(i){const f=Ht(An(ee,u.digest()),0,de);for(let h=0;h<de;h++)if(f[h]!=B[h])throw new Error(yr)}o.enqueue(d)}}})}}class ca extends TransformStream{constructor({password:t,rawPassword:n,encryptionStrength:s}){let A;super({start(){Object.assign(this,{ready:new Promise(r=>this.resolveReady=r),password:Tr(t,n),strength:s-1,pending:new Uint8Array})},async transform(r,o){const i=this,{password:a,strength:u,resolveReady:c,ready:g}=i;let l=new Uint8Array;a?(l=await la(i,u,a),c()):await g;const B=new Uint8Array(l.length+r.length-r.length%_e);B.set(l,0),o.enqueue(br(i,r,B,l.length,0))},async flush(r){const{ctr:o,hmac:i,pending:a,ready:u}=this;if(i&&o){await u;let c=new Uint8Array;if(a.length){const g=o.update(rn(ee,a));i.update(g),c=An(ee,g)}A.signature=An(ee,i.digest()).slice(0,de),r.enqueue(_s(c,A.signature))}}}),A=this}}function br(e,t,n,s,A,r){const{ctr:o,hmac:i,pending:a}=e,u=t.length-A;a.length&&(t=_s(a,t),n=Ba(n,u-u%_e));let c;for(c=0;c<=u-_e;c+=_e){const g=rn(ee,Ht(t,c,c+_e));r&&i.update(g);const l=o.update(g);r||i.update(l),n.set(An(ee,l),c+s)}return e.pending=Ht(t,c),n}async function ga(e,t,n,s){const A=await Mr(e,t,n,Ht(s,0,sn[t])),r=Ht(s,sn[t]);if(A[0]!=r[0]||A[1]!=r[1])throw new Error(xr)}async function la(e,t,n){const s=Sr(new Uint8Array(sn[t])),A=await Mr(e,t,n,s);return _s(s,A)}async function Mr(e,t,n,s){e.password=null;const A=await da(ta,n,sa,!1,Aa),r=await fa(Object.assign({salt:s},ms),A,8*(qe[t]*2+2)),o=new Uint8Array(r),i=rn(ee,Ht(o,0,qe[t])),a=rn(ee,Ht(o,qe[t],qe[t]*2)),u=Ht(o,qe[t]*2);return Object.assign(e,{keys:{key:i,authentication:a,passwordVerification:u},ctr:new ia(new oa(i),Array.from(ra)),hmac:new aa(a)}),u}async function da(e,t,n,s,A){if(cA)try{return await on.importKey(e,t,n,s,A)}catch{return cA=!1,be.importKey(t)}else return be.importKey(t)}async function fa(e,t,n){if(gA)try{return await on.deriveBits(e,t,n)}catch{return gA=!1,be.pbkdf2(t,e.salt,ms.iterations,n)}else return be.pbkdf2(t,e.salt,ms.iterations,n)}function Tr(e,t){return t===F?pn(e):t}function _s(e,t){let n=e;return e.length+t.length&&(n=new Uint8Array(e.length+t.length),n.set(e,0),n.set(t,e.length)),n}function Ba(e,t){if(t&&t>e.length){const n=e;e=new Uint8Array(t),e.set(n,0)}return e}function Ht(e,t,n){return e.subarray(t,n)}function An(e,t){return e.fromBits(t)}function rn(e,t){return e.toBits(t)}const tn=12;class Ea extends TransformStream{constructor({password:t,passwordVerification:n,checkPasswordOnly:s}){super({start(){Object.assign(this,{password:t,passwordVerification:n}),Yr(this,t)},transform(A,r){const o=this;if(o.password){const i=lA(o,A.subarray(0,tn));if(o.password=null,i.at(-1)!=o.passwordVerification)throw new Error(xr);A=A.subarray(tn)}s?r.error(new Error(ks)):r.enqueue(lA(o,A))}})}}class ha extends TransformStream{constructor({password:t,passwordVerification:n}){super({start(){Object.assign(this,{password:t,passwordVerification:n}),Yr(this,t)},transform(s,A){const r=this;let o,i;if(r.password){r.password=null;const a=Sr(new Uint8Array(tn));a[tn-1]=r.passwordVerification,o=new Uint8Array(s.length+a.length),o.set(dA(r,a),0),i=tn}else o=new Uint8Array(s.length),i=0;o.set(dA(r,s),i),A.enqueue(o)}})}}function lA(e,t){const n=new Uint8Array(t.length);for(let s=0;s<t.length;s++)n[s]=Pr(e)^t[s],Ls(e,n[s]);return n}function dA(e,t){const n=new Uint8Array(t.length);for(let s=0;s<t.length;s++)n[s]=Pr(e)^t[s],Ls(e,t[s]);return n}function Yr(e,t){const n=[305419896,591751049,878082192];Object.assign(e,{keys:n,crcKey0:new Qn(n[0]),crcKey2:new Qn(n[2])});for(let s=0;s<t.length;s++)Ls(e,t.charCodeAt(s))}function Ls(e,t){let[n,s,A]=e.keys;e.crcKey0.append([t]),n=~e.crcKey0.get(),s=fA(Math.imul(fA(s+Rr(n)),134775813)+1),e.crcKey2.append([s>>>24]),A=~e.crcKey2.get(),e.keys=[n,s,A]}function Pr(e){const t=e.keys[2]|2;return Rr(Math.imul(t,t^1)>>>8)}function Rr(e){return e&255}function fA(e){return e&4294967295}const Or="Invalid uncompressed size",pa="deflate-raw",Da="deflate64-raw";class Ca extends TransformStream{constructor(t,{chunkSize:n,CompressionStreamZlib:s,CompressionStream:A}){super({});const{compressed:r,encrypted:o,useCompressionStream:i,zipCrypto:a,signed:u,level:c}=t,g=this;let l,B,d=super.readable;(!o||a)&&u&&(l=new mr,d=ne(d,l)),r&&(d=_r(d,i,{level:c,chunkSize:n},A,s,A)),o&&(a?d=ne(d,new ha(t)):(B=new ca(t),d=ne(d,B))),kr(g,d,()=>{let f;o&&!a&&(f=B.signature),(!o||a)&&u&&(f=new DataView(l.value.buffer).getUint32(0)),g.signature=f})}}class ma extends TransformStream{constructor(t,{chunkSize:n,DecompressionStreamZlib:s,DecompressionStream:A}){super({});const{zipCrypto:r,encrypted:o,signed:i,signature:a,compressed:u,useCompressionStream:c,deflate64:g}=t;let l,B,d=super.readable;o&&(r?d=ne(d,new Ea(t)):(B=new ua(t),d=ne(d,B))),u&&(d=_r(d,c,{chunkSize:n,deflate64:g},A,s,A)),(!o||r)&&i&&(l=new mr,d=ne(d,l)),kr(this,d,()=>{if((!o||r)&&i){const f=new DataView(l.value.buffer);if(a!=f.getUint32(0,!1))throw new Error(yr)}})}}function kr(e,t,n){t=ne(t,new TransformStream({flush:n})),Object.defineProperty(e,"readable",{get(){return t}})}function _r(e,t,n,s,A,r){const o=t&&s?s:A||r,i=n.deflate64?Da:pa;try{e=ne(e,new o(i,n))}catch(a){if(t)if(A)e=ne(e,new A(i,n));else if(r)e=ne(e,new r(i,n));else throw a;else throw a}return e}function ne(e,t){return e.pipeThrough(t)}const Ia="message",wa="start",Fa="pull",BA="data",xa="ack",EA="close",Lr="deflate",Gr="inflate";class ya extends TransformStream{constructor(t,n){super({});const s=this,{codecType:A}=t;let r;A.startsWith(Lr)?r=Ca:A.startsWith(Gr)&&(r=ma),s.outputSize=0;let o=0;const i=new r(t,n),a=super.readable,u=new TransformStream({transform(g,l){g&&g.length&&(o+=g.length,l.enqueue(g))},flush(){Object.assign(s,{inputSize:o})}}),c=new TransformStream({transform(g,l){if(g&&g.length&&(l.enqueue(g),s.outputSize+=g.length,t.outputSize!==F&&s.outputSize>t.outputSize))throw new Error(Or)},flush(){const{signature:g}=i;Object.assign(s,{signature:g,inputSize:o})}});Object.defineProperty(s,"readable",{get(){return a.pipeThrough(u).pipeThrough(i).pipeThrough(c)}})}}class Sa extends TransformStream{constructor(t){let n;super({transform:s,flush(A){n&&n.length&&A.enqueue(n)}});function s(A,r){if(n){const o=new Uint8Array(n.length+A.length);o.set(n),o.set(A,n.length),A=o,n=null}A.length>t?(r.enqueue(A.slice(0,t)),s(A.slice(t),r)):n=A}}}let Nr=typeof Worker!=pe,Ur=()=>{};function Qa({initModule:e}){Ur=e}class Xn{constructor(t,{readable:n,writable:s},{options:A,config:r,streamOptions:o,useWebWorkers:i,transferStreams:a,workerURI:u},c){const{signal:g}=o;return Object.assign(t,{busy:!0,readable:n.pipeThrough(new Sa(r.chunkSize)).pipeThrough(new va(o),{signal:g}),writable:s,options:Object.assign({},A),workerURI:u,transferStreams:a,terminate(){return new Promise(l=>{const{worker:B,busy:d}=t;B?(d?t.resolveTerminated=l:(B.terminate(),l()),t.interface=null):l()})},onTaskFinished(){const{resolveTerminated:l}=t;l&&(t.resolveTerminated=null,t.terminated=!0,t.worker.terminate(),l()),t.busy=!1,c(t)}}),(i&&Nr?ba:Hr)(t,r)}}class va extends TransformStream{constructor({onstart:t,onprogress:n,size:s,onend:A}){let r=0;super({async start(){t&&await Zn(t,s)},async transform(o,i){r+=o.length,n&&await Zn(n,r,s),i.enqueue(o)},async flush(){A&&await Zn(A,r)}})}}async function Zn(e,...t){try{await e(...t)}catch{}}function Hr(e,t){return{run:()=>Ma(e,t)}}function ba(e,t){const{baseURI:n,chunkSize:s}=t;let{wasmURI:A}=t;if(!e.interface){typeof A==Me&&(A=A());let r;try{r=Pa(e.workerURI,n,e)}catch{return Nr=!1,Hr(e,t)}Object.assign(e,{worker:r,interface:{run:()=>Ta(e,{chunkSize:s,wasmURI:A,baseURI:n})}})}return e.interface}async function Ma({options:e,readable:t,writable:n,onTaskFinished:s},A){let r;try{if(!e.useCompressionStream)try{await Ur(A)}catch{e.useCompressionStream=!0}r=new ya(e,A),await t.pipeThrough(r).pipeTo(n,{preventClose:!0,preventAbort:!0});const{signature:o,inputSize:i,outputSize:a}=r;return{signature:o,inputSize:i,outputSize:a}}catch(o){throw r&&(o.outputSize=r.outputSize),o}finally{s()}}async function Ta(e,t){let n,s;const A=new Promise((g,l)=>{n=g,s=l});Object.assign(e,{reader:null,writer:null,resolveResult:n,rejectResult:s,result:A});const{readable:r,options:o}=e,{writable:i,closed:a}=Ya(e.writable),u=Dn({type:wa,options:o,config:t,readable:r,writable:i},e);u||Object.assign(e,{reader:r.getReader(),writer:i.getWriter()});const c=await A;return u||await i.getWriter().close(),await a,c}function Ya(e){let t;const n=new Promise(A=>t=A);return{writable:new WritableStream({async write(A){const r=e.getWriter();await r.ready,await r.write(A),r.releaseLock()},close(){t()},abort(A){return e.getWriter().abort(A)}}),closed:n}}let hA=!0;function Pa(e,t,n){const s={type:"module"};let A,r;if(typeof e==Me&&(e=e()),e.startsWith("data:")||e.startsWith("blob:"))try{r=new Worker(e)}catch{r=new Worker(e,s)}else{try{A=new URL(e,t)}catch{A=e}r=new Worker(A,s)}return r.addEventListener(Ia,o=>Ra(o,n)),r}function Dn(e,{worker:t,writer:n,onTaskFinished:s,transferStreams:A}){try{const{value:r,readable:o,writable:i}=e,a=[];if(r&&(e.value=r,a.push(e.value.buffer)),A&&hA?(o&&a.push(o),i&&a.push(i)):e.readable=e.writable=null,a.length)try{return t.postMessage(e,a),!0}catch{hA=!1,e.readable=e.writable=null,t.postMessage(e)}else t.postMessage(e)}catch(r){throw n&&n.releaseLock(),s(),r}}async function Ra({data:e},t){const{type:n,value:s,messageId:A,result:r,error:o}=e,{reader:i,writer:a,resolveResult:u,rejectResult:c,onTaskFinished:g}=t;try{if(o){const{message:B,stack:d,code:f,name:h,outputSize:p}=o,E=new Error(B);Object.assign(E,{stack:d,code:f,name:h,outputSize:p}),l(E)}else{if(n==Fa){const{value:B,done:d}=await i.read();Dn({type:BA,value:B,done:d,messageId:A},t)}n==BA&&(await a.ready,await a.write(new Uint8Array(s)),Dn({type:xa,messageId:A},t)),n==EA&&l(null,r)}}catch(B){Dn({type:EA,messageId:A},t),l(B)}function l(B,d){B?c(B):u(d),a&&a.releaseLock(),g()}}let Se=[];const ts=[];let pA=0;async function Kr(e,t){const{options:n,config:s}=t,{transferStreams:A,useWebWorkers:r,useCompressionStream:o,compressed:i,signed:a,encrypted:u}=n,{workerURI:c,maxWorkers:g}=s;t.transferStreams=A||A===F;const l=!i&&!a&&!u&&!t.transferStreams;return t.useWebWorkers=!l&&(r||r===F&&s.useWebWorkers),t.workerURI=t.useWebWorkers&&c?c:F,n.useCompressionStream=o||o===F&&s.useCompressionStream,(await B()).run();async function B(){const f=Se.find(h=>!h.busy);if(f)return DA(f),new Xn(f,e,t,d);if(Se.length<g){const h={indexWorker:pA};return pA++,Se.push(h),new Xn(h,e,t,d)}else return new Promise(h=>ts.push({resolve:h,stream:e,workerOptions:t}))}function d(f){if(ts.length){const[{resolve:h,stream:p,workerOptions:E}]=ts.splice(0,1);h(new Xn(f,p,E,d))}else f.worker?(DA(f),Oa(f,t)):Se=Se.filter(h=>h!=f)}}function Oa(e,t){const{config:n}=t,{terminateWorkerTimeout:s}=n;Number.isFinite(s)&&s>=0&&(e.terminated?e.terminated=!1:e.terminateTimeout=setTimeout(async()=>{Se=Se.filter(A=>A!=e);try{await e.terminate()}catch{}},s))}function DA(e){const{terminateTimeout:t}=e;t&&(clearTimeout(t),e.terminateTimeout=null)}const ka="Writer iterator completed too soon",_a="text/plain",La="Content-Type",Ga=64*1024,Jr="writable";class Gs{constructor(){this.size=0}init(){this.initialized=!0}}class Wr extends Gs{get readable(){const t=this,{chunkSize:n=Ga}=t,s=new ReadableStream({start(){this.chunkOffset=0},async pull(A){const{offset:r=0,size:o,diskNumberStart:i}=s,{chunkOffset:a}=this,u=o===F?n:Math.min(n,o-a),c=await Dt(t,r+a,u,i);A.enqueue(c),a+n>o||o===F&&!c.length&&u?A.close():this.chunkOffset+=n}});return s}}class qr extends Wr{constructor(t){super(),Object.assign(this,{blob:t,size:t.size})}async readUint8Array(t,n){const s=this,A=t+n;let o=await(t||A<s.size?s.blob.slice(t,A):s.blob).arrayBuffer();return o.byteLength>n&&(o=o.slice(t,A)),new Uint8Array(o)}}class Na extends Gs{constructor(t){super();const n=this,s=new TransformStream,A=[];t&&A.push([La,t]),Object.defineProperty(n,Jr,{get(){return s.writable}}),n.blob=new Response(s.readable,{headers:A}).blob()}getData(){return this.blob}}class yt extends qr{constructor(t){super(new Blob([t],{type:_a}))}}class Ua extends Wr{constructor(t){super(),this.readers=t}async init(){const t=this,{readers:n}=t;t.lastDiskNumber=0,t.lastDiskOffset=0,await Promise.all(n.map(async(s,A)=>{await s.init(),A!=n.length-1&&(t.lastDiskOffset+=s.size),t.size+=s.size})),super.init()}async readUint8Array(t,n,s=0){const A=this,{readers:r}=this;let o,i=s;i==-1&&(i=r.length-1);let a=t;for(;r[i]&&a>=r[i].size;)a-=r[i].size,i++;const u=r[i];if(u){const c=u.size;if(a+n<=c)o=await Dt(u,a,n);else{const g=c-a;o=new Uint8Array(n);const l=await Dt(u,a,g);o.set(l,0);const B=await A.readUint8Array(t+g,n-g,s);o.set(B,g),l.length+B.length<n&&(o=o.subarray(0,l.length+B.length))}}else o=new Uint8Array;return A.lastDiskNumber=Math.max(i,A.lastDiskNumber),o}}class CA extends Gs{constructor(t,n=4294967295){super();const s=this;Object.assign(s,{diskNumber:0,diskOffset:0,size:0,maxSize:n,availableSize:n});let A,r,o;const i=new WritableStream({async write(c){const{availableSize:g}=s;if(o)c.length>=g?(await a(c.subarray(0,g)),await u(),s.diskOffset+=A.size,s.diskNumber++,o=null,await this.write(c.subarray(g))):await a(c);else{const{value:l,done:B}=await t.next();if(B&&!l)throw new Error(ka);A=l,A.size=0,A.maxSize&&(s.maxSize=A.maxSize),s.availableSize=s.maxSize,await De(A),r=l.writable,o=r.getWriter(),await this.write(c)}},async close(){await o.ready,await u()}});Object.defineProperty(s,Jr,{get(){return i}});async function a(c){const g=c.length;g&&(await o.ready,await o.write(c),A.size+=g,s.size+=g,s.availableSize-=g)}async function u(){await o.close()}}}class Ns{constructor(t){return Array.isArray(t)&&(t=new Ua(t)),t instanceof ReadableStream&&(t={readable:t}),t}}class zr{constructor(t){return t.writable===F&&typeof t.next==Me&&(t=new CA(t)),t instanceof WritableStream&&(t={writable:t}),t.size===F&&(t.size=0),t instanceof CA||Object.assign(t,{diskNumber:0,diskOffset:0,availableSize:1/0,maxSize:1/0}),t}}async function De(e,t){if(e.init&&!e.initialized)await e.init(t);else return Promise.resolve()}function Dt(e,t,n,s){return e.readUint8Array(t,n,s)}const Vr="\0☺☻♥♦♣♠•◘○◙♂♀♪♫☼►◄↕‼¶§▬↨↑↓→←∟↔▲▼ !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~⌂ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜ¢£¥₧ƒáíóúñѪº¿⌐¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ ".split(""),Ha=Vr.length==256;function Ka(e){if(Ha){let t="";for(let n=0;n<e.length;n++)t+=Vr[e[n]];return t}else return new TextDecoder().decode(e)}function Cn(e,t){return t&&t.trim().toLowerCase()=="cp437"?Ka(e):new TextDecoder(t).decode(e)}const jr="filename",$r="rawFilename",Us="comment",Xr="rawComment",Hs="uncompressedSize",Zr="compressedSize",to="offset",eo="diskNumberStart",bn="lastModDate",Is="rawLastModDate",Ks="lastAccessDate",Ja="rawLastAccessDate",Js="creationDate",no="rawCreationDate",so="internalFileAttributes",Ao="externalFileAttributes",ro="msdosAttributesRaw",oo="msdosAttributes",io="msDosCompatible",Ws="zip64",ao="encrypted",uo="version",co="versionMadeBy",go="zipCrypto",mn="directory",lo="executable",fo="compressionMethod",Bo="signature",Eo="extraField",Wa="extraFieldInfoZip",qa="extraFieldUnix",ho="uid",po="gid",Do="unixMode",Co="setuid",mo="setgid",Io="sticky",za="bitFlag",Va="filenameUTF8",ja="commentUTF8",$a="rawExtraField",Xa="extraFieldZip64",Za="extraFieldUnicodePath",tu="extraFieldUnicodeComment",eu="extraFieldAES",nu="extraFieldNTFS",su="extraFieldExtendedTimestamp",Au=[jr,$r,Hs,Zr,bn,Is,Us,Xr,Ks,Js,no,to,eo,so,Ao,ro,oo,io,Ws,ao,uo,co,go,mn,lo,fo,Bo,Eo,qa,Wa,ho,po,Do,Co,mo,Io,za,Va,ja,$a,Xa,Za,tu,eu,nu,su];class Mn{constructor(t){Au.forEach(n=>this[n]=t[n])}}const ru="filenameEncoding",ou="commentEncoding",iu="decodeText",au="extractPrependedData",uu="extractAppendedData",wo="password",Fo="rawPassword",xo="passThrough",yo="signal",cu="checkPasswordOnly",gu="checkOverlappingEntryOnly",lu="checkOverlappingEntry",du="checkSignature",So="useWebWorkers",Qo="useCompressionStream",fu="transferStreams",vo="preventClose",Bu="encryptionStrength",Eu="extendedTimestamp",hu="keepOrder",pu="level",Du="bufferedWrite",Cu="dataDescriptorSignature",mu="useUnicodeFileNames",Iu="dataDescriptor",bo="supportZip64SplitFile",wu="encodeText",mA="offset",Mo="usdz",Fu="unixExtraFieldType",es="File format is not recognized",xu="End of central directory not found",yu="End of Zip64 central directory locator not found",Su="Central directory header not found",Qu="Local file header not found",vu="Zip64 extra field not found",bu="File contains encrypted entry",Mu="Encryption method not supported",IA="Compression method not supported",wA="Split zip file",Tu="Overlapping entry found",FA="utf-8",Yu="UTF8",xA="cp437",Pu=[[Hs,nt],[Zr,nt],[to,nt],[eo,q]],Ru={[q]:{getValue:tt,bytes:4},[nt]:{getValue:Ge,bytes:8}};class Ou{constructor(t,n={}){Object.assign(this,{reader:new Ns(t),options:n,config:pr(),readRanges:[]})}async*getEntriesGenerator(t={}){const n=this;let{reader:s}=n;const{config:A}=n;if(await De(s),(s.size===F||!s.readUint8Array)&&(s=new qr(await new Response(s.readable).blob()),await De(s)),s.size<ie)throw new Error(es);s.chunkSize=Dr(A);const r=await Hu(s,rr,s.size,ie,q*16);if(!r){const Y=await Dt(s,0,4),Q=et(Y);throw tt(Q)==Ps?new Error(wA):new Error(xu)}const o=et(r);let i=tt(o,12),a=tt(o,16);const u=r.offset,c=Et(o,20),g=u+ie+c;let l=Et(o,4);const B=s.lastDiskNumber||0;let d=Et(o,6),f=Et(o,8),h=0,p=0;if(a==nt||i==nt||f==q||d==q){const Y=await Dt(s,r.offset-je,je),Q=et(Y);if(tt(Q,0)==or){a=Ge(Q,8);let _=await Dt(s,a,$e,-1),b=et(_);const M=r.offset-je-$e;if(tt(b,0)!=ds&&a!=M){const v=a;a=M,a>v&&(h=a-v),_=await Dt(s,a,$e,-1),b=et(_)}if(tt(b,0)!=ds)throw new Error(yu);l==q&&(l=tt(b,16)),d==q&&(d=tt(b,20)),f==q&&(f=Ge(b,32)),i==nt&&(i=Ge(b,40)),a-=i}}if(a>=s.size&&(h=s.size-a-i-ie,a=s.size-i-ie),B!=l)throw new Error(wA);if(a<0)throw new Error(es);let E=0,C=await Dt(s,a,i,d),I=et(C);if(i){const Y=r.offset-i;if(tt(I,E)!=ls&&a!=Y){const Q=a;a=Y,a>Q&&(h+=a-Q),C=await Dt(s,a,i,d),I=et(C)}}const w=r.offset-a-(s.lastDiskOffset||0);if(i!=w&&w>=0&&(i=w,C=await Dt(s,a,i,d),I=et(C)),a<0||a>=s.size)throw new Error(es);const m=ht(n,t,ru),x=ht(n,t,ou);for(let Y=0;Y<f;Y++){const Q=new ku(s,A,n.options);if(tt(I,E)!=ls)throw new Error(Su);To(Q,I,E+6);const _=!!Q.bitFlag.languageEncodingFlag,b=E+46,M=b+Q.filenameLength,v=M+Q.extraFieldLength,W=Et(I,E+4),z=W>>8==0,gt=W>>8==3,lt=C.subarray(b,M),Ft=Et(I,E+32),Ct=v+Ft,vt=C.subarray(v,Ct),j=_,rt=_,mt=tt(I,E+38),H=mt&Zt,$={readOnly:!!(H&hs),hidden:!!(H&ps),system:!!(H&Ds),directory:!!(H&Fn),archive:!!(H&Cs)},K=tt(I,E+42)+h,S=ht(n,t,iu)||Cn,It=j?FA:m||xA,Ot=rt?FA:x||xA;let xt=S(lt,It);xt===F&&(xt=Cn(lt,It));let wt=S(vt,Ot);wt===F&&(wt=Cn(vt,Ot)),Object.assign(Q,{versionMadeBy:W,msDosCompatible:z,compressedSize:0,uncompressedSize:0,commentLength:Ft,offset:K,diskNumberStart:Et(I,E+34),internalFileAttributes:Et(I,E+36),externalFileAttributes:mt,msdosAttributesRaw:H,msdosAttributes:$,rawFilename:lt,filenameUTF8:j,commentUTF8:rt,rawExtraField:C.subarray(M,v),rawComment:vt,filename:xt,comment:wt}),p=Math.max(K,p),Yo(Q,Q,I,E+6);const dt=Q.externalFileAttributes>>16&q;Q.unixMode===F&&(dt&(En|Ze|Xe))!=0&&(Q.unixMode=dt);const ft=!!(Q.unixMode&xn),Jt=!!(Q.unixMode&yn),kt=!!(Q.unixMode&Sn),bt=Q.unixMode!==F?(Q.unixMode&Ze)!=0:gt&&(dt&Ze)!=0,zt=Q.unixMode!==F&&(Q.unixMode&rA)==Xe,me=(dt&rA)==Xe;Object.assign(Q,{setuid:ft,setgid:Jt,sticky:kt,unixExternalUpper:dt,internalFileAttribute:Q.internalFileAttributes,externalFileAttribute:Q.externalFileAttributes,executable:bt,directory:zt||me||z&&$.directory||xt.endsWith(hn)&&!Q.uncompressedSize,zipCrypto:Q.encrypted&&!Q.extraFieldAES});const Vt=new Mn(Q);Vt.getData=(Ye,se)=>Q.getData(Ye,Vt,n.readRanges,se),Vt.arrayBuffer=async Ye=>{const se=new TransformStream,[Je]=await Promise.all([new Response(se.readable).arrayBuffer(),Q.getData(se,Vt,n.readRanges,Ye)]);return Je},E=Ct;const{onprogress:Ie}=t;if(Ie)try{await Ie(Y+1,f,new Mn(Q))}catch{}yield Vt}const y=ht(n,t,au),G=ht(n,t,uu);return y&&(n.prependedData=p>0?await Dt(s,0,p):new Uint8Array),n.comment=c?await Dt(s,u+ie,c):new Uint8Array,G&&(n.appendedData=g<s.size?await Dt(s,g,s.size-g):new Uint8Array),!0}async getEntries(t={}){const n=[];for await(const s of this.getEntriesGenerator(t))n.push(s);return n}async close(){}}class ku{constructor(t,n,s){Object.assign(this,{reader:t,config:n,options:s})}async getData(t,n,s,A={}){const r=this,{reader:o,offset:i,diskNumberStart:a,extraFieldAES:u,extraFieldZip64:c,compressionMethod:g,config:l,bitFlag:B,signature:d,rawLastModDate:f,uncompressedSize:h,compressedSize:p}=r,{dataDescriptor:E}=B,C=n.localDirectory={},I=await Dt(o,i,Qe,a),w=et(I);let m=ht(r,A,wo),x=ht(r,A,Fo);const y=ht(r,A,xo);if(m=m&&m.length&&m,x=x&&x.length&&x,u&&u.originalCompressionMethod!=nr)throw new Error(IA);if(g!=er&&g!=Ys&&g!=gs&&!y)throw new Error(IA);if(tt(w,0)!=sr)throw new Error(Qu);To(C,w,4);const{extraFieldLength:G,filenameLength:Y,lastAccessDate:Q,creationDate:_}=C;C.rawExtraField=G?await Dt(o,i+Qe+Y,G,a):new Uint8Array,Yo(r,C,w,4,!0),Object.assign(n,{lastAccessDate:Q,creationDate:_});const b=r.encrypted&&C.encrypted&&!y,M=b&&!u;if(y||(n.zipCrypto=M),b){if(!M&&u.strength===F)throw new Error(Mu);if(!m&&!x)throw new Error(bu)}const v=i+Qe+Y+G,W=p,z=o.readable;Object.assign(z,{diskNumberStart:a,offset:v,size:W});const gt=ht(r,A,yo),lt=ht(r,A,cu);let Ft=ht(r,A,lu);const Ct=ht(r,A,gu);Ct&&(Ft=!0);const{onstart:vt,onprogress:j,onend:rt}=A,mt=g==gs;let H=ht(r,A,Qo);mt&&(H=!1);const $={options:{codecType:Gr,password:m,rawPassword:x,zipCrypto:M,encryptionStrength:u&&u.strength,signed:ht(r,A,du)&&!y,passwordVerification:M&&(E?f>>>8&Zt:d>>>24&Zt),outputSize:y?p:h,signature:d,compressed:g!=0&&!y,encrypted:r.encrypted&&!y,useWebWorkers:ht(r,A,So),useCompressionStream:H,transferStreams:ht(r,A,fu),deflate64:mt,checkPasswordOnly:lt},config:l,streamOptions:{signal:gt,size:W,onstart:vt,onprogress:j,onend:rt}};Ft&&await Uu({reader:o,fileEntry:n,offset:i,diskNumberStart:a,signature:d,compressedSize:p,uncompressedSize:h,dataOffset:v,dataDescriptor:E||C.bitFlag.dataDescriptor,extraFieldZip64:c||C.extraFieldZip64,readRanges:s});let K;try{if(!Ct){lt&&(t=new WritableStream),t=new zr(t),await De(t,y?p:h),{writable:K}=t;const{outputSize:S}=await Kr({readable:z,writable:K},$);if(t.size+=S,S!=(y?p:h))throw new Error(Or)}}catch(S){if(S.outputSize!==F&&(t.size+=S.outputSize),!lt||S.message!=ks)throw S}finally{!ht(r,A,vo)&&K&&!K.locked&&await K.getWriter().close()}return lt||Ct?F:t.getData?t.getData():K}}function To(e,t,n){const s=e.rawBitFlag=Et(t,n+2),A=(s&fs)==fs,r=tt(t,n+6);Object.assign(e,{encrypted:A,version:Et(t,n),bitFlag:{level:(s&Hi)>>1,dataDescriptor:(s&Bs)==Bs,languageEncodingFlag:(s&Es)==Es},rawLastModDate:r,lastModDate:Ku(r),filenameLength:Et(t,n+22),extraFieldLength:Et(t,n+24)})}function Yo(e,t,n,s,A){const{rawExtraField:r}=t,o=t.extraField=new Map,i=et(new Uint8Array(r));let a=0;try{for(;a<r.length;){const E=Et(i,a),C=Et(i,a+2);o.set(E,{type:E,data:r.slice(a+4,a+4+C)}),a+=4+C}}catch{}const u=Et(n,s+4);Object.assign(t,{signature:tt(n,s+Os),compressedSize:tt(n,s+Ue),uncompressedSize:tt(n,s+He)});const c=o.get(ur);c&&(_u(c,t),t.extraFieldZip64=c);const g=o.get(Ni);g&&(yA(g,jr,$r,t,e),t.extraFieldUnicodePath=g);const l=o.get(Ui);l&&(yA(l,Us,Xr,t,e),t.extraFieldUnicodeComment=l);const B=o.get(cr);B?(Lu(B,t,u),t.extraFieldAES=B):t.compressionMethod=u;const d=o.get(gr);d&&(Gu(d,t),t.extraFieldNTFS=d);const f=o.get(Br);if(f)SA(f,t,!1),t.extraFieldUnix=f;else{const E=o.get(fr);E&&(SA(E,t,!0),t.extraFieldInfoZip=E)}const h=o.get(Rs);h&&(Nu(h,t,A),t.extraFieldExtendedTimestamp=h);const p=o.get(dr);p&&(t.extraFieldUSDZ=p)}function _u(e,t){t.zip64=!0;const n=et(e.data),s=Pu.filter(([A,r])=>t[A]==r);for(let A=0,r=0;A<s.length;A++){const[o,i]=s[A];if(t[o]==i){const a=Ru[i];t[o]=e[o]=a.getValue(n,r),r+=a.bytes}else if(e[o])throw new Error(vu)}}function yA(e,t,n,s,A){const r=et(e.data),o=new Qn;o.append(A[n]);const i=et(new Uint8Array(4));i.setUint32(0,o.get(),!0);const a=tt(r,1);Object.assign(e,{version:he(r,0),[t]:Cn(e.data.subarray(5)),valid:!A.bitFlag.languageEncodingFlag&&a==tt(i,0)}),e.valid&&(s[t]=e[t],s[t+Yu]=!0)}function Lu(e,t,n){const s=et(e.data),A=he(s,4);Object.assign(e,{vendorVersion:he(s,0),vendorId:he(s,2),strength:A,originalCompressionMethod:n,compressionMethod:Et(s,5)}),t.compressionMethod=e.compressionMethod}function Gu(e,t){const n=et(e.data);let s=4,A;try{for(;s<e.data.length&&!A;){const r=Et(n,s),o=Et(n,s+2);r==lr&&(A=e.data.slice(s+4,s+4+o)),s+=4+o}}catch{}try{if(A&&A.length==24){const r=et(A),o=r.getBigUint64(0,!0),i=r.getBigUint64(8,!0),a=r.getBigUint64(16,!0);Object.assign(e,{rawLastModDate:o,rawLastAccessDate:i,rawCreationDate:a});const u=ns(o),c=ns(i),g=ns(a),l={lastModDate:u,lastAccessDate:c,creationDate:g};Object.assign(e,l),Object.assign(t,l)}}catch{}}function SA(e,t,n){try{const s=et(new Uint8Array(e.data));let A=0;const r=he(s,A++),o=he(s,A++),i=e.data.subarray(A,A+o);A+=o;const a=QA(i),u=he(s,A++),c=e.data.subarray(A,A+u);A+=u;const g=QA(c);let l=F;if(!n&&A+2<=e.data.length){const B=e.data;l=new DataView(B.buffer,B.byteOffset+A,2).getUint16(0,!0)}Object.assign(e,{version:r,uid:a,gid:g,unixMode:l}),a!==F&&(t.uid=a),g!==F&&(t.gid=g),l!==F&&(t.unixMode=l)}catch{}}function QA(e){const t=new Uint8Array(4);return t.set(e,0),new DataView(t.buffer,t.byteOffset,4).getUint32(0,!0)}function Nu(e,t,n){const s=et(e.data),A=he(s,0),r=[],o=[];n?((A&1)==1&&(r.push(bn),o.push(Is)),(A&2)==2&&(r.push(Ks),o.push(Ja)),(A&4)==4&&(r.push(Js),o.push(no))):e.data.length>=5&&(r.push(bn),o.push(Is));let i=1;r.forEach((a,u)=>{if(e.data.length>=i+4){const c=tt(s,i);t[a]=e[a]=new Date(c*1e3);const g=o[u];e[g]=c}i+=4})}async function Uu({reader:e,fileEntry:t,offset:n,diskNumberStart:s,signature:A,compressedSize:r,uncompressedSize:o,dataOffset:i,dataDescriptor:a,extraFieldZip64:u,readRanges:c}){let g=0;if(s)for(let d=0;d<s;d++){const f=e.readers[d];g+=f.size}let l=0;if(a&&(u?l=ar:l=ir),l){const d=await Dt(e,i+r,l+wn,s);if(tt(et(d),0)==Ar){const h=tt(et(d),4);let p,E;u?(p=Ge(et(d),8),E=Ge(et(d),16)):(p=tt(et(d),8),E=tt(et(d),12)),(t.encrypted&&!t.zipCrypto||h==A)&&p==r&&E==o&&(l+=wn)}}const B={start:g+n,end:g+i+r+l,fileEntry:t};for(const d of c)if(d.fileEntry!=t&&B.start>=d.start&&B.start<d.end){const f=new Error(Tu);throw f.overlappingEntry=d.fileEntry,f}c.push(B)}async function Hu(e,t,n,s,A){const r=new Uint8Array(4),o=et(r);Ju(o,0,t);const i=s+A;return await a(s)||await a(Math.min(i,n));async function a(u){const c=n-u,g=await Dt(e,c,u);for(let l=g.length-s;l>=0;l--)if(g[l]==r[0]&&g[l+1]==r[1]&&g[l+2]==r[2]&&g[l+3]==r[3])return{offset:c+l,buffer:g.slice(l,l+s).buffer}}}function ht(e,t,n){return t[n]===F?e.options[n]:t[n]}function Ku(e){const t=(e&4294901760)>>16,n=e&q;try{return new Date(1980+((t&65024)>>9),((t&480)>>5)-1,t&31,(n&63488)>>11,(n&2016)>>5,(n&31)*2,0)}catch{}}function ns(e){return new Date(Number(e/BigInt(1e4)-BigInt(116444736e5)))}function he(e,t){return e.getUint8(t)}function Et(e,t){return e.getUint16(t,!0)}function tt(e,t){return e.getUint32(t,!0)}function Ge(e,t){return Number(e.getBigUint64(t,!0))}function Ju(e,t,n){e.setUint32(t,n,!0)}function et(e){return new DataView(e.buffer)}const Wu="File already exists",qu="Zip file comment exceeds 64KB",zu="File entry comment exceeds 64KB",Vu="File entry name exceeds 64KB",vA="Version exceeds 65535",ju="The strength must equal 1, 2, or 3",$u="Extra field type exceeds 65535",Xu="Extra field data exceeds 64KB",qs="Zip64 is not supported (make sure 'keepOrder' is set to 'true')",Zu="Undefined uncompressed size",tc="Zip file not empty",ec="Invalid uid (must be integer 0..2^32-1)",nc="Invalid gid (must be integer 0..2^32-1)",sc="Invalid UNIX mode (must be integer 0..65535)",Ac="Invalid unixExtraFieldType (must be 'infozip' or 'unix')",rc="Invalid msdosAttributesRaw (must be integer 0..255)",oc="Invalid msdosAttributes (must be an object with boolean flags)",bA=new Uint8Array([7,0,2,0,65,69,3,0,0]),Po="infozip",Ro="unix";let ss=0;const MA=[];class ic{constructor(t,n={}){t=new zr(t);const s=t.availableSize!==F&&t.availableSize>0&&t.availableSize!==1/0&&t.maxSize!==F&&t.maxSize>0&&t.maxSize!==1/0;Object.assign(this,{writer:t,addSplitZipSignature:s,options:n,config:pr(),files:new Map,filenames:new Set,offset:n[mA]===F?t.size||t.writable.size||0:n[mA],pendingEntriesSize:0,pendingAddFileCalls:new Set,bufferedWrites:0})}async prependZip(t){if(this.filenames.size)throw new Error(tc);t=new Ns(t);const n=new Ou(t.readable),s=await n.getEntries();await n.close(),await t.readable.pipeTo(this.writer.writable,{preventClose:!0,preventAbort:!0}),this.writer.size=this.offset=t.size,this.filenames=new Set(s.map(A=>A.filename)),this.files=new Map(s.map(A=>{const{version:r,compressionMethod:o,lastModDate:i,lastAccessDate:a,creationDate:u,rawFilename:c,bitFlag:g,encrypted:l,uncompressedSize:B,compressedSize:d,diskOffset:f,diskNumber:h,zip64:p}=A;let{rawExtraFieldZip64:E,rawExtraFieldAES:C,rawExtraFieldExtendedTimestamp:I,rawExtraFieldNTFS:w,rawExtraFieldUnix:m,rawExtraField:x}=A;const{level:y,languageEncodingFlag:G,dataDescriptor:Y}=g;E=E||new Uint8Array,C=C||new Uint8Array,I=I||new Uint8Array,w=w||new Uint8Array,m=A.rawExtraFieldUnix||new Uint8Array,x=x||new Uint8Array;const Q=k(E,C,I,w,m,x),_=p&&B>nt,b=p&&d>nt,{headerArray:M,headerView:v}=Oo({version:r,bitFlag:ko(y,G,Y,l,o),compressionMethod:o,uncompressedSize:B,compressedSize:d,lastModDate:i,rawFilename:c,zip64CompressedSize:b,zip64UncompressedSize:_,extraFieldLength:Q});return Object.assign(A,{zip64UncompressedSize:_,zip64CompressedSize:b,zip64Offset:p&&this.offset-f>nt,zip64DiskNumberStart:p&&h>q,rawExtraFieldZip64:E,rawExtraFieldAES:C,rawExtraFieldExtendedTimestamp:I,rawExtraFieldNTFS:w,rawExtraFieldUnix:m,rawExtraField:x,extendedTimestamp:I.length>0||w.length>0,extraFieldExtendedTimestampFlag:1+(a?2:0)+(u?4:0),headerArray:M,headerView:v}),[A.filename,A]}))}async add(t="",n,s={}){const A=this,{pendingAddFileCalls:r,config:o}=A;ss<o.maxWorkers?ss++:await new Promise(a=>MA.push(a));let i;try{if(t=t.trim(),A.filenames.has(t))throw new Error(Wu);return A.filenames.add(t),i=ac(A,t,n,s),r.add(i),await i}catch(a){throw A.filenames.delete(t),a}finally{r.delete(i);const a=MA.shift();a?a():ss--}}remove(t){const{filenames:n,files:s}=this;if(typeof t=="string"&&(t=s.get(t)),t&&t.filename!==F){const{filename:A}=t;if(n.has(A)&&s.has(A))return n.delete(A),s.delete(A),!0}return!1}async close(t=new Uint8Array,n={}){const s=this,{pendingAddFileCalls:A,writer:r}=this,{writable:o}=r;for(;A.size;)await Promise.allSettled(Array.from(A));return await hc(s,t,n),P(s,n,vo)||await o.getWriter().close(),r.getData?r.getData():o}}async function ac(e,t,n,s){t=t.trim();let A=P(e,s,io),r=P(e,s,co,A?20:768);const o=P(e,s,lo),i=P(e,s,ho),a=P(e,s,po);let u=P(e,s,Do);const c=P(e,s,Fu);let g=P(e,s,Co),l=P(e,s,mo),B=P(e,s,Io);if(i!==F&&(i<0||i>nt))throw new Error(ec);if(a!==F&&(a<0||a>nt))throw new Error(nc);if(u!==F&&(u<0||u>q))throw new Error(sc);if(c!==F&&c!==Po&&c!==Ro)throw new Error(Ac);let d=P(e,s,ro),f=P(e,s,oo);const h=i!==F||a!==F||u!==F||c,p=d!==F||f!==F;if(h?(A=!1,r=r&q|768):p&&(A=!0,r=r&Zt),d!==F&&(d<0||d>Zt))throw new Error(rc);if(f&&typeof f!==zi)throw new Error(oc);if(r>q)throw new Error(vA);let E=P(e,s,Ao,0);!s[mn]&&t.endsWith(hn)&&(s[mn]=!0);const C=P(e,s,mn);C?(t.endsWith(hn)||(t+=hn),E===0&&(E=Fn,A||(E|=(Xe|Ze|En)<<16))):!A&&E===0&&(o?E=(Ze|En)<<16:E=En<<16);let I;A||(I=E>>16&q,u=u===F?I:u&q,g?u|=xn:g=!!(u&xn),l?u|=yn:l=!!(u&yn),B?u|=Sn:B=!!(u&Sn),C&&(u|=Xe),E=(u&q)<<16|E&Zt),{msdosAttributesRaw:d,msdosAttributes:f}=dc(d,f),p&&(E=E&nt|d&Zt);const w=P(e,s,wu,pn);let m=w(t);if(m===F&&(m=pn(t)),k(m)>q)throw new Error(Vu);const x=s[Us]||"";let y=w(x);if(y===F&&(y=pn(x)),k(y)>q)throw new Error(zu);const G=P(e,s,uo,qi);if(G>q)throw new Error(vA);const Y=P(e,s,bn,new Date),Q=P(e,s,Ks),_=P(e,s,Js),b=P(e,s,so,0),M=P(e,s,xo);let v,W;M||(v=P(e,s,wo),W=P(e,s,Fo));const z=P(e,s,Bu,3),gt=P(e,s,go),lt=P(e,s,Eu,!0),Ft=P(e,s,hu,!0),Ct=P(e,s,So),vt=P(e,s,Du),j=P(e,s,Cu,!1),rt=P(e,s,yo),mt=P(e,s,mu,!0),H=P(e,s,fo);let $=P(e,s,pu),K=P(e,s,Qo),S=P(e,s,Iu);vt&&S===F&&(S=!1),(S===F||gt)&&(S=!0),$!==F&&$!=6&&(K=!1),!K&&e.config.CompressionStream===F&&e.config.CompressionStreamZlib===F&&($=0);let It=P(e,s,Ws);if(!gt&&(v!==F||W!==F)&&!(z>=1&&z<=3))throw new Error(ju);let Ot=new Uint8Array;const xt=s[Eo];if(xt){let Re=0,Ae=0;xt.forEach(_t=>Re+=4+k(_t)),Ot=new Uint8Array(Re),xt.forEach((_t,ln)=>{if(ln>q)throw new Error($u);if(k(_t)>q)throw new Error(Xu);V(Ot,new Uint16Array([ln]),Ae),V(Ot,new Uint16Array([k(_t)]),Ae+2),V(Ot,_t,Ae+4),Ae+=4+k(_t)})}let wt=0,dt=0,ft=0;if(M&&(ft=s[Hs],ft===F))throw new Error(Zu);const Jt=It===!0;n&&(n=new Ns(n),await De(n),M?(s.uncompressedSize=ft,wt=PA(ft)):n.size===F?(S=!0,(It||It===F)&&(It=!0,ft=wt=nt+1)):(s.uncompressedSize=ft=n.size,wt=PA(ft)));const{diskOffset:kt,diskNumber:bt,maxSize:zt}=e.writer,me=Jt||ft>nt,Vt=Jt||wt>nt,Ie=Jt||e.offset+e.pendingEntriesSize-kt>nt,se=P(e,s,bo,!0)&&Jt||bt+Math.ceil(e.pendingEntriesSize/zt)>q;if(Ie||me||Vt||se){if(It===!1||!Ft)throw new Error(qs);It=!0}It=It||!1;const Je=P(e,s,ao);s=Object.assign({},s,{rawFilename:m,rawComment:y,version:G,versionMadeBy:r,lastModDate:Y,lastAccessDate:Q,creationDate:_,rawExtraField:Ot,zip64:It,zip64UncompressedSize:me,zip64CompressedSize:Vt,zip64Offset:Ie,zip64DiskNumberStart:se,password:v,rawPassword:W,level:$,useWebWorkers:Ct,encryptionStrength:z,extendedTimestamp:lt,zipCrypto:gt,bufferedWrite:vt,keepOrder:Ft,useUnicodeFileNames:mt,dataDescriptor:S,dataDescriptorSignature:j,signal:rt,msDosCompatible:A,internalFileAttribute:b,internalFileAttributes:b,externalFileAttribute:E,externalFileAttributes:E,useCompressionStream:K,passThrough:M,encrypted:!!(v&&k(v)||W&&k(W))||M&&Je,signature:s[Bo],compressionMethod:H,uncompressedSize:ft,offset:e.offset-kt,diskNumberStart:bt,uid:i,gid:a,setuid:g,setgid:l,sticky:B,unixMode:u,msdosAttributesRaw:d,msdosAttributes:f,unixExternalUpper:I});const cn=gc(s),gn=fc(s),le=k(cn.localHeaderArray,gn.dataDescriptorArray);dt=le+wt,e.options[Mo]&&(dt+=dt+64),e.pendingEntriesSize+=dt;let Pe;try{Pe=await uc(e,t,n,{headerInfo:cn,dataDescriptorInfo:gn,metadataSize:le},s)}finally{e.pendingEntriesSize-=dt}return Object.assign(Pe,{name:t,comment:x,extraField:xt}),new Mn(Pe)}async function uc(e,t,n,s,A){const{files:r,writer:o}=e,{keepOrder:i,dataDescriptor:a,signal:u}=A,{headerInfo:c}=s,g=e.options[Mo],l=Array.from(r.values()).pop();let B={},d,f,h,p,E,C,I;r.set(t,B);try{let y;i&&(y=l&&l.lock,w()),(A.bufferedWrite||e.writerLocked||e.bufferedWrites&&i||!a)&&!g?(C=new TransformStream,C.size=0,d=!0,e.bufferedWrites++,await De(o)):(C=o,await m()),await De(C);const{writable:G,diskOffset:Y}=o;if(e.addSplitZipSignature){delete e.addSplitZipSignature;const v=new Uint8Array(4),W=ct(v);L(W,0,Ps),await ue(o,v),e.offset+=4}g&&lc(s,e.offset-Y);const{localHeaderView:Q,localHeaderArray:_}=c;d||(await y,await x(G));const{diskNumber:b}=o;E=!0,B.diskNumberStart=b,d?I=new Response(C.readable).blob():await ue(C,_),B=await cc(n,C,B,s,e.config,A);const{zip64:M}=B;if(E=!1,r.set(t,B),B.filename=t,d){const[v]=await Promise.all([I,C.writable.getWriter().close(),y]);await m(),p=!0,B.diskNumberStart=o.diskNumber,B.offset=e.offset-o.diskOffset,M&&YA(B),Ec(B,Q,A),await x(G),await ue(o,_),await v.stream().pipeTo(G,{preventClose:!0,preventAbort:!0,signal:u}),o.size+=C.size,p=!1}else B.offset=e.offset-Y,M&&YA(B);if(B.offset>nt&&!M)throw new Error(qs);return e.offset+=B.size,B}catch(y){if(d&&p||!d&&E){if(e.hasCorruptedEntries=!0,y)try{y.corruptedEntry=!0}catch{}d?e.offset+=C.size:e.offset=C.size}throw r.delete(t),y}finally{d&&e.bufferedWrites--,h&&h(),f&&f()}function w(){B.lock=new Promise(y=>h=y)}async function m(){e.writerLocked=!0;const{lockWriter:y}=e;e.lockWriter=new Promise(G=>f=()=>{e.writerLocked=!1,G()}),await y}async function x(y){k(c.localHeaderArray)>o.availableSize&&(o.availableSize=0,await ue(y,new Uint8Array))}}async function cc(e,t,{diskNumberStart:n,lock:s},A,r,o){const{headerInfo:i,dataDescriptorInfo:a,metadataSize:u}=A,{headerArray:c,headerView:g,lastModDate:l,rawLastModDate:B,encrypted:d,compressed:f,version:h,compressionMethod:p,rawExtraFieldZip64:E,localExtraFieldZip64Length:C,rawExtraFieldExtendedTimestamp:I,extraFieldExtendedTimestampFlag:w,rawExtraFieldNTFS:m,rawExtraFieldUnix:x,rawExtraFieldAES:y}=i,{dataDescriptorArray:G}=a,{rawFilename:Y,lastAccessDate:Q,creationDate:_,password:b,rawPassword:M,level:v,zip64:W,zip64UncompressedSize:z,zip64CompressedSize:gt,zip64Offset:lt,zip64DiskNumberStart:Ft,zipCrypto:Ct,dataDescriptor:vt,directory:j,executable:rt,versionMadeBy:mt,rawComment:H,rawExtraField:$,useWebWorkers:K,onstart:S,onprogress:It,onend:Ot,signal:xt,encryptionStrength:wt,extendedTimestamp:dt,msDosCompatible:ft,internalFileAttributes:Jt,externalFileAttributes:kt,uid:bt,gid:zt,unixMode:me,setuid:Vt,setgid:Ie,sticky:Ye,unixExternalUpper:se,msdosAttributesRaw:Je,msdosAttributes:cn,useCompressionStream:gn,passThrough:le}=o,Pe={lock:s,versionMadeBy:mt,zip64:W,directory:!!j,executable:!!rt,filenameUTF8:!0,rawFilename:Y,commentUTF8:!0,rawComment:H,rawExtraFieldZip64:E,localExtraFieldZip64Length:C,rawExtraFieldExtendedTimestamp:I,rawExtraFieldNTFS:m,rawExtraFieldUnix:x,rawExtraFieldAES:y,rawExtraField:$,extendedTimestamp:dt,msDosCompatible:ft,internalFileAttributes:Jt,externalFileAttributes:kt,diskNumberStart:n,uid:bt,gid:zt,unixMode:me,setuid:Vt,setgid:Ie,sticky:Ye,unixExternalUpper:se,msdosAttributesRaw:Je,msdosAttributes:cn};let{signature:Re,uncompressedSize:Ae}=o,_t=0;le||(Ae=0);const{writable:ln}=t;if(e){e.chunkSize=Dr(r);const ii=e.readable,ai=e.size,ui={options:{codecType:Lr,level:v,rawPassword:M,password:b,encryptionStrength:wt,zipCrypto:d&&Ct,passwordVerification:d&&Ct&&B>>8&Zt,signed:!le,compressed:f&&!le,encrypted:d&&!le,useWebWorkers:K,useCompressionStream:gn,transferStreams:!1},config:r,streamOptions:{signal:xt,size:ai,onstart:S,onprogress:It,onend:Ot}};try{const we=await Kr({readable:ii,writable:ln},ui);_t=we.outputSize,t.size+=_t,le||(Ae=we.inputSize,Re=we.signature)}catch(we){throw we.outputSize!==F&&(t.size+=we.outputSize),we}}return Bc({signature:Re,compressedSize:_t,uncompressedSize:Ae,headerInfo:i,dataDescriptorInfo:a},o),vt&&await ue(t,G),Object.assign(Pe,{uncompressedSize:Ae,compressedSize:_t,lastModDate:l,rawLastModDate:B,creationDate:_,lastAccessDate:Q,encrypted:d,zipCrypto:Ct,size:u+_t,compressionMethod:p,version:h,headerArray:c,headerView:g,signature:Re,extraFieldExtendedTimestampFlag:w,zip64UncompressedSize:z,zip64CompressedSize:gt,zip64Offset:lt,zip64DiskNumberStart:Ft}),Pe}function gc(e){const{rawFilename:t,lastModDate:n,lastAccessDate:s,creationDate:A,level:r,zip64:o,zipCrypto:i,useUnicodeFileNames:a,dataDescriptor:u,directory:c,rawExtraField:g,encryptionStrength:l,extendedTimestamp:B,passThrough:d,encrypted:f,zip64UncompressedSize:h,zip64CompressedSize:p,zip64Offset:E,zip64DiskNumberStart:C,uncompressedSize:I,offset:w,diskNumberStart:m}=e;let{version:x,compressionMethod:y}=e;const G=!c&&(r>0||r===F&&y!==0);let Y;const Q=d||!G,_=o&&(e.bufferedWrite||!h&&!p||Q);if(o){let H=4;h&&(H+=8),p&&(H+=8),E&&(H+=8),C&&(H+=4),Y=new Uint8Array(H);const $=ct(Y);if(U($,0,ur),U($,2,k(Y)-4),_){const K=ct(Y);let S=4;h&&(ut(K,S,BigInt(I)),S+=8),p&&Q&&(ut(K,S,BigInt(I)),S+=8),E&&(ut(K,S,BigInt(w)),S+=8),C&&(L(K,S,m),S+=4)}}else Y=new Uint8Array;let b;if(f&&!i){b=new Uint8Array(k(bA)+2);const H=ct(b);U(H,0,cr),V(b,bA,2),Oe(H,8,l)}else b=new Uint8Array;let M,v,W;if(B){v=new Uint8Array(9+(s?4:0)+(A?4:0));const H=ct(v);U(H,0,Rs),U(H,2,k(v)-4),W=1+(s?2:0)+(A?4:0),Oe(H,4,W);let $=5;L(H,$,Math.floor(n.getTime()/1e3)),$+=4,s&&(L(H,$,Math.floor(s.getTime()/1e3)),$+=4),A&&L(H,$,Math.floor(A.getTime()/1e3));try{M=new Uint8Array(36);const K=ct(M),S=As(n);U(K,0,gr),U(K,2,32),U(K,8,lr),U(K,10,24),ut(K,12,S),ut(K,20,As(s)||S),ut(K,28,As(A)||S)}catch{M=new Uint8Array}}else M=v=new Uint8Array;let z;try{const{uid:H,gid:$,unixMode:K,setuid:S,setgid:It,sticky:Ot,unixExtraFieldType:xt}=e;if(xt&&(H!==F||$!==F||K!==F)){const wt=TA(H),dt=TA($);let ft=new Uint8Array;if(xt==Ro&&K!==F){let zt=K&q;S&&(zt|=xn),It&&(zt|=yn),Ot&&(zt|=Sn),ft=new Uint8Array(2),new DataView(ft.buffer).setUint16(0,zt,!0)}const Jt=3+wt.length+dt.length+ft.length;z=new Uint8Array(4+Jt);const kt=ct(z);U(kt,0,xt==Po?fr:Br),U(kt,2,Jt),Oe(kt,4,1),Oe(kt,5,wt.length);let bt=6;V(z,wt,bt),bt+=wt.length,Oe(kt,bt,dt.length),bt++,V(z,dt,bt),bt+=dt.length,V(z,ft,bt)}else z=new Uint8Array}catch{z=new Uint8Array}y===F&&(y=G?Ys:er),o&&(x=x>oA?x:oA),f&&!i&&(x=x>iA?x:iA,b[9]=y,y=nr);const gt=_?k(Y):0,lt=gt+k(b,v,M,z,g),{headerArray:Ft,headerView:Ct,rawLastModDate:vt}=Oo({version:x,bitFlag:ko(r,a,u,f,y),compressionMethod:y,uncompressedSize:I,lastModDate:n<uA?uA:n>aA?aA:n,rawFilename:t,zip64CompressedSize:p,zip64UncompressedSize:h,extraFieldLength:lt});let j=Qe;const rt=new Uint8Array(j+k(t)+lt),mt=ct(rt);return L(mt,0,sr),V(rt,Ft,4),V(rt,t,j),j+=k(t),_&&V(rt,Y,j),j+=gt,V(rt,b,j),j+=k(b),V(rt,v,j),j+=k(v),V(rt,M,j),j+=k(M),V(rt,z,j),j+=k(z),V(rt,g,j),u&&(L(mt,Ue+4,0),L(mt,He+4,0)),{localHeaderArray:rt,localHeaderView:mt,headerArray:Ft,headerView:Ct,lastModDate:n,rawLastModDate:vt,encrypted:f,compressed:G,version:x,compressionMethod:y,extraFieldExtendedTimestampFlag:W,rawExtraFieldZip64:Y,localExtraFieldZip64Length:gt,rawExtraFieldExtendedTimestamp:v,rawExtraFieldNTFS:M,rawExtraFieldUnix:z,rawExtraFieldAES:b,extraFieldLength:lt}}function lc(e,t){const{headerInfo:n}=e;let{localHeaderArray:s,extraFieldLength:A}=n,r=ct(s),o=64-(t+k(s))%64;o<4&&(o+=64);const i=new Uint8Array(o),a=ct(i);U(a,0,dr),U(a,2,o-2);const u=s;n.localHeaderArray=s=new Uint8Array(k(u)+o),V(s,u),V(s,i,k(u)),r=ct(s),U(r,28,A+o),e.metadataSize+=o}function TA(e){if(e===F)return new Uint8Array;{const t=new Uint8Array(4);ct(t).setUint32(0,e,!0);let s=4;for(;s>1&&t[s-1]===0;)s--;return t.subarray(0,s)}}function dc(e,t){if(e!==F)e=e&Zt;else if(t!==F){const{readOnly:n,hidden:s,system:A,directory:r,archive:o}=t;let i=0;n&&(i|=hs),s&&(i|=ps),A&&(i|=Ds),r&&(i|=Fn),o&&(i|=Cs),e=i&Zt}return t===F&&(t={readOnly:!!(e&hs),hidden:!!(e&ps),system:!!(e&Ds),directory:!!(e&Fn),archive:!!(e&Cs)}),{msdosAttributesRaw:e,msdosAttributes:t}}function fc({zip64:e,dataDescriptor:t,dataDescriptorSignature:n}){let s=new Uint8Array,A,r=0,o=e?ar:ir;return n&&(o+=wn),t&&(s=new Uint8Array(o),A=ct(s),n&&(r=wn,L(A,0,Ar))),{dataDescriptorArray:s,dataDescriptorView:A,dataDescriptorOffset:r}}function Bc({signature:e,compressedSize:t,uncompressedSize:n,headerInfo:s,dataDescriptorInfo:A},{zip64:r,zipCrypto:o,dataDescriptor:i}){const{headerView:a,encrypted:u}=s,{dataDescriptorView:c,dataDescriptorOffset:g}=A;(!u||o)&&e!==F&&(L(a,Os,e),i&&L(c,g,e)),r?i&&(ut(c,g+4,BigInt(t)),ut(c,g+12,BigInt(n))):(L(a,Ue,t),L(a,He,n),i&&(L(c,g+4,t),L(c,g+8,n)))}function Ec({rawFilename:e,encrypted:t,zip64:n,localExtraFieldZip64Length:s,signature:A,compressedSize:r,uncompressedSize:o,offset:i,diskNumberStart:a,zip64UncompressedSize:u,zip64CompressedSize:c,zip64Offset:g,zip64DiskNumberStart:l},B,{dataDescriptor:d}){if(d||(t||L(B,Os+4,A),n||(L(B,Ue+4,r),L(B,He+4,o))),n&&s){let f=Qe+k(e)+4;u&&(ut(B,f,BigInt(o)),f+=8),c&&(ut(B,f,BigInt(r)),f+=8),g&&(ut(B,f,BigInt(i)),f+=8),l&&L(B,f,a)}}function YA({compressedSize:e,uncompressedSize:t,offset:n,diskNumberStart:s,zip64UncompressedSize:A,zip64CompressedSize:r,zip64Offset:o,zip64DiskNumberStart:i,rawExtraFieldZip64:a}){const u=ct(a);let c=4;A&&(ut(u,c,BigInt(t)),c+=8),r&&(ut(u,c,BigInt(e)),c+=8),o&&(ut(u,c,BigInt(n)),c+=8),i&&L(u,c,s)}async function hc(e,t,n){const{files:s,writer:A}=e,{diskOffset:r}=A;let{diskNumber:o}=A,i=0,a=0,u=e.offset-r,c=s.size;for(const[,I]of s){const{rawFilename:w,rawExtraFieldZip64:m,rawExtraFieldAES:x,rawComment:y,rawExtraFieldNTFS:G,rawExtraFieldUnix:Y,rawExtraField:Q,extendedTimestamp:_,extraFieldExtendedTimestampFlag:b,lastModDate:M}=I;let v;if(_){v=new Uint8Array(9);const W=ct(v);U(W,0,Rs),U(W,2,5),Oe(W,4,b),L(W,5,Math.floor(M.getTime()/1e3))}else v=new Uint8Array;I.rawExtraFieldExtendedTimestamp=v,a+=46+k(w,y,m,x,G,Y,v,Q)}const g=new Uint8Array(a),l=ct(g);await De(A);let B=0;for(const[I,w]of Array.from(s.values()).entries()){const{offset:m,rawFilename:x,rawExtraFieldZip64:y,rawExtraFieldAES:G,rawExtraFieldExtendedTimestamp:Y,rawExtraFieldNTFS:Q,rawExtraFieldUnix:_,rawExtraField:b,rawComment:M,versionMadeBy:v,headerArray:W,headerView:z,zip64:gt,zip64UncompressedSize:lt,zip64CompressedSize:Ft,zip64DiskNumberStart:Ct,zip64Offset:vt,internalFileAttributes:j,externalFileAttributes:rt,diskNumberStart:mt,uncompressedSize:H,compressedSize:$}=w,K=k(y,G,Y,Q,_,b);L(l,i,ls),U(l,i+4,v),lt||L(z,He,H),Ft||L(z,Ue,$),V(g,W,i+6);let S=i+Qe;if(U(l,S,K),S+=2,U(l,S,k(M)),S+=2,U(l,S,gt&&Ct?q:mt),S+=2,U(l,S,j),S+=2,rt&&L(l,S,rt),S+=4,L(l,S,gt&&vt?nt:m),S+=4,V(g,x,S),S+=k(x),V(g,y,S),S+=k(y),V(g,G,S),S+=k(G),V(g,Y,S),S+=k(Y),V(g,Q,S),S+=k(Q),V(g,_,S),S+=k(_),V(g,b,S),S+=k(b),V(g,M,S),S+=k(M),i-B>A.availableSize&&(A.availableSize=0,await ue(A,g.slice(B,i)),B=i),i=S,n.onprogress)try{await n.onprogress(I+1,s.size,new Mn(w))}catch{}}await ue(A,B?g.slice(B):g);let d=A.diskNumber;const{availableSize:f}=A;f<ie&&d++;let h=P(e,n,Ws);if(u>nt||a>nt||c>q||d>q){if(h===!1)throw new Error(qs);h=!0}const p=new Uint8Array(h?Gi:ie),E=ct(p);i=0,h&&(L(E,0,ds),ut(E,4,BigInt(44)),U(E,12,45),U(E,14,45),L(E,16,d),L(E,20,o),ut(E,24,BigInt(c)),ut(E,32,BigInt(c)),ut(E,40,BigInt(a)),ut(E,48,BigInt(u)),L(E,56,or),ut(E,64,BigInt(u)+BigInt(a)),L(E,72,d+1),P(e,n,bo,!0)&&(d=q,o=q),c=q,u=nt,a=nt,i+=$e+je),L(E,i,rr),U(E,i+4,d),U(E,i+6,o),U(E,i+8,c),U(E,i+10,c),L(E,i+12,a),L(E,i+16,u);const C=k(t);if(C)if(C<=q)U(E,i+20,C);else throw new Error(qu);await ue(A,p),C&&await ue(A,t)}async function ue(e,t){const{writable:n}=e,s=n.getWriter();try{await s.ready,e.size+=k(t),await s.write(t)}finally{s.releaseLock()}}function As(e){if(e)return(BigInt(e.getTime())+BigInt(116444736e5))*BigInt(1e4)}function P(e,t,n,s){const A=t[n]===F?e.options[n]:t[n];return A===F?s:A}function PA(e){return e+5*(Math.floor(e/16383)+1)}function Oe(e,t,n){e.setUint8(t,n)}function U(e,t,n){e.setUint16(t,n,!0)}function L(e,t,n){e.setUint32(t,n,!0)}function ut(e,t,n){e.setBigUint64(t,n,!0)}function V(e,t,n){e.set(t,n)}function ct(e){return new DataView(e.buffer)}function k(...e){let t=0;return e.forEach(n=>n&&(t+=n.length)),t}function Oo({version:e,bitFlag:t,compressionMethod:n,uncompressedSize:s,compressedSize:A,lastModDate:r,rawFilename:o,zip64CompressedSize:i,zip64UncompressedSize:a,extraFieldLength:u}){const c=new Uint8Array(Qe-4),g=ct(c);U(g,0,e),U(g,2,t),U(g,4,n);const l=new Uint32Array(1),B=ct(l);U(B,0,(r.getHours()<<6|r.getMinutes())<<5|r.getSeconds()/2),U(B,2,(r.getFullYear()-1980<<4|r.getMonth()+1)<<5|r.getDate());const d=l[0];return L(g,6,d),(i||A!==F)&&L(g,Ue,i?nt:A),(a||s!==F)&&L(g,He,a?nt:s),U(g,22,k(o)),U(g,24,u),{headerArray:c,headerView:g,rawLastModDate:d}}function ko(e,t,n,s,A){let r=0;return t&&(r=r|Es),n&&(r=r|Bs),(A==Ys||A==gs)&&(e>=0&&e<=3&&(r=r|Wi),e>3&&e<=5&&(r=r|Ji),e==9&&(r=r|Ki)),s&&(r=r|fs),r}try{Ln({baseURI:import.meta.url})}catch{}const Yt="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";function pc(e){let t;e({wasmURI:()=>(t||(t="data:application/wasm;base64,"+(n=>{n=(o=>{const i=(o=(o+"").replace(/[^A-Za-z0-9+/=]/g,"")).length,a=[];for(let u=0;i>u;u+=4){const c=Yt.indexOf(o[u])<<18|Yt.indexOf(o[u+1])<<12|(63&Yt.indexOf(o[u+2]))<<6|63&Yt.indexOf(o[u+3]);a.push(c>>16&255),o[u+2]!=="="&&a.push(c>>8&255),o[u+3]!=="="&&a.push(255&c)}return new Uint8Array(a)})(n);let s=new Uint8Array(1024),A=0;for(let o=0;o<n.length;){const i=n[o++];if(128&i){const a=3+(127&i),u=n[o++]<<8|n[o++],c=A-u;r(A+a);for(let g=0;a>g;g++)s[A++]=s[c+g]}else{const a=i;r(A+a);for(let u=0;a>u&&o<n.length;u++)s[A++]=n[o++]}}return(o=>{let i="";const a=o.length;let u=0;for(;a>u+2;u+=3){const g=o[u]<<16|o[u+1]<<8|o[u+2];i+=Yt[g>>18&63]+Yt[g>>12&63]+Yt[g>>6&63]+Yt[63&g]}const c=a-u;if(c===1){const g=o[u]<<16;i+=Yt[g>>18&63]+Yt[g>>12&63]+"=="}else if(c===2){const g=o[u]<<16|o[u+1]<<8;i+=Yt[g>>18&63]+Yt[g>>12&63]+Yt[g>>6&63]+"="}return i})(new Uint8Array(s.buffer.slice(0,A)));function r(o){if(s.length<o){let i=2*s.length;for(;o>i;)i*=2;const a=new Uint8Array(i);a.set(s.subarray(0,A)),s=a}}})("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mYAABAFZgAAEAdmAAAQBOYAABAG5gAAEAXmAAAQB+YAABAEFgAAEAYWAAAQBRYAABAHFgAAEASWAAAQBpYAABAFlgAAEAeWAAAQBFYAABAGVgAAEAVWAAAQB1YAABAE1gAAEAbWAAAQBdYAABAH1gAAEAQ2AAAQBjYAABAFNgAAEAc2AAASAETMCAK2AAAQBbYAABAHtgAAEAR2AAAQBnYAABAFdgAAEAd2AAAQBPYAABAG9gAAEAX2AAAQB/YAABAETgADCBRMBCQCTgAAIAZOAAAgBU4AACAFTgAAIAdOAAAgB04AACAEzgAAIATOAAAgBs4AACAGzgAAIAXOAAAgBc4AACAHzgAAIAfOAAAgBC4AACIAQ2oAEAoAABIAACAFLgAAIAUuAAAgBy4AACAHLgAAIASuAAAgBK4AACAGrgAAIAauAAAgBa4AACAFrgAAIAeuAAAgB64AACAEbgAAIARuAAAgBm4AACAGbgAAIAVuAAAgBW4AACAHbgAAIAduAAAgBO4AACAE7gAAIAbuAAAgBu4AACAF7gAAIAXuAAAgB+4AACAH7gAAIgQO2AQeAAAgBh4AACAGHgAAIAUeAAAgBR4AACAHHgAAIAceAAAgBJ4AACAEngAAIAaeAAAgBp4AACAFngAAIAWeAAAgB54AACAHngAAIAReAAAgBF4AACAGXgAAIAZeAAAgBV4AACAFXgAAIAdeAAAgB14AACAE3gAAIATeAAAgBt4AACAG3gAAIAXeAAAgBd4AACAH3gAAIAfeAAAgBD4AACAEPgAAIAY+AAAgBj4AACAFPgAAIAU+AAAgBz4AACAHPgAAIAS+AAAgBL4AACAGvgAAIAa+AAAgBb4AACAFvgAAIAe+AAAgB74AACAEfgAAIAR+AAAgBn4AACAGfgAAIAV+AAAgBX4AACAHfgAAIAd+AAAgBP4AACAE/gAAIAb+AAAgBv4AACAF/gAAIAX+AAAgB/4AACAH/gAAIgQQKAUCAAAQBIIAABAFggAAEARCAAAQBUIAABAEwgAAEAXCCBVYDBwBIgAAEASiAAAQBaIAABAEYgAAEAViAAAQBOIAABAF4gAAEAQSAAAQBRIAABAEkgAAEAWSAAAQBFIAABAFUgAAEATSAAAQBdIAABAEDgABCAYOAAAQBQ4AABAHDgAAEASOAAAQBo4AABAFjgAAEAeOAAASAveaAAHSBAsYBBYAAXAEFggVKARSAAAQBDIAABAEcgAAEgL34gAREAQWCBgQBGoIF6gEFgAPUAQWAA7gBBYADnIBPdoAABAERgAAEAQmAAAQBGYAABIEAAgEVgAAEAQ2AAAQBHYAABAEDgAAEAROCBkABBYACLIEFpgEFgAG0AQWAPd8DGwtNgx+5hwAEAQKMAASBB1GJAAQBBIwABAEFigAEBEGwHAuAvMWLAEuNADuFAC8BBoQABIEFiIEABIEBCoEABIEBkoEABICEcYIABAELhAAEAQyEAASABduBR3kE4B0LI4UAX4UFywIQEYAFbQYHCQYKBQuAOrgEDQIOAYAHJQSUHgtphQCQhQCIhQCAhQB4gQBogQBcgQYfARCAAAQBFIAABAEYgAAEARyAAAQBIIAABAEogAAEATCAAAQBOIAABAFAgAAEAVCAAASBBr0BcIAABAGAgAAEAaCAAAQBwIAABAHggABvAx8Lco0Ab4EAa4EAZ4EAY4EAX4EAW4EAV4EAU4EAT4EAS4EAR4EAQ4EBPAGArwBBgFHNAgttgQDHAQSAAAIBCIAABIEBM4ECSwEQgAAOgwAMgYVpgKomhAAkgQdzgQBPAQiAAAiBABiFAAyBCLeDAAwBIIEAlIAyhIEAawGAgQgvAQSDAAyAP0gKAQAQDABBkSEL/4AlHwEDgpvTBQgJCQoKgEk3gAABAQ2AAAEBDoAAAQEPgAABARCEAAEBEYQAAQEShAABAROEAAEBFIwAAQEVjAABARaMAAEBF4wAAQEYnAABARmcAAEBGpwAAQEbmwABARyBffsEBAQFBYHBkAEHgAABAQiEAAGAXSqCAAEBCowAAYAnsooAAYEBMJkAAYEBTJkAAYEBaLkAAYEBpLkAAYIDdYABzoUBvI0BqJ0BkLwBgAIbHLwAAQEdvAABgA9PgH05A9AqAQ==")),t)})}let ot,Ne,Rt,en;function Dc(e){if(ot=e,{malloc:Ne,free:Rt,memory:en}=ot,typeof Ne!="function"||typeof Rt!="function"||!en)throw ot=Ne=Rt=en=null,new Error("Invalid WASM module")}function _o(e,t,n={}){const s=typeof n.level=="number"?n.level:-1,A=typeof n.outBuffer=="number"?n.outBuffer:64*1024,r=typeof n.inBufferSize=="number"?n.inBufferSize:64*1024;return new TransformStream({start(){let o;if(this.out=Ne(A),this.in=Ne(r),this.inBufferSize=r,this._scratch=new Uint8Array(A),e?(this._process=ot.deflate_process,this._last_consumed=ot.deflate_last_consumed,this._end=ot.deflate_end,this.streamHandle=ot.deflate_new(),t==="gzip"?o=ot.deflate_init_gzip(this.streamHandle,s):t==="deflate-raw"?o=ot.deflate_init_raw(this.streamHandle,s):o=ot.deflate_init(this.streamHandle,s)):t==="deflate64-raw"?(this._process=ot.inflate9_process,this._last_consumed=ot.inflate9_last_consumed,this._end=ot.inflate9_end,this.streamHandle=ot.inflate9_new(),o=ot.inflate9_init_raw(this.streamHandle)):(this._process=ot.inflate_process,this._last_consumed=ot.inflate_last_consumed,this._end=ot.inflate_end,this.streamHandle=ot.inflate_new(),t==="deflate-raw"?o=ot.inflate_init_raw(this.streamHandle):t==="gzip"?o=ot.inflate_init_gzip(this.streamHandle):o=ot.inflate_init(this.streamHandle)),o!==0)throw new Error("init failed:"+o)},transform(o,i){try{const a=o,u=new Uint8Array(en.buffer),c=this._process,g=this._last_consumed,l=this.out,B=this._scratch;let d=0;for(;d<a.length;){const f=Math.min(a.length-d,32768);(!this.in||this.inBufferSize<f)&&(this.in&&Rt&&Rt(this.in),this.in=Ne(f),this.inBufferSize=f),u.set(a.subarray(d,d+f),this.in);const h=c(this.streamHandle,this.in,f,l,A,0);if(!e&&h<0)throw new Error("process error:"+h);const p=h&16777215;p&&(B.set(u.subarray(l,l+p),0),i.enqueue(B.slice(0,p)));const E=g(this.streamHandle);if(E===0)break;d+=E}}catch(a){this._end&&this.streamHandle&&this._end(this.streamHandle),this.in&&Rt&&Rt(this.in),this.out&&Rt&&Rt(this.out),i.error(a)}},flush(o){try{const i=new Uint8Array(en.buffer),a=this._process,u=this.out,c=this._scratch;for(;;){const g=a(this.streamHandle,0,0,u,A,4);if(!e&&g<0)throw new Error("process error:"+g);const l=g&16777215,B=g>>24&255;if(l&&(c.set(i.subarray(u,u+l),0),o.enqueue(c.slice(0,l))),B===1||l===0)break}}catch(i){o.error(i)}finally{if(this._end&&this.streamHandle){const i=this._end(this.streamHandle);i!==0&&o.error(new Error("end error:"+i))}this.in&&Rt&&Rt(this.in),this.out&&Rt&&Rt(this.out)}}})}class Cc{constructor(t="deflate",n){return _o(!0,t,n)}}class mc{constructor(t="deflate",n){return _o(!1,t,n)}}let RA=!1;async function Ic(e,{baseURI:t}){if(!RA){let n,s;try{try{s=new URL(e,t)}catch{}n=await(await fetch(s)).arrayBuffer()}catch(r){if(e.startsWith("data:application/wasm;base64,"))n=wc(e);else throw r}const A=await WebAssembly.instantiate(n);Dc(A.instance.exports),RA=!0}}function wc(e){const t=e.split(",")[1],n=atob(t),s=n.length,A=new Uint8Array(s);for(let r=0;r<s;++r)A[r]=n.charCodeAt(r);return A.buffer}let rs;pc(Ln);Qa({initModule:e=>{if(!rs){let{wasmURI:t}=e;typeof t==Me&&(t=t()),rs=Ic(t,e)}return rs}});Ln({CompressionStreamZlib:Cc,DecompressionStreamZlib:mc});const os={application:{"andrew-inset":"ez",annodex:"anx","atom+xml":"atom","atomcat+xml":"atomcat","atomserv+xml":"atomsrv",bbolin:"lin","cu-seeme":"cu","davmount+xml":"davmount",dsptype:"tsp",ecmascript:["es","ecma"],futuresplash:"spl",hta:"hta","java-archive":"jar","java-serialized-object":"ser","java-vm":"class",m3g:"m3g","mac-binhex40":"hqx",mathematica:["nb","ma","mb"],msaccess:"mdb",msword:["doc","dot","wiz"],mxf:"mxf",oda:"oda",ogg:"ogx",pdf:"pdf","pgp-keys":"key","pgp-signature":["asc","sig"],"pics-rules":"prf",postscript:["ps","ai","eps","epsi","epsf","eps2","eps3"],rar:"rar","rdf+xml":"rdf","rss+xml":"rss",rtf:"rtf","xhtml+xml":["xhtml","xht"],xml:["xml","xsl","xsd","xpdl"],"xspf+xml":"xspf",zip:"zip","vnd.android.package-archive":"apk","vnd.cinderella":"cdy","vnd.google-earth.kml+xml":"kml","vnd.google-earth.kmz":"kmz","vnd.mozilla.xul+xml":"xul","vnd.ms-excel":["xls","xlb","xlt","xlm","xla","xlc","xlw"],"vnd.ms-pki.seccat":"cat","vnd.ms-pki.stl":"stl","vnd.ms-powerpoint":["ppt","pps","pot","ppa","pwz"],"vnd.oasis.opendocument.chart":"odc","vnd.oasis.opendocument.database":"odb","vnd.oasis.opendocument.formula":"odf","vnd.oasis.opendocument.graphics":"odg","vnd.oasis.opendocument.graphics-template":"otg","vnd.oasis.opendocument.image":"odi","vnd.oasis.opendocument.presentation":"odp","vnd.oasis.opendocument.presentation-template":"otp","vnd.oasis.opendocument.spreadsheet":"ods","vnd.oasis.opendocument.spreadsheet-template":"ots","vnd.oasis.opendocument.text":"odt","vnd.oasis.opendocument.text-master":["odm","otm"],"vnd.oasis.opendocument.text-template":"ott","vnd.oasis.opendocument.text-web":"oth","vnd.openxmlformats-officedocument.spreadsheetml.sheet":"xlsx","vnd.openxmlformats-officedocument.spreadsheetml.template":"xltx","vnd.openxmlformats-officedocument.presentationml.presentation":"pptx","vnd.openxmlformats-officedocument.presentationml.slideshow":"ppsx","vnd.openxmlformats-officedocument.presentationml.template":"potx","vnd.openxmlformats-officedocument.wordprocessingml.document":"docx","vnd.openxmlformats-officedocument.wordprocessingml.template":"dotx","vnd.smaf":"mmf","vnd.stardivision.calc":"sdc","vnd.stardivision.chart":"sds","vnd.stardivision.draw":"sda","vnd.stardivision.impress":"sdd","vnd.stardivision.math":["sdf","smf"],"vnd.stardivision.writer":["sdw","vor"],"vnd.stardivision.writer-global":"sgl","vnd.sun.xml.calc":"sxc","vnd.sun.xml.calc.template":"stc","vnd.sun.xml.draw":"sxd","vnd.sun.xml.draw.template":"std","vnd.sun.xml.impress":"sxi","vnd.sun.xml.impress.template":"sti","vnd.sun.xml.math":"sxm","vnd.sun.xml.writer":"sxw","vnd.sun.xml.writer.global":"sxg","vnd.sun.xml.writer.template":"stw","vnd.symbian.install":["sis","sisx"],"vnd.visio":["vsd","vst","vss","vsw","vsdx","vssx","vstx","vssm","vstm"],"vnd.wap.wbxml":"wbxml","vnd.wap.wmlc":"wmlc","vnd.wap.wmlscriptc":"wmlsc","vnd.wordperfect":"wpd","vnd.wordperfect5.1":"wp5","x-123":"wk","x-7z-compressed":"7z","x-abiword":"abw","x-apple-diskimage":"dmg","x-bcpio":"bcpio","x-bittorrent":"torrent","x-cbr":["cbr","cba","cbt","cb7"],"x-cbz":"cbz","x-cdf":["cdf","cda"],"x-cdlink":"vcd","x-chess-pgn":"pgn","x-cpio":"cpio","x-csh":"csh","x-director":["dir","dxr","cst","cct","cxt","w3d","fgd","swa"],"x-dms":"dms","x-doom":"wad","x-dvi":"dvi","x-httpd-eruby":"rhtml","x-font":"pcf.Z","x-freemind":"mm","x-gnumeric":"gnumeric","x-go-sgf":"sgf","x-graphing-calculator":"gcf","x-gtar":["gtar","taz"],"x-hdf":"hdf","x-httpd-php":["phtml","pht","php"],"x-httpd-php-source":"phps","x-httpd-php3":"php3","x-httpd-php3-preprocessed":"php3p","x-httpd-php4":"php4","x-httpd-php5":"php5","x-ica":"ica","x-info":"info","x-internet-signup":["ins","isp"],"x-iphone":"iii","x-iso9660-image":"iso","x-java-jnlp-file":"jnlp","x-jmol":"jmz","x-killustrator":"kil","x-latex":"latex","x-lyx":"lyx","x-lzx":"lzx","x-maker":["frm","fb","fbdoc"],"x-ms-wmd":"wmd","x-msdos-program":["com","exe","bat","dll"],"x-netcdf":["nc"],"x-ns-proxy-autoconfig":["pac","dat"],"x-nwc":"nwc","x-object":"o","x-oz-application":"oza","x-pkcs7-certreqresp":"p7r","x-python-code":["pyc","pyo"],"x-qgis":["qgs","shp","shx"],"x-quicktimeplayer":"qtl","x-redhat-package-manager":["rpm","rpa"],"x-ruby":"rb","x-sh":"sh","x-shar":"shar","x-shockwave-flash":["swf","swfl"],"x-silverlight":"scr","x-stuffit":"sit","x-sv4cpio":"sv4cpio","x-sv4crc":"sv4crc","x-tar":"tar","x-tex-gf":"gf","x-tex-pk":"pk","x-texinfo":["texinfo","texi"],"x-trash":["~","%","bak","old","sik"],"x-ustar":"ustar","x-wais-source":"src","x-wingz":"wz","x-x509-ca-cert":["crt","der","cer"],"x-xcf":"xcf","x-xfig":"fig","x-xpinstall":"xpi",applixware:"aw","atomsvc+xml":"atomsvc","ccxml+xml":"ccxml","cdmi-capability":"cdmia","cdmi-container":"cdmic","cdmi-domain":"cdmid","cdmi-object":"cdmio","cdmi-queue":"cdmiq","docbook+xml":"dbk","dssc+der":"dssc","dssc+xml":"xdssc","emma+xml":"emma","epub+zip":"epub",exi:"exi","font-tdpfr":"pfr","gml+xml":"gml","gpx+xml":"gpx",gxf:"gxf",hyperstudio:"stk","inkml+xml":["ink","inkml"],ipfix:"ipfix","jsonml+json":"jsonml","lost+xml":"lostxml","mads+xml":"mads",marc:"mrc","marcxml+xml":"mrcx","mathml+xml":["mathml","mml"],mbox:"mbox","mediaservercontrol+xml":"mscml","metalink+xml":"metalink","metalink4+xml":"meta4","mets+xml":"mets","mods+xml":"mods",mp21:["m21","mp21"],mp4:"mp4s","oebps-package+xml":"opf","omdoc+xml":"omdoc",onenote:["onetoc","onetoc2","onetmp","onepkg"],oxps:"oxps","patch-ops-error+xml":"xer","pgp-encrypted":"pgp",pkcs10:"p10","pkcs7-mime":["p7m","p7c"],"pkcs7-signature":"p7s",pkcs8:"p8","pkix-attr-cert":"ac","pkix-crl":"crl","pkix-pkipath":"pkipath",pkixcmp:"pki","pls+xml":"pls","prs.cww":"cww","pskc+xml":"pskcxml","reginfo+xml":"rif","relax-ng-compact-syntax":"rnc","resource-lists+xml":"rl","resource-lists-diff+xml":"rld","rls-services+xml":"rs","rpki-ghostbusters":"gbr","rpki-manifest":"mft","rpki-roa":"roa","rsd+xml":"rsd","sbml+xml":"sbml","scvp-cv-request":"scq","scvp-cv-response":"scs","scvp-vp-request":"spq","scvp-vp-response":"spp",sdp:"sdp","set-payment-initiation":"setpay","set-registration-initiation":"setreg","shf+xml":"shf","sparql-query":"rq","sparql-results+xml":"srx",srgs:"gram","srgs+xml":"grxml","sru+xml":"sru","ssdl+xml":"ssdl","ssml+xml":"ssml","tei+xml":["tei","teicorpus"],"thraud+xml":"tfi","timestamped-data":"tsd","vnd.3gpp.pic-bw-large":"plb","vnd.3gpp.pic-bw-small":"psb","vnd.3gpp.pic-bw-var":"pvb","vnd.3gpp2.tcap":"tcap","vnd.3m.post-it-notes":"pwn","vnd.accpac.simply.aso":"aso","vnd.accpac.simply.imp":"imp","vnd.acucobol":"acu","vnd.acucorp":["atc","acutc"],"vnd.adobe.air-application-installer-package+zip":"air","vnd.adobe.formscentral.fcdt":"fcdt","vnd.adobe.fxp":["fxp","fxpl"],"vnd.adobe.xdp+xml":"xdp","vnd.adobe.xfdf":"xfdf","vnd.ahead.space":"ahead","vnd.airzip.filesecure.azf":"azf","vnd.airzip.filesecure.azs":"azs","vnd.amazon.ebook":"azw","vnd.americandynamics.acc":"acc","vnd.amiga.ami":"ami","vnd.anser-web-certificate-issue-initiation":"cii","vnd.anser-web-funds-transfer-initiation":"fti","vnd.antix.game-component":"atx","vnd.apple.installer+xml":"mpkg","vnd.apple.mpegurl":"m3u8","vnd.aristanetworks.swi":"swi","vnd.astraea-software.iota":"iota","vnd.audiograph":"aep","vnd.blueice.multipass":"mpm","vnd.bmi":"bmi","vnd.businessobjects":"rep","vnd.chemdraw+xml":"cdxml","vnd.chipnuts.karaoke-mmd":"mmd","vnd.claymore":"cla","vnd.cloanto.rp9":"rp9","vnd.clonk.c4group":["c4g","c4d","c4f","c4p","c4u"],"vnd.cluetrust.cartomobile-config":"c11amc","vnd.cluetrust.cartomobile-config-pkg":"c11amz","vnd.commonspace":"csp","vnd.contact.cmsg":"cdbcmsg","vnd.cosmocaller":"cmc","vnd.crick.clicker":"clkx","vnd.crick.clicker.keyboard":"clkk","vnd.crick.clicker.palette":"clkp","vnd.crick.clicker.template":"clkt","vnd.crick.clicker.wordbank":"clkw","vnd.criticaltools.wbs+xml":"wbs","vnd.ctc-posml":"pml","vnd.cups-ppd":"ppd","vnd.curl.car":"car","vnd.curl.pcurl":"pcurl","vnd.dart":"dart","vnd.data-vision.rdz":"rdz","vnd.dece.data":["uvf","uvvf","uvd","uvvd"],"vnd.dece.ttml+xml":["uvt","uvvt"],"vnd.dece.unspecified":["uvx","uvvx"],"vnd.dece.zip":["uvz","uvvz"],"vnd.denovo.fcselayout-link":"fe_launch","vnd.dna":"dna","vnd.dolby.mlp":"mlp","vnd.dpgraph":"dpg","vnd.dreamfactory":"dfac","vnd.ds-keypoint":"kpxx","vnd.dvb.ait":"ait","vnd.dvb.service":"svc","vnd.dynageo":"geo","vnd.ecowin.chart":"mag","vnd.enliven":"nml","vnd.epson.esf":"esf","vnd.epson.msf":"msf","vnd.epson.quickanime":"qam","vnd.epson.salt":"slt","vnd.epson.ssf":"ssf","vnd.eszigno3+xml":["es3","et3"],"vnd.ezpix-album":"ez2","vnd.ezpix-package":"ez3","vnd.fdf":"fdf","vnd.fdsn.mseed":"mseed","vnd.fdsn.seed":["seed","dataless"],"vnd.flographit":"gph","vnd.fluxtime.clip":"ftc","vnd.framemaker":["fm","frame","maker","book"],"vnd.frogans.fnc":"fnc","vnd.frogans.ltf":"ltf","vnd.fsc.weblaunch":"fsc","vnd.fujitsu.oasys":"oas","vnd.fujitsu.oasys2":"oa2","vnd.fujitsu.oasys3":"oa3","vnd.fujitsu.oasysgp":"fg5","vnd.fujitsu.oasysprs":"bh2","vnd.fujixerox.ddd":"ddd","vnd.fujixerox.docuworks":"xdw","vnd.fujixerox.docuworks.binder":"xbd","vnd.fuzzysheet":"fzs","vnd.genomatix.tuxedo":"txd","vnd.geogebra.file":"ggb","vnd.geogebra.tool":"ggt","vnd.geometry-explorer":["gex","gre"],"vnd.geonext":"gxt","vnd.geoplan":"g2w","vnd.geospace":"g3w","vnd.gmx":"gmx","vnd.grafeq":["gqf","gqs"],"vnd.groove-account":"gac","vnd.groove-help":"ghf","vnd.groove-identity-message":"gim","vnd.groove-injector":"grv","vnd.groove-tool-message":"gtm","vnd.groove-tool-template":"tpl","vnd.groove-vcard":"vcg","vnd.hal+xml":"hal","vnd.handheld-entertainment+xml":"zmm","vnd.hbci":"hbci","vnd.hhe.lesson-player":"les","vnd.hp-hpgl":"hpgl","vnd.hp-hpid":"hpid","vnd.hp-hps":"hps","vnd.hp-jlyt":"jlt","vnd.hp-pcl":"pcl","vnd.hp-pclxl":"pclxl","vnd.hydrostatix.sof-data":"sfd-hdstx","vnd.ibm.minipay":"mpy","vnd.ibm.modcap":["afp","listafp","list3820"],"vnd.ibm.rights-management":"irm","vnd.ibm.secure-container":"sc","vnd.iccprofile":["icc","icm"],"vnd.igloader":"igl","vnd.immervision-ivp":"ivp","vnd.immervision-ivu":"ivu","vnd.insors.igm":"igm","vnd.intercon.formnet":["xpw","xpx"],"vnd.intergeo":"i2g","vnd.intu.qbo":"qbo","vnd.intu.qfx":"qfx","vnd.ipunplugged.rcprofile":"rcprofile","vnd.irepository.package+xml":"irp","vnd.is-xpr":"xpr","vnd.isac.fcs":"fcs","vnd.jam":"jam","vnd.jcp.javame.midlet-rms":"rms","vnd.jisp":"jisp","vnd.joost.joda-archive":"joda","vnd.kahootz":["ktz","ktr"],"vnd.kde.karbon":"karbon","vnd.kde.kchart":"chrt","vnd.kde.kformula":"kfo","vnd.kde.kivio":"flw","vnd.kde.kontour":"kon","vnd.kde.kpresenter":["kpr","kpt"],"vnd.kde.kspread":"ksp","vnd.kde.kword":["kwd","kwt"],"vnd.kenameaapp":"htke","vnd.kidspiration":"kia","vnd.kinar":["kne","knp"],"vnd.koan":["skp","skd","skt","skm"],"vnd.kodak-descriptor":"sse","vnd.las.las+xml":"lasxml","vnd.llamagraphics.life-balance.desktop":"lbd","vnd.llamagraphics.life-balance.exchange+xml":"lbe","vnd.lotus-1-2-3":"123","vnd.lotus-approach":"apr","vnd.lotus-freelance":"pre","vnd.lotus-notes":"nsf","vnd.lotus-organizer":"org","vnd.lotus-screencam":"scm","vnd.lotus-wordpro":"lwp","vnd.macports.portpkg":"portpkg","vnd.mcd":"mcd","vnd.medcalcdata":"mc1","vnd.mediastation.cdkey":"cdkey","vnd.mfer":"mwf","vnd.mfmp":"mfm","vnd.micrografx.flo":"flo","vnd.micrografx.igx":"igx","vnd.mif":"mif","vnd.mobius.daf":"daf","vnd.mobius.dis":"dis","vnd.mobius.mbk":"mbk","vnd.mobius.mqy":"mqy","vnd.mobius.msl":"msl","vnd.mobius.plc":"plc","vnd.mobius.txf":"txf","vnd.mophun.application":"mpn","vnd.mophun.certificate":"mpc","vnd.ms-artgalry":"cil","vnd.ms-cab-compressed":"cab","vnd.ms-excel.addin.macroenabled.12":"xlam","vnd.ms-excel.sheet.binary.macroenabled.12":"xlsb","vnd.ms-excel.sheet.macroenabled.12":"xlsm","vnd.ms-excel.template.macroenabled.12":"xltm","vnd.ms-fontobject":"eot","vnd.ms-htmlhelp":"chm","vnd.ms-ims":"ims","vnd.ms-lrm":"lrm","vnd.ms-officetheme":"thmx","vnd.ms-powerpoint.addin.macroenabled.12":"ppam","vnd.ms-powerpoint.presentation.macroenabled.12":"pptm","vnd.ms-powerpoint.slide.macroenabled.12":"sldm","vnd.ms-powerpoint.slideshow.macroenabled.12":"ppsm","vnd.ms-powerpoint.template.macroenabled.12":"potm","vnd.ms-project":["mpp","mpt"],"vnd.ms-word.document.macroenabled.12":"docm","vnd.ms-word.template.macroenabled.12":"dotm","vnd.ms-works":["wps","wks","wcm","wdb"],"vnd.ms-wpl":"wpl","vnd.ms-xpsdocument":"xps","vnd.mseq":"mseq","vnd.musician":"mus","vnd.muvee.style":"msty","vnd.mynfc":"taglet","vnd.neurolanguage.nlu":"nlu","vnd.nitf":["ntf","nitf"],"vnd.noblenet-directory":"nnd","vnd.noblenet-sealer":"nns","vnd.noblenet-web":"nnw","vnd.nokia.n-gage.data":"ngdat","vnd.nokia.n-gage.symbian.install":"n-gage","vnd.nokia.radio-preset":"rpst","vnd.nokia.radio-presets":"rpss","vnd.novadigm.edm":"edm","vnd.novadigm.edx":"edx","vnd.novadigm.ext":"ext","vnd.oasis.opendocument.chart-template":"otc","vnd.oasis.opendocument.formula-template":"odft","vnd.oasis.opendocument.image-template":"oti","vnd.olpc-sugar":"xo","vnd.oma.dd2+xml":"dd2","vnd.openofficeorg.extension":"oxt","vnd.openxmlformats-officedocument.presentationml.slide":"sldx","vnd.osgeo.mapguide.package":"mgp","vnd.osgi.dp":"dp","vnd.osgi.subsystem":"esa","vnd.palm":["pdb","pqa","oprc"],"vnd.pawaafile":"paw","vnd.pg.format":"str","vnd.pg.osasli":"ei6","vnd.picsel":"efif","vnd.pmi.widget":"wg","vnd.pocketlearn":"plf","vnd.powerbuilder6":"pbd","vnd.previewsystems.box":"box","vnd.proteus.magazine":"mgz","vnd.publishare-delta-tree":"qps","vnd.pvi.ptid1":"ptid","vnd.quark.quarkxpress":["qxd","qxt","qwd","qwt","qxl","qxb"],"vnd.realvnc.bed":"bed","vnd.recordare.musicxml":"mxl","vnd.recordare.musicxml+xml":"musicxml","vnd.rig.cryptonote":"cryptonote","vnd.rn-realmedia":"rm","vnd.rn-realmedia-vbr":"rmvb","vnd.route66.link66+xml":"link66","vnd.sailingtracker.track":"st","vnd.seemail":"see","vnd.sema":"sema","vnd.semd":"semd","vnd.semf":"semf","vnd.shana.informed.formdata":"ifm","vnd.shana.informed.formtemplate":"itp","vnd.shana.informed.interchange":"iif","vnd.shana.informed.package":"ipk","vnd.simtech-mindmapper":["twd","twds"],"vnd.smart.teacher":"teacher","vnd.solent.sdkm+xml":["sdkm","sdkd"],"vnd.spotfire.dxp":"dxp","vnd.spotfire.sfs":"sfs","vnd.stepmania.package":"smzip","vnd.stepmania.stepchart":"sm","vnd.sus-calendar":["sus","susp"],"vnd.svd":"svd","vnd.syncml+xml":"xsm","vnd.syncml.dm+wbxml":"bdm","vnd.syncml.dm+xml":"xdm","vnd.tao.intent-module-archive":"tao","vnd.tcpdump.pcap":["pcap","cap","dmp"],"vnd.tmobile-livetv":"tmo","vnd.trid.tpt":"tpt","vnd.triscape.mxs":"mxs","vnd.trueapp":"tra","vnd.ufdl":["ufd","ufdl"],"vnd.uiq.theme":"utz","vnd.umajin":"umj","vnd.unity":"unityweb","vnd.uoml+xml":"uoml","vnd.vcx":"vcx","vnd.visionary":"vis","vnd.vsf":"vsf","vnd.webturbo":"wtb","vnd.wolfram.player":"nbp","vnd.wqd":"wqd","vnd.wt.stf":"stf","vnd.xara":"xar","vnd.xfdl":"xfdl","vnd.yamaha.hv-dic":"hvd","vnd.yamaha.hv-script":"hvs","vnd.yamaha.hv-voice":"hvp","vnd.yamaha.openscoreformat":"osf","vnd.yamaha.openscoreformat.osfpvg+xml":"osfpvg","vnd.yamaha.smaf-audio":"saf","vnd.yamaha.smaf-phrase":"spf","vnd.yellowriver-custom-menu":"cmp","vnd.zul":["zir","zirz"],"vnd.zzazz.deck+xml":"zaz","voicexml+xml":"vxml",widget:"wgt",winhlp:"hlp","wsdl+xml":"wsdl","wspolicy+xml":"wspolicy","x-ace-compressed":"ace","x-authorware-bin":["aab","x32","u32","vox"],"x-authorware-map":"aam","x-authorware-seg":"aas","x-blorb":["blb","blorb"],"x-bzip":"bz","x-bzip2":["bz2","boz"],"x-cfs-compressed":"cfs","x-chat":"chat","x-conference":"nsc","x-dgc-compressed":"dgc","x-dtbncx+xml":"ncx","x-dtbook+xml":"dtb","x-dtbresource+xml":"res","x-eva":"eva","x-font-bdf":"bdf","x-font-ghostscript":"gsf","x-font-linux-psf":"psf","x-font-pcf":"pcf","x-font-snf":"snf","x-font-ttf":["ttf","ttc"],"x-font-type1":["pfa","pfb","pfm","afm"],"x-freearc":"arc","x-gca-compressed":"gca","x-glulx":"ulx","x-gramps-xml":"gramps","x-install-instructions":"install","x-lzh-compressed":["lzh","lha"],"x-mie":"mie","x-mobipocket-ebook":["prc","mobi"],"x-ms-application":"application","x-ms-shortcut":"lnk","x-ms-xbap":"xbap","x-msbinder":"obd","x-mscardfile":"crd","x-msclip":"clp","application/x-ms-installer":"msi","x-msmediaview":["mvb","m13","m14"],"x-msmetafile":["wmf","wmz","emf","emz"],"x-msmoney":"mny","x-mspublisher":"pub","x-msschedule":"scd","x-msterminal":"trm","x-mswrite":"wri","x-nzb":"nzb","x-pkcs12":["p12","pfx"],"x-pkcs7-certificates":["p7b","spc"],"x-research-info-systems":"ris","x-silverlight-app":"xap","x-sql":"sql","x-stuffitx":"sitx","x-subrip":"srt","x-t3vm-image":"t3","x-tex-tfm":"tfm","x-tgif":"obj","x-xliff+xml":"xlf","x-xz":"xz","x-zmachine":["z1","z2","z3","z4","z5","z6","z7","z8"],"xaml+xml":"xaml","xcap-diff+xml":"xdf","xenc+xml":"xenc","xml-dtd":"dtd","xop+xml":"xop","xproc+xml":"xpl","xslt+xml":"xslt","xv+xml":["mxml","xhvml","xvml","xvm"],yang:"yang","yin+xml":"yin",envoy:"evy",fractals:"fif","internet-property-stream":"acx",olescript:"axs","vnd.ms-outlook":"msg","vnd.ms-pkicertstore":"sst","x-compress":"z","x-perfmon":["pma","pmc","pmr","pmw"],"ynd.ms-pkipko":"pko",gzip:["gz","tgz"],"smil+xml":["smi","smil"],"vnd.debian.binary-package":["deb","udeb"],"vnd.hzn-3d-crossword":"x3d","vnd.sqlite3":["db","sqlite","sqlite3","db-wal","sqlite-wal","db-shm","sqlite-shm"],"vnd.wap.sic":"sic","vnd.wap.slc":"slc","x-krita":["kra","krz"],"x-perl":["pm","pl"],yaml:["yaml","yml"]},audio:{amr:"amr","amr-wb":"awb",annodex:"axa",basic:["au","snd"],flac:"flac",midi:["mid","midi","kar","rmi"],mpeg:["mpga","mpega","mp3","m4a","mp2a","m2a","m3a"],mpegurl:"m3u",ogg:["oga","ogg","spx"],"prs.sid":"sid","x-aiff":"aifc","x-gsm":"gsm","x-ms-wma":"wma","x-ms-wax":"wax","x-pn-realaudio":"ram","x-realaudio":"ra","x-sd2":"sd2",adpcm:"adp",mp4:"mp4a",s3m:"s3m",silk:"sil","vnd.dece.audio":["uva","uvva"],"vnd.digital-winds":"eol","vnd.dra":"dra","vnd.dts":"dts","vnd.dts.hd":"dtshd","vnd.lucent.voice":"lvp","vnd.ms-playready.media.pya":"pya","vnd.nuera.ecelp4800":"ecelp4800","vnd.nuera.ecelp7470":"ecelp7470","vnd.nuera.ecelp9600":"ecelp9600","vnd.rip":"rip",webm:"weba","x-caf":"caf","x-matroska":"mka","x-pn-realaudio-plugin":"rmp",xm:"xm",aac:"aac",aiff:["aiff","aif","aff"],opus:"opus",wav:"wav"},chemical:{"x-alchemy":"alc","x-cache":["cac","cache"],"x-cache-csf":"csf","x-cactvs-binary":["cbin","cascii","ctab"],"x-cdx":"cdx","x-chem3d":"c3d","x-cif":"cif","x-cmdf":"cmdf","x-cml":"cml","x-compass":"cpa","x-crossfire":"bsd","x-csml":["csml","csm"],"x-ctx":"ctx","x-cxf":["cxf","cef"],"x-embl-dl-nucleotide":["emb","embl"],"x-gamess-input":["inp","gam","gamin"],"x-gaussian-checkpoint":["fch","fchk"],"x-gaussian-cube":"cub","x-gaussian-input":["gau","gjc","gjf"],"x-gaussian-log":"gal","x-gcg8-sequence":"gcg","x-genbank":"gen","x-hin":"hin","x-isostar":["istr","ist"],"x-jcamp-dx":["jdx","dx"],"x-kinemage":"kin","x-macmolecule":"mcm","x-macromodel-input":"mmod","x-mdl-molfile":"mol","x-mdl-rdfile":"rd","x-mdl-rxnfile":"rxn","x-mdl-sdfile":"sd","x-mdl-tgf":"tgf","x-mmcif":"mcif","x-mol2":"mol2","x-molconn-Z":"b","x-mopac-graph":"gpt","x-mopac-input":["mop","mopcrt","zmt"],"x-mopac-out":"moo","x-ncbi-asn1":"asn","x-ncbi-asn1-ascii":["prt","ent"],"x-ncbi-asn1-binary":"val","x-rosdal":"ros","x-swissprot":"sw","x-vamas-iso14976":"vms","x-vmd":"vmd","x-xtel":"xtel","x-xyz":"xyz"},font:{otf:"otf",woff:"woff",woff2:"woff2"},image:{gif:"gif",ief:"ief",jpeg:["jpeg","jpg","jpe","jfif","jfif-tbnl","jif"],pcx:"pcx",png:"png","svg+xml":["svg","svgz"],tiff:["tiff","tif"],"vnd.djvu":["djvu","djv"],"vnd.wap.wbmp":"wbmp","x-canon-cr2":"cr2","x-canon-crw":"crw","x-cmu-raster":"ras","x-coreldraw":"cdr","x-coreldrawpattern":"pat","x-coreldrawtemplate":"cdt","x-corelphotopaint":"cpt","x-epson-erf":"erf","x-icon":"ico","x-jg":"art","x-jng":"jng","x-nikon-nef":"nef","x-olympus-orf":"orf","x-portable-anymap":"pnm","x-portable-bitmap":"pbm","x-portable-graymap":"pgm","x-portable-pixmap":"ppm","x-rgb":"rgb","x-xbitmap":"xbm","x-xpixmap":"xpm","x-xwindowdump":"xwd",bmp:"bmp",cgm:"cgm",g3fax:"g3",ktx:"ktx","prs.btif":"btif",sgi:"sgi","vnd.dece.graphic":["uvi","uvvi","uvg","uvvg"],"vnd.dwg":"dwg","vnd.dxf":"dxf","vnd.fastbidsheet":"fbs","vnd.fpx":"fpx","vnd.fst":"fst","vnd.fujixerox.edmics-mmr":"mmr","vnd.fujixerox.edmics-rlc":"rlc","vnd.ms-modi":"mdi","vnd.ms-photo":"wdp","vnd.net-fpx":"npx","vnd.xiff":"xif",webp:"webp","x-3ds":"3ds","x-cmx":"cmx","x-freehand":["fh","fhc","fh4","fh5","fh7"],"x-pict":["pic","pct"],"x-tga":"tga","cis-cod":"cod",avif:"avifs",heic:["heif","heic"],pjpeg:["pjpg"],"vnd.adobe.photoshop":"psd","x-adobe-dng":"dng","x-fuji-raf":"raf","x-icns":"icns","x-kodak-dcr":"dcr","x-kodak-k25":"k25","x-kodak-kdc":"kdc","x-minolta-mrw":"mrw","x-panasonic-raw":["raw","rw2","rwl"],"x-pentax-pef":["pef","ptx"],"x-sigma-x3f":"x3f","x-sony-arw":"arw","x-sony-sr2":"sr2","x-sony-srf":"srf"},message:{rfc822:["eml","mime","mht","mhtml","nws"]},model:{iges:["igs","iges"],mesh:["msh","mesh","silo"],vrml:["wrl","vrml"],"x3d+vrml":["x3dv","x3dvz"],"x3d+xml":"x3dz","x3d+binary":["x3db","x3dbz"],"vnd.collada+xml":"dae","vnd.dwf":"dwf","vnd.gdl":"gdl","vnd.gtw":"gtw","vnd.mts":"mts","vnd.usdz+zip":"usdz","vnd.vtu":"vtu"},text:{"cache-manifest":["manifest","appcache"],calendar:["ics","icz","ifb"],css:"css",csv:"csv",h323:"323",html:["html","htm","shtml","stm"],iuls:"uls",plain:["txt","text","brf","conf","def","list","log","in","bas","diff","ksh"],richtext:"rtx",scriptlet:["sct","wsc"],texmacs:"tm","tab-separated-values":"tsv","vnd.sun.j2me.app-descriptor":"jad","vnd.wap.wml":"wml","vnd.wap.wmlscript":"wmls","x-bibtex":"bib","x-boo":"boo","x-c++hdr":["h++","hpp","hxx","hh"],"x-c++src":["c++","cpp","cxx","cc"],"x-component":"htc","x-dsrc":"d","x-diff":"patch","x-haskell":"hs","x-java":"java","x-literate-haskell":"lhs","x-moc":"moc","x-pascal":["p","pas","pp","inc"],"x-pcs-gcd":"gcd","x-python":"py","x-scala":"scala","x-setext":"etx","x-tcl":["tcl","tk"],"x-tex":["tex","ltx","sty","cls"],"x-vcalendar":"vcs","x-vcard":"vcf",n3:"n3","prs.lines.tag":"dsc",sgml:["sgml","sgm"],troff:["t","tr","roff","man","me","ms"],turtle:"ttl","uri-list":["uri","uris","urls"],vcard:"vcard","vnd.curl":"curl","vnd.curl.dcurl":"dcurl","vnd.curl.scurl":"scurl","vnd.curl.mcurl":"mcurl","vnd.dvb.subtitle":"sub","vnd.fly":"fly","vnd.fmi.flexstor":"flx","vnd.graphviz":"gv","vnd.in3d.3dml":"3dml","vnd.in3d.spot":"spot","x-asm":["s","asm"],"x-c":["c","h","dic"],"x-fortran":["f","for","f77","f90"],"x-opml":"opml","x-nfo":"nfo","x-sfv":"sfv","x-uuencode":"uu",webviewhtml:"htt",javascript:"js",json:"json",markdown:["md","markdown","mdown","markdn"],"vnd.wap.si":"si","vnd.wap.sl":"sl"},video:{avif:"avif","3gpp":"3gp",annodex:"axv",dl:"dl",dv:["dif","dv"],fli:"fli",gl:"gl",mpeg:["mpeg","mpg","mpe","m1v","m2v","mp2","mpa","mpv2"],mp4:["mp4","mp4v","mpg4"],quicktime:["qt","mov"],ogg:"ogv","vnd.mpegurl":["mxu","m4u"],"x-flv":"flv","x-la-asf":["lsf","lsx"],"x-mng":"mng","x-ms-asf":["asf","asx","asr"],"x-ms-wm":"wm","x-ms-wmv":"wmv","x-ms-wmx":"wmx","x-ms-wvx":"wvx","x-msvideo":"avi","x-sgi-movie":"movie","x-matroska":["mpv","mkv","mk3d","mks"],"3gpp2":"3g2",h261:"h261",h263:"h263",h264:"h264",jpeg:"jpgv",jpm:["jpm","jpgm"],mj2:["mj2","mjp2"],"vnd.dece.hd":["uvh","uvvh"],"vnd.dece.mobile":["uvm","uvvm"],"vnd.dece.pd":["uvp","uvvp"],"vnd.dece.sd":["uvs","uvvs"],"vnd.dece.video":["uvv","uvvv"],"vnd.dvb.file":"dvb","vnd.fvt":"fvt","vnd.ms-playready.media.pyv":"pyv","vnd.uvvu.mp4":["uvu","uvvu"],"vnd.vivo":"viv",webm:"webm","x-f4v":"f4v","x-m4v":"m4v","x-ms-vob":"vob","x-smv":"smv",mp2t:"ts"},"x-conference":{"x-cooltalk":"ice"},"x-world":{"x-vrml":["vrm","flr","wrz","xaf","xof"]}};(()=>{const e={};for(const t of Object.keys(os))for(const n of Object.keys(os[t])){const s=os[t][n];if(typeof s=="string")e[s]=t+"/"+n;else for(let A=0;A<s.length;A++)e[s[A]]=t+"/"+n}return e})();$i(Ln);var Fc=/[\u1680\u2000-\u200A\u202F\u205F\u3000]/,xc=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCA0-\uDCDF\uDCFF\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE83\uDE86-\uDE89\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]/,yc=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u08D4-\u08E1\u08E3-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u09FC\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0AF9-\u0AFF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58-\u0C5A\u0C60-\u0C63\u0C66-\u0C6F\u0C80-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D00-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D54-\u0D57\u0D5F-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19D9\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1C80-\u1C88\u1CD0-\u1CD2\u1CD4-\u1CF9\u1D00-\u1DF9\u1DFB-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u2E2F\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099\u309A\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C5\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA8FD\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2F\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDCA-\uDDCC\uDDD0-\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE37\uDE3E\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF00-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF50\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC00-\uDC4A\uDC50-\uDC59\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDDD8-\uDDDD\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9\uDF00-\uDF19\uDF1D-\uDF2B\uDF30-\uDF39]|\uD806[\uDCA0-\uDCE9\uDCFF\uDE00-\uDE3E\uDE47\uDE50-\uDE83\uDE86-\uDE99\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC36\uDC38-\uDC40\uDC50-\uDC59\uDC72-\uDC8F\uDC92-\uDCA7\uDCA9-\uDCB6\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD36\uDD3A\uDD3C\uDD3D\uDD3F-\uDD47\uDD50-\uDD59]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6\uDD00-\uDD4A\uDD50-\uDD59]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/,is={Space_Separator:Fc,ID_Start:xc,ID_Continue:yc},at={isSpaceSeparator(e){return typeof e=="string"&&is.Space_Separator.test(e)},isIdStartChar(e){return typeof e=="string"&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||e==="$"||e==="_"||is.ID_Start.test(e))},isIdContinueChar(e){return typeof e=="string"&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||e>="0"&&e<="9"||e==="$"||e==="_"||e==="‌"||e==="‍"||is.ID_Continue.test(e))},isDigit(e){return typeof e=="string"&&/[0-9]/.test(e)},isHexDigit(e){return typeof e=="string"&&/[0-9A-Fa-f]/.test(e)}};let ws,Qt,ae,Tn,Ce,qt,Bt,zs,nn;var Sc=function(t,n){ws=String(t),Qt="start",ae=[],Tn=0,Ce=1,qt=0,Bt=void 0,zs=void 0,nn=void 0;do Bt=Qc(),Mc[Qt]();while(Bt.type!=="eof");return typeof n=="function"?Fs({"":nn},"",n):nn};function Fs(e,t,n){const s=e[t];if(s!=null&&typeof s=="object")if(Array.isArray(s))for(let A=0;A<s.length;A++){const r=String(A),o=Fs(s,r,n);o===void 0?delete s[r]:Object.defineProperty(s,r,{value:o,writable:!0,enumerable:!0,configurable:!0})}else for(const A in s){const r=Fs(s,A,n);r===void 0?delete s[A]:Object.defineProperty(s,A,{value:r,writable:!0,enumerable:!0,configurable:!0})}return n.call(e,t,s)}let R,T,Ve,re,N;function Qc(){for(R="default",T="",Ve=!1,re=1;;){N=ce();const e=Lo[R]();if(e)return e}}function ce(){if(ws[Tn])return String.fromCodePoint(ws.codePointAt(Tn))}function D(){const e=ce();return e===`
3
- `?(Ce++,qt=0):e?qt+=e.length:qt++,e&&(Tn+=e.length),e}const Lo={default(){switch(N){case" ":case"\v":case"\f":case" ":case" ":case"\uFEFF":case`
4
- `:case"\r":case"\u2028":case"\u2029":D();return;case"/":D(),R="comment";return;case void 0:return D(),X("eof")}if(at.isSpaceSeparator(N)){D();return}return Lo[Qt]()},comment(){switch(N){case"*":D(),R="multiLineComment";return;case"/":D(),R="singleLineComment";return}throw Z(D())},multiLineComment(){switch(N){case"*":D(),R="multiLineCommentAsterisk";return;case void 0:throw Z(D())}D()},multiLineCommentAsterisk(){switch(N){case"*":D();return;case"/":D(),R="default";return;case void 0:throw Z(D())}D(),R="multiLineComment"},singleLineComment(){switch(N){case`
5
- `:case"\r":case"\u2028":case"\u2029":D(),R="default";return;case void 0:return D(),X("eof")}D()},value(){switch(N){case"{":case"[":return X("punctuator",D());case"n":return D(),Fe("ull"),X("null",null);case"t":return D(),Fe("rue"),X("boolean",!0);case"f":return D(),Fe("alse"),X("boolean",!1);case"-":case"+":D()==="-"&&(re=-1),R="sign";return;case".":T=D(),R="decimalPointLeading";return;case"0":T=D(),R="zero";return;case"1":case"2":case"3":case"4":case"5":case"6":case"7":case"8":case"9":T=D(),R="decimalInteger";return;case"I":return D(),Fe("nfinity"),X("numeric",1/0);case"N":return D(),Fe("aN"),X("numeric",NaN);case'"':case"'":Ve=D()==='"',T="",R="string";return}throw Z(D())},identifierNameStartEscape(){if(N!=="u")throw Z(D());D();const e=xs();switch(e){case"$":case"_":break;default:if(!at.isIdStartChar(e))throw OA();break}T+=e,R="identifierName"},identifierName(){switch(N){case"$":case"_":case"‌":case"‍":T+=D();return;case"\\":D(),R="identifierNameEscape";return}if(at.isIdContinueChar(N)){T+=D();return}return X("identifier",T)},identifierNameEscape(){if(N!=="u")throw Z(D());D();const e=xs();switch(e){case"$":case"_":case"‌":case"‍":break;default:if(!at.isIdContinueChar(e))throw OA();break}T+=e,R="identifierName"},sign(){switch(N){case".":T=D(),R="decimalPointLeading";return;case"0":T=D(),R="zero";return;case"1":case"2":case"3":case"4":case"5":case"6":case"7":case"8":case"9":T=D(),R="decimalInteger";return;case"I":return D(),Fe("nfinity"),X("numeric",re*(1/0));case"N":return D(),Fe("aN"),X("numeric",NaN)}throw Z(D())},zero(){switch(N){case".":T+=D(),R="decimalPoint";return;case"e":case"E":T+=D(),R="decimalExponent";return;case"x":case"X":T+=D(),R="hexadecimal";return}return X("numeric",re*0)},decimalInteger(){switch(N){case".":T+=D(),R="decimalPoint";return;case"e":case"E":T+=D(),R="decimalExponent";return}if(at.isDigit(N)){T+=D();return}return X("numeric",re*Number(T))},decimalPointLeading(){if(at.isDigit(N)){T+=D(),R="decimalFraction";return}throw Z(D())},decimalPoint(){switch(N){case"e":case"E":T+=D(),R="decimalExponent";return}if(at.isDigit(N)){T+=D(),R="decimalFraction";return}return X("numeric",re*Number(T))},decimalFraction(){switch(N){case"e":case"E":T+=D(),R="decimalExponent";return}if(at.isDigit(N)){T+=D();return}return X("numeric",re*Number(T))},decimalExponent(){switch(N){case"+":case"-":T+=D(),R="decimalExponentSign";return}if(at.isDigit(N)){T+=D(),R="decimalExponentInteger";return}throw Z(D())},decimalExponentSign(){if(at.isDigit(N)){T+=D(),R="decimalExponentInteger";return}throw Z(D())},decimalExponentInteger(){if(at.isDigit(N)){T+=D();return}return X("numeric",re*Number(T))},hexadecimal(){if(at.isHexDigit(N)){T+=D(),R="hexadecimalInteger";return}throw Z(D())},hexadecimalInteger(){if(at.isHexDigit(N)){T+=D();return}return X("numeric",re*Number(T))},string(){switch(N){case"\\":D(),T+=vc();return;case'"':if(Ve)return D(),X("string",T);T+=D();return;case"'":if(!Ve)return D(),X("string",T);T+=D();return;case`
6
- `:case"\r":throw Z(D());case"\u2028":case"\u2029":Tc(N);break;case void 0:throw Z(D())}T+=D()},start(){switch(N){case"{":case"[":return X("punctuator",D())}R="value"},beforePropertyName(){switch(N){case"$":case"_":T=D(),R="identifierName";return;case"\\":D(),R="identifierNameStartEscape";return;case"}":return X("punctuator",D());case'"':case"'":Ve=D()==='"',R="string";return}if(at.isIdStartChar(N)){T+=D(),R="identifierName";return}throw Z(D())},afterPropertyName(){if(N===":")return X("punctuator",D());throw Z(D())},beforePropertyValue(){R="value"},afterPropertyValue(){switch(N){case",":case"}":return X("punctuator",D())}throw Z(D())},beforeArrayValue(){if(N==="]")return X("punctuator",D());R="value"},afterArrayValue(){switch(N){case",":case"]":return X("punctuator",D())}throw Z(D())},end(){throw Z(D())}};function X(e,t){return{type:e,value:t,line:Ce,column:qt}}function Fe(e){for(const t of e){if(ce()!==t)throw Z(D());D()}}function vc(){switch(ce()){case"b":return D(),"\b";case"f":return D(),"\f";case"n":return D(),`
7
- `;case"r":return D(),"\r";case"t":return D()," ";case"v":return D(),"\v";case"0":if(D(),at.isDigit(ce()))throw Z(D());return"\0";case"x":return D(),bc();case"u":return D(),xs();case`
8
- `:case"\u2028":case"\u2029":return D(),"";case"\r":return D(),ce()===`
9
- `&&D(),"";case"1":case"2":case"3":case"4":case"5":case"6":case"7":case"8":case"9":throw Z(D());case void 0:throw Z(D())}return D()}function bc(){let e="",t=ce();if(!at.isHexDigit(t)||(e+=D(),t=ce(),!at.isHexDigit(t)))throw Z(D());return e+=D(),String.fromCodePoint(parseInt(e,16))}function xs(){let e="",t=4;for(;t-- >0;){const n=ce();if(!at.isHexDigit(n))throw Z(D());e+=D()}return String.fromCodePoint(parseInt(e,16))}const Mc={start(){if(Bt.type==="eof")throw xe();as()},beforePropertyName(){switch(Bt.type){case"identifier":case"string":zs=Bt.value,Qt="afterPropertyName";return;case"punctuator":dn();return;case"eof":throw xe()}},afterPropertyName(){if(Bt.type==="eof")throw xe();Qt="beforePropertyValue"},beforePropertyValue(){if(Bt.type==="eof")throw xe();as()},beforeArrayValue(){if(Bt.type==="eof")throw xe();if(Bt.type==="punctuator"&&Bt.value==="]"){dn();return}as()},afterPropertyValue(){if(Bt.type==="eof")throw xe();switch(Bt.value){case",":Qt="beforePropertyName";return;case"}":dn()}},afterArrayValue(){if(Bt.type==="eof")throw xe();switch(Bt.value){case",":Qt="beforeArrayValue";return;case"]":dn()}},end(){}};function as(){let e;switch(Bt.type){case"punctuator":switch(Bt.value){case"{":e={};break;case"[":e=[];break}break;case"null":case"boolean":case"numeric":case"string":e=Bt.value;break}if(nn===void 0)nn=e;else{const t=ae[ae.length-1];Array.isArray(t)?t.push(e):Object.defineProperty(t,zs,{value:e,writable:!0,enumerable:!0,configurable:!0})}if(e!==null&&typeof e=="object")ae.push(e),Array.isArray(e)?Qt="beforeArrayValue":Qt="beforePropertyName";else{const t=ae[ae.length-1];t==null?Qt="end":Array.isArray(t)?Qt="afterArrayValue":Qt="afterPropertyValue"}}function dn(){ae.pop();const e=ae[ae.length-1];e==null?Qt="end":Array.isArray(e)?Qt="afterArrayValue":Qt="afterPropertyValue"}function Z(e){return Yn(e===void 0?`JSON5: invalid end of input at ${Ce}:${qt}`:`JSON5: invalid character '${Go(e)}' at ${Ce}:${qt}`)}function xe(){return Yn(`JSON5: invalid end of input at ${Ce}:${qt}`)}function OA(){return qt-=5,Yn(`JSON5: invalid identifier character at ${Ce}:${qt}`)}function Tc(e){console.warn(`JSON5: '${Go(e)}' in strings is not valid ECMAScript; consider escaping`)}function Go(e){const t={"'":"\\'",'"':'\\"',"\\":"\\\\","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r"," ":"\\t","\v":"\\v","\0":"\\0","\u2028":"\\u2028","\u2029":"\\u2029"};if(t[e])return t[e];if(e<" "){const n=e.charCodeAt(0).toString(16);return"\\x"+("00"+n).substring(n.length)}return e}function Yn(e){const t=new SyntaxError(e);return t.lineNumber=Ce,t.columnNumber=qt,t}var Yc=function(t,n,s){const A=[];let r="",o,i,a="",u;if(n!=null&&typeof n=="object"&&!Array.isArray(n)&&(s=n.space,u=n.quote,n=n.replacer),typeof n=="function")i=n;else if(Array.isArray(n)){o=[];for(const f of n){let h;typeof f=="string"?h=f:(typeof f=="number"||f instanceof String||f instanceof Number)&&(h=String(f)),h!==void 0&&o.indexOf(h)<0&&o.push(h)}}return s instanceof Number?s=Number(s):s instanceof String&&(s=String(s)),typeof s=="number"?s>0&&(s=Math.min(10,Math.floor(s)),a=" ".substr(0,s)):typeof s=="string"&&(a=s.substr(0,10)),c("",{"":t});function c(f,h){let p=h[f];switch(p!=null&&(typeof p.toJSON5=="function"?p=p.toJSON5(f):typeof p.toJSON=="function"&&(p=p.toJSON(f))),i&&(p=i.call(h,f,p)),p instanceof Number?p=Number(p):p instanceof String?p=String(p):p instanceof Boolean&&(p=p.valueOf()),p){case null:return"null";case!0:return"true";case!1:return"false"}if(typeof p=="string")return g(p);if(typeof p=="number")return String(p);if(typeof p=="object")return Array.isArray(p)?d(p):l(p)}function g(f){const h={"'":.1,'"':.2},p={"'":"\\'",'"':'\\"',"\\":"\\\\","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r"," ":"\\t","\v":"\\v","\0":"\\0","\u2028":"\\u2028","\u2029":"\\u2029"};let E="";for(let I=0;I<f.length;I++){const w=f[I];switch(w){case"'":case'"':h[w]++,E+=w;continue;case"\0":if(at.isDigit(f[I+1])){E+="\\x00";continue}}if(p[w]){E+=p[w];continue}if(w<" "){let m=w.charCodeAt(0).toString(16);E+="\\x"+("00"+m).substring(m.length);continue}E+=w}const C=u||Object.keys(h).reduce((I,w)=>h[I]<h[w]?I:w);return E=E.replace(new RegExp(C,"g"),p[C]),C+E+C}function l(f){if(A.indexOf(f)>=0)throw TypeError("Converting circular structure to JSON5");A.push(f);let h=r;r=r+a;let p=o||Object.keys(f),E=[];for(const I of p){const w=c(I,f);if(w!==void 0){let m=B(I)+":";a!==""&&(m+=" "),m+=w,E.push(m)}}let C;if(E.length===0)C="{}";else{let I;if(a==="")I=E.join(","),C="{"+I+"}";else{let w=`,
10
- `+r;I=E.join(w),C=`{
11
- `+r+I+`,
12
- `+h+"}"}}return A.pop(),r=h,C}function B(f){if(f.length===0)return g(f);const h=String.fromCodePoint(f.codePointAt(0));if(!at.isIdStartChar(h))return g(f);for(let p=h.length;p<f.length;p++)if(!at.isIdContinueChar(String.fromCodePoint(f.codePointAt(p))))return g(f);return f}function d(f){if(A.indexOf(f)>=0)throw TypeError("Converting circular structure to JSON5");A.push(f);let h=r;r=r+a;let p=[];for(let C=0;C<f.length;C++){const I=c(String(C),f);p.push(I!==void 0?I:"null")}let E;if(p.length===0)E="[]";else if(a==="")E="["+p.join(",")+"]";else{let C=`,
13
- `+r,I=p.join(C);E=`[
14
- `+r+I+`,
15
- `+h+"]"}return A.pop(),r=h,E}};const Pc={parse:Sc,stringify:Yc};var Rc=Pc,Vs=10**-4;function qg(e){return e*Math.PI/180}function Tt(e){return 180*e/Math.PI}function J(e){let t=e;return Math.abs(t)<Vs&&(t=0),t}function ge(e){let t=e%(2*Math.PI);return t<0&&(t+=2*Math.PI),t}function At(e){let t=ge(e);return t>Math.PI&&(t-=2*Math.PI),t}function Xt(e){let t=e%Math.PI;return t<0&&(t+=Math.PI),t}function Pt(e){let t=Xt(e);return t>Math.PI/2&&(t-=Math.PI),t}function ys(e,t,n){const s=At(t)-At(e);return n?ge(s):ge(s)-2*Math.PI}function No(e,t,n,s){let A=!1;if(J(At(e-t))===0)A=!0;else if(J(At(e-n))===0)A=!0;else{const r=ys(t,n,s),o=ys(t,e,s);Math.abs(o)<Math.abs(r)&&(A=!0)}return A}function te(e){return e.toFixed(2)}var it={point:"grey",line:"grey",contour:"green",mainOuter:"SlateBlue",mainInner:"SteelBlue",mainB:"SlateGrey",second:"Violet",secondB:"SlateGrey",dynamics:"Tomato",ruler:"blue",origin:"red",reference:"blue",mouse:"yellow"},Le=.05;function ve(e,t,n){const s=n.shiftX+(e-n.xMin)*n.scaleX,A=n.shiftY+(t-n.yMin)*n.scaleY;return[s,A]}function zg(e,t,n){const s=(e-n.shiftX)/n.scaleX+n.xMin,A=(t-n.shiftY)/n.scaleY+n.yMin;return[s,A]}function Uo(e,t){if(J(t.scaleX-Math.abs(t.scaleY))!==0)throw`err683: iAdjust.scaleX and scaleY differ ${t.scaleX} ${t.scaleY}`;if(t.scaleX<0)throw`err684: iAdjust.scaleX ${t.scaleX} is negative`;const n=e*t.scaleX;if(n<0)throw`err685: rRadius for canvas ${n} is negative`;return n}function Ss(){return{init:0,xMin:0,yMin:0,xyDiff:1,shiftX:0,shiftY:0,scaleX:1,scaleY:1}}function Nn(e){return{init:e.init,xMin:e.xMin,yMin:e.yMin,xyDiff:e.xyDiff,shiftX:e.shiftX,shiftY:e.shiftY,scaleX:e.scaleX,scaleY:e.scaleY}}function Qs(e,t,n,s,A,r){const o=Ss(),i=Math.max(t-e,1),a=Math.max(s-n,1),u=A/i,c=r/a;let g=.9*u,l=i;return c<u&&(g=.9*c,l=a),o.init=1,o.xMin=e,o.yMin=n,o.xyDiff=l,o.shiftX=Le*A,o.scaleX=g,o.shiftY=r-Le*r,o.scaleY=-1*g,o}function Vg(e,t,n){const s=Nn(n);return s.xMin=e-s.xyDiff/2,s.yMin=t-s.xyDiff/2,s}function jg(e,t,n,s,A,r){const o=Math.min(e,n),i=Math.max(e,n),a=Math.min(t,s),u=Math.max(t,s);return Qs(o,i,a,u,A,r)}function $g(e,t){const n=Nn(t),s=(1-e)/2;return n.xMin+=s*t.xyDiff,n.yMin+=s*t.xyDiff,n.xyDiff*=e,n.scaleX*=1/e,n.scaleY*=1/e,n}function Xg(e,t,n,s,A){const r=Nn(A),o=n-e,i=s-t;return r.xMin+=-o,r.yMin+=-i,r}function Zg(e,t,n){const s=Nn(n);if(e>0&&t>0){const A=e/t;s.xyDiff*=A,s.scaleX*=1/A,s.scaleY*=1/A,s.shiftX+=Le*t-Le*e,s.shiftY+=(1-Le)*t-(1-Le)*e}return s}function Un(e,t){let n=0;if(t>e)throw`err539: ila < ilc ${e} ${t}`;return n=Math.sqrt(e**2-t**2),n}function kA(e,t,n){let s=0;const A=[e,t,n];for(let o=0;o<A.length;o++)if(A[o]<0)throw`err209: l3[${o}] = ${A[o]}`;const r=A.sort(function(o,i){return i-o});if(r[0]>r[1]+r[2])throw`err839: impossible triangle with length ${e}, ${t} and ${n}`;return s=Math.acos((e**2+t**2-n**2)/(2*e*t)),s}function _A(e,t,n){let s=0;const A=[e,t,n];for(let a=0;a<A.length;a++)if(J(A[a])===0||A[a]<0)throw`err329: negative or zero triangle-args ${a} : ${A[a]}`;const r=Xt(t),o=Xt(n);if(r+o>Math.PI)throw`err939: impossible triangle with angles ${t} and ${n}`;return s=e*Math.sin(n)/Math.sin(t),s}var Nt=class ke{cx;cy;shape;constructor(t,n,s=0){this.cx=t,this.cy=n,this.shape=s}draw(t,n,s=it.point,A=0){if(isFinite(this.cx)&&isFinite(this.cy)){const r=t.canvas.width*.006999999999999999,o=2*r,[i,a]=ve(this.cx,this.cy,n);let u=A;switch(u===0&&(u=this.shape),t.beginPath(),u){case 2:t.moveTo(i-o,a),t.lineTo(i+o,a),t.moveTo(i,a-o),t.lineTo(i,a+o);break;case 3:t.rect(i-r,a-r,2*r,2*r);break;case 4:t.rect(i-2*r,a-2*r,4*r,4*r);break;case 5:t.moveTo(i-o,a),t.lineTo(i+o,a),t.lineTo(i,a+o),t.lineTo(i,a-o),t.lineTo(i-o,a);break;case 6:t.moveTo(i-o,a),t.lineTo(i+o,a),t.lineTo(i,a-o),t.lineTo(i,a+o);break;case 7:t.moveTo(i+o,a),t.lineTo(i-o,a),t.lineTo(i,a-o),t.lineTo(i,a+o);break;case 8:t.moveTo(i+o,a),t.lineTo(i-o,a),t.lineTo(i,a+o),t.lineTo(i,a-o);break;case 9:t.moveTo(i-o,a),t.lineTo(i+o,a),t.lineTo(i,a+o),t.lineTo(i,a-o);break;case 1:default:t.arc(i,a,r,0,2*Math.PI)}t.strokeStyle=s,t.stroke()}else console.log(`INFO489: point not draw because of infinity ${this.cx} ${this.cy}`)}distanceOrig(){return Math.sqrt(this.cx**2+this.cy**2)}angleOrig(){return Math.atan2(this.cy,this.cx)}getPolar(){return[this.angleOrig(),this.distanceOrig()]}setPolar(t,n){return new ke(n*Math.cos(t),n*Math.sin(t))}translate(t,n){return new ke(this.cx+t,this.cy+n)}translatePolar(t,n){return new ke(this.cx+n*Math.cos(t),this.cy+n*Math.sin(t))}clone(t=0){return new ke(this.cx,this.cy,t)}rotateOrig(t){const n=this.getPolar();return this.setPolar(n[0]+t,n[1])}scaleOrig(t){const n=this.getPolar();return this.setPolar(n[0],n[1]*t)}rotate(t,n){const A=this.translate(-1*t.cx,-1*t.cy).getPolar();return this.setPolar(A[0]+n,A[1]).translate(t.cx,t.cy)}scale(t,n){const A=this.translate(-1*t.cx,-1*t.cy).getPolar();return this.setPolar(A[0],A[1]*n).translate(t.cx,t.cy)}isEqual(t){return J(this.cx-t.cx)===0&&J(this.cy-t.cy)===0}distanceToPoint(t){return Math.sqrt((t.cx-this.cx)**2+(t.cy-this.cy)**2)}angleToPoint(t){if(J(this.distanceToPoint(t))===0)throw`err434: no angle because points identical ${this.cx} ${t.cx} ${this.cy} ${t.cy}`;return Math.atan2(t.cy-this.cy,t.cx-this.cx)}angleFromToPoints(t,n){const s=this.angleToPoint(t),A=this.angleToPoint(n);return At(A-s)}middlePoint(t){const n=(this.cx+t.cx)/2,s=(this.cy+t.cy)/2;return new ke(n,s)}equidistantPoint(t,n,s){const A=this.distanceToPoint(t)/2;if(this.isEqual(t))throw`err633: no equidistance because identical point ${this.cx} ${this.cy}`;if(n<A)throw`err392: equidistance ${n} smaller than lp1p2h ${A}`;const r=this.middlePoint(t),o=this.angleToPoint(t)+Math.PI/2,i=Math.sqrt(n**2-A**2),a=r.translatePolar(o,i),u=r.translatePolar(o+Math.PI,i),c=s.distanceToPoint(a),g=s.distanceToPoint(u);if(i!==0&&c===g)throw`err284: magnet point p3 is on line p1p2. cx ${s.cx} cy: ${s.cy}`;let l=a;return g<c&&(l=u),l}};function O(e,t,n=0){return new Nt(e,t,n)}function Ho(e){let t=0,n=0,s=0,A=0;if(e.length>0){const r=e[0];if(r.cx===Number.NEGATIVE_INFINITY||r.cx===Number.POSITIVE_INFINITY||r.cy===Number.NEGATIVE_INFINITY||r.cy===Number.POSITIVE_INFINITY)throw`err292: pointMinMax first point with infinity: ${r.cx} ${r.cy}`;t=e[0].cx,n=e[0].cx,s=e[0].cy,A=e[0].cy;for(const o of e)o.cx!==Number.NEGATIVE_INFINITY&&(t=Math.min(t,o.cx)),o.cx!==Number.POSITIVE_INFINITY&&(n=Math.max(n,o.cx)),o.cy!==Number.NEGATIVE_INFINITY&&(s=Math.min(s,o.cy)),o.cy!==Number.POSITIVE_INFINITY&&(A=Math.max(A,o.cy))}return[t,n,s,A]}var Oc=class Mt{cx;cy;ca;constructor(t,n,s){this.cx=t,this.cy=n,this.ca=s}draw(t,n,s=it.line){const A=t.canvas.width*2,[r,o]=ve(this.cx-A*Math.cos(this.ca),this.cy-A*Math.sin(this.ca),n),[i,a]=ve(this.cx+2*A*Math.cos(this.ca),this.cy+2*A*Math.sin(this.ca),n);t.beginPath(),t.moveTo(r,o),t.lineTo(i,a),t.strokeStyle=s,t.stroke()}setFromPoints(t,n){return this.cx=t.cx,this.cy=t.cy,this.ca=t.angleToPoint(n),this}getAffine(){const t={quasiVertical:!1,ha:0,hb:0,va:0,vb:0};return Math.abs(Pt(this.ca))>Math.PI/4?(t.quasiVertical=!0,t.va=-1*Math.tan(Pt(this.ca-Math.PI/2)),t.vb=this.cx-t.va*this.cy):(t.ha=Math.tan(Pt(this.ca)),t.hb=this.cy-t.ha*this.cx),t}setAffine(t){const n=new Mt(0,0,0);return t.quasiVertical?(n.ca=Math.PI/2-Math.atan(t.va),n.cx=t.vb,n.cy=0):(n.ca=Math.atan(t.ha),n.cx=0,n.cy=t.hb),n}intersection(t){if(this.isParallel(t))throw`err902: no intersection, lines are parallel ca1: ${this.ca} ca2: ${t.ca}`;let n=0,s=0;const A=this.getAffine(),r=t.getAffine();return A.quasiVertical?r.quasiVertical?(s=(A.vb-r.vb)/(r.va-A.va),n=A.va*s+A.vb):(n=(A.va*r.hb+A.vb)/(1-A.va*r.ha),s=r.ha*n+r.hb):r.quasiVertical?(s=(A.ha*r.vb+A.hb)/(1-A.ha*r.va),n=r.va*s+r.vb):(n=(A.hb-r.hb)/(r.ha-A.ha),s=A.ha*n+A.hb),O(n,s)}getAxisXIntersection(){const t=new Mt(0,0,0);return this.intersection(t).cx}getAxisYIntersection(){const t=new Mt(0,0,Math.PI/2);return this.intersection(t).cy}getAxisXIntersecTri(){let t=1/0;if(J(Pt(this.ca))!==0){const n=new Nt(this.cx,this.cy),s=Xt(this.ca),A=n.angleOrig(),r=n.distanceOrig();if(J(r)===0)t=0;else if(J(Pt(s-A))===0)t=0;else{const o=Math.min(s,Math.PI-s),i=At(s-A),a=Math.min(Math.abs(i),Math.PI-Math.abs(i));t=Math.sign(i)*_A(r,o,a)}}return t}getAxisYIntersecTri(){let t=1/0;if(J(Pt(this.ca-Math.PI/2))!==0){const n=new Nt(this.cx,this.cy),s=Pt(this.ca),A=n.angleOrig(),r=n.distanceOrig(),o=Pt(s-A);if(J(r)===0)t=0;else if(J(o)===0)t=0;else{const i=Xt(s-Math.PI/2),a=-1*At(s-A),u=Math.min(i,Math.PI-i),c=Math.min(Math.abs(a),Math.PI-Math.abs(a));t=Math.sign(a)*_A(r,u,c)}}return t}angleOrig(){const n=new Nt(this.cx,this.cy).angleOrig(),s=Pt(this.ca),A=-1*At(s-n);let r=0;return A<0&&(r=-Math.PI),Xt(Math.PI/2+this.ca)+r}distanceOrig(){const t=this.angleOrig(),n=new Nt(this.cx,this.cy),s=n.angleOrig(),A=n.distanceOrig(),r=Pt(s-t);return A*Math.cos(r)}projectOrig(){const t=this.angleOrig(),n=this.distanceOrig();return O(0,0).setPolar(t,n)}translate(t,n){return new Mt(this.cx+t,this.cy+n,this.ca)}rotateOrig(t){const n=new Nt(this.cx,this.cy).rotateOrig(t);return new Mt(n.cx,n.cy,At(this.ca+t))}scaleOrig(t){const n=new Nt(this.cx,this.cy).scaleOrig(t);return new Mt(n.cx,n.cy,this.ca)}rotate(t,n){const s=new Nt(this.cx,this.cy).rotate(t,n);return new Mt(s.cx,s.cy,At(this.ca+n))}scale(t,n){const s=new Nt(this.cx,this.cy).scale(t,n);return new Mt(s.cx,s.cy,this.ca)}clone(){const t=new Nt(this.cx,this.cy);return new Mt(t.cx,t.cy,this.ca)}lineOrthogonal(t){return new Mt(t.cx,t.cy,this.ca+Math.PI/2)}lineParallel(t){return new Mt(t.cx,t.cy,this.ca)}distanceToPoint(t){let n=0;const s=new Nt(this.cx,this.cy),A=s.distanceToPoint(t);if(J(A)!==0){const r=s.angleToPoint(t),o=Pt(r-this.ca);n=A*Math.abs(Math.sin(o))}return n}projectPoint(t){let n=0;const s=new Nt(this.cx,this.cy),A=s.distanceToPoint(t);if(J(A)!==0){const o=s.angleToPoint(t),i=At(o-this.ca);n=A*Math.cos(i)}return s.translatePolar(this.ca,n)}isParallel(t){return J(Pt(this.ca-t.ca))===0}isOrthogonal(t){return J(Pt(Math.PI/2+this.ca-t.ca))===0}isEqual(t){const n=O(t.cx,t.cy),s=this.distanceToPoint(n);return J(s)===0&&this.isParallel(t)}bisector(t,n){const s=this.intersection(t),A=Xt(this.ca),r=Xt(t.ca),o=Math.min(A,r),i=Math.max(A,r),a=[o,i,o+Math.PI,i+Math.PI,o],u=s.angleToPoint(n);let c=0;for(let B=0;B<4;B++){const d=At(a[B]-u),f=At(a[B+1]-u);if(d===0||f===0)throw`err419: bad reference point for bisecor ${n.cx} ${n.cy}`;d<0&&f>0&&(c=B)}const l=Xt((o+i)/2)+c*Math.PI/2;return new Mt(s.cx,s.cy,l)}lineParallelDistance(t,n,s){const A=O(this.cx,this.cy),r=A.translatePolar(this.ca+Math.PI/2,t),o=A.translatePolar(this.ca-Math.PI/2,t);let i=o,a=n;return J(this.distanceToPoint(a))===0&&(a=s),a.distanceToPoint(r)<a.distanceToPoint(o)&&(i=r),new Mt(i.cx,i.cy,this.ca)}};function Hn(e,t,n){return new Oc(e,t,n)}function an(e,t){return Hn(0,0,0).setFromPoints(e,t)}function vs(e,t){if(e.isEqual(t))throw`err546: no bisector with two same points cx: ${e.cx} cy: ${e.cy}`;const n=e.middlePoint(t),s=Xt(e.angleToPoint(t)+Math.PI/2);return Hn(n.cx,n.cy,s)}function kc(e,t,n){if(e.isEqual(t)||t.isEqual(n)||e.isEqual(n))throw`err833: no bisector with two same points cx: ${e.cx} cy: ${e.cy}`;const s=vs(e,t),A=vs(t,n);return s.intersection(A)}function Wt(e){let t=!1;return(e===0||e===1)&&(t=!0),t}function ze(e){let t=!1;return(Wt(e)||e===6)&&(t=!0),t}function In(e){let t=!1;return(e===3||e===4||e===5)&&(t=!0),t}function fn(e){let t=!1;return(e===2||In(e))&&(t=!0),t}var Ut=class Ko{sType;px;py;radius;arcLarge;arcCcw;constructor(t,n,s,A,r=!1,o=!1){this.sType=t,this.px=n,this.py=s,this.radius=A,this.arcLarge=r,this.arcCcw=o}clone(){return new Ko(this.sType,this.px,this.py,this.radius,this.arcLarge,this.arcCcw)}},Kt=class{sType;p1;p2;pc;radius;a1;a2;arcCcw;constructor(e,t,n,s,A,r,o,i=!1){this.sType=e,this.p1=t,this.p2=n,this.pc=s,this.radius=A,this.a1=r,this.a2=o,this.arcCcw=i}},_c=class{debugPoints;debugLines;logMessage;constructor(){this.debugPoints=[],this.debugLines=[],this.logMessage=""}addPoint(e){this.debugPoints.push(e)}getPoints(){return this.debugPoints}clearPoints(){this.debugPoints=[]}addLine(e){this.debugLines.push(e)}getLines(){return this.debugLines}clearLines(){this.debugLines=[]}addMsg(e){this.logMessage+=e}getMsg(){return this.logMessage}clearMsg(){this.logMessage=""}},Be=new _c;function Ee(e,t,n){if(n.sType!==1)throw`err202: arcSeg1To2 has unexpected type ${n.sType}`;const s=O(e,t),A=O(n.px,n.py),r=s.distanceToPoint(A)/2;if(s.isEqual(A))throw`err638: no equidistance because identical point ${s.cx} ${A.cy}`;let o=0;if(J(n.radius-r)===0)o=0;else{if(n.radius<r)throw`err399: radius ${n.radius} smaller than lp1p2h ${r}`;o=Un(n.radius,r)}const i=s.middlePoint(A),a=s.angleToPoint(A)+Math.PI/2,u=i.translatePolar(a,o),c=i.translatePolar(a+Math.PI,o);let g=u;(!n.arcLarge&&!n.arcCcw||n.arcLarge&&n.arcCcw)&&(g=c);const l=g.angleToPoint(s),B=g.angleToPoint(A);return new Kt(1,s,A,g,n.radius,l,B,n.arcCcw)}function Lc(e){let t=ge(e.a2-e.a1);e.arcCcw||(t=2*Math.PI-t);let n=!1;return t>Math.PI&&(n=!0),new Ut(1,e.p2.cx,e.p2.cy,e.radius,n,e.arcCcw)}function Gc(e,t,n){const s=e.p1,A=e.p2,r=n.p1,o=n.p2;if(!A.isEqual(r))throw`err309: makeCorner-prepare p2 and p2b differ px ${A.cx} ${r.cx} py ${A.cy} ${r.cy}`;let i=A.angleToPoint(s);if(e.sType===1){const f=e.arcCcw?1:-1;i=e.a2-f*Math.PI/2}let a=A.angleToPoint(o);if(n.sType===1){const f=n.arcCcw?1:-1;a=n.a1+f*Math.PI/2}const u=a-i;let g=At(u)/2;if(J(g)===0){const f=Vs*.01;if(e.sType===0&&n.sType===1)g=n.arcCcw?f:-f;else if(e.sType===1&&n.sType===0)g=e.arcCcw?f:-f;else if(e.sType===0&&n.sType===0)throw`err402: prepare aPeakHalf too closed to zero ${g}`}const l=i+g,B=A.translatePolar(l,t.radius);return{s1:e,s2:t,s3:n,ra:t.radius,p1:s,p2:A,p3:o,p4:e.pc,p5:n.pc,p6:B,at1:i,at3:a,abi:l,aph:g}}function Pn(e,t,n){if(t.sType!==1)throw`err510: modifRadius with wrong type ${t.sType}`;const s=e>0?1:-1,A=t.arcCcw?1:-1,r=J(e)===0?1:s*A,o=t.radius+r*n;if(o<=0)throw`err621: modifRadius with negative modified lenght ${o}`;return o}function js(e,t,n,s){const A=n.translatePolar(e,t),r=n.translatePolar(e+Math.PI,t),o=s.distanceToPoint(A),i=s.distanceToPoint(r);return o<i?A:r}function LA(e,t,n,s,A){const r=e.translatePolar(t-n,s),o=e.translatePolar(t+n,s),i=A.distanceToPoint(r),a=A.distanceToPoint(o);return i<a?-1:1}function Kn(e,t){const n=t.clone(),s=e.p1.clone(),A=e.p2;if(e.sType!==0)throw`err103: newStrokeFirst unexpected sType ${e.sType}`;const r=an(s,A).distanceToPoint(n);if(J(r)!==0)throw`err104: newStrokeFirst new point not aligned ${r} ${n.cx} ${n.cy}`;const o=s.angleToPoint(A),i=s.angleToPoint(n);if(J(At(i-o))!==0)throw`err105: newStrokeFirst new point miss aligned ${o} ${i} ${n.cx} ${n.cy}`;const a=s.distanceToPoint(n),u=s.distanceToPoint(A);if(u<a)throw`err106: newStrokeFirst new point out of scope ${u} ${a} ${n.cx} ${n.cy}`;const c=O(0,0);return new Kt(0,s,n,c,0,0,0,!1)}function Jn(e,t){const n=t.clone(),s=e.p2.clone(),A=e.p1;if(e.sType!==0)throw`err203: newStrokeSecond unexpected sType ${e.sType}`;const r=an(s,A).distanceToPoint(n);if(J(r)!==0)throw`err204: newStrokeSecond new point not aligned ${r} ${n.cx} ${n.cy}`;const o=s.angleToPoint(A),i=s.angleToPoint(n);if(J(At(i-o))!==0)throw`err205: newStrokeSecond new point miss aligned ${o} ${i} ${n.cx} ${n.cy}`;const a=s.distanceToPoint(n),u=s.distanceToPoint(A);if(u<a)throw`err206: newStrokeSecond new point out of scope ${u} ${a} ${n.cx} ${n.cy}`;const c=O(0,0);return new Kt(0,n,s,c,0,0,0,!1)}function Wn(e,t){if(e.sType!==1)throw`err203: newArcFirst unexpected sType ${e.sType}`;const n=e.p1.clone(),s=e.pc.clone(),A=t.clone(),r=s.angleToPoint(A);if(!No(r,e.a1,e.a2,e.arcCcw))throw`err908: newArcFirst a48 out of scope ${r} ${e.a1} ${e.a2} ${e.arcCcw}`;return new Kt(1,n,A,s,e.radius,e.a1,r,e.arcCcw)}function qn(e,t){if(e.sType!==1)throw`err204: newArcSecond unexpected sType ${e.sType}`;const n=e.p2.clone(),s=e.pc.clone(),A=t.clone(),r=s.angleToPoint(A);if(!No(r,e.a1,e.a2,e.arcCcw))throw`err907: newArcSecond a59 out of scope ${r} ${e.a1} ${e.a2} ${e.arcCcw}`;return new Kt(1,A,n,s,e.radius,r,e.a2,e.arcCcw)}function un(e,t,n,s,A,r){const o=e.clone(),i=t.clone(),a=n.clone(),u=a.distanceToPoint(o),c=a.distanceToPoint(i);if(J(u-s)!==0||J(c-s)!==0)throw`err610: newRounded not on circle ${s} ${u} ${c}`;const g=a.angleToPoint(o),l=a.angleToPoint(i),B=At(g-r+Math.PI),d=At(l-r+Math.PI);Math.abs(d-B)>Math.PI+Vs&&Be.addMsg(`warn882: newRounded a873 or a972 larger than PI/2 ${te(B)} ${te(d)} at ${te(a.cx)} ${te(a.cy)}
16
- `);const f=!(A>0);return new Kt(1,o,i,a,s,g,l,f)}function Nc(e){const t=Math.abs(e.ra/Math.sin(e.aph)),n=t*Math.cos(e.aph),s=e.p2.translatePolar(e.abi,t),A=e.p2.translatePolar(e.at1,n),r=e.p2.translatePolar(e.at3,n),o=[];return o.push(Kn(e.s1,A)),o.push(un(A,r,s,e.ra,e.aph,e.abi)),o.push(Jn(e.s3,r)),o}function Uc(e){const n=an(e.p1,e.p2).lineParallelDistance(e.ra,e.p6,e.p5),s=n.projectPoint(e.p5),A=s.distanceToPoint(e.p5),r=Pn(e.aph,e.s3,e.ra),o=Un(r,A),i=js(n.ca,o,s,e.p6),a=e.p5.angleToPoint(i),u=e.p5.translatePolar(a,e.s3.radius),c=e.p2.angleFromToPoints(e.p1,i),l=Math.abs(e.ra/Math.sin(c))*Math.cos(c),B=e.p2.angleToPoint(e.p1),d=e.p2.translatePolar(B,l),f=[];return f.push(Kn(e.s1,d)),f.push(un(d,u,i,e.ra,e.aph,e.abi)),f.push(qn(e.s3,u)),f}function Hc(e){const n=an(e.p3,e.p2).lineParallelDistance(e.ra,e.p6,e.p4),s=n.projectPoint(e.p4),A=s.distanceToPoint(e.p4),r=Pn(e.aph,e.s1,e.ra),o=Un(r,A),i=js(n.ca,o,s,e.p6),a=e.p4.angleToPoint(i),u=e.p4.translatePolar(a,e.s1.radius),c=e.p2.angleFromToPoints(e.p3,i),l=Math.abs(e.ra/Math.sin(c))*Math.cos(c),B=e.p2.angleToPoint(e.p3),d=e.p2.translatePolar(B,l),f=[];return f.push(Wn(e.s1,u)),f.push(un(u,d,i,e.ra,e.aph,e.abi)),f.push(Jn(e.s3,d)),f}function Kc(e){const t=Pn(e.aph,e.s1,e.ra),n=Pn(e.aph,e.s3,e.ra),s=e.p4.distanceToPoint(e.p5),A=e.p4.angleToPoint(e.p5),r=kA(s,t,n),o=LA(e.p4,A,r,t,e.p6),i=A+o*r,a=e.p4.translatePolar(i,t),u=e.p4.translatePolar(i,e.s1.radius),c=Math.PI+A,g=kA(s,n,t),l=LA(e.p5,c,g,n,e.p6),B=c+l*g,d=e.p5.translatePolar(B,n);if(!d.isEqual(a))throw`err909: roundArcArc p7 anf p7b differ ${a.cx} ${d.cx} ${a.cy} ${d.cy} 0`;const f=e.p5.translatePolar(B,e.s3.radius),h=[];return h.push(Wn(e.s1,u)),h.push(un(u,f,a,e.ra,e.aph,e.abi)),h.push(qn(e.s3,f)),h}function Jo(e){const t=e.abi-2*e.aph,n=e.abi+2*e.aph;let s=e.p6.translatePolar(t,e.ra),A=e.p6.translatePolar(n,e.ra);if(e.s1.sType===1){const a=e.p4.angleFromToPoints(e.p2,e.p6),c=e.p4.angleToPoint(e.p2)+2*a;s=e.p4.translatePolar(c,e.s1.radius)}if(e.s3.sType===1){const a=e.p5.angleFromToPoints(e.p2,e.p6),c=e.p5.angleToPoint(e.p2)+2*a;A=e.p5.translatePolar(c,e.s3.radius)}const r=!(e.aph>0),o=new Kt(1,s,A,e.p6,e.ra,t,n,r),i=[];return e.s1.sType===0?i.push(Kn(e.s1,s)):e.s1.sType===1&&i.push(Wn(e.s1,s)),i.push(o),e.s3.sType===0?i.push(Jn(e.s3,A)):e.s3.sType===1&&i.push(qn(e.s3,A)),i}function GA(e,t,n,s){let A=n,r=n;const o=s.p6.angleFromToPoints(s.p2,n);if(Math.abs(o)>Math.PI/2){r=s.p6.translatePolar(s.abi+e*Math.PI/2,s.ra);const i=Hn(r.cx,r.cy,s.abi);if(t.sType===0)A=an(t.p1,t.p2).intersection(i);else if(t.sType===1){const a=i.projectPoint(t.pc),u=a.distanceToPoint(t.pc);if(u<t.radius){const c=Un(t.radius,u);A=js(s.abi,c,a,n)}else Be.addMsg(`warn222: wideAccess not possible on arc ${te(t.radius)} ${te(u)} at ${te(n.cx)} ${te(n.cy)}
17
- `),A=n,r=n}}return[A,r]}function Jc(e){const t=Jo(e),n=t[1].arcCcw?1:-1,[s,A]=GA(n,e.s1,t[1].p1,e),[r,o]=GA(-n,e.s3,t[1].p2,e),i=[];if(s.isEqual(A))i.push(t[0]);else{e.s1.sType===0?i.push(Kn(e.s1,s)):e.s1.sType===1&&i.push(Wn(e.s1,s));const a=O(0,0),u=new Kt(0,s,A,a,0,0,0,!1);i.push(u)}if(i.push(un(A,o,e.p6,e.ra,e.aph,e.abi)),r.isEqual(o))i.push(t[2]);else{const a=O(0,0),u=new Kt(0,o,r,a,0,0,0,!1);i.push(u),e.s3.sType===0?i.push(Jn(e.s3,r)):e.s3.sType===1&&i.push(qn(e.s3,r))}return i}function NA(e,t,n){const s=Gc(e,t,n),A=[];if(t.sType===3)if(e.sType===0&&n.sType===0)A.push(...Nc(s));else if(e.sType===0&&n.sType===1)A.push(...Uc(s));else if(e.sType===1&&n.sType===0)A.push(...Hc(s));else if(e.sType===1&&n.sType===1)A.push(...Kc(s));else throw`err123: makeCorner unexpected s1s3.sType ${e.sType} ${n.sType}`;else if(t.sType===4)A.push(...Jo(s));else if(t.sType===5)A.push(...Jc(s));else throw`err723: makeCorner unexpected s2.sType ${t.sType}`;return A}function $t(e){return e.toFixed(4)}function Wc(e,t,n,s=""){let A=s;return A===""&&(A="black"),`<circle cx="${$t(e)}" cy="${$t(t)}" r="${$t(n)}" stroke="${A}" stroke-width="1" fill="none" />`}var qc=class{pathD;constructor(){this.pathD=""}addStart(e,t){this.pathD=`M ${$t(e)} ${$t(t)}`}addStroke(e,t){this.pathD+=` L ${$t(e)} ${$t(t)}`}addArc(e,t,n,s,A){const r=$t(n),o=s?1:0,i=A?1:0;this.pathD+=` A ${r} ${r} 0 ${o} ${i} ${$t(e)} ${$t(t)}`}stringify(e=""){let t=e;return t===""&&(t="black"),`<path d="${this.pathD} Z" stroke="${t}" stroke-width="1" fill="none" />`}};function zc(){return new qc}var Vc=class{svgStr;payloadStr;groupActive;constructor(){this.payloadStr="",this.svgStr="",this.groupActive=!1}addHeader(e,t,n,s){const A=`${e} ${n} ${t} ${s}`;this.svgStr=`<svg width="${t}" height="${s}" viewBox="${A}" xmlns="http://www.w3.org/2000/svg">`}addSvgString(e){this.payloadStr+=e}addGroup(e){if(this.groupActive)throw"err321: group must be closed before opening a new one";this.groupActive=!0,this.payloadStr+=`<g id="${e}">`}closeGroup(){if(!this.groupActive)throw"err331: group is not active so can not be closed";this.groupActive=!1,this.payloadStr+="</g>"}closeSvg(){if(this.svgStr==="")throw"err301: no header set for the svg";if(this.groupActive)throw"err311: group is not closed";this.svgStr+=this.payloadStr,this.svgStr+="</svg>"}stringify(){return this.closeSvg(),this.svgStr}};function jc(){return new Vc}function Gt(e){return e.toFixed(4)}var $s=class{arc;p1x;p1y;radius;a1;a2;p2x;p2y;constructor(e,t,n,s,A,r,o,i){this.arc=e,this.p1x=t,this.p1y=n,this.radius=s,this.a1=A,this.a2=r,this.p2x=o,this.p2y=i}};function $c(e,t,n,s){return new $s(!1,e,t,0,0,0,n,s)}function Xc(e,t,n,s,A,r){const o=r?s:A,i=r?A:s,a=Tt(ge(o)),u=Tt(ge(i));return new $s(!0,e,t,n,a,u,0,0)}function Zc(e,t,n){return new $s(!1,e,t,n,0,0,0,0)}var tg=class{dxfStr;constructor(){this.dxfStr=`0
18
- SECTION
19
- 2
20
- ENTITIES
21
- `}addCircle(e,t,n){this.dxfStr+=`0
22
- CIRCLE
23
- 8
24
- PARAMETRIX
25
- `,this.dxfStr+=`10
26
- ${Gt(e)}
27
- 20
28
- ${Gt(t)}
29
- 40
30
- ${Gt(n)}
31
- `}addLine(e,t,n,s){this.dxfStr+=`0
32
- LINE
33
- 8
34
- PARAMETRIX
35
- `,this.dxfStr+=`10
36
- ${Gt(e)}
37
- 20
38
- ${Gt(t)}
39
- 11
40
- ${Gt(n)}
41
- 21
42
- ${Gt(s)}
43
- `}addArc(e,t,n,s,A){this.dxfStr+=`0
44
- ARC
45
- 8
46
- PARAMETRIX
47
- `,this.dxfStr+=`10
48
- ${Gt(e)}
49
- 20
50
- ${Gt(t)}
51
- 40
52
- ${Gt(n)}
53
- 50
54
- ${Gt(s)}
55
- 51
56
- ${Gt(A)}
57
- `}close(){this.dxfStr+=`0
58
- ENDSEC
59
- 0
60
- EOF
61
- `}stringify(){return this.close(),this.dxfStr}};function eg(){return new tg}function ng(e,t,n){return{circle:!0,cx:e,cy:t,radius:n}}var sg=class{seg;constructor(){this.seg=[]}addStart(e,t){this.seg=[];const n={typ:0,px:e,py:t};this.seg.push(n)}addStroke(e,t){const n={typ:1,px:e,py:t};this.seg.push(n)}addArc(e,t,n,s,A){const r={typ:2,px:e,py:t,radius:n,large:s,ccw:A};this.seg.push(r)}toJson(){return{circle:!1,seg:this.seg}}};function Ag(){return new sg}var Wo=class{};function qo(e,t,n,s){const A=Ee(e,t,n),r=O(A.pc.cx,A.pc.cy),o=ge(A.a2-A.a1),a=(n.arcCcw?o:o-2*Math.PI)/s,u=[];for(let c=1;c<s;c++)u.push(r.translatePolar(A.a1+c*a,n.radius));return u}var rg=class fe extends Wo{circle=!1;segments;points;debugPoints;debugLines;lastPoint;lastPoint2;imposedColor;constructor(t,n,s=""){super(),this.segments=[new Ut(6,t,n,0)],this.points=[],this.debugPoints=[],this.debugLines=[],this.lastPoint=O(t,n),this.lastPoint2=O(t,n),this.imposedColor=s}setLastPoint(t,n){this.lastPoint2=this.lastPoint,this.lastPoint=O(t,n)}getLastPoint(){return this.lastPoint}getFirstPoint(){return O(this.segments[0].px,this.segments[0].py)}addPointA(t,n){if(this.points.length>2)throw`err311: contour add too much point ${t} ${n}`;return this.points.push(O(t,n)),this}addPointAP(t,n){const s=O(0,0).translatePolar(t,n);return this.addPointA(s.cx,s.cy),this}addPointR(t,n){const A=this.getLastPoint().translate(t,n);return this.addPointA(A.cx,A.cy),this}addPointRP(t,n){const A=this.getLastPoint().translatePolar(t,n);return this.addPointA(A.cx,A.cy),this}addSeg(t){return this.segments.push(t),this}addSegStroke(){if(this.points.length!==1)throw`err554: contour addSegStroke at segment ${this.segments.length} with unexpected points.length ${this.points.length}`;const t=this.points.pop();if(t!==void 0){const n=new Ut(0,t.cx,t.cy,0);t.isEqual(this.getLastPoint())||(this.addSeg(n),this.setLastPoint(t.cx,t.cy))}else throw"err284: contour p1 is undefined";return this}addSegStrokeA(t,n){return this.addPointA(t,n).addSegStroke(),this}addSegStrokeAP(t,n){return this.addPointAP(t,n).addSegStroke(),this}addSegStrokeR(t,n){return this.addPointR(t,n).addSegStroke(),this}addSegStrokeRP(t,n){return this.addPointRP(t,n).addSegStroke(),this}addSegArc(t,n,s){if(this.points.length!==1)throw`err954: contour addSegArc at segment ${this.segments.length} with unexpected points.length ${this.points.length}`;const A=this.points.pop();if(A!==void 0){const r=new Ut(1,A.cx,A.cy,t,n,s);A.isEqual(this.getLastPoint())?console.log(`warn144: addSegArc last and new point identical ${te(A.cx)} ${te(A.cy)}`):(this.addSeg(r),this.setLastPoint(A.cx,A.cy))}else throw"err482: contour p1 is undefined";return this}addSegArc2(){if(this.points.length!==2)throw`err958: contour addSegArc2 at segment ${this.segments.length} with unexpected points.length ${this.points.length}`;const t=this.points.pop(),n=this.points.pop();if(n!==void 0&&t!==void 0){const s=this.getLastPoint(),A=kc(s,n,t),r=A.distanceToPoint(s),o=s.middlePoint(t),i=o.angleToPoint(s),a=o.angleToPoint(n),u=At(a-i);let c=!1,g=!1;if(!o.isEqual(A)){const l=o.angleToPoint(A),B=At(l-i);Math.sign(B)*Math.sign(u)>0&&(c=!0)}Math.sign(u)>0&&(g=!0),this.addPointA(t.cx,t.cy).addSegArc(r,c,g),this.debugPoints.push(n)}else throw"err488: contour p1 or p2 or seg is undefined";return this}addSegArc3(t,n){if(this.points.length!==1)throw`err914: contour addSegArc3 at segment ${this.segments.length} with unexpected points.length ${this.points.length}`;const s=this.points.pop();if(s!==void 0){const A=this.getLastPoint(),r=vs(A,s);let o=s;n&&(o=A);const i=Hn(o.cx,o.cy,t+Math.PI/2),a=r.intersection(i),u=a.distanceToPoint(A),c=A.middlePoint(s),g=o.angleToPoint(c),l=At(t-g);let B=!1;Math.abs(l)>Math.PI/2&&(B=!0);let d=!1;l<0&&(d=!0),n||(d=!d),this.addPointA(s.cx,s.cy).addSegArc(u,B,d),this.debugPoints.push(c),this.debugPoints.push(a)}else throw"err282: contour p1 is undefined";return this}addSeg2Arcs(t,n){if(this.points.length!==1)throw`err214: contour addSeg2Arcs at segment ${this.segments.length} with unexpected points.length ${this.points.length}`;const s=this.points.pop();if(s!==void 0){const A=this.getLastPoint(),r=A.distanceToPoint(s),o=A.angleToPoint(s),i=s.angleToPoint(A),a=At(t-o),u=-1*At(n-i);if(Math.abs(a)>=Math.PI/2)throw`err545: addSeg2Arcs with too large au ${a}`;if(Math.abs(u)>=Math.PI/2)throw`err546: addSeg2Arcs with too large av ${u}`;if(J(a)===0)throw`err765: addSeg2Arcs with almost zero au ${a}`;if(J(u)===0)throw`err766: addSeg2Arcs with almost zero av ${u}`;if(Math.sign(a)*Math.sign(u)<1)throw`err767: addSeg2Arcs with au/av bad orientation ${a} ${u}`;const c=Math.tan(a/2),g=Math.tan(u/2),l=r*g/(g+c),B=Math.abs(l/Math.sin(a)),d=l/Math.cos(a/2),f=r*c/(g+c),h=Math.abs(f/Math.sin(u)),p=A.translatePolar(o+a/2,d);let E=!1;Math.sign(a)<0&&(E=!0),this.addPointA(p.cx,p.cy).addSegArc(B,!1,E),this.addPointA(s.cx,s.cy).addSegArc(h,!1,E),this.debugPoints.push(A.translatePolar(o,l)),this.debugPoints.push(A.translatePolar(o+a-Math.sign(a)*Math.PI/2,B)),this.debugPoints.push(s.translatePolar(i-u+Math.sign(a)*Math.PI/2,h))}else throw"err182: contour p1 is undefined";return this}addSegStrokeAifBig(t,n,s,A){const r=this.getLastPoint();if(Math.sqrt((t-r.cx)**2+(n-r.cy)**2)>s)this.addPointA(t,n).addSegStroke();else if(A){const i=this.segments[this.segments.length-1],a=this.lastPoint2;if(this.setLastPoint(a.cx,a.cy),i.sType===0)this.segments.pop(),this.addPointA(t,n).addSegStroke();else if(i.sType===1)this.segments.pop(),this.addPointA(t,n).addSegArc(i.radius,i.arcLarge,i.arcCcw);else throw`err186: addSegStrokeA-ifBig used after eStart or eCorner ${i.sType} at segment ${this.segments.length}`}return this}addCornerPointed(){const t=new Ut(2,0,0,0);return this.addSeg(t),this}addCornerRounded(t){const n=new Ut(3,0,0,t);return this.addSeg(n),this}addCornerWidened(t){const n=new Ut(4,0,0,t);return this.addSeg(n),this}addCornerWideAcc(t){const n=new Ut(5,0,0,t);return this.addSeg(n),this}closeSegStroke(){const t=this.segments[0].px,n=this.segments[0].py;return this.addSegStrokeA(t,n),this}closeSegArc(t,n,s){const A=this.segments[0].px,r=this.segments[0].py;return this.addPointA(A,r).addSegArc(t,n,s),this}clone(){const t=new fe(this.segments[0].px,this.segments[0].py);for(const n of this.segments){const s=n.clone();s.sType!==6&&(t.addSeg(s),Wt(s.sType)&&t.setLastPoint(s.px,s.py))}return t}translate(t,n){const s=this.segments[0].px+t,A=this.segments[0].py+n,r=new fe(s,A);for(const o of this.segments){const i=o.clone();Wt(o.sType)&&(i.px+=t,i.py+=n),i.sType!==6&&(r.addSeg(i),Wt(i.sType)&&r.setLastPoint(i.px,i.py))}return r}translatePolar(t,n){return this.translate(n*Math.cos(t),n*Math.sin(t))}rotate(t,n,s){const A=O(t,n),o=O(this.segments[0].px,this.segments[0].py).rotate(A,s),i=new fe(o.cx,o.cy);for(const a of this.segments){const u=a.clone();if(Wt(a.sType)){const g=O(u.px,u.py).rotate(A,s);u.px=g.cx,u.py=g.cy}u.sType!==6&&(i.addSeg(u),Wt(u.sType)&&i.setLastPoint(u.px,u.py))}return i}scale(t,n,s,A=!1){const r=O(t,n),i=O(this.segments[0].px,this.segments[0].py).scale(r,s),a=new fe(i.cx,i.cy);for(const u of this.segments){const c=u.clone();if(Wt(u.sType)){const l=O(c.px,c.py).scale(r,s);c.px=l.cx,c.py=l.cy}u.sType===1&&(c.radius*=s),In(u.sType)&&A&&(c.radius*=s),c.sType!==6&&(a.addSeg(c),Wt(c.sType)&&a.setLastPoint(c.px,c.py))}return a}addPartial(t){if(this.points.length>0)throw`err911: addPartial, points should be used ${this.points.length}`;let n=t;if(t.segments.length>0){const s=t.segments[0],A=this.getLastPoint(),r=s.px-A.cx,o=s.py-A.cy;s.sType===6&&(n=t.translate(-r,-o))}for(const s of n.segments)s.sType!==6&&(this.addSeg(s),Wt(s.sType)&&this.setLastPoint(s.px,s.py));return this}draw(t,n,s=it.contour){const A=this.imposedColor===""?s:this.imposedColor;let r=0,o=0;for(const i of this.segments){if(i.sType===0){const[a,u]=ve(r,o,n),[c,g]=ve(i.px,i.py,n);t.beginPath(),t.moveTo(a,u),t.lineTo(c,g),t.strokeStyle=A,t.stroke()}if(i.sType===1)try{const a=Ee(r,o,i),[u,c]=ve(a.pc.cx,a.pc.cy,n),g=Uo(i.radius,n);t.beginPath(),t.arc(u,c,g,-a.a1,-a.a2,i.arcCcw),t.strokeStyle=A,t.stroke()}catch(a){console.log("err413: "+a)}ze(i.sType)&&(r=i.px,o=i.py)}}extractSkeleton(){const t=this.segments[0],n=new fe(t.px,t.py);for(const s of this.segments)Wt(s.sType)&&n.addSeg(s);return n}generateContour(){Be.clearPoints(),Be.clearLines();const t=[],n=[];let s=0,A=0,r=0;for(const u of this.segments){if(u.sType===0){const l=O(A,r),B=O(u.px,u.py),d=O(0,0);t.push(new Kt(u.sType,l,B,d,0,0,0,!1)),s=1}if(u.sType===1){const l=Ee(A,r,u);t.push(l),s=1}const c=t.at(-1),g=t.at(-2);if(c!==void 0&&g!==void 0&&Wt(c.sType)&&fn(g.sType)){const l=t.pop(),B=t.pop(),d=t.pop();if(d!==void 0&&B!==void 0&&l!==void 0){const f=NA(d,B,l);t.push(...f)}else throw"err603: contour generateContour internal error"}if(fn(u.sType)){if(s===2)throw`err419: generateContour with two consecutive corners ${u.sType}`;if(s===0&&In(u.sType)&&u.radius>0){const l=O(0,0);n.push(new Kt(u.sType,l,l,l,u.radius,0,0,!1))}if(s===1&&In(u.sType)&&u.radius>0){const l=O(0,0);t.push(new Kt(u.sType,l,l,l,u.radius,0,0,!1))}s=2}ze(u.sType)&&(A=u.px,r=u.py)}if(n.length>0)if(s===1)t.push(...n);else throw"err397: contour generateContour Corners defined at end and begining";const o=t.at(-1);if(o!==void 0&&fn(o.sType)){const u=t[0],c=t.pop(),g=t.pop();if(g!==void 0&&c!==void 0&&u!==void 0){const l=NA(g,c,u);t.push(...l.slice(0,-1));const B=l.at(-1);if(B!==void 0)t[0]=B;else throw"err606: contour generateContour internal error"}else throw"err602: contour generateContour internal error"}const i=t[0],a=new fe(i.p1.cx,i.p1.cy,this.imposedColor);a.debugPoints.push(...Be.getPoints()),a.debugLines.push(...Be.getLines());for(const u of t)if(u.sType===0)a.addSegStrokeA(u.p2.cx,u.p2.cy);else if(u.sType===1){const c=Lc(u);a.addPointA(u.p2.cx,u.p2.cy).addSegArc(c.radius,c.arcLarge,c.arcCcw)}else throw`err986: contour generateContour unexpected in seg2 Enum ${u.sType}`;return a}generatePoints(t){const n=[];let s=0,A=0;for(const r of this.segments){if(r.sType===1)try{const o=qo(s,A,r,t);n.push(...o)}catch(o){console.log("err453: "+o)}ze(r.sType)&&(s=r.px,A=r.py,n.push(O(s,A)))}return n}getOrientation(t,n,s){const r=t.slice(1);let o=0,i=r.at(-3),a=r.at(-2),u=r.at(-1),c=-1;for(const[l,B]of r.entries()){i=a,a=u,u=B;const d=s?a.cx>n-.001:a.cx<n+.001,f=s?i.cx>n-.001:i.cx<n+.001;if(d&&!f){const h=i.cx-a.cx,p=i.cy-a.cy,E=u.cx-a.cx,C=u.cy-a.cy,I=E*p-C*h;o=Math.sign(I),c=l}}if(o===0)throw`err299: Orientation not found with ${r.length} points and foundIdx ${c}`;return o>0}getEnvelop(){const t=this.generatePoints(24),n=[],s=[];for(const c of t)n.push(c.cx),s.push(c.cy);const A=Math.min(...n),r=Math.max(...n),o=Math.min(...s),i=Math.max(...s),a=this.getOrientation(t,A,!1),u=this.getOrientation(t,r,!0);if(u!==a)throw`err390: orientation unstable ${a} ${u} with ${t.length} points`;return{xMin:A,xMax:r,yMin:o,yMax:i,orientation:a}}generateLines(){const t=[];return t.push(...this.debugLines),t}checkContour(t){if(t.segments[0].sType!==6)throw`err412: contour check first seg is not eStart ${t.segments[0].sType}`;let n=0,s=0;for(const o of t.segments){if(o.sType===1)try{Ee(n,s,o)}catch(i){throw`err778: ${i}`}ze(o.sType)&&(n=o.px,s=o.py)}const A=t.segments[0].px,r=t.segments[0].py;if(J(n-A)!==0||J(s-r)!==0)throw`err414: contour check, contour is not closed px ${A} ${n} py ${A} ${r}`}check(){Be.clearMsg(),this.checkContour(this);const t=this.generateContour();return this.checkContour(t),Be.getMsg()}toSvg(t,n=""){const s=zc();for(const r of this.segments)r.sType===6?s.addStart(r.px,t-r.py):r.sType===0?s.addStroke(r.px,t-r.py):r.sType===1?s.addArc(r.px,t-r.py,r.radius,r.arcLarge,!r.arcCcw):console.log(`err631: contour.toSvg has unknown segment type ${r.sType}`);return s.stringify(n)}toDxfSeg(){const t=[];let n=0,s=0;for(const A of this.segments){if(A.sType===0)t.push($c(n,s,A.px,A.py));else if(A.sType===1)try{const r=Ee(n,s,A);t.push(Xc(r.pc.cx,r.pc.cy,A.radius,r.a1,r.a2,r.arcCcw))}catch(r){console.log("err413: "+r)}ze(A.sType)&&(n=A.px,s=A.py)}return t}toPax(){const t=Ag();for(const s of this.segments)s.sType===6?t.addStart(s.px,s.py):s.sType===0?t.addStroke(s.px,s.py):s.sType===1?t.addArc(s.px,s.py,s.radius,s.arcLarge,s.arcCcw):console.log(`err709: contour.toPax has unknown segment type ${s.sType}`);return t.toJson()}getPerimeter(){let t=0;const n=this.generateContour();let s=0,A=0;for(const r of n.segments)if(r.sType===6)s=r.px,A=r.py;else if(r.sType===0){const o=Math.sqrt((r.px-s)**2+(r.py-A)**2);s=r.px,A=r.py,t+=o}else if(r.sType===1){const o=Ee(s,A,r),i=ge(o.a2-o.a1),a=o.arcCcw?i:ge(2*Math.PI-i),u=r.radius*a;s=r.px,A=r.py,t+=u}else console.log(`err760: contour.getPerimeter has unknown segment type ${r.sType}`);return t}generateRevertOrientation(){let t=this.segments[0];const n=new fe(t.px,t.py);let s=this.segments[0],A=!1;for(const r of this.segments.slice().reverse())if(fn(r.sType))A=!0,t=r;else{if(s.sType!==6){const o=new Ut(s.sType,r.px,r.py,s.radius,s.arcLarge,!s.arcCcw);n.addSeg(o)}s=r,A&&(n.addSeg(t),A=!1)}return n}},og=class ye extends Wo{circle=!0;px;py;radius;imposedColor;constructor(t,n,s,A=""){if(super(),this.px=t,this.py=n,this.radius=s,this.imposedColor=A,s<0)throw`err432: iRadius ${s} is negative at circle ix ${t}, iy ${n}`}clone(){return new ye(this.px,this.py,this.radius,this.imposedColor)}translate(t,n){return new ye(this.px+t,this.py+n,this.radius,this.imposedColor)}translatePolar(t,n){return this.translate(n*Math.cos(t),n*Math.sin(t))}rotate(t,n,s){const A=O(t,n),r=O(this.px,this.py).rotate(A,s);return new ye(r.cx,r.cy,this.radius,this.imposedColor)}draw(t,n,s=it.contour){const[A,r]=ve(this.px,this.py,n),o=Uo(this.radius,n),i=this.imposedColor===""?s:this.imposedColor;t.beginPath(),t.arc(A,r,o,0,2*Math.PI,!0),t.strokeStyle=i,t.stroke()}extractSkeleton(){return new ye(this.px,this.py,this.radius)}generateContour(){return new ye(this.px,this.py,this.radius,this.imposedColor)}generatePoints(t){const n=[],s=O(this.px,this.py),A=t*2;n.push(s);for(let r=0;r<A;r++){const o=s.translatePolar(r*2*Math.PI/A,this.radius);n.push(o)}return n}getEnvelop(){return{xMin:this.px-this.radius,xMax:this.px+this.radius,yMin:this.py-this.radius,yMax:this.py+this.radius,orientation:!0}}generateLines(){return[]}check(){return""}toSvg(t,n=""){return Wc(this.px,t-this.py,this.radius,n)}toDxfSeg(){const t=[];return t.push(Zc(this.px,this.py,this.radius)),t}toPax(){return ng(this.px,this.py,this.radius)}getPerimeter(){return 2*Math.PI*this.radius}generateRevertOrientation(){return new ye(this.px,this.py,this.radius,this.imposedColor)}};function ig(e,t,n=""){return new rg(e,t,n)}function tl(e,t,n,s=""){return new og(e,t,n,s)}var ag=class bs{pointList;lineList;vectorList;mainList;mainBList;secondList;secondBList;dynamicsList;xMin;xMax;yMin;yMax;constructor(){this.pointList=[],this.lineList=[],this.vectorList=[],this.mainList=[],this.mainBList=[],this.secondList=[],this.secondBList=[],this.dynamicsList=[],this.xMin=0,this.xMax=0,this.yMin=0,this.yMax=0}addPoint(t){this.pointList.push(t)}addPoints(t){this.pointList.push(...t)}addLine(t){this.lineList.push(t)}addLines(t){for(const n of t)this.lineList.push(n)}addVector(t){this.vectorList.push(t)}addMainOI(t){const n=[];for(const s of t){const A=s.generateContour();this.addPoints(A.generatePoints(2)),this.addLines(A.generateLines()),n.push(A),this.mainBList.push(s.extractSkeleton())}this.mainList.push(n)}addMainO(t){const n=[t];this.addMainOI(n)}addSecond(t){const n=t.generateContour();this.addPoints(n.generatePoints(2)),this.addLines(n.generateLines()),this.secondList.push(n),this.secondBList.push(t.extractSkeleton())}addDynamics(t){this.addPoints(t.generatePoints(2)),this.addLines(t.generateLines()),this.dynamicsList.push(t)}translate(t,n){const s=new bs;for(const A of this.pointList)s.addPoint(A.translate(t,n));for(const A of this.lineList)s.addLine(A.translate(t,n));for(const A of this.vectorList)s.addVector(A.translate(t,n));for(const A of this.mainList){const r=[];for(const o of A)r.push(o.translate(t,n));s.addMainOI(r)}for(const A of this.secondList)s.addSecond(A.translate(t,n));for(const A of this.dynamicsList)s.addDynamics(A.translate(t,n));return s}translatePolar(t,n){return this.translate(n*Math.cos(t),n*Math.sin(t))}rotate(t,n,s){const A=new bs,r=O(t,n);for(const o of this.pointList)A.addPoint(o.rotate(r,s));for(const o of this.lineList)A.addLine(o.rotate(r,s));for(const o of this.vectorList)A.addVector(o.rotate(r,s));for(const o of this.mainList){const i=[];for(const a of o)i.push(a.rotate(t,n,s));A.addMainOI(i)}for(const o of this.secondList)A.addSecond(o.rotate(t,n,s));for(const o of this.dynamicsList)A.addDynamics(o.rotate(t,n,s));return A}mergeFigure(t,n=!1){for(const s of t.pointList)this.addPoint(s.clone());for(const s of t.lineList)this.addLine(s.clone());for(const s of t.vectorList)this.addVector(s.clone());for(const s of t.mainList){const A=[];for(const r of s)A.push(r.clone());if(n)for(const r of A)this.addSecond(r);else this.addMainOI(A)}for(const s of t.secondList)this.addSecond(s.clone());for(const s of t.dynamicsList)this.addDynamics(s.clone())}mainListC(){const t=[];for(const n of this.mainList)for(const s of n)t.push(s);return t}clear(){this.pointList=[],this.lineList=[],this.vectorList=[],this.mainList=[],this.mainBList=[],this.secondList=[],this.secondBList=[],this.dynamicsList=[]}getMinMax(){[this.xMin,this.xMax,this.yMin,this.yMax]=Ho(this.pointList)}getAdjustFull(t,n){let s=Ss();return this.pointList.length>0&&(this.getMinMax(),s=Qs(this.xMin,this.xMax,this.yMin,this.yMax,t,n)),s}getAdjustZoom(t,n){let s=Ss();if(this.pointList.length>0){this.getMinMax();const A=(this.xMin+this.xMax)/2,r=(this.yMin+this.yMax)/2;s=Qs(A,this.xMax,r,this.yMax,t,n)}return s}quantifyRuler(t,n){const A=t/10/n.scaleX;let r=1e-4;for(;r<A;)r*=10;r/5>A?r/=5:r/2>A&&(r/=2);const o=r*n.scaleX;return[r,o]}drawRuler(t,n,s){const[A,r]=this.quantifyRuler(t.canvas.width,n),o=t.canvas.width-10-r;t.font="15px Arial",t.fillStyle=s,t.fillText(`${A.toFixed(4)}`,o,20),t.beginPath(),t.moveTo(o,25),t.lineTo(o+r,25),t.lineTo(o+r,25+r),t.strokeStyle=s,t.stroke()}draw(t,n,s){if(s.points)for(const A of this.pointList)A.draw(t,n);if(s.lines)for(const A of this.lineList)A.draw(t,n);if(s.vectors)for(const A of this.vectorList)A.draw(t,n);if(s.main)for(const A of this.mainList)for(const[r,o]of A.entries()){let i=it.mainOuter;r>0&&(i=it.mainInner),o.draw(t,n,i)}if(s.mainB)for(const A of this.mainBList)A.draw(t,n,it.mainB);if(s.second)for(const A of this.secondList)A.draw(t,n,it.second);if(s.secondB)for(const A of this.secondBList)A.draw(t,n,it.secondB);if(s.dynamics)for(const A of this.dynamicsList)A.draw(t,n,it.dynamics);if(s.ruler&&this.drawRuler(t,n,it.ruler),s.refframe){for(const A of[10,100,200])O(A,0).draw(t,n,it.reference,2),O(-A,0).draw(t,n,it.reference,2),O(0,A).draw(t,n,it.reference,2),O(0,-A).draw(t,n,it.reference,2);O(0,0).draw(t,n,it.origin,2)}}};function ug(){return new ag}function Ms(e){const t=ug();for(const n in e){const s=e[n];for(const A of s.pointList)t.pointList.push(A);for(const A of s.lineList)t.lineList.push(A);for(const A of s.vectorList)t.vectorList.push(A);for(const A of s.mainList)t.mainList.push(A);for(const A of s.mainBList)t.mainBList.push(A);for(const A of s.secondList)t.secondList.push(A);for(const A of s.secondBList)t.secondBList.push(A);for(const A of s.dynamicsList)t.dynamicsList.push(A)}return t}function el(){return{points:!1,lines:!1,vectors:!1,main:!0,mainB:!1,second:!0,secondB:!1,dynamics:!1,ruler:!0,refframe:!1}}function nl(e){return{points:e.points,lines:e.lines,vectors:e.vectors,main:e.main,mainB:e.mainB,second:e.second,secondB:e.secondB,dynamics:e.dynamics,ruler:e.ruler,refframe:e.refframe}}var cg=(e=>(e[e.eNumber=0]="eNumber",e[e.eCheckbox=1]="eCheckbox",e[e.eDropdown=2]="eDropdown",e[e.eSectionSeparator=3]="eSectionSeparator",e))(cg||{}),Ke={partName:"",params:[],paramSvg:{},sim:{tMax:0,tStep:0,tUpdate:0}};function sl(e){const t={};for(const n of Object.keys(e))t[n]=e[n].val;return t}function Al(e,t,n,s=0,A=100,r=1){return{name:e,unit:t,init:n,min:s,max:A,step:r,dropdown:[],pType:0}}function rl(e,t){return{name:e,unit:"checkbox",init:t?1:0,min:0,max:1,step:1,dropdown:[],pType:1}}function ol(e,t,n=0){let s=0;return n<t.length&&(s=n),{name:e,unit:"dropdown",init:s,min:0,max:t.length-1,step:1,dropdown:t,pType:2}}function il(e){return{name:e,unit:"section-separator",init:0,min:0,max:0,step:0,dropdown:[],pType:3}}var gg=(e=>(e[e.eLinearOrtho=0]="eLinearOrtho",e[e.eRotate=1]="eRotate",e))(gg||{}),lg=(e=>(e[e.eIdentity=0]="eIdentity",e[e.eIntersection=1]="eIntersection",e[e.eUnion=2]="eUnion",e[e.eSubstraction=3]="eSubstraction",e))(lg||{});function al(e){return{partName:e,calcErr:!0,logstr:"",fig:{},vol:{extrudes:[],volumes:[]},sub:{}}}var dg=class{figureToPaxF(e){const t=[];for(const n of e){const s=[];for(const A of n)s.push(A.toPax());t.push(s)}return t}getFigures(e){const t={};for(const n in e){const s=this.figureToPaxF(e[n].mainList);t[n]=s}return t}getPaxJson(e,t,n){return{partName:t.partName,pDef:n,params:e,figures:this.getFigures(t.fig),volume:t.vol,subs:t.sub,log:t.logstr}}getPaxStr(e,t,n){const s=this.getPaxJson(e,t,n);return JSON.stringify(s,null,2)}};function Te(){return new dg}function Xs(e){let t=6;return e===1?t=0:e===2&&(t=1),t}function fg(e){return new Ut(Xs(e.typ),e.px,e.py,e.radius,e.large,e.ccw)}function zo(e,t,n,s){let A=Math.PI/2;t<2*n&&(A=2*Math.asin(t/(2*n)));const r=Math.min(e,A),o=Math.ceil(s/r),i=s/o;return[o,i]}function Vo(e,t,n,s=Math.PI/6,A=2){const[r,o]=zo(s,A,n,2*Math.PI),i=[];for(let c=0;c<r;c++){const g=e+n*Math.cos(c*o),l=t+n*Math.sin(c*o);i.push([g,l])}const a=i[0][0],u=i[0][1];return i.push([a,u]),i}function jo(e,t,n,s,A,r,o=Math.PI/6,i=2){const a=ys(s,A,r),[u,c]=zo(o,i,n,Math.abs(a)),g=r?c:-c,l=u+1,B=[];for(let d=1;d<l;d++){const f=s+d*g,h=e+n*Math.cos(f),p=t+n*Math.sin(f);B.push([h,p])}return B}var $o=Math.PI/16,Xo=2;function UA(e){return e.toFixed(4)}function HA(e){return e.toString().padStart(3,"0")}function KA(e,t){return[[e,t]]}function Bg(e,t,n,s,A,r){return jo(e,t,n,s,A,r,$o,Xo)}function Eg(e,t,n){return Vo(e,t,n,$o,Xo)}function hg(e){const t=[];let n=0,s=0;for(const A of e){if(A.typ===0)t.push(...KA(A.px,A.py));else if(A.typ===1)t.push(...KA(A.px,A.py));else if(A.typ===2)try{const r=A,o=new Ut(Xs(r.typ),r.px,r.py,r.radius,r.large,r.ccw),i=Ee(n,s,o);t.push(...Bg(i.pc.cx,i.pc.cy,o.radius,i.a1,i.a2,i.arcCcw))}catch(r){console.log("err730: "+r)}n=A.px,s=A.py}return t}var pg=class{pts;ptIdx;idx;constructor(){this.pts=[],this.ptIdx=[],this.idx=0}addContour(e){const t=[],n=[];for(const r of e){const[o,i]=r;t.push(`[ ${UA(o)}, ${UA(i)} ]`),n.push(` ${this.idx}`),this.idx+=1}const s=`[ ${t.join(",")} ]`,A=`[ ${n.join(",")} ]`;this.pts.push(s),this.ptIdx.push(A)}getFigure(e){let t="";const n=[],s=[];for(const o of this.pts.keys()){const i=`ca_${e}_${HA(o)}`,a=`cb_${e}_${HA(o)}`;t+=`${i} = ${this.pts[o]};
62
- `,t+=`${a} = ${this.ptIdx[o]};
63
- `,n.push(i),s.push(a)}const A=n.join(", "),r=s.join(", ");return t+=`a_${e} = concat(${A});
64
- `,t+=`b_${e} = [${r}];
65
- `,t}},Dg=class{getHeader(){return`// Generated by Parametrix
66
- `}getOneFigure(e,t){const n=new pg;for(const A of e)for(const r of A)if(r.circle===!0){const o=r,i=Eg(o.cx,o.cy,o.radius);n.addContour(i)}else{const i=hg(r.seg);n.addContour(i)}return n.getFigure(t)}getAllFigures(e,t){let n="";for(const s in e){const A=this.getOneFigure(e[s],`${t}_${s}`);n+=A}return n}getOneExtrude(e){let t="rotate_extrude",n="";return e.extrudeMethod===0&&(e.length===void 0&&console.log("err103: design error: scad-linear_extrude length undefined!"),t="linear_extrude",n=`height = ${e.length}`),`
67
- module ${e.outName} () {
68
- translate( [ ${e.translate[0]}, ${e.translate[1]}, ${e.translate[2]} ])
69
- rotate( [ ${Tt(e.rotate[0])}, ${Tt(e.rotate[1])}, ${Tt(e.rotate[2])} ])
70
- ${t}(${n}) polygon(a_${e.face}, b_${e.face});
71
- }
72
- `}getAllExtrudes(e){let t="";for(const n of e){const s=this.getOneExtrude(n);t+=s}return t}getOneVolume(e){let t="identity";switch(e.boolMethod){case 1:t="intersection";break;case 2:t="union";break;case 3:t="difference";break}const n=[];for(const r of e.inList)n.push(`${r}();`);const s=n.join(`
73
- `);let A=`
74
- module ${e.outName} () {
75
- ${t} () {
76
- ${s}
77
- }
78
- }
79
- `;return e.boolMethod===0&&(A=`
80
- module ${e.outName} () {
81
- ${s}
82
- }
83
- `),A}getAllVolumes(e){let t="";for(const n of e){const s=this.getOneVolume(n);t+=s}return t}getAllSubGeoms(e){const t=[];for(const n of e)t.includes(n.subgeom)||t.push(n.subgeom);return t}getOneInherit(e){return`
84
- module ${e.outName} () {
85
- translate( [ ${e.translate[0]}, ${e.translate[1]}, ${e.translate[2]} ])
86
- rotate( [ ${Tt(e.rotate[0])}, ${Tt(e.rotate[1])}, ${Tt(e.rotate[2])} ])
87
- ${e.subdesign}();
88
- }
89
- `}getAllInherits(e){let t="";for(const n of e){const s=this.getOneInherit(n);t+=s}return t}getVolume(e){let t="";if(e.inherits!==void 0){const n=this.getAllSubGeoms(e.inherits);for(const s of n){const A=Te().getPaxJson({},s,Ke);t+=this.getAllFigures(A.figures,A.partName),t+=this.getVolume(s.vol)}t+=this.getAllInherits(e.inherits)}return t+=this.getAllExtrudes(e.extrudes),t+=this.getAllVolumes(e.volumes),t}getFooter(e){return`
90
- pax_${e}();
91
- `}getExportFile(e){let t=this.getHeader();return t+=this.getAllFigures(e.figures,e.partName),t+=this.getVolume(e.volume),t+=this.getFooter(e.partName),t}};function Cg(){return new Dg}var Zo=Math.PI/16,ti=2;function JA(e){return e.toFixed(4)}function WA(e){return e.toString().padStart(3,"0")}function qA(e,t){return[[e,t]]}function mg(e,t,n,s,A,r){return jo(e,t,n,s,A,r,Zo,ti)}function Ig(e){const t=[];let n=0,s=0;for(const A of e){if(A.typ===0)t.push(...qA(A.px,A.py));else if(A.typ===1)t.push(...qA(A.px,A.py));else if(A.typ===2)try{const r=A,o=new Ut(Xs(r.typ),r.px,r.py,r.radius,r.large,r.ccw),i=Ee(n,s,o);t.push(...mg(i.pc.cx,i.pc.cy,o.radius,i.a1,i.a2,i.arcCcw))}catch(r){console.log("err730: "+r)}n=A.px,s=A.py}return t}function wg(e,t,n){return Vo(e,t,n,Zo,ti)}function ei(e,t){const n=[];for(const r of e){const[o,i]=r;n.push(`[ ${JA(o)}, ${JA(i)} ]`)}const s=`[ ${n.join(`,
92
- `)} ]`;return`const ${t} = polygon({ points: ${s} });
93
-
94
- `}function Fg(e,t,n,s){const A=wg(e,t,n);return ei(A,s)}function xg(e,t){const n=Ig(e);return ei(n,t)}function yg(e,t){let n="";const s=e[0];return e.slice(1).length>0?n+=`${t} = subtract( ${e.join(", ")} );
95
- `:n+=`${t} = ${s};
96
- `,n}function Sg(e,t){let n="";const s=e[0];return e.slice(1).length>0?n+=`${t} = union( ${e.join(", ")} );
97
- `:n+=`${t} = ${s};
98
- `,n}var Qg=class{getHeader(){return`// Generated by Parametrix
99
-
100
- const { polygon } = require('@jscad/modeling').primitives;
101
- //const { subtract } = require('@jscad/modeling').booleans;
102
- //const { union, intersect, scission, subtract } = require('@jscad/modeling').booleans;
103
- const { union, intersect, subtract } = require('@jscad/modeling').booleans;
104
- const { extrudeLinear, extrudeRotate } = require('@jscad/modeling').extrusions;
105
- const { translate, rotate } = require('@jscad/modeling').transforms;
106
-
107
- const main = () => {
108
-
109
- `}getOneFigure(e,t){let n="";const s=[];for(const[A,r]of e.entries()){const o=`face_${t}_Fa${WA(A)}`,i=[];for(const[a,u]of r.entries()){const c=`ctr_${o}_Ctr${WA(a)}`;if(u.circle===!0){const g=u;n+=Fg(g.cx,g.cy,g.radius,c)}else n+=xg(u.seg,c);i.push(c)}n+=yg(i,o),s.push(o)}return n+=Sg(s,t),n}getAllFigures(e,t){let n="";for(const s in e){const A=this.getOneFigure(e[s],`fig_${t}_${s}`);n+=A}return n}getOneExtrude(e){let t="extrudeRotate",n="{segments: 32}";return e.extrudeMethod===0&&(e.length===void 0&&console.log("err079: design error: extrudeLinear length undefined!"),t="extrudeLinear",n=`{height: ${e.length}}`),`
110
- const ${e.outName} =
111
- translate( [ ${e.translate[0]}, ${e.translate[1]}, ${e.translate[2]}, ],
112
- rotate( [ ${e.rotate[0]}, ${e.rotate[1]}, ${e.rotate[2]}, ],
113
- ${t}( ${n}, fig_${e.face} )
114
- )
115
- );
116
-
117
- `}getAllExtrudes(e){let t="";for(const n of e){const s=this.getOneExtrude(n);t+=s}return t}getOneVolume(e){let t="identity";switch(e.boolMethod){case 1:t="intersect";break;case 2:t="union";break;case 3:t="subtract";break}const n=e.inList.join(", ");let s=`const ${e.outName} = ${t}( ${n} );
118
- `;return e.boolMethod===0&&(s=`const ${e.outName} = ${e.inList[0]};
119
- `),s}getAllVolumes(e){let t="";for(const n of e){const s=this.getOneVolume(n);t+=s}return t}getAllSubGeoms(e){const t=[];for(const n of e)t.includes(n.subgeom)||t.push(n.subgeom);return t}getOneInherit(e){return`
120
- const ${e.outName} =
121
- translate( [ ${e.translate[0]}, ${e.translate[1]}, ${e.translate[2]}, ],
122
- rotate( [ ${e.rotate[0]}, ${e.rotate[1]}, ${e.rotate[2]}, ],
123
- ${e.subdesign}
124
- )
125
- );
126
- `}getAllInherits(e){let t="";for(const n of e){const s=this.getOneInherit(n);t+=s}return t}getVolume(e){let t="";if(e.inherits!==void 0){const n=this.getAllSubGeoms(e.inherits);for(const s of n){const A=Te().getPaxJson({},s,Ke);t+=this.getAllFigures(A.figures,A.partName),t+=this.getVolume(s.vol)}t+=this.getAllInherits(e.inherits)}return t+=this.getAllExtrudes(e.extrudes),t+=this.getAllVolumes(e.volumes),t}getFooter(e){return`
127
- return pax_${e};
128
- }
129
- module.exports = { main };
130
- `}getExportFile(e){let t=this.getHeader();return t+=this.getAllFigures(e.figures,e.partName),t+=this.getVolume(e.volume),t+=this.getFooter(e.partName),t}};function vg(){return new Qg}function st(e){return e.toFixed(4)}function pt(e){return e.toString().padStart(3,"0")}function bg(e,t,n,s){return`def ${s}():
131
- # Radius, XYZ-position, orientation
132
- aCircle = Part.makeCircle(${st(n)}, App.Vector(${st(e)}, ${st(t)}, 0), App.Vector(0, 0, 1))
133
- aWire = Part.Wire(aCircle)
134
- rFace = Part.Face(aWire)
135
- return rFace
136
-
137
- `}function Mg(e,t){let n=`def ${t}():
138
- `,s=0,A=0,r=0,o=0,i=0;for(const[u,c]of e.entries()){if(c.typ===0)n+=` P${pt(r)} = App.Vector(${st(c.px)}, ${st(c.py)}, 0)
139
- `,r+=1;else if(c.typ===1)n+=` P${pt(r)} = App.Vector(${st(c.px)}, ${st(c.py)}, 0)
140
- `,u<e.length-1?o=r:o=0,n+=` S${pt(i)} = Part.LineSegment(P${pt(r-1)}, P${pt(o)})
141
- `,r+=1,i+=1;else if(c.typ===2){try{const g=fg(c),l=qo(s,A,g,2)[0];n+=` P${pt(r)} = App.Vector(${st(l.cx)}, ${st(l.cy)}, 0)
142
- `,r+=1}catch(g){console.log("err730: "+g)}n+=` P${pt(r)} = App.Vector(${st(c.px)}, ${st(c.py)}, 0)
143
- `,u<e.length-1?o=r:o=0,n+=` S${pt(i)} = Part.Arc(P${pt(r-2)}, P${pt(r-1)}, P${pt(o)})
144
- `,r+=1,i+=1}s=c.px,A=c.py}const a=Array.from({length:i},(u,c)=>`S${pt(c)}`);return n+=` aShape = Part.Shape([${a.join(", ")}])
145
- aWire = Part.Wire(aShape.Edges)
146
- subFace = Part.Face(aWire)
147
- subFace.check()
148
- return subFace
149
-
150
- `,n}function Tg(e,t){let n=`def ${t}():
151
- `;const s=[];for(const[o,i]of e.entries()){const a=`FC${pt(o)}`;n+=` ${a} = ${i}()
152
- `,s.push(a)}const A=s[0],r=s.slice(1);return r.length>0?n+=` rOneFace = ${A}.cut([${r.join(", ")}])
153
- `:n+=` rOneFace = ${A}
154
- `,n+=` rOneFace.check()
155
- return rOneFace
156
-
157
- `,n}function Yg(e,t){let n=`def ${t}():
158
- `;const s=[];for(const[o,i]of e.entries()){const a=`FA${pt(o)}`;n+=` ${a} = ${i}()
159
- `,s.push(a)}const A=s[0],r=s.slice(1);return r.length>0?n+=` rOneFig = ${A}.fuse([${r.join(", ")}])
160
- `:n+=` rOneFig = ${A}
161
- `,n+=` rOneFig.check()
162
- return rOneFig
163
-
164
- `,n}var Pg=class{getHeader(e){return`# freecad-python generated by Parametrix
165
- # run the script with:
166
- # freecad.cmd myScript.py
167
-
168
- import FreeCAD as App
169
- import Part
170
-
171
- #print(sys.argv)
172
- outFileName = "${e}"
173
- if (len(sys.argv) == 3):
174
- outFileName = sys.argv[2]
175
- print(f"outFileName: {outFileName}")
176
-
177
- `}getOneFigure(e,t){let n="";const s=[];for(const[A,r]of e.entries()){const o=`face_${t}_Fa${A}`,i=[];for(const[a,u]of r.entries()){const c=`ctr_${o}_Ctr${a}`;if(u.circle===!0){const g=u;n+=bg(g.cx,g.cy,g.radius,c)}else n+=Mg(u.seg,c);i.push(c)}n+=Tg(i,o),s.push(o)}return n+=Yg(s,t),n}getAllFigures(e,t){let n="";for(const s in e){const A=this.getOneFigure(e[s],`${t}_${s}`);n+=A}return n}getOneExtrude(e){let t=`def fex_${e.outName}():
178
- FIG = ${e.face}()
179
- `;return e.extrudeMethod===0?(e.length===void 0&&console.log(`err103: ${e.face} ${e.outName} design error: eLinearOrtho length undefined!`),t+=` VEX = FIG.extrude(App.Vector(0, 0, ${e.length}))`):e.extrudeMethod===1&&(t+=" VEX = FIG.revolve(App.Vector(0, 0, 0), App.Vector(0, 1, 0), 360).rotate(App.Vector(0, 0, 0), App.Vector(1, 0, 0), 90)"),t+=`
180
- VR1 = VEX.rotate(App.Vector(0, 0, 0), App.Vector(1, 0, 0), ${st(Tt(e.rotate[0]))})
181
- VR2 = VR1.rotate(App.Vector(0, 0, 0), App.Vector(0, 1, 0), ${st(Tt(e.rotate[1]))})
182
- VR3 = VR2.rotate(App.Vector(0, 0, 0), App.Vector(0, 0, 1), ${st(Tt(e.rotate[2]))})
183
- VFP = VR3.translate(App.Vector(${st(e.translate[0])}, ${st(e.translate[1])}, ${st(e.translate[2])}))
184
- return VFP
185
- ${e.outName} = fex_${e.outName}()
186
-
187
- `,t}getAllExtrudes(e){let t="";for(const n of e){const s=this.getOneExtrude(n);t+=s}return t}getOneVolume(e){let t="";if(e.inList.length===0)console.log(`err215: ${e.outName} has an empty inList`);else if(e.inList.length===1||e.boolMethod===0)t+=`${e.outName} = ${e.inList[0]}
188
- `;else{const n=e.inList[0],s=e.inList.slice(1);let A="dbg897";switch(e.boolMethod){case 1:A="common";break;case 2:A="fuse";break;case 3:A="cut";break}t+=`def fvol_${e.outName}():
189
- V000 = ${n}
190
- `;let r=0;for(const o of s)t+=` V${pt(r+1)} = V${pt(r)}.${A}(${o})
191
- `,r+=1;t+=` VFC = V${pt(r)}.removeSplitter()
192
- return VFC
193
- ${e.outName} = fvol_${e.outName}()
194
-
195
- `}return t}getAllVolumes(e){let t="";for(const n of e){const s=this.getOneVolume(n);t+=s}return t}getAllSubGeoms(e){const t=[];for(const n of e)t.includes(n.subgeom)||t.push(n.subgeom);return t}getOneInherit(e){return`def finh_${e.outName}():
196
- IVR1 = ${e.subdesign}.rotate(App.Vector(0, 0, 0), App.Vector(1, 0, 0), ${st(Tt(e.rotate[0]))})
197
- IVR2 = IVR1.rotate(App.Vector(0, 0, 0), App.Vector(0, 1, 0), ${st(Tt(e.rotate[1]))})
198
- IVR3 = IVR2.rotate(App.Vector(0, 0, 0), App.Vector(0, 0, 1), ${st(Tt(e.rotate[2]))})
199
- IVF = IVR3.translate(App.Vector(${st(e.translate[0])}, ${st(e.translate[1])}, ${st(e.translate[2])}))
200
- return IVF
201
- ${e.outName} = finh_${e.outName}()
202
-
203
- `}getAllInherits(e){let t="";for(const n of e){const s=this.getOneInherit(n);t+=s}return t}getVolume(e){let t="";if(e.inherits!==void 0){const n=this.getAllSubGeoms(e.inherits);for(const s of n){const A=Te().getPaxJson({},s,Ke);t+=this.getAllFigures(A.figures,A.partName),t+=this.getVolume(s.vol)}t+=this.getAllInherits(e.inherits)}return t+=this.getAllExtrudes(e.extrudes),t+=this.getAllVolumes(e.volumes),t}getFooter(e){return`
204
- pax_${e}.check()
205
- #pax_${e}.exportBrep(f"{outFileName}.brep")
206
- #pax_${e}.exportIges(f"{outFileName}.igs")
207
- #pax_${e}.exportStep(f"{outFileName}.stp")
208
- pax_${e}.exportStl(f"{outFileName}.stl")
209
-
210
- `}getExportFile(e){let t=this.getHeader(e.partName);return t+=this.getAllFigures(e.figures,e.partName),t+=this.getVolume(e.volume),t+=this.getFooter(e.partName),t}};function Rg(){return new Pg}var Og=class{xMin;xMax;yMin;yMax;firstDone;constructor(){this.firstDone=!1,this.xMin=0,this.xMax=0,this.yMin=0,this.yMax=0}addAContour(e){if(e.length>0){const t=[];this.firstDone&&(t.push(O(this.xMin,this.yMin)),t.push(O(this.xMax,this.yMax)));for(const o of e)t.push(...o.generatePoints(2));const[n,s,A,r]=Ho(t);this.xMin=n,this.xMax=s,this.yMin=A,this.yMax=r}}getViewBox(){const e=Math.round((this.xMax-this.xMin)*1.1)+10,t=Math.round((this.yMax-this.yMin)*1.1)+10,n=Math.round(this.xMin-e*.05),s=Math.round(this.yMin-t*.05);return[n,e,s,t]}},kg=class{minMax;groups;svg;constructor(){this.minMax=new Og,this.groups=[],this.svg=jc()}addAContour(e,t="",n=it.contour){this.minMax.addAContour(e);const s={gpName:t,gpColor:n,ctrs:e};this.groups.push(s)}makeSvg(e){for(const t of this.groups){t.gpName!==""&&this.svg.addGroup(t.gpName);for(const n of t.ctrs){let s=n.imposedColor;s===""&&(s=t.gpColor),this.svg.addSvgString(n.toSvg(e,s))}t.gpName!==""&&this.svg.closeGroup()}}stringify(){const[e,t,n,s]=this.minMax.getViewBox();return this.svg.addHeader(e,t,n,s),this.makeSvg(this.minMax.yMax+this.minMax.yMin),this.svg.stringify()}};function ni(){return new kg}function Rn(e){const t=ni();return t.addAContour(e),t.stringify()}function Bn(e){const t=ni();return t.addAContour(e.mainListC(),"main",it.mainInner),t.addAContour(e.mainBList,"mainB",it.mainB),t.addAContour(e.secondList,"second",it.second),t.addAContour(e.secondBList,"secondB",it.secondB),t.addAContour(e.dynamicsList,"dynamics",it.dynamics),t.stringify()}function On(e){const t=eg();for(const s of e)if(s.circle){const A=s.toDxfSeg()[0];t.addCircle(A.p1x,A.p1y,A.radius)}else for(const A of s.toDxfSeg())A.arc?t.addArc(A.p1x,A.p1y,A.radius,A.a1,A.a2):t.addLine(A.p1x,A.p1y,A.p2x,A.p2y);return t.stringify()}function _g(e){let t="";return t+=e.logstr,t}function si(e,t,n){return Te().getPaxStr(e,t,n)}function Ai(e){const t=Te().getPaxJson({},e,Ke);return Cg().getExportFile(t)}function ri(e){const t=Te().getPaxJson({},e,Ke);return vg().getExportFile(t)}function oi(e){const t=Te().getPaxJson({},e,Ke);return Rg().getExportFile(t)}async function Lg(e,t,n,s,A){const r=new Na("application/zip"),o=new ic(r),i=t.partName,a=new yt(JSON.stringify(e,null,2));await o.add(`param_${i}.json`,a);const u=new yt(t.logstr);await o.add(`geom_${i}_log.txt`,u);const c=new yt(s.logstr);await o.add(`geom_${i}_t${n}_log.txt`,c);for(const w in t.fig){const m=new yt(Rn(t.fig[w].mainListC()));await o.add(`face_${i}_${w}.svg`,m);const x=new yt(On(t.fig[w].mainListC()));await o.add(`face_${i}_${w}.dxf`,x);const y=new yt(Bn(t.fig[w]));await o.add(`deco_${i}_${w}.svg`,y);const G=new yt(Bn(s.fig[w]));await o.add(`deco_${i}_${w}_t${n}.svg`,G)}const g=Ms(t.fig),l=new yt(Rn(g.mainListC()));await o.add(`face_${i}_all_merged.svg`,l);const B=new yt(On(g.mainListC()));await o.add(`face_${i}_all_merged.dxf`,B);const d=new yt(Bn(g));await o.add(`deco_${i}_all_merged.svg`,d);const f=new yt(Bn(g));await o.add(`deco_${i}_all_merged_t${n}.svg`,f);const h=new yt(si(e,t,A));await o.add(`${i}.pax.json`,h);const p=new yt(Ai(t));await o.add(`${i}_noarc_openscad.scad`,p);const E=new yt(ri(t));await o.add(`${i}_noarc_jscad.js`,E);const C=new yt(oi(t));return await o.add(`${i}_freecad.py`,C),await o.close(),await r.getData()}var Gg=(e=>(e[e.eSVG=0]="eSVG",e[e.eSVGALL=1]="eSVGALL",e[e.eDXF=2]="eDXF",e[e.eDXFALL=3]="eDXFALL",e[e.eTXTLOG=4]="eTXTLOG",e[e.ePAX=5]="ePAX",e[e.eOPENSCAD=6]="eOPENSCAD",e[e.eJSCAD=7]="eJSCAD",e[e.eFREECAD=8]="eFREECAD",e[e.eZIP=9]="eZIP",e))(Gg||{});function ul(e,t,n,s,A){const r=e(0,t);let o="";if(r.calcErr)console.log("err931: error by calling geome ${geome0.calcErr}");else{const i=Object.keys(r.fig);if(A===0)if(i.includes(s)){const a=r.fig[s];o=Rn(a.mainListC())}else console.log(`err749: fileTextContent eFace ${s} invalid`);else if(A===1){const a=Ms(r.fig);o=Rn(a.mainListC())}else if(A===2)if(i.includes(s)){const a=r.fig[s];o=On(a.mainListC())}else console.log(`err759: fileTextContent eFace ${s} invalid`);else if(A===3){const a=Ms(r.fig);o=On(a.mainListC())}else A===4?o=_g(r):A===5?o=si(t,r,n):A===6?o=Ai(r):A===7?o=ri(r):A===8?o=oi(r):console.log(`err912: unknown exportFormat ${A}`)}return o}async function cl(e,t,n,s,A){const r=e(0,n),o=e(t,n);let i=new Blob;return!r.calcErr&&!o.calcErr?A===9?i=await Lg(n,r,t,o,s):console.log(`err913: unknown exportFormat ${A}`):console.log("err932: error by calling geome ${geome0.calcErr} ${geome1.calcErr}"),i}function gl(e){let t="";return e===0||e===1?t="image/svg+xml":e===2||e===3?t="application/dxf":e===4?t="text/plain":e===5?t="application/json":e===6||e===7||e===8?t="text/plain":e===9&&(t="application/zip"),t}function ll(e){let t="";return e===0||e===1?t=".svg":e===2||e===3?t=".dxf":e===4?t=".log":e===5?t=".pax.json":e===6?t="_noarc_openscad.scad":e===7?t="_noarc_jscad.js":e===8?t="_freecad.py":e===9&&(t=".zip"),t}function dl(e){let t=!1;return e===9&&(t=!0),t}function fl(e,t,n,s){return JSON.stringify({lastModif:e,partName:t,pVal:n,comment:s},null," ")}function Bl(e){const t=Rc.parse(e),n="lastModif",s="partName",A="pVal",r="comment";let o="";const i={lastModif:"",partName:"",pVal:{},comment:""};if(Object.hasOwn(t,n)&&(i[n]=t[n]),Object.hasOwn(t,s)&&(i[s]=t[s]),Object.hasOwn(t,A)){const a=t[A];for(const u of Object.keys(a)){const c=a[u];if(isNaN(c))throw`err905: ${c} is not a number!`;i[A][u]=c}o+=`info398: parsing file has found ${Object.keys(i[A]).length} parameters
211
- `}else throw`err489: parameter-json-file has no key ${A}
212
- `;return Object.hasOwn(t,r)&&(i[r]=t[r]),[i,o]}function El(e,t,n,s,A=0){return ig(e,t).addCornerRounded(A).addSegStrokeR(n,0).addCornerRounded(A).addSegStrokeR(0,s).addCornerRounded(A).addSegStrokeR(-n,0).addCornerRounded(A).closeSegStroke()}function hl(e){const t=[];t.push("version details:"),t.push(`${e.name} : ${e.version}`),t.push("dependencies:");const n=Object.keys(e.dependencies);for(const[s,A]of n.entries()){const r=A;t.push(`${s+1} : ${A} : ${e.dependencies[r]}`)}return t}export{$g as A,zg as B,Vg as C,jg as D,lg as E,Nn as F,Xg as G,it as H,Wg as I,sl as J,Gg as K,cl as L,ul as M,ll as N,dl as O,cg as P,Ms as Q,gl as R,rl as a,il as b,ol as c,ig as d,Hg as e,tl as f,ug as g,gg as h,al as i,El as j,qg as k,te as l,O as m,Ug as n,Kg as o,Al as p,Jg as q,Tt as r,sA as s,Ss as t,el as u,hl as v,nl as w,Zg as x,fl as y,Bl as z};