designix-uis 1.0.26 → 1.0.27

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 (55) hide show
  1. package/dist/public/_app/immutable/chunks/BHBmAp0t.js +1 -0
  2. package/dist/public/_app/immutable/chunks/BsC0KJnE.js +1 -0
  3. package/dist/public/_app/immutable/chunks/BvMyOpMW.js +2 -0
  4. package/dist/public/_app/immutable/chunks/CDPXKizA.js +216 -0
  5. package/dist/public/_app/immutable/chunks/CLLMBv3G.js +1 -0
  6. package/dist/public/_app/immutable/chunks/{BpB6ZMII.js → CdIMtTB_.js} +1 -1
  7. package/dist/public/_app/immutable/chunks/Crb22ScH.js +1 -0
  8. package/dist/public/_app/immutable/chunks/DWiHY1yh.js +1 -0
  9. package/dist/public/_app/immutable/chunks/hUAl4A9s.js +1 -0
  10. package/dist/public/_app/immutable/chunks/r5-SrLJV.js +1 -0
  11. package/dist/public/_app/immutable/entry/app.e5mkuYQF.js +2 -0
  12. package/dist/public/_app/immutable/entry/start.D_czURb2.js +1 -0
  13. package/dist/public/_app/immutable/nodes/0.CH76o7dk.js +2 -0
  14. package/dist/public/_app/immutable/nodes/1.BiA6rY6y.js +1 -0
  15. package/dist/public/_app/immutable/nodes/2.Bi0HaUO8.js +1 -0
  16. package/dist/public/_app/immutable/nodes/3.CTvJ8tYy.js +10 -0
  17. package/dist/public/_app/version.json +1 -1
  18. package/dist/public/gear/gear_bar.html +19 -19
  19. package/dist/public/gear/gear_epicycloid.html +19 -19
  20. package/dist/public/gear/gear_ring.html +19 -19
  21. package/dist/public/gear/gear_wheel.html +19 -19
  22. package/dist/public/heliostat/base.html +19 -19
  23. package/dist/public/heliostat/haxis_guidance.html +19 -19
  24. package/dist/public/heliostat/heliostat.html +19 -19
  25. package/dist/public/heliostat/heliostat_2.html +19 -19
  26. package/dist/public/heliostat/pole_static.html +19 -19
  27. package/dist/public/heliostat/rake.html +19 -19
  28. package/dist/public/heliostat/rake_stopper.html +19 -19
  29. package/dist/public/heliostat/ring.html +19 -19
  30. package/dist/public/heliostat/ring_guidance.html +19 -19
  31. package/dist/public/heliostat/rod.html +19 -19
  32. package/dist/public/heliostat/spider.html +19 -19
  33. package/dist/public/heliostat/surface.html +19 -19
  34. package/dist/public/heliostat/swing.html +19 -19
  35. package/dist/public/heliostat/trapeze.html +19 -19
  36. package/dist/public/heliostat/vaxis.html +19 -19
  37. package/dist/public/heliostat/vaxis_guidance.html +19 -19
  38. package/dist/public/heliostat/vaxis_holder.html +19 -19
  39. package/dist/public/index.html +17 -17
  40. package/package.json +9 -9
  41. package/dist/public/_app/immutable/chunks/BH8tjzc2.js +0 -1
  42. package/dist/public/_app/immutable/chunks/BiCAQyXr.js +0 -1
  43. package/dist/public/_app/immutable/chunks/BqHUI63y.js +0 -1
  44. package/dist/public/_app/immutable/chunks/C5fCte6y.js +0 -216
  45. package/dist/public/_app/immutable/chunks/ChskwOFv.js +0 -1
  46. package/dist/public/_app/immutable/chunks/Csg-7wXO.js +0 -2
  47. package/dist/public/_app/immutable/chunks/DVBr_Z6U.js +0 -1
  48. package/dist/public/_app/immutable/chunks/DtzzcODf.js +0 -1
  49. package/dist/public/_app/immutable/chunks/l6DKjiJV.js +0 -1
  50. package/dist/public/_app/immutable/entry/app.AqAQrxcy.js +0 -2
  51. package/dist/public/_app/immutable/entry/start.CeKEg60I.js +0 -1
  52. package/dist/public/_app/immutable/nodes/0.Bf2yhCKc.js +0 -2
  53. package/dist/public/_app/immutable/nodes/1.CV_CN1Zq.js +0 -1
  54. package/dist/public/_app/immutable/nodes/2.UY0WbqBt.js +0 -1
  55. package/dist/public/_app/immutable/nodes/3.pomHYnc7.js +0 -10
@@ -0,0 +1,216 @@
1
+ import{N as qn,S as di,ay as ZA,a8 as jn,i as Ee,Y as Ei,T as hi,g as sA,ah as Bi,a5 as pi,a6 as Di,a7 as AA,a9 as $n,P as En,az as Ci,aA as mi,aB as rA,J as Ii,aC as ie,O as us,R as wi,aD as oA,at as Fi,aE as Ps,o as xi,aF as yi,aG as Qi,aH as Si,K as tr,M as er,aI as Xn,ac as nr,aJ as vi,aK as bi,aL as Mi,L as Ti,aM as Ri,aN as Pi,aO as Yi,aP as Oi,aQ as Gi}from"./BvMyOpMW.js";import{a as ki,b as sr,r as _i}from"./BHBmAp0t.js";function Li(e,t,n){for(var s=[],A=t.length,r,o=t.length,i=0;i<A;i++){let g=t[i];er(g,()=>{if(r){if(r.pending.delete(g),r.done.add(g),r.pending.size===0){var l=e.outrogroups;gs(Ps(r.done)),l.delete(r),l.size===0&&(e.outrogroups=null)}}else o-=1},!1)}if(o===0){var a=s.length===0&&n!==null;if(a){var c=n,u=c.parentNode;Mi(u),u.append(c),e.items.clear()}gs(t,!a)}else r={pending:new Set(t),done:new Set},(e.outrogroups??=new Set).add(r)}function gs(e,t=!0){for(var n=0;n<e.length;n++)Ti(e[n],t)}var iA;function dl(e,t,n,s,A,r=null){var o=e,i=new Map,a=(t&ZA)!==0;if(a){var c=e;o=Ee?jn(Ei(c)):c.appendChild(qn())}Ee&&hi();var u=null,g=Bi(()=>{var B=n();return xi(B)?B:B==null?[]:Ps(B)}),l,f=!0;function d(){h.fallback=u,Ni(h,l,o,t,s),u!==null&&(l.length===0?(u.f&ie)===0?tr(u):(u.f^=ie,je(u,null,o)):er(u,()=>{u=null}))}var E=di(()=>{l=sA(g);var B=l.length;let p=!1;if(Ee){var C=pi(o)===Di;C!==(B===0)&&(o=AA(),jn(o),$n(!1),p=!0)}for(var m=new Set,F=Ii,v=wi(),S=0;S<B;S+=1){Ee&&En.nodeType===Ci&&En.data===mi&&(o=En,p=!0,$n(!1));var x=l[S],k=s(x,S),Q=f?null:i.get(k);Q?(Q.v&&rA(Q.v,x),Q.i&&rA(Q.i,S),v&&F.skipped_effects.delete(Q.e)):(Q=Ui(i,f?o:iA??=qn(),x,k,S,A,t,n),f||(Q.e.f|=ie),i.set(k,Q)),m.add(k)}if(B===0&&r&&!u&&(f?u=us(()=>r(o)):(u=us(()=>r(iA??=qn())),u.f|=ie)),Ee&&B>0&&jn(AA()),!f)if(v){for(const[y,V]of i)m.has(y)||F.skipped_effects.add(V.e);F.oncommit(d),F.ondiscard(()=>{})}else d();p&&$n(!0),sA(g)}),h={effect:E,items:i,outrogroups:null,fallback:u};f=!1,Ee&&(o=En)}function Ni(e,t,n,s,A){var r=(s&bi)!==0,o=t.length,i=e.items,a=e.effect.first,c,u=null,g,l=[],f=[],d,E,h,B;if(r)for(B=0;B<o;B+=1)d=t[B],E=A(d,B),h=i.get(E).e,(h.f&ie)===0&&(h.nodes?.a?.measure(),(g??=new Set).add(h));for(B=0;B<o;B+=1){if(d=t[B],E=A(d,B),h=i.get(E).e,e.outrogroups!==null)for(const Q of e.outrogroups)Q.pending.delete(h),Q.done.delete(h);if((h.f&ie)!==0)if(h.f^=ie,h===a)je(h,null,n);else{var p=u?u.next:a;h===e.effect.last&&(e.effect.last=h.prev),h.prev&&(h.prev.next=h.next),h.next&&(h.next.prev=h.prev),le(e,u,h),le(e,h,p),je(h,p,n),u=h,l=[],f=[],a=u.next;continue}if((h.f&Xn)!==0&&(tr(h),r&&(h.nodes?.a?.unfix(),(g??=new Set).delete(h))),h!==a){if(c!==void 0&&c.has(h)){if(l.length<f.length){var C=f[0],m;u=C.prev;var F=l[0],v=l[l.length-1];for(m=0;m<l.length;m+=1)je(l[m],C,n);for(m=0;m<f.length;m+=1)c.delete(f[m]);le(e,F.prev,v.next),le(e,u,F),le(e,v,C),a=C,u=v,B-=1,l=[],f=[]}else c.delete(h),je(h,a,n),le(e,h.prev,h.next),le(e,h,u===null?e.effect.first:u.next),le(e,u,h),u=h;continue}for(l=[],f=[];a!==null&&a!==h;)(c??=new Set).add(a),f.push(a),a=a.next;if(a===null)continue}(h.f&ie)===0&&l.push(h),u=h,a=h.next}if(e.outrogroups!==null){for(const Q of e.outrogroups)Q.pending.size===0&&(gs(Ps(Q.done)),e.outrogroups?.delete(Q));e.outrogroups.size===0&&(e.outrogroups=null)}if(a!==null||c!==void 0){var S=[];if(c!==void 0)for(h of c)(h.f&Xn)===0&&S.push(h);for(;a!==null;)(a.f&Xn)===0&&a!==e.fallback&&S.push(a),a=a.next;var x=S.length;if(x>0){var k=(s&ZA)!==0&&o===0?n:null;if(r){for(B=0;B<x;B+=1)S[B].nodes?.a?.measure();for(B=0;B<x;B+=1)S[B].nodes?.a?.fix()}Li(e,S,k)}}r&&nr(()=>{if(g!==void 0)for(h of g)h.nodes?.a?.apply()})}function Ui(e,t,n,s,A,r,o,i){var a=(o&yi)!==0?(o&Qi)===0?Fi(n,!1,!1):oA(n):null,c=(o&Si)!==0?oA(A):null;return{v:a,i:c,e:us(()=>(r(t,a??n,c??A,i),()=>{e.delete(s)}))}}function je(e,t,n){if(e.nodes)for(var s=e.nodes.start,A=e.nodes.end,r=t&&(t.f&ie)===0?t.nodes.start:n;s!==null;){var o=vi(s);if(r.before(s),s===A)return;s=o}}function le(e,t,n){t===null?e.effect.first=n:t.next=n,n===null?e.effect.last=t:n.prev=t}const Hi=Symbol("is custom element"),Ki=Symbol("is html");function El(e){if(Ee){var t=!1,n=()=>{if(!t){if(t=!0,e.hasAttribute("value")){var s=e.value;aA(e,"value",null),e.value=s}if(e.hasAttribute("checked")){var A=e.checked;aA(e,"checked",null),e.checked=A}}};e.__on_r=n,nr(n),Gi()}}function hl(e,t){var n=Ys(e);n.value===(n.value=t??void 0)||e.value===t&&(t!==0||e.nodeName!=="PROGRESS")||(e.value=t??"")}function Bl(e,t){var n=Ys(e);n.checked!==(n.checked=t)&&(e.checked=t)}function aA(e,t,n,s){var A=Ys(e);Ee&&(A[t]=e.getAttribute(t),t==="src"||t==="srcset"||t==="href"&&e.nodeName==="LINK")||A[t]!==(A[t]=n)&&(t==="loading"&&(e[Ri]=n),n==null?e.removeAttribute(t):typeof n!="string"&&Ji(e).includes(t)?e[t]=n:e.setAttribute(t,n))}function Ys(e){return e.__attributes??={[Hi]:e.nodeName.includes("-"),[Ki]:e.namespaceURI===Pi}}var cA=new Map;function Ji(e){var t=e.getAttribute("is")||e.nodeName,n=cA.get(t);if(n)return n;cA.set(t,n=[]);for(var s,A=e,r=Element.prototype;r!==A;){s=Oi(A);for(var o in s)s[o].set&&n.push(o);A=Yi(A)}return n}function pl(e){return(ki||sr)+e}const Vi="";function Dl(...e){return sr+Vi+_i(e[0],e[1])}const nt=4294967295,J=65535,Xt=255,Os=8,ls=9,Ar=0,rr=99,or=67324752,Gs=134695760,ir=Gs,fs=33639248,ar=101010256,ds=101075792,cr=117853008,re=22,Xe=20,Ze=56,zi=re+Xe+Ze,ur=12,gr=20,yn=4,lr=1,fr=39169,dr=10,Er=1,ks=21589,Wi=28789,qi=25461,hr=6534,Br=30837,pr=30805,Es=1,ji=6,$i=2,Xi=4,Zi=6,hs=8,Bs=2048,Qn=16,ps=1,Ds=2,Cs=4,ms=32,uA=61440,tn=16384,en=73,Dn=420,Sn=2048,vn=1024,bn=512,ta=20,gA=45,lA=51,Cn="/",ve=30,_s=10,He=14,Ke=18,fA=new Date(2107,11,31),dA=new Date(1980,0,1),I=void 0,De="undefined",Te="function",ea="object",na=64;let Dr=2;try{typeof navigator!=De&&navigator.hardwareConcurrency&&(Dr=navigator.hardwareConcurrency)}catch{}const sa={workerURI:"./core/web-worker-wasm.js",wasmURI:"./core/streams/zlib-wasm/zlib-streams.wasm",chunkSize:64*1024,maxWorkers:Dr,terminateWorkerTimeout:5e3,useWebWorkers:!0,useCompressionStream:!0,CompressionStream:typeof CompressionStream!=De&&CompressionStream,DecompressionStream:typeof DecompressionStream!=De&&DecompressionStream},Cr=Object.assign({},sa);function mr(){return Cr}function Ir(e){return Math.max(e.chunkSize,na)}function Ln(e){const{baseURI:t,chunkSize:n,maxWorkers:s,terminateWorkerTimeout:A,useCompressionStream:r,useWebWorkers:o,CompressionStream:i,DecompressionStream:a,CompressionStreamZlib:c,DecompressionStreamZlib:u,workerURI:g,wasmURI:l}=e;_t("baseURI",t),_t("wasmURI",l),_t("workerURI",g),_t("chunkSize",n),_t("maxWorkers",s),_t("terminateWorkerTimeout",A),_t("useCompressionStream",r),_t("useWebWorkers",o),_t("CompressionStream",i),_t("DecompressionStream",a),_t("CompressionStreamZlib",c),_t("DecompressionStreamZlib",u)}function _t(e,t){t!==I&&(Cr[e]=t)}function Aa(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),p=16777215&o;if(p&&(u.set(a.subarray(l,l+p),0),n.enqueue(u.slice(0,p))),!t){const t=o>>24&255,e=128&t?t-256:t;if(0>e)throw new r("process error:"+e)}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),h=16777215&o,f=o>>24&255;if(!t){const t=128&f?f-256:f;if(0>t)throw new r("process error:"+t)}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 wr=[];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;wr[e]=t}class Mn{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^wr[(n^t[s])&255];this.crc=n}get(){return~this.crc}}class Fr extends TransformStream{constructor(){let t;const n=new Mn;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 mn(e){if(typeof TextEncoder==De){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 Qt={concat(e,t){if(e.length===0||t.length===0)return e.concat(t);const n=e[e.length-1],s=Qt.getPartial(n);return s===32?e.concat(t):Qt._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+Qt.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]=Qt.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=Qt.getPartial(A);return s.push(Qt.partial(t+r&31,t+r>32?n:s.pop(),1)),s}},Tn={bytes:{fromBits(e){const n=Qt.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(Qt.partial(8*(n&3),s)),t}}},xr={};xr.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=Tn.utf8String.toBits(e));const n=t._buffer=Qt.concat(t._buffer,e),s=t._length,A=t._length=s+Qt.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=Qt.concat(t,[Qt.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 c=0;c<16;c++)s[c]=e[c];let A=n[0],r=n[1],o=n[2],i=n[3],a=n[4];for(let c=0;c<=79;c++){c>=16&&(s[c]=t._S(1,s[c-3]^s[c-8]^s[c-14]^s[c-16]));const u=t._S(5,A)+t._f(c,r,o,i)+a+s[c]+t._key[Math.floor(c/20)]|0;a=i,i=o,o=t._S(30,r),r=A,A=u}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 yr={};yr.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 c=o[r-1];(r%A===0||A===8&&r%A===4)&&(c=n[c>>>24]<<24^n[c>>16&255]<<16^n[c>>8&255]<<8^n[c&255],r%A===0&&(c=c<<8^c>>>24^a<<24,a=a<<1^(a>>7)*283)),o[r]=o[r-A]^c}for(let c=0;r;c++,r--){const u=o[c&3?r:r-4];r<=4||c<4?i[c]=u:i[c]=s[0][n[u>>>24]]^s[1][n[u>>16&255]]^s[2][n[u>>8&255]]^s[3][n[u&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,c;for(let u=0;u<256;u++)r[(A[u]=u<<1^(u>>7)*283)^u]=u;for(let u=o=0;!n[u];u^=i||1,o=r[o]||1){let g=o^o<<1^o<<2^o<<3^o<<4;g=g>>8^g&255^99,n[u]=g,s[g]=u,c=A[a=A[i=A[u]]];let l=c*16843009^a*65537^i*257^u*16843008,f=A[g]*257^g*16843008;for(let d=0;d<4;d++)e[d][u]=f=f<<24^f>>>8,t[d][g]=l=l<<24^l>>>8}for(let u=0;u<5;u++)e[u]=e[u].slice(0),t[u]=t[u].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],c=r[3],u=r[4];let g=e[0]^n[0],l=e[t?3:1]^n[1],f=e[2]^n[2],d=e[t?1:3]^n[3],E=4,h,B,p;for(let C=0;C<s;C++)h=o[g>>>24]^i[l>>16&255]^a[f>>8&255]^c[d&255]^n[E],B=o[l>>>24]^i[f>>16&255]^a[d>>8&255]^c[g&255]^n[E+1],p=o[f>>>24]^i[d>>16&255]^a[g>>8&255]^c[l&255]^n[E+2],d=o[d>>>24]^i[g>>16&255]^a[l>>8&255]^c[f&255]^n[E+3],E+=4,g=h,l=B,f=p;for(let C=0;C<4;C++)A[t?3&-C:C]=u[g>>>24]<<24^u[l>>16&255]<<16^u[f>>8&255]<<8^u[d&255]^n[E++],h=g,g=l,l=f,f=d,d=h;return A}};const ra={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}},Qr={};Qr.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=Qt.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 Qt.clamp(t,A)}};const Me={importKey(e){return new Me.hmacSha1(Tn.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,c;const u=new ArrayBuffer(A),g=new DataView(u);let l=0;const f=Qt;for(t=Tn.bytes.toBits(t),c=1;l<(A||1);c++){for(r=o=e.encrypt(f.concat(t,[c])),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 u.slice(0,s/8)}};Me.hmacSha1=class{constructor(e){const t=this,n=t._hash=xr.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 oa=typeof crypto!=De&&typeof crypto.getRandomValues==Te,Sr="Invalid password",vr="Invalid signature",Ls="zipjs-abort-check-password";function br(e){return oa?crypto.getRandomValues(e):ra.getRandomValues(e)}const _e=16,ia="raw",Mr={name:"PBKDF2"},aa={name:"HMAC"},ca="SHA-1",ua=Object.assign({hash:aa},Mr),Is=Object.assign({iterations:1e3,hash:{name:ca}},Mr),ga=["deriveBits"],rn=[8,12,16],We=[16,24,32],fe=10,la=[0,0,0,0],Nn=typeof crypto!=De,cn=Nn&&crypto.subtle,Tr=Nn&&typeof cn!=De,te=Tn.bytes,fa=yr.aes,da=Qr.ctrGladman,Ea=Me.hmacSha1;let EA=Nn&&Tr&&typeof cn.importKey==Te,hA=Nn&&Tr&&typeof cn.deriveBits==Te;class ha 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:Yr(t,n),signed:s,strength:A-1,pending:new Uint8Array})},async transform(o,i){const a=this,{password:c,strength:u,resolveReady:g,ready:l}=a;c?(await pa(a,u,c,Ht(o,0,rn[u]+2)),o=Ht(o,rn[u]+2),r?i.error(new Error(Ls)):g()):await l;const f=new Uint8Array(o.length-fe-(o.length-fe)%_e);i.enqueue(Rr(a,o,f,0,fe,!0))},async flush(o){const{signed:i,ctr:a,hmac:c,pending:u,ready:g}=this;if(c&&a){await g;const l=Ht(u,0,u.length-fe),f=Ht(u,u.length-fe);let d=new Uint8Array;if(l.length){const E=an(te,l);c.update(E);const h=a.update(E);d=on(te,h)}if(i){const E=Ht(on(te,c.digest()),0,fe);for(let h=0;h<fe;h++)if(E[h]!=f[h])throw new Error(vr)}o.enqueue(d)}}})}}class Ba extends TransformStream{constructor({password:t,rawPassword:n,encryptionStrength:s}){let A;super({start(){Object.assign(this,{ready:new Promise(r=>this.resolveReady=r),password:Yr(t,n),strength:s-1,pending:new Uint8Array})},async transform(r,o){const i=this,{password:a,strength:c,resolveReady:u,ready:g}=i;let l=new Uint8Array;a?(l=await Da(i,c,a),u()):await g;const f=new Uint8Array(l.length+r.length-r.length%_e);f.set(l,0),o.enqueue(Rr(i,r,f,l.length,0))},async flush(r){const{ctr:o,hmac:i,pending:a,ready:c}=this;if(i&&o){await c;let u=new Uint8Array;if(a.length){const g=o.update(an(te,a));i.update(g),u=on(te,g)}A.signature=on(te,i.digest()).slice(0,fe),r.enqueue(Ns(u,A.signature))}}}),A=this}}function Rr(e,t,n,s,A,r){const{ctr:o,hmac:i,pending:a}=e,c=t.length-A;a.length&&(t=Ns(a,t),n=Ia(n,c-c%_e));let u;for(u=0;u<=c-_e;u+=_e){const g=an(te,Ht(t,u,u+_e));r&&i.update(g);const l=o.update(g);r||i.update(l),n.set(on(te,l),u+s)}return e.pending=Ht(t,u),n}async function pa(e,t,n,s){const A=await Pr(e,t,n,Ht(s,0,rn[t])),r=Ht(s,rn[t]);if(A[0]!=r[0]||A[1]!=r[1])throw new Error(Sr)}async function Da(e,t,n){const s=br(new Uint8Array(rn[t])),A=await Pr(e,t,n,s);return Ns(s,A)}async function Pr(e,t,n,s){e.password=null;const A=await Ca(ia,n,ua,!1,ga),r=await ma(Object.assign({salt:s},Is),A,8*(We[t]*2+2)),o=new Uint8Array(r),i=an(te,Ht(o,0,We[t])),a=an(te,Ht(o,We[t],We[t]*2)),c=Ht(o,We[t]*2);return Object.assign(e,{keys:{key:i,authentication:a,passwordVerification:c},ctr:new da(new fa(i),Array.from(la)),hmac:new Ea(a)}),c}async function Ca(e,t,n,s,A){if(EA)try{return await cn.importKey(e,t,n,s,A)}catch{return EA=!1,Me.importKey(t)}else return Me.importKey(t)}async function ma(e,t,n){if(hA)try{return await cn.deriveBits(e,t,n)}catch{return hA=!1,Me.pbkdf2(t,e.salt,Is.iterations,n)}else return Me.pbkdf2(t,e.salt,Is.iterations,n)}function Yr(e,t){return t===I?mn(e):t}function Ns(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 Ia(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 on(e,t){return e.fromBits(t)}function an(e,t){return e.toBits(t)}const nn=12;class wa extends TransformStream{constructor({password:t,passwordVerification:n,checkPasswordOnly:s}){super({start(){Object.assign(this,{password:t,passwordVerification:n}),Or(this,t)},transform(A,r){const o=this;if(o.password){const i=BA(o,A.subarray(0,nn));if(o.password=null,i.at(-1)!=o.passwordVerification)throw new Error(Sr);A=A.subarray(nn)}s?r.error(new Error(Ls)):r.enqueue(BA(o,A))}})}}class Fa extends TransformStream{constructor({password:t,passwordVerification:n}){super({start(){Object.assign(this,{password:t,passwordVerification:n}),Or(this,t)},transform(s,A){const r=this;let o,i;if(r.password){r.password=null;const a=br(new Uint8Array(nn));a[nn-1]=r.passwordVerification,o=new Uint8Array(s.length+a.length),o.set(pA(r,a),0),i=nn}else o=new Uint8Array(s.length),i=0;o.set(pA(r,s),i),A.enqueue(o)}})}}function BA(e,t){const n=new Uint8Array(t.length);for(let s=0;s<t.length;s++)n[s]=Gr(e)^t[s],Us(e,n[s]);return n}function pA(e,t){const n=new Uint8Array(t.length);for(let s=0;s<t.length;s++)n[s]=Gr(e)^t[s],Us(e,t[s]);return n}function Or(e,t){const n=[305419896,591751049,878082192];Object.assign(e,{keys:n,crcKey0:new Mn(n[0]),crcKey2:new Mn(n[2])});for(let s=0;s<t.length;s++)Us(e,t.charCodeAt(s))}function Us(e,t){let[n,s,A]=e.keys;e.crcKey0.append([t]),n=~e.crcKey0.get(),s=DA(Math.imul(DA(s+kr(n)),134775813)+1),e.crcKey2.append([s>>>24]),A=~e.crcKey2.get(),e.keys=[n,s,A]}function Gr(e){const t=e.keys[2]|2;return kr(Math.imul(t,t^1)>>>8)}function kr(e){return e&255}function DA(e){return e&4294967295}const _r="Invalid uncompressed size",xa="deflate-raw",ya="deflate64-raw";class Qa extends TransformStream{constructor(t,{chunkSize:n,CompressionStreamZlib:s,CompressionStream:A}){super({});const{compressed:r,encrypted:o,useCompressionStream:i,zipCrypto:a,signed:c,level:u}=t,g=this;let l,f,d=super.readable;(!o||a)&&c&&(l=new Fr,d=ee(d,l)),r&&(d=Nr(d,i,{level:u,chunkSize:n},A,s,A)),o&&(a?d=ee(d,new Fa(t)):(f=new Ba(t),d=ee(d,f))),Lr(g,d,()=>{let E;o&&!a&&(E=f.signature),(!o||a)&&c&&(E=new DataView(l.value.buffer).getUint32(0)),g.signature=E})}}class Sa extends TransformStream{constructor(t,{chunkSize:n,DecompressionStreamZlib:s,DecompressionStream:A}){super({});const{zipCrypto:r,encrypted:o,signed:i,signature:a,compressed:c,useCompressionStream:u,deflate64:g}=t;let l,f,d=super.readable;o&&(r?d=ee(d,new wa(t)):(f=new ha(t),d=ee(d,f))),c&&(d=Nr(d,u,{chunkSize:n,deflate64:g},A,s,A)),(!o||r)&&i&&(l=new Fr,d=ee(d,l)),Lr(this,d,()=>{if((!o||r)&&i){const E=new DataView(l.value.buffer);if(a!=E.getUint32(0,!1))throw new Error(vr)}})}}function Lr(e,t,n){t=ee(t,new TransformStream({flush:n})),Object.defineProperty(e,"readable",{get(){return t}})}function Nr(e,t,n,s,A,r){const o=t&&s?s:A||r,i=n.deflate64?ya:xa;try{e=ee(e,new o(i,n))}catch(a){if(t)if(A)e=ee(e,new A(i,n));else if(r)e=ee(e,new r(i,n));else throw a;else throw a}return e}function ee(e,t){return e.pipeThrough(t)}const va="message",ba="start",Ma="pull",CA="data",Ta="ack",mA="close",Ur="deflate",Hr="inflate";class Ra extends TransformStream{constructor(t,n){super({});const s=this,{codecType:A}=t;let r;A.startsWith(Ur)?r=Qa:A.startsWith(Hr)&&(r=Sa),s.outputSize=0;let o=0;const i=new r(t,n),a=super.readable,c=new TransformStream({transform(g,l){g&&g.length&&(o+=g.length,l.enqueue(g))},flush(){Object.assign(s,{inputSize:o})}}),u=new TransformStream({transform(g,l){if(g&&g.length&&(l.enqueue(g),s.outputSize+=g.length,t.outputSize!==I&&s.outputSize>t.outputSize))throw new Error(_r)},flush(){const{signature:g}=i;Object.assign(s,{signature:g,inputSize:o})}});Object.defineProperty(s,"readable",{get(){return a.pipeThrough(c).pipeThrough(i).pipeThrough(u)}})}}class Pa 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 Kr=typeof Worker!=De,Jr=()=>{};function Ya({initModule:e}){Jr=e}class Zn{constructor(t,{readable:n,writable:s},{options:A,config:r,streamOptions:o,useWebWorkers:i,transferStreams:a,workerURI:c},u){const{signal:g}=o;return Object.assign(t,{busy:!0,readable:n.pipeThrough(new Pa(r.chunkSize)).pipeThrough(new Oa(o),{signal:g}),writable:s,options:Object.assign({},A),workerURI:c,transferStreams:a,terminate(){return new Promise(l=>{const{worker:f,busy:d}=t;f?(d?t.resolveTerminated=l:(f.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,u(t)}}),(i&&Kr?Ga:Vr)(t,r)}}class Oa extends TransformStream{constructor({onstart:t,onprogress:n,size:s,onend:A}){let r=0;super({async start(){t&&await ts(t,s)},async transform(o,i){r+=o.length,n&&await ts(n,r,s),i.enqueue(o)},async flush(){A&&await ts(A,r)}})}}async function ts(e,...t){try{await e(...t)}catch{}}function Vr(e,t){return{run:()=>ka(e,t)}}function Ga(e,t){const{baseURI:n,chunkSize:s}=t;let{wasmURI:A}=t;if(!e.interface){typeof A==Te&&(A=A());let r;try{r=Na(e.workerURI,n,e)}catch{return Kr=!1,Vr(e,t)}Object.assign(e,{worker:r,interface:{run:()=>_a(e,{chunkSize:s,wasmURI:A,baseURI:n})}})}return e.interface}async function ka({options:e,readable:t,writable:n,onTaskFinished:s},A){let r;try{if(!e.useCompressionStream)try{await Jr(A)}catch{e.useCompressionStream=!0}r=new Ra(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 _a(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}=La(e.writable),c=In({type:ba,options:o,config:t,readable:r,writable:i},e);c||Object.assign(e,{reader:r.getReader(),writer:i.getWriter()});const u=await A;return c||await i.getWriter().close(),await a,u}function La(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 IA=!0;function Na(e,t,n){const s={type:"module"};let A,r;if(typeof e==Te&&(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(va,o=>Ua(o,n)),r}function In(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&&IA?(o&&a.push(o),i&&a.push(i)):e.readable=e.writable=null,a.length)try{return t.postMessage(e,a),!0}catch{IA=!1,e.readable=e.writable=null,t.postMessage(e)}else t.postMessage(e)}catch(r){throw n&&n.releaseLock(),s(),r}}async function Ua({data:e},t){const{type:n,value:s,messageId:A,result:r,error:o}=e,{reader:i,writer:a,resolveResult:c,rejectResult:u,onTaskFinished:g}=t;try{if(o){const{message:f,stack:d,code:E,name:h,outputSize:B}=o,p=new Error(f);Object.assign(p,{stack:d,code:E,name:h,outputSize:B}),l(p)}else{if(n==Ma){const{value:f,done:d}=await i.read();In({type:CA,value:f,done:d,messageId:A},t)}n==CA&&(await a.ready,await a.write(new Uint8Array(s)),In({type:Ta,messageId:A},t)),n==mA&&l(null,r)}}catch(f){In({type:mA,messageId:A},t),l(f)}function l(f,d){f?u(f):c(d),a&&a.releaseLock(),g()}}let Se=[];const es=[];let wA=0;async function zr(e,t){const{options:n,config:s}=t,{transferStreams:A,useWebWorkers:r,useCompressionStream:o,compressed:i,signed:a,encrypted:c}=n,{workerURI:u,maxWorkers:g}=s;t.transferStreams=A||A===I;const l=!i&&!a&&!c&&!t.transferStreams;return t.useWebWorkers=!l&&(r||r===I&&s.useWebWorkers),t.workerURI=t.useWebWorkers&&u?u:I,n.useCompressionStream=o||o===I&&s.useCompressionStream,(await f()).run();async function f(){const E=Se.find(h=>!h.busy);if(E)return FA(E),new Zn(E,e,t,d);if(Se.length<g){const h={indexWorker:wA};return wA++,Se.push(h),new Zn(h,e,t,d)}else return new Promise(h=>es.push({resolve:h,stream:e,workerOptions:t}))}function d(E){if(es.length){const[{resolve:h,stream:B,workerOptions:p}]=es.splice(0,1);h(new Zn(E,B,p,d))}else E.worker?(FA(E),Ha(E,t)):Se=Se.filter(h=>h!=E)}}function Ha(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 FA(e){const{terminateTimeout:t}=e;t&&(clearTimeout(t),e.terminateTimeout=null)}const Ka="Writer iterator completed too soon",Ja="text/plain",Va="Content-Type",za=64*1024,Wr="writable";class Hs{constructor(){this.size=0}init(){this.initialized=!0}}class qr extends Hs{get readable(){const t=this,{chunkSize:n=za}=t,s=new ReadableStream({start(){this.chunkOffset=0},async pull(A){const{offset:r=0,size:o,diskNumberStart:i}=s,{chunkOffset:a}=this,c=o===I?n:Math.min(n,o-a),u=await pt(t,r+a,c,i);A.enqueue(u),a+n>o||o===I&&!u.length&&c?A.close():this.chunkOffset+=n}});return s}}class jr extends qr{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 Wa extends Hs{constructor(t){super();const n=this,s=new TransformStream,A=[];t&&A.push([Va,t]),Object.defineProperty(n,Wr,{get(){return s.writable}}),n.blob=new Response(s.readable,{headers:A}).blob()}getData(){return this.blob}}class yt extends jr{constructor(t){super(new Blob([t],{type:Ja}))}}class qa extends qr{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 c=r[i];if(c){const u=c.size;if(a+n<=u)o=await pt(c,a,n);else{const g=u-a;o=new Uint8Array(n);const l=await pt(c,a,g);o.set(l,0);const f=await A.readUint8Array(t+g,n-g,s);o.set(f,g),l.length+f.length<n&&(o=o.subarray(0,l.length+f.length))}}else o=new Uint8Array;return A.lastDiskNumber=Math.max(i,A.lastDiskNumber),o}}class xA extends Hs{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(u){const{availableSize:g}=s;if(o)u.length>=g?(await a(u.subarray(0,g)),await c(),s.diskOffset+=A.size,s.diskNumber++,o=null,await this.write(u.subarray(g))):await a(u);else{const{value:l,done:f}=await t.next();if(f&&!l)throw new Error(Ka);A=l,A.size=0,A.maxSize&&(s.maxSize=A.maxSize),s.availableSize=s.maxSize,await Ce(A),r=l.writable,o=r.getWriter(),await this.write(u)}},async close(){await o.ready,await c()}});Object.defineProperty(s,Wr,{get(){return i}});async function a(u){const g=u.length;g&&(await o.ready,await o.write(u),A.size+=g,s.size+=g,s.availableSize-=g)}async function c(){await o.close()}}}class Ks{constructor(t){return Array.isArray(t)&&(t=new qa(t)),t instanceof ReadableStream&&(t={readable:t}),t}}class $r{constructor(t){return t.writable===I&&typeof t.next==Te&&(t=new xA(t)),t instanceof WritableStream&&(t={writable:t}),t.size===I&&(t.size=0),t instanceof xA||Object.assign(t,{diskNumber:0,diskOffset:0,availableSize:1/0,maxSize:1/0}),t}}async function Ce(e,t){if(e.init&&!e.initialized)await e.init(t);else return Promise.resolve()}function pt(e,t,n,s){return e.readUint8Array(t,n,s)}const Xr="\0☺☻♥♦♣♠•◘○◙♂♀♪♫☼►◄↕‼¶§▬↨↑↓→←∟↔▲▼ !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~⌂ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜ¢£¥₧ƒáíóúñѪº¿⌐¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ ".split(""),ja=Xr.length==256;function $a(e){if(ja){let t="";for(let n=0;n<e.length;n++)t+=Xr[e[n]];return t}else return new TextDecoder().decode(e)}function wn(e,t){return t&&t.trim().toLowerCase()=="cp437"?$a(e):new TextDecoder(t).decode(e)}const Zr="filename",to="rawFilename",Js="comment",eo="rawComment",Vs="uncompressedSize",no="compressedSize",so="offset",Ao="diskNumberStart",Rn="lastModDate",ws="rawLastModDate",zs="lastAccessDate",Xa="rawLastAccessDate",Ws="creationDate",ro="rawCreationDate",oo="internalFileAttributes",io="externalFileAttributes",ao="msdosAttributesRaw",co="msdosAttributes",uo="msDosCompatible",qs="zip64",go="encrypted",lo="version",fo="versionMadeBy",Eo="zipCrypto",Fn="directory",ho="executable",Bo="compressionMethod",po="signature",Do="extraField",Za="extraFieldInfoZip",tc="extraFieldUnix",Co="uid",mo="gid",Io="unixMode",wo="setuid",Fo="setgid",xo="sticky",ec="bitFlag",nc="filenameUTF8",sc="commentUTF8",Ac="rawExtraField",rc="extraFieldZip64",oc="extraFieldUnicodePath",ic="extraFieldUnicodeComment",ac="extraFieldAES",cc="extraFieldNTFS",uc="extraFieldExtendedTimestamp",gc=[Zr,to,Vs,no,Rn,ws,Js,eo,zs,Ws,ro,so,Ao,oo,io,ao,co,uo,qs,go,lo,fo,Eo,Fn,ho,Bo,po,Do,tc,Za,Co,mo,Io,wo,Fo,xo,ec,nc,sc,Ac,rc,oc,ic,ac,cc,uc];class Pn{constructor(t){gc.forEach(n=>this[n]=t[n])}}const lc="filenameEncoding",fc="commentEncoding",dc="decodeText",Ec="extractPrependedData",hc="extractAppendedData",yo="password",Qo="rawPassword",So="passThrough",vo="signal",Bc="checkPasswordOnly",pc="checkOverlappingEntryOnly",Dc="checkOverlappingEntry",Cc="checkSignature",bo="useWebWorkers",Mo="useCompressionStream",mc="transferStreams",To="preventClose",Ic="encryptionStrength",wc="extendedTimestamp",Fc="keepOrder",xc="level",yc="bufferedWrite",Qc="dataDescriptorSignature",Sc="useUnicodeFileNames",vc="dataDescriptor",Ro="supportZip64SplitFile",bc="encodeText",yA="offset",Po="usdz",Mc="unixExtraFieldType",ns="File format is not recognized",Tc="End of central directory not found",Rc="End of Zip64 central directory locator not found",Pc="Central directory header not found",Yc="Local file header not found",Oc="Zip64 extra field not found",Gc="File contains encrypted entry",kc="Encryption method not supported",QA="Compression method not supported",SA="Split zip file",_c="Overlapping entry found",vA="utf-8",Lc="UTF8",bA="cp437",Nc=[[Vs,nt],[no,nt],[so,nt],[Ao,J]],Uc={[J]:{getValue:tt,bytes:4},[nt]:{getValue:Ne,bytes:8}};class Hc{constructor(t,n={}){Object.assign(this,{reader:new Ks(t),options:n,config:mr(),readRanges:[]})}async*getEntriesGenerator(t={}){const n=this;let{reader:s}=n;const{config:A}=n;if(await Ce(s),(s.size===I||!s.readUint8Array)&&(s=new jr(await new Response(s.readable).blob()),await Ce(s)),s.size<re)throw new Error(ns);s.chunkSize=Ir(A);const r=await jc(s,ar,s.size,re,J*16);if(!r){const Q=await pt(s,0,4),y=et(Q);throw tt(y)==Gs?new Error(SA):new Error(Tc)}const o=et(r);let i=tt(o,12),a=tt(o,16);const c=r.offset,u=Et(o,20),g=c+re+u;let l=Et(o,4);const f=s.lastDiskNumber||0;let d=Et(o,6),E=Et(o,8),h=0,B=0;if(a==nt||i==nt||E==J||d==J){const Q=await pt(s,r.offset-Xe,Xe),y=et(Q);if(tt(y,0)==cr){a=Ne(y,8);let V=await pt(s,a,Ze,-1),G=et(V);const R=r.offset-Xe-Ze;if(tt(G,0)!=ds&&a!=R){const T=a;a=R,a>T&&(h=a-T),V=await pt(s,a,Ze,-1),G=et(V)}if(tt(G,0)!=ds)throw new Error(Rc);l==J&&(l=tt(G,16)),d==J&&(d=tt(G,20)),E==J&&(E=Ne(G,32)),i==nt&&(i=Ne(G,40)),a-=i}}if(a>=s.size&&(h=s.size-a-i-re,a=s.size-i-re),f!=l)throw new Error(SA);if(a<0)throw new Error(ns);let p=0,C=await pt(s,a,i,d),m=et(C);if(i){const Q=r.offset-i;if(tt(m,p)!=fs&&a!=Q){const y=a;a=Q,a>y&&(h+=a-y),C=await pt(s,a,i,d),m=et(C)}}const F=r.offset-a-(s.lastDiskOffset||0);if(i!=F&&F>=0&&(i=F,C=await pt(s,a,i,d),m=et(C)),a<0||a>=s.size)throw new Error(ns);const v=ht(n,t,lc),S=ht(n,t,fc);for(let Q=0;Q<E;Q++){const y=new Kc(s,A,n.options);if(tt(m,p)!=fs)throw new Error(Pc);Yo(y,m,p+6);const V=!!y.bitFlag.languageEncodingFlag,G=p+46,R=G+y.filenameLength,T=R+y.extraFieldLength,z=Et(m,p+4),W=z>>8==0,Dt=z>>8==3,gt=C.subarray(G,R),Ft=Et(m,p+32),Ct=T+Ft,vt=C.subarray(T,Ct),j=V,rt=V,mt=tt(m,p+38),U=mt&Xt,$={readOnly:!!(U&ps),hidden:!!(U&Ds),system:!!(U&Cs),directory:!!(U&Qn),archive:!!(U&ms)},H=tt(m,p+42)+h,w=ht(n,t,dc)||wn,It=j?vA:v||bA,Ot=rt?vA:S||bA;let xt=w(gt,It);xt===I&&(xt=wn(gt,It));let wt=w(vt,Ot);wt===I&&(wt=wn(vt,Ot)),Object.assign(y,{versionMadeBy:z,msDosCompatible:W,compressedSize:0,uncompressedSize:0,commentLength:Ft,offset:H,diskNumberStart:Et(m,p+34),internalFileAttributes:Et(m,p+36),externalFileAttributes:mt,msdosAttributesRaw:U,msdosAttributes:$,rawFilename:gt,filenameUTF8:j,commentUTF8:rt,rawExtraField:C.subarray(R,T),rawComment:vt,filename:xt,comment:wt}),B=Math.max(H,B),Oo(y,y,m,p+6);const lt=y.externalFileAttributes>>16&J;y.unixMode===I&&(lt&(Dn|en|tn))!=0&&(y.unixMode=lt);const ft=!!(y.unixMode&Sn),Jt=!!(y.unixMode&vn),Gt=!!(y.unixMode&bn),bt=y.unixMode!==I?(y.unixMode&en)!=0:Dt&&(lt&en)!=0,Wt=y.unixMode!==I&&(y.unixMode&uA)==tn,Ie=(lt&uA)==tn;Object.assign(y,{setuid:ft,setgid:Jt,sticky:Gt,unixExternalUpper:lt,internalFileAttribute:y.internalFileAttributes,externalFileAttribute:y.externalFileAttributes,executable:bt,directory:Wt||Ie||W&&$.directory||xt.endsWith(Cn)&&!y.uncompressedSize,zipCrypto:y.encrypted&&!y.extraFieldAES});const qt=new Pn(y);qt.getData=(Pe,ne)=>y.getData(Pe,qt,n.readRanges,ne),qt.arrayBuffer=async Pe=>{const ne=new TransformStream,[ze]=await Promise.all([new Response(ne.readable).arrayBuffer(),y.getData(ne,qt,n.readRanges,Pe)]);return ze},p=Ct;const{onprogress:we}=t;if(we)try{await we(Q+1,E,new Pn(y))}catch{}yield qt}const x=ht(n,t,Ec),k=ht(n,t,hc);return x&&(n.prependedData=B>0?await pt(s,0,B):new Uint8Array),n.comment=u?await pt(s,c+re,u):new Uint8Array,k&&(n.appendedData=g<s.size?await pt(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 Kc{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:c,extraFieldZip64:u,compressionMethod:g,config:l,bitFlag:f,signature:d,rawLastModDate:E,uncompressedSize:h,compressedSize:B}=r,{dataDescriptor:p}=f,C=n.localDirectory={},m=await pt(o,i,ve,a),F=et(m);let v=ht(r,A,yo),S=ht(r,A,Qo);const x=ht(r,A,So);if(v=v&&v.length&&v,S=S&&S.length&&S,c&&c.originalCompressionMethod!=rr)throw new Error(QA);if(g!=Ar&&g!=Os&&g!=ls&&!x)throw new Error(QA);if(tt(F,0)!=or)throw new Error(Yc);Yo(C,F,4);const{extraFieldLength:k,filenameLength:Q,lastAccessDate:y,creationDate:V}=C;C.rawExtraField=k?await pt(o,i+ve+Q,k,a):new Uint8Array,Oo(r,C,F,4,!0),Object.assign(n,{lastAccessDate:y,creationDate:V});const G=r.encrypted&&C.encrypted&&!x,R=G&&!c;if(x||(n.zipCrypto=R),G){if(!R&&c.strength===I)throw new Error(kc);if(!v&&!S)throw new Error(Gc)}const T=i+ve+Q+k,z=B,W=o.readable;Object.assign(W,{diskNumberStart:a,offset:T,size:z});const Dt=ht(r,A,vo),gt=ht(r,A,Bc);let Ft=ht(r,A,Dc);const Ct=ht(r,A,pc);Ct&&(Ft=!0);const{onstart:vt,onprogress:j,onend:rt}=A,mt=g==ls;let U=ht(r,A,Mo);mt&&(U=!1);const $={options:{codecType:Hr,password:v,rawPassword:S,zipCrypto:R,encryptionStrength:c&&c.strength,signed:ht(r,A,Cc)&&!x,passwordVerification:R&&(p?E>>>8&Xt:d>>>24&Xt),outputSize:x?B:h,signature:d,compressed:g!=0&&!x,encrypted:r.encrypted&&!x,useWebWorkers:ht(r,A,bo),useCompressionStream:U,transferStreams:ht(r,A,mc),deflate64:mt,checkPasswordOnly:gt},config:l,streamOptions:{signal:Dt,size:z,onstart:vt,onprogress:j,onend:rt}};Ft&&await qc({reader:o,fileEntry:n,offset:i,diskNumberStart:a,signature:d,compressedSize:B,uncompressedSize:h,dataOffset:T,dataDescriptor:p||C.bitFlag.dataDescriptor,extraFieldZip64:u||C.extraFieldZip64,readRanges:s});let H;try{if(!Ct){gt&&(t=new WritableStream),t=new $r(t),await Ce(t,x?B:h),{writable:H}=t;const{outputSize:w}=await zr({readable:W,writable:H},$);if(t.size+=w,w!=(x?B:h))throw new Error(_r)}}catch(w){if(w.outputSize!==I&&(t.size+=w.outputSize),!gt||w.message!=Ls)throw w}finally{!ht(r,A,To)&&H&&!H.locked&&await H.getWriter().close()}return gt||Ct?I:t.getData?t.getData():H}}function Yo(e,t,n){const s=e.rawBitFlag=Et(t,n+2),A=(s&Es)==Es,r=tt(t,n+6);Object.assign(e,{encrypted:A,version:Et(t,n),bitFlag:{level:(s&ji)>>1,dataDescriptor:(s&hs)==hs,languageEncodingFlag:(s&Bs)==Bs},rawLastModDate:r,lastModDate:$c(r),filenameLength:Et(t,n+22),extraFieldLength:Et(t,n+24)})}function Oo(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 p=Et(i,a),C=Et(i,a+2);o.set(p,{type:p,data:r.slice(a+4,a+4+C)}),a+=4+C}}catch{}const c=Et(n,s+4);Object.assign(t,{signature:tt(n,s+_s),compressedSize:tt(n,s+He),uncompressedSize:tt(n,s+Ke)});const u=o.get(lr);u&&(Jc(u,t),t.extraFieldZip64=u);const g=o.get(Wi);g&&(MA(g,Zr,to,t,e),t.extraFieldUnicodePath=g);const l=o.get(qi);l&&(MA(l,Js,eo,t,e),t.extraFieldUnicodeComment=l);const f=o.get(fr);f?(Vc(f,t,c),t.extraFieldAES=f):t.compressionMethod=c;const d=o.get(dr);d&&(zc(d,t),t.extraFieldNTFS=d);const E=o.get(pr);if(E)TA(E,t,!1),t.extraFieldUnix=E;else{const p=o.get(Br);p&&(TA(p,t,!0),t.extraFieldInfoZip=p)}const h=o.get(ks);h&&(Wc(h,t,A),t.extraFieldExtendedTimestamp=h);const B=o.get(hr);B&&(t.extraFieldUSDZ=B)}function Jc(e,t){t.zip64=!0;const n=et(e.data),s=Nc.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=Uc[i];t[o]=e[o]=a.getValue(n,r),r+=a.bytes}else if(e[o])throw new Error(Oc)}}function MA(e,t,n,s,A){const r=et(e.data),o=new Mn;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:pe(r,0),[t]:wn(e.data.subarray(5)),valid:!A.bitFlag.languageEncodingFlag&&a==tt(i,0)}),e.valid&&(s[t]=e[t],s[t+Lc]=!0)}function Vc(e,t,n){const s=et(e.data),A=pe(s,4);Object.assign(e,{vendorVersion:pe(s,0),vendorId:pe(s,2),strength:A,originalCompressionMethod:n,compressionMethod:Et(s,5)}),t.compressionMethod=e.compressionMethod}function zc(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==Er&&(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 c=ss(o),u=ss(i),g=ss(a),l={lastModDate:c,lastAccessDate:u,creationDate:g};Object.assign(e,l),Object.assign(t,l)}}catch{}}function TA(e,t,n){try{const s=et(new Uint8Array(e.data));let A=0;const r=pe(s,A++),o=pe(s,A++),i=e.data.subarray(A,A+o);A+=o;const a=RA(i),c=pe(s,A++),u=e.data.subarray(A,A+c);A+=c;const g=RA(u);let l=I;if(!n&&A+2<=e.data.length){const f=e.data;l=new DataView(f.buffer,f.byteOffset+A,2).getUint16(0,!0)}Object.assign(e,{version:r,uid:a,gid:g,unixMode:l}),a!==I&&(t.uid=a),g!==I&&(t.gid=g),l!==I&&(t.unixMode=l)}catch{}}function RA(e){const t=new Uint8Array(4);return t.set(e,0),new DataView(t.buffer,t.byteOffset,4).getUint32(0,!0)}function Wc(e,t,n){const s=et(e.data),A=pe(s,0),r=[],o=[];n?((A&1)==1&&(r.push(Rn),o.push(ws)),(A&2)==2&&(r.push(zs),o.push(Xa)),(A&4)==4&&(r.push(Ws),o.push(ro))):e.data.length>=5&&(r.push(Rn),o.push(ws));let i=1;r.forEach((a,c)=>{if(e.data.length>=i+4){const u=tt(s,i);t[a]=e[a]=new Date(u*1e3);const g=o[c];e[g]=u}i+=4})}async function qc({reader:e,fileEntry:t,offset:n,diskNumberStart:s,signature:A,compressedSize:r,uncompressedSize:o,dataOffset:i,dataDescriptor:a,extraFieldZip64:c,readRanges:u}){let g=0;if(s)for(let d=0;d<s;d++){const E=e.readers[d];g+=E.size}let l=0;if(a&&(c?l=gr:l=ur),l){const d=await pt(e,i+r,l+yn,s);if(tt(et(d),0)==ir){const h=tt(et(d),4);let B,p;c?(B=Ne(et(d),8),p=Ne(et(d),16)):(B=tt(et(d),8),p=tt(et(d),12)),(t.encrypted&&!t.zipCrypto||h==A)&&B==r&&p==o&&(l+=yn)}}const f={start:g+n,end:g+i+r+l,fileEntry:t};for(const d of u)if(d.fileEntry!=t&&f.start>=d.start&&f.start<d.end){const E=new Error(_c);throw E.overlappingEntry=d.fileEntry,E}u.push(f)}async function jc(e,t,n,s,A){const r=new Uint8Array(4),o=et(r);Xc(o,0,t);const i=s+A;return await a(s)||await a(Math.min(i,n));async function a(c){const u=n-c,g=await pt(e,u,c);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:u+l,buffer:g.slice(l,l+s).buffer}}}function ht(e,t,n){return t[n]===I?e.options[n]:t[n]}function $c(e){const t=(e&4294901760)>>16,n=e&J;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 ss(e){return new Date(Number(e/BigInt(1e4)-BigInt(116444736e5)))}function pe(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 Ne(e,t){return Number(e.getBigUint64(t,!0))}function Xc(e,t,n){e.setUint32(t,n,!0)}function et(e){return new DataView(e.buffer)}const Zc="File already exists",tu="Zip file comment exceeds 64KB",eu="File entry comment exceeds 64KB",nu="File entry name exceeds 64KB",PA="Version exceeds 65535",su="The strength must equal 1, 2, or 3",Au="Extra field type exceeds 65535",ru="Extra field data exceeds 64KB",js="Zip64 is not supported (make sure 'keepOrder' is set to 'true')",ou="Undefined uncompressed size",iu="Zip file not empty",au="Invalid uid (must be integer 0..2^32-1)",cu="Invalid gid (must be integer 0..2^32-1)",uu="Invalid UNIX mode (must be integer 0..65535)",gu="Invalid unixExtraFieldType (must be 'infozip' or 'unix')",lu="Invalid msdosAttributesRaw (must be integer 0..255)",fu="Invalid msdosAttributes (must be an object with boolean flags)",YA=new Uint8Array([7,0,2,0,65,69,3,0,0]),Go="infozip",ko="unix";let As=0;const OA=[];class du{constructor(t,n={}){t=new $r(t);const s=t.availableSize!==I&&t.availableSize>0&&t.availableSize!==1/0&&t.maxSize!==I&&t.maxSize>0&&t.maxSize!==1/0;Object.assign(this,{writer:t,addSplitZipSignature:s,options:n,config:mr(),files:new Map,filenames:new Set,offset:n[yA]===I?t.size||t.writable.size||0:n[yA],pendingEntriesSize:0,pendingAddFileCalls:new Set,bufferedWrites:0})}async prependZip(t){if(this.filenames.size)throw new Error(iu);t=new Ks(t);const n=new Hc(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:c,rawFilename:u,bitFlag:g,encrypted:l,uncompressedSize:f,compressedSize:d,diskOffset:E,diskNumber:h,zip64:B}=A;let{rawExtraFieldZip64:p,rawExtraFieldAES:C,rawExtraFieldExtendedTimestamp:m,rawExtraFieldNTFS:F,rawExtraFieldUnix:v,rawExtraField:S}=A;const{level:x,languageEncodingFlag:k,dataDescriptor:Q}=g;p=p||new Uint8Array,C=C||new Uint8Array,m=m||new Uint8Array,F=F||new Uint8Array,v=A.rawExtraFieldUnix||new Uint8Array,S=S||new Uint8Array;const y=O(p,C,m,F,v,S),V=B&&f>nt,G=B&&d>nt,{headerArray:R,headerView:T}=_o({version:r,bitFlag:Lo(x,k,Q,l,o),compressionMethod:o,uncompressedSize:f,compressedSize:d,lastModDate:i,rawFilename:u,zip64CompressedSize:G,zip64UncompressedSize:V,extraFieldLength:y});return Object.assign(A,{zip64UncompressedSize:V,zip64CompressedSize:G,zip64Offset:B&&this.offset-E>nt,zip64DiskNumberStart:B&&h>J,rawExtraFieldZip64:p,rawExtraFieldAES:C,rawExtraFieldExtendedTimestamp:m,rawExtraFieldNTFS:F,rawExtraFieldUnix:v,rawExtraField:S,extendedTimestamp:m.length>0||F.length>0,extraFieldExtendedTimestampFlag:1+(a?2:0)+(c?4:0),headerArray:R,headerView:T}),[A.filename,A]}))}async add(t="",n,s={}){const A=this,{pendingAddFileCalls:r,config:o}=A;As<o.maxWorkers?As++:await new Promise(a=>OA.push(a));let i;try{if(t=t.trim(),A.filenames.has(t))throw new Error(Zc);return A.filenames.add(t),i=Eu(A,t,n,s),r.add(i),await i}catch(a){throw A.filenames.delete(t),a}finally{r.delete(i);const a=OA.shift();a?a():As--}}remove(t){const{filenames:n,files:s}=this;if(typeof t=="string"&&(t=s.get(t)),t&&t.filename!==I){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 Fu(s,t,n),M(s,n,To)||await o.getWriter().close(),r.getData?r.getData():o}}async function Eu(e,t,n,s){t=t.trim();let A=M(e,s,uo),r=M(e,s,fo,A?20:768);const o=M(e,s,ho),i=M(e,s,Co),a=M(e,s,mo);let c=M(e,s,Io);const u=M(e,s,Mc);let g=M(e,s,wo),l=M(e,s,Fo),f=M(e,s,xo);if(i!==I&&(i<0||i>nt))throw new Error(au);if(a!==I&&(a<0||a>nt))throw new Error(cu);if(c!==I&&(c<0||c>J))throw new Error(uu);if(u!==I&&u!==Go&&u!==ko)throw new Error(gu);let d=M(e,s,ao),E=M(e,s,co);const h=i!==I||a!==I||c!==I||u,B=d!==I||E!==I;if(h?(A=!1,r=r&J|768):B&&(A=!0,r=r&Xt),d!==I&&(d<0||d>Xt))throw new Error(lu);if(E&&typeof E!==ea)throw new Error(fu);if(r>J)throw new Error(PA);let p=M(e,s,io,0);!s[Fn]&&t.endsWith(Cn)&&(s[Fn]=!0);const C=M(e,s,Fn);C?(t.endsWith(Cn)||(t+=Cn),p===0&&(p=Qn,A||(p|=(tn|en|Dn)<<16))):!A&&p===0&&(o?p=(en|Dn)<<16:p=Dn<<16);let m;A||(m=p>>16&J,c=c===I?m:c&J,g?c|=Sn:g=!!(c&Sn),l?c|=vn:l=!!(c&vn),f?c|=bn:f=!!(c&bn),C&&(c|=tn),p=(c&J)<<16|p&Xt),{msdosAttributesRaw:d,msdosAttributes:E}=Cu(d,E),B&&(p=p&nt|d&Xt);const F=M(e,s,bc,mn);let v=F(t);if(v===I&&(v=mn(t)),O(v)>J)throw new Error(nu);const S=s[Js]||"";let x=F(S);if(x===I&&(x=mn(S)),O(x)>J)throw new Error(eu);const k=M(e,s,lo,ta);if(k>J)throw new Error(PA);const Q=M(e,s,Rn,new Date),y=M(e,s,zs),V=M(e,s,Ws),G=M(e,s,oo,0),R=M(e,s,So);let T,z;R||(T=M(e,s,yo),z=M(e,s,Qo));const W=M(e,s,Ic,3),Dt=M(e,s,Eo),gt=M(e,s,wc,!0),Ft=M(e,s,Fc,!0),Ct=M(e,s,bo),vt=M(e,s,yc),j=M(e,s,Qc,!1),rt=M(e,s,vo),mt=M(e,s,Sc,!0),U=M(e,s,Bo);let $=M(e,s,xc),H=M(e,s,Mo),w=M(e,s,vc);vt&&w===I&&(w=!1),(w===I||Dt)&&(w=!0),$!==I&&$!=6&&(H=!1),!H&&e.config.CompressionStream===I&&e.config.CompressionStreamZlib===I&&($=0);let It=M(e,s,qs);if(!Dt&&(T!==I||z!==I)&&!(W>=1&&W<=3))throw new Error(su);let Ot=new Uint8Array;const xt=s[Do];if(xt){let Oe=0,se=0;xt.forEach(kt=>Oe+=4+O(kt)),Ot=new Uint8Array(Oe),xt.forEach((kt,dn)=>{if(dn>J)throw new Error(Au);if(O(kt)>J)throw new Error(ru);q(Ot,new Uint16Array([dn]),se),q(Ot,new Uint16Array([O(kt)]),se+2),q(Ot,kt,se+4),se+=4+O(kt)})}let wt=0,lt=0,ft=0;if(R&&(ft=s[Vs],ft===I))throw new Error(ou);const Jt=It===!0;n&&(n=new Ks(n),await Ce(n),R?(s.uncompressedSize=ft,wt=_A(ft)):n.size===I?(w=!0,(It||It===I)&&(It=!0,ft=wt=nt+1)):(s.uncompressedSize=ft=n.size,wt=_A(ft)));const{diskOffset:Gt,diskNumber:bt,maxSize:Wt}=e.writer,Ie=Jt||ft>nt,qt=Jt||wt>nt,we=Jt||e.offset+e.pendingEntriesSize-Gt>nt,ne=M(e,s,Ro,!0)&&Jt||bt+Math.ceil(e.pendingEntriesSize/Wt)>J;if(we||Ie||qt||ne){if(It===!1||!Ft)throw new Error(js);It=!0}It=It||!1;const ze=M(e,s,go);s=Object.assign({},s,{rawFilename:v,rawComment:x,version:k,versionMadeBy:r,lastModDate:Q,lastAccessDate:y,creationDate:V,rawExtraField:Ot,zip64:It,zip64UncompressedSize:Ie,zip64CompressedSize:qt,zip64Offset:we,zip64DiskNumberStart:ne,password:T,rawPassword:z,level:$,useWebWorkers:Ct,encryptionStrength:W,extendedTimestamp:gt,zipCrypto:Dt,bufferedWrite:vt,keepOrder:Ft,useUnicodeFileNames:mt,dataDescriptor:w,dataDescriptorSignature:j,signal:rt,msDosCompatible:A,internalFileAttribute:G,internalFileAttributes:G,externalFileAttribute:p,externalFileAttributes:p,useCompressionStream:H,passThrough:R,encrypted:!!(T&&O(T)||z&&O(z))||R&&ze,signature:s[po],compressionMethod:U,uncompressedSize:ft,offset:e.offset-Gt,diskNumberStart:bt,uid:i,gid:a,setuid:g,setgid:l,sticky:f,unixMode:c,msdosAttributesRaw:d,msdosAttributes:E,unixExternalUpper:m});const ln=pu(s),fn=mu(s),ge=O(ln.localHeaderArray,fn.dataDescriptorArray);lt=ge+wt,e.options[Po]&&(lt+=lt+64),e.pendingEntriesSize+=lt;let Ye;try{Ye=await hu(e,t,n,{headerInfo:ln,dataDescriptorInfo:fn,metadataSize:ge},s)}finally{e.pendingEntriesSize-=lt}return Object.assign(Ye,{name:t,comment:S,extraField:xt}),new Pn(Ye)}async function hu(e,t,n,s,A){const{files:r,writer:o}=e,{keepOrder:i,dataDescriptor:a,signal:c}=A,{headerInfo:u}=s,g=e.options[Po],l=Array.from(r.values()).pop();let f={},d,E,h,B,p,C,m;r.set(t,f);try{let x;i&&(x=l&&l.lock,F()),(A.bufferedWrite||e.writerLocked||e.bufferedWrites&&i||!a)&&!g?(C=new TransformStream,C.size=0,d=!0,e.bufferedWrites++,await Ce(o)):(C=o,await v()),await Ce(C);const{writable:k,diskOffset:Q}=o;if(e.addSplitZipSignature){delete e.addSplitZipSignature;const T=new Uint8Array(4),z=ut(T);_(z,0,Gs),await ae(o,T),e.offset+=4}g&&Du(s,e.offset-Q);const{localHeaderView:y,localHeaderArray:V}=u;d||(await x,await S(k));const{diskNumber:G}=o;p=!0,f.diskNumberStart=G,d?m=new Response(C.readable).blob():await ae(C,V),f=await Bu(n,C,f,s,e.config,A);const{zip64:R}=f;if(p=!1,r.set(t,f),f.filename=t,d){const[T]=await Promise.all([m,C.writable.getWriter().close(),x]);await v(),B=!0,f.diskNumberStart=o.diskNumber,f.offset=e.offset-o.diskOffset,R&&kA(f),wu(f,y,A),await S(k),await ae(o,V),await T.stream().pipeTo(k,{preventClose:!0,preventAbort:!0,signal:c}),o.size+=C.size,B=!1}else f.offset=e.offset-Q,R&&kA(f);if(f.offset>nt&&!R)throw new Error(js);return e.offset+=f.size,f}catch(x){if(d&&B||!d&&p){if(e.hasCorruptedEntries=!0,x)try{x.corruptedEntry=!0}catch{}d?e.offset+=C.size:e.offset=C.size}throw r.delete(t),x}finally{d&&e.bufferedWrites--,h&&h(),E&&E()}function F(){f.lock=new Promise(x=>h=x)}async function v(){e.writerLocked=!0;const{lockWriter:x}=e;e.lockWriter=new Promise(k=>E=()=>{e.writerLocked=!1,k()}),await x}async function S(x){O(u.localHeaderArray)>o.availableSize&&(o.availableSize=0,await ae(x,new Uint8Array))}}async function Bu(e,t,{diskNumberStart:n,lock:s},A,r,o){const{headerInfo:i,dataDescriptorInfo:a,metadataSize:c}=A,{headerArray:u,headerView:g,lastModDate:l,rawLastModDate:f,encrypted:d,compressed:E,version:h,compressionMethod:B,rawExtraFieldZip64:p,localExtraFieldZip64Length:C,rawExtraFieldExtendedTimestamp:m,extraFieldExtendedTimestampFlag:F,rawExtraFieldNTFS:v,rawExtraFieldUnix:S,rawExtraFieldAES:x}=i,{dataDescriptorArray:k}=a,{rawFilename:Q,lastAccessDate:y,creationDate:V,password:G,rawPassword:R,level:T,zip64:z,zip64UncompressedSize:W,zip64CompressedSize:Dt,zip64Offset:gt,zip64DiskNumberStart:Ft,zipCrypto:Ct,dataDescriptor:vt,directory:j,executable:rt,versionMadeBy:mt,rawComment:U,rawExtraField:$,useWebWorkers:H,onstart:w,onprogress:It,onend:Ot,signal:xt,encryptionStrength:wt,extendedTimestamp:lt,msDosCompatible:ft,internalFileAttributes:Jt,externalFileAttributes:Gt,uid:bt,gid:Wt,unixMode:Ie,setuid:qt,setgid:we,sticky:Pe,unixExternalUpper:ne,msdosAttributesRaw:ze,msdosAttributes:ln,useCompressionStream:fn,passThrough:ge}=o,Ye={lock:s,versionMadeBy:mt,zip64:z,directory:!!j,executable:!!rt,filenameUTF8:!0,rawFilename:Q,commentUTF8:!0,rawComment:U,rawExtraFieldZip64:p,localExtraFieldZip64Length:C,rawExtraFieldExtendedTimestamp:m,rawExtraFieldNTFS:v,rawExtraFieldUnix:S,rawExtraFieldAES:x,rawExtraField:$,extendedTimestamp:lt,msDosCompatible:ft,internalFileAttributes:Jt,externalFileAttributes:Gt,diskNumberStart:n,uid:bt,gid:Wt,unixMode:Ie,setuid:qt,setgid:we,sticky:Pe,unixExternalUpper:ne,msdosAttributesRaw:ze,msdosAttributes:ln};let{signature:Oe,uncompressedSize:se}=o,kt=0;ge||(se=0);const{writable:dn}=t;if(e){e.chunkSize=Ir(r);const gi=e.readable,li=e.size,fi={options:{codecType:Ur,level:T,rawPassword:R,password:G,encryptionStrength:wt,zipCrypto:d&&Ct,passwordVerification:d&&Ct&&f>>8&Xt,signed:!ge,compressed:E&&!ge,encrypted:d&&!ge,useWebWorkers:H,useCompressionStream:fn,transferStreams:!1},config:r,streamOptions:{signal:xt,size:li,onstart:w,onprogress:It,onend:Ot}};try{const Fe=await zr({readable:gi,writable:dn},fi);kt=Fe.outputSize,t.size+=kt,ge||(se=Fe.inputSize,Oe=Fe.signature)}catch(Fe){throw Fe.outputSize!==I&&(t.size+=Fe.outputSize),Fe}}return Iu({signature:Oe,compressedSize:kt,uncompressedSize:se,headerInfo:i,dataDescriptorInfo:a},o),vt&&await ae(t,k),Object.assign(Ye,{uncompressedSize:se,compressedSize:kt,lastModDate:l,rawLastModDate:f,creationDate:V,lastAccessDate:y,encrypted:d,zipCrypto:Ct,size:c+kt,compressionMethod:B,version:h,headerArray:u,headerView:g,signature:Oe,extraFieldExtendedTimestampFlag:F,zip64UncompressedSize:W,zip64CompressedSize:Dt,zip64Offset:gt,zip64DiskNumberStart:Ft}),Ye}function pu(e){const{rawFilename:t,lastModDate:n,lastAccessDate:s,creationDate:A,level:r,zip64:o,zipCrypto:i,useUnicodeFileNames:a,dataDescriptor:c,directory:u,rawExtraField:g,encryptionStrength:l,extendedTimestamp:f,passThrough:d,encrypted:E,zip64UncompressedSize:h,zip64CompressedSize:B,zip64Offset:p,zip64DiskNumberStart:C,uncompressedSize:m,offset:F,diskNumberStart:v}=e;let{version:S,compressionMethod:x}=e;const k=!u&&(r>0||r===I&&x!==0);let Q;const y=d||!k,V=o&&(e.bufferedWrite||!h&&!B||y);if(o){let U=4;h&&(U+=8),B&&(U+=8),p&&(U+=8),C&&(U+=4),Q=new Uint8Array(U);const $=ut(Q);if(N($,0,lr),N($,2,O(Q)-4),V){const H=ut(Q);let w=4;h&&(ct(H,w,BigInt(m)),w+=8),B&&y&&(ct(H,w,BigInt(m)),w+=8),p&&(ct(H,w,BigInt(F)),w+=8),C&&(_(H,w,v),w+=4)}}else Q=new Uint8Array;let G;if(E&&!i){G=new Uint8Array(O(YA)+2);const U=ut(G);N(U,0,fr),q(G,YA,2),Ge(U,8,l)}else G=new Uint8Array;let R,T,z;if(f){T=new Uint8Array(9+(s?4:0)+(A?4:0));const U=ut(T);N(U,0,ks),N(U,2,O(T)-4),z=1+(s?2:0)+(A?4:0),Ge(U,4,z);let $=5;_(U,$,Math.floor(n.getTime()/1e3)),$+=4,s&&(_(U,$,Math.floor(s.getTime()/1e3)),$+=4),A&&_(U,$,Math.floor(A.getTime()/1e3));try{R=new Uint8Array(36);const H=ut(R),w=rs(n);N(H,0,dr),N(H,2,32),N(H,8,Er),N(H,10,24),ct(H,12,w),ct(H,20,rs(s)||w),ct(H,28,rs(A)||w)}catch{R=new Uint8Array}}else R=T=new Uint8Array;let W;try{const{uid:U,gid:$,unixMode:H,setuid:w,setgid:It,sticky:Ot,unixExtraFieldType:xt}=e;if(xt&&(U!==I||$!==I||H!==I)){const wt=GA(U),lt=GA($);let ft=new Uint8Array;if(xt==ko&&H!==I){let Wt=H&J;w&&(Wt|=Sn),It&&(Wt|=vn),Ot&&(Wt|=bn),ft=new Uint8Array(2),new DataView(ft.buffer).setUint16(0,Wt,!0)}const Jt=3+wt.length+lt.length+ft.length;W=new Uint8Array(4+Jt);const Gt=ut(W);N(Gt,0,xt==Go?Br:pr),N(Gt,2,Jt),Ge(Gt,4,1),Ge(Gt,5,wt.length);let bt=6;q(W,wt,bt),bt+=wt.length,Ge(Gt,bt,lt.length),bt++,q(W,lt,bt),bt+=lt.length,q(W,ft,bt)}else W=new Uint8Array}catch{W=new Uint8Array}x===I&&(x=k?Os:Ar),o&&(S=S>gA?S:gA),E&&!i&&(S=S>lA?S:lA,G[9]=x,x=rr);const Dt=V?O(Q):0,gt=Dt+O(G,T,R,W,g),{headerArray:Ft,headerView:Ct,rawLastModDate:vt}=_o({version:S,bitFlag:Lo(r,a,c,E,x),compressionMethod:x,uncompressedSize:m,lastModDate:n<dA?dA:n>fA?fA:n,rawFilename:t,zip64CompressedSize:B,zip64UncompressedSize:h,extraFieldLength:gt});let j=ve;const rt=new Uint8Array(j+O(t)+gt),mt=ut(rt);return _(mt,0,or),q(rt,Ft,4),q(rt,t,j),j+=O(t),V&&q(rt,Q,j),j+=Dt,q(rt,G,j),j+=O(G),q(rt,T,j),j+=O(T),q(rt,R,j),j+=O(R),q(rt,W,j),j+=O(W),q(rt,g,j),c&&(_(mt,He+4,0),_(mt,Ke+4,0)),{localHeaderArray:rt,localHeaderView:mt,headerArray:Ft,headerView:Ct,lastModDate:n,rawLastModDate:vt,encrypted:E,compressed:k,version:S,compressionMethod:x,extraFieldExtendedTimestampFlag:z,rawExtraFieldZip64:Q,localExtraFieldZip64Length:Dt,rawExtraFieldExtendedTimestamp:T,rawExtraFieldNTFS:R,rawExtraFieldUnix:W,rawExtraFieldAES:G,extraFieldLength:gt}}function Du(e,t){const{headerInfo:n}=e;let{localHeaderArray:s,extraFieldLength:A}=n,r=ut(s),o=64-(t+O(s))%64;o<4&&(o+=64);const i=new Uint8Array(o),a=ut(i);N(a,0,hr),N(a,2,o-2);const c=s;n.localHeaderArray=s=new Uint8Array(O(c)+o),q(s,c),q(s,i,O(c)),r=ut(s),N(r,28,A+o),e.metadataSize+=o}function GA(e){if(e===I)return new Uint8Array;{const t=new Uint8Array(4);ut(t).setUint32(0,e,!0);let s=4;for(;s>1&&t[s-1]===0;)s--;return t.subarray(0,s)}}function Cu(e,t){if(e!==I)e=e&Xt;else if(t!==I){const{readOnly:n,hidden:s,system:A,directory:r,archive:o}=t;let i=0;n&&(i|=ps),s&&(i|=Ds),A&&(i|=Cs),r&&(i|=Qn),o&&(i|=ms),e=i&Xt}return t===I&&(t={readOnly:!!(e&ps),hidden:!!(e&Ds),system:!!(e&Cs),directory:!!(e&Qn),archive:!!(e&ms)}),{msdosAttributesRaw:e,msdosAttributes:t}}function mu({zip64:e,dataDescriptor:t,dataDescriptorSignature:n}){let s=new Uint8Array,A,r=0,o=e?gr:ur;return n&&(o+=yn),t&&(s=new Uint8Array(o),A=ut(s),n&&(r=yn,_(A,0,ir))),{dataDescriptorArray:s,dataDescriptorView:A,dataDescriptorOffset:r}}function Iu({signature:e,compressedSize:t,uncompressedSize:n,headerInfo:s,dataDescriptorInfo:A},{zip64:r,zipCrypto:o,dataDescriptor:i}){const{headerView:a,encrypted:c}=s,{dataDescriptorView:u,dataDescriptorOffset:g}=A;(!c||o)&&e!==I&&(_(a,_s,e),i&&_(u,g,e)),r?i&&(ct(u,g+4,BigInt(t)),ct(u,g+12,BigInt(n))):(_(a,He,t),_(a,Ke,n),i&&(_(u,g+4,t),_(u,g+8,n)))}function wu({rawFilename:e,encrypted:t,zip64:n,localExtraFieldZip64Length:s,signature:A,compressedSize:r,uncompressedSize:o,offset:i,diskNumberStart:a,zip64UncompressedSize:c,zip64CompressedSize:u,zip64Offset:g,zip64DiskNumberStart:l},f,{dataDescriptor:d}){if(d||(t||_(f,_s+4,A),n||(_(f,He+4,r),_(f,Ke+4,o))),n&&s){let E=ve+O(e)+4;c&&(ct(f,E,BigInt(o)),E+=8),u&&(ct(f,E,BigInt(r)),E+=8),g&&(ct(f,E,BigInt(i)),E+=8),l&&_(f,E,a)}}function kA({compressedSize:e,uncompressedSize:t,offset:n,diskNumberStart:s,zip64UncompressedSize:A,zip64CompressedSize:r,zip64Offset:o,zip64DiskNumberStart:i,rawExtraFieldZip64:a}){const c=ut(a);let u=4;A&&(ct(c,u,BigInt(t)),u+=8),r&&(ct(c,u,BigInt(e)),u+=8),o&&(ct(c,u,BigInt(n)),u+=8),i&&_(c,u,s)}async function Fu(e,t,n){const{files:s,writer:A}=e,{diskOffset:r}=A;let{diskNumber:o}=A,i=0,a=0,c=e.offset-r,u=s.size;for(const[,m]of s){const{rawFilename:F,rawExtraFieldZip64:v,rawExtraFieldAES:S,rawComment:x,rawExtraFieldNTFS:k,rawExtraFieldUnix:Q,rawExtraField:y,extendedTimestamp:V,extraFieldExtendedTimestampFlag:G,lastModDate:R}=m;let T;if(V){T=new Uint8Array(9);const z=ut(T);N(z,0,ks),N(z,2,5),Ge(z,4,G),_(z,5,Math.floor(R.getTime()/1e3))}else T=new Uint8Array;m.rawExtraFieldExtendedTimestamp=T,a+=46+O(F,x,v,S,k,Q,T,y)}const g=new Uint8Array(a),l=ut(g);await Ce(A);let f=0;for(const[m,F]of Array.from(s.values()).entries()){const{offset:v,rawFilename:S,rawExtraFieldZip64:x,rawExtraFieldAES:k,rawExtraFieldExtendedTimestamp:Q,rawExtraFieldNTFS:y,rawExtraFieldUnix:V,rawExtraField:G,rawComment:R,versionMadeBy:T,headerArray:z,headerView:W,zip64:Dt,zip64UncompressedSize:gt,zip64CompressedSize:Ft,zip64DiskNumberStart:Ct,zip64Offset:vt,internalFileAttributes:j,externalFileAttributes:rt,diskNumberStart:mt,uncompressedSize:U,compressedSize:$}=F,H=O(x,k,Q,y,V,G);_(l,i,fs),N(l,i+4,T),gt||_(W,Ke,U),Ft||_(W,He,$),q(g,z,i+6);let w=i+ve;if(N(l,w,H),w+=2,N(l,w,O(R)),w+=2,N(l,w,Dt&&Ct?J:mt),w+=2,N(l,w,j),w+=2,rt&&_(l,w,rt),w+=4,_(l,w,Dt&&vt?nt:v),w+=4,q(g,S,w),w+=O(S),q(g,x,w),w+=O(x),q(g,k,w),w+=O(k),q(g,Q,w),w+=O(Q),q(g,y,w),w+=O(y),q(g,V,w),w+=O(V),q(g,G,w),w+=O(G),q(g,R,w),w+=O(R),i-f>A.availableSize&&(A.availableSize=0,await ae(A,g.slice(f,i)),f=i),i=w,n.onprogress)try{await n.onprogress(m+1,s.size,new Pn(F))}catch{}}await ae(A,f?g.slice(f):g);let d=A.diskNumber;const{availableSize:E}=A;E<re&&d++;let h=M(e,n,qs);if(c>nt||a>nt||u>J||d>J){if(h===!1)throw new Error(js);h=!0}const B=new Uint8Array(h?zi:re),p=ut(B);i=0,h&&(_(p,0,ds),ct(p,4,BigInt(44)),N(p,12,45),N(p,14,45),_(p,16,d),_(p,20,o),ct(p,24,BigInt(u)),ct(p,32,BigInt(u)),ct(p,40,BigInt(a)),ct(p,48,BigInt(c)),_(p,56,cr),ct(p,64,BigInt(c)+BigInt(a)),_(p,72,d+1),M(e,n,Ro,!0)&&(d=J,o=J),u=J,c=nt,a=nt,i+=Ze+Xe),_(p,i,ar),N(p,i+4,d),N(p,i+6,o),N(p,i+8,u),N(p,i+10,u),_(p,i+12,a),_(p,i+16,c);const C=O(t);if(C)if(C<=J)N(p,i+20,C);else throw new Error(tu);await ae(A,B),C&&await ae(A,t)}async function ae(e,t){const{writable:n}=e,s=n.getWriter();try{await s.ready,e.size+=O(t),await s.write(t)}finally{s.releaseLock()}}function rs(e){if(e)return(BigInt(e.getTime())+BigInt(116444736e5))*BigInt(1e4)}function M(e,t,n,s){const A=t[n]===I?e.options[n]:t[n];return A===I?s:A}function _A(e){return e+5*(Math.floor(e/16383)+1)}function Ge(e,t,n){e.setUint8(t,n)}function N(e,t,n){e.setUint16(t,n,!0)}function _(e,t,n){e.setUint32(t,n,!0)}function ct(e,t,n){e.setBigUint64(t,n,!0)}function q(e,t,n){e.set(t,n)}function ut(e){return new DataView(e.buffer)}function O(...e){let t=0;return e.forEach(n=>n&&(t+=n.length)),t}function _o({version:e,bitFlag:t,compressionMethod:n,uncompressedSize:s,compressedSize:A,lastModDate:r,rawFilename:o,zip64CompressedSize:i,zip64UncompressedSize:a,extraFieldLength:c}){const u=new Uint8Array(ve-4),g=ut(u);N(g,0,e),N(g,2,t),N(g,4,n);const l=new Uint32Array(1),f=ut(l);N(f,0,(r.getHours()<<6|r.getMinutes())<<5|r.getSeconds()/2),N(f,2,(r.getFullYear()-1980<<4|r.getMonth()+1)<<5|r.getDate());const d=l[0];return _(g,6,d),(i||A!==I)&&_(g,He,i?nt:A),(a||s!==I)&&_(g,Ke,a?nt:s),N(g,22,O(o)),N(g,24,c),{headerArray:u,headerView:g,rawLastModDate:d}}function Lo(e,t,n,s,A){let r=0;return t&&(r=r|Bs),n&&(r=r|hs),(A==Os||A==ls)&&(e>=0&&e<=3&&(r=r|Zi),e>3&&e<=5&&(r=r|Xi),e==9&&(r=r|$i)),s&&(r=r|Es),r}try{Ln({baseURI:import.meta.url})}catch{}const Rt="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";function xu(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 c=0;i>c;c+=4){const u=Rt.indexOf(o[c])<<18|Rt.indexOf(o[c+1])<<12|(63&Rt.indexOf(o[c+2]))<<6|63&Rt.indexOf(o[c+3]);a.push(u>>16&255),o[c+2]!=="="&&a.push(u>>8&255),o[c+3]!=="="&&a.push(255&u)}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),c=n[o++]<<8|n[o++],u=A-c;r(A+a);for(let g=0;a>g;g++)s[A++]=s[u+g]}else{const a=i;r(A+a);for(let c=0;a>c&&o<n.length;c++)s[A++]=n[o++]}}return(o=>{let i="";const a=o.length;let c=0;for(;a>c+2;c+=3){const g=o[c]<<16|o[c+1]<<8|o[c+2];i+=Rt[g>>18&63]+Rt[g>>12&63]+Rt[g>>6&63]+Rt[63&g]}const u=a-c;if(u===1){const g=o[c]<<16;i+=Rt[g>>18&63]+Rt[g>>12&63]+"=="}else if(u===2){const g=o[c]<<16|o[c+1]<<8;i+=Rt[g>>18&63]+Rt[g>>12&63]+Rt[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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BAGZgAAEAVmAAAQB2YAABAE5gAAEAbmAAAQBeYAABAH5gAAEAQWAAAQBhYAABAFFgAAEAcWAAAQBJYAABAGlgAAEAWWAAAQB5YAABAEVgAAEAZWAAAQBVYAABAHVgAAEATWAAAQBtYAABAF1gAAEAfWAAAQBDYAABAGNgAAEAU2AAAQBzYAABIARMwIArYAABAFtgAAEAe2AAAQBHYAABAGdgAAEAV2AAAQB3YAABAE9gAAEAb2AAAQBfYAABAH9gAAEAROAAMIFEwEJAJOAAAgBk4AACAFTgAAIAVOAAAgB04AACAHTgAAIATOAAAgBM4AACAGzgAAIAbOAAAgBc4AACAFzgAAIAfOAAAgB84AACAELgAAIgBDagAQCgAAEgAAIAUuAAAgBS4AACAHLgAAIAcuAAAgBK4AACAErgAAIAauAAAgBq4AACAFrgAAIAWuAAAgB64AACAHrgAAIARuAAAgBG4AACAGbgAAIAZuAAAgBW4AACAFbgAAIAduAAAgB24AACAE7gAAIATuAAAgBu4AACAG7gAAIAXuAAAgBe4AACAH7gAAIAfuAAAiBA7YBB4AACAGHgAAIAYeAAAgBR4AACAFHgAAIAceAAAgBx4AACAEngAAIASeAAAgBp4AACAGngAAIAWeAAAgBZ4AACAHngAAIAeeAAAgBF4AACAEXgAAIAZeAAAgBl4AACAFXgAAIAVeAAAgB14AACAHXgAAIATeAAAgBN4AACAG3gAAIAbeAAAgBd4AACAF3gAAIAfeAAAgB94AACAEPgAAIAQ+AAAgBj4AACAGPgAAIAU+AAAgBT4AACAHPgAAIAc+AAAgBL4AACAEvgAAIAa+AAAgBr4AACAFvgAAIAW+AAAgB74AACAHvgAAIAR+AAAgBH4AACAGfgAAIAZ+AAAgBX4AACAFfgAAIAd+AAAgB34AACAE/gAAIAT+AAAgBv4AACAG/gAAIAX+AAAgBf4AACAH/gAAIAf+AAAiBBAoBQIAABAEggAAEAWCAAAQBEIAABAFQgAAEATCAAAQBcIIFVgMHAEiAAAQBKIAABAFogAAEARiAAAQBWIAABAE4gAAEAXiAAAQBBIAABAFEgAAEASSAAAQBZIAABAEUgAAEAVSAAAQBNIAABAF0gAAEAQOAAEIBg4AABAFDgAAEAcOAAAQBI4AABAGjgAAEAWOAAAQB44AABIC+K4AAdIECxgEFgABcAQWCBUoBFIAABAEMgAAEARyAAASAvlaABEQBBYIGBAEaggXqAQWAA9QBBYADuAEFgAOcgE92gAAEARGAAAQBCYAABAEZgAAEgQACARWAAAQBDYAABAEdgAAEgL59gAKkgQZAAQWAAiyBBaYBBYABtAEFgD3fAxsLTYMfuYcABIC+rooABIEHUYkABAEEjAAEAQWKAAQEQbAcC4C9CosAS40AO4UALwEGhAAEgQWIgQAEgQEKgQAEgQGSgQAEgIS2ggAEAQuEAAQBDIQABIAF24FHeQTgHQsjhQBfhQXLAhARgAVtBgcJBgoFC4A6uAQNAg4BgAclBJQeC2mFAJCFAIiFAICFAHiBAGiBAFyBBh8BEIAABAEUgAAEARiAAAQBHIAABAEggAAEASiAAAQBMIAABAE4gAAEAUCAAAQBUIAABIEGvQFwgAAEAYCAAAQBoIAABAHAgAAEAeCAAG8DHwtyjQBvgQBrgQBngQBjgQBfgQBbgQBXgQBTgQBPgQBLgQBHgQBDgQE8AYCvAEGAUc0CC22BAMcBBIAAAgEIgAAEgQEzgQJLARCAAA6DAAyBnqyAqmuEACSBB3OBAE8BCIAACIEAGIUADIEIt4MADAEggQCUgDKEgQBrAYCBCC8BBIMADIA/SAoBABAMAEGRIQv/gCUfgMDAgIKxBQgJCQoKgEk3gAABAQ2AAAEBDoAAAQEPgAABARCEAAEBEYQAAQEShAABAROEAAEBFIwAAQEVjAABARaMAAEBF4wAAQEYnAABARmcAAEBGpwAAQEbmwABARyBffsEBAQFBYHB1QEHgAABAQiEAAGAXSqCAAEBCowAAYAnsooAAYEBMJkAAYEBTJkAAYEBaLkAAYEBpLkAAYIDdYABzoUBvI0BqJ0BkLwBgAIbHLwAAQEdvAABgA9PgH05A9AqAQ==")),t)})}let ot,Ue,Yt,sn;function yu(e){if(ot=e,{malloc:Ue,free:Yt,memory:sn}=ot,typeof Ue!="function"||typeof Yt!="function"||!sn)throw ot=Ue=Yt=sn=null,new Error("Invalid WASM module")}function No(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=Ue(A),this.in=Ue(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,c=new Uint8Array(sn.buffer),u=this._process,g=this._last_consumed,l=this.out,f=this._scratch;let d=0;for(;d<a.length;){const E=Math.min(a.length-d,32768);(!this.in||this.inBufferSize<E)&&(this.in&&Yt&&Yt(this.in),this.in=Ue(E),this.inBufferSize=E),c.set(a.subarray(d,d+E),this.in);const h=u(this.streamHandle,this.in,E,l,A,0),B=h&16777215;if(B&&(f.set(c.subarray(l,l+B),0),i.enqueue(f.slice(0,B))),!e){const C=h>>24&255,m=C&128?C-256:C;if(m<0)throw new Error("process error:"+m)}const p=g(this.streamHandle);if(p===0)break;d+=p}}catch(a){this._end&&this.streamHandle&&this._end(this.streamHandle),this.in&&Yt&&Yt(this.in),this.out&&Yt&&Yt(this.out),i.error(a)}},flush(o){try{const i=new Uint8Array(sn.buffer),a=this._process,c=this.out,u=this._scratch;for(;;){const g=a(this.streamHandle,0,0,c,A,4),l=g&16777215,f=g>>24&255;if(!e){const d=f&128?f-256:f;if(d<0)throw new Error("process error:"+d)}if(l&&(u.set(i.subarray(c,c+l),0),o.enqueue(u.slice(0,l))),f===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&&Yt&&Yt(this.in),this.out&&Yt&&Yt(this.out)}}})}class Qu{constructor(t="deflate",n){return No(!0,t,n)}}class Su{constructor(t="deflate",n){return No(!1,t,n)}}let LA=!1;async function vu(e,{baseURI:t}){if(!LA){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=bu(e);else throw r}const A=await WebAssembly.instantiate(n);yu(A.instance.exports),LA=!0}}function bu(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 os;xu(Ln);Ya({initModule:e=>{if(!os){let{wasmURI:t}=e;typeof t==Te&&(t=t()),os=vu(t,e)}return os}});Ln({CompressionStreamZlib:Qu,DecompressionStreamZlib:Su});const is={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(is))for(const n of Object.keys(is[t])){const s=is[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})();Aa(Ln);var Mu=/[\u1680\u2000-\u200A\u202F\u205F\u3000]/,Tu=/[\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]/,Ru=/[\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]/,as={Space_Separator:Mu,ID_Start:Tu,ID_Continue:Ru},at={isSpaceSeparator(e){return typeof e=="string"&&as.Space_Separator.test(e)},isIdStartChar(e){return typeof e=="string"&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||e==="$"||e==="_"||as.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==="‍"||as.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 Fs,St,oe,Yn,me,zt,dt,$s,An;var Pu=function(t,n){Fs=String(t),St="start",oe=[],Yn=0,me=1,zt=0,dt=void 0,$s=void 0,An=void 0;do dt=Yu(),ku[St]();while(dt.type!=="eof");return typeof n=="function"?xs({"":An},"",n):An};function xs(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=xs(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=xs(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 P,b,$e,Ae,L;function Yu(){for(P="default",b="",$e=!1,Ae=1;;){L=ce();const e=Uo[P]();if(e)return e}}function ce(){if(Fs[Yn])return String.fromCodePoint(Fs.codePointAt(Yn))}function D(){const e=ce();return e===`
3
+ `?(me++,zt=0):e?zt+=e.length:zt++,e&&(Yn+=e.length),e}const Uo={default(){switch(L){case" ":case"\v":case"\f":case" ":case" ":case"\uFEFF":case`
4
+ `:case"\r":case"\u2028":case"\u2029":D();return;case"/":D(),P="comment";return;case void 0:return D(),X("eof")}if(at.isSpaceSeparator(L)){D();return}return Uo[St]()},comment(){switch(L){case"*":D(),P="multiLineComment";return;case"/":D(),P="singleLineComment";return}throw Z(D())},multiLineComment(){switch(L){case"*":D(),P="multiLineCommentAsterisk";return;case void 0:throw Z(D())}D()},multiLineCommentAsterisk(){switch(L){case"*":D();return;case"/":D(),P="default";return;case void 0:throw Z(D())}D(),P="multiLineComment"},singleLineComment(){switch(L){case`
5
+ `:case"\r":case"\u2028":case"\u2029":D(),P="default";return;case void 0:return D(),X("eof")}D()},value(){switch(L){case"{":case"[":return X("punctuator",D());case"n":return D(),xe("ull"),X("null",null);case"t":return D(),xe("rue"),X("boolean",!0);case"f":return D(),xe("alse"),X("boolean",!1);case"-":case"+":D()==="-"&&(Ae=-1),P="sign";return;case".":b=D(),P="decimalPointLeading";return;case"0":b=D(),P="zero";return;case"1":case"2":case"3":case"4":case"5":case"6":case"7":case"8":case"9":b=D(),P="decimalInteger";return;case"I":return D(),xe("nfinity"),X("numeric",1/0);case"N":return D(),xe("aN"),X("numeric",NaN);case'"':case"'":$e=D()==='"',b="",P="string";return}throw Z(D())},identifierNameStartEscape(){if(L!=="u")throw Z(D());D();const e=ys();switch(e){case"$":case"_":break;default:if(!at.isIdStartChar(e))throw NA();break}b+=e,P="identifierName"},identifierName(){switch(L){case"$":case"_":case"‌":case"‍":b+=D();return;case"\\":D(),P="identifierNameEscape";return}if(at.isIdContinueChar(L)){b+=D();return}return X("identifier",b)},identifierNameEscape(){if(L!=="u")throw Z(D());D();const e=ys();switch(e){case"$":case"_":case"‌":case"‍":break;default:if(!at.isIdContinueChar(e))throw NA();break}b+=e,P="identifierName"},sign(){switch(L){case".":b=D(),P="decimalPointLeading";return;case"0":b=D(),P="zero";return;case"1":case"2":case"3":case"4":case"5":case"6":case"7":case"8":case"9":b=D(),P="decimalInteger";return;case"I":return D(),xe("nfinity"),X("numeric",Ae*(1/0));case"N":return D(),xe("aN"),X("numeric",NaN)}throw Z(D())},zero(){switch(L){case".":b+=D(),P="decimalPoint";return;case"e":case"E":b+=D(),P="decimalExponent";return;case"x":case"X":b+=D(),P="hexadecimal";return}return X("numeric",Ae*0)},decimalInteger(){switch(L){case".":b+=D(),P="decimalPoint";return;case"e":case"E":b+=D(),P="decimalExponent";return}if(at.isDigit(L)){b+=D();return}return X("numeric",Ae*Number(b))},decimalPointLeading(){if(at.isDigit(L)){b+=D(),P="decimalFraction";return}throw Z(D())},decimalPoint(){switch(L){case"e":case"E":b+=D(),P="decimalExponent";return}if(at.isDigit(L)){b+=D(),P="decimalFraction";return}return X("numeric",Ae*Number(b))},decimalFraction(){switch(L){case"e":case"E":b+=D(),P="decimalExponent";return}if(at.isDigit(L)){b+=D();return}return X("numeric",Ae*Number(b))},decimalExponent(){switch(L){case"+":case"-":b+=D(),P="decimalExponentSign";return}if(at.isDigit(L)){b+=D(),P="decimalExponentInteger";return}throw Z(D())},decimalExponentSign(){if(at.isDigit(L)){b+=D(),P="decimalExponentInteger";return}throw Z(D())},decimalExponentInteger(){if(at.isDigit(L)){b+=D();return}return X("numeric",Ae*Number(b))},hexadecimal(){if(at.isHexDigit(L)){b+=D(),P="hexadecimalInteger";return}throw Z(D())},hexadecimalInteger(){if(at.isHexDigit(L)){b+=D();return}return X("numeric",Ae*Number(b))},string(){switch(L){case"\\":D(),b+=Ou();return;case'"':if($e)return D(),X("string",b);b+=D();return;case"'":if(!$e)return D(),X("string",b);b+=D();return;case`
6
+ `:case"\r":throw Z(D());case"\u2028":case"\u2029":_u(L);break;case void 0:throw Z(D())}b+=D()},start(){switch(L){case"{":case"[":return X("punctuator",D())}P="value"},beforePropertyName(){switch(L){case"$":case"_":b=D(),P="identifierName";return;case"\\":D(),P="identifierNameStartEscape";return;case"}":return X("punctuator",D());case'"':case"'":$e=D()==='"',P="string";return}if(at.isIdStartChar(L)){b+=D(),P="identifierName";return}throw Z(D())},afterPropertyName(){if(L===":")return X("punctuator",D());throw Z(D())},beforePropertyValue(){P="value"},afterPropertyValue(){switch(L){case",":case"}":return X("punctuator",D())}throw Z(D())},beforeArrayValue(){if(L==="]")return X("punctuator",D());P="value"},afterArrayValue(){switch(L){case",":case"]":return X("punctuator",D())}throw Z(D())},end(){throw Z(D())}};function X(e,t){return{type:e,value:t,line:me,column:zt}}function xe(e){for(const t of e){if(ce()!==t)throw Z(D());D()}}function Ou(){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(),Gu();case"u":return D(),ys();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 Gu(){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 ys(){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 ku={start(){if(dt.type==="eof")throw ye();cs()},beforePropertyName(){switch(dt.type){case"identifier":case"string":$s=dt.value,St="afterPropertyName";return;case"punctuator":hn();return;case"eof":throw ye()}},afterPropertyName(){if(dt.type==="eof")throw ye();St="beforePropertyValue"},beforePropertyValue(){if(dt.type==="eof")throw ye();cs()},beforeArrayValue(){if(dt.type==="eof")throw ye();if(dt.type==="punctuator"&&dt.value==="]"){hn();return}cs()},afterPropertyValue(){if(dt.type==="eof")throw ye();switch(dt.value){case",":St="beforePropertyName";return;case"}":hn()}},afterArrayValue(){if(dt.type==="eof")throw ye();switch(dt.value){case",":St="beforeArrayValue";return;case"]":hn()}},end(){}};function cs(){let e;switch(dt.type){case"punctuator":switch(dt.value){case"{":e={};break;case"[":e=[];break}break;case"null":case"boolean":case"numeric":case"string":e=dt.value;break}if(An===void 0)An=e;else{const t=oe[oe.length-1];Array.isArray(t)?t.push(e):Object.defineProperty(t,$s,{value:e,writable:!0,enumerable:!0,configurable:!0})}if(e!==null&&typeof e=="object")oe.push(e),Array.isArray(e)?St="beforeArrayValue":St="beforePropertyName";else{const t=oe[oe.length-1];t==null?St="end":Array.isArray(t)?St="afterArrayValue":St="afterPropertyValue"}}function hn(){oe.pop();const e=oe[oe.length-1];e==null?St="end":Array.isArray(e)?St="afterArrayValue":St="afterPropertyValue"}function Z(e){return On(e===void 0?`JSON5: invalid end of input at ${me}:${zt}`:`JSON5: invalid character '${Ho(e)}' at ${me}:${zt}`)}function ye(){return On(`JSON5: invalid end of input at ${me}:${zt}`)}function NA(){return zt-=5,On(`JSON5: invalid identifier character at ${me}:${zt}`)}function _u(e){console.warn(`JSON5: '${Ho(e)}' in strings is not valid ECMAScript; consider escaping`)}function Ho(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 On(e){const t=new SyntaxError(e);return t.lineNumber=me,t.columnNumber=zt,t}var Lu=function(t,n,s){const A=[];let r="",o,i,a="",c;if(n!=null&&typeof n=="object"&&!Array.isArray(n)&&(s=n.space,c=n.quote,n=n.replacer),typeof n=="function")i=n;else if(Array.isArray(n)){o=[];for(const E of n){let h;typeof E=="string"?h=E:(typeof E=="number"||E instanceof String||E instanceof Number)&&(h=String(E)),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)),u("",{"":t});function u(E,h){let B=h[E];switch(B!=null&&(typeof B.toJSON5=="function"?B=B.toJSON5(E):typeof B.toJSON=="function"&&(B=B.toJSON(E))),i&&(B=i.call(h,E,B)),B instanceof Number?B=Number(B):B instanceof String?B=String(B):B instanceof Boolean&&(B=B.valueOf()),B){case null:return"null";case!0:return"true";case!1:return"false"}if(typeof B=="string")return g(B);if(typeof B=="number")return String(B);if(typeof B=="object")return Array.isArray(B)?d(B):l(B)}function g(E){const h={"'":.1,'"':.2},B={"'":"\\'",'"':'\\"',"\\":"\\\\","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r"," ":"\\t","\v":"\\v","\0":"\\0","\u2028":"\\u2028","\u2029":"\\u2029"};let p="";for(let m=0;m<E.length;m++){const F=E[m];switch(F){case"'":case'"':h[F]++,p+=F;continue;case"\0":if(at.isDigit(E[m+1])){p+="\\x00";continue}}if(B[F]){p+=B[F];continue}if(F<" "){let v=F.charCodeAt(0).toString(16);p+="\\x"+("00"+v).substring(v.length);continue}p+=F}const C=c||Object.keys(h).reduce((m,F)=>h[m]<h[F]?m:F);return p=p.replace(new RegExp(C,"g"),B[C]),C+p+C}function l(E){if(A.indexOf(E)>=0)throw TypeError("Converting circular structure to JSON5");A.push(E);let h=r;r=r+a;let B=o||Object.keys(E),p=[];for(const m of B){const F=u(m,E);if(F!==void 0){let v=f(m)+":";a!==""&&(v+=" "),v+=F,p.push(v)}}let C;if(p.length===0)C="{}";else{let m;if(a==="")m=p.join(","),C="{"+m+"}";else{let F=`,
10
+ `+r;m=p.join(F),C=`{
11
+ `+r+m+`,
12
+ `+h+"}"}}return A.pop(),r=h,C}function f(E){if(E.length===0)return g(E);const h=String.fromCodePoint(E.codePointAt(0));if(!at.isIdStartChar(h))return g(E);for(let B=h.length;B<E.length;B++)if(!at.isIdContinueChar(String.fromCodePoint(E.codePointAt(B))))return g(E);return E}function d(E){if(A.indexOf(E)>=0)throw TypeError("Converting circular structure to JSON5");A.push(E);let h=r;r=r+a;let B=[];for(let C=0;C<E.length;C++){const m=u(String(C),E);B.push(m!==void 0?m:"null")}let p;if(B.length===0)p="[]";else if(a==="")p="["+B.join(",")+"]";else{let C=`,
13
+ `+r,m=B.join(C);p=`[
14
+ `+r+m+`,
15
+ `+h+"]"}return A.pop(),r=h,p}};const Nu={parse:Pu,stringify:Lu};var Uu=Nu,Xs=10**-4;function Cl(e){return e*Math.PI/180}function Tt(e){return 180*e/Math.PI}function K(e){let t=e;return Math.abs(t)<Xs&&(t=0),t}function ue(e){let t=e%(2*Math.PI);return t<0&&(t+=2*Math.PI),t}function At(e){let t=ue(e);return t>Math.PI&&(t-=2*Math.PI),t}function $t(e){let t=e%Math.PI;return t<0&&(t+=Math.PI),t}function Pt(e){let t=$t(e);return t>Math.PI/2&&(t-=Math.PI),t}function Qs(e,t,n){const s=At(t)-At(e);return n?ue(s):ue(s)-2*Math.PI}function Ko(e,t,n,s){let A=!1;if(K(At(e-t))===0)A=!0;else if(K(At(e-n))===0)A=!0;else{const r=Qs(t,n,s),o=Qs(t,e,s);Math.abs(o)<Math.abs(r)&&(A=!0)}return A}function Zt(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 be(e,t,n){const s=n.shiftX+(e-n.xMin)*n.scaleX,A=n.shiftY+(t-n.yMin)*n.scaleY;return[s,A]}function ml(e,t,n){const s=(e-n.shiftX)/n.scaleX+n.xMin,A=(t-n.shiftY)/n.scaleY+n.yMin;return[s,A]}function Jo(e,t){if(K(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 Un(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 vs(e,t,n,s,A,r){const o=Ss(),i=Math.max(t-e,1),a=Math.max(s-n,1),c=A/i,u=r/a;let g=.9*c,l=i;return u<c&&(g=.9*u,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 Il(e,t,n){const s=Un(n);return s.xMin=e-s.xyDiff/2,s.yMin=t-s.xyDiff/2,s}function wl(e,t,n,s,A,r){const o=Math.min(e,n),i=Math.max(e,n),a=Math.min(t,s),c=Math.max(t,s);return vs(o,i,a,c,A,r)}function Fl(e,t){const n=Un(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 xl(e,t,n,s,A){const r=Un(A),o=n-e,i=s-t;return r.xMin+=-o,r.yMin+=-i,r}function yl(e,t,n){const s=Un(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 Hn(e,t){let n=0;if(t>e)throw`err539: ila < ilc ${e} ${t}`;return n=Math.sqrt(e**2-t**2),n}function Ql(e,t,n){return Math.sqrt(e**2+t**2-2*e*t*Math.cos(n))}function UA(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 HA(e,t,n){let s=0;const A=[e,t,n];for(let a=0;a<A.length;a++)if(K(A[a])===0||A[a]<0)throw`err329: negative or zero triangle-args ${a} : ${A[a]}`;const r=$t(t),o=$t(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}function Sl(e,t,n){let s=0;const A=[e,t,n];for(let r=0;r<A.length;r++)if(A[r]<=0)throw`err429: negative or zero triangle-args ${r} : ${A[r]}`;return s=Math.asin(t*Math.sin(n)/e),s}var Hu=(e=>(e[e.eDefault=0]="eDefault",e[e.eCircle=1]="eCircle",e[e.eCross=2]="eCross",e[e.eSquare=3]="eSquare",e[e.eBigSquare=4]="eBigSquare",e[e.eTwoTri=5]="eTwoTri",e[e.eTri1=6]="eTri1",e[e.eTri2=7]="eTri2",e[e.eTri3=8]="eTri3",e[e.eTri4=9]="eTri4",e))(Hu||{}),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]=be(this.cx,this.cy,n);let c=A;switch(c===0&&(c=this.shape),t.beginPath(),c){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;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 K(this.cx-t.cx)===0&&K(this.cy-t.cy)===0}distanceToPoint(t){return Math.sqrt((t.cx-this.cx)**2+(t.cy-this.cy)**2)}angleToPoint(t){if(K(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),c=r.translatePolar(o+Math.PI,i),u=s.distanceToPoint(a),g=s.distanceToPoint(c);if(i!==0&&u===g)throw`err284: magnet point p3 is on line p1p2. cx ${s.cx} cy: ${s.cy}`;let l=a;return g<u&&(l=c),l}};function Y(e,t,n=0){return new Nt(e,t,n)}function Vo(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 Ku=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]=be(this.cx-A*Math.cos(this.ca),this.cy-A*Math.sin(this.ca),n),[i,a]=be(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),Y(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(K(Pt(this.ca))!==0){const n=new Nt(this.cx,this.cy),s=$t(this.ca),A=n.angleOrig(),r=n.distanceOrig();if(K(r)===0)t=0;else if(K(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)*HA(r,o,a)}}return t}getAxisYIntersecTri(){let t=1/0;if(K(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(K(r)===0)t=0;else if(K(o)===0)t=0;else{const i=$t(s-Math.PI/2),a=-1*At(s-A),c=Math.min(i,Math.PI-i),u=Math.min(Math.abs(a),Math.PI-Math.abs(a));t=Math.sign(a)*HA(r,c,u)}}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),$t(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 Y(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(K(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(K(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 K(Pt(this.ca-t.ca))===0}isOrthogonal(t){return K(Pt(Math.PI/2+this.ca-t.ca))===0}isEqual(t){const n=Y(t.cx,t.cy),s=this.distanceToPoint(n);return K(s)===0&&this.isParallel(t)}bisector(t,n){const s=this.intersection(t),A=$t(this.ca),r=$t(t.ca),o=Math.min(A,r),i=Math.max(A,r),a=[o,i,o+Math.PI,i+Math.PI,o],c=s.angleToPoint(n);let u=0;for(let f=0;f<4;f++){const d=At(a[f]-c),E=At(a[f+1]-c);if(d===0||E===0)throw`err419: bad reference point for bisecor ${n.cx} ${n.cy}`;d<0&&E>0&&(u=f)}const l=$t((o+i)/2)+u*Math.PI/2;return new Mt(s.cx,s.cy,l)}lineParallelDistance(t,n,s){const A=Y(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 K(this.distanceToPoint(a))===0&&(a=s),a.distanceToPoint(r)<a.distanceToPoint(o)&&(i=r),new Mt(i.cx,i.cy,this.ca)}};function Kn(e,t,n){return new Ku(e,t,n)}function un(e,t){return Kn(0,0,0).setFromPoints(e,t)}function bs(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=$t(e.angleToPoint(t)+Math.PI/2);return Kn(n.cx,n.cy,s)}function Ju(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=bs(e,t),A=bs(t,n);return s.intersection(A)}function Vt(e){let t=!1;return(e===0||e===1)&&(t=!0),t}function qe(e){let t=!1;return(Vt(e)||e===6)&&(t=!0),t}function xn(e){let t=!1;return(e===3||e===4||e===5)&&(t=!0),t}function Bn(e){let t=!1;return(e===2||xn(e))&&(t=!0),t}var Ut=class zo{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 zo(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}},Vu=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=""}},he=new Vu;function Be(e,t,n){if(n.sType!==1)throw`err202: arcSeg1To2 has unexpected type ${n.sType}`;const s=Y(e,t),A=Y(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(K(n.radius-r)===0)o=0;else{if(n.radius<r)throw`err399: radius ${n.radius} smaller than lp1p2h ${r}`;o=Hn(n.radius,r)}const i=s.middlePoint(A),a=s.angleToPoint(A)+Math.PI/2,c=i.translatePolar(a,o),u=i.translatePolar(a+Math.PI,o);let g=c;(!n.arcLarge&&!n.arcCcw||n.arcLarge&&n.arcCcw)&&(g=u);const l=g.angleToPoint(s),f=g.angleToPoint(A);return new Kt(1,s,A,g,n.radius,l,f,n.arcCcw)}function zu(e){let t=ue(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 Wu(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 E=e.arcCcw?1:-1;i=e.a2-E*Math.PI/2}let a=A.angleToPoint(o);if(n.sType===1){const E=n.arcCcw?1:-1;a=n.a1+E*Math.PI/2}const c=a-i;let g=At(c)/2;if(K(g)===0){const E=Xs*.01;if(e.sType===0&&n.sType===1)g=n.arcCcw?E:-E;else if(e.sType===1&&n.sType===0)g=e.arcCcw?E:-E;else if(e.sType===0&&n.sType===0)throw`err402: prepare aPeakHalf too closed to zero ${g}`}const l=i+g,f=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:f,at1:i,at3:a,abi:l,aph:g}}function Gn(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=K(e)===0?1:s*A,o=t.radius+r*n;if(o<=0)throw`err621: modifRadius with negative modified lenght ${o}`;return o}function Zs(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 KA(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 Jn(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=un(s,A).distanceToPoint(n);if(K(r)!==0)throw`err104: newStrokeFirst new point not aligned ${r} ${n.cx} ${n.cy}`;const o=s.angleToPoint(A),i=s.angleToPoint(n);if(K(At(i-o))!==0)throw`err105: newStrokeFirst new point miss aligned ${o} ${i} ${n.cx} ${n.cy}`;const a=s.distanceToPoint(n),c=s.distanceToPoint(A);if(c<a)throw`err106: newStrokeFirst new point out of scope ${c} ${a} ${n.cx} ${n.cy}`;const u=Y(0,0);return new Kt(0,s,n,u,0,0,0,!1)}function Vn(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=un(s,A).distanceToPoint(n);if(K(r)!==0)throw`err204: newStrokeSecond new point not aligned ${r} ${n.cx} ${n.cy}`;const o=s.angleToPoint(A),i=s.angleToPoint(n);if(K(At(i-o))!==0)throw`err205: newStrokeSecond new point miss aligned ${o} ${i} ${n.cx} ${n.cy}`;const a=s.distanceToPoint(n),c=s.distanceToPoint(A);if(c<a)throw`err206: newStrokeSecond new point out of scope ${c} ${a} ${n.cx} ${n.cy}`;const u=Y(0,0);return new Kt(0,n,s,u,0,0,0,!1)}function zn(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(!Ko(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 Wn(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(!Ko(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 gn(e,t,n,s,A,r){const o=e.clone(),i=t.clone(),a=n.clone(),c=a.distanceToPoint(o),u=a.distanceToPoint(i);if(K(c-s)!==0||K(u-s)!==0)throw`err610: newRounded not on circle ${s} ${c} ${u}`;const g=a.angleToPoint(o),l=a.angleToPoint(i),f=At(g-r+Math.PI),d=At(l-r+Math.PI);Math.abs(d-f)>Math.PI+Xs&&he.addMsg(`warn882: newRounded a873 or a972 larger than PI/2 ${Zt(f)} ${Zt(d)} at ${Zt(a.cx)} ${Zt(a.cy)}
16
+ `);const E=!(A>0);return new Kt(1,o,i,a,s,g,l,E)}function qu(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(Jn(e.s1,A)),o.push(gn(A,r,s,e.ra,e.aph,e.abi)),o.push(Vn(e.s3,r)),o}function ju(e){const n=un(e.p1,e.p2).lineParallelDistance(e.ra,e.p6,e.p5),s=n.projectPoint(e.p5),A=s.distanceToPoint(e.p5),r=Gn(e.aph,e.s3,e.ra),o=Hn(r,A),i=Zs(n.ca,o,s,e.p6),a=e.p5.angleToPoint(i),c=e.p5.translatePolar(a,e.s3.radius),u=e.p2.angleFromToPoints(e.p1,i),l=Math.abs(e.ra/Math.sin(u))*Math.cos(u),f=e.p2.angleToPoint(e.p1),d=e.p2.translatePolar(f,l),E=[];return E.push(Jn(e.s1,d)),E.push(gn(d,c,i,e.ra,e.aph,e.abi)),E.push(Wn(e.s3,c)),E}function $u(e){const n=un(e.p3,e.p2).lineParallelDistance(e.ra,e.p6,e.p4),s=n.projectPoint(e.p4),A=s.distanceToPoint(e.p4),r=Gn(e.aph,e.s1,e.ra),o=Hn(r,A),i=Zs(n.ca,o,s,e.p6),a=e.p4.angleToPoint(i),c=e.p4.translatePolar(a,e.s1.radius),u=e.p2.angleFromToPoints(e.p3,i),l=Math.abs(e.ra/Math.sin(u))*Math.cos(u),f=e.p2.angleToPoint(e.p3),d=e.p2.translatePolar(f,l),E=[];return E.push(zn(e.s1,c)),E.push(gn(c,d,i,e.ra,e.aph,e.abi)),E.push(Vn(e.s3,d)),E}function Xu(e){const t=Gn(e.aph,e.s1,e.ra),n=Gn(e.aph,e.s3,e.ra),s=e.p4.distanceToPoint(e.p5),A=e.p4.angleToPoint(e.p5),r=UA(s,t,n),o=KA(e.p4,A,r,t,e.p6),i=A+o*r,a=e.p4.translatePolar(i,t),c=e.p4.translatePolar(i,e.s1.radius),u=Math.PI+A,g=UA(s,n,t),l=KA(e.p5,u,g,n,e.p6),f=u+l*g,d=e.p5.translatePolar(f,n);if(!d.isEqual(a))throw`err909: roundArcArc p7 anf p7b differ ${a.cx} ${d.cx} ${a.cy} ${d.cy} 0`;const E=e.p5.translatePolar(f,e.s3.radius),h=[];return h.push(zn(e.s1,c)),h.push(gn(c,E,a,e.ra,e.aph,e.abi)),h.push(Wn(e.s3,E)),h}function Wo(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),u=e.p4.angleToPoint(e.p2)+2*a;s=e.p4.translatePolar(u,e.s1.radius)}if(e.s3.sType===1){const a=e.p5.angleFromToPoints(e.p2,e.p6),u=e.p5.angleToPoint(e.p2)+2*a;A=e.p5.translatePolar(u,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(Jn(e.s1,s)):e.s1.sType===1&&i.push(zn(e.s1,s)),i.push(o),e.s3.sType===0?i.push(Vn(e.s3,A)):e.s3.sType===1&&i.push(Wn(e.s3,A)),i}function JA(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=Kn(r.cx,r.cy,s.abi);if(t.sType===0)A=un(t.p1,t.p2).intersection(i);else if(t.sType===1){const a=i.projectPoint(t.pc),c=a.distanceToPoint(t.pc);if(c<t.radius){const u=Hn(t.radius,c);A=Zs(s.abi,u,a,n)}else he.addMsg(`warn222: wideAccess not possible on arc ${Zt(t.radius)} ${Zt(c)} at ${Zt(n.cx)} ${Zt(n.cy)}
17
+ `),A=n,r=n}}return[A,r]}function Zu(e){const t=Wo(e),n=t[1].arcCcw?1:-1,[s,A]=JA(n,e.s1,t[1].p1,e),[r,o]=JA(-n,e.s3,t[1].p2,e),i=[];if(s.isEqual(A))i.push(t[0]);else{e.s1.sType===0?i.push(Jn(e.s1,s)):e.s1.sType===1&&i.push(zn(e.s1,s));const a=Y(0,0),c=new Kt(0,s,A,a,0,0,0,!1);i.push(c)}if(i.push(gn(A,o,e.p6,e.ra,e.aph,e.abi)),r.isEqual(o))i.push(t[2]);else{const a=Y(0,0),c=new Kt(0,o,r,a,0,0,0,!1);i.push(c),e.s3.sType===0?i.push(Vn(e.s3,r)):e.s3.sType===1&&i.push(Wn(e.s3,r))}return i}function VA(e,t,n){const s=Wu(e,t,n),A=[];if(t.sType===3)if(e.sType===0&&n.sType===0)A.push(...qu(s));else if(e.sType===0&&n.sType===1)A.push(...ju(s));else if(e.sType===1&&n.sType===0)A.push(...$u(s));else if(e.sType===1&&n.sType===1)A.push(...Xu(s));else throw`err123: makeCorner unexpected s1s3.sType ${e.sType} ${n.sType}`;else if(t.sType===4)A.push(...Wo(s));else if(t.sType===5)A.push(...Zu(s));else throw`err723: makeCorner unexpected s2.sType ${t.sType}`;return A}function jt(e){return e.toFixed(4)}function tg(e,t,n,s=""){let A=s;return A===""&&(A="black"),`<circle cx="${jt(e)}" cy="${jt(t)}" r="${jt(n)}" stroke="${A}" stroke-width="1" fill="none" />`}var eg=class{pathD;constructor(){this.pathD=""}addStart(e,t){this.pathD=`M ${jt(e)} ${jt(t)}`}addStroke(e,t){this.pathD+=` L ${jt(e)} ${jt(t)}`}addArc(e,t,n,s,A){const r=jt(n),o=s?1:0,i=A?1:0;this.pathD+=` A ${r} ${r} 0 ${o} ${i} ${jt(e)} ${jt(t)}`}stringify(e=""){let t=e;return t===""&&(t="black"),`<path d="${this.pathD} Z" stroke="${t}" stroke-width="1" fill="none" />`}};function ng(){return new eg}var sg=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 Ag(){return new sg}function Lt(e){return e.toFixed(4)}var tA=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 rg(e,t,n,s){return new tA(!1,e,t,0,0,0,n,s)}function og(e,t,n,s,A,r){const o=r?s:A,i=r?A:s,a=Tt(ue(o)),c=Tt(ue(i));return new tA(!0,e,t,n,a,c,0,0)}function ig(e,t,n){return new tA(!1,e,t,n,0,0,0,0)}var ag=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
+ ${Lt(e)}
27
+ 20
28
+ ${Lt(t)}
29
+ 40
30
+ ${Lt(n)}
31
+ `}addLine(e,t,n,s){this.dxfStr+=`0
32
+ LINE
33
+ 8
34
+ PARAMETRIX
35
+ `,this.dxfStr+=`10
36
+ ${Lt(e)}
37
+ 20
38
+ ${Lt(t)}
39
+ 11
40
+ ${Lt(n)}
41
+ 21
42
+ ${Lt(s)}
43
+ `}addArc(e,t,n,s,A){this.dxfStr+=`0
44
+ ARC
45
+ 8
46
+ PARAMETRIX
47
+ `,this.dxfStr+=`10
48
+ ${Lt(e)}
49
+ 20
50
+ ${Lt(t)}
51
+ 40
52
+ ${Lt(n)}
53
+ 50
54
+ ${Lt(s)}
55
+ 51
56
+ ${Lt(A)}
57
+ `}close(){this.dxfStr+=`0
58
+ ENDSEC
59
+ 0
60
+ EOF
61
+ `}stringify(){return this.close(),this.dxfStr}};function cg(){return new ag}function ug(e,t,n){return{circle:!0,cx:e,cy:t,radius:n}}var gg=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 lg(){return new gg}var qo=class{};function jo(e,t,n,s){const A=Be(e,t,n),r=Y(A.pc.cx,A.pc.cy),o=ue(A.a2-A.a1),a=(n.arcCcw?o:o-2*Math.PI)/s,c=[];for(let u=1;u<s;u++)c.push(r.translatePolar(A.a1+u*a,n.radius));return c}var fg=class de extends qo{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=Y(t,n),this.lastPoint2=Y(t,n),this.imposedColor=s}setLastPoint(t,n){this.lastPoint2=this.lastPoint,this.lastPoint=Y(t,n)}getLastPoint(){return this.lastPoint}getFirstPoint(){return Y(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(Y(t,n)),this}addPointAP(t,n){const s=Y(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 ${Zt(A.cx)} ${Zt(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=Ju(s,n,t),r=A.distanceToPoint(s),o=s.middlePoint(t),i=o.angleToPoint(s),a=o.angleToPoint(n),c=At(a-i);let u=!1,g=!1;if(!o.isEqual(A)){const l=o.angleToPoint(A),f=At(l-i);Math.sign(f)*Math.sign(c)>0&&(u=!0)}Math.sign(c)>0&&(g=!0),this.addPointA(t.cx,t.cy).addSegArc(r,u,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=bs(A,s);let o=s;n&&(o=A);const i=Kn(o.cx,o.cy,t+Math.PI/2),a=r.intersection(i),c=a.distanceToPoint(A),u=A.middlePoint(s),g=o.angleToPoint(u),l=At(t-g);let f=!1;Math.abs(l)>Math.PI/2&&(f=!0);let d=!1;l<0&&(d=!0),n||(d=!d),this.addPointA(s.cx,s.cy).addSegArc(c,f,d),this.debugPoints.push(u),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),c=-1*At(n-i);if(Math.abs(a)>=Math.PI/2)throw`err545: addSeg2Arcs with too large au ${a}`;if(Math.abs(c)>=Math.PI/2)throw`err546: addSeg2Arcs with too large av ${c}`;if(K(a)===0)throw`err765: addSeg2Arcs with almost zero au ${a}`;if(K(c)===0)throw`err766: addSeg2Arcs with almost zero av ${c}`;if(Math.sign(a)*Math.sign(c)<1)throw`err767: addSeg2Arcs with au/av bad orientation ${a} ${c}`;const u=Math.tan(a/2),g=Math.tan(c/2),l=r*g/(g+u),f=Math.abs(l/Math.sin(a)),d=l/Math.cos(a/2),E=r*u/(g+u),h=Math.abs(E/Math.sin(c)),B=A.translatePolar(o+a/2,d);let p=!1;Math.sign(a)<0&&(p=!0),this.addPointA(B.cx,B.cy).addSegArc(f,!1,p),this.addPointA(s.cx,s.cy).addSegArc(h,!1,p),this.debugPoints.push(A.translatePolar(o,l)),this.debugPoints.push(A.translatePolar(o+a-Math.sign(a)*Math.PI/2,f)),this.debugPoints.push(s.translatePolar(i-c+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 de(this.segments[0].px,this.segments[0].py);for(const n of this.segments){const s=n.clone();s.sType!==6&&(t.addSeg(s),Vt(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 de(s,A);for(const o of this.segments){const i=o.clone();Vt(o.sType)&&(i.px+=t,i.py+=n),i.sType!==6&&(r.addSeg(i),Vt(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=Y(t,n),o=Y(this.segments[0].px,this.segments[0].py).rotate(A,s),i=new de(o.cx,o.cy);for(const a of this.segments){const c=a.clone();if(Vt(a.sType)){const g=Y(c.px,c.py).rotate(A,s);c.px=g.cx,c.py=g.cy}c.sType!==6&&(i.addSeg(c),Vt(c.sType)&&i.setLastPoint(c.px,c.py))}return i}scale(t,n,s,A=!1){const r=Y(t,n),i=Y(this.segments[0].px,this.segments[0].py).scale(r,s),a=new de(i.cx,i.cy);for(const c of this.segments){const u=c.clone();if(Vt(c.sType)){const l=Y(u.px,u.py).scale(r,s);u.px=l.cx,u.py=l.cy}c.sType===1&&(u.radius*=s),xn(c.sType)&&A&&(u.radius*=s),u.sType!==6&&(a.addSeg(u),Vt(u.sType)&&a.setLastPoint(u.px,u.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),Vt(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,c]=be(r,o,n),[u,g]=be(i.px,i.py,n);t.beginPath(),t.moveTo(a,c),t.lineTo(u,g),t.strokeStyle=A,t.stroke()}if(i.sType===1)try{const a=Be(r,o,i),[c,u]=be(a.pc.cx,a.pc.cy,n),g=Jo(i.radius,n);t.beginPath(),t.arc(c,u,g,-a.a1,-a.a2,i.arcCcw),t.strokeStyle=A,t.stroke()}catch(a){console.log("err413: "+a)}qe(i.sType)&&(r=i.px,o=i.py)}}extractSkeleton(){const t=this.segments[0],n=new de(t.px,t.py);for(const s of this.segments)Vt(s.sType)&&n.addSeg(s);return n}generateContour(){he.clearPoints(),he.clearLines();const t=[],n=[];let s=0,A=0,r=0;for(const c of this.segments){if(c.sType===0){const l=Y(A,r),f=Y(c.px,c.py),d=Y(0,0);t.push(new Kt(c.sType,l,f,d,0,0,0,!1)),s=1}if(c.sType===1){const l=Be(A,r,c);t.push(l),s=1}const u=t.at(-1),g=t.at(-2);if(u!==void 0&&g!==void 0&&Vt(u.sType)&&Bn(g.sType)){const l=t.pop(),f=t.pop(),d=t.pop();if(d!==void 0&&f!==void 0&&l!==void 0){const E=VA(d,f,l);t.push(...E)}else throw"err603: contour generateContour internal error"}if(Bn(c.sType)){if(s===2)throw`err419: generateContour with two consecutive corners ${c.sType}`;if(s===0&&xn(c.sType)&&c.radius>0){const l=Y(0,0);n.push(new Kt(c.sType,l,l,l,c.radius,0,0,!1))}if(s===1&&xn(c.sType)&&c.radius>0){const l=Y(0,0);t.push(new Kt(c.sType,l,l,l,c.radius,0,0,!1))}s=2}qe(c.sType)&&(A=c.px,r=c.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&&Bn(o.sType)){const c=t[0],u=t.pop(),g=t.pop();if(g!==void 0&&u!==void 0&&c!==void 0){const l=VA(g,u,c);t.push(...l.slice(0,-1));const f=l.at(-1);if(f!==void 0)t[0]=f;else throw"err606: contour generateContour internal error"}else throw"err602: contour generateContour internal error"}const i=t[0],a=new de(i.p1.cx,i.p1.cy,this.imposedColor);a.debugPoints.push(...he.getPoints()),a.debugLines.push(...he.getLines());for(const c of t)if(c.sType===0)a.addSegStrokeA(c.p2.cx,c.p2.cy);else if(c.sType===1){const u=zu(c);a.addPointA(c.p2.cx,c.p2.cy).addSegArc(u.radius,u.arcLarge,u.arcCcw)}else throw`err986: contour generateContour unexpected in seg2 Enum ${c.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=jo(s,A,r,t);n.push(...o)}catch(o){console.log("err453: "+o)}qe(r.sType)&&(s=r.px,A=r.py,n.push(Y(s,A)))}return n}getOrientation(t,n,s){const r=t.slice(1);let o=0,i=r.at(-3),a=r.at(-2),c=r.at(-1),u=-1;for(const[l,f]of r.entries()){i=a,a=c,c=f;const d=s?a.cx>n-.001:a.cx<n+.001,E=s?i.cx>n-.001:i.cx<n+.001;if(d&&!E){const h=i.cx-a.cx,B=i.cy-a.cy,p=c.cx-a.cx,C=c.cy-a.cy,m=p*B-C*h;o=Math.sign(m),u=l}}if(o===0)throw`err299: Orientation not found with ${r.length} points and foundIdx ${u}`;return o>0}getEnvelop(){const t=this.generatePoints(24),n=[],s=[];for(const u of t)n.push(u.cx),s.push(u.cy);const A=Math.min(...n),r=Math.max(...n),o=Math.min(...s),i=Math.max(...s),a=this.getOrientation(t,A,!1),c=this.getOrientation(t,r,!0);if(c!==a)throw`err390: orientation unstable ${a} ${c} 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{Be(n,s,o)}catch(i){throw`err778: ${i}`}qe(o.sType)&&(n=o.px,s=o.py)}const A=t.segments[0].px,r=t.segments[0].py;if(K(n-A)!==0||K(s-r)!==0)throw`err414: contour check, contour is not closed px ${A} ${n} py ${A} ${r}`}check(){he.clearMsg(),this.checkContour(this);const t=this.generateContour();return this.checkContour(t),he.getMsg()}toSvg(t,n=""){const s=ng();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(rg(n,s,A.px,A.py));else if(A.sType===1)try{const r=Be(n,s,A);t.push(og(r.pc.cx,r.pc.cy,A.radius,r.a1,r.a2,r.arcCcw))}catch(r){console.log("err413: "+r)}qe(A.sType)&&(n=A.px,s=A.py)}return t}toPax(){const t=lg();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=Be(s,A,r),i=ue(o.a2-o.a1),a=o.arcCcw?i:ue(2*Math.PI-i),c=r.radius*a;s=r.px,A=r.py,t+=c}else console.log(`err760: contour.getPerimeter has unknown segment type ${r.sType}`);return t}generateRevertOrientation(){let t=this.segments[0];const n=new de(t.px,t.py);let s=this.segments[0],A=!1;for(const r of this.segments.slice().reverse())if(Bn(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}},dg=class Qe extends qo{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 Qe(this.px,this.py,this.radius,this.imposedColor)}translate(t,n){return new Qe(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=Y(t,n),r=Y(this.px,this.py).rotate(A,s);return new Qe(r.cx,r.cy,this.radius,this.imposedColor)}draw(t,n,s=it.contour){const[A,r]=be(this.px,this.py,n),o=Jo(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 Qe(this.px,this.py,this.radius)}generateContour(){return new Qe(this.px,this.py,this.radius,this.imposedColor)}generatePoints(t){const n=[],s=Y(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 tg(this.px,t-this.py,this.radius,n)}toDxfSeg(){const t=[];return t.push(ig(this.px,this.py,this.radius)),t}toPax(){return ug(this.px,this.py,this.radius)}getPerimeter(){return 2*Math.PI*this.radius}generateRevertOrientation(){return new Qe(this.px,this.py,this.radius,this.imposedColor)}};function eA(e,t,n=""){return new fg(e,t,n)}function vl(e,t,n,s=""){return new dg(e,t,n,s)}var Eg=class Ms{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 Ms;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 Ms,r=Y(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]=Vo(this.pointList)}getAdjustFull(t,n){let s=Ss();return this.pointList.length>0&&(this.getMinMax(),s=vs(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=vs(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])Y(A,0).draw(t,n,it.reference,2),Y(-A,0).draw(t,n,it.reference,2),Y(0,A).draw(t,n,it.reference,2),Y(0,-A).draw(t,n,it.reference,2);Y(0,0).draw(t,n,it.origin,2)}}};function hg(){return new Eg}function Ts(e){const t=hg();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 bl(){return{points:!1,lines:!1,vectors:!1,main:!0,mainB:!1,second:!0,secondB:!1,dynamics:!1,ruler:!0,refframe:!1}}function Ml(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 Bg=(e=>(e[e.eNumber=0]="eNumber",e[e.eCheckbox=1]="eCheckbox",e[e.eDropdown=2]="eDropdown",e[e.eSectionSeparator=3]="eSectionSeparator",e))(Bg||{}),Je={partName:"",params:[],paramSvg:{},sim:{tMax:0,tStep:0,tUpdate:0}};function pg(e,t,n){return{val:e,init:t,chg:n}}function Dg(e){const t={};for(const n of Object.keys(e))t[n]=e[n].val;return t}var Cg=class{paramVal={};paramInit={};paramChanged={};partName;suffix;paramNames;getParamName(){const e=[];for(const t of Object.keys(this.paramVal))e.push(t);return e}constructor(e,t=""){for(const n of e.params)this.paramVal[n.name]=n.init,this.paramInit[n.name]=n.init,this.paramChanged[n.name]=!1;this.suffix=t,this.partName=e.partName,this.paramNames=this.getParamName()}getPartName(){return this.partName}getPartNameSuffix(){return this.partName+this.suffix}getSuffix(){return this.suffix}getParamVal(){return this.paramVal}getVal(e){if(this.paramNames.includes(e))return this.paramVal[e];throw`err140: parameter ${e} does not exist in design ${this.partName}`}getInit(e){if(this.paramNames.includes(e))return this.paramInit[e];throw`err149: parameter ${e} does not exist in design ${this.partName}`}getChanged(e){if(this.paramNames.includes(e))return this.paramChanged[e];throw`err156: parameter ${e} does not exist in design ${this.partName}`}setVal(e,t){if(this.paramNames.includes(e))this.paramVal[e]=t,this.paramChanged[e]=!0;else throw`err163: parameter ${e} does not exist in design ${this.partName}`}applyParamVal(e){let t="";for(const n of Object.keys(e))this.setVal(n,e[n]);return t+=`info104: apply ${Object.keys(e).length} parameters on ${this.partName}
62
+ `,t}applyParamList(e){return this.applyParamVal(Dg(e))}getDesignParamList(){const e={};for(const t of this.paramNames)e[t]=pg(this.getVal(t),this.getInit(t),this.getChanged(t));return e}};function Tl(e,t=""){return new Cg(e,t)}function Rl(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 Pl(e,t){return{name:e,unit:"checkbox",init:t?1:0,min:0,max:1,step:1,dropdown:[],pType:1}}function Yl(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 Ol(e){return{name:e,unit:"section-separator",init:0,min:0,max:0,step:0,dropdown:[],pType:3}}var mg=(e=>(e[e.eLinearOrtho=0]="eLinearOrtho",e[e.eRotate=1]="eRotate",e))(mg||{}),Ig=(e=>(e[e.eIdentity=0]="eIdentity",e[e.eIntersection=1]="eIntersection",e[e.eUnion=2]="eUnion",e[e.eSubstraction=3]="eSubstraction",e))(Ig||{});function Gl(e){return{partName:e,calcErr:!0,logstr:"",fig:{},vol:{extrudes:[],volumes:[]},sub:{}}}function kl(e){if(e.calcErr){let t=`err182: Error in sub-design ${e.partName}
63
+ `;throw t+=wg(e.logstr,e.partName),t}}function wg(e,t){let n="";for(const s of e.split(`
64
+ `))s!==""&&(n+=`[${t}]: ${s}
65
+ `);return n}var Fg=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 Re(){return new Fg}function nA(e){let t=6;return e===1?t=0:e===2&&(t=1),t}function xg(e){return new Ut(nA(e.typ),e.px,e.py,e.radius,e.large,e.ccw)}function $o(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 Xo(e,t,n,s=Math.PI/6,A=2){const[r,o]=$o(s,A,n,2*Math.PI),i=[];for(let u=0;u<r;u++){const g=e+n*Math.cos(u*o),l=t+n*Math.sin(u*o);i.push([g,l])}const a=i[0][0],c=i[0][1];return i.push([a,c]),i}function Zo(e,t,n,s,A,r,o=Math.PI/6,i=2){const a=Qs(s,A,r),[c,u]=$o(o,i,n,Math.abs(a)),g=r?u:-u,l=c+1,f=[];for(let d=1;d<l;d++){const E=s+d*g,h=e+n*Math.cos(E),B=t+n*Math.sin(E);f.push([h,B])}return f}var ti=Math.PI/16,ei=2;function zA(e){return e.toFixed(4)}function WA(e){return e.toString().padStart(3,"0")}function qA(e,t){return[[e,t]]}function yg(e,t,n,s,A,r){return Zo(e,t,n,s,A,r,ti,ei)}function Qg(e,t,n){return Xo(e,t,n,ti,ei)}function Sg(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(nA(r.typ),r.px,r.py,r.radius,r.large,r.ccw),i=Be(n,s,o);t.push(...yg(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 vg=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(`[ ${zA(o)}, ${zA(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}_${WA(o)}`,a=`cb_${e}_${WA(o)}`;t+=`${i} = ${this.pts[o]};
66
+ `,t+=`${a} = ${this.ptIdx[o]};
67
+ `,n.push(i),s.push(a)}const A=n.join(", "),r=s.join(", ");return t+=`a_${e} = concat(${A});
68
+ `,t+=`b_${e} = [${r}];
69
+ `,t}},bg=class{getHeader(){return`// Generated by Parametrix
70
+ `}getOneFigure(e,t){const n=new vg;for(const A of e)for(const r of A)if(r.circle===!0){const o=r,i=Qg(o.cx,o.cy,o.radius);n.addContour(i)}else{const i=Sg(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}`),`
71
+ module ${e.outName} () {
72
+ translate( [ ${e.translate[0]}, ${e.translate[1]}, ${e.translate[2]} ])
73
+ rotate( [ ${Tt(e.rotate[0])}, ${Tt(e.rotate[1])}, ${Tt(e.rotate[2])} ])
74
+ ${t}(${n}) polygon(a_${e.face}, b_${e.face});
75
+ }
76
+ `}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(`
77
+ `);let A=`
78
+ module ${e.outName} () {
79
+ ${t} () {
80
+ ${s}
81
+ }
82
+ }
83
+ `;return e.boolMethod===0&&(A=`
84
+ module ${e.outName} () {
85
+ ${s}
86
+ }
87
+ `),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`
88
+ module ${e.outName} () {
89
+ translate( [ ${e.translate[0]}, ${e.translate[1]}, ${e.translate[2]} ])
90
+ rotate( [ ${Tt(e.rotate[0])}, ${Tt(e.rotate[1])}, ${Tt(e.rotate[2])} ])
91
+ ${e.subdesign}();
92
+ }
93
+ `}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=Re().getPaxJson({},s,Je);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`
94
+ pax_${e}();
95
+ `}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 Mg(){return new bg}var ni=Math.PI/16,si=2;function jA(e){return e.toFixed(4)}function $A(e){return e.toString().padStart(3,"0")}function XA(e,t){return[[e,t]]}function Tg(e,t,n,s,A,r){return Zo(e,t,n,s,A,r,ni,si)}function Rg(e){const t=[];let n=0,s=0;for(const A of e){if(A.typ===0)t.push(...XA(A.px,A.py));else if(A.typ===1)t.push(...XA(A.px,A.py));else if(A.typ===2)try{const r=A,o=new Ut(nA(r.typ),r.px,r.py,r.radius,r.large,r.ccw),i=Be(n,s,o);t.push(...Tg(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 Pg(e,t,n){return Xo(e,t,n,ni,si)}function Ai(e,t){const n=[];for(const r of e){const[o,i]=r;n.push(`[ ${jA(o)}, ${jA(i)} ]`)}const s=`[ ${n.join(`,
96
+ `)} ]`;return`const ${t} = polygon({ points: ${s} });
97
+
98
+ `}function Yg(e,t,n,s){const A=Pg(e,t,n);return Ai(A,s)}function Og(e,t){const n=Rg(e);return Ai(n,t)}function Gg(e,t){let n="";const s=e[0];return e.slice(1).length>0?n+=`${t} = subtract( ${e.join(", ")} );
99
+ `:n+=`${t} = ${s};
100
+ `,n}function kg(e,t){let n="";const s=e[0];return e.slice(1).length>0?n+=`${t} = union( ${e.join(", ")} );
101
+ `:n+=`${t} = ${s};
102
+ `,n}var _g=class{getHeader(){return`// Generated by Parametrix
103
+
104
+ const { polygon } = require('@jscad/modeling').primitives;
105
+ //const { subtract } = require('@jscad/modeling').booleans;
106
+ //const { union, intersect, scission, subtract } = require('@jscad/modeling').booleans;
107
+ const { union, intersect, subtract } = require('@jscad/modeling').booleans;
108
+ const { extrudeLinear, extrudeRotate } = require('@jscad/modeling').extrusions;
109
+ const { translate, rotate } = require('@jscad/modeling').transforms;
110
+
111
+ const main = () => {
112
+
113
+ `}getOneFigure(e,t){let n="";const s=[];for(const[A,r]of e.entries()){const o=`face_${t}_Fa${$A(A)}`,i=[];for(const[a,c]of r.entries()){const u=`ctr_${o}_Ctr${$A(a)}`;if(c.circle===!0){const g=c;n+=Yg(g.cx,g.cy,g.radius,u)}else n+=Og(c.seg,u);i.push(u)}n+=Gg(i,o),s.push(o)}return n+=kg(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}}`),`
114
+ const ${e.outName} =
115
+ translate( [ ${e.translate[0]}, ${e.translate[1]}, ${e.translate[2]}, ],
116
+ rotate( [ ${e.rotate[0]}, ${e.rotate[1]}, ${e.rotate[2]}, ],
117
+ ${t}( ${n}, fig_${e.face} )
118
+ )
119
+ );
120
+
121
+ `}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} );
122
+ `;return e.boolMethod===0&&(s=`const ${e.outName} = ${e.inList[0]};
123
+ `),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`
124
+ const ${e.outName} =
125
+ translate( [ ${e.translate[0]}, ${e.translate[1]}, ${e.translate[2]}, ],
126
+ rotate( [ ${e.rotate[0]}, ${e.rotate[1]}, ${e.rotate[2]}, ],
127
+ ${e.subdesign}
128
+ )
129
+ );
130
+ `}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=Re().getPaxJson({},s,Je);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`
131
+ return pax_${e};
132
+ }
133
+ module.exports = { main };
134
+ `}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 Lg(){return new _g}function st(e){return e.toFixed(4)}function Bt(e){return e.toString().padStart(3,"0")}function Ng(e,t,n,s){return`def ${s}():
135
+ # Radius, XYZ-position, orientation
136
+ aCircle = Part.makeCircle(${st(n)}, App.Vector(${st(e)}, ${st(t)}, 0), App.Vector(0, 0, 1))
137
+ aWire = Part.Wire(aCircle)
138
+ rFace = Part.Face(aWire)
139
+ return rFace
140
+
141
+ `}function Ug(e,t){let n=`def ${t}():
142
+ `,s=0,A=0,r=0,o=0,i=0;for(const[c,u]of e.entries()){if(u.typ===0)n+=` P${Bt(r)} = App.Vector(${st(u.px)}, ${st(u.py)}, 0)
143
+ `,r+=1;else if(u.typ===1)n+=` P${Bt(r)} = App.Vector(${st(u.px)}, ${st(u.py)}, 0)
144
+ `,c<e.length-1?o=r:o=0,n+=` S${Bt(i)} = Part.LineSegment(P${Bt(r-1)}, P${Bt(o)})
145
+ `,r+=1,i+=1;else if(u.typ===2){try{const g=xg(u),l=jo(s,A,g,2)[0];n+=` P${Bt(r)} = App.Vector(${st(l.cx)}, ${st(l.cy)}, 0)
146
+ `,r+=1}catch(g){console.log("err730: "+g)}n+=` P${Bt(r)} = App.Vector(${st(u.px)}, ${st(u.py)}, 0)
147
+ `,c<e.length-1?o=r:o=0,n+=` S${Bt(i)} = Part.Arc(P${Bt(r-2)}, P${Bt(r-1)}, P${Bt(o)})
148
+ `,r+=1,i+=1}s=u.px,A=u.py}const a=Array.from({length:i},(c,u)=>`S${Bt(u)}`);return n+=` aShape = Part.Shape([${a.join(", ")}])
149
+ aWire = Part.Wire(aShape.Edges)
150
+ subFace = Part.Face(aWire)
151
+ subFace.check()
152
+ return subFace
153
+
154
+ `,n}function Hg(e,t){let n=`def ${t}():
155
+ `;const s=[];for(const[o,i]of e.entries()){const a=`FC${Bt(o)}`;n+=` ${a} = ${i}()
156
+ `,s.push(a)}const A=s[0],r=s.slice(1);return r.length>0?n+=` rOneFace = ${A}.cut([${r.join(", ")}])
157
+ `:n+=` rOneFace = ${A}
158
+ `,n+=` rOneFace.check()
159
+ return rOneFace
160
+
161
+ `,n}function Kg(e,t){let n=`def ${t}():
162
+ `;const s=[];for(const[o,i]of e.entries()){const a=`FA${Bt(o)}`;n+=` ${a} = ${i}()
163
+ `,s.push(a)}const A=s[0],r=s.slice(1);return r.length>0?n+=` rOneFig = ${A}.fuse([${r.join(", ")}])
164
+ `:n+=` rOneFig = ${A}
165
+ `,n+=` rOneFig.check()
166
+ return rOneFig
167
+
168
+ `,n}var Jg=class{getHeader(e){return`# freecad-python generated by Parametrix
169
+ # run the script with:
170
+ # freecad.cmd myScript.py
171
+
172
+ import FreeCAD as App
173
+ import Part
174
+
175
+ #print(sys.argv)
176
+ outFileName = "${e}"
177
+ if (len(sys.argv) == 3):
178
+ outFileName = sys.argv[2]
179
+ print(f"outFileName: {outFileName}")
180
+
181
+ `}getOneFigure(e,t){let n="";const s=[];for(const[A,r]of e.entries()){const o=`face_${t}_Fa${A}`,i=[];for(const[a,c]of r.entries()){const u=`ctr_${o}_Ctr${a}`;if(c.circle===!0){const g=c;n+=Ng(g.cx,g.cy,g.radius,u)}else n+=Ug(c.seg,u);i.push(u)}n+=Hg(i,o),s.push(o)}return n+=Kg(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}():
182
+ FIG = ${e.face}()
183
+ `;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+=`
184
+ VR1 = VEX.rotate(App.Vector(0, 0, 0), App.Vector(1, 0, 0), ${st(Tt(e.rotate[0]))})
185
+ VR2 = VR1.rotate(App.Vector(0, 0, 0), App.Vector(0, 1, 0), ${st(Tt(e.rotate[1]))})
186
+ VR3 = VR2.rotate(App.Vector(0, 0, 0), App.Vector(0, 0, 1), ${st(Tt(e.rotate[2]))})
187
+ VFP = VR3.translate(App.Vector(${st(e.translate[0])}, ${st(e.translate[1])}, ${st(e.translate[2])}))
188
+ return VFP
189
+ ${e.outName} = fex_${e.outName}()
190
+
191
+ `,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]}
192
+ `;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}():
193
+ V000 = ${n}
194
+ `;let r=0;for(const o of s)t+=` V${Bt(r+1)} = V${Bt(r)}.${A}(${o})
195
+ `,r+=1;t+=` VFC = V${Bt(r)}.removeSplitter()
196
+ return VFC
197
+ ${e.outName} = fvol_${e.outName}()
198
+
199
+ `}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}():
200
+ IVR1 = ${e.subdesign}.rotate(App.Vector(0, 0, 0), App.Vector(1, 0, 0), ${st(Tt(e.rotate[0]))})
201
+ IVR2 = IVR1.rotate(App.Vector(0, 0, 0), App.Vector(0, 1, 0), ${st(Tt(e.rotate[1]))})
202
+ IVR3 = IVR2.rotate(App.Vector(0, 0, 0), App.Vector(0, 0, 1), ${st(Tt(e.rotate[2]))})
203
+ IVF = IVR3.translate(App.Vector(${st(e.translate[0])}, ${st(e.translate[1])}, ${st(e.translate[2])}))
204
+ return IVF
205
+ ${e.outName} = finh_${e.outName}()
206
+
207
+ `}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=Re().getPaxJson({},s,Je);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`
208
+ pax_${e}.check()
209
+ #pax_${e}.exportBrep(f"{outFileName}.brep")
210
+ #pax_${e}.exportIges(f"{outFileName}.igs")
211
+ #pax_${e}.exportStep(f"{outFileName}.stp")
212
+ pax_${e}.exportStl(f"{outFileName}.stl")
213
+
214
+ `}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 Vg(){return new Jg}var zg=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(Y(this.xMin,this.yMin)),t.push(Y(this.xMax,this.yMax)));for(const o of e)t.push(...o.generatePoints(2));const[n,s,A,r]=Vo(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]}},Wg=class{minMax;groups;svg;constructor(){this.minMax=new zg,this.groups=[],this.svg=Ag()}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 ri(){return new Wg}function kn(e){const t=ri();return t.addAContour(e),t.stringify()}function pn(e){const t=ri();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 _n(e){const t=cg();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 qg(e){let t="";return t+=e.logstr,t}function oi(e,t,n){return Re().getPaxStr(e,t,n)}function ii(e){const t=Re().getPaxJson({},e,Je);return Mg().getExportFile(t)}function ai(e){const t=Re().getPaxJson({},e,Je);return Lg().getExportFile(t)}function ci(e){const t=Re().getPaxJson({},e,Je);return Vg().getExportFile(t)}async function jg(e,t,n,s,A){const r=new Wa("application/zip"),o=new du(r),i=t.partName,a=new yt(JSON.stringify(e,null,2));await o.add(`param_${i}.json`,a);const c=new yt(t.logstr);await o.add(`geom_${i}_log.txt`,c);const u=new yt(s.logstr);await o.add(`geom_${i}_t${n}_log.txt`,u);for(const F in t.fig){const v=new yt(kn(t.fig[F].mainListC()));await o.add(`face_${i}_${F}.svg`,v);const S=new yt(_n(t.fig[F].mainListC()));await o.add(`face_${i}_${F}.dxf`,S);const x=new yt(pn(t.fig[F]));await o.add(`deco_${i}_${F}.svg`,x);const k=new yt(pn(s.fig[F]));await o.add(`deco_${i}_${F}_t${n}.svg`,k)}const g=Ts(t.fig),l=new yt(kn(g.mainListC()));await o.add(`face_${i}_all_merged.svg`,l);const f=new yt(_n(g.mainListC()));await o.add(`face_${i}_all_merged.dxf`,f);const d=new yt(pn(g));await o.add(`deco_${i}_all_merged.svg`,d);const E=new yt(pn(g));await o.add(`deco_${i}_all_merged_t${n}.svg`,E);const h=new yt(oi(e,t,A));await o.add(`${i}.pax.json`,h);const B=new yt(ii(t));await o.add(`${i}_noarc_openscad.scad`,B);const p=new yt(ai(t));await o.add(`${i}_noarc_jscad.js`,p);const C=new yt(ci(t));return await o.add(`${i}_freecad.py`,C),await o.close(),await r.getData()}var $g=(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))($g||{});function _l(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=kn(a.mainListC())}else console.log(`err749: fileTextContent eFace ${s} invalid`);else if(A===1){const a=Ts(r.fig);o=kn(a.mainListC())}else if(A===2)if(i.includes(s)){const a=r.fig[s];o=_n(a.mainListC())}else console.log(`err759: fileTextContent eFace ${s} invalid`);else if(A===3){const a=Ts(r.fig);o=_n(a.mainListC())}else A===4?o=qg(r):A===5?o=oi(t,r,n):A===6?o=ii(r):A===7?o=ai(r):A===8?o=ci(r):console.log(`err912: unknown exportFormat ${A}`)}return o}async function Ll(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 jg(n,r,t,o,s):console.log(`err913: unknown exportFormat ${A}`):console.log("err932: error by calling geome ${geome0.calcErr} ${geome1.calcErr}"),i}function Nl(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 Ul(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 Hl(e){let t=!1;return e===9&&(t=!0),t}function Kl(e,t,n,s){return JSON.stringify({lastModif:e,partName:t,pVal:n,comment:s},null," ")}function Jl(e){const t=Uu.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 c of Object.keys(a)){const u=a[c];if(isNaN(u))throw`err905: ${u} is not a number!`;i[A][c]=u}o+=`info398: parsing file has found ${Object.keys(i[A]).length} parameters
215
+ `}else throw`err489: parameter-json-file has no key ${A}
216
+ `;return Object.hasOwn(t,r)&&(i[r]=t[r]),[i,o]}function ui(){return[[0,0,0,0],[0,0,0,0],[0,0,0,0],[0,0,0,0]]}function Ve(){return[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]]}function Xg(e){const t=Ve(),n=Math.cos(e),s=Math.sin(e);return t[1][1]=n,t[2][2]=n,t[2][1]=s,t[1][2]=-s,t}function Zg(e){const t=Ve(),n=Math.cos(e),s=Math.sin(e);return t[0][0]=n,t[2][2]=n,t[0][2]=s,t[2][0]=-s,t}function tl(e){const t=Ve(),n=Math.cos(e),s=Math.sin(e);return t[0][0]=n,t[1][1]=n,t[0][1]=-s,t[1][0]=s,t}function el(e,t){const n=ui();for(let s=0;s<4;s++)for(let A=0;A<4;A++){let r=0;for(let o=0;o<4;o++)r+=e[s][o]*t[o][A];n[s][A]=r}return n}function Rs(e){let t=Ve();for(const n of e)t=el(n,t);return t}function nl(e,t,n){return Rs([Xg(e),Zg(t),tl(n)])}function sl(e,t,n){const s=Ve();return s[0][3]=e,s[1][3]=t,s[2][3]=n,s}function Al(e){const t=ui();for(let n=0;n<4;n++)for(let s=0;s<4;s++)t[n][s]=e[n][s];return t}function rl(e,t){const n=[t[0],t[1],t[2],1],s=[0,0,0];for(let A=0;A<3;A++){let r=0;for(let o=0;o<4;o++)r+=e[A][o]*n[o];s[A]=r}return s}function ol(e){return[e[0][3],e[1][3],e[2][3]]}function il(e){let t=0,n=0,s=0;const A=e[2][0],r=10**-5;return Math.abs(A-1)<r?(s=0,n=-Math.PI/2,t=-s+Math.atan2(-e[0][1],-e[0][2])):Math.abs(A+1)<r?(s=0,n=Math.PI/2,t=s+Math.atan2(e[0][1],e[0][2])):(t=Math.atan2(e[2][1],e[2][2]),n=Math.atan2(-e[2][0],Math.sqrt(e[2][1]**2+e[2][2]**2)),s=Math.atan2(e[1][0],e[0][0])),[t,n,s]}var al=class{mmat;constructor(e){this.mmat=Al(e)}addRotation(e,t,n){const s=nl(e,t,n);return this.mmat=Rs([this.mmat,s]),this}addTranslation(e,t,n){const s=sl(e,t,n);return this.mmat=Rs([this.mmat,s]),this}getMatrix(){return this.mmat}getRotation(){return il(this.mmat)}getTranslation(){return ol(this.mmat)}transform(e){return rl(this.mmat,e)}},cl=Ve();function Vl(e=cl){return new al(e)}function ul(e,t,n,s,A=0){return eA(e,t).addCornerRounded(A).addSegStrokeR(n,0).addCornerRounded(A).addSegStrokeR(0,s).addCornerRounded(A).addSegStrokeR(-n,0).addCornerRounded(A).closeSegStroke()}function gl(e,t,n,s,A,r=0){return ul(e,t,n,s,r).rotate(e,t,A)}function zl(e,t,n,s,A,r=0){const o=s/2*Math.sin(A),i=-s/2*Math.cos(A);return gl(e+o,t+i,n,s,A,r)}function Wl(e,t,n,s,A,r=0){const o=(s-n)/2;return eA(e,t).addCornerRounded(r).addSegStrokeR(n,0).addCornerRounded(r).addSegStrokeR(o,A).addCornerRounded(r).addSegStrokeR(-s,0).addCornerRounded(r).closeSegStroke()}function ql(e,t,n,s,A){if(s<n)throw`err821: Hlength ${s} is too small compare to Vwidth ${n}`;const r=n/2,o=s-n;return eA(r+o,-r).addPointA(r+o,r).addSegArc(r,!1,!0).addSegStrokeA(r,r).addPointA(r,-r).addSegArc(r,!1,!0).closeSegStroke().rotate(0,0,A).translate(e,t)}function jl(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{Ll as $,Sl as A,Ql as B,ue as C,At as D,Ig as E,jl as F,pl as G,El as H,hl as I,Ss as J,bl as K,Ml as L,yl as M,Kl as N,Jl as O,Bg as P,Fl as Q,ml as R,Hu as S,Il as T,wl as U,Un as V,xl as W,it as X,Bl as Y,Dg as Z,$g as _,Ol as a,_l as a0,Ul as a1,Hl as a2,Ts as a3,Nl as a4,Pl as b,Yl as c,eA as d,dl as e,Zt as f,hg as g,mg as h,Gl as i,Tt as j,vl as k,ul as l,Y as m,Cl as n,zl as o,Rl as p,Tl as q,Dl as r,aA as s,kl as t,wg as u,Wl as v,gl as w,Vl as x,ql as y,K as z};