@splinetool/loader 0.9.30 → 0.9.33
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/SplineLoader.d.ts +1 -1
- package/build/SplineLoader.js +51 -51
- package/package.json +6 -4
package/build/SplineLoader.js
CHANGED
|
@@ -1,27 +1,27 @@
|
|
|
1
|
-
var J_=Object.create;var sa=Object.defineProperty,K_=Object.defineProperties,X_=Object.getOwnPropertyDescriptor,Z_=Object.getOwnPropertyDescriptors,Y_=Object.getOwnPropertyNames,dg=Object.getOwnPropertySymbols,Q_=Object.getPrototypeOf,pg=Object.prototype.hasOwnProperty,eT=Object.prototype.propertyIsEnumerable;var mg=(i,e,t)=>e in i?sa(i,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):i[e]=t,U=(i,e)=>{for(var t in e||(e={}))pg.call(e,t)&&mg(i,t,e[t]);if(dg)for(var t of dg(e))eT.call(e,t)&&mg(i,t,e[t]);return i},fe=(i,e)=>K_(i,Z_(e)),gg=i=>sa(i,"__esModule",{value:!0});var th=(i,e)=>()=>(e||i((e={exports:{}}).exports,e),e.exports),tT=(i,e)=>{gg(i);for(var t in e)sa(i,t,{get:e[t],enumerable:!0})},rT=(i,e,t)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of Y_(e))!pg.call(i,r)&&r!=="default"&&sa(i,r,{get:()=>e[r],enumerable:!(t=X_(e,r))||t.enumerable});return i},rh=i=>rT(gg(sa(i!=null?J_(Q_(i)):{},"default",i&&i.__esModule&&"default"in i?{get:()=>i.default,enumerable:!0}:{value:i,enumerable:!0})),i);var Cv=th(du=>{"use strict";du.byteLength=yD;du.toByteArray=vD;du.fromByteArray=wD;var Yn=[],yn=[],gD=typeof Uint8Array!="undefined"?Uint8Array:Array,od="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";for(_o=0,wv=od.length;_o<wv;++_o)Yn[_o]=od[_o],yn[od.charCodeAt(_o)]=_o;var _o,wv;yn["-".charCodeAt(0)]=62;yn["_".charCodeAt(0)]=63;function Nv(i){var e=i.length;if(e%4>0)throw new Error("Invalid string. Length must be a multiple of 4");var t=i.indexOf("=");t===-1&&(t=e);var r=t===e?0:4-t%4;return[t,r]}function yD(i){var e=Nv(i),t=e[0],r=e[1];return(t+r)*3/4-r}function xD(i,e,t){return(e+t)*3/4-t}function vD(i){var e,t=Nv(i),r=t[0],n=t[1],s=new gD(xD(i,r,n)),l=0,c=n>0?r-4:r,f;for(f=0;f<c;f+=4)e=yn[i.charCodeAt(f)]<<18|yn[i.charCodeAt(f+1)]<<12|yn[i.charCodeAt(f+2)]<<6|yn[i.charCodeAt(f+3)],s[l++]=e>>16&255,s[l++]=e>>8&255,s[l++]=e&255;return n===2&&(e=yn[i.charCodeAt(f)]<<2|yn[i.charCodeAt(f+1)]>>4,s[l++]=e&255),n===1&&(e=yn[i.charCodeAt(f)]<<10|yn[i.charCodeAt(f+1)]<<4|yn[i.charCodeAt(f+2)]>>2,s[l++]=e>>8&255,s[l++]=e&255),s}function bD(i){return Yn[i>>18&63]+Yn[i>>12&63]+Yn[i>>6&63]+Yn[i&63]}function SD(i,e,t){for(var r,n=[],s=e;s<t;s+=3)r=(i[s]<<16&16711680)+(i[s+1]<<8&65280)+(i[s+2]&255),n.push(bD(r));return n.join("")}function wD(i){for(var e,t=i.length,r=t%3,n=[],s=16383,l=0,c=t-r;l<c;l+=s)n.push(SD(i,l,l+s>c?c:l+s));return r===1?(e=i[t-1],n.push(Yn[e>>2]+Yn[e<<4&63]+"==")):r===2&&(e=(i[t-2]<<8)+i[t-1],n.push(Yn[e>>10]+Yn[e>>4&63]+Yn[e<<2&63]+"=")),n.join("")}});var mb=th((Uu,pb)=>{(function(i,e){typeof Uu=="object"&&typeof pb!="undefined"?e(Uu):typeof define=="function"&&define.amd?define(["exports"],e):e((i=typeof globalThis!="undefined"?globalThis:i||self).SVDJS={})})(Uu,function(i){"use strict";i.SVD=function(e,t,r,n,s){if(t=t===void 0||t,r=r===void 0||r,s=1e-64/(n=n||Math.pow(2,-52)),!e)throw new TypeError("Matrix a is not defined");var l,c,f,h,p,y,g,w,S,T,C,B,G=e[0].length,D=e.length;if(D<G)throw new TypeError("Invalid matrix: m < n");for(var W=[],A=[],q=[],E=t==="f"?D:G,b=T=g=0;b<D;b++)A[b]=new Array(E).fill(0);for(b=0;b<G;b++)q[b]=new Array(G).fill(0);var R,I=new Array(G).fill(0);for(b=0;b<D;b++)for(l=0;l<G;l++)A[b][l]=e[b][l];for(b=0;b<G;b++){for(W[b]=g,S=0,f=b+1,l=b;l<D;l++)S+=Math.pow(A[l][b],2);if(S<s)g=0;else for(w=(y=A[b][b])*(g=y<0?Math.sqrt(S):-Math.sqrt(S))-S,A[b][b]=y-g,l=f;l<G;l++){for(S=0,c=b;c<D;c++)S+=A[c][b]*A[c][l];for(y=S/w,c=b;c<D;c++)A[c][l]=A[c][l]+y*A[c][b]}for(I[b]=g,S=0,l=f;l<G;l++)S+=Math.pow(A[b][l],2);if(S<s)g=0;else{for(w=(y=A[b][b+1])*(g=y<0?Math.sqrt(S):-Math.sqrt(S))-S,A[b][b+1]=y-g,l=f;l<G;l++)W[l]=A[b][l]/w;for(l=f;l<D;l++){for(S=0,c=f;c<G;c++)S+=A[l][c]*A[b][c];for(c=f;c<G;c++)A[l][c]=A[l][c]+S*W[c]}}T<(C=Math.abs(I[b])+Math.abs(W[b]))&&(T=C)}if(r)for(b=G-1;0<=b;b--){if(g!==0){for(w=A[b][b+1]*g,l=f;l<G;l++)q[l][b]=A[b][l]/w;for(l=f;l<G;l++){for(S=0,c=f;c<G;c++)S+=A[b][c]*q[c][l];for(c=f;c<G;c++)q[c][l]=q[c][l]+S*q[c][b]}}for(l=f;l<G;l++)q[b][l]=0,q[l][b]=0;q[b][b]=1,g=W[b],f=b}if(t){if(t==="f")for(b=G;b<D;b++){for(l=G;l<D;l++)A[b][l]=0;A[b][b]=1}for(b=G-1;0<=b;b--){for(f=b+1,g=I[b],l=f;l<E;l++)A[b][l]=0;if(g!==0){for(w=A[b][b]*g,l=f;l<E;l++){for(S=0,c=f;c<D;c++)S+=A[c][b]*A[c][l];for(y=S/w,c=b;c<D;c++)A[c][l]=A[c][l]+y*A[c][b]}for(l=b;l<D;l++)A[l][b]=A[l][b]/g}else for(l=b;l<D;l++)A[l][b]=0;A[b][b]=A[b][b]+1}}for(n*=T,c=G-1;0<=c;c--)for(var z=0;z<50;z++){for(R=!1,f=c;0<=f;f--){if(Math.abs(W[f])<=n){R=!0;break}if(Math.abs(I[f-1])<=n)break}if(!R){for(p=0,h=f-(S=1),b=f;b<c+1&&(y=S*W[b],W[b]=p*W[b],!(Math.abs(y)<=n));b++)if(g=I[b],I[b]=Math.sqrt(y*y+g*g),p=g/(w=I[b]),S=-y/w,t)for(l=0;l<D;l++)C=A[l][h],B=A[l][b],A[l][h]=C*p+B*S,A[l][b]=-C*S+B*p}if(B=I[c],f===c){if(B<0&&(I[c]=-B,r))for(l=0;l<G;l++)q[l][c]=-q[l][c];break}for(T=I[f],y=(((C=I[c-1])-B)*(C+B)+((g=W[c-1])-(w=W[c]))*(g+w))/(2*w*C),g=Math.sqrt(y*y+1),y=((T-B)*(T+B)+w*(C/(y<0?y-g:y+g)-w))/T,b=f+(S=p=1);b<c+1;b++){if(g=W[b],C=I[b],w=S*g,g*=p,B=Math.sqrt(y*y+w*w),y=T*(p=y/(W[b-1]=B))+g*(S=w/B),g=-T*S+g*p,w=C*S,C*=p,r)for(l=0;l<G;l++)T=q[l][b-1],B=q[l][b],q[l][b-1]=T*p+B*S,q[l][b]=-T*S+B*p;if(B=Math.sqrt(y*y+w*w),y=(p=y/(I[b-1]=B))*g+(S=w/B)*C,T=-S*g+p*C,t)for(l=0;l<D;l++)C=A[l][b-1],B=A[l][b],A[l][b-1]=C*p+B*S,A[l][b]=-C*S+B*p}W[f]=0,W[c]=y,I[c]=T}for(b=0;b<G;b++)I[b]<n&&(I[b]=0);return{u:A,q:I,v:q}},i.VERSION="1.1.1",Object.defineProperty(i,"__esModule",{value:!0})})});var Ab=th((Hs,Ya)=>{(function(){var i,e="4.17.20",t=200,r="Unsupported core-js use. Try https://npms.io/search?q=ponyfill.",n="Expected a function",s="__lodash_hash_undefined__",l=500,c="__lodash_placeholder__",f=1,h=2,p=4,y=1,g=2,w=1,S=2,T=4,C=8,B=16,G=32,D=64,W=128,A=256,q=512,E=30,b="...",R=800,I=16,z=1,O=2,$=3,he=1/0,re=9007199254740991,Ne=17976931348623157e292,ye=0/0,Me=4294967295,Fe=Me-1,k=Me>>>1,H=[["ary",W],["bind",w],["bindKey",S],["curry",C],["curryRight",B],["flip",q],["partial",G],["partialRight",D],["rearg",A]],_="[object Arguments]",J="[object Array]",ee="[object AsyncFunction]",oe="[object Boolean]",se="[object Date]",ce="[object DOMException]",ue="[object Error]",K="[object Function]",ae="[object GeneratorFunction]",ne="[object Map]",Ce="[object Number]",Y="[object Null]",le="[object Object]",de="[object Promise]",xe="[object Proxy]",_e="[object RegExp]",pe="[object Set]",we="[object String]",Ve="[object Symbol]",Ge="[object Undefined]",Qe="[object WeakMap]",bt="[object WeakSet]",Lt="[object ArrayBuffer]",At="[object DataView]",sr="[object Float32Array]",Ur="[object Float64Array]",Ht="[object Int8Array]",kr="[object Int16Array]",Nn="[object Int32Array]",Cn="[object Uint8Array]",pt="[object Uint8ClampedArray]",Wt="[object Uint16Array]",ar="[object Uint32Array]",Do=/\b__p \+= '';/g,Bo=/\b(__p \+=) '' \+/g,Go=/(__e\(.*?\)|\b__t\)) \+\n'';/g,no=/&(?:amp|lt|gt|quot|#39);/g,io=/[&<>"']/g,jo=RegExp(no.source),Mr=RegExp(io.source),oo=/<%-([\s\S]+?)%>/g,Jt=/<%([\s\S]+?)%>/g,ni=/<%=([\s\S]+?)%>/g,Eo=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Ee=/^\w*$/,Xe=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,He=/[\\^$.*+?()[\]{}|]/g,$e=RegExp(He.source),tt=/^\s+|\s+$/g,at=/^\s+/,mt=/\s+$/,gt=/\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/,ct=/\{\n\/\* \[wrapped with (.+)\] \*/,St=/,? & /,Rt=/[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g,Ar=/\\(\\)?/g,Ln=/\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g,_n=/\w*$/,zn=/^[-+]0x[0-9a-f]+$/i,Qa=/^0b[01]+$/i,jb=/^\[object .+?Constructor\]$/,Eb=/^0o[0-7]+$/i,Rb=/^(?:0|[1-9]\d*)$/,zb=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g,el=/($^)/,Fb=/['\n\r\u2028\u2029\\]/g,tl="\\ud800-\\udfff",Vb="\\u0300-\\u036f",Ub="\\ufe20-\\ufe2f",kb="\\u20d0-\\u20ff",Hd=Vb+Ub+kb,Wd="\\u2700-\\u27bf",qd="a-z\\xdf-\\xf6\\xf8-\\xff",Hb="\\xac\\xb1\\xd7\\xf7",Wb="\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf",qb="\\u2000-\\u206f",$b=" \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000",$d="A-Z\\xc0-\\xd6\\xd8-\\xde",Jd="\\ufe0e\\ufe0f",Kd=Hb+Wb+qb+$b,Hu="['\u2019]",Jb="["+tl+"]",Xd="["+Kd+"]",rl="["+Hd+"]",Zd="\\d+",Kb="["+Wd+"]",Yd="["+qd+"]",Qd="[^"+tl+Kd+Zd+Wd+qd+$d+"]",Wu="\\ud83c[\\udffb-\\udfff]",Xb="(?:"+rl+"|"+Wu+")",ep="[^"+tl+"]",qu="(?:\\ud83c[\\udde6-\\uddff]){2}",$u="[\\ud800-\\udbff][\\udc00-\\udfff]",Ro="["+$d+"]",tp="\\u200d",rp="(?:"+Yd+"|"+Qd+")",Zb="(?:"+Ro+"|"+Qd+")",np="(?:"+Hu+"(?:d|ll|m|re|s|t|ve))?",ip="(?:"+Hu+"(?:D|LL|M|RE|S|T|VE))?",op=Xb+"?",sp="["+Jd+"]?",Yb="(?:"+tp+"(?:"+[ep,qu,$u].join("|")+")"+sp+op+")*",Qb="\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?=\\b|[A-Z_])",eS="\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?=\\b|[a-z_])",ap=sp+op+Yb,tS="(?:"+[Kb,qu,$u].join("|")+")"+ap,rS="(?:"+[ep+rl+"?",rl,qu,$u,Jb].join("|")+")",nS=RegExp(Hu,"g"),iS=RegExp(rl,"g"),Ju=RegExp(Wu+"(?="+Wu+")|"+rS+ap,"g"),oS=RegExp([Ro+"?"+Yd+"+"+np+"(?="+[Xd,Ro,"$"].join("|")+")",Zb+"+"+ip+"(?="+[Xd,Ro+rp,"$"].join("|")+")",Ro+"?"+rp+"+"+np,Ro+"+"+ip,eS,Qb,Zd,tS].join("|"),"g"),sS=RegExp("["+tp+tl+Hd+Jd+"]"),aS=/[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/,lS=["Array","Buffer","DataView","Date","Error","Float32Array","Float64Array","Function","Int8Array","Int16Array","Int32Array","Map","Math","Object","Promise","RegExp","Set","String","Symbol","TypeError","Uint8Array","Uint8ClampedArray","Uint16Array","Uint32Array","WeakMap","_","clearTimeout","isFinite","parseInt","setTimeout"],cS=-1,_t={};_t[sr]=_t[Ur]=_t[Ht]=_t[kr]=_t[Nn]=_t[Cn]=_t[pt]=_t[Wt]=_t[ar]=!0,_t[_]=_t[J]=_t[Lt]=_t[oe]=_t[At]=_t[se]=_t[ue]=_t[K]=_t[ne]=_t[Ce]=_t[le]=_t[_e]=_t[pe]=_t[we]=_t[Qe]=!1;var wt={};wt[_]=wt[J]=wt[Lt]=wt[At]=wt[oe]=wt[se]=wt[sr]=wt[Ur]=wt[Ht]=wt[kr]=wt[Nn]=wt[ne]=wt[Ce]=wt[le]=wt[_e]=wt[pe]=wt[we]=wt[Ve]=wt[Cn]=wt[pt]=wt[Wt]=wt[ar]=!0,wt[ue]=wt[K]=wt[Qe]=!1;var uS={\u00C0:"A",\u00C1:"A",\u00C2:"A",\u00C3:"A",\u00C4:"A",\u00C5:"A",\u00E0:"a",\u00E1:"a",\u00E2:"a",\u00E3:"a",\u00E4:"a",\u00E5:"a",\u00C7:"C",\u00E7:"c",\u00D0:"D",\u00F0:"d",\u00C8:"E",\u00C9:"E",\u00CA:"E",\u00CB:"E",\u00E8:"e",\u00E9:"e",\u00EA:"e",\u00EB:"e",\u00CC:"I",\u00CD:"I",\u00CE:"I",\u00CF:"I",\u00EC:"i",\u00ED:"i",\u00EE:"i",\u00EF:"i",\u00D1:"N",\u00F1:"n",\u00D2:"O",\u00D3:"O",\u00D4:"O",\u00D5:"O",\u00D6:"O",\u00D8:"O",\u00F2:"o",\u00F3:"o",\u00F4:"o",\u00F5:"o",\u00F6:"o",\u00F8:"o",\u00D9:"U",\u00DA:"U",\u00DB:"U",\u00DC:"U",\u00F9:"u",\u00FA:"u",\u00FB:"u",\u00FC:"u",\u00DD:"Y",\u00FD:"y",\u00FF:"y",\u00C6:"Ae",\u00E6:"ae",\u00DE:"Th",\u00FE:"th",\u00DF:"ss",\u0100:"A",\u0102:"A",\u0104:"A",\u0101:"a",\u0103:"a",\u0105:"a",\u0106:"C",\u0108:"C",\u010A:"C",\u010C:"C",\u0107:"c",\u0109:"c",\u010B:"c",\u010D:"c",\u010E:"D",\u0110:"D",\u010F:"d",\u0111:"d",\u0112:"E",\u0114:"E",\u0116:"E",\u0118:"E",\u011A:"E",\u0113:"e",\u0115:"e",\u0117:"e",\u0119:"e",\u011B:"e",\u011C:"G",\u011E:"G",\u0120:"G",\u0122:"G",\u011D:"g",\u011F:"g",\u0121:"g",\u0123:"g",\u0124:"H",\u0126:"H",\u0125:"h",\u0127:"h",\u0128:"I",\u012A:"I",\u012C:"I",\u012E:"I",\u0130:"I",\u0129:"i",\u012B:"i",\u012D:"i",\u012F:"i",\u0131:"i",\u0134:"J",\u0135:"j",\u0136:"K",\u0137:"k",\u0138:"k",\u0139:"L",\u013B:"L",\u013D:"L",\u013F:"L",\u0141:"L",\u013A:"l",\u013C:"l",\u013E:"l",\u0140:"l",\u0142:"l",\u0143:"N",\u0145:"N",\u0147:"N",\u014A:"N",\u0144:"n",\u0146:"n",\u0148:"n",\u014B:"n",\u014C:"O",\u014E:"O",\u0150:"O",\u014D:"o",\u014F:"o",\u0151:"o",\u0154:"R",\u0156:"R",\u0158:"R",\u0155:"r",\u0157:"r",\u0159:"r",\u015A:"S",\u015C:"S",\u015E:"S",\u0160:"S",\u015B:"s",\u015D:"s",\u015F:"s",\u0161:"s",\u0162:"T",\u0164:"T",\u0166:"T",\u0163:"t",\u0165:"t",\u0167:"t",\u0168:"U",\u016A:"U",\u016C:"U",\u016E:"U",\u0170:"U",\u0172:"U",\u0169:"u",\u016B:"u",\u016D:"u",\u016F:"u",\u0171:"u",\u0173:"u",\u0174:"W",\u0175:"w",\u0176:"Y",\u0177:"y",\u0178:"Y",\u0179:"Z",\u017B:"Z",\u017D:"Z",\u017A:"z",\u017C:"z",\u017E:"z",\u0132:"IJ",\u0133:"ij",\u0152:"Oe",\u0153:"oe",\u0149:"'n",\u017F:"s"},fS={"&":"&","<":"<",">":">",'"':""","'":"'"},hS={"&":"&","<":"<",">":">",""":'"',"'":"'"},dS={"\\":"\\","'":"'","\n":"n","\r":"r","\u2028":"u2028","\u2029":"u2029"},pS=parseFloat,mS=parseInt,lp=typeof global=="object"&&global&&global.Object===Object&&global,gS=typeof self=="object"&&self&&self.Object===Object&&self,rr=lp||gS||Function("return this")(),Ku=typeof Hs=="object"&&Hs&&!Hs.nodeType&&Hs,so=Ku&&typeof Ya=="object"&&Ya&&!Ya.nodeType&&Ya,cp=so&&so.exports===Ku,Xu=cp&&lp.process,on=function(){try{var P=so&&so.require&&so.require("util").types;return P||Xu&&Xu.binding&&Xu.binding("util")}catch(X){}}(),up=on&&on.isArrayBuffer,fp=on&&on.isDate,hp=on&&on.isMap,dp=on&&on.isRegExp,pp=on&&on.isSet,mp=on&&on.isTypedArray;function Hr(P,X,V){switch(V.length){case 0:return P.call(X);case 1:return P.call(X,V[0]);case 2:return P.call(X,V[0],V[1]);case 3:return P.call(X,V[0],V[1],V[2])}return P.apply(X,V)}function yS(P,X,V,be){for(var Ue=-1,lt=P==null?0:P.length;++Ue<lt;){var Kt=P[Ue];X(be,Kt,V(Kt),P)}return be}function sn(P,X){for(var V=-1,be=P==null?0:P.length;++V<be&&X(P[V],V,P)!==!1;);return P}function xS(P,X){for(var V=P==null?0:P.length;V--&&X(P[V],V,P)!==!1;);return P}function gp(P,X){for(var V=-1,be=P==null?0:P.length;++V<be;)if(!X(P[V],V,P))return!1;return!0}function _i(P,X){for(var V=-1,be=P==null?0:P.length,Ue=0,lt=[];++V<be;){var Kt=P[V];X(Kt,V,P)&&(lt[Ue++]=Kt)}return lt}function nl(P,X){var V=P==null?0:P.length;return!!V&&zo(P,X,0)>-1}function Zu(P,X,V){for(var be=-1,Ue=P==null?0:P.length;++be<Ue;)if(V(X,P[be]))return!0;return!1}function Ot(P,X){for(var V=-1,be=P==null?0:P.length,Ue=Array(be);++V<be;)Ue[V]=X(P[V],V,P);return Ue}function Ti(P,X){for(var V=-1,be=X.length,Ue=P.length;++V<be;)P[Ue+V]=X[V];return P}function Yu(P,X,V,be){var Ue=-1,lt=P==null?0:P.length;for(be&<&&(V=P[++Ue]);++Ue<lt;)V=X(V,P[Ue],Ue,P);return V}function vS(P,X,V,be){var Ue=P==null?0:P.length;for(be&&Ue&&(V=P[--Ue]);Ue--;)V=X(V,P[Ue],Ue,P);return V}function Qu(P,X){for(var V=-1,be=P==null?0:P.length;++V<be;)if(X(P[V],V,P))return!0;return!1}var bS=ef("length");function SS(P){return P.split("")}function wS(P){return P.match(Rt)||[]}function yp(P,X,V){var be;return V(P,function(Ue,lt,Kt){if(X(Ue,lt,Kt))return be=lt,!1}),be}function il(P,X,V,be){for(var Ue=P.length,lt=V+(be?1:-1);be?lt--:++lt<Ue;)if(X(P[lt],lt,P))return lt;return-1}function zo(P,X,V){return X===X?BS(P,X,V):il(P,xp,V)}function NS(P,X,V,be){for(var Ue=V-1,lt=P.length;++Ue<lt;)if(be(P[Ue],X))return Ue;return-1}function xp(P){return P!==P}function vp(P,X){var V=P==null?0:P.length;return V?rf(P,X)/V:ye}function ef(P){return function(X){return X==null?i:X[P]}}function tf(P){return function(X){return P==null?i:P[X]}}function bp(P,X,V,be,Ue){return Ue(P,function(lt,Kt,yt){V=be?(be=!1,lt):X(V,lt,Kt,yt)}),V}function CS(P,X){var V=P.length;for(P.sort(X);V--;)P[V]=P[V].value;return P}function rf(P,X){for(var V,be=-1,Ue=P.length;++be<Ue;){var lt=X(P[be]);lt!==i&&(V=V===i?lt:V+lt)}return V}function nf(P,X){for(var V=-1,be=Array(P);++V<P;)be[V]=X(V);return be}function LS(P,X){return Ot(X,function(V){return[V,P[V]]})}function Wr(P){return function(X){return P(X)}}function of(P,X){return Ot(X,function(V){return P[V]})}function Ws(P,X){return P.has(X)}function Sp(P,X){for(var V=-1,be=P.length;++V<be&&zo(X,P[V],0)>-1;);return V}function wp(P,X){for(var V=P.length;V--&&zo(X,P[V],0)>-1;);return V}function _S(P,X){for(var V=P.length,be=0;V--;)P[V]===X&&++be;return be}var TS=tf(uS),IS=tf(fS);function MS(P){return"\\"+dS[P]}function AS(P,X){return P==null?i:P[X]}function Fo(P){return sS.test(P)}function OS(P){return aS.test(P)}function PS(P){for(var X,V=[];!(X=P.next()).done;)V.push(X.value);return V}function sf(P){var X=-1,V=Array(P.size);return P.forEach(function(be,Ue){V[++X]=[Ue,be]}),V}function Np(P,X){return function(V){return P(X(V))}}function Ii(P,X){for(var V=-1,be=P.length,Ue=0,lt=[];++V<be;){var Kt=P[V];(Kt===X||Kt===c)&&(P[V]=c,lt[Ue++]=V)}return lt}function ol(P){var X=-1,V=Array(P.size);return P.forEach(function(be){V[++X]=be}),V}function DS(P){var X=-1,V=Array(P.size);return P.forEach(function(be){V[++X]=[be,be]}),V}function BS(P,X,V){for(var be=V-1,Ue=P.length;++be<Ue;)if(P[be]===X)return be;return-1}function GS(P,X,V){for(var be=V+1;be--;)if(P[be]===X)return be;return be}function Vo(P){return Fo(P)?ES(P):bS(P)}function Tn(P){return Fo(P)?RS(P):SS(P)}var jS=tf(hS);function ES(P){for(var X=Ju.lastIndex=0;Ju.test(P);)++X;return X}function RS(P){return P.match(Ju)||[]}function zS(P){return P.match(oS)||[]}var FS=function P(X){X=X==null?rr:Mi.defaults(rr.Object(),X,Mi.pick(rr,lS));var V=X.Array,be=X.Date,Ue=X.Error,lt=X.Function,Kt=X.Math,yt=X.Object,af=X.RegExp,VS=X.String,an=X.TypeError,sl=V.prototype,US=lt.prototype,Uo=yt.prototype,al=X["__core-js_shared__"],ll=US.toString,dt=Uo.hasOwnProperty,kS=0,Cp=function(){var o=/[^.]+$/.exec(al&&al.keys&&al.keys.IE_PROTO||"");return o?"Symbol(src)_1."+o:""}(),cl=Uo.toString,HS=ll.call(yt),WS=rr._,qS=af("^"+ll.call(dt).replace(He,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$"),ul=cp?X.Buffer:i,Ai=X.Symbol,fl=X.Uint8Array,Lp=ul?ul.allocUnsafe:i,hl=Np(yt.getPrototypeOf,yt),_p=yt.create,Tp=Uo.propertyIsEnumerable,dl=sl.splice,Ip=Ai?Ai.isConcatSpreadable:i,qs=Ai?Ai.iterator:i,ao=Ai?Ai.toStringTag:i,pl=function(){try{var o=ho(yt,"defineProperty");return o({},"",{}),o}catch(a){}}(),$S=X.clearTimeout!==rr.clearTimeout&&X.clearTimeout,JS=be&&be.now!==rr.Date.now&&be.now,KS=X.setTimeout!==rr.setTimeout&&X.setTimeout,ml=Kt.ceil,gl=Kt.floor,lf=yt.getOwnPropertySymbols,XS=ul?ul.isBuffer:i,Mp=X.isFinite,ZS=sl.join,YS=Np(yt.keys,yt),Xt=Kt.max,pr=Kt.min,QS=be.now,ew=X.parseInt,Ap=Kt.random,tw=sl.reverse,cf=ho(X,"DataView"),$s=ho(X,"Map"),uf=ho(X,"Promise"),ko=ho(X,"Set"),Js=ho(X,"WeakMap"),Ks=ho(yt,"create"),yl=Js&&new Js,Ho={},rw=po(cf),nw=po($s),iw=po(uf),ow=po(ko),sw=po(Js),xl=Ai?Ai.prototype:i,Xs=xl?xl.valueOf:i,Op=xl?xl.toString:i;function x(o){if(Gt(o)&&!ke(o)&&!(o instanceof rt)){if(o instanceof ln)return o;if(dt.call(o,"__wrapped__"))return Pm(o)}return new ln(o)}var Wo=function(){function o(){}return function(a){if(!Dt(a))return{};if(_p)return _p(a);o.prototype=a;var u=new o;return o.prototype=i,u}}();function vl(){}function ln(o,a){this.__wrapped__=o,this.__actions__=[],this.__chain__=!!a,this.__index__=0,this.__values__=i}x.templateSettings={escape:oo,evaluate:Jt,interpolate:ni,variable:"",imports:{_:x}},x.prototype=vl.prototype,x.prototype.constructor=x,ln.prototype=Wo(vl.prototype),ln.prototype.constructor=ln;function rt(o){this.__wrapped__=o,this.__actions__=[],this.__dir__=1,this.__filtered__=!1,this.__iteratees__=[],this.__takeCount__=Me,this.__views__=[]}function aw(){var o=new rt(this.__wrapped__);return o.__actions__=Or(this.__actions__),o.__dir__=this.__dir__,o.__filtered__=this.__filtered__,o.__iteratees__=Or(this.__iteratees__),o.__takeCount__=this.__takeCount__,o.__views__=Or(this.__views__),o}function lw(){if(this.__filtered__){var o=new rt(this);o.__dir__=-1,o.__filtered__=!0}else o=this.clone(),o.__dir__*=-1;return o}function cw(){var o=this.__wrapped__.value(),a=this.__dir__,u=ke(o),d=a<0,m=u?o.length:0,v=S1(0,m,this.__views__),N=v.start,L=v.end,M=L-N,Q=d?L:N-1,te=this.__iteratees__,ie=te.length,me=0,Le=pr(M,this.__takeCount__);if(!u||!d&&m==M&&Le==M)return tm(o,this.__actions__);var Re=[];e:for(;M--&&me<Le;){Q+=a;for(var Je=-1,je=o[Q];++Je<ie;){var et=te[Je],nt=et.iteratee,Jr=et.type,wr=nt(je);if(Jr==O)je=wr;else if(!wr){if(Jr==z)continue e;break e}}Re[me++]=je}return Re}rt.prototype=Wo(vl.prototype),rt.prototype.constructor=rt;function lo(o){var a=-1,u=o==null?0:o.length;for(this.clear();++a<u;){var d=o[a];this.set(d[0],d[1])}}function uw(){this.__data__=Ks?Ks(null):{},this.size=0}function fw(o){var a=this.has(o)&&delete this.__data__[o];return this.size-=a?1:0,a}function hw(o){var a=this.__data__;if(Ks){var u=a[o];return u===s?i:u}return dt.call(a,o)?a[o]:i}function dw(o){var a=this.__data__;return Ks?a[o]!==i:dt.call(a,o)}function pw(o,a){var u=this.__data__;return this.size+=this.has(o)?0:1,u[o]=Ks&&a===i?s:a,this}lo.prototype.clear=uw,lo.prototype.delete=fw,lo.prototype.get=hw,lo.prototype.has=dw,lo.prototype.set=pw;function ii(o){var a=-1,u=o==null?0:o.length;for(this.clear();++a<u;){var d=o[a];this.set(d[0],d[1])}}function mw(){this.__data__=[],this.size=0}function gw(o){var a=this.__data__,u=bl(a,o);if(u<0)return!1;var d=a.length-1;return u==d?a.pop():dl.call(a,u,1),--this.size,!0}function yw(o){var a=this.__data__,u=bl(a,o);return u<0?i:a[u][1]}function xw(o){return bl(this.__data__,o)>-1}function vw(o,a){var u=this.__data__,d=bl(u,o);return d<0?(++this.size,u.push([o,a])):u[d][1]=a,this}ii.prototype.clear=mw,ii.prototype.delete=gw,ii.prototype.get=yw,ii.prototype.has=xw,ii.prototype.set=vw;function oi(o){var a=-1,u=o==null?0:o.length;for(this.clear();++a<u;){var d=o[a];this.set(d[0],d[1])}}function bw(){this.size=0,this.__data__={hash:new lo,map:new($s||ii),string:new lo}}function Sw(o){var a=Pl(this,o).delete(o);return this.size-=a?1:0,a}function ww(o){return Pl(this,o).get(o)}function Nw(o){return Pl(this,o).has(o)}function Cw(o,a){var u=Pl(this,o),d=u.size;return u.set(o,a),this.size+=u.size==d?0:1,this}oi.prototype.clear=bw,oi.prototype.delete=Sw,oi.prototype.get=ww,oi.prototype.has=Nw,oi.prototype.set=Cw;function co(o){var a=-1,u=o==null?0:o.length;for(this.__data__=new oi;++a<u;)this.add(o[a])}function Lw(o){return this.__data__.set(o,s),this}function _w(o){return this.__data__.has(o)}co.prototype.add=co.prototype.push=Lw,co.prototype.has=_w;function In(o){var a=this.__data__=new ii(o);this.size=a.size}function Tw(){this.__data__=new ii,this.size=0}function Iw(o){var a=this.__data__,u=a.delete(o);return this.size=a.size,u}function Mw(o){return this.__data__.get(o)}function Aw(o){return this.__data__.has(o)}function Ow(o,a){var u=this.__data__;if(u instanceof ii){var d=u.__data__;if(!$s||d.length<t-1)return d.push([o,a]),this.size=++u.size,this;u=this.__data__=new oi(d)}return u.set(o,a),this.size=u.size,this}In.prototype.clear=Tw,In.prototype.delete=Iw,In.prototype.get=Mw,In.prototype.has=Aw,In.prototype.set=Ow;function Pp(o,a){var u=ke(o),d=!u&&mo(o),m=!u&&!d&&Gi(o),v=!u&&!d&&!m&&Ko(o),N=u||d||m||v,L=N?nf(o.length,VS):[],M=L.length;for(var Q in o)(a||dt.call(o,Q))&&!(N&&(Q=="length"||m&&(Q=="offset"||Q=="parent")||v&&(Q=="buffer"||Q=="byteLength"||Q=="byteOffset")||ci(Q,M)))&&L.push(Q);return L}function Dp(o){var a=o.length;return a?o[Sf(0,a-1)]:i}function Pw(o,a){return Dl(Or(o),uo(a,0,o.length))}function Dw(o){return Dl(Or(o))}function ff(o,a,u){(u!==i&&!Mn(o[a],u)||u===i&&!(a in o))&&si(o,a,u)}function Zs(o,a,u){var d=o[a];(!(dt.call(o,a)&&Mn(d,u))||u===i&&!(a in o))&&si(o,a,u)}function bl(o,a){for(var u=o.length;u--;)if(Mn(o[u][0],a))return u;return-1}function Bw(o,a,u,d){return Oi(o,function(m,v,N){a(d,m,u(m),N)}),d}function Bp(o,a){return o&&Vn(a,nr(a),o)}function Gw(o,a){return o&&Vn(a,Dr(a),o)}function si(o,a,u){a=="__proto__"&&pl?pl(o,a,{configurable:!0,enumerable:!0,value:u,writable:!0}):o[a]=u}function hf(o,a){for(var u=-1,d=a.length,m=V(d),v=o==null;++u<d;)m[u]=v?i:qf(o,a[u]);return m}function uo(o,a,u){return o===o&&(u!==i&&(o=o<=u?o:u),a!==i&&(o=o>=a?o:a)),o}function cn(o,a,u,d,m,v){var N,L=a&f,M=a&h,Q=a&p;if(u&&(N=m?u(o,d,m,v):u(o)),N!==i)return N;if(!Dt(o))return o;var te=ke(o);if(te){if(N=N1(o),!L)return Or(o,N)}else{var ie=mr(o),me=ie==K||ie==ae;if(Gi(o))return im(o,L);if(ie==le||ie==_||me&&!m){if(N=M||me?{}:Nm(o),!L)return M?h1(o,Gw(N,o)):f1(o,Bp(N,o))}else{if(!wt[ie])return m?o:{};N=C1(o,ie,L)}}v||(v=new In);var Le=v.get(o);if(Le)return Le;v.set(o,N),Ym(o)?o.forEach(function(je){N.add(cn(je,a,u,je,o,v))}):Xm(o)&&o.forEach(function(je,et){N.set(et,cn(je,a,u,et,o,v))});var Re=Q?M?Pf:Of:M?Dr:nr,Je=te?i:Re(o);return sn(Je||o,function(je,et){Je&&(et=je,je=o[et]),Zs(N,et,cn(je,a,u,et,o,v))}),N}function jw(o){var a=nr(o);return function(u){return Gp(u,o,a)}}function Gp(o,a,u){var d=u.length;if(o==null)return!d;for(o=yt(o);d--;){var m=u[d],v=a[m],N=o[m];if(N===i&&!(m in o)||!v(N))return!1}return!0}function jp(o,a,u){if(typeof o!="function")throw new an(n);return ia(function(){o.apply(i,u)},a)}function Ys(o,a,u,d){var m=-1,v=nl,N=!0,L=o.length,M=[],Q=a.length;if(!L)return M;u&&(a=Ot(a,Wr(u))),d?(v=Zu,N=!1):a.length>=t&&(v=Ws,N=!1,a=new co(a));e:for(;++m<L;){var te=o[m],ie=u==null?te:u(te);if(te=d||te!==0?te:0,N&&ie===ie){for(var me=Q;me--;)if(a[me]===ie)continue e;M.push(te)}else v(a,ie,d)||M.push(te)}return M}var Oi=cm(Fn),Ep=cm(pf,!0);function Ew(o,a){var u=!0;return Oi(o,function(d,m,v){return u=!!a(d,m,v),u}),u}function Sl(o,a,u){for(var d=-1,m=o.length;++d<m;){var v=o[d],N=a(v);if(N!=null&&(L===i?N===N&&!$r(N):u(N,L)))var L=N,M=v}return M}function Rw(o,a,u,d){var m=o.length;for(u=We(u),u<0&&(u=-u>m?0:m+u),d=d===i||d>m?m:We(d),d<0&&(d+=m),d=u>d?0:eg(d);u<d;)o[u++]=a;return o}function Rp(o,a){var u=[];return Oi(o,function(d,m,v){a(d,m,v)&&u.push(d)}),u}function lr(o,a,u,d,m){var v=-1,N=o.length;for(u||(u=_1),m||(m=[]);++v<N;){var L=o[v];a>0&&u(L)?a>1?lr(L,a-1,u,d,m):Ti(m,L):d||(m[m.length]=L)}return m}var df=um(),zp=um(!0);function Fn(o,a){return o&&df(o,a,nr)}function pf(o,a){return o&&zp(o,a,nr)}function wl(o,a){return _i(a,function(u){return ui(o[u])})}function fo(o,a){a=Di(a,o);for(var u=0,d=a.length;o!=null&&u<d;)o=o[Un(a[u++])];return u&&u==d?o:i}function Fp(o,a,u){var d=a(o);return ke(o)?d:Ti(d,u(o))}function br(o){return o==null?o===i?Ge:Y:ao&&ao in yt(o)?b1(o):D1(o)}function mf(o,a){return o>a}function zw(o,a){return o!=null&&dt.call(o,a)}function Fw(o,a){return o!=null&&a in yt(o)}function Vw(o,a,u){return o>=pr(a,u)&&o<Xt(a,u)}function gf(o,a,u){for(var d=u?Zu:nl,m=o[0].length,v=o.length,N=v,L=V(v),M=1/0,Q=[];N--;){var te=o[N];N&&a&&(te=Ot(te,Wr(a))),M=pr(te.length,M),L[N]=!u&&(a||m>=120&&te.length>=120)?new co(N&&te):i}te=o[0];var ie=-1,me=L[0];e:for(;++ie<m&&Q.length<M;){var Le=te[ie],Re=a?a(Le):Le;if(Le=u||Le!==0?Le:0,!(me?Ws(me,Re):d(Q,Re,u))){for(N=v;--N;){var Je=L[N];if(!(Je?Ws(Je,Re):d(o[N],Re,u)))continue e}me&&me.push(Re),Q.push(Le)}}return Q}function Uw(o,a,u,d){return Fn(o,function(m,v,N){a(d,u(m),v,N)}),d}function Qs(o,a,u){a=Di(a,o),o=Tm(o,a);var d=o==null?o:o[Un(fn(a))];return d==null?i:Hr(d,o,u)}function Vp(o){return Gt(o)&&br(o)==_}function kw(o){return Gt(o)&&br(o)==Lt}function Hw(o){return Gt(o)&&br(o)==se}function ea(o,a,u,d,m){return o===a?!0:o==null||a==null||!Gt(o)&&!Gt(a)?o!==o&&a!==a:Ww(o,a,u,d,ea,m)}function Ww(o,a,u,d,m,v){var N=ke(o),L=ke(a),M=N?J:mr(o),Q=L?J:mr(a);M=M==_?le:M,Q=Q==_?le:Q;var te=M==le,ie=Q==le,me=M==Q;if(me&&Gi(o)){if(!Gi(a))return!1;N=!0,te=!1}if(me&&!te)return v||(v=new In),N||Ko(o)?bm(o,a,u,d,m,v):x1(o,a,M,u,d,m,v);if(!(u&y)){var Le=te&&dt.call(o,"__wrapped__"),Re=ie&&dt.call(a,"__wrapped__");if(Le||Re){var Je=Le?o.value():o,je=Re?a.value():a;return v||(v=new In),m(Je,je,u,d,v)}}return me?(v||(v=new In),v1(o,a,u,d,m,v)):!1}function qw(o){return Gt(o)&&mr(o)==ne}function yf(o,a,u,d){var m=u.length,v=m,N=!d;if(o==null)return!v;for(o=yt(o);m--;){var L=u[m];if(N&&L[2]?L[1]!==o[L[0]]:!(L[0]in o))return!1}for(;++m<v;){L=u[m];var M=L[0],Q=o[M],te=L[1];if(N&&L[2]){if(Q===i&&!(M in o))return!1}else{var ie=new In;if(d)var me=d(Q,te,M,o,a,ie);if(!(me===i?ea(te,Q,y|g,d,ie):me))return!1}}return!0}function Up(o){if(!Dt(o)||I1(o))return!1;var a=ui(o)?qS:jb;return a.test(po(o))}function $w(o){return Gt(o)&&br(o)==_e}function Jw(o){return Gt(o)&&mr(o)==pe}function Kw(o){return Gt(o)&&zl(o.length)&&!!_t[br(o)]}function kp(o){return typeof o=="function"?o:o==null?Br:typeof o=="object"?ke(o)?qp(o[0],o[1]):Wp(o):fg(o)}function xf(o){if(!na(o))return YS(o);var a=[];for(var u in yt(o))dt.call(o,u)&&u!="constructor"&&a.push(u);return a}function Xw(o){if(!Dt(o))return P1(o);var a=na(o),u=[];for(var d in o)d=="constructor"&&(a||!dt.call(o,d))||u.push(d);return u}function vf(o,a){return o<a}function Hp(o,a){var u=-1,d=Pr(o)?V(o.length):[];return Oi(o,function(m,v,N){d[++u]=a(m,v,N)}),d}function Wp(o){var a=Bf(o);return a.length==1&&a[0][2]?Lm(a[0][0],a[0][1]):function(u){return u===o||yf(u,o,a)}}function qp(o,a){return jf(o)&&Cm(a)?Lm(Un(o),a):function(u){var d=qf(u,o);return d===i&&d===a?$f(u,o):ea(a,d,y|g)}}function Nl(o,a,u,d,m){o!==a&&df(a,function(v,N){if(m||(m=new In),Dt(v))Zw(o,a,N,u,Nl,d,m);else{var L=d?d(Rf(o,N),v,N+"",o,a,m):i;L===i&&(L=v),ff(o,N,L)}},Dr)}function Zw(o,a,u,d,m,v,N){var L=Rf(o,u),M=Rf(a,u),Q=N.get(M);if(Q){ff(o,u,Q);return}var te=v?v(L,M,u+"",o,a,N):i,ie=te===i;if(ie){var me=ke(M),Le=!me&&Gi(M),Re=!me&&!Le&&Ko(M);te=M,me||Le||Re?ke(L)?te=L:zt(L)?te=Or(L):Le?(ie=!1,te=im(M,!0)):Re?(ie=!1,te=om(M,!0)):te=[]:oa(M)||mo(M)?(te=L,mo(L)?te=tg(L):(!Dt(L)||ui(L))&&(te=Nm(M))):ie=!1}ie&&(N.set(M,te),m(te,M,d,v,N),N.delete(M)),ff(o,u,te)}function $p(o,a){var u=o.length;if(!!u)return a+=a<0?u:0,ci(a,u)?o[a]:i}function Jp(o,a,u){a.length?a=Ot(a,function(v){return ke(v)?function(N){return fo(N,v.length===1?v[0]:v)}:v}):a=[Br];var d=-1;a=Ot(a,Wr(De()));var m=Hp(o,function(v,N,L){var M=Ot(a,function(Q){return Q(v)});return{criteria:M,index:++d,value:v}});return CS(m,function(v,N){return u1(v,N,u)})}function Yw(o,a){return Kp(o,a,function(u,d){return $f(o,d)})}function Kp(o,a,u){for(var d=-1,m=a.length,v={};++d<m;){var N=a[d],L=fo(o,N);u(L,N)&&ta(v,Di(N,o),L)}return v}function Qw(o){return function(a){return fo(a,o)}}function bf(o,a,u,d){var m=d?NS:zo,v=-1,N=a.length,L=o;for(o===a&&(a=Or(a)),u&&(L=Ot(o,Wr(u)));++v<N;)for(var M=0,Q=a[v],te=u?u(Q):Q;(M=m(L,te,M,d))>-1;)L!==o&&dl.call(L,M,1),dl.call(o,M,1);return o}function Xp(o,a){for(var u=o?a.length:0,d=u-1;u--;){var m=a[u];if(u==d||m!==v){var v=m;ci(m)?dl.call(o,m,1):Cf(o,m)}}return o}function Sf(o,a){return o+gl(Ap()*(a-o+1))}function e1(o,a,u,d){for(var m=-1,v=Xt(ml((a-o)/(u||1)),0),N=V(v);v--;)N[d?v:++m]=o,o+=u;return N}function wf(o,a){var u="";if(!o||a<1||a>re)return u;do a%2&&(u+=o),a=gl(a/2),a&&(o+=o);while(a);return u}function Ze(o,a){return zf(_m(o,a,Br),o+"")}function t1(o){return Dp(Xo(o))}function r1(o,a){var u=Xo(o);return Dl(u,uo(a,0,u.length))}function ta(o,a,u,d){if(!Dt(o))return o;a=Di(a,o);for(var m=-1,v=a.length,N=v-1,L=o;L!=null&&++m<v;){var M=Un(a[m]),Q=u;if(M==="__proto__"||M==="constructor"||M==="prototype")return o;if(m!=N){var te=L[M];Q=d?d(te,M,L):i,Q===i&&(Q=Dt(te)?te:ci(a[m+1])?[]:{})}Zs(L,M,Q),L=L[M]}return o}var Zp=yl?function(o,a){return yl.set(o,a),o}:Br,n1=pl?function(o,a){return pl(o,"toString",{configurable:!0,enumerable:!1,value:Kf(a),writable:!0})}:Br;function i1(o){return Dl(Xo(o))}function un(o,a,u){var d=-1,m=o.length;a<0&&(a=-a>m?0:m+a),u=u>m?m:u,u<0&&(u+=m),m=a>u?0:u-a>>>0,a>>>=0;for(var v=V(m);++d<m;)v[d]=o[d+a];return v}function o1(o,a){var u;return Oi(o,function(d,m,v){return u=a(d,m,v),!u}),!!u}function Cl(o,a,u){var d=0,m=o==null?d:o.length;if(typeof a=="number"&&a===a&&m<=k){for(;d<m;){var v=d+m>>>1,N=o[v];N!==null&&!$r(N)&&(u?N<=a:N<a)?d=v+1:m=v}return m}return Nf(o,a,Br,u)}function Nf(o,a,u,d){var m=0,v=o==null?0:o.length;if(v===0)return 0;a=u(a);for(var N=a!==a,L=a===null,M=$r(a),Q=a===i;m<v;){var te=gl((m+v)/2),ie=u(o[te]),me=ie!==i,Le=ie===null,Re=ie===ie,Je=$r(ie);if(N)var je=d||Re;else Q?je=Re&&(d||me):L?je=Re&&me&&(d||!Le):M?je=Re&&me&&!Le&&(d||!Je):Le||Je?je=!1:je=d?ie<=a:ie<a;je?m=te+1:v=te}return pr(v,Fe)}function Yp(o,a){for(var u=-1,d=o.length,m=0,v=[];++u<d;){var N=o[u],L=a?a(N):N;if(!u||!Mn(L,M)){var M=L;v[m++]=N===0?0:N}}return v}function Qp(o){return typeof o=="number"?o:$r(o)?ye:+o}function qr(o){if(typeof o=="string")return o;if(ke(o))return Ot(o,qr)+"";if($r(o))return Op?Op.call(o):"";var a=o+"";return a=="0"&&1/o==-he?"-0":a}function Pi(o,a,u){var d=-1,m=nl,v=o.length,N=!0,L=[],M=L;if(u)N=!1,m=Zu;else if(v>=t){var Q=a?null:g1(o);if(Q)return ol(Q);N=!1,m=Ws,M=new co}else M=a?[]:L;e:for(;++d<v;){var te=o[d],ie=a?a(te):te;if(te=u||te!==0?te:0,N&&ie===ie){for(var me=M.length;me--;)if(M[me]===ie)continue e;a&&M.push(ie),L.push(te)}else m(M,ie,u)||(M!==L&&M.push(ie),L.push(te))}return L}function Cf(o,a){return a=Di(a,o),o=Tm(o,a),o==null||delete o[Un(fn(a))]}function em(o,a,u,d){return ta(o,a,u(fo(o,a)),d)}function Ll(o,a,u,d){for(var m=o.length,v=d?m:-1;(d?v--:++v<m)&&a(o[v],v,o););return u?un(o,d?0:v,d?v+1:m):un(o,d?v+1:0,d?m:v)}function tm(o,a){var u=o;return u instanceof rt&&(u=u.value()),Yu(a,function(d,m){return m.func.apply(m.thisArg,Ti([d],m.args))},u)}function Lf(o,a,u){var d=o.length;if(d<2)return d?Pi(o[0]):[];for(var m=-1,v=V(d);++m<d;)for(var N=o[m],L=-1;++L<d;)L!=m&&(v[m]=Ys(v[m]||N,o[L],a,u));return Pi(lr(v,1),a,u)}function rm(o,a,u){for(var d=-1,m=o.length,v=a.length,N={};++d<m;){var L=d<v?a[d]:i;u(N,o[d],L)}return N}function _f(o){return zt(o)?o:[]}function Tf(o){return typeof o=="function"?o:Br}function Di(o,a){return ke(o)?o:jf(o,a)?[o]:Om(ut(o))}var s1=Ze;function Bi(o,a,u){var d=o.length;return u=u===i?d:u,!a&&u>=d?o:un(o,a,u)}var nm=$S||function(o){return rr.clearTimeout(o)};function im(o,a){if(a)return o.slice();var u=o.length,d=Lp?Lp(u):new o.constructor(u);return o.copy(d),d}function If(o){var a=new o.constructor(o.byteLength);return new fl(a).set(new fl(o)),a}function a1(o,a){var u=a?If(o.buffer):o.buffer;return new o.constructor(u,o.byteOffset,o.byteLength)}function l1(o){var a=new o.constructor(o.source,_n.exec(o));return a.lastIndex=o.lastIndex,a}function c1(o){return Xs?yt(Xs.call(o)):{}}function om(o,a){var u=a?If(o.buffer):o.buffer;return new o.constructor(u,o.byteOffset,o.length)}function sm(o,a){if(o!==a){var u=o!==i,d=o===null,m=o===o,v=$r(o),N=a!==i,L=a===null,M=a===a,Q=$r(a);if(!L&&!Q&&!v&&o>a||v&&N&&M&&!L&&!Q||d&&N&&M||!u&&M||!m)return 1;if(!d&&!v&&!Q&&o<a||Q&&u&&m&&!d&&!v||L&&u&&m||!N&&m||!M)return-1}return 0}function u1(o,a,u){for(var d=-1,m=o.criteria,v=a.criteria,N=m.length,L=u.length;++d<N;){var M=sm(m[d],v[d]);if(M){if(d>=L)return M;var Q=u[d];return M*(Q=="desc"?-1:1)}}return o.index-a.index}function am(o,a,u,d){for(var m=-1,v=o.length,N=u.length,L=-1,M=a.length,Q=Xt(v-N,0),te=V(M+Q),ie=!d;++L<M;)te[L]=a[L];for(;++m<N;)(ie||m<v)&&(te[u[m]]=o[m]);for(;Q--;)te[L++]=o[m++];return te}function lm(o,a,u,d){for(var m=-1,v=o.length,N=-1,L=u.length,M=-1,Q=a.length,te=Xt(v-L,0),ie=V(te+Q),me=!d;++m<te;)ie[m]=o[m];for(var Le=m;++M<Q;)ie[Le+M]=a[M];for(;++N<L;)(me||m<v)&&(ie[Le+u[N]]=o[m++]);return ie}function Or(o,a){var u=-1,d=o.length;for(a||(a=V(d));++u<d;)a[u]=o[u];return a}function Vn(o,a,u,d){var m=!u;u||(u={});for(var v=-1,N=a.length;++v<N;){var L=a[v],M=d?d(u[L],o[L],L,u,o):i;M===i&&(M=o[L]),m?si(u,L,M):Zs(u,L,M)}return u}function f1(o,a){return Vn(o,Gf(o),a)}function h1(o,a){return Vn(o,Sm(o),a)}function _l(o,a){return function(u,d){var m=ke(u)?yS:Bw,v=a?a():{};return m(u,o,De(d,2),v)}}function qo(o){return Ze(function(a,u){var d=-1,m=u.length,v=m>1?u[m-1]:i,N=m>2?u[2]:i;for(v=o.length>3&&typeof v=="function"?(m--,v):i,N&&Sr(u[0],u[1],N)&&(v=m<3?i:v,m=1),a=yt(a);++d<m;){var L=u[d];L&&o(a,L,d,v)}return a})}function cm(o,a){return function(u,d){if(u==null)return u;if(!Pr(u))return o(u,d);for(var m=u.length,v=a?m:-1,N=yt(u);(a?v--:++v<m)&&d(N[v],v,N)!==!1;);return u}}function um(o){return function(a,u,d){for(var m=-1,v=yt(a),N=d(a),L=N.length;L--;){var M=N[o?L:++m];if(u(v[M],M,v)===!1)break}return a}}function d1(o,a,u){var d=a&w,m=ra(o);function v(){var N=this&&this!==rr&&this instanceof v?m:o;return N.apply(d?u:this,arguments)}return v}function fm(o){return function(a){a=ut(a);var u=Fo(a)?Tn(a):i,d=u?u[0]:a.charAt(0),m=u?Bi(u,1).join(""):a.slice(1);return d[o]()+m}}function $o(o){return function(a){return Yu(cg(lg(a).replace(nS,"")),o,"")}}function ra(o){return function(){var a=arguments;switch(a.length){case 0:return new o;case 1:return new o(a[0]);case 2:return new o(a[0],a[1]);case 3:return new o(a[0],a[1],a[2]);case 4:return new o(a[0],a[1],a[2],a[3]);case 5:return new o(a[0],a[1],a[2],a[3],a[4]);case 6:return new o(a[0],a[1],a[2],a[3],a[4],a[5]);case 7:return new o(a[0],a[1],a[2],a[3],a[4],a[5],a[6])}var u=Wo(o.prototype),d=o.apply(u,a);return Dt(d)?d:u}}function p1(o,a,u){var d=ra(o);function m(){for(var v=arguments.length,N=V(v),L=v,M=Jo(m);L--;)N[L]=arguments[L];var Q=v<3&&N[0]!==M&&N[v-1]!==M?[]:Ii(N,M);if(v-=Q.length,v<u)return gm(o,a,Tl,m.placeholder,i,N,Q,i,i,u-v);var te=this&&this!==rr&&this instanceof m?d:o;return Hr(te,this,N)}return m}function hm(o){return function(a,u,d){var m=yt(a);if(!Pr(a)){var v=De(u,3);a=nr(a),u=function(L){return v(m[L],L,m)}}var N=o(a,u,d);return N>-1?m[v?a[N]:N]:i}}function dm(o){return li(function(a){var u=a.length,d=u,m=ln.prototype.thru;for(o&&a.reverse();d--;){var v=a[d];if(typeof v!="function")throw new an(n);if(m&&!N&&Ol(v)=="wrapper")var N=new ln([],!0)}for(d=N?d:u;++d<u;){v=a[d];var L=Ol(v),M=L=="wrapper"?Df(v):i;M&&Ef(M[0])&&M[1]==(W|C|G|A)&&!M[4].length&&M[9]==1?N=N[Ol(M[0])].apply(N,M[3]):N=v.length==1&&Ef(v)?N[L]():N.thru(v)}return function(){var Q=arguments,te=Q[0];if(N&&Q.length==1&&ke(te))return N.plant(te).value();for(var ie=0,me=u?a[ie].apply(this,Q):te;++ie<u;)me=a[ie].call(this,me);return me}})}function Tl(o,a,u,d,m,v,N,L,M,Q){var te=a&W,ie=a&w,me=a&S,Le=a&(C|B),Re=a&q,Je=me?i:ra(o);function je(){for(var et=arguments.length,nt=V(et),Jr=et;Jr--;)nt[Jr]=arguments[Jr];if(Le)var wr=Jo(je),Kr=_S(nt,wr);if(d&&(nt=am(nt,d,m,Le)),v&&(nt=lm(nt,v,N,Le)),et-=Kr,Le&&et<Q){var Ft=Ii(nt,wr);return gm(o,a,Tl,je.placeholder,u,nt,Ft,L,M,Q-et)}var An=ie?u:this,hi=me?An[o]:o;return et=nt.length,L?nt=B1(nt,L):Re&&et>1&&nt.reverse(),te&&M<et&&(nt.length=M),this&&this!==rr&&this instanceof je&&(hi=Je||ra(hi)),hi.apply(An,nt)}return je}function pm(o,a){return function(u,d){return Uw(u,o,a(d),{})}}function Il(o,a){return function(u,d){var m;if(u===i&&d===i)return a;if(u!==i&&(m=u),d!==i){if(m===i)return d;typeof u=="string"||typeof d=="string"?(u=qr(u),d=qr(d)):(u=Qp(u),d=Qp(d)),m=o(u,d)}return m}}function Mf(o){return li(function(a){return a=Ot(a,Wr(De())),Ze(function(u){var d=this;return o(a,function(m){return Hr(m,d,u)})})})}function Ml(o,a){a=a===i?" ":qr(a);var u=a.length;if(u<2)return u?wf(a,o):a;var d=wf(a,ml(o/Vo(a)));return Fo(a)?Bi(Tn(d),0,o).join(""):d.slice(0,o)}function m1(o,a,u,d){var m=a&w,v=ra(o);function N(){for(var L=-1,M=arguments.length,Q=-1,te=d.length,ie=V(te+M),me=this&&this!==rr&&this instanceof N?v:o;++Q<te;)ie[Q]=d[Q];for(;M--;)ie[Q++]=arguments[++L];return Hr(me,m?u:this,ie)}return N}function mm(o){return function(a,u,d){return d&&typeof d!="number"&&Sr(a,u,d)&&(u=d=i),a=fi(a),u===i?(u=a,a=0):u=fi(u),d=d===i?a<u?1:-1:fi(d),e1(a,u,d,o)}}function Al(o){return function(a,u){return typeof a=="string"&&typeof u=="string"||(a=hn(a),u=hn(u)),o(a,u)}}function gm(o,a,u,d,m,v,N,L,M,Q){var te=a&C,ie=te?N:i,me=te?i:N,Le=te?v:i,Re=te?i:v;a|=te?G:D,a&=~(te?D:G),a&T||(a&=~(w|S));var Je=[o,a,m,Le,ie,Re,me,L,M,Q],je=u.apply(i,Je);return Ef(o)&&Im(je,Je),je.placeholder=d,Mm(je,o,a)}function Af(o){var a=Kt[o];return function(u,d){if(u=hn(u),d=d==null?0:pr(We(d),292),d&&Mp(u)){var m=(ut(u)+"e").split("e"),v=a(m[0]+"e"+(+m[1]+d));return m=(ut(v)+"e").split("e"),+(m[0]+"e"+(+m[1]-d))}return a(u)}}var g1=ko&&1/ol(new ko([,-0]))[1]==he?function(o){return new ko(o)}:Yf;function ym(o){return function(a){var u=mr(a);return u==ne?sf(a):u==pe?DS(a):LS(a,o(a))}}function ai(o,a,u,d,m,v,N,L){var M=a&S;if(!M&&typeof o!="function")throw new an(n);var Q=d?d.length:0;if(Q||(a&=~(G|D),d=m=i),N=N===i?N:Xt(We(N),0),L=L===i?L:We(L),Q-=m?m.length:0,a&D){var te=d,ie=m;d=m=i}var me=M?i:Df(o),Le=[o,a,u,d,m,te,ie,v,N,L];if(me&&O1(Le,me),o=Le[0],a=Le[1],u=Le[2],d=Le[3],m=Le[4],L=Le[9]=Le[9]===i?M?0:o.length:Xt(Le[9]-Q,0),!L&&a&(C|B)&&(a&=~(C|B)),!a||a==w)var Re=d1(o,a,u);else a==C||a==B?Re=p1(o,a,L):(a==G||a==(w|G))&&!m.length?Re=m1(o,a,u,d):Re=Tl.apply(i,Le);var Je=me?Zp:Im;return Mm(Je(Re,Le),o,a)}function xm(o,a,u,d){return o===i||Mn(o,Uo[u])&&!dt.call(d,u)?a:o}function vm(o,a,u,d,m,v){return Dt(o)&&Dt(a)&&(v.set(a,o),Nl(o,a,i,vm,v),v.delete(a)),o}function y1(o){return oa(o)?i:o}function bm(o,a,u,d,m,v){var N=u&y,L=o.length,M=a.length;if(L!=M&&!(N&&M>L))return!1;var Q=v.get(o),te=v.get(a);if(Q&&te)return Q==a&&te==o;var ie=-1,me=!0,Le=u&g?new co:i;for(v.set(o,a),v.set(a,o);++ie<L;){var Re=o[ie],Je=a[ie];if(d)var je=N?d(Je,Re,ie,a,o,v):d(Re,Je,ie,o,a,v);if(je!==i){if(je)continue;me=!1;break}if(Le){if(!Qu(a,function(et,nt){if(!Ws(Le,nt)&&(Re===et||m(Re,et,u,d,v)))return Le.push(nt)})){me=!1;break}}else if(!(Re===Je||m(Re,Je,u,d,v))){me=!1;break}}return v.delete(o),v.delete(a),me}function x1(o,a,u,d,m,v,N){switch(u){case At:if(o.byteLength!=a.byteLength||o.byteOffset!=a.byteOffset)return!1;o=o.buffer,a=a.buffer;case Lt:return!(o.byteLength!=a.byteLength||!v(new fl(o),new fl(a)));case oe:case se:case Ce:return Mn(+o,+a);case ue:return o.name==a.name&&o.message==a.message;case _e:case we:return o==a+"";case ne:var L=sf;case pe:var M=d&y;if(L||(L=ol),o.size!=a.size&&!M)return!1;var Q=N.get(o);if(Q)return Q==a;d|=g,N.set(o,a);var te=bm(L(o),L(a),d,m,v,N);return N.delete(o),te;case Ve:if(Xs)return Xs.call(o)==Xs.call(a)}return!1}function v1(o,a,u,d,m,v){var N=u&y,L=Of(o),M=L.length,Q=Of(a),te=Q.length;if(M!=te&&!N)return!1;for(var ie=M;ie--;){var me=L[ie];if(!(N?me in a:dt.call(a,me)))return!1}var Le=v.get(o),Re=v.get(a);if(Le&&Re)return Le==a&&Re==o;var Je=!0;v.set(o,a),v.set(a,o);for(var je=N;++ie<M;){me=L[ie];var et=o[me],nt=a[me];if(d)var Jr=N?d(nt,et,me,a,o,v):d(et,nt,me,o,a,v);if(!(Jr===i?et===nt||m(et,nt,u,d,v):Jr)){Je=!1;break}je||(je=me=="constructor")}if(Je&&!je){var wr=o.constructor,Kr=a.constructor;wr!=Kr&&"constructor"in o&&"constructor"in a&&!(typeof wr=="function"&&wr instanceof wr&&typeof Kr=="function"&&Kr instanceof Kr)&&(Je=!1)}return v.delete(o),v.delete(a),Je}function li(o){return zf(_m(o,i,Gm),o+"")}function Of(o){return Fp(o,nr,Gf)}function Pf(o){return Fp(o,Dr,Sm)}var Df=yl?function(o){return yl.get(o)}:Yf;function Ol(o){for(var a=o.name+"",u=Ho[a],d=dt.call(Ho,a)?u.length:0;d--;){var m=u[d],v=m.func;if(v==null||v==o)return m.name}return a}function Jo(o){var a=dt.call(x,"placeholder")?x:o;return a.placeholder}function De(){var o=x.iteratee||Xf;return o=o===Xf?kp:o,arguments.length?o(arguments[0],arguments[1]):o}function Pl(o,a){var u=o.__data__;return T1(a)?u[typeof a=="string"?"string":"hash"]:u.map}function Bf(o){for(var a=nr(o),u=a.length;u--;){var d=a[u],m=o[d];a[u]=[d,m,Cm(m)]}return a}function ho(o,a){var u=AS(o,a);return Up(u)?u:i}function b1(o){var a=dt.call(o,ao),u=o[ao];try{o[ao]=i;var d=!0}catch(v){}var m=cl.call(o);return d&&(a?o[ao]=u:delete o[ao]),m}var Gf=lf?function(o){return o==null?[]:(o=yt(o),_i(lf(o),function(a){return Tp.call(o,a)}))}:Qf,Sm=lf?function(o){for(var a=[];o;)Ti(a,Gf(o)),o=hl(o);return a}:Qf,mr=br;(cf&&mr(new cf(new ArrayBuffer(1)))!=At||$s&&mr(new $s)!=ne||uf&&mr(uf.resolve())!=de||ko&&mr(new ko)!=pe||Js&&mr(new Js)!=Qe)&&(mr=function(o){var a=br(o),u=a==le?o.constructor:i,d=u?po(u):"";if(d)switch(d){case rw:return At;case nw:return ne;case iw:return de;case ow:return pe;case sw:return Qe}return a});function S1(o,a,u){for(var d=-1,m=u.length;++d<m;){var v=u[d],N=v.size;switch(v.type){case"drop":o+=N;break;case"dropRight":a-=N;break;case"take":a=pr(a,o+N);break;case"takeRight":o=Xt(o,a-N);break}}return{start:o,end:a}}function w1(o){var a=o.match(ct);return a?a[1].split(St):[]}function wm(o,a,u){a=Di(a,o);for(var d=-1,m=a.length,v=!1;++d<m;){var N=Un(a[d]);if(!(v=o!=null&&u(o,N)))break;o=o[N]}return v||++d!=m?v:(m=o==null?0:o.length,!!m&&zl(m)&&ci(N,m)&&(ke(o)||mo(o)))}function N1(o){var a=o.length,u=new o.constructor(a);return a&&typeof o[0]=="string"&&dt.call(o,"index")&&(u.index=o.index,u.input=o.input),u}function Nm(o){return typeof o.constructor=="function"&&!na(o)?Wo(hl(o)):{}}function C1(o,a,u){var d=o.constructor;switch(a){case Lt:return If(o);case oe:case se:return new d(+o);case At:return a1(o,u);case sr:case Ur:case Ht:case kr:case Nn:case Cn:case pt:case Wt:case ar:return om(o,u);case ne:return new d;case Ce:case we:return new d(o);case _e:return l1(o);case pe:return new d;case Ve:return c1(o)}}function L1(o,a){var u=a.length;if(!u)return o;var d=u-1;return a[d]=(u>1?"& ":"")+a[d],a=a.join(u>2?", ":" "),o.replace(gt,`{
|
|
1
|
+
var B_=Object.create;var ra=Object.defineProperty,G_=Object.defineProperties,j_=Object.getOwnPropertyDescriptor,E_=Object.getOwnPropertyDescriptors,R_=Object.getOwnPropertyNames,og=Object.getOwnPropertySymbols,z_=Object.getPrototypeOf,sg=Object.prototype.hasOwnProperty,F_=Object.prototype.propertyIsEnumerable;var ag=(i,e,t)=>e in i?ra(i,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):i[e]=t,U=(i,e)=>{for(var t in e||(e={}))sg.call(e,t)&&ag(i,t,e[t]);if(og)for(var t of og(e))F_.call(e,t)&&ag(i,t,e[t]);return i},fe=(i,e)=>G_(i,E_(e)),lg=i=>ra(i,"__esModule",{value:!0});var cg=(i,e)=>()=>(e||i((e={exports:{}}).exports,e),e.exports),V_=(i,e)=>{lg(i);for(var t in e)ra(i,t,{get:e[t],enumerable:!0})},U_=(i,e,t)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of R_(e))!sg.call(i,r)&&r!=="default"&&ra(i,r,{get:()=>e[r],enumerable:!(t=j_(e,r))||t.enumerable});return i},ug=i=>U_(lg(ra(i!=null?B_(z_(i)):{},"default",i&&i.__esModule&&"default"in i?{get:()=>i.default,enumerable:!0}:{value:i,enumerable:!0})),i);var eb=cg((Eu,Qv)=>{(function(i,e){typeof Eu=="object"&&typeof Qv!="undefined"?e(Eu):typeof define=="function"&&define.amd?define(["exports"],e):e((i=typeof globalThis!="undefined"?globalThis:i||self).SVDJS={})})(Eu,function(i){"use strict";i.SVD=function(e,t,r,n,s){if(t=t===void 0||t,r=r===void 0||r,s=1e-64/(n=n||Math.pow(2,-52)),!e)throw new TypeError("Matrix a is not defined");var l,c,f,h,d,x,g,w,S,D,C,G,B=e[0].length,P=e.length;if(P<B)throw new TypeError("Invalid matrix: m < n");for(var W=[],M=[],q=[],E=t==="f"?P:B,b=D=g=0;b<P;b++)M[b]=new Array(E).fill(0);for(b=0;b<B;b++)q[b]=new Array(B).fill(0);var R,T=new Array(B).fill(0);for(b=0;b<P;b++)for(l=0;l<B;l++)M[b][l]=e[b][l];for(b=0;b<B;b++){for(W[b]=g,S=0,f=b+1,l=b;l<P;l++)S+=Math.pow(M[l][b],2);if(S<s)g=0;else for(w=(x=M[b][b])*(g=x<0?Math.sqrt(S):-Math.sqrt(S))-S,M[b][b]=x-g,l=f;l<B;l++){for(S=0,c=b;c<P;c++)S+=M[c][b]*M[c][l];for(x=S/w,c=b;c<P;c++)M[c][l]=M[c][l]+x*M[c][b]}for(T[b]=g,S=0,l=f;l<B;l++)S+=Math.pow(M[b][l],2);if(S<s)g=0;else{for(w=(x=M[b][b+1])*(g=x<0?Math.sqrt(S):-Math.sqrt(S))-S,M[b][b+1]=x-g,l=f;l<B;l++)W[l]=M[b][l]/w;for(l=f;l<P;l++){for(S=0,c=f;c<B;c++)S+=M[l][c]*M[b][c];for(c=f;c<B;c++)M[l][c]=M[l][c]+S*W[c]}}D<(C=Math.abs(T[b])+Math.abs(W[b]))&&(D=C)}if(r)for(b=B-1;0<=b;b--){if(g!==0){for(w=M[b][b+1]*g,l=f;l<B;l++)q[l][b]=M[b][l]/w;for(l=f;l<B;l++){for(S=0,c=f;c<B;c++)S+=M[b][c]*q[c][l];for(c=f;c<B;c++)q[c][l]=q[c][l]+S*q[c][b]}}for(l=f;l<B;l++)q[b][l]=0,q[l][b]=0;q[b][b]=1,g=W[b],f=b}if(t){if(t==="f")for(b=B;b<P;b++){for(l=B;l<P;l++)M[b][l]=0;M[b][b]=1}for(b=B-1;0<=b;b--){for(f=b+1,g=T[b],l=f;l<E;l++)M[b][l]=0;if(g!==0){for(w=M[b][b]*g,l=f;l<E;l++){for(S=0,c=f;c<P;c++)S+=M[c][b]*M[c][l];for(x=S/w,c=b;c<P;c++)M[c][l]=M[c][l]+x*M[c][b]}for(l=b;l<P;l++)M[l][b]=M[l][b]/g}else for(l=b;l<P;l++)M[l][b]=0;M[b][b]=M[b][b]+1}}for(n*=D,c=B-1;0<=c;c--)for(var z=0;z<50;z++){for(R=!1,f=c;0<=f;f--){if(Math.abs(W[f])<=n){R=!0;break}if(Math.abs(T[f-1])<=n)break}if(!R){for(d=0,h=f-(S=1),b=f;b<c+1&&(x=S*W[b],W[b]=d*W[b],!(Math.abs(x)<=n));b++)if(g=T[b],T[b]=Math.sqrt(x*x+g*g),d=g/(w=T[b]),S=-x/w,t)for(l=0;l<P;l++)C=M[l][h],G=M[l][b],M[l][h]=C*d+G*S,M[l][b]=-C*S+G*d}if(G=T[c],f===c){if(G<0&&(T[c]=-G,r))for(l=0;l<B;l++)q[l][c]=-q[l][c];break}for(D=T[f],x=(((C=T[c-1])-G)*(C+G)+((g=W[c-1])-(w=W[c]))*(g+w))/(2*w*C),g=Math.sqrt(x*x+1),x=((D-G)*(D+G)+w*(C/(x<0?x-g:x+g)-w))/D,b=f+(S=d=1);b<c+1;b++){if(g=W[b],C=T[b],w=S*g,g*=d,G=Math.sqrt(x*x+w*w),x=D*(d=x/(W[b-1]=G))+g*(S=w/G),g=-D*S+g*d,w=C*S,C*=d,r)for(l=0;l<B;l++)D=q[l][b-1],G=q[l][b],q[l][b-1]=D*d+G*S,q[l][b]=-D*S+G*d;if(G=Math.sqrt(x*x+w*w),x=(d=x/(T[b-1]=G))*g+(S=w/G)*C,D=-S*g+d*C,t)for(l=0;l<P;l++)C=M[l][b-1],G=M[l][b],M[l][b-1]=C*d+G*S,M[l][b]=-C*S+G*d}W[f]=0,W[c]=x,T[c]=D}for(b=0;b<B;b++)T[b]<n&&(T[b]=0);return{u:M,q:T,v:q}},i.VERSION="1.1.1",Object.defineProperty(i,"__esModule",{value:!0})})});var gb=cg((Fs,Xa)=>{(function(){var i,e="4.17.20",t=200,r="Unsupported core-js use. Try https://npms.io/search?q=ponyfill.",n="Expected a function",s="__lodash_hash_undefined__",l=500,c="__lodash_placeholder__",f=1,h=2,d=4,x=1,g=2,w=1,S=2,D=4,C=8,G=16,B=32,P=64,W=128,M=256,q=512,E=30,b="...",R=800,T=16,z=1,A=2,$=3,he=1/0,re=9007199254740991,Ne=17976931348623157e292,ye=0/0,Me=4294967295,Fe=Me-1,k=Me>>>1,H=[["ary",W],["bind",w],["bindKey",S],["curry",C],["curryRight",G],["flip",q],["partial",B],["partialRight",P],["rearg",M]],_="[object Arguments]",J="[object Array]",ee="[object AsyncFunction]",oe="[object Boolean]",se="[object Date]",ce="[object DOMException]",ue="[object Error]",K="[object Function]",ae="[object GeneratorFunction]",ne="[object Map]",Ce="[object Number]",Y="[object Null]",le="[object Object]",pe="[object Promise]",xe="[object Proxy]",_e="[object RegExp]",de="[object Set]",we="[object String]",Ve="[object Symbol]",Ge="[object Undefined]",Qe="[object WeakMap]",bt="[object WeakSet]",Lt="[object ArrayBuffer]",At="[object DataView]",sr="[object Float32Array]",Ur="[object Float64Array]",Ht="[object Int8Array]",kr="[object Int16Array]",wn="[object Int32Array]",Nn="[object Uint8Array]",dt="[object Uint8ClampedArray]",Wt="[object Uint16Array]",ar="[object Uint32Array]",Ao=/\b__p \+= '';/g,Oo=/\b(__p \+=) '' \+/g,Po=/(__e\(.*?\)|\b__t\)) \+\n'';/g,ro=/&(?:amp|lt|gt|quot|#39);/g,no=/[&<>"']/g,Do=RegExp(ro.source),Mr=RegExp(no.source),io=/<%-([\s\S]+?)%>/g,Jt=/<%([\s\S]+?)%>/g,ti=/<%=([\s\S]+?)%>/g,Bo=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Ee=/^\w*$/,Xe=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,He=/[\\^$.*+?()[\]{}|]/g,$e=RegExp(He.source),tt=/^\s+|\s+$/g,at=/^\s+/,mt=/\s+$/,gt=/\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/,ct=/\{\n\/\* \[wrapped with (.+)\] \*/,St=/,? & /,Rt=/[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g,Ar=/\\(\\)?/g,Cn=/\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g,Ln=/\w*$/,Rn=/^[-+]0x[0-9a-f]+$/i,Za=/^0b[01]+$/i,wb=/^\[object .+?Constructor\]$/,Nb=/^0o[0-7]+$/i,Cb=/^(?:0|[1-9]\d*)$/,Lb=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g,Ya=/($^)/,_b=/['\n\r\u2028\u2029\\]/g,Qa="\\ud800-\\udfff",Tb="\\u0300-\\u036f",Ib="\\ufe20-\\ufe2f",Mb="\\u20d0-\\u20ff",jp=Tb+Ib+Mb,Ep="\\u2700-\\u27bf",Rp="a-z\\xdf-\\xf6\\xf8-\\xff",Ab="\\xac\\xb1\\xd7\\xf7",Ob="\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf",Pb="\\u2000-\\u206f",Db=" \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000",zp="A-Z\\xc0-\\xd6\\xd8-\\xde",Fp="\\ufe0e\\ufe0f",Vp=Ab+Ob+Pb+Db,zu="['\u2019]",Bb="["+Qa+"]",Up="["+Vp+"]",el="["+jp+"]",kp="\\d+",Gb="["+Ep+"]",Hp="["+Rp+"]",Wp="[^"+Qa+Vp+kp+Ep+Rp+zp+"]",Fu="\\ud83c[\\udffb-\\udfff]",jb="(?:"+el+"|"+Fu+")",qp="[^"+Qa+"]",Vu="(?:\\ud83c[\\udde6-\\uddff]){2}",Uu="[\\ud800-\\udbff][\\udc00-\\udfff]",Go="["+zp+"]",$p="\\u200d",Jp="(?:"+Hp+"|"+Wp+")",Eb="(?:"+Go+"|"+Wp+")",Kp="(?:"+zu+"(?:d|ll|m|re|s|t|ve))?",Xp="(?:"+zu+"(?:D|LL|M|RE|S|T|VE))?",Zp=jb+"?",Yp="["+Fp+"]?",Rb="(?:"+$p+"(?:"+[qp,Vu,Uu].join("|")+")"+Yp+Zp+")*",zb="\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?=\\b|[A-Z_])",Fb="\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?=\\b|[a-z_])",Qp=Yp+Zp+Rb,Vb="(?:"+[Gb,Vu,Uu].join("|")+")"+Qp,Ub="(?:"+[qp+el+"?",el,Vu,Uu,Bb].join("|")+")",kb=RegExp(zu,"g"),Hb=RegExp(el,"g"),ku=RegExp(Fu+"(?="+Fu+")|"+Ub+Qp,"g"),Wb=RegExp([Go+"?"+Hp+"+"+Kp+"(?="+[Up,Go,"$"].join("|")+")",Eb+"+"+Xp+"(?="+[Up,Go+Jp,"$"].join("|")+")",Go+"?"+Jp+"+"+Kp,Go+"+"+Xp,Fb,zb,kp,Vb].join("|"),"g"),qb=RegExp("["+$p+Qa+jp+Fp+"]"),$b=/[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/,Jb=["Array","Buffer","DataView","Date","Error","Float32Array","Float64Array","Function","Int8Array","Int16Array","Int32Array","Map","Math","Object","Promise","RegExp","Set","String","Symbol","TypeError","Uint8Array","Uint8ClampedArray","Uint16Array","Uint32Array","WeakMap","_","clearTimeout","isFinite","parseInt","setTimeout"],Kb=-1,_t={};_t[sr]=_t[Ur]=_t[Ht]=_t[kr]=_t[wn]=_t[Nn]=_t[dt]=_t[Wt]=_t[ar]=!0,_t[_]=_t[J]=_t[Lt]=_t[oe]=_t[At]=_t[se]=_t[ue]=_t[K]=_t[ne]=_t[Ce]=_t[le]=_t[_e]=_t[de]=_t[we]=_t[Qe]=!1;var wt={};wt[_]=wt[J]=wt[Lt]=wt[At]=wt[oe]=wt[se]=wt[sr]=wt[Ur]=wt[Ht]=wt[kr]=wt[wn]=wt[ne]=wt[Ce]=wt[le]=wt[_e]=wt[de]=wt[we]=wt[Ve]=wt[Nn]=wt[dt]=wt[Wt]=wt[ar]=!0,wt[ue]=wt[K]=wt[Qe]=!1;var Xb={\u00C0:"A",\u00C1:"A",\u00C2:"A",\u00C3:"A",\u00C4:"A",\u00C5:"A",\u00E0:"a",\u00E1:"a",\u00E2:"a",\u00E3:"a",\u00E4:"a",\u00E5:"a",\u00C7:"C",\u00E7:"c",\u00D0:"D",\u00F0:"d",\u00C8:"E",\u00C9:"E",\u00CA:"E",\u00CB:"E",\u00E8:"e",\u00E9:"e",\u00EA:"e",\u00EB:"e",\u00CC:"I",\u00CD:"I",\u00CE:"I",\u00CF:"I",\u00EC:"i",\u00ED:"i",\u00EE:"i",\u00EF:"i",\u00D1:"N",\u00F1:"n",\u00D2:"O",\u00D3:"O",\u00D4:"O",\u00D5:"O",\u00D6:"O",\u00D8:"O",\u00F2:"o",\u00F3:"o",\u00F4:"o",\u00F5:"o",\u00F6:"o",\u00F8:"o",\u00D9:"U",\u00DA:"U",\u00DB:"U",\u00DC:"U",\u00F9:"u",\u00FA:"u",\u00FB:"u",\u00FC:"u",\u00DD:"Y",\u00FD:"y",\u00FF:"y",\u00C6:"Ae",\u00E6:"ae",\u00DE:"Th",\u00FE:"th",\u00DF:"ss",\u0100:"A",\u0102:"A",\u0104:"A",\u0101:"a",\u0103:"a",\u0105:"a",\u0106:"C",\u0108:"C",\u010A:"C",\u010C:"C",\u0107:"c",\u0109:"c",\u010B:"c",\u010D:"c",\u010E:"D",\u0110:"D",\u010F:"d",\u0111:"d",\u0112:"E",\u0114:"E",\u0116:"E",\u0118:"E",\u011A:"E",\u0113:"e",\u0115:"e",\u0117:"e",\u0119:"e",\u011B:"e",\u011C:"G",\u011E:"G",\u0120:"G",\u0122:"G",\u011D:"g",\u011F:"g",\u0121:"g",\u0123:"g",\u0124:"H",\u0126:"H",\u0125:"h",\u0127:"h",\u0128:"I",\u012A:"I",\u012C:"I",\u012E:"I",\u0130:"I",\u0129:"i",\u012B:"i",\u012D:"i",\u012F:"i",\u0131:"i",\u0134:"J",\u0135:"j",\u0136:"K",\u0137:"k",\u0138:"k",\u0139:"L",\u013B:"L",\u013D:"L",\u013F:"L",\u0141:"L",\u013A:"l",\u013C:"l",\u013E:"l",\u0140:"l",\u0142:"l",\u0143:"N",\u0145:"N",\u0147:"N",\u014A:"N",\u0144:"n",\u0146:"n",\u0148:"n",\u014B:"n",\u014C:"O",\u014E:"O",\u0150:"O",\u014D:"o",\u014F:"o",\u0151:"o",\u0154:"R",\u0156:"R",\u0158:"R",\u0155:"r",\u0157:"r",\u0159:"r",\u015A:"S",\u015C:"S",\u015E:"S",\u0160:"S",\u015B:"s",\u015D:"s",\u015F:"s",\u0161:"s",\u0162:"T",\u0164:"T",\u0166:"T",\u0163:"t",\u0165:"t",\u0167:"t",\u0168:"U",\u016A:"U",\u016C:"U",\u016E:"U",\u0170:"U",\u0172:"U",\u0169:"u",\u016B:"u",\u016D:"u",\u016F:"u",\u0171:"u",\u0173:"u",\u0174:"W",\u0175:"w",\u0176:"Y",\u0177:"y",\u0178:"Y",\u0179:"Z",\u017B:"Z",\u017D:"Z",\u017A:"z",\u017C:"z",\u017E:"z",\u0132:"IJ",\u0133:"ij",\u0152:"Oe",\u0153:"oe",\u0149:"'n",\u017F:"s"},Zb={"&":"&","<":"<",">":">",'"':""","'":"'"},Yb={"&":"&","<":"<",">":">",""":'"',"'":"'"},Qb={"\\":"\\","'":"'","\n":"n","\r":"r","\u2028":"u2028","\u2029":"u2029"},eS=parseFloat,tS=parseInt,ed=typeof global=="object"&&global&&global.Object===Object&&global,rS=typeof self=="object"&&self&&self.Object===Object&&self,rr=ed||rS||Function("return this")(),Hu=typeof Fs=="object"&&Fs&&!Fs.nodeType&&Fs,oo=Hu&&typeof Xa=="object"&&Xa&&!Xa.nodeType&&Xa,td=oo&&oo.exports===Hu,Wu=td&&ed.process,on=function(){try{var O=oo&&oo.require&&oo.require("util").types;return O||Wu&&Wu.binding&&Wu.binding("util")}catch(X){}}(),rd=on&&on.isArrayBuffer,nd=on&&on.isDate,id=on&&on.isMap,od=on&&on.isRegExp,sd=on&&on.isSet,ad=on&&on.isTypedArray;function Hr(O,X,V){switch(V.length){case 0:return O.call(X);case 1:return O.call(X,V[0]);case 2:return O.call(X,V[0],V[1]);case 3:return O.call(X,V[0],V[1],V[2])}return O.apply(X,V)}function nS(O,X,V,be){for(var Ue=-1,lt=O==null?0:O.length;++Ue<lt;){var Kt=O[Ue];X(be,Kt,V(Kt),O)}return be}function sn(O,X){for(var V=-1,be=O==null?0:O.length;++V<be&&X(O[V],V,O)!==!1;);return O}function iS(O,X){for(var V=O==null?0:O.length;V--&&X(O[V],V,O)!==!1;);return O}function ld(O,X){for(var V=-1,be=O==null?0:O.length;++V<be;)if(!X(O[V],V,O))return!1;return!0}function Ci(O,X){for(var V=-1,be=O==null?0:O.length,Ue=0,lt=[];++V<be;){var Kt=O[V];X(Kt,V,O)&&(lt[Ue++]=Kt)}return lt}function tl(O,X){var V=O==null?0:O.length;return!!V&&jo(O,X,0)>-1}function qu(O,X,V){for(var be=-1,Ue=O==null?0:O.length;++be<Ue;)if(V(X,O[be]))return!0;return!1}function Ot(O,X){for(var V=-1,be=O==null?0:O.length,Ue=Array(be);++V<be;)Ue[V]=X(O[V],V,O);return Ue}function Li(O,X){for(var V=-1,be=X.length,Ue=O.length;++V<be;)O[Ue+V]=X[V];return O}function $u(O,X,V,be){var Ue=-1,lt=O==null?0:O.length;for(be&<&&(V=O[++Ue]);++Ue<lt;)V=X(V,O[Ue],Ue,O);return V}function oS(O,X,V,be){var Ue=O==null?0:O.length;for(be&&Ue&&(V=O[--Ue]);Ue--;)V=X(V,O[Ue],Ue,O);return V}function Ju(O,X){for(var V=-1,be=O==null?0:O.length;++V<be;)if(X(O[V],V,O))return!0;return!1}var sS=Ku("length");function aS(O){return O.split("")}function lS(O){return O.match(Rt)||[]}function cd(O,X,V){var be;return V(O,function(Ue,lt,Kt){if(X(Ue,lt,Kt))return be=lt,!1}),be}function rl(O,X,V,be){for(var Ue=O.length,lt=V+(be?1:-1);be?lt--:++lt<Ue;)if(X(O[lt],lt,O))return lt;return-1}function jo(O,X,V){return X===X?bS(O,X,V):rl(O,ud,V)}function cS(O,X,V,be){for(var Ue=V-1,lt=O.length;++Ue<lt;)if(be(O[Ue],X))return Ue;return-1}function ud(O){return O!==O}function fd(O,X){var V=O==null?0:O.length;return V?Zu(O,X)/V:ye}function Ku(O){return function(X){return X==null?i:X[O]}}function Xu(O){return function(X){return O==null?i:O[X]}}function hd(O,X,V,be,Ue){return Ue(O,function(lt,Kt,yt){V=be?(be=!1,lt):X(V,lt,Kt,yt)}),V}function uS(O,X){var V=O.length;for(O.sort(X);V--;)O[V]=O[V].value;return O}function Zu(O,X){for(var V,be=-1,Ue=O.length;++be<Ue;){var lt=X(O[be]);lt!==i&&(V=V===i?lt:V+lt)}return V}function Yu(O,X){for(var V=-1,be=Array(O);++V<O;)be[V]=X(V);return be}function fS(O,X){return Ot(X,function(V){return[V,O[V]]})}function Wr(O){return function(X){return O(X)}}function Qu(O,X){return Ot(X,function(V){return O[V]})}function Vs(O,X){return O.has(X)}function pd(O,X){for(var V=-1,be=O.length;++V<be&&jo(X,O[V],0)>-1;);return V}function dd(O,X){for(var V=O.length;V--&&jo(X,O[V],0)>-1;);return V}function hS(O,X){for(var V=O.length,be=0;V--;)O[V]===X&&++be;return be}var pS=Xu(Xb),dS=Xu(Zb);function mS(O){return"\\"+Qb[O]}function gS(O,X){return O==null?i:O[X]}function Eo(O){return qb.test(O)}function yS(O){return $b.test(O)}function xS(O){for(var X,V=[];!(X=O.next()).done;)V.push(X.value);return V}function ef(O){var X=-1,V=Array(O.size);return O.forEach(function(be,Ue){V[++X]=[Ue,be]}),V}function md(O,X){return function(V){return O(X(V))}}function _i(O,X){for(var V=-1,be=O.length,Ue=0,lt=[];++V<be;){var Kt=O[V];(Kt===X||Kt===c)&&(O[V]=c,lt[Ue++]=V)}return lt}function nl(O){var X=-1,V=Array(O.size);return O.forEach(function(be){V[++X]=be}),V}function vS(O){var X=-1,V=Array(O.size);return O.forEach(function(be){V[++X]=[be,be]}),V}function bS(O,X,V){for(var be=V-1,Ue=O.length;++be<Ue;)if(O[be]===X)return be;return-1}function SS(O,X,V){for(var be=V+1;be--;)if(O[be]===X)return be;return be}function Ro(O){return Eo(O)?NS(O):sS(O)}function _n(O){return Eo(O)?CS(O):aS(O)}var wS=Xu(Yb);function NS(O){for(var X=ku.lastIndex=0;ku.test(O);)++X;return X}function CS(O){return O.match(ku)||[]}function LS(O){return O.match(Wb)||[]}var _S=function O(X){X=X==null?rr:Ti.defaults(rr.Object(),X,Ti.pick(rr,Jb));var V=X.Array,be=X.Date,Ue=X.Error,lt=X.Function,Kt=X.Math,yt=X.Object,tf=X.RegExp,TS=X.String,an=X.TypeError,il=V.prototype,IS=lt.prototype,zo=yt.prototype,ol=X["__core-js_shared__"],sl=IS.toString,pt=zo.hasOwnProperty,MS=0,gd=function(){var o=/[^.]+$/.exec(ol&&ol.keys&&ol.keys.IE_PROTO||"");return o?"Symbol(src)_1."+o:""}(),al=zo.toString,AS=sl.call(yt),OS=rr._,PS=tf("^"+sl.call(pt).replace(He,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$"),ll=td?X.Buffer:i,Ii=X.Symbol,cl=X.Uint8Array,yd=ll?ll.allocUnsafe:i,ul=md(yt.getPrototypeOf,yt),xd=yt.create,vd=zo.propertyIsEnumerable,fl=il.splice,bd=Ii?Ii.isConcatSpreadable:i,Us=Ii?Ii.iterator:i,so=Ii?Ii.toStringTag:i,hl=function(){try{var o=fo(yt,"defineProperty");return o({},"",{}),o}catch(a){}}(),DS=X.clearTimeout!==rr.clearTimeout&&X.clearTimeout,BS=be&&be.now!==rr.Date.now&&be.now,GS=X.setTimeout!==rr.setTimeout&&X.setTimeout,pl=Kt.ceil,dl=Kt.floor,rf=yt.getOwnPropertySymbols,jS=ll?ll.isBuffer:i,Sd=X.isFinite,ES=il.join,RS=md(yt.keys,yt),Xt=Kt.max,dr=Kt.min,zS=be.now,FS=X.parseInt,wd=Kt.random,VS=il.reverse,nf=fo(X,"DataView"),ks=fo(X,"Map"),of=fo(X,"Promise"),Fo=fo(X,"Set"),Hs=fo(X,"WeakMap"),Ws=fo(yt,"create"),ml=Hs&&new Hs,Vo={},US=ho(nf),kS=ho(ks),HS=ho(of),WS=ho(Fo),qS=ho(Hs),gl=Ii?Ii.prototype:i,qs=gl?gl.valueOf:i,Nd=gl?gl.toString:i;function y(o){if(Gt(o)&&!ke(o)&&!(o instanceof rt)){if(o instanceof ln)return o;if(pt.call(o,"__wrapped__"))return Cm(o)}return new ln(o)}var Uo=function(){function o(){}return function(a){if(!Dt(a))return{};if(xd)return xd(a);o.prototype=a;var u=new o;return o.prototype=i,u}}();function yl(){}function ln(o,a){this.__wrapped__=o,this.__actions__=[],this.__chain__=!!a,this.__index__=0,this.__values__=i}y.templateSettings={escape:io,evaluate:Jt,interpolate:ti,variable:"",imports:{_:y}},y.prototype=yl.prototype,y.prototype.constructor=y,ln.prototype=Uo(yl.prototype),ln.prototype.constructor=ln;function rt(o){this.__wrapped__=o,this.__actions__=[],this.__dir__=1,this.__filtered__=!1,this.__iteratees__=[],this.__takeCount__=Me,this.__views__=[]}function $S(){var o=new rt(this.__wrapped__);return o.__actions__=Or(this.__actions__),o.__dir__=this.__dir__,o.__filtered__=this.__filtered__,o.__iteratees__=Or(this.__iteratees__),o.__takeCount__=this.__takeCount__,o.__views__=Or(this.__views__),o}function JS(){if(this.__filtered__){var o=new rt(this);o.__dir__=-1,o.__filtered__=!0}else o=this.clone(),o.__dir__*=-1;return o}function KS(){var o=this.__wrapped__.value(),a=this.__dir__,u=ke(o),p=a<0,m=u?o.length:0,v=a1(0,m,this.__views__),N=v.start,L=v.end,I=L-N,Q=p?L:N-1,te=this.__iteratees__,ie=te.length,me=0,Le=dr(I,this.__takeCount__);if(!u||!p&&m==I&&Le==I)return $d(o,this.__actions__);var Re=[];e:for(;I--&&me<Le;){Q+=a;for(var Je=-1,je=o[Q];++Je<ie;){var et=te[Je],nt=et.iteratee,Jr=et.type,wr=nt(je);if(Jr==A)je=wr;else if(!wr){if(Jr==z)continue e;break e}}Re[me++]=je}return Re}rt.prototype=Uo(yl.prototype),rt.prototype.constructor=rt;function ao(o){var a=-1,u=o==null?0:o.length;for(this.clear();++a<u;){var p=o[a];this.set(p[0],p[1])}}function XS(){this.__data__=Ws?Ws(null):{},this.size=0}function ZS(o){var a=this.has(o)&&delete this.__data__[o];return this.size-=a?1:0,a}function YS(o){var a=this.__data__;if(Ws){var u=a[o];return u===s?i:u}return pt.call(a,o)?a[o]:i}function QS(o){var a=this.__data__;return Ws?a[o]!==i:pt.call(a,o)}function ew(o,a){var u=this.__data__;return this.size+=this.has(o)?0:1,u[o]=Ws&&a===i?s:a,this}ao.prototype.clear=XS,ao.prototype.delete=ZS,ao.prototype.get=YS,ao.prototype.has=QS,ao.prototype.set=ew;function ri(o){var a=-1,u=o==null?0:o.length;for(this.clear();++a<u;){var p=o[a];this.set(p[0],p[1])}}function tw(){this.__data__=[],this.size=0}function rw(o){var a=this.__data__,u=xl(a,o);if(u<0)return!1;var p=a.length-1;return u==p?a.pop():fl.call(a,u,1),--this.size,!0}function nw(o){var a=this.__data__,u=xl(a,o);return u<0?i:a[u][1]}function iw(o){return xl(this.__data__,o)>-1}function ow(o,a){var u=this.__data__,p=xl(u,o);return p<0?(++this.size,u.push([o,a])):u[p][1]=a,this}ri.prototype.clear=tw,ri.prototype.delete=rw,ri.prototype.get=nw,ri.prototype.has=iw,ri.prototype.set=ow;function ni(o){var a=-1,u=o==null?0:o.length;for(this.clear();++a<u;){var p=o[a];this.set(p[0],p[1])}}function sw(){this.size=0,this.__data__={hash:new ao,map:new(ks||ri),string:new ao}}function aw(o){var a=Al(this,o).delete(o);return this.size-=a?1:0,a}function lw(o){return Al(this,o).get(o)}function cw(o){return Al(this,o).has(o)}function uw(o,a){var u=Al(this,o),p=u.size;return u.set(o,a),this.size+=u.size==p?0:1,this}ni.prototype.clear=sw,ni.prototype.delete=aw,ni.prototype.get=lw,ni.prototype.has=cw,ni.prototype.set=uw;function lo(o){var a=-1,u=o==null?0:o.length;for(this.__data__=new ni;++a<u;)this.add(o[a])}function fw(o){return this.__data__.set(o,s),this}function hw(o){return this.__data__.has(o)}lo.prototype.add=lo.prototype.push=fw,lo.prototype.has=hw;function Tn(o){var a=this.__data__=new ri(o);this.size=a.size}function pw(){this.__data__=new ri,this.size=0}function dw(o){var a=this.__data__,u=a.delete(o);return this.size=a.size,u}function mw(o){return this.__data__.get(o)}function gw(o){return this.__data__.has(o)}function yw(o,a){var u=this.__data__;if(u instanceof ri){var p=u.__data__;if(!ks||p.length<t-1)return p.push([o,a]),this.size=++u.size,this;u=this.__data__=new ni(p)}return u.set(o,a),this.size=u.size,this}Tn.prototype.clear=pw,Tn.prototype.delete=dw,Tn.prototype.get=mw,Tn.prototype.has=gw,Tn.prototype.set=yw;function Cd(o,a){var u=ke(o),p=!u&&po(o),m=!u&&!p&&Di(o),v=!u&&!p&&!m&&qo(o),N=u||p||m||v,L=N?Yu(o.length,TS):[],I=L.length;for(var Q in o)(a||pt.call(o,Q))&&!(N&&(Q=="length"||m&&(Q=="offset"||Q=="parent")||v&&(Q=="buffer"||Q=="byteLength"||Q=="byteOffset")||ai(Q,I)))&&L.push(Q);return L}function Ld(o){var a=o.length;return a?o[gf(0,a-1)]:i}function xw(o,a){return Ol(Or(o),co(a,0,o.length))}function vw(o){return Ol(Or(o))}function sf(o,a,u){(u!==i&&!In(o[a],u)||u===i&&!(a in o))&&ii(o,a,u)}function $s(o,a,u){var p=o[a];(!(pt.call(o,a)&&In(p,u))||u===i&&!(a in o))&&ii(o,a,u)}function xl(o,a){for(var u=o.length;u--;)if(In(o[u][0],a))return u;return-1}function bw(o,a,u,p){return Mi(o,function(m,v,N){a(p,m,u(m),N)}),p}function _d(o,a){return o&&Fn(a,nr(a),o)}function Sw(o,a){return o&&Fn(a,Dr(a),o)}function ii(o,a,u){a=="__proto__"&&hl?hl(o,a,{configurable:!0,enumerable:!0,value:u,writable:!0}):o[a]=u}function af(o,a){for(var u=-1,p=a.length,m=V(p),v=o==null;++u<p;)m[u]=v?i:Vf(o,a[u]);return m}function co(o,a,u){return o===o&&(u!==i&&(o=o<=u?o:u),a!==i&&(o=o>=a?o:a)),o}function cn(o,a,u,p,m,v){var N,L=a&f,I=a&h,Q=a&d;if(u&&(N=m?u(o,p,m,v):u(o)),N!==i)return N;if(!Dt(o))return o;var te=ke(o);if(te){if(N=c1(o),!L)return Or(o,N)}else{var ie=mr(o),me=ie==K||ie==ae;if(Di(o))return Xd(o,L);if(ie==le||ie==_||me&&!m){if(N=I||me?{}:mm(o),!L)return I?Yw(o,Sw(N,o)):Zw(o,_d(N,o))}else{if(!wt[ie])return m?o:{};N=u1(o,ie,L)}}v||(v=new Tn);var Le=v.get(o);if(Le)return Le;v.set(o,N),Hm(o)?o.forEach(function(je){N.add(cn(je,a,u,je,o,v))}):Um(o)&&o.forEach(function(je,et){N.set(et,cn(je,a,u,et,o,v))});var Re=Q?I?Tf:_f:I?Dr:nr,Je=te?i:Re(o);return sn(Je||o,function(je,et){Je&&(et=je,je=o[et]),$s(N,et,cn(je,a,u,et,o,v))}),N}function ww(o){var a=nr(o);return function(u){return Td(u,o,a)}}function Td(o,a,u){var p=u.length;if(o==null)return!p;for(o=yt(o);p--;){var m=u[p],v=a[m],N=o[m];if(N===i&&!(m in o)||!v(N))return!1}return!0}function Id(o,a,u){if(typeof o!="function")throw new an(n);return ea(function(){o.apply(i,u)},a)}function Js(o,a,u,p){var m=-1,v=tl,N=!0,L=o.length,I=[],Q=a.length;if(!L)return I;u&&(a=Ot(a,Wr(u))),p?(v=qu,N=!1):a.length>=t&&(v=Vs,N=!1,a=new lo(a));e:for(;++m<L;){var te=o[m],ie=u==null?te:u(te);if(te=p||te!==0?te:0,N&&ie===ie){for(var me=Q;me--;)if(a[me]===ie)continue e;I.push(te)}else v(a,ie,p)||I.push(te)}return I}var Mi=tm(zn),Md=tm(cf,!0);function Nw(o,a){var u=!0;return Mi(o,function(p,m,v){return u=!!a(p,m,v),u}),u}function vl(o,a,u){for(var p=-1,m=o.length;++p<m;){var v=o[p],N=a(v);if(N!=null&&(L===i?N===N&&!$r(N):u(N,L)))var L=N,I=v}return I}function Cw(o,a,u,p){var m=o.length;for(u=We(u),u<0&&(u=-u>m?0:m+u),p=p===i||p>m?m:We(p),p<0&&(p+=m),p=u>p?0:qm(p);u<p;)o[u++]=a;return o}function Ad(o,a){var u=[];return Mi(o,function(p,m,v){a(p,m,v)&&u.push(p)}),u}function lr(o,a,u,p,m){var v=-1,N=o.length;for(u||(u=h1),m||(m=[]);++v<N;){var L=o[v];a>0&&u(L)?a>1?lr(L,a-1,u,p,m):Li(m,L):p||(m[m.length]=L)}return m}var lf=rm(),Od=rm(!0);function zn(o,a){return o&&lf(o,a,nr)}function cf(o,a){return o&&Od(o,a,nr)}function bl(o,a){return Ci(a,function(u){return li(o[u])})}function uo(o,a){a=Oi(a,o);for(var u=0,p=a.length;o!=null&&u<p;)o=o[Vn(a[u++])];return u&&u==p?o:i}function Pd(o,a,u){var p=a(o);return ke(o)?p:Li(p,u(o))}function br(o){return o==null?o===i?Ge:Y:so&&so in yt(o)?s1(o):v1(o)}function uf(o,a){return o>a}function Lw(o,a){return o!=null&&pt.call(o,a)}function _w(o,a){return o!=null&&a in yt(o)}function Tw(o,a,u){return o>=dr(a,u)&&o<Xt(a,u)}function ff(o,a,u){for(var p=u?qu:tl,m=o[0].length,v=o.length,N=v,L=V(v),I=1/0,Q=[];N--;){var te=o[N];N&&a&&(te=Ot(te,Wr(a))),I=dr(te.length,I),L[N]=!u&&(a||m>=120&&te.length>=120)?new lo(N&&te):i}te=o[0];var ie=-1,me=L[0];e:for(;++ie<m&&Q.length<I;){var Le=te[ie],Re=a?a(Le):Le;if(Le=u||Le!==0?Le:0,!(me?Vs(me,Re):p(Q,Re,u))){for(N=v;--N;){var Je=L[N];if(!(Je?Vs(Je,Re):p(o[N],Re,u)))continue e}me&&me.push(Re),Q.push(Le)}}return Q}function Iw(o,a,u,p){return zn(o,function(m,v,N){a(p,u(m),v,N)}),p}function Ks(o,a,u){a=Oi(a,o),o=vm(o,a);var p=o==null?o:o[Vn(fn(a))];return p==null?i:Hr(p,o,u)}function Dd(o){return Gt(o)&&br(o)==_}function Mw(o){return Gt(o)&&br(o)==Lt}function Aw(o){return Gt(o)&&br(o)==se}function Xs(o,a,u,p,m){return o===a?!0:o==null||a==null||!Gt(o)&&!Gt(a)?o!==o&&a!==a:Ow(o,a,u,p,Xs,m)}function Ow(o,a,u,p,m,v){var N=ke(o),L=ke(a),I=N?J:mr(o),Q=L?J:mr(a);I=I==_?le:I,Q=Q==_?le:Q;var te=I==le,ie=Q==le,me=I==Q;if(me&&Di(o)){if(!Di(a))return!1;N=!0,te=!1}if(me&&!te)return v||(v=new Tn),N||qo(o)?hm(o,a,u,p,m,v):i1(o,a,I,u,p,m,v);if(!(u&x)){var Le=te&&pt.call(o,"__wrapped__"),Re=ie&&pt.call(a,"__wrapped__");if(Le||Re){var Je=Le?o.value():o,je=Re?a.value():a;return v||(v=new Tn),m(Je,je,u,p,v)}}return me?(v||(v=new Tn),o1(o,a,u,p,m,v)):!1}function Pw(o){return Gt(o)&&mr(o)==ne}function hf(o,a,u,p){var m=u.length,v=m,N=!p;if(o==null)return!v;for(o=yt(o);m--;){var L=u[m];if(N&&L[2]?L[1]!==o[L[0]]:!(L[0]in o))return!1}for(;++m<v;){L=u[m];var I=L[0],Q=o[I],te=L[1];if(N&&L[2]){if(Q===i&&!(I in o))return!1}else{var ie=new Tn;if(p)var me=p(Q,te,I,o,a,ie);if(!(me===i?Xs(te,Q,x|g,p,ie):me))return!1}}return!0}function Bd(o){if(!Dt(o)||d1(o))return!1;var a=li(o)?PS:wb;return a.test(ho(o))}function Dw(o){return Gt(o)&&br(o)==_e}function Bw(o){return Gt(o)&&mr(o)==de}function Gw(o){return Gt(o)&&El(o.length)&&!!_t[br(o)]}function Gd(o){return typeof o=="function"?o:o==null?Br:typeof o=="object"?ke(o)?Rd(o[0],o[1]):Ed(o):ng(o)}function pf(o){if(!Qs(o))return RS(o);var a=[];for(var u in yt(o))pt.call(o,u)&&u!="constructor"&&a.push(u);return a}function jw(o){if(!Dt(o))return x1(o);var a=Qs(o),u=[];for(var p in o)p=="constructor"&&(a||!pt.call(o,p))||u.push(p);return u}function df(o,a){return o<a}function jd(o,a){var u=-1,p=Pr(o)?V(o.length):[];return Mi(o,function(m,v,N){p[++u]=a(m,v,N)}),p}function Ed(o){var a=Mf(o);return a.length==1&&a[0][2]?ym(a[0][0],a[0][1]):function(u){return u===o||hf(u,o,a)}}function Rd(o,a){return Of(o)&&gm(a)?ym(Vn(o),a):function(u){var p=Vf(u,o);return p===i&&p===a?Uf(u,o):Xs(a,p,x|g)}}function Sl(o,a,u,p,m){o!==a&&lf(a,function(v,N){if(m||(m=new Tn),Dt(v))Ew(o,a,N,u,Sl,p,m);else{var L=p?p(Df(o,N),v,N+"",o,a,m):i;L===i&&(L=v),sf(o,N,L)}},Dr)}function Ew(o,a,u,p,m,v,N){var L=Df(o,u),I=Df(a,u),Q=N.get(I);if(Q){sf(o,u,Q);return}var te=v?v(L,I,u+"",o,a,N):i,ie=te===i;if(ie){var me=ke(I),Le=!me&&Di(I),Re=!me&&!Le&&qo(I);te=I,me||Le||Re?ke(L)?te=L:zt(L)?te=Or(L):Le?(ie=!1,te=Xd(I,!0)):Re?(ie=!1,te=Zd(I,!0)):te=[]:ta(I)||po(I)?(te=L,po(L)?te=$m(L):(!Dt(L)||li(L))&&(te=mm(I))):ie=!1}ie&&(N.set(I,te),m(te,I,p,v,N),N.delete(I)),sf(o,u,te)}function zd(o,a){var u=o.length;if(!!u)return a+=a<0?u:0,ai(a,u)?o[a]:i}function Fd(o,a,u){a.length?a=Ot(a,function(v){return ke(v)?function(N){return uo(N,v.length===1?v[0]:v)}:v}):a=[Br];var p=-1;a=Ot(a,Wr(De()));var m=jd(o,function(v,N,L){var I=Ot(a,function(Q){return Q(v)});return{criteria:I,index:++p,value:v}});return uS(m,function(v,N){return Xw(v,N,u)})}function Rw(o,a){return Vd(o,a,function(u,p){return Uf(o,p)})}function Vd(o,a,u){for(var p=-1,m=a.length,v={};++p<m;){var N=a[p],L=uo(o,N);u(L,N)&&Zs(v,Oi(N,o),L)}return v}function zw(o){return function(a){return uo(a,o)}}function mf(o,a,u,p){var m=p?cS:jo,v=-1,N=a.length,L=o;for(o===a&&(a=Or(a)),u&&(L=Ot(o,Wr(u)));++v<N;)for(var I=0,Q=a[v],te=u?u(Q):Q;(I=m(L,te,I,p))>-1;)L!==o&&fl.call(L,I,1),fl.call(o,I,1);return o}function Ud(o,a){for(var u=o?a.length:0,p=u-1;u--;){var m=a[u];if(u==p||m!==v){var v=m;ai(m)?fl.call(o,m,1):vf(o,m)}}return o}function gf(o,a){return o+dl(wd()*(a-o+1))}function Fw(o,a,u,p){for(var m=-1,v=Xt(pl((a-o)/(u||1)),0),N=V(v);v--;)N[p?v:++m]=o,o+=u;return N}function yf(o,a){var u="";if(!o||a<1||a>re)return u;do a%2&&(u+=o),a=dl(a/2),a&&(o+=o);while(a);return u}function Ze(o,a){return Bf(xm(o,a,Br),o+"")}function Vw(o){return Ld($o(o))}function Uw(o,a){var u=$o(o);return Ol(u,co(a,0,u.length))}function Zs(o,a,u,p){if(!Dt(o))return o;a=Oi(a,o);for(var m=-1,v=a.length,N=v-1,L=o;L!=null&&++m<v;){var I=Vn(a[m]),Q=u;if(I==="__proto__"||I==="constructor"||I==="prototype")return o;if(m!=N){var te=L[I];Q=p?p(te,I,L):i,Q===i&&(Q=Dt(te)?te:ai(a[m+1])?[]:{})}$s(L,I,Q),L=L[I]}return o}var kd=ml?function(o,a){return ml.set(o,a),o}:Br,kw=hl?function(o,a){return hl(o,"toString",{configurable:!0,enumerable:!1,value:Hf(a),writable:!0})}:Br;function Hw(o){return Ol($o(o))}function un(o,a,u){var p=-1,m=o.length;a<0&&(a=-a>m?0:m+a),u=u>m?m:u,u<0&&(u+=m),m=a>u?0:u-a>>>0,a>>>=0;for(var v=V(m);++p<m;)v[p]=o[p+a];return v}function Ww(o,a){var u;return Mi(o,function(p,m,v){return u=a(p,m,v),!u}),!!u}function wl(o,a,u){var p=0,m=o==null?p:o.length;if(typeof a=="number"&&a===a&&m<=k){for(;p<m;){var v=p+m>>>1,N=o[v];N!==null&&!$r(N)&&(u?N<=a:N<a)?p=v+1:m=v}return m}return xf(o,a,Br,u)}function xf(o,a,u,p){var m=0,v=o==null?0:o.length;if(v===0)return 0;a=u(a);for(var N=a!==a,L=a===null,I=$r(a),Q=a===i;m<v;){var te=dl((m+v)/2),ie=u(o[te]),me=ie!==i,Le=ie===null,Re=ie===ie,Je=$r(ie);if(N)var je=p||Re;else Q?je=Re&&(p||me):L?je=Re&&me&&(p||!Le):I?je=Re&&me&&!Le&&(p||!Je):Le||Je?je=!1:je=p?ie<=a:ie<a;je?m=te+1:v=te}return dr(v,Fe)}function Hd(o,a){for(var u=-1,p=o.length,m=0,v=[];++u<p;){var N=o[u],L=a?a(N):N;if(!u||!In(L,I)){var I=L;v[m++]=N===0?0:N}}return v}function Wd(o){return typeof o=="number"?o:$r(o)?ye:+o}function qr(o){if(typeof o=="string")return o;if(ke(o))return Ot(o,qr)+"";if($r(o))return Nd?Nd.call(o):"";var a=o+"";return a=="0"&&1/o==-he?"-0":a}function Ai(o,a,u){var p=-1,m=tl,v=o.length,N=!0,L=[],I=L;if(u)N=!1,m=qu;else if(v>=t){var Q=a?null:r1(o);if(Q)return nl(Q);N=!1,m=Vs,I=new lo}else I=a?[]:L;e:for(;++p<v;){var te=o[p],ie=a?a(te):te;if(te=u||te!==0?te:0,N&&ie===ie){for(var me=I.length;me--;)if(I[me]===ie)continue e;a&&I.push(ie),L.push(te)}else m(I,ie,u)||(I!==L&&I.push(ie),L.push(te))}return L}function vf(o,a){return a=Oi(a,o),o=vm(o,a),o==null||delete o[Vn(fn(a))]}function qd(o,a,u,p){return Zs(o,a,u(uo(o,a)),p)}function Nl(o,a,u,p){for(var m=o.length,v=p?m:-1;(p?v--:++v<m)&&a(o[v],v,o););return u?un(o,p?0:v,p?v+1:m):un(o,p?v+1:0,p?m:v)}function $d(o,a){var u=o;return u instanceof rt&&(u=u.value()),$u(a,function(p,m){return m.func.apply(m.thisArg,Li([p],m.args))},u)}function bf(o,a,u){var p=o.length;if(p<2)return p?Ai(o[0]):[];for(var m=-1,v=V(p);++m<p;)for(var N=o[m],L=-1;++L<p;)L!=m&&(v[m]=Js(v[m]||N,o[L],a,u));return Ai(lr(v,1),a,u)}function Jd(o,a,u){for(var p=-1,m=o.length,v=a.length,N={};++p<m;){var L=p<v?a[p]:i;u(N,o[p],L)}return N}function Sf(o){return zt(o)?o:[]}function wf(o){return typeof o=="function"?o:Br}function Oi(o,a){return ke(o)?o:Of(o,a)?[o]:Nm(ut(o))}var qw=Ze;function Pi(o,a,u){var p=o.length;return u=u===i?p:u,!a&&u>=p?o:un(o,a,u)}var Kd=DS||function(o){return rr.clearTimeout(o)};function Xd(o,a){if(a)return o.slice();var u=o.length,p=yd?yd(u):new o.constructor(u);return o.copy(p),p}function Nf(o){var a=new o.constructor(o.byteLength);return new cl(a).set(new cl(o)),a}function $w(o,a){var u=a?Nf(o.buffer):o.buffer;return new o.constructor(u,o.byteOffset,o.byteLength)}function Jw(o){var a=new o.constructor(o.source,Ln.exec(o));return a.lastIndex=o.lastIndex,a}function Kw(o){return qs?yt(qs.call(o)):{}}function Zd(o,a){var u=a?Nf(o.buffer):o.buffer;return new o.constructor(u,o.byteOffset,o.length)}function Yd(o,a){if(o!==a){var u=o!==i,p=o===null,m=o===o,v=$r(o),N=a!==i,L=a===null,I=a===a,Q=$r(a);if(!L&&!Q&&!v&&o>a||v&&N&&I&&!L&&!Q||p&&N&&I||!u&&I||!m)return 1;if(!p&&!v&&!Q&&o<a||Q&&u&&m&&!p&&!v||L&&u&&m||!N&&m||!I)return-1}return 0}function Xw(o,a,u){for(var p=-1,m=o.criteria,v=a.criteria,N=m.length,L=u.length;++p<N;){var I=Yd(m[p],v[p]);if(I){if(p>=L)return I;var Q=u[p];return I*(Q=="desc"?-1:1)}}return o.index-a.index}function Qd(o,a,u,p){for(var m=-1,v=o.length,N=u.length,L=-1,I=a.length,Q=Xt(v-N,0),te=V(I+Q),ie=!p;++L<I;)te[L]=a[L];for(;++m<N;)(ie||m<v)&&(te[u[m]]=o[m]);for(;Q--;)te[L++]=o[m++];return te}function em(o,a,u,p){for(var m=-1,v=o.length,N=-1,L=u.length,I=-1,Q=a.length,te=Xt(v-L,0),ie=V(te+Q),me=!p;++m<te;)ie[m]=o[m];for(var Le=m;++I<Q;)ie[Le+I]=a[I];for(;++N<L;)(me||m<v)&&(ie[Le+u[N]]=o[m++]);return ie}function Or(o,a){var u=-1,p=o.length;for(a||(a=V(p));++u<p;)a[u]=o[u];return a}function Fn(o,a,u,p){var m=!u;u||(u={});for(var v=-1,N=a.length;++v<N;){var L=a[v],I=p?p(u[L],o[L],L,u,o):i;I===i&&(I=o[L]),m?ii(u,L,I):$s(u,L,I)}return u}function Zw(o,a){return Fn(o,Af(o),a)}function Yw(o,a){return Fn(o,pm(o),a)}function Cl(o,a){return function(u,p){var m=ke(u)?nS:bw,v=a?a():{};return m(u,o,De(p,2),v)}}function ko(o){return Ze(function(a,u){var p=-1,m=u.length,v=m>1?u[m-1]:i,N=m>2?u[2]:i;for(v=o.length>3&&typeof v=="function"?(m--,v):i,N&&Sr(u[0],u[1],N)&&(v=m<3?i:v,m=1),a=yt(a);++p<m;){var L=u[p];L&&o(a,L,p,v)}return a})}function tm(o,a){return function(u,p){if(u==null)return u;if(!Pr(u))return o(u,p);for(var m=u.length,v=a?m:-1,N=yt(u);(a?v--:++v<m)&&p(N[v],v,N)!==!1;);return u}}function rm(o){return function(a,u,p){for(var m=-1,v=yt(a),N=p(a),L=N.length;L--;){var I=N[o?L:++m];if(u(v[I],I,v)===!1)break}return a}}function Qw(o,a,u){var p=a&w,m=Ys(o);function v(){var N=this&&this!==rr&&this instanceof v?m:o;return N.apply(p?u:this,arguments)}return v}function nm(o){return function(a){a=ut(a);var u=Eo(a)?_n(a):i,p=u?u[0]:a.charAt(0),m=u?Pi(u,1).join(""):a.slice(1);return p[o]()+m}}function Ho(o){return function(a){return $u(tg(eg(a).replace(kb,"")),o,"")}}function Ys(o){return function(){var a=arguments;switch(a.length){case 0:return new o;case 1:return new o(a[0]);case 2:return new o(a[0],a[1]);case 3:return new o(a[0],a[1],a[2]);case 4:return new o(a[0],a[1],a[2],a[3]);case 5:return new o(a[0],a[1],a[2],a[3],a[4]);case 6:return new o(a[0],a[1],a[2],a[3],a[4],a[5]);case 7:return new o(a[0],a[1],a[2],a[3],a[4],a[5],a[6])}var u=Uo(o.prototype),p=o.apply(u,a);return Dt(p)?p:u}}function e1(o,a,u){var p=Ys(o);function m(){for(var v=arguments.length,N=V(v),L=v,I=Wo(m);L--;)N[L]=arguments[L];var Q=v<3&&N[0]!==I&&N[v-1]!==I?[]:_i(N,I);if(v-=Q.length,v<u)return lm(o,a,Ll,m.placeholder,i,N,Q,i,i,u-v);var te=this&&this!==rr&&this instanceof m?p:o;return Hr(te,this,N)}return m}function im(o){return function(a,u,p){var m=yt(a);if(!Pr(a)){var v=De(u,3);a=nr(a),u=function(L){return v(m[L],L,m)}}var N=o(a,u,p);return N>-1?m[v?a[N]:N]:i}}function om(o){return si(function(a){var u=a.length,p=u,m=ln.prototype.thru;for(o&&a.reverse();p--;){var v=a[p];if(typeof v!="function")throw new an(n);if(m&&!N&&Ml(v)=="wrapper")var N=new ln([],!0)}for(p=N?p:u;++p<u;){v=a[p];var L=Ml(v),I=L=="wrapper"?If(v):i;I&&Pf(I[0])&&I[1]==(W|C|B|M)&&!I[4].length&&I[9]==1?N=N[Ml(I[0])].apply(N,I[3]):N=v.length==1&&Pf(v)?N[L]():N.thru(v)}return function(){var Q=arguments,te=Q[0];if(N&&Q.length==1&&ke(te))return N.plant(te).value();for(var ie=0,me=u?a[ie].apply(this,Q):te;++ie<u;)me=a[ie].call(this,me);return me}})}function Ll(o,a,u,p,m,v,N,L,I,Q){var te=a&W,ie=a&w,me=a&S,Le=a&(C|G),Re=a&q,Je=me?i:Ys(o);function je(){for(var et=arguments.length,nt=V(et),Jr=et;Jr--;)nt[Jr]=arguments[Jr];if(Le)var wr=Wo(je),Kr=hS(nt,wr);if(p&&(nt=Qd(nt,p,m,Le)),v&&(nt=em(nt,v,N,Le)),et-=Kr,Le&&et<Q){var Ft=_i(nt,wr);return lm(o,a,Ll,je.placeholder,u,nt,Ft,L,I,Q-et)}var Mn=ie?u:this,ui=me?Mn[o]:o;return et=nt.length,L?nt=b1(nt,L):Re&&et>1&&nt.reverse(),te&&I<et&&(nt.length=I),this&&this!==rr&&this instanceof je&&(ui=Je||Ys(ui)),ui.apply(Mn,nt)}return je}function sm(o,a){return function(u,p){return Iw(u,o,a(p),{})}}function _l(o,a){return function(u,p){var m;if(u===i&&p===i)return a;if(u!==i&&(m=u),p!==i){if(m===i)return p;typeof u=="string"||typeof p=="string"?(u=qr(u),p=qr(p)):(u=Wd(u),p=Wd(p)),m=o(u,p)}return m}}function Cf(o){return si(function(a){return a=Ot(a,Wr(De())),Ze(function(u){var p=this;return o(a,function(m){return Hr(m,p,u)})})})}function Tl(o,a){a=a===i?" ":qr(a);var u=a.length;if(u<2)return u?yf(a,o):a;var p=yf(a,pl(o/Ro(a)));return Eo(a)?Pi(_n(p),0,o).join(""):p.slice(0,o)}function t1(o,a,u,p){var m=a&w,v=Ys(o);function N(){for(var L=-1,I=arguments.length,Q=-1,te=p.length,ie=V(te+I),me=this&&this!==rr&&this instanceof N?v:o;++Q<te;)ie[Q]=p[Q];for(;I--;)ie[Q++]=arguments[++L];return Hr(me,m?u:this,ie)}return N}function am(o){return function(a,u,p){return p&&typeof p!="number"&&Sr(a,u,p)&&(u=p=i),a=ci(a),u===i?(u=a,a=0):u=ci(u),p=p===i?a<u?1:-1:ci(p),Fw(a,u,p,o)}}function Il(o){return function(a,u){return typeof a=="string"&&typeof u=="string"||(a=hn(a),u=hn(u)),o(a,u)}}function lm(o,a,u,p,m,v,N,L,I,Q){var te=a&C,ie=te?N:i,me=te?i:N,Le=te?v:i,Re=te?i:v;a|=te?B:P,a&=~(te?P:B),a&D||(a&=~(w|S));var Je=[o,a,m,Le,ie,Re,me,L,I,Q],je=u.apply(i,Je);return Pf(o)&&bm(je,Je),je.placeholder=p,Sm(je,o,a)}function Lf(o){var a=Kt[o];return function(u,p){if(u=hn(u),p=p==null?0:dr(We(p),292),p&&Sd(u)){var m=(ut(u)+"e").split("e"),v=a(m[0]+"e"+(+m[1]+p));return m=(ut(v)+"e").split("e"),+(m[0]+"e"+(+m[1]-p))}return a(u)}}var r1=Fo&&1/nl(new Fo([,-0]))[1]==he?function(o){return new Fo(o)}:$f;function cm(o){return function(a){var u=mr(a);return u==ne?ef(a):u==de?vS(a):fS(a,o(a))}}function oi(o,a,u,p,m,v,N,L){var I=a&S;if(!I&&typeof o!="function")throw new an(n);var Q=p?p.length:0;if(Q||(a&=~(B|P),p=m=i),N=N===i?N:Xt(We(N),0),L=L===i?L:We(L),Q-=m?m.length:0,a&P){var te=p,ie=m;p=m=i}var me=I?i:If(o),Le=[o,a,u,p,m,te,ie,v,N,L];if(me&&y1(Le,me),o=Le[0],a=Le[1],u=Le[2],p=Le[3],m=Le[4],L=Le[9]=Le[9]===i?I?0:o.length:Xt(Le[9]-Q,0),!L&&a&(C|G)&&(a&=~(C|G)),!a||a==w)var Re=Qw(o,a,u);else a==C||a==G?Re=e1(o,a,L):(a==B||a==(w|B))&&!m.length?Re=t1(o,a,u,p):Re=Ll.apply(i,Le);var Je=me?kd:bm;return Sm(Je(Re,Le),o,a)}function um(o,a,u,p){return o===i||In(o,zo[u])&&!pt.call(p,u)?a:o}function fm(o,a,u,p,m,v){return Dt(o)&&Dt(a)&&(v.set(a,o),Sl(o,a,i,fm,v),v.delete(a)),o}function n1(o){return ta(o)?i:o}function hm(o,a,u,p,m,v){var N=u&x,L=o.length,I=a.length;if(L!=I&&!(N&&I>L))return!1;var Q=v.get(o),te=v.get(a);if(Q&&te)return Q==a&&te==o;var ie=-1,me=!0,Le=u&g?new lo:i;for(v.set(o,a),v.set(a,o);++ie<L;){var Re=o[ie],Je=a[ie];if(p)var je=N?p(Je,Re,ie,a,o,v):p(Re,Je,ie,o,a,v);if(je!==i){if(je)continue;me=!1;break}if(Le){if(!Ju(a,function(et,nt){if(!Vs(Le,nt)&&(Re===et||m(Re,et,u,p,v)))return Le.push(nt)})){me=!1;break}}else if(!(Re===Je||m(Re,Je,u,p,v))){me=!1;break}}return v.delete(o),v.delete(a),me}function i1(o,a,u,p,m,v,N){switch(u){case At:if(o.byteLength!=a.byteLength||o.byteOffset!=a.byteOffset)return!1;o=o.buffer,a=a.buffer;case Lt:return!(o.byteLength!=a.byteLength||!v(new cl(o),new cl(a)));case oe:case se:case Ce:return In(+o,+a);case ue:return o.name==a.name&&o.message==a.message;case _e:case we:return o==a+"";case ne:var L=ef;case de:var I=p&x;if(L||(L=nl),o.size!=a.size&&!I)return!1;var Q=N.get(o);if(Q)return Q==a;p|=g,N.set(o,a);var te=hm(L(o),L(a),p,m,v,N);return N.delete(o),te;case Ve:if(qs)return qs.call(o)==qs.call(a)}return!1}function o1(o,a,u,p,m,v){var N=u&x,L=_f(o),I=L.length,Q=_f(a),te=Q.length;if(I!=te&&!N)return!1;for(var ie=I;ie--;){var me=L[ie];if(!(N?me in a:pt.call(a,me)))return!1}var Le=v.get(o),Re=v.get(a);if(Le&&Re)return Le==a&&Re==o;var Je=!0;v.set(o,a),v.set(a,o);for(var je=N;++ie<I;){me=L[ie];var et=o[me],nt=a[me];if(p)var Jr=N?p(nt,et,me,a,o,v):p(et,nt,me,o,a,v);if(!(Jr===i?et===nt||m(et,nt,u,p,v):Jr)){Je=!1;break}je||(je=me=="constructor")}if(Je&&!je){var wr=o.constructor,Kr=a.constructor;wr!=Kr&&"constructor"in o&&"constructor"in a&&!(typeof wr=="function"&&wr instanceof wr&&typeof Kr=="function"&&Kr instanceof Kr)&&(Je=!1)}return v.delete(o),v.delete(a),Je}function si(o){return Bf(xm(o,i,Tm),o+"")}function _f(o){return Pd(o,nr,Af)}function Tf(o){return Pd(o,Dr,pm)}var If=ml?function(o){return ml.get(o)}:$f;function Ml(o){for(var a=o.name+"",u=Vo[a],p=pt.call(Vo,a)?u.length:0;p--;){var m=u[p],v=m.func;if(v==null||v==o)return m.name}return a}function Wo(o){var a=pt.call(y,"placeholder")?y:o;return a.placeholder}function De(){var o=y.iteratee||Wf;return o=o===Wf?Gd:o,arguments.length?o(arguments[0],arguments[1]):o}function Al(o,a){var u=o.__data__;return p1(a)?u[typeof a=="string"?"string":"hash"]:u.map}function Mf(o){for(var a=nr(o),u=a.length;u--;){var p=a[u],m=o[p];a[u]=[p,m,gm(m)]}return a}function fo(o,a){var u=gS(o,a);return Bd(u)?u:i}function s1(o){var a=pt.call(o,so),u=o[so];try{o[so]=i;var p=!0}catch(v){}var m=al.call(o);return p&&(a?o[so]=u:delete o[so]),m}var Af=rf?function(o){return o==null?[]:(o=yt(o),Ci(rf(o),function(a){return vd.call(o,a)}))}:Jf,pm=rf?function(o){for(var a=[];o;)Li(a,Af(o)),o=ul(o);return a}:Jf,mr=br;(nf&&mr(new nf(new ArrayBuffer(1)))!=At||ks&&mr(new ks)!=ne||of&&mr(of.resolve())!=pe||Fo&&mr(new Fo)!=de||Hs&&mr(new Hs)!=Qe)&&(mr=function(o){var a=br(o),u=a==le?o.constructor:i,p=u?ho(u):"";if(p)switch(p){case US:return At;case kS:return ne;case HS:return pe;case WS:return de;case qS:return Qe}return a});function a1(o,a,u){for(var p=-1,m=u.length;++p<m;){var v=u[p],N=v.size;switch(v.type){case"drop":o+=N;break;case"dropRight":a-=N;break;case"take":a=dr(a,o+N);break;case"takeRight":o=Xt(o,a-N);break}}return{start:o,end:a}}function l1(o){var a=o.match(ct);return a?a[1].split(St):[]}function dm(o,a,u){a=Oi(a,o);for(var p=-1,m=a.length,v=!1;++p<m;){var N=Vn(a[p]);if(!(v=o!=null&&u(o,N)))break;o=o[N]}return v||++p!=m?v:(m=o==null?0:o.length,!!m&&El(m)&&ai(N,m)&&(ke(o)||po(o)))}function c1(o){var a=o.length,u=new o.constructor(a);return a&&typeof o[0]=="string"&&pt.call(o,"index")&&(u.index=o.index,u.input=o.input),u}function mm(o){return typeof o.constructor=="function"&&!Qs(o)?Uo(ul(o)):{}}function u1(o,a,u){var p=o.constructor;switch(a){case Lt:return Nf(o);case oe:case se:return new p(+o);case At:return $w(o,u);case sr:case Ur:case Ht:case kr:case wn:case Nn:case dt:case Wt:case ar:return Zd(o,u);case ne:return new p;case Ce:case we:return new p(o);case _e:return Jw(o);case de:return new p;case Ve:return Kw(o)}}function f1(o,a){var u=a.length;if(!u)return o;var p=u-1;return a[p]=(u>1?"& ":"")+a[p],a=a.join(u>2?", ":" "),o.replace(gt,`{
|
|
2
2
|
/* [wrapped with `+a+`] */
|
|
3
|
-
`)}function _1(o){return ke(o)||mo(o)||!!(Ip&&o&&o[Ip])}function ci(o,a){var u=typeof o;return a=a==null?re:a,!!a&&(u=="number"||u!="symbol"&&Rb.test(o))&&o>-1&&o%1==0&&o<a}function Sr(o,a,u){if(!Dt(u))return!1;var d=typeof a;return(d=="number"?Pr(u)&&ci(a,u.length):d=="string"&&a in u)?Mn(u[a],o):!1}function jf(o,a){if(ke(o))return!1;var u=typeof o;return u=="number"||u=="symbol"||u=="boolean"||o==null||$r(o)?!0:Ee.test(o)||!Eo.test(o)||a!=null&&o in yt(a)}function T1(o){var a=typeof o;return a=="string"||a=="number"||a=="symbol"||a=="boolean"?o!=="__proto__":o===null}function Ef(o){var a=Ol(o),u=x[a];if(typeof u!="function"||!(a in rt.prototype))return!1;if(o===u)return!0;var d=Df(u);return!!d&&o===d[0]}function I1(o){return!!Cp&&Cp in o}var M1=al?ui:eh;function na(o){var a=o&&o.constructor,u=typeof a=="function"&&a.prototype||Uo;return o===u}function Cm(o){return o===o&&!Dt(o)}function Lm(o,a){return function(u){return u==null?!1:u[o]===a&&(a!==i||o in yt(u))}}function A1(o){var a=El(o,function(d){return u.size===l&&u.clear(),d}),u=a.cache;return a}function O1(o,a){var u=o[1],d=a[1],m=u|d,v=m<(w|S|W),N=d==W&&u==C||d==W&&u==A&&o[7].length<=a[8]||d==(W|A)&&a[7].length<=a[8]&&u==C;if(!(v||N))return o;d&w&&(o[2]=a[2],m|=u&w?0:T);var L=a[3];if(L){var M=o[3];o[3]=M?am(M,L,a[4]):L,o[4]=M?Ii(o[3],c):a[4]}return L=a[5],L&&(M=o[5],o[5]=M?lm(M,L,a[6]):L,o[6]=M?Ii(o[5],c):a[6]),L=a[7],L&&(o[7]=L),d&W&&(o[8]=o[8]==null?a[8]:pr(o[8],a[8])),o[9]==null&&(o[9]=a[9]),o[0]=a[0],o[1]=m,o}function P1(o){var a=[];if(o!=null)for(var u in yt(o))a.push(u);return a}function D1(o){return cl.call(o)}function _m(o,a,u){return a=Xt(a===i?o.length-1:a,0),function(){for(var d=arguments,m=-1,v=Xt(d.length-a,0),N=V(v);++m<v;)N[m]=d[a+m];m=-1;for(var L=V(a+1);++m<a;)L[m]=d[m];return L[a]=u(N),Hr(o,this,L)}}function Tm(o,a){return a.length<2?o:fo(o,un(a,0,-1))}function B1(o,a){for(var u=o.length,d=pr(a.length,u),m=Or(o);d--;){var v=a[d];o[d]=ci(v,u)?m[v]:i}return o}function Rf(o,a){if(!(a==="constructor"&&typeof o[a]=="function")&&a!="__proto__")return o[a]}var Im=Am(Zp),ia=KS||function(o,a){return rr.setTimeout(o,a)},zf=Am(n1);function Mm(o,a,u){var d=a+"";return zf(o,L1(d,G1(w1(d),u)))}function Am(o){var a=0,u=0;return function(){var d=QS(),m=I-(d-u);if(u=d,m>0){if(++a>=R)return arguments[0]}else a=0;return o.apply(i,arguments)}}function Dl(o,a){var u=-1,d=o.length,m=d-1;for(a=a===i?d:a;++u<a;){var v=Sf(u,m),N=o[v];o[v]=o[u],o[u]=N}return o.length=a,o}var Om=A1(function(o){var a=[];return o.charCodeAt(0)===46&&a.push(""),o.replace(Xe,function(u,d,m,v){a.push(m?v.replace(Ar,"$1"):d||u)}),a});function Un(o){if(typeof o=="string"||$r(o))return o;var a=o+"";return a=="0"&&1/o==-he?"-0":a}function po(o){if(o!=null){try{return ll.call(o)}catch(a){}try{return o+""}catch(a){}}return""}function G1(o,a){return sn(H,function(u){var d="_."+u[0];a&u[1]&&!nl(o,d)&&o.push(d)}),o.sort()}function Pm(o){if(o instanceof rt)return o.clone();var a=new ln(o.__wrapped__,o.__chain__);return a.__actions__=Or(o.__actions__),a.__index__=o.__index__,a.__values__=o.__values__,a}function j1(o,a,u){(u?Sr(o,a,u):a===i)?a=1:a=Xt(We(a),0);var d=o==null?0:o.length;if(!d||a<1)return[];for(var m=0,v=0,N=V(ml(d/a));m<d;)N[v++]=un(o,m,m+=a);return N}function E1(o){for(var a=-1,u=o==null?0:o.length,d=0,m=[];++a<u;){var v=o[a];v&&(m[d++]=v)}return m}function R1(){var o=arguments.length;if(!o)return[];for(var a=V(o-1),u=arguments[0],d=o;d--;)a[d-1]=arguments[d];return Ti(ke(u)?Or(u):[u],lr(a,1))}var z1=Ze(function(o,a){return zt(o)?Ys(o,lr(a,1,zt,!0)):[]}),F1=Ze(function(o,a){var u=fn(a);return zt(u)&&(u=i),zt(o)?Ys(o,lr(a,1,zt,!0),De(u,2)):[]}),V1=Ze(function(o,a){var u=fn(a);return zt(u)&&(u=i),zt(o)?Ys(o,lr(a,1,zt,!0),i,u):[]});function U1(o,a,u){var d=o==null?0:o.length;return d?(a=u||a===i?1:We(a),un(o,a<0?0:a,d)):[]}function k1(o,a,u){var d=o==null?0:o.length;return d?(a=u||a===i?1:We(a),a=d-a,un(o,0,a<0?0:a)):[]}function H1(o,a){return o&&o.length?Ll(o,De(a,3),!0,!0):[]}function W1(o,a){return o&&o.length?Ll(o,De(a,3),!0):[]}function q1(o,a,u,d){var m=o==null?0:o.length;return m?(u&&typeof u!="number"&&Sr(o,a,u)&&(u=0,d=m),Rw(o,a,u,d)):[]}function Dm(o,a,u){var d=o==null?0:o.length;if(!d)return-1;var m=u==null?0:We(u);return m<0&&(m=Xt(d+m,0)),il(o,De(a,3),m)}function Bm(o,a,u){var d=o==null?0:o.length;if(!d)return-1;var m=d-1;return u!==i&&(m=We(u),m=u<0?Xt(d+m,0):pr(m,d-1)),il(o,De(a,3),m,!0)}function Gm(o){var a=o==null?0:o.length;return a?lr(o,1):[]}function $1(o){var a=o==null?0:o.length;return a?lr(o,he):[]}function J1(o,a){var u=o==null?0:o.length;return u?(a=a===i?1:We(a),lr(o,a)):[]}function K1(o){for(var a=-1,u=o==null?0:o.length,d={};++a<u;){var m=o[a];d[m[0]]=m[1]}return d}function jm(o){return o&&o.length?o[0]:i}function X1(o,a,u){var d=o==null?0:o.length;if(!d)return-1;var m=u==null?0:We(u);return m<0&&(m=Xt(d+m,0)),zo(o,a,m)}function Z1(o){var a=o==null?0:o.length;return a?un(o,0,-1):[]}var Y1=Ze(function(o){var a=Ot(o,_f);return a.length&&a[0]===o[0]?gf(a):[]}),Q1=Ze(function(o){var a=fn(o),u=Ot(o,_f);return a===fn(u)?a=i:u.pop(),u.length&&u[0]===o[0]?gf(u,De(a,2)):[]}),eN=Ze(function(o){var a=fn(o),u=Ot(o,_f);return a=typeof a=="function"?a:i,a&&u.pop(),u.length&&u[0]===o[0]?gf(u,i,a):[]});function tN(o,a){return o==null?"":ZS.call(o,a)}function fn(o){var a=o==null?0:o.length;return a?o[a-1]:i}function rN(o,a,u){var d=o==null?0:o.length;if(!d)return-1;var m=d;return u!==i&&(m=We(u),m=m<0?Xt(d+m,0):pr(m,d-1)),a===a?GS(o,a,m):il(o,xp,m,!0)}function nN(o,a){return o&&o.length?$p(o,We(a)):i}var iN=Ze(Em);function Em(o,a){return o&&o.length&&a&&a.length?bf(o,a):o}function oN(o,a,u){return o&&o.length&&a&&a.length?bf(o,a,De(u,2)):o}function sN(o,a,u){return o&&o.length&&a&&a.length?bf(o,a,i,u):o}var aN=li(function(o,a){var u=o==null?0:o.length,d=hf(o,a);return Xp(o,Ot(a,function(m){return ci(m,u)?+m:m}).sort(sm)),d});function lN(o,a){var u=[];if(!(o&&o.length))return u;var d=-1,m=[],v=o.length;for(a=De(a,3);++d<v;){var N=o[d];a(N,d,o)&&(u.push(N),m.push(d))}return Xp(o,m),u}function Ff(o){return o==null?o:tw.call(o)}function cN(o,a,u){var d=o==null?0:o.length;return d?(u&&typeof u!="number"&&Sr(o,a,u)?(a=0,u=d):(a=a==null?0:We(a),u=u===i?d:We(u)),un(o,a,u)):[]}function uN(o,a){return Cl(o,a)}function fN(o,a,u){return Nf(o,a,De(u,2))}function hN(o,a){var u=o==null?0:o.length;if(u){var d=Cl(o,a);if(d<u&&Mn(o[d],a))return d}return-1}function dN(o,a){return Cl(o,a,!0)}function pN(o,a,u){return Nf(o,a,De(u,2),!0)}function mN(o,a){var u=o==null?0:o.length;if(u){var d=Cl(o,a,!0)-1;if(Mn(o[d],a))return d}return-1}function gN(o){return o&&o.length?Yp(o):[]}function yN(o,a){return o&&o.length?Yp(o,De(a,2)):[]}function xN(o){var a=o==null?0:o.length;return a?un(o,1,a):[]}function vN(o,a,u){return o&&o.length?(a=u||a===i?1:We(a),un(o,0,a<0?0:a)):[]}function bN(o,a,u){var d=o==null?0:o.length;return d?(a=u||a===i?1:We(a),a=d-a,un(o,a<0?0:a,d)):[]}function SN(o,a){return o&&o.length?Ll(o,De(a,3),!1,!0):[]}function wN(o,a){return o&&o.length?Ll(o,De(a,3)):[]}var NN=Ze(function(o){return Pi(lr(o,1,zt,!0))}),CN=Ze(function(o){var a=fn(o);return zt(a)&&(a=i),Pi(lr(o,1,zt,!0),De(a,2))}),LN=Ze(function(o){var a=fn(o);return a=typeof a=="function"?a:i,Pi(lr(o,1,zt,!0),i,a)});function _N(o){return o&&o.length?Pi(o):[]}function TN(o,a){return o&&o.length?Pi(o,De(a,2)):[]}function IN(o,a){return a=typeof a=="function"?a:i,o&&o.length?Pi(o,i,a):[]}function Vf(o){if(!(o&&o.length))return[];var a=0;return o=_i(o,function(u){if(zt(u))return a=Xt(u.length,a),!0}),nf(a,function(u){return Ot(o,ef(u))})}function Rm(o,a){if(!(o&&o.length))return[];var u=Vf(o);return a==null?u:Ot(u,function(d){return Hr(a,i,d)})}var MN=Ze(function(o,a){return zt(o)?Ys(o,a):[]}),AN=Ze(function(o){return Lf(_i(o,zt))}),ON=Ze(function(o){var a=fn(o);return zt(a)&&(a=i),Lf(_i(o,zt),De(a,2))}),PN=Ze(function(o){var a=fn(o);return a=typeof a=="function"?a:i,Lf(_i(o,zt),i,a)}),DN=Ze(Vf);function BN(o,a){return rm(o||[],a||[],Zs)}function GN(o,a){return rm(o||[],a||[],ta)}var jN=Ze(function(o){var a=o.length,u=a>1?o[a-1]:i;return u=typeof u=="function"?(o.pop(),u):i,Rm(o,u)});function zm(o){var a=x(o);return a.__chain__=!0,a}function EN(o,a){return a(o),o}function Bl(o,a){return a(o)}var RN=li(function(o){var a=o.length,u=a?o[0]:0,d=this.__wrapped__,m=function(v){return hf(v,o)};return a>1||this.__actions__.length||!(d instanceof rt)||!ci(u)?this.thru(m):(d=d.slice(u,+u+(a?1:0)),d.__actions__.push({func:Bl,args:[m],thisArg:i}),new ln(d,this.__chain__).thru(function(v){return a&&!v.length&&v.push(i),v}))});function zN(){return zm(this)}function FN(){return new ln(this.value(),this.__chain__)}function VN(){this.__values__===i&&(this.__values__=Qm(this.value()));var o=this.__index__>=this.__values__.length,a=o?i:this.__values__[this.__index__++];return{done:o,value:a}}function UN(){return this}function kN(o){for(var a,u=this;u instanceof vl;){var d=Pm(u);d.__index__=0,d.__values__=i,a?m.__wrapped__=d:a=d;var m=d;u=u.__wrapped__}return m.__wrapped__=o,a}function HN(){var o=this.__wrapped__;if(o instanceof rt){var a=o;return this.__actions__.length&&(a=new rt(this)),a=a.reverse(),a.__actions__.push({func:Bl,args:[Ff],thisArg:i}),new ln(a,this.__chain__)}return this.thru(Ff)}function WN(){return tm(this.__wrapped__,this.__actions__)}var qN=_l(function(o,a,u){dt.call(o,u)?++o[u]:si(o,u,1)});function $N(o,a,u){var d=ke(o)?gp:Ew;return u&&Sr(o,a,u)&&(a=i),d(o,De(a,3))}function JN(o,a){var u=ke(o)?_i:Rp;return u(o,De(a,3))}var KN=hm(Dm),XN=hm(Bm);function ZN(o,a){return lr(Gl(o,a),1)}function YN(o,a){return lr(Gl(o,a),he)}function QN(o,a,u){return u=u===i?1:We(u),lr(Gl(o,a),u)}function Fm(o,a){var u=ke(o)?sn:Oi;return u(o,De(a,3))}function Vm(o,a){var u=ke(o)?xS:Ep;return u(o,De(a,3))}var eC=_l(function(o,a,u){dt.call(o,u)?o[u].push(a):si(o,u,[a])});function tC(o,a,u,d){o=Pr(o)?o:Xo(o),u=u&&!d?We(u):0;var m=o.length;return u<0&&(u=Xt(m+u,0)),Fl(o)?u<=m&&o.indexOf(a,u)>-1:!!m&&zo(o,a,u)>-1}var rC=Ze(function(o,a,u){var d=-1,m=typeof a=="function",v=Pr(o)?V(o.length):[];return Oi(o,function(N){v[++d]=m?Hr(a,N,u):Qs(N,a,u)}),v}),nC=_l(function(o,a,u){si(o,u,a)});function Gl(o,a){var u=ke(o)?Ot:Hp;return u(o,De(a,3))}function iC(o,a,u,d){return o==null?[]:(ke(a)||(a=a==null?[]:[a]),u=d?i:u,ke(u)||(u=u==null?[]:[u]),Jp(o,a,u))}var oC=_l(function(o,a,u){o[u?0:1].push(a)},function(){return[[],[]]});function sC(o,a,u){var d=ke(o)?Yu:bp,m=arguments.length<3;return d(o,De(a,4),u,m,Oi)}function aC(o,a,u){var d=ke(o)?vS:bp,m=arguments.length<3;return d(o,De(a,4),u,m,Ep)}function lC(o,a){var u=ke(o)?_i:Rp;return u(o,Rl(De(a,3)))}function cC(o){var a=ke(o)?Dp:t1;return a(o)}function uC(o,a,u){(u?Sr(o,a,u):a===i)?a=1:a=We(a);var d=ke(o)?Pw:r1;return d(o,a)}function fC(o){var a=ke(o)?Dw:i1;return a(o)}function hC(o){if(o==null)return 0;if(Pr(o))return Fl(o)?Vo(o):o.length;var a=mr(o);return a==ne||a==pe?o.size:xf(o).length}function dC(o,a,u){var d=ke(o)?Qu:o1;return u&&Sr(o,a,u)&&(a=i),d(o,De(a,3))}var pC=Ze(function(o,a){if(o==null)return[];var u=a.length;return u>1&&Sr(o,a[0],a[1])?a=[]:u>2&&Sr(a[0],a[1],a[2])&&(a=[a[0]]),Jp(o,lr(a,1),[])}),jl=JS||function(){return rr.Date.now()};function mC(o,a){if(typeof a!="function")throw new an(n);return o=We(o),function(){if(--o<1)return a.apply(this,arguments)}}function Um(o,a,u){return a=u?i:a,a=o&&a==null?o.length:a,ai(o,W,i,i,i,i,a)}function km(o,a){var u;if(typeof a!="function")throw new an(n);return o=We(o),function(){return--o>0&&(u=a.apply(this,arguments)),o<=1&&(a=i),u}}var Uf=Ze(function(o,a,u){var d=w;if(u.length){var m=Ii(u,Jo(Uf));d|=G}return ai(o,d,a,u,m)}),Hm=Ze(function(o,a,u){var d=w|S;if(u.length){var m=Ii(u,Jo(Hm));d|=G}return ai(a,d,o,u,m)});function Wm(o,a,u){a=u?i:a;var d=ai(o,C,i,i,i,i,i,a);return d.placeholder=Wm.placeholder,d}function qm(o,a,u){a=u?i:a;var d=ai(o,B,i,i,i,i,i,a);return d.placeholder=qm.placeholder,d}function $m(o,a,u){var d,m,v,N,L,M,Q=0,te=!1,ie=!1,me=!0;if(typeof o!="function")throw new an(n);a=hn(a)||0,Dt(u)&&(te=!!u.leading,ie="maxWait"in u,v=ie?Xt(hn(u.maxWait)||0,a):v,me="trailing"in u?!!u.trailing:me);function Le(Ft){var An=d,hi=m;return d=m=i,Q=Ft,N=o.apply(hi,An),N}function Re(Ft){return Q=Ft,L=ia(et,a),te?Le(Ft):N}function Je(Ft){var An=Ft-M,hi=Ft-Q,hg=a-An;return ie?pr(hg,v-hi):hg}function je(Ft){var An=Ft-M,hi=Ft-Q;return M===i||An>=a||An<0||ie&&hi>=v}function et(){var Ft=jl();if(je(Ft))return nt(Ft);L=ia(et,Je(Ft))}function nt(Ft){return L=i,me&&d?Le(Ft):(d=m=i,N)}function Jr(){L!==i&&nm(L),Q=0,d=M=m=L=i}function wr(){return L===i?N:nt(jl())}function Kr(){var Ft=jl(),An=je(Ft);if(d=arguments,m=this,M=Ft,An){if(L===i)return Re(M);if(ie)return nm(L),L=ia(et,a),Le(M)}return L===i&&(L=ia(et,a)),N}return Kr.cancel=Jr,Kr.flush=wr,Kr}var gC=Ze(function(o,a){return jp(o,1,a)}),yC=Ze(function(o,a,u){return jp(o,hn(a)||0,u)});function xC(o){return ai(o,q)}function El(o,a){if(typeof o!="function"||a!=null&&typeof a!="function")throw new an(n);var u=function(){var d=arguments,m=a?a.apply(this,d):d[0],v=u.cache;if(v.has(m))return v.get(m);var N=o.apply(this,d);return u.cache=v.set(m,N)||v,N};return u.cache=new(El.Cache||oi),u}El.Cache=oi;function Rl(o){if(typeof o!="function")throw new an(n);return function(){var a=arguments;switch(a.length){case 0:return!o.call(this);case 1:return!o.call(this,a[0]);case 2:return!o.call(this,a[0],a[1]);case 3:return!o.call(this,a[0],a[1],a[2])}return!o.apply(this,a)}}function vC(o){return km(2,o)}var bC=s1(function(o,a){a=a.length==1&&ke(a[0])?Ot(a[0],Wr(De())):Ot(lr(a,1),Wr(De()));var u=a.length;return Ze(function(d){for(var m=-1,v=pr(d.length,u);++m<v;)d[m]=a[m].call(this,d[m]);return Hr(o,this,d)})}),kf=Ze(function(o,a){var u=Ii(a,Jo(kf));return ai(o,G,i,a,u)}),Jm=Ze(function(o,a){var u=Ii(a,Jo(Jm));return ai(o,D,i,a,u)}),SC=li(function(o,a){return ai(o,A,i,i,i,a)});function wC(o,a){if(typeof o!="function")throw new an(n);return a=a===i?a:We(a),Ze(o,a)}function NC(o,a){if(typeof o!="function")throw new an(n);return a=a==null?0:Xt(We(a),0),Ze(function(u){var d=u[a],m=Bi(u,0,a);return d&&Ti(m,d),Hr(o,this,m)})}function CC(o,a,u){var d=!0,m=!0;if(typeof o!="function")throw new an(n);return Dt(u)&&(d="leading"in u?!!u.leading:d,m="trailing"in u?!!u.trailing:m),$m(o,a,{leading:d,maxWait:a,trailing:m})}function LC(o){return Um(o,1)}function _C(o,a){return kf(Tf(a),o)}function TC(){if(!arguments.length)return[];var o=arguments[0];return ke(o)?o:[o]}function IC(o){return cn(o,p)}function MC(o,a){return a=typeof a=="function"?a:i,cn(o,p,a)}function AC(o){return cn(o,f|p)}function OC(o,a){return a=typeof a=="function"?a:i,cn(o,f|p,a)}function PC(o,a){return a==null||Gp(o,a,nr(a))}function Mn(o,a){return o===a||o!==o&&a!==a}var DC=Al(mf),BC=Al(function(o,a){return o>=a}),mo=Vp(function(){return arguments}())?Vp:function(o){return Gt(o)&&dt.call(o,"callee")&&!Tp.call(o,"callee")},ke=V.isArray,GC=up?Wr(up):kw;function Pr(o){return o!=null&&zl(o.length)&&!ui(o)}function zt(o){return Gt(o)&&Pr(o)}function jC(o){return o===!0||o===!1||Gt(o)&&br(o)==oe}var Gi=XS||eh,EC=fp?Wr(fp):Hw;function RC(o){return Gt(o)&&o.nodeType===1&&!oa(o)}function zC(o){if(o==null)return!0;if(Pr(o)&&(ke(o)||typeof o=="string"||typeof o.splice=="function"||Gi(o)||Ko(o)||mo(o)))return!o.length;var a=mr(o);if(a==ne||a==pe)return!o.size;if(na(o))return!xf(o).length;for(var u in o)if(dt.call(o,u))return!1;return!0}function FC(o,a){return ea(o,a)}function VC(o,a,u){u=typeof u=="function"?u:i;var d=u?u(o,a):i;return d===i?ea(o,a,i,u):!!d}function Hf(o){if(!Gt(o))return!1;var a=br(o);return a==ue||a==ce||typeof o.message=="string"&&typeof o.name=="string"&&!oa(o)}function UC(o){return typeof o=="number"&&Mp(o)}function ui(o){if(!Dt(o))return!1;var a=br(o);return a==K||a==ae||a==ee||a==xe}function Km(o){return typeof o=="number"&&o==We(o)}function zl(o){return typeof o=="number"&&o>-1&&o%1==0&&o<=re}function Dt(o){var a=typeof o;return o!=null&&(a=="object"||a=="function")}function Gt(o){return o!=null&&typeof o=="object"}var Xm=hp?Wr(hp):qw;function kC(o,a){return o===a||yf(o,a,Bf(a))}function HC(o,a,u){return u=typeof u=="function"?u:i,yf(o,a,Bf(a),u)}function WC(o){return Zm(o)&&o!=+o}function qC(o){if(M1(o))throw new Ue(r);return Up(o)}function $C(o){return o===null}function JC(o){return o==null}function Zm(o){return typeof o=="number"||Gt(o)&&br(o)==Ce}function oa(o){if(!Gt(o)||br(o)!=le)return!1;var a=hl(o);if(a===null)return!0;var u=dt.call(a,"constructor")&&a.constructor;return typeof u=="function"&&u instanceof u&&ll.call(u)==HS}var Wf=dp?Wr(dp):$w;function KC(o){return Km(o)&&o>=-re&&o<=re}var Ym=pp?Wr(pp):Jw;function Fl(o){return typeof o=="string"||!ke(o)&&Gt(o)&&br(o)==we}function $r(o){return typeof o=="symbol"||Gt(o)&&br(o)==Ve}var Ko=mp?Wr(mp):Kw;function XC(o){return o===i}function ZC(o){return Gt(o)&&mr(o)==Qe}function YC(o){return Gt(o)&&br(o)==bt}var QC=Al(vf),eL=Al(function(o,a){return o<=a});function Qm(o){if(!o)return[];if(Pr(o))return Fl(o)?Tn(o):Or(o);if(qs&&o[qs])return PS(o[qs]());var a=mr(o),u=a==ne?sf:a==pe?ol:Xo;return u(o)}function fi(o){if(!o)return o===0?o:0;if(o=hn(o),o===he||o===-he){var a=o<0?-1:1;return a*Ne}return o===o?o:0}function We(o){var a=fi(o),u=a%1;return a===a?u?a-u:a:0}function eg(o){return o?uo(We(o),0,Me):0}function hn(o){if(typeof o=="number")return o;if($r(o))return ye;if(Dt(o)){var a=typeof o.valueOf=="function"?o.valueOf():o;o=Dt(a)?a+"":a}if(typeof o!="string")return o===0?o:+o;o=o.replace(tt,"");var u=Qa.test(o);return u||Eb.test(o)?mS(o.slice(2),u?2:8):zn.test(o)?ye:+o}function tg(o){return Vn(o,Dr(o))}function tL(o){return o?uo(We(o),-re,re):o===0?o:0}function ut(o){return o==null?"":qr(o)}var rL=qo(function(o,a){if(na(a)||Pr(a)){Vn(a,nr(a),o);return}for(var u in a)dt.call(a,u)&&Zs(o,u,a[u])}),rg=qo(function(o,a){Vn(a,Dr(a),o)}),Vl=qo(function(o,a,u,d){Vn(a,Dr(a),o,d)}),nL=qo(function(o,a,u,d){Vn(a,nr(a),o,d)}),iL=li(hf);function oL(o,a){var u=Wo(o);return a==null?u:Bp(u,a)}var sL=Ze(function(o,a){o=yt(o);var u=-1,d=a.length,m=d>2?a[2]:i;for(m&&Sr(a[0],a[1],m)&&(d=1);++u<d;)for(var v=a[u],N=Dr(v),L=-1,M=N.length;++L<M;){var Q=N[L],te=o[Q];(te===i||Mn(te,Uo[Q])&&!dt.call(o,Q))&&(o[Q]=v[Q])}return o}),aL=Ze(function(o){return o.push(i,vm),Hr(ng,i,o)});function lL(o,a){return yp(o,De(a,3),Fn)}function cL(o,a){return yp(o,De(a,3),pf)}function uL(o,a){return o==null?o:df(o,De(a,3),Dr)}function fL(o,a){return o==null?o:zp(o,De(a,3),Dr)}function hL(o,a){return o&&Fn(o,De(a,3))}function dL(o,a){return o&&pf(o,De(a,3))}function pL(o){return o==null?[]:wl(o,nr(o))}function mL(o){return o==null?[]:wl(o,Dr(o))}function qf(o,a,u){var d=o==null?i:fo(o,a);return d===i?u:d}function gL(o,a){return o!=null&&wm(o,a,zw)}function $f(o,a){return o!=null&&wm(o,a,Fw)}var yL=pm(function(o,a,u){a!=null&&typeof a.toString!="function"&&(a=cl.call(a)),o[a]=u},Kf(Br)),xL=pm(function(o,a,u){a!=null&&typeof a.toString!="function"&&(a=cl.call(a)),dt.call(o,a)?o[a].push(u):o[a]=[u]},De),vL=Ze(Qs);function nr(o){return Pr(o)?Pp(o):xf(o)}function Dr(o){return Pr(o)?Pp(o,!0):Xw(o)}function bL(o,a){var u={};return a=De(a,3),Fn(o,function(d,m,v){si(u,a(d,m,v),d)}),u}function SL(o,a){var u={};return a=De(a,3),Fn(o,function(d,m,v){si(u,m,a(d,m,v))}),u}var wL=qo(function(o,a,u){Nl(o,a,u)}),ng=qo(function(o,a,u,d){Nl(o,a,u,d)}),NL=li(function(o,a){var u={};if(o==null)return u;var d=!1;a=Ot(a,function(v){return v=Di(v,o),d||(d=v.length>1),v}),Vn(o,Pf(o),u),d&&(u=cn(u,f|h|p,y1));for(var m=a.length;m--;)Cf(u,a[m]);return u});function CL(o,a){return ig(o,Rl(De(a)))}var LL=li(function(o,a){return o==null?{}:Yw(o,a)});function ig(o,a){if(o==null)return{};var u=Ot(Pf(o),function(d){return[d]});return a=De(a),Kp(o,u,function(d,m){return a(d,m[0])})}function _L(o,a,u){a=Di(a,o);var d=-1,m=a.length;for(m||(m=1,o=i);++d<m;){var v=o==null?i:o[Un(a[d])];v===i&&(d=m,v=u),o=ui(v)?v.call(o):v}return o}function TL(o,a,u){return o==null?o:ta(o,a,u)}function IL(o,a,u,d){return d=typeof d=="function"?d:i,o==null?o:ta(o,a,u,d)}var og=ym(nr),sg=ym(Dr);function ML(o,a,u){var d=ke(o),m=d||Gi(o)||Ko(o);if(a=De(a,4),u==null){var v=o&&o.constructor;m?u=d?new v:[]:Dt(o)?u=ui(v)?Wo(hl(o)):{}:u={}}return(m?sn:Fn)(o,function(N,L,M){return a(u,N,L,M)}),u}function AL(o,a){return o==null?!0:Cf(o,a)}function OL(o,a,u){return o==null?o:em(o,a,Tf(u))}function PL(o,a,u,d){return d=typeof d=="function"?d:i,o==null?o:em(o,a,Tf(u),d)}function Xo(o){return o==null?[]:of(o,nr(o))}function DL(o){return o==null?[]:of(o,Dr(o))}function BL(o,a,u){return u===i&&(u=a,a=i),u!==i&&(u=hn(u),u=u===u?u:0),a!==i&&(a=hn(a),a=a===a?a:0),uo(hn(o),a,u)}function GL(o,a,u){return a=fi(a),u===i?(u=a,a=0):u=fi(u),o=hn(o),Vw(o,a,u)}function jL(o,a,u){if(u&&typeof u!="boolean"&&Sr(o,a,u)&&(a=u=i),u===i&&(typeof a=="boolean"?(u=a,a=i):typeof o=="boolean"&&(u=o,o=i)),o===i&&a===i?(o=0,a=1):(o=fi(o),a===i?(a=o,o=0):a=fi(a)),o>a){var d=o;o=a,a=d}if(u||o%1||a%1){var m=Ap();return pr(o+m*(a-o+pS("1e-"+((m+"").length-1))),a)}return Sf(o,a)}var EL=$o(function(o,a,u){return a=a.toLowerCase(),o+(u?ag(a):a)});function ag(o){return Jf(ut(o).toLowerCase())}function lg(o){return o=ut(o),o&&o.replace(zb,TS).replace(iS,"")}function RL(o,a,u){o=ut(o),a=qr(a);var d=o.length;u=u===i?d:uo(We(u),0,d);var m=u;return u-=a.length,u>=0&&o.slice(u,m)==a}function zL(o){return o=ut(o),o&&Mr.test(o)?o.replace(io,IS):o}function FL(o){return o=ut(o),o&&$e.test(o)?o.replace(He,"\\$&"):o}var VL=$o(function(o,a,u){return o+(u?"-":"")+a.toLowerCase()}),UL=$o(function(o,a,u){return o+(u?" ":"")+a.toLowerCase()}),kL=fm("toLowerCase");function HL(o,a,u){o=ut(o),a=We(a);var d=a?Vo(o):0;if(!a||d>=a)return o;var m=(a-d)/2;return Ml(gl(m),u)+o+Ml(ml(m),u)}function WL(o,a,u){o=ut(o),a=We(a);var d=a?Vo(o):0;return a&&d<a?o+Ml(a-d,u):o}function qL(o,a,u){o=ut(o),a=We(a);var d=a?Vo(o):0;return a&&d<a?Ml(a-d,u)+o:o}function $L(o,a,u){return u||a==null?a=0:a&&(a=+a),ew(ut(o).replace(at,""),a||0)}function JL(o,a,u){return(u?Sr(o,a,u):a===i)?a=1:a=We(a),wf(ut(o),a)}function KL(){var o=arguments,a=ut(o[0]);return o.length<3?a:a.replace(o[1],o[2])}var XL=$o(function(o,a,u){return o+(u?"_":"")+a.toLowerCase()});function ZL(o,a,u){return u&&typeof u!="number"&&Sr(o,a,u)&&(a=u=i),u=u===i?Me:u>>>0,u?(o=ut(o),o&&(typeof a=="string"||a!=null&&!Wf(a))&&(a=qr(a),!a&&Fo(o))?Bi(Tn(o),0,u):o.split(a,u)):[]}var YL=$o(function(o,a,u){return o+(u?" ":"")+Jf(a)});function QL(o,a,u){return o=ut(o),u=u==null?0:uo(We(u),0,o.length),a=qr(a),o.slice(u,u+a.length)==a}function e_(o,a,u){var d=x.templateSettings;u&&Sr(o,a,u)&&(a=i),o=ut(o),a=Vl({},a,d,xm);var m=Vl({},a.imports,d.imports,xm),v=nr(m),N=of(m,v),L,M,Q=0,te=a.interpolate||el,ie="__p += '",me=af((a.escape||el).source+"|"+te.source+"|"+(te===ni?Ln:el).source+"|"+(a.evaluate||el).source+"|$","g"),Le="//# sourceURL="+(dt.call(a,"sourceURL")?(a.sourceURL+"").replace(/\s/g," "):"lodash.templateSources["+ ++cS+"]")+`
|
|
4
|
-
`;o.replace(me,function(je,et,nt,Jr,wr,Kr){return nt||(nt=Jr),ie+=o.slice(Q,Kr).replace(
|
|
3
|
+
`)}function h1(o){return ke(o)||po(o)||!!(bd&&o&&o[bd])}function ai(o,a){var u=typeof o;return a=a==null?re:a,!!a&&(u=="number"||u!="symbol"&&Cb.test(o))&&o>-1&&o%1==0&&o<a}function Sr(o,a,u){if(!Dt(u))return!1;var p=typeof a;return(p=="number"?Pr(u)&&ai(a,u.length):p=="string"&&a in u)?In(u[a],o):!1}function Of(o,a){if(ke(o))return!1;var u=typeof o;return u=="number"||u=="symbol"||u=="boolean"||o==null||$r(o)?!0:Ee.test(o)||!Bo.test(o)||a!=null&&o in yt(a)}function p1(o){var a=typeof o;return a=="string"||a=="number"||a=="symbol"||a=="boolean"?o!=="__proto__":o===null}function Pf(o){var a=Ml(o),u=y[a];if(typeof u!="function"||!(a in rt.prototype))return!1;if(o===u)return!0;var p=If(u);return!!p&&o===p[0]}function d1(o){return!!gd&&gd in o}var m1=ol?li:Kf;function Qs(o){var a=o&&o.constructor,u=typeof a=="function"&&a.prototype||zo;return o===u}function gm(o){return o===o&&!Dt(o)}function ym(o,a){return function(u){return u==null?!1:u[o]===a&&(a!==i||o in yt(u))}}function g1(o){var a=Gl(o,function(p){return u.size===l&&u.clear(),p}),u=a.cache;return a}function y1(o,a){var u=o[1],p=a[1],m=u|p,v=m<(w|S|W),N=p==W&&u==C||p==W&&u==M&&o[7].length<=a[8]||p==(W|M)&&a[7].length<=a[8]&&u==C;if(!(v||N))return o;p&w&&(o[2]=a[2],m|=u&w?0:D);var L=a[3];if(L){var I=o[3];o[3]=I?Qd(I,L,a[4]):L,o[4]=I?_i(o[3],c):a[4]}return L=a[5],L&&(I=o[5],o[5]=I?em(I,L,a[6]):L,o[6]=I?_i(o[5],c):a[6]),L=a[7],L&&(o[7]=L),p&W&&(o[8]=o[8]==null?a[8]:dr(o[8],a[8])),o[9]==null&&(o[9]=a[9]),o[0]=a[0],o[1]=m,o}function x1(o){var a=[];if(o!=null)for(var u in yt(o))a.push(u);return a}function v1(o){return al.call(o)}function xm(o,a,u){return a=Xt(a===i?o.length-1:a,0),function(){for(var p=arguments,m=-1,v=Xt(p.length-a,0),N=V(v);++m<v;)N[m]=p[a+m];m=-1;for(var L=V(a+1);++m<a;)L[m]=p[m];return L[a]=u(N),Hr(o,this,L)}}function vm(o,a){return a.length<2?o:uo(o,un(a,0,-1))}function b1(o,a){for(var u=o.length,p=dr(a.length,u),m=Or(o);p--;){var v=a[p];o[p]=ai(v,u)?m[v]:i}return o}function Df(o,a){if(!(a==="constructor"&&typeof o[a]=="function")&&a!="__proto__")return o[a]}var bm=wm(kd),ea=GS||function(o,a){return rr.setTimeout(o,a)},Bf=wm(kw);function Sm(o,a,u){var p=a+"";return Bf(o,f1(p,S1(l1(p),u)))}function wm(o){var a=0,u=0;return function(){var p=zS(),m=T-(p-u);if(u=p,m>0){if(++a>=R)return arguments[0]}else a=0;return o.apply(i,arguments)}}function Ol(o,a){var u=-1,p=o.length,m=p-1;for(a=a===i?p:a;++u<a;){var v=gf(u,m),N=o[v];o[v]=o[u],o[u]=N}return o.length=a,o}var Nm=g1(function(o){var a=[];return o.charCodeAt(0)===46&&a.push(""),o.replace(Xe,function(u,p,m,v){a.push(m?v.replace(Ar,"$1"):p||u)}),a});function Vn(o){if(typeof o=="string"||$r(o))return o;var a=o+"";return a=="0"&&1/o==-he?"-0":a}function ho(o){if(o!=null){try{return sl.call(o)}catch(a){}try{return o+""}catch(a){}}return""}function S1(o,a){return sn(H,function(u){var p="_."+u[0];a&u[1]&&!tl(o,p)&&o.push(p)}),o.sort()}function Cm(o){if(o instanceof rt)return o.clone();var a=new ln(o.__wrapped__,o.__chain__);return a.__actions__=Or(o.__actions__),a.__index__=o.__index__,a.__values__=o.__values__,a}function w1(o,a,u){(u?Sr(o,a,u):a===i)?a=1:a=Xt(We(a),0);var p=o==null?0:o.length;if(!p||a<1)return[];for(var m=0,v=0,N=V(pl(p/a));m<p;)N[v++]=un(o,m,m+=a);return N}function N1(o){for(var a=-1,u=o==null?0:o.length,p=0,m=[];++a<u;){var v=o[a];v&&(m[p++]=v)}return m}function C1(){var o=arguments.length;if(!o)return[];for(var a=V(o-1),u=arguments[0],p=o;p--;)a[p-1]=arguments[p];return Li(ke(u)?Or(u):[u],lr(a,1))}var L1=Ze(function(o,a){return zt(o)?Js(o,lr(a,1,zt,!0)):[]}),_1=Ze(function(o,a){var u=fn(a);return zt(u)&&(u=i),zt(o)?Js(o,lr(a,1,zt,!0),De(u,2)):[]}),T1=Ze(function(o,a){var u=fn(a);return zt(u)&&(u=i),zt(o)?Js(o,lr(a,1,zt,!0),i,u):[]});function I1(o,a,u){var p=o==null?0:o.length;return p?(a=u||a===i?1:We(a),un(o,a<0?0:a,p)):[]}function M1(o,a,u){var p=o==null?0:o.length;return p?(a=u||a===i?1:We(a),a=p-a,un(o,0,a<0?0:a)):[]}function A1(o,a){return o&&o.length?Nl(o,De(a,3),!0,!0):[]}function O1(o,a){return o&&o.length?Nl(o,De(a,3),!0):[]}function P1(o,a,u,p){var m=o==null?0:o.length;return m?(u&&typeof u!="number"&&Sr(o,a,u)&&(u=0,p=m),Cw(o,a,u,p)):[]}function Lm(o,a,u){var p=o==null?0:o.length;if(!p)return-1;var m=u==null?0:We(u);return m<0&&(m=Xt(p+m,0)),rl(o,De(a,3),m)}function _m(o,a,u){var p=o==null?0:o.length;if(!p)return-1;var m=p-1;return u!==i&&(m=We(u),m=u<0?Xt(p+m,0):dr(m,p-1)),rl(o,De(a,3),m,!0)}function Tm(o){var a=o==null?0:o.length;return a?lr(o,1):[]}function D1(o){var a=o==null?0:o.length;return a?lr(o,he):[]}function B1(o,a){var u=o==null?0:o.length;return u?(a=a===i?1:We(a),lr(o,a)):[]}function G1(o){for(var a=-1,u=o==null?0:o.length,p={};++a<u;){var m=o[a];p[m[0]]=m[1]}return p}function Im(o){return o&&o.length?o[0]:i}function j1(o,a,u){var p=o==null?0:o.length;if(!p)return-1;var m=u==null?0:We(u);return m<0&&(m=Xt(p+m,0)),jo(o,a,m)}function E1(o){var a=o==null?0:o.length;return a?un(o,0,-1):[]}var R1=Ze(function(o){var a=Ot(o,Sf);return a.length&&a[0]===o[0]?ff(a):[]}),z1=Ze(function(o){var a=fn(o),u=Ot(o,Sf);return a===fn(u)?a=i:u.pop(),u.length&&u[0]===o[0]?ff(u,De(a,2)):[]}),F1=Ze(function(o){var a=fn(o),u=Ot(o,Sf);return a=typeof a=="function"?a:i,a&&u.pop(),u.length&&u[0]===o[0]?ff(u,i,a):[]});function V1(o,a){return o==null?"":ES.call(o,a)}function fn(o){var a=o==null?0:o.length;return a?o[a-1]:i}function U1(o,a,u){var p=o==null?0:o.length;if(!p)return-1;var m=p;return u!==i&&(m=We(u),m=m<0?Xt(p+m,0):dr(m,p-1)),a===a?SS(o,a,m):rl(o,ud,m,!0)}function k1(o,a){return o&&o.length?zd(o,We(a)):i}var H1=Ze(Mm);function Mm(o,a){return o&&o.length&&a&&a.length?mf(o,a):o}function W1(o,a,u){return o&&o.length&&a&&a.length?mf(o,a,De(u,2)):o}function q1(o,a,u){return o&&o.length&&a&&a.length?mf(o,a,i,u):o}var $1=si(function(o,a){var u=o==null?0:o.length,p=af(o,a);return Ud(o,Ot(a,function(m){return ai(m,u)?+m:m}).sort(Yd)),p});function J1(o,a){var u=[];if(!(o&&o.length))return u;var p=-1,m=[],v=o.length;for(a=De(a,3);++p<v;){var N=o[p];a(N,p,o)&&(u.push(N),m.push(p))}return Ud(o,m),u}function Gf(o){return o==null?o:VS.call(o)}function K1(o,a,u){var p=o==null?0:o.length;return p?(u&&typeof u!="number"&&Sr(o,a,u)?(a=0,u=p):(a=a==null?0:We(a),u=u===i?p:We(u)),un(o,a,u)):[]}function X1(o,a){return wl(o,a)}function Z1(o,a,u){return xf(o,a,De(u,2))}function Y1(o,a){var u=o==null?0:o.length;if(u){var p=wl(o,a);if(p<u&&In(o[p],a))return p}return-1}function Q1(o,a){return wl(o,a,!0)}function eN(o,a,u){return xf(o,a,De(u,2),!0)}function tN(o,a){var u=o==null?0:o.length;if(u){var p=wl(o,a,!0)-1;if(In(o[p],a))return p}return-1}function rN(o){return o&&o.length?Hd(o):[]}function nN(o,a){return o&&o.length?Hd(o,De(a,2)):[]}function iN(o){var a=o==null?0:o.length;return a?un(o,1,a):[]}function oN(o,a,u){return o&&o.length?(a=u||a===i?1:We(a),un(o,0,a<0?0:a)):[]}function sN(o,a,u){var p=o==null?0:o.length;return p?(a=u||a===i?1:We(a),a=p-a,un(o,a<0?0:a,p)):[]}function aN(o,a){return o&&o.length?Nl(o,De(a,3),!1,!0):[]}function lN(o,a){return o&&o.length?Nl(o,De(a,3)):[]}var cN=Ze(function(o){return Ai(lr(o,1,zt,!0))}),uN=Ze(function(o){var a=fn(o);return zt(a)&&(a=i),Ai(lr(o,1,zt,!0),De(a,2))}),fN=Ze(function(o){var a=fn(o);return a=typeof a=="function"?a:i,Ai(lr(o,1,zt,!0),i,a)});function hN(o){return o&&o.length?Ai(o):[]}function pN(o,a){return o&&o.length?Ai(o,De(a,2)):[]}function dN(o,a){return a=typeof a=="function"?a:i,o&&o.length?Ai(o,i,a):[]}function jf(o){if(!(o&&o.length))return[];var a=0;return o=Ci(o,function(u){if(zt(u))return a=Xt(u.length,a),!0}),Yu(a,function(u){return Ot(o,Ku(u))})}function Am(o,a){if(!(o&&o.length))return[];var u=jf(o);return a==null?u:Ot(u,function(p){return Hr(a,i,p)})}var mN=Ze(function(o,a){return zt(o)?Js(o,a):[]}),gN=Ze(function(o){return bf(Ci(o,zt))}),yN=Ze(function(o){var a=fn(o);return zt(a)&&(a=i),bf(Ci(o,zt),De(a,2))}),xN=Ze(function(o){var a=fn(o);return a=typeof a=="function"?a:i,bf(Ci(o,zt),i,a)}),vN=Ze(jf);function bN(o,a){return Jd(o||[],a||[],$s)}function SN(o,a){return Jd(o||[],a||[],Zs)}var wN=Ze(function(o){var a=o.length,u=a>1?o[a-1]:i;return u=typeof u=="function"?(o.pop(),u):i,Am(o,u)});function Om(o){var a=y(o);return a.__chain__=!0,a}function NN(o,a){return a(o),o}function Pl(o,a){return a(o)}var CN=si(function(o){var a=o.length,u=a?o[0]:0,p=this.__wrapped__,m=function(v){return af(v,o)};return a>1||this.__actions__.length||!(p instanceof rt)||!ai(u)?this.thru(m):(p=p.slice(u,+u+(a?1:0)),p.__actions__.push({func:Pl,args:[m],thisArg:i}),new ln(p,this.__chain__).thru(function(v){return a&&!v.length&&v.push(i),v}))});function LN(){return Om(this)}function _N(){return new ln(this.value(),this.__chain__)}function TN(){this.__values__===i&&(this.__values__=Wm(this.value()));var o=this.__index__>=this.__values__.length,a=o?i:this.__values__[this.__index__++];return{done:o,value:a}}function IN(){return this}function MN(o){for(var a,u=this;u instanceof yl;){var p=Cm(u);p.__index__=0,p.__values__=i,a?m.__wrapped__=p:a=p;var m=p;u=u.__wrapped__}return m.__wrapped__=o,a}function AN(){var o=this.__wrapped__;if(o instanceof rt){var a=o;return this.__actions__.length&&(a=new rt(this)),a=a.reverse(),a.__actions__.push({func:Pl,args:[Gf],thisArg:i}),new ln(a,this.__chain__)}return this.thru(Gf)}function ON(){return $d(this.__wrapped__,this.__actions__)}var PN=Cl(function(o,a,u){pt.call(o,u)?++o[u]:ii(o,u,1)});function DN(o,a,u){var p=ke(o)?ld:Nw;return u&&Sr(o,a,u)&&(a=i),p(o,De(a,3))}function BN(o,a){var u=ke(o)?Ci:Ad;return u(o,De(a,3))}var GN=im(Lm),jN=im(_m);function EN(o,a){return lr(Dl(o,a),1)}function RN(o,a){return lr(Dl(o,a),he)}function zN(o,a,u){return u=u===i?1:We(u),lr(Dl(o,a),u)}function Pm(o,a){var u=ke(o)?sn:Mi;return u(o,De(a,3))}function Dm(o,a){var u=ke(o)?iS:Md;return u(o,De(a,3))}var FN=Cl(function(o,a,u){pt.call(o,u)?o[u].push(a):ii(o,u,[a])});function VN(o,a,u,p){o=Pr(o)?o:$o(o),u=u&&!p?We(u):0;var m=o.length;return u<0&&(u=Xt(m+u,0)),Rl(o)?u<=m&&o.indexOf(a,u)>-1:!!m&&jo(o,a,u)>-1}var UN=Ze(function(o,a,u){var p=-1,m=typeof a=="function",v=Pr(o)?V(o.length):[];return Mi(o,function(N){v[++p]=m?Hr(a,N,u):Ks(N,a,u)}),v}),kN=Cl(function(o,a,u){ii(o,u,a)});function Dl(o,a){var u=ke(o)?Ot:jd;return u(o,De(a,3))}function HN(o,a,u,p){return o==null?[]:(ke(a)||(a=a==null?[]:[a]),u=p?i:u,ke(u)||(u=u==null?[]:[u]),Fd(o,a,u))}var WN=Cl(function(o,a,u){o[u?0:1].push(a)},function(){return[[],[]]});function qN(o,a,u){var p=ke(o)?$u:hd,m=arguments.length<3;return p(o,De(a,4),u,m,Mi)}function $N(o,a,u){var p=ke(o)?oS:hd,m=arguments.length<3;return p(o,De(a,4),u,m,Md)}function JN(o,a){var u=ke(o)?Ci:Ad;return u(o,jl(De(a,3)))}function KN(o){var a=ke(o)?Ld:Vw;return a(o)}function XN(o,a,u){(u?Sr(o,a,u):a===i)?a=1:a=We(a);var p=ke(o)?xw:Uw;return p(o,a)}function ZN(o){var a=ke(o)?vw:Hw;return a(o)}function YN(o){if(o==null)return 0;if(Pr(o))return Rl(o)?Ro(o):o.length;var a=mr(o);return a==ne||a==de?o.size:pf(o).length}function QN(o,a,u){var p=ke(o)?Ju:Ww;return u&&Sr(o,a,u)&&(a=i),p(o,De(a,3))}var eC=Ze(function(o,a){if(o==null)return[];var u=a.length;return u>1&&Sr(o,a[0],a[1])?a=[]:u>2&&Sr(a[0],a[1],a[2])&&(a=[a[0]]),Fd(o,lr(a,1),[])}),Bl=BS||function(){return rr.Date.now()};function tC(o,a){if(typeof a!="function")throw new an(n);return o=We(o),function(){if(--o<1)return a.apply(this,arguments)}}function Bm(o,a,u){return a=u?i:a,a=o&&a==null?o.length:a,oi(o,W,i,i,i,i,a)}function Gm(o,a){var u;if(typeof a!="function")throw new an(n);return o=We(o),function(){return--o>0&&(u=a.apply(this,arguments)),o<=1&&(a=i),u}}var Ef=Ze(function(o,a,u){var p=w;if(u.length){var m=_i(u,Wo(Ef));p|=B}return oi(o,p,a,u,m)}),jm=Ze(function(o,a,u){var p=w|S;if(u.length){var m=_i(u,Wo(jm));p|=B}return oi(a,p,o,u,m)});function Em(o,a,u){a=u?i:a;var p=oi(o,C,i,i,i,i,i,a);return p.placeholder=Em.placeholder,p}function Rm(o,a,u){a=u?i:a;var p=oi(o,G,i,i,i,i,i,a);return p.placeholder=Rm.placeholder,p}function zm(o,a,u){var p,m,v,N,L,I,Q=0,te=!1,ie=!1,me=!0;if(typeof o!="function")throw new an(n);a=hn(a)||0,Dt(u)&&(te=!!u.leading,ie="maxWait"in u,v=ie?Xt(hn(u.maxWait)||0,a):v,me="trailing"in u?!!u.trailing:me);function Le(Ft){var Mn=p,ui=m;return p=m=i,Q=Ft,N=o.apply(ui,Mn),N}function Re(Ft){return Q=Ft,L=ea(et,a),te?Le(Ft):N}function Je(Ft){var Mn=Ft-I,ui=Ft-Q,ig=a-Mn;return ie?dr(ig,v-ui):ig}function je(Ft){var Mn=Ft-I,ui=Ft-Q;return I===i||Mn>=a||Mn<0||ie&&ui>=v}function et(){var Ft=Bl();if(je(Ft))return nt(Ft);L=ea(et,Je(Ft))}function nt(Ft){return L=i,me&&p?Le(Ft):(p=m=i,N)}function Jr(){L!==i&&Kd(L),Q=0,p=I=m=L=i}function wr(){return L===i?N:nt(Bl())}function Kr(){var Ft=Bl(),Mn=je(Ft);if(p=arguments,m=this,I=Ft,Mn){if(L===i)return Re(I);if(ie)return Kd(L),L=ea(et,a),Le(I)}return L===i&&(L=ea(et,a)),N}return Kr.cancel=Jr,Kr.flush=wr,Kr}var rC=Ze(function(o,a){return Id(o,1,a)}),nC=Ze(function(o,a,u){return Id(o,hn(a)||0,u)});function iC(o){return oi(o,q)}function Gl(o,a){if(typeof o!="function"||a!=null&&typeof a!="function")throw new an(n);var u=function(){var p=arguments,m=a?a.apply(this,p):p[0],v=u.cache;if(v.has(m))return v.get(m);var N=o.apply(this,p);return u.cache=v.set(m,N)||v,N};return u.cache=new(Gl.Cache||ni),u}Gl.Cache=ni;function jl(o){if(typeof o!="function")throw new an(n);return function(){var a=arguments;switch(a.length){case 0:return!o.call(this);case 1:return!o.call(this,a[0]);case 2:return!o.call(this,a[0],a[1]);case 3:return!o.call(this,a[0],a[1],a[2])}return!o.apply(this,a)}}function oC(o){return Gm(2,o)}var sC=qw(function(o,a){a=a.length==1&&ke(a[0])?Ot(a[0],Wr(De())):Ot(lr(a,1),Wr(De()));var u=a.length;return Ze(function(p){for(var m=-1,v=dr(p.length,u);++m<v;)p[m]=a[m].call(this,p[m]);return Hr(o,this,p)})}),Rf=Ze(function(o,a){var u=_i(a,Wo(Rf));return oi(o,B,i,a,u)}),Fm=Ze(function(o,a){var u=_i(a,Wo(Fm));return oi(o,P,i,a,u)}),aC=si(function(o,a){return oi(o,M,i,i,i,a)});function lC(o,a){if(typeof o!="function")throw new an(n);return a=a===i?a:We(a),Ze(o,a)}function cC(o,a){if(typeof o!="function")throw new an(n);return a=a==null?0:Xt(We(a),0),Ze(function(u){var p=u[a],m=Pi(u,0,a);return p&&Li(m,p),Hr(o,this,m)})}function uC(o,a,u){var p=!0,m=!0;if(typeof o!="function")throw new an(n);return Dt(u)&&(p="leading"in u?!!u.leading:p,m="trailing"in u?!!u.trailing:m),zm(o,a,{leading:p,maxWait:a,trailing:m})}function fC(o){return Bm(o,1)}function hC(o,a){return Rf(wf(a),o)}function pC(){if(!arguments.length)return[];var o=arguments[0];return ke(o)?o:[o]}function dC(o){return cn(o,d)}function mC(o,a){return a=typeof a=="function"?a:i,cn(o,d,a)}function gC(o){return cn(o,f|d)}function yC(o,a){return a=typeof a=="function"?a:i,cn(o,f|d,a)}function xC(o,a){return a==null||Td(o,a,nr(a))}function In(o,a){return o===a||o!==o&&a!==a}var vC=Il(uf),bC=Il(function(o,a){return o>=a}),po=Dd(function(){return arguments}())?Dd:function(o){return Gt(o)&&pt.call(o,"callee")&&!vd.call(o,"callee")},ke=V.isArray,SC=rd?Wr(rd):Mw;function Pr(o){return o!=null&&El(o.length)&&!li(o)}function zt(o){return Gt(o)&&Pr(o)}function wC(o){return o===!0||o===!1||Gt(o)&&br(o)==oe}var Di=jS||Kf,NC=nd?Wr(nd):Aw;function CC(o){return Gt(o)&&o.nodeType===1&&!ta(o)}function LC(o){if(o==null)return!0;if(Pr(o)&&(ke(o)||typeof o=="string"||typeof o.splice=="function"||Di(o)||qo(o)||po(o)))return!o.length;var a=mr(o);if(a==ne||a==de)return!o.size;if(Qs(o))return!pf(o).length;for(var u in o)if(pt.call(o,u))return!1;return!0}function _C(o,a){return Xs(o,a)}function TC(o,a,u){u=typeof u=="function"?u:i;var p=u?u(o,a):i;return p===i?Xs(o,a,i,u):!!p}function zf(o){if(!Gt(o))return!1;var a=br(o);return a==ue||a==ce||typeof o.message=="string"&&typeof o.name=="string"&&!ta(o)}function IC(o){return typeof o=="number"&&Sd(o)}function li(o){if(!Dt(o))return!1;var a=br(o);return a==K||a==ae||a==ee||a==xe}function Vm(o){return typeof o=="number"&&o==We(o)}function El(o){return typeof o=="number"&&o>-1&&o%1==0&&o<=re}function Dt(o){var a=typeof o;return o!=null&&(a=="object"||a=="function")}function Gt(o){return o!=null&&typeof o=="object"}var Um=id?Wr(id):Pw;function MC(o,a){return o===a||hf(o,a,Mf(a))}function AC(o,a,u){return u=typeof u=="function"?u:i,hf(o,a,Mf(a),u)}function OC(o){return km(o)&&o!=+o}function PC(o){if(m1(o))throw new Ue(r);return Bd(o)}function DC(o){return o===null}function BC(o){return o==null}function km(o){return typeof o=="number"||Gt(o)&&br(o)==Ce}function ta(o){if(!Gt(o)||br(o)!=le)return!1;var a=ul(o);if(a===null)return!0;var u=pt.call(a,"constructor")&&a.constructor;return typeof u=="function"&&u instanceof u&&sl.call(u)==AS}var Ff=od?Wr(od):Dw;function GC(o){return Vm(o)&&o>=-re&&o<=re}var Hm=sd?Wr(sd):Bw;function Rl(o){return typeof o=="string"||!ke(o)&&Gt(o)&&br(o)==we}function $r(o){return typeof o=="symbol"||Gt(o)&&br(o)==Ve}var qo=ad?Wr(ad):Gw;function jC(o){return o===i}function EC(o){return Gt(o)&&mr(o)==Qe}function RC(o){return Gt(o)&&br(o)==bt}var zC=Il(df),FC=Il(function(o,a){return o<=a});function Wm(o){if(!o)return[];if(Pr(o))return Rl(o)?_n(o):Or(o);if(Us&&o[Us])return xS(o[Us]());var a=mr(o),u=a==ne?ef:a==de?nl:$o;return u(o)}function ci(o){if(!o)return o===0?o:0;if(o=hn(o),o===he||o===-he){var a=o<0?-1:1;return a*Ne}return o===o?o:0}function We(o){var a=ci(o),u=a%1;return a===a?u?a-u:a:0}function qm(o){return o?co(We(o),0,Me):0}function hn(o){if(typeof o=="number")return o;if($r(o))return ye;if(Dt(o)){var a=typeof o.valueOf=="function"?o.valueOf():o;o=Dt(a)?a+"":a}if(typeof o!="string")return o===0?o:+o;o=o.replace(tt,"");var u=Za.test(o);return u||Nb.test(o)?tS(o.slice(2),u?2:8):Rn.test(o)?ye:+o}function $m(o){return Fn(o,Dr(o))}function VC(o){return o?co(We(o),-re,re):o===0?o:0}function ut(o){return o==null?"":qr(o)}var UC=ko(function(o,a){if(Qs(a)||Pr(a)){Fn(a,nr(a),o);return}for(var u in a)pt.call(a,u)&&$s(o,u,a[u])}),Jm=ko(function(o,a){Fn(a,Dr(a),o)}),zl=ko(function(o,a,u,p){Fn(a,Dr(a),o,p)}),kC=ko(function(o,a,u,p){Fn(a,nr(a),o,p)}),HC=si(af);function WC(o,a){var u=Uo(o);return a==null?u:_d(u,a)}var qC=Ze(function(o,a){o=yt(o);var u=-1,p=a.length,m=p>2?a[2]:i;for(m&&Sr(a[0],a[1],m)&&(p=1);++u<p;)for(var v=a[u],N=Dr(v),L=-1,I=N.length;++L<I;){var Q=N[L],te=o[Q];(te===i||In(te,zo[Q])&&!pt.call(o,Q))&&(o[Q]=v[Q])}return o}),$C=Ze(function(o){return o.push(i,fm),Hr(Km,i,o)});function JC(o,a){return cd(o,De(a,3),zn)}function KC(o,a){return cd(o,De(a,3),cf)}function XC(o,a){return o==null?o:lf(o,De(a,3),Dr)}function ZC(o,a){return o==null?o:Od(o,De(a,3),Dr)}function YC(o,a){return o&&zn(o,De(a,3))}function QC(o,a){return o&&cf(o,De(a,3))}function eL(o){return o==null?[]:bl(o,nr(o))}function tL(o){return o==null?[]:bl(o,Dr(o))}function Vf(o,a,u){var p=o==null?i:uo(o,a);return p===i?u:p}function rL(o,a){return o!=null&&dm(o,a,Lw)}function Uf(o,a){return o!=null&&dm(o,a,_w)}var nL=sm(function(o,a,u){a!=null&&typeof a.toString!="function"&&(a=al.call(a)),o[a]=u},Hf(Br)),iL=sm(function(o,a,u){a!=null&&typeof a.toString!="function"&&(a=al.call(a)),pt.call(o,a)?o[a].push(u):o[a]=[u]},De),oL=Ze(Ks);function nr(o){return Pr(o)?Cd(o):pf(o)}function Dr(o){return Pr(o)?Cd(o,!0):jw(o)}function sL(o,a){var u={};return a=De(a,3),zn(o,function(p,m,v){ii(u,a(p,m,v),p)}),u}function aL(o,a){var u={};return a=De(a,3),zn(o,function(p,m,v){ii(u,m,a(p,m,v))}),u}var lL=ko(function(o,a,u){Sl(o,a,u)}),Km=ko(function(o,a,u,p){Sl(o,a,u,p)}),cL=si(function(o,a){var u={};if(o==null)return u;var p=!1;a=Ot(a,function(v){return v=Oi(v,o),p||(p=v.length>1),v}),Fn(o,Tf(o),u),p&&(u=cn(u,f|h|d,n1));for(var m=a.length;m--;)vf(u,a[m]);return u});function uL(o,a){return Xm(o,jl(De(a)))}var fL=si(function(o,a){return o==null?{}:Rw(o,a)});function Xm(o,a){if(o==null)return{};var u=Ot(Tf(o),function(p){return[p]});return a=De(a),Vd(o,u,function(p,m){return a(p,m[0])})}function hL(o,a,u){a=Oi(a,o);var p=-1,m=a.length;for(m||(m=1,o=i);++p<m;){var v=o==null?i:o[Vn(a[p])];v===i&&(p=m,v=u),o=li(v)?v.call(o):v}return o}function pL(o,a,u){return o==null?o:Zs(o,a,u)}function dL(o,a,u,p){return p=typeof p=="function"?p:i,o==null?o:Zs(o,a,u,p)}var Zm=cm(nr),Ym=cm(Dr);function mL(o,a,u){var p=ke(o),m=p||Di(o)||qo(o);if(a=De(a,4),u==null){var v=o&&o.constructor;m?u=p?new v:[]:Dt(o)?u=li(v)?Uo(ul(o)):{}:u={}}return(m?sn:zn)(o,function(N,L,I){return a(u,N,L,I)}),u}function gL(o,a){return o==null?!0:vf(o,a)}function yL(o,a,u){return o==null?o:qd(o,a,wf(u))}function xL(o,a,u,p){return p=typeof p=="function"?p:i,o==null?o:qd(o,a,wf(u),p)}function $o(o){return o==null?[]:Qu(o,nr(o))}function vL(o){return o==null?[]:Qu(o,Dr(o))}function bL(o,a,u){return u===i&&(u=a,a=i),u!==i&&(u=hn(u),u=u===u?u:0),a!==i&&(a=hn(a),a=a===a?a:0),co(hn(o),a,u)}function SL(o,a,u){return a=ci(a),u===i?(u=a,a=0):u=ci(u),o=hn(o),Tw(o,a,u)}function wL(o,a,u){if(u&&typeof u!="boolean"&&Sr(o,a,u)&&(a=u=i),u===i&&(typeof a=="boolean"?(u=a,a=i):typeof o=="boolean"&&(u=o,o=i)),o===i&&a===i?(o=0,a=1):(o=ci(o),a===i?(a=o,o=0):a=ci(a)),o>a){var p=o;o=a,a=p}if(u||o%1||a%1){var m=wd();return dr(o+m*(a-o+eS("1e-"+((m+"").length-1))),a)}return gf(o,a)}var NL=Ho(function(o,a,u){return a=a.toLowerCase(),o+(u?Qm(a):a)});function Qm(o){return kf(ut(o).toLowerCase())}function eg(o){return o=ut(o),o&&o.replace(Lb,pS).replace(Hb,"")}function CL(o,a,u){o=ut(o),a=qr(a);var p=o.length;u=u===i?p:co(We(u),0,p);var m=u;return u-=a.length,u>=0&&o.slice(u,m)==a}function LL(o){return o=ut(o),o&&Mr.test(o)?o.replace(no,dS):o}function _L(o){return o=ut(o),o&&$e.test(o)?o.replace(He,"\\$&"):o}var TL=Ho(function(o,a,u){return o+(u?"-":"")+a.toLowerCase()}),IL=Ho(function(o,a,u){return o+(u?" ":"")+a.toLowerCase()}),ML=nm("toLowerCase");function AL(o,a,u){o=ut(o),a=We(a);var p=a?Ro(o):0;if(!a||p>=a)return o;var m=(a-p)/2;return Tl(dl(m),u)+o+Tl(pl(m),u)}function OL(o,a,u){o=ut(o),a=We(a);var p=a?Ro(o):0;return a&&p<a?o+Tl(a-p,u):o}function PL(o,a,u){o=ut(o),a=We(a);var p=a?Ro(o):0;return a&&p<a?Tl(a-p,u)+o:o}function DL(o,a,u){return u||a==null?a=0:a&&(a=+a),FS(ut(o).replace(at,""),a||0)}function BL(o,a,u){return(u?Sr(o,a,u):a===i)?a=1:a=We(a),yf(ut(o),a)}function GL(){var o=arguments,a=ut(o[0]);return o.length<3?a:a.replace(o[1],o[2])}var jL=Ho(function(o,a,u){return o+(u?"_":"")+a.toLowerCase()});function EL(o,a,u){return u&&typeof u!="number"&&Sr(o,a,u)&&(a=u=i),u=u===i?Me:u>>>0,u?(o=ut(o),o&&(typeof a=="string"||a!=null&&!Ff(a))&&(a=qr(a),!a&&Eo(o))?Pi(_n(o),0,u):o.split(a,u)):[]}var RL=Ho(function(o,a,u){return o+(u?" ":"")+kf(a)});function zL(o,a,u){return o=ut(o),u=u==null?0:co(We(u),0,o.length),a=qr(a),o.slice(u,u+a.length)==a}function FL(o,a,u){var p=y.templateSettings;u&&Sr(o,a,u)&&(a=i),o=ut(o),a=zl({},a,p,um);var m=zl({},a.imports,p.imports,um),v=nr(m),N=Qu(m,v),L,I,Q=0,te=a.interpolate||Ya,ie="__p += '",me=tf((a.escape||Ya).source+"|"+te.source+"|"+(te===ti?Cn:Ya).source+"|"+(a.evaluate||Ya).source+"|$","g"),Le="//# sourceURL="+(pt.call(a,"sourceURL")?(a.sourceURL+"").replace(/\s/g," "):"lodash.templateSources["+ ++Kb+"]")+`
|
|
4
|
+
`;o.replace(me,function(je,et,nt,Jr,wr,Kr){return nt||(nt=Jr),ie+=o.slice(Q,Kr).replace(_b,mS),et&&(L=!0,ie+=`' +
|
|
5
5
|
__e(`+et+`) +
|
|
6
|
-
'`),wr&&(
|
|
6
|
+
'`),wr&&(I=!0,ie+=`';
|
|
7
7
|
`+wr+`;
|
|
8
8
|
__p += '`),nt&&(ie+=`' +
|
|
9
9
|
((__t = (`+nt+`)) == null ? '' : __t) +
|
|
10
10
|
'`),Q=Kr+je.length,je}),ie+=`';
|
|
11
|
-
`;var Re=
|
|
11
|
+
`;var Re=pt.call(a,"variable")&&a.variable;Re||(ie=`with (obj) {
|
|
12
12
|
`+ie+`
|
|
13
13
|
}
|
|
14
|
-
`),ie=(
|
|
14
|
+
`),ie=(I?ie.replace(Ao,""):ie).replace(Oo,"$1").replace(Po,"$1;"),ie="function("+(Re||"obj")+`) {
|
|
15
15
|
`+(Re?"":`obj || (obj = {});
|
|
16
|
-
`)+"var __t, __p = ''"+(L?", __e = _.escape":"")+(
|
|
16
|
+
`)+"var __t, __p = ''"+(L?", __e = _.escape":"")+(I?`, __j = Array.prototype.join;
|
|
17
17
|
function print() { __p += __j.call(arguments, '') }
|
|
18
18
|
`:`;
|
|
19
19
|
`)+ie+`return __p
|
|
20
|
-
}`;var Je=ug(function(){return lt(v,Le+"return "+ie).apply(i,N)});if(Je.source=ie,Hf(Je))throw Je;return Je}function t_(o){return ut(o).toLowerCase()}function r_(o){return ut(o).toUpperCase()}function n_(o,a,u){if(o=ut(o),o&&(u||a===i))return o.replace(tt,"");if(!o||!(a=qr(a)))return o;var d=Tn(o),m=Tn(a),v=Sp(d,m),N=wp(d,m)+1;return Bi(d,v,N).join("")}function i_(o,a,u){if(o=ut(o),o&&(u||a===i))return o.replace(mt,"");if(!o||!(a=qr(a)))return o;var d=Tn(o),m=wp(d,Tn(a))+1;return Bi(d,0,m).join("")}function o_(o,a,u){if(o=ut(o),o&&(u||a===i))return o.replace(at,"");if(!o||!(a=qr(a)))return o;var d=Tn(o),m=Sp(d,Tn(a));return Bi(d,m).join("")}function s_(o,a){var u=E,d=b;if(Dt(a)){var m="separator"in a?a.separator:m;u="length"in a?We(a.length):u,d="omission"in a?qr(a.omission):d}o=ut(o);var v=o.length;if(Fo(o)){var N=Tn(o);v=N.length}if(u>=v)return o;var L=u-Vo(d);if(L<1)return d;var M=N?Bi(N,0,L).join(""):o.slice(0,L);if(m===i)return M+d;if(N&&(L+=M.length-L),Wf(m)){if(o.slice(L).search(m)){var Q,te=M;for(m.global||(m=af(m.source,ut(_n.exec(m))+"g")),m.lastIndex=0;Q=m.exec(te);)var ie=Q.index;M=M.slice(0,ie===i?L:ie)}}else if(o.indexOf(qr(m),L)!=L){var me=M.lastIndexOf(m);me>-1&&(M=M.slice(0,me))}return M+d}function a_(o){return o=ut(o),o&&jo.test(o)?o.replace(no,jS):o}var l_=$o(function(o,a,u){return o+(u?" ":"")+a.toUpperCase()}),Jf=fm("toUpperCase");function cg(o,a,u){return o=ut(o),a=u?i:a,a===i?OS(o)?zS(o):wS(o):o.match(a)||[]}var ug=Ze(function(o,a){try{return Hr(o,i,a)}catch(u){return Hf(u)?u:new Ue(u)}}),c_=li(function(o,a){return sn(a,function(u){u=Un(u),si(o,u,Uf(o[u],o))}),o});function u_(o){var a=o==null?0:o.length,u=De();return o=a?Ot(o,function(d){if(typeof d[1]!="function")throw new an(n);return[u(d[0]),d[1]]}):[],Ze(function(d){for(var m=-1;++m<a;){var v=o[m];if(Hr(v[0],this,d))return Hr(v[1],this,d)}})}function f_(o){return jw(cn(o,f))}function Kf(o){return function(){return o}}function h_(o,a){return o==null||o!==o?a:o}var d_=dm(),p_=dm(!0);function Br(o){return o}function Xf(o){return kp(typeof o=="function"?o:cn(o,f))}function m_(o){return Wp(cn(o,f))}function g_(o,a){return qp(o,cn(a,f))}var y_=Ze(function(o,a){return function(u){return Qs(u,o,a)}}),x_=Ze(function(o,a){return function(u){return Qs(o,u,a)}});function Zf(o,a,u){var d=nr(a),m=wl(a,d);u==null&&!(Dt(a)&&(m.length||!d.length))&&(u=a,a=o,o=this,m=wl(a,nr(a)));var v=!(Dt(u)&&"chain"in u)||!!u.chain,N=ui(o);return sn(m,function(L){var M=a[L];o[L]=M,N&&(o.prototype[L]=function(){var Q=this.__chain__;if(v||Q){var te=o(this.__wrapped__),ie=te.__actions__=Or(this.__actions__);return ie.push({func:M,args:arguments,thisArg:o}),te.__chain__=Q,te}return M.apply(o,Ti([this.value()],arguments))})}),o}function v_(){return rr._===this&&(rr._=WS),this}function Yf(){}function b_(o){return o=We(o),Ze(function(a){return $p(a,o)})}var S_=Mf(Ot),w_=Mf(gp),N_=Mf(Qu);function fg(o){return jf(o)?ef(Un(o)):Qw(o)}function C_(o){return function(a){return o==null?i:fo(o,a)}}var L_=mm(),__=mm(!0);function Qf(){return[]}function eh(){return!1}function T_(){return{}}function I_(){return""}function M_(){return!0}function A_(o,a){if(o=We(o),o<1||o>re)return[];var u=Me,d=pr(o,Me);a=De(a),o-=Me;for(var m=nf(d,a);++u<o;)a(u);return m}function O_(o){return ke(o)?Ot(o,Un):$r(o)?[o]:Or(Om(ut(o)))}function P_(o){var a=++kS;return ut(o)+a}var D_=Il(function(o,a){return o+a},0),B_=Af("ceil"),G_=Il(function(o,a){return o/a},1),j_=Af("floor");function E_(o){return o&&o.length?Sl(o,Br,mf):i}function R_(o,a){return o&&o.length?Sl(o,De(a,2),mf):i}function z_(o){return vp(o,Br)}function F_(o,a){return vp(o,De(a,2))}function V_(o){return o&&o.length?Sl(o,Br,vf):i}function U_(o,a){return o&&o.length?Sl(o,De(a,2),vf):i}var k_=Il(function(o,a){return o*a},1),H_=Af("round"),W_=Il(function(o,a){return o-a},0);function q_(o){return o&&o.length?rf(o,Br):0}function $_(o,a){return o&&o.length?rf(o,De(a,2)):0}return x.after=mC,x.ary=Um,x.assign=rL,x.assignIn=rg,x.assignInWith=Vl,x.assignWith=nL,x.at=iL,x.before=km,x.bind=Uf,x.bindAll=c_,x.bindKey=Hm,x.castArray=TC,x.chain=zm,x.chunk=j1,x.compact=E1,x.concat=R1,x.cond=u_,x.conforms=f_,x.constant=Kf,x.countBy=qN,x.create=oL,x.curry=Wm,x.curryRight=qm,x.debounce=$m,x.defaults=sL,x.defaultsDeep=aL,x.defer=gC,x.delay=yC,x.difference=z1,x.differenceBy=F1,x.differenceWith=V1,x.drop=U1,x.dropRight=k1,x.dropRightWhile=H1,x.dropWhile=W1,x.fill=q1,x.filter=JN,x.flatMap=ZN,x.flatMapDeep=YN,x.flatMapDepth=QN,x.flatten=Gm,x.flattenDeep=$1,x.flattenDepth=J1,x.flip=xC,x.flow=d_,x.flowRight=p_,x.fromPairs=K1,x.functions=pL,x.functionsIn=mL,x.groupBy=eC,x.initial=Z1,x.intersection=Y1,x.intersectionBy=Q1,x.intersectionWith=eN,x.invert=yL,x.invertBy=xL,x.invokeMap=rC,x.iteratee=Xf,x.keyBy=nC,x.keys=nr,x.keysIn=Dr,x.map=Gl,x.mapKeys=bL,x.mapValues=SL,x.matches=m_,x.matchesProperty=g_,x.memoize=El,x.merge=wL,x.mergeWith=ng,x.method=y_,x.methodOf=x_,x.mixin=Zf,x.negate=Rl,x.nthArg=b_,x.omit=NL,x.omitBy=CL,x.once=vC,x.orderBy=iC,x.over=S_,x.overArgs=bC,x.overEvery=w_,x.overSome=N_,x.partial=kf,x.partialRight=Jm,x.partition=oC,x.pick=LL,x.pickBy=ig,x.property=fg,x.propertyOf=C_,x.pull=iN,x.pullAll=Em,x.pullAllBy=oN,x.pullAllWith=sN,x.pullAt=aN,x.range=L_,x.rangeRight=__,x.rearg=SC,x.reject=lC,x.remove=lN,x.rest=wC,x.reverse=Ff,x.sampleSize=uC,x.set=TL,x.setWith=IL,x.shuffle=fC,x.slice=cN,x.sortBy=pC,x.sortedUniq=gN,x.sortedUniqBy=yN,x.split=ZL,x.spread=NC,x.tail=xN,x.take=vN,x.takeRight=bN,x.takeRightWhile=SN,x.takeWhile=wN,x.tap=EN,x.throttle=CC,x.thru=Bl,x.toArray=Qm,x.toPairs=og,x.toPairsIn=sg,x.toPath=O_,x.toPlainObject=tg,x.transform=ML,x.unary=LC,x.union=NN,x.unionBy=CN,x.unionWith=LN,x.uniq=_N,x.uniqBy=TN,x.uniqWith=IN,x.unset=AL,x.unzip=Vf,x.unzipWith=Rm,x.update=OL,x.updateWith=PL,x.values=Xo,x.valuesIn=DL,x.without=MN,x.words=cg,x.wrap=_C,x.xor=AN,x.xorBy=ON,x.xorWith=PN,x.zip=DN,x.zipObject=BN,x.zipObjectDeep=GN,x.zipWith=jN,x.entries=og,x.entriesIn=sg,x.extend=rg,x.extendWith=Vl,Zf(x,x),x.add=D_,x.attempt=ug,x.camelCase=EL,x.capitalize=ag,x.ceil=B_,x.clamp=BL,x.clone=IC,x.cloneDeep=AC,x.cloneDeepWith=OC,x.cloneWith=MC,x.conformsTo=PC,x.deburr=lg,x.defaultTo=h_,x.divide=G_,x.endsWith=RL,x.eq=Mn,x.escape=zL,x.escapeRegExp=FL,x.every=$N,x.find=KN,x.findIndex=Dm,x.findKey=lL,x.findLast=XN,x.findLastIndex=Bm,x.findLastKey=cL,x.floor=j_,x.forEach=Fm,x.forEachRight=Vm,x.forIn=uL,x.forInRight=fL,x.forOwn=hL,x.forOwnRight=dL,x.get=qf,x.gt=DC,x.gte=BC,x.has=gL,x.hasIn=$f,x.head=jm,x.identity=Br,x.includes=tC,x.indexOf=X1,x.inRange=GL,x.invoke=vL,x.isArguments=mo,x.isArray=ke,x.isArrayBuffer=GC,x.isArrayLike=Pr,x.isArrayLikeObject=zt,x.isBoolean=jC,x.isBuffer=Gi,x.isDate=EC,x.isElement=RC,x.isEmpty=zC,x.isEqual=FC,x.isEqualWith=VC,x.isError=Hf,x.isFinite=UC,x.isFunction=ui,x.isInteger=Km,x.isLength=zl,x.isMap=Xm,x.isMatch=kC,x.isMatchWith=HC,x.isNaN=WC,x.isNative=qC,x.isNil=JC,x.isNull=$C,x.isNumber=Zm,x.isObject=Dt,x.isObjectLike=Gt,x.isPlainObject=oa,x.isRegExp=Wf,x.isSafeInteger=KC,x.isSet=Ym,x.isString=Fl,x.isSymbol=$r,x.isTypedArray=Ko,x.isUndefined=XC,x.isWeakMap=ZC,x.isWeakSet=YC,x.join=tN,x.kebabCase=VL,x.last=fn,x.lastIndexOf=rN,x.lowerCase=UL,x.lowerFirst=kL,x.lt=QC,x.lte=eL,x.max=E_,x.maxBy=R_,x.mean=z_,x.meanBy=F_,x.min=V_,x.minBy=U_,x.stubArray=Qf,x.stubFalse=eh,x.stubObject=T_,x.stubString=I_,x.stubTrue=M_,x.multiply=k_,x.nth=nN,x.noConflict=v_,x.noop=Yf,x.now=jl,x.pad=HL,x.padEnd=WL,x.padStart=qL,x.parseInt=$L,x.random=jL,x.reduce=sC,x.reduceRight=aC,x.repeat=JL,x.replace=KL,x.result=_L,x.round=H_,x.runInContext=P,x.sample=cC,x.size=hC,x.snakeCase=XL,x.some=dC,x.sortedIndex=uN,x.sortedIndexBy=fN,x.sortedIndexOf=hN,x.sortedLastIndex=dN,x.sortedLastIndexBy=pN,x.sortedLastIndexOf=mN,x.startCase=YL,x.startsWith=QL,x.subtract=W_,x.sum=q_,x.sumBy=$_,x.template=e_,x.times=A_,x.toFinite=fi,x.toInteger=We,x.toLength=eg,x.toLower=t_,x.toNumber=hn,x.toSafeInteger=tL,x.toString=ut,x.toUpper=r_,x.trim=n_,x.trimEnd=i_,x.trimStart=o_,x.truncate=s_,x.unescape=a_,x.uniqueId=P_,x.upperCase=l_,x.upperFirst=Jf,x.each=Fm,x.eachRight=Vm,x.first=jm,Zf(x,function(){var o={};return Fn(x,function(a,u){dt.call(x.prototype,u)||(o[u]=a)}),o}(),{chain:!1}),x.VERSION=e,sn(["bind","bindKey","curry","curryRight","partial","partialRight"],function(o){x[o].placeholder=x}),sn(["drop","take"],function(o,a){rt.prototype[o]=function(u){u=u===i?1:Xt(We(u),0);var d=this.__filtered__&&!a?new rt(this):this.clone();return d.__filtered__?d.__takeCount__=pr(u,d.__takeCount__):d.__views__.push({size:pr(u,Me),type:o+(d.__dir__<0?"Right":"")}),d},rt.prototype[o+"Right"]=function(u){return this.reverse()[o](u).reverse()}}),sn(["filter","map","takeWhile"],function(o,a){var u=a+1,d=u==z||u==$;rt.prototype[o]=function(m){var v=this.clone();return v.__iteratees__.push({iteratee:De(m,3),type:u}),v.__filtered__=v.__filtered__||d,v}}),sn(["head","last"],function(o,a){var u="take"+(a?"Right":"");rt.prototype[o]=function(){return this[u](1).value()[0]}}),sn(["initial","tail"],function(o,a){var u="drop"+(a?"":"Right");rt.prototype[o]=function(){return this.__filtered__?new rt(this):this[u](1)}}),rt.prototype.compact=function(){return this.filter(Br)},rt.prototype.find=function(o){return this.filter(o).head()},rt.prototype.findLast=function(o){return this.reverse().find(o)},rt.prototype.invokeMap=Ze(function(o,a){return typeof o=="function"?new rt(this):this.map(function(u){return Qs(u,o,a)})}),rt.prototype.reject=function(o){return this.filter(Rl(De(o)))},rt.prototype.slice=function(o,a){o=We(o);var u=this;return u.__filtered__&&(o>0||a<0)?new rt(u):(o<0?u=u.takeRight(-o):o&&(u=u.drop(o)),a!==i&&(a=We(a),u=a<0?u.dropRight(-a):u.take(a-o)),u)},rt.prototype.takeRightWhile=function(o){return this.reverse().takeWhile(o).reverse()},rt.prototype.toArray=function(){return this.take(Me)},Fn(rt.prototype,function(o,a){var u=/^(?:filter|find|map|reject)|While$/.test(a),d=/^(?:head|last)$/.test(a),m=x[d?"take"+(a=="last"?"Right":""):a],v=d||/^find/.test(a);!m||(x.prototype[a]=function(){var N=this.__wrapped__,L=d?[1]:arguments,M=N instanceof rt,Q=L[0],te=M||ke(N),ie=function(et){var nt=m.apply(x,Ti([et],L));return d&&me?nt[0]:nt};te&&u&&typeof Q=="function"&&Q.length!=1&&(M=te=!1);var me=this.__chain__,Le=!!this.__actions__.length,Re=v&&!me,Je=M&&!Le;if(!v&&te){N=Je?N:new rt(this);var je=o.apply(N,L);return je.__actions__.push({func:Bl,args:[ie],thisArg:i}),new ln(je,me)}return Re&&Je?o.apply(this,L):(je=this.thru(ie),Re?d?je.value()[0]:je.value():je)})}),sn(["pop","push","shift","sort","splice","unshift"],function(o){var a=sl[o],u=/^(?:push|sort|unshift)$/.test(o)?"tap":"thru",d=/^(?:pop|shift)$/.test(o);x.prototype[o]=function(){var m=arguments;if(d&&!this.__chain__){var v=this.value();return a.apply(ke(v)?v:[],m)}return this[u](function(N){return a.apply(ke(N)?N:[],m)})}}),Fn(rt.prototype,function(o,a){var u=x[a];if(u){var d=u.name+"";dt.call(Ho,d)||(Ho[d]=[]),Ho[d].push({name:a,func:u})}}),Ho[Tl(i,S).name]=[{name:"wrapper",func:i}],rt.prototype.clone=aw,rt.prototype.reverse=lw,rt.prototype.value=cw,x.prototype.at=RN,x.prototype.chain=zN,x.prototype.commit=FN,x.prototype.next=VN,x.prototype.plant=kN,x.prototype.reverse=HN,x.prototype.toJSON=x.prototype.valueOf=x.prototype.value=WN,x.prototype.first=x.prototype.head,qs&&(x.prototype[qs]=UN),x},Mi=FS();typeof define=="function"&&typeof define.amd=="object"&&define.amd?(rr._=Mi,define(function(){return Mi})):so?((so.exports=Mi)._=Mi,Ku._=Mi):rr._=Mi}).call(Hs)});import{FileLoader as _B,Loader as TB}from"three";function yg(i){return Array.isArray(i)?i:[i]}var nT=typeof global=="object"&&global&&global.Object===Object&&global,Ul=nT;var iT=typeof self=="object"&&self&&self.Object===Object&&self,oT=Ul||iT||Function("return this")(),qt=oT;var sT=qt.Symbol,Nr=sT;var xg=Object.prototype,aT=xg.hasOwnProperty,lT=xg.toString,aa=Nr?Nr.toStringTag:void 0;function cT(i){var e=aT.call(i,aa),t=i[aa];try{i[aa]=void 0;var r=!0}catch(s){}var n=lT.call(i);return r&&(e?i[aa]=t:delete i[aa]),n}var vg=cT;var uT=Object.prototype,fT=uT.toString;function hT(i){return fT.call(i)}var bg=hT;var dT="[object Null]",pT="[object Undefined]",Sg=Nr?Nr.toStringTag:void 0;function mT(i){return i==null?i===void 0?pT:dT:Sg&&Sg in Object(i)?vg(i):bg(i)}var Xr=mT;function gT(i){return i!=null&&typeof i=="object"}var gr=gT;var yT="[object Symbol]";function xT(i){return typeof i=="symbol"||gr(i)&&Xr(i)==yT}var Zo=xT;function vT(i,e){for(var t=-1,r=i==null?0:i.length,n=Array(r);++t<r;)n[t]=e(i[t],t,i);return n}var kl=vT;var bT=Array.isArray,cr=bT;var ST=1/0,wg=Nr?Nr.prototype:void 0,Ng=wg?wg.toString:void 0;function Cg(i){if(typeof i=="string")return i;if(cr(i))return kl(i,Cg)+"";if(Zo(i))return Ng?Ng.call(i):"";var e=i+"";return e=="0"&&1/i==-ST?"-0":e}var Lg=Cg;function wT(i){var e=typeof i;return i!=null&&(e=="object"||e=="function")}var yr=wT;function NT(i){return i}var Hl=NT;var CT="[object AsyncFunction]",LT="[object Function]",_T="[object GeneratorFunction]",TT="[object Proxy]";function IT(i){if(!yr(i))return!1;var e=Xr(i);return e==LT||e==_T||e==CT||e==TT}var Yo=IT;var MT=qt["__core-js_shared__"],Wl=MT;var _g=function(){var i=/[^.]+$/.exec(Wl&&Wl.keys&&Wl.keys.IE_PROTO||"");return i?"Symbol(src)_1."+i:""}();function AT(i){return!!_g&&_g in i}var Tg=AT;var OT=Function.prototype,PT=OT.toString;function DT(i){if(i!=null){try{return PT.call(i)}catch(e){}try{return i+""}catch(e){}}return""}var di=DT;var BT=/[\\^$.*+?()[\]{}|]/g,GT=/^\[object .+?Constructor\]$/,jT=Function.prototype,ET=Object.prototype,RT=jT.toString,zT=ET.hasOwnProperty,FT=RegExp("^"+RT.call(zT).replace(BT,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function VT(i){if(!yr(i)||Tg(i))return!1;var e=Yo(i)?FT:GT;return e.test(di(i))}var Ig=VT;function UT(i,e){return i==null?void 0:i[e]}var Mg=UT;function kT(i,e){var t=Mg(i,e);return Ig(t)?t:void 0}var Gr=kT;var HT=Gr(qt,"WeakMap"),ql=HT;var Ag=Object.create,WT=function(){function i(){}return function(e){if(!yr(e))return{};if(Ag)return Ag(e);i.prototype=e;var t=new i;return i.prototype=void 0,t}}(),Og=WT;function qT(i,e,t){switch(t.length){case 0:return i.call(e);case 1:return i.call(e,t[0]);case 2:return i.call(e,t[0],t[1]);case 3:return i.call(e,t[0],t[1],t[2])}return i.apply(e,t)}var Pg=qT;function $T(i,e){var t=-1,r=i.length;for(e||(e=Array(r));++t<r;)e[t]=i[t];return e}var $l=$T;var JT=800,KT=16,XT=Date.now;function ZT(i){var e=0,t=0;return function(){var r=XT(),n=KT-(r-t);if(t=r,n>0){if(++e>=JT)return arguments[0]}else e=0;return i.apply(void 0,arguments)}}var Dg=ZT;function YT(i){return function(){return i}}var Bg=YT;var QT=function(){try{var i=Gr(Object,"defineProperty");return i({},"",{}),i}catch(e){}}(),Qo=QT;var eI=Qo?function(i,e){return Qo(i,"toString",{configurable:!0,enumerable:!1,value:Bg(e),writable:!0})}:Hl,Gg=eI;var tI=Dg(Gg),Jl=tI;function rI(i,e){for(var t=-1,r=i==null?0:i.length;++t<r&&e(i[t],t,i)!==!1;);return i}var jg=rI;var nI=9007199254740991,iI=/^(?:0|[1-9]\d*)$/;function oI(i,e){var t=typeof i;return e=e==null?nI:e,!!e&&(t=="number"||t!="symbol"&&iI.test(i))&&i>-1&&i%1==0&&i<e}var Kl=oI;function sI(i,e,t){e=="__proto__"&&Qo?Qo(i,e,{configurable:!0,enumerable:!0,value:t,writable:!0}):i[e]=t}var es=sI;function aI(i,e){return i===e||i!==i&&e!==e}var ji=aI;var lI=Object.prototype,cI=lI.hasOwnProperty;function uI(i,e,t){var r=i[e];(!(cI.call(i,e)&&ji(r,t))||t===void 0&&!(e in i))&&es(i,e,t)}var Xl=uI;function fI(i,e,t,r){var n=!t;t||(t={});for(var s=-1,l=e.length;++s<l;){var c=e[s],f=r?r(t[c],i[c],c,t,i):void 0;f===void 0&&(f=i[c]),n?es(t,c,f):Xl(t,c,f)}return t}var dn=fI;var Eg=Math.max;function hI(i,e,t){return e=Eg(e===void 0?i.length-1:e,0),function(){for(var r=arguments,n=-1,s=Eg(r.length-e,0),l=Array(s);++n<s;)l[n]=r[e+n];n=-1;for(var c=Array(e+1);++n<e;)c[n]=r[n];return c[e]=t(l),Pg(i,this,c)}}var Zl=hI;function dI(i,e){return Jl(Zl(i,e,Hl),i+"")}var Rg=dI;var pI=9007199254740991;function mI(i){return typeof i=="number"&&i>-1&&i%1==0&&i<=pI}var Yl=mI;function gI(i){return i!=null&&Yl(i.length)&&!Yo(i)}var Ei=gI;function yI(i,e,t){if(!yr(t))return!1;var r=typeof e;return(r=="number"?Ei(t)&&Kl(e,t.length):r=="string"&&e in t)?ji(t[e],i):!1}var zg=yI;function xI(i){return Rg(function(e,t){var r=-1,n=t.length,s=n>1?t[n-1]:void 0,l=n>2?t[2]:void 0;for(s=i.length>3&&typeof s=="function"?(n--,s):void 0,l&&zg(t[0],t[1],l)&&(s=n<3?void 0:s,n=1),e=Object(e);++r<n;){var c=t[r];c&&i(e,c,r,s)}return e})}var Fg=xI;var vI=Object.prototype;function bI(i){var e=i&&i.constructor,t=typeof e=="function"&&e.prototype||vI;return i===t}var ts=bI;function SI(i,e){for(var t=-1,r=Array(i);++t<i;)r[t]=e(t);return r}var Vg=SI;var wI="[object Arguments]";function NI(i){return gr(i)&&Xr(i)==wI}var nh=NI;var Ug=Object.prototype,CI=Ug.hasOwnProperty,LI=Ug.propertyIsEnumerable,_I=nh(function(){return arguments}())?nh:function(i){return gr(i)&&CI.call(i,"callee")&&!LI.call(i,"callee")},go=_I;function TI(){return!1}var kg=TI;var Hg=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Wg=Hg&&typeof module=="object"&&module&&!module.nodeType&&module,II=Wg&&Wg.exports===Hg,qg=II?qt.Buffer:void 0,MI=qg?qg.isBuffer:void 0,AI=MI||kg,rs=AI;var OI="[object Arguments]",PI="[object Array]",DI="[object Boolean]",BI="[object Date]",GI="[object Error]",jI="[object Function]",EI="[object Map]",RI="[object Number]",zI="[object Object]",FI="[object RegExp]",VI="[object Set]",UI="[object String]",kI="[object WeakMap]",HI="[object ArrayBuffer]",WI="[object DataView]",qI="[object Float32Array]",$I="[object Float64Array]",JI="[object Int8Array]",KI="[object Int16Array]",XI="[object Int32Array]",ZI="[object Uint8Array]",YI="[object Uint8ClampedArray]",QI="[object Uint16Array]",eM="[object Uint32Array]",Tt={};Tt[qI]=Tt[$I]=Tt[JI]=Tt[KI]=Tt[XI]=Tt[ZI]=Tt[YI]=Tt[QI]=Tt[eM]=!0;Tt[OI]=Tt[PI]=Tt[HI]=Tt[DI]=Tt[WI]=Tt[BI]=Tt[GI]=Tt[jI]=Tt[EI]=Tt[RI]=Tt[zI]=Tt[FI]=Tt[VI]=Tt[UI]=Tt[kI]=!1;function tM(i){return gr(i)&&Yl(i.length)&&!!Tt[Xr(i)]}var $g=tM;function rM(i){return function(e){return i(e)}}var ns=rM;var Jg=typeof exports=="object"&&exports&&!exports.nodeType&&exports,la=Jg&&typeof module=="object"&&module&&!module.nodeType&&module,nM=la&&la.exports===Jg,ih=nM&&Ul.process,iM=function(){try{var i=la&&la.require&&la.require("util").types;return i||ih&&ih.binding&&ih.binding("util")}catch(e){}}(),pi=iM;var Kg=pi&&pi.isTypedArray,oM=Kg?ns(Kg):$g,Ql=oM;var sM=Object.prototype,aM=sM.hasOwnProperty;function lM(i,e){var t=cr(i),r=!t&&go(i),n=!t&&!r&&rs(i),s=!t&&!r&&!n&&Ql(i),l=t||r||n||s,c=l?Vg(i.length,String):[],f=c.length;for(var h in i)(e||aM.call(i,h))&&!(l&&(h=="length"||n&&(h=="offset"||h=="parent")||s&&(h=="buffer"||h=="byteLength"||h=="byteOffset")||Kl(h,f)))&&c.push(h);return c}var ec=lM;function cM(i,e){return function(t){return i(e(t))}}var tc=cM;var uM=tc(Object.keys,Object),Xg=uM;var fM=Object.prototype,hM=fM.hasOwnProperty;function dM(i){if(!ts(i))return Xg(i);var e=[];for(var t in Object(i))hM.call(i,t)&&t!="constructor"&&e.push(t);return e}var Zg=dM;function pM(i){return Ei(i)?ec(i):Zg(i)}var is=pM;function mM(i){var e=[];if(i!=null)for(var t in Object(i))e.push(t);return e}var Yg=mM;var gM=Object.prototype,yM=gM.hasOwnProperty;function xM(i){if(!yr(i))return Yg(i);var e=ts(i),t=[];for(var r in i)r=="constructor"&&(e||!yM.call(i,r))||t.push(r);return t}var Qg=xM;function vM(i){return Ei(i)?ec(i,!0):Qg(i)}var kn=vM;var bM=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,SM=/^\w*$/;function wM(i,e){if(cr(i))return!1;var t=typeof i;return t=="number"||t=="symbol"||t=="boolean"||i==null||Zo(i)?!0:SM.test(i)||!bM.test(i)||e!=null&&i in Object(e)}var ey=wM;var NM=Gr(Object,"create"),mi=NM;function CM(){this.__data__=mi?mi(null):{},this.size=0}var ty=CM;function LM(i){var e=this.has(i)&&delete this.__data__[i];return this.size-=e?1:0,e}var ry=LM;var _M="__lodash_hash_undefined__",TM=Object.prototype,IM=TM.hasOwnProperty;function MM(i){var e=this.__data__;if(mi){var t=e[i];return t===_M?void 0:t}return IM.call(e,i)?e[i]:void 0}var ny=MM;var AM=Object.prototype,OM=AM.hasOwnProperty;function PM(i){var e=this.__data__;return mi?e[i]!==void 0:OM.call(e,i)}var iy=PM;var DM="__lodash_hash_undefined__";function BM(i,e){var t=this.__data__;return this.size+=this.has(i)?0:1,t[i]=mi&&e===void 0?DM:e,this}var oy=BM;function os(i){var e=-1,t=i==null?0:i.length;for(this.clear();++e<t;){var r=i[e];this.set(r[0],r[1])}}os.prototype.clear=ty;os.prototype.delete=ry;os.prototype.get=ny;os.prototype.has=iy;os.prototype.set=oy;var oh=os;function GM(){this.__data__=[],this.size=0}var sy=GM;function jM(i,e){for(var t=i.length;t--;)if(ji(i[t][0],e))return t;return-1}var Ri=jM;var EM=Array.prototype,RM=EM.splice;function zM(i){var e=this.__data__,t=Ri(e,i);if(t<0)return!1;var r=e.length-1;return t==r?e.pop():RM.call(e,t,1),--this.size,!0}var ay=zM;function FM(i){var e=this.__data__,t=Ri(e,i);return t<0?void 0:e[t][1]}var ly=FM;function VM(i){return Ri(this.__data__,i)>-1}var cy=VM;function UM(i,e){var t=this.__data__,r=Ri(t,i);return r<0?(++this.size,t.push([i,e])):t[r][1]=e,this}var uy=UM;function ss(i){var e=-1,t=i==null?0:i.length;for(this.clear();++e<t;){var r=i[e];this.set(r[0],r[1])}}ss.prototype.clear=sy;ss.prototype.delete=ay;ss.prototype.get=ly;ss.prototype.has=cy;ss.prototype.set=uy;var zi=ss;var kM=Gr(qt,"Map"),Fi=kM;function HM(){this.size=0,this.__data__={hash:new oh,map:new(Fi||zi),string:new oh}}var fy=HM;function WM(i){var e=typeof i;return e=="string"||e=="number"||e=="symbol"||e=="boolean"?i!=="__proto__":i===null}var hy=WM;function qM(i,e){var t=i.__data__;return hy(e)?t[typeof e=="string"?"string":"hash"]:t.map}var Vi=qM;function $M(i){var e=Vi(this,i).delete(i);return this.size-=e?1:0,e}var dy=$M;function JM(i){return Vi(this,i).get(i)}var py=JM;function KM(i){return Vi(this,i).has(i)}var my=KM;function XM(i,e){var t=Vi(this,i),r=t.size;return t.set(i,e),this.size+=t.size==r?0:1,this}var gy=XM;function as(i){var e=-1,t=i==null?0:i.length;for(this.clear();++e<t;){var r=i[e];this.set(r[0],r[1])}}as.prototype.clear=fy;as.prototype.delete=dy;as.prototype.get=py;as.prototype.has=my;as.prototype.set=gy;var ca=as;var ZM="Expected a function";function sh(i,e){if(typeof i!="function"||e!=null&&typeof e!="function")throw new TypeError(ZM);var t=function(){var r=arguments,n=e?e.apply(this,r):r[0],s=t.cache;if(s.has(n))return s.get(n);var l=i.apply(this,r);return t.cache=s.set(n,l)||s,l};return t.cache=new(sh.Cache||ca),t}sh.Cache=ca;var yy=sh;var YM=500;function QM(i){var e=yy(i,function(r){return t.size===YM&&t.clear(),r}),t=e.cache;return e}var xy=QM;var eA=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,tA=/\\(\\)?/g,rA=xy(function(i){var e=[];return i.charCodeAt(0)===46&&e.push(""),i.replace(eA,function(t,r,n,s){e.push(n?s.replace(tA,"$1"):r||t)}),e}),vy=rA;function nA(i){return i==null?"":Lg(i)}var by=nA;function iA(i,e){return cr(i)?i:ey(i,e)?[i]:vy(by(i))}var ls=iA;var oA=1/0;function sA(i){if(typeof i=="string"||Zo(i))return i;var e=i+"";return e=="0"&&1/i==-oA?"-0":e}var rc=sA;function aA(i,e){e=ls(e,i);for(var t=0,r=e.length;i!=null&&t<r;)i=i[rc(e[t++])];return t&&t==r?i:void 0}var Sy=aA;function lA(i,e){for(var t=-1,r=e.length,n=i.length;++t<r;)i[n+t]=e[t];return i}var cs=lA;var wy=Nr?Nr.isConcatSpreadable:void 0;function cA(i){return cr(i)||go(i)||!!(wy&&i&&i[wy])}var Ny=cA;function Cy(i,e,t,r,n){var s=-1,l=i.length;for(t||(t=Ny),n||(n=[]);++s<l;){var c=i[s];e>0&&t(c)?e>1?Cy(c,e-1,t,r,n):cs(n,c):r||(n[n.length]=c)}return n}var Ly=Cy;function uA(i){var e=i==null?0:i.length;return e?Ly(i,1):[]}var _y=uA;function fA(i){return Jl(Zl(i,void 0,_y),i+"")}var Ty=fA;var hA=tc(Object.getPrototypeOf,Object),us=hA;var dA="[object Object]",pA=Function.prototype,mA=Object.prototype,Iy=pA.toString,gA=mA.hasOwnProperty,yA=Iy.call(Object);function xA(i){if(!gr(i)||Xr(i)!=dA)return!1;var e=us(i);if(e===null)return!0;var t=gA.call(e,"constructor")&&e.constructor;return typeof t=="function"&&t instanceof t&&Iy.call(t)==yA}var nc=xA;function vA(i,e,t){var r=-1,n=i.length;e<0&&(e=-e>n?0:n+e),t=t>n?n:t,t<0&&(t+=n),n=e>t?0:t-e>>>0,e>>>=0;for(var s=Array(n);++r<n;)s[r]=i[r+e];return s}var My=vA;function bA(){this.__data__=new zi,this.size=0}var Ay=bA;function SA(i){var e=this.__data__,t=e.delete(i);return this.size=e.size,t}var Oy=SA;function wA(i){return this.__data__.get(i)}var Py=wA;function NA(i){return this.__data__.has(i)}var Dy=NA;var CA=200;function LA(i,e){var t=this.__data__;if(t instanceof zi){var r=t.__data__;if(!Fi||r.length<CA-1)return r.push([i,e]),this.size=++t.size,this;t=this.__data__=new ca(r)}return t.set(i,e),this.size=t.size,this}var By=LA;function fs(i){var e=this.__data__=new zi(i);this.size=e.size}fs.prototype.clear=Ay;fs.prototype.delete=Oy;fs.prototype.get=Py;fs.prototype.has=Dy;fs.prototype.set=By;var ic=fs;function _A(i,e){return i&&dn(e,is(e),i)}var Gy=_A;function TA(i,e){return i&&dn(e,kn(e),i)}var jy=TA;var Ey=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Ry=Ey&&typeof module=="object"&&module&&!module.nodeType&&module,IA=Ry&&Ry.exports===Ey,zy=IA?qt.Buffer:void 0,Fy=zy?zy.allocUnsafe:void 0;function MA(i,e){if(e)return i.slice();var t=i.length,r=Fy?Fy(t):new i.constructor(t);return i.copy(r),r}var oc=MA;function AA(i,e){for(var t=-1,r=i==null?0:i.length,n=0,s=[];++t<r;){var l=i[t];e(l,t,i)&&(s[n++]=l)}return s}var Vy=AA;function OA(){return[]}var sc=OA;var PA=Object.prototype,DA=PA.propertyIsEnumerable,Uy=Object.getOwnPropertySymbols,BA=Uy?function(i){return i==null?[]:(i=Object(i),Vy(Uy(i),function(e){return DA.call(i,e)}))}:sc,hs=BA;function GA(i,e){return dn(i,hs(i),e)}var ky=GA;var jA=Object.getOwnPropertySymbols,EA=jA?function(i){for(var e=[];i;)cs(e,hs(i)),i=us(i);return e}:sc,ac=EA;function RA(i,e){return dn(i,ac(i),e)}var Hy=RA;function zA(i,e,t){var r=e(i);return cr(i)?r:cs(r,t(i))}var lc=zA;function FA(i){return lc(i,is,hs)}var Wy=FA;function VA(i){return lc(i,kn,ac)}var cc=VA;var UA=Gr(qt,"DataView"),uc=UA;var kA=Gr(qt,"Promise"),fc=kA;var HA=Gr(qt,"Set"),hc=HA;var qy="[object Map]",WA="[object Object]",$y="[object Promise]",Jy="[object Set]",Ky="[object WeakMap]",Xy="[object DataView]",qA=di(uc),$A=di(Fi),JA=di(fc),KA=di(hc),XA=di(ql),yo=Xr;(uc&&yo(new uc(new ArrayBuffer(1)))!=Xy||Fi&&yo(new Fi)!=qy||fc&&yo(fc.resolve())!=$y||hc&&yo(new hc)!=Jy||ql&&yo(new ql)!=Ky)&&(yo=function(i){var e=Xr(i),t=e==WA?i.constructor:void 0,r=t?di(t):"";if(r)switch(r){case qA:return Xy;case $A:return qy;case JA:return $y;case KA:return Jy;case XA:return Ky}return e});var ds=yo;var ZA=Object.prototype,YA=ZA.hasOwnProperty;function QA(i){var e=i.length,t=new i.constructor(e);return e&&typeof i[0]=="string"&&YA.call(i,"index")&&(t.index=i.index,t.input=i.input),t}var Zy=QA;var eO=qt.Uint8Array,ah=eO;function tO(i){var e=new i.constructor(i.byteLength);return new ah(e).set(new ah(i)),e}var ps=tO;function rO(i,e){var t=e?ps(i.buffer):i.buffer;return new i.constructor(t,i.byteOffset,i.byteLength)}var Yy=rO;var nO=/\w*$/;function iO(i){var e=new i.constructor(i.source,nO.exec(i));return e.lastIndex=i.lastIndex,e}var Qy=iO;var ex=Nr?Nr.prototype:void 0,tx=ex?ex.valueOf:void 0;function oO(i){return tx?Object(tx.call(i)):{}}var rx=oO;function sO(i,e){var t=e?ps(i.buffer):i.buffer;return new i.constructor(t,i.byteOffset,i.length)}var dc=sO;var aO="[object Boolean]",lO="[object Date]",cO="[object Map]",uO="[object Number]",fO="[object RegExp]",hO="[object Set]",dO="[object String]",pO="[object Symbol]",mO="[object ArrayBuffer]",gO="[object DataView]",yO="[object Float32Array]",xO="[object Float64Array]",vO="[object Int8Array]",bO="[object Int16Array]",SO="[object Int32Array]",wO="[object Uint8Array]",NO="[object Uint8ClampedArray]",CO="[object Uint16Array]",LO="[object Uint32Array]";function _O(i,e,t){var r=i.constructor;switch(e){case mO:return ps(i);case aO:case lO:return new r(+i);case gO:return Yy(i,t);case yO:case xO:case vO:case bO:case SO:case wO:case NO:case CO:case LO:return dc(i,t);case cO:return new r;case uO:case dO:return new r(i);case fO:return Qy(i);case hO:return new r;case pO:return rx(i)}}var nx=_O;function TO(i){return typeof i.constructor=="function"&&!ts(i)?Og(us(i)):{}}var pc=TO;var IO="[object Map]";function MO(i){return gr(i)&&ds(i)==IO}var ix=MO;var ox=pi&&pi.isMap,AO=ox?ns(ox):ix,sx=AO;var OO="[object Set]";function PO(i){return gr(i)&&ds(i)==OO}var ax=PO;var lx=pi&&pi.isSet,DO=lx?ns(lx):ax,cx=DO;var BO=1,GO=2,jO=4,ux="[object Arguments]",EO="[object Array]",RO="[object Boolean]",zO="[object Date]",FO="[object Error]",fx="[object Function]",VO="[object GeneratorFunction]",UO="[object Map]",kO="[object Number]",hx="[object Object]",HO="[object RegExp]",WO="[object Set]",qO="[object String]",$O="[object Symbol]",JO="[object WeakMap]",KO="[object ArrayBuffer]",XO="[object DataView]",ZO="[object Float32Array]",YO="[object Float64Array]",QO="[object Int8Array]",eP="[object Int16Array]",tP="[object Int32Array]",rP="[object Uint8Array]",nP="[object Uint8ClampedArray]",iP="[object Uint16Array]",oP="[object Uint32Array]",Nt={};Nt[ux]=Nt[EO]=Nt[KO]=Nt[XO]=Nt[RO]=Nt[zO]=Nt[ZO]=Nt[YO]=Nt[QO]=Nt[eP]=Nt[tP]=Nt[UO]=Nt[kO]=Nt[hx]=Nt[HO]=Nt[WO]=Nt[qO]=Nt[$O]=Nt[rP]=Nt[nP]=Nt[iP]=Nt[oP]=!0;Nt[FO]=Nt[fx]=Nt[JO]=!1;function mc(i,e,t,r,n,s){var l,c=e&BO,f=e&GO,h=e&jO;if(t&&(l=n?t(i,r,n,s):t(i)),l!==void 0)return l;if(!yr(i))return i;var p=cr(i);if(p){if(l=Zy(i),!c)return $l(i,l)}else{var y=ds(i),g=y==fx||y==VO;if(rs(i))return oc(i,c);if(y==hx||y==ux||g&&!n){if(l=f||g?{}:pc(i),!c)return f?Hy(i,jy(l,i)):ky(i,Gy(l,i))}else{if(!Nt[y])return n?i:{};l=nx(i,y,c)}}s||(s=new ic);var w=s.get(i);if(w)return w;s.set(i,l),cx(i)?i.forEach(function(C){l.add(mc(C,e,t,C,i,s))}):sx(i)&&i.forEach(function(C,B){l.set(B,mc(C,e,t,B,i,s))});var S=h?f?cc:Wy:f?kn:is,T=p?void 0:S(i);return jg(T||i,function(C,B){T&&(B=C,C=i[B]),Xl(l,B,mc(C,e,t,B,i,s))}),l}var gc=mc;var sP=1,aP=4;function lP(i){return gc(i,sP|aP)}var xo=lP;function cP(i){return function(e,t,r){for(var n=-1,s=Object(e),l=r(e),c=l.length;c--;){var f=l[i?c:++n];if(t(s[f],f,s)===!1)break}return e}}var dx=cP;var uP=dx(),px=uP;function fP(i,e,t){(t!==void 0&&!ji(i[e],t)||t===void 0&&!(e in i))&&es(i,e,t)}var ua=fP;function hP(i){return gr(i)&&Ei(i)}var mx=hP;function dP(i,e){if(!(e==="constructor"&&typeof i[e]=="function")&&e!="__proto__")return i[e]}var fa=dP;function pP(i){return dn(i,kn(i))}var gx=pP;function mP(i,e,t,r,n,s,l){var c=fa(i,t),f=fa(e,t),h=l.get(f);if(h){ua(i,t,h);return}var p=s?s(c,f,t+"",i,e,l):void 0,y=p===void 0;if(y){var g=cr(f),w=!g&&rs(f),S=!g&&!w&&Ql(f);p=f,g||w||S?cr(c)?p=c:mx(c)?p=$l(c):w?(y=!1,p=oc(f,!0)):S?(y=!1,p=dc(f,!0)):p=[]:nc(f)||go(f)?(p=c,go(c)?p=gx(c):(!yr(c)||Yo(c))&&(p=pc(f))):y=!1}y&&(l.set(f,p),n(p,f,r,s,l),l.delete(f)),ua(i,t,p)}var yx=mP;function xx(i,e,t,r,n){i!==e&&px(e,function(s,l){if(n||(n=new ic),yr(s))yx(i,e,l,t,xx,r,n);else{var c=r?r(fa(i,l),s,l+"",i,e,n):void 0;c===void 0&&(c=s),ua(i,l,c)}},kn)}var vx=xx;function gP(i){var e=i==null?0:i.length;return e?i[e-1]:void 0}var bx=gP;function yP(i,e){return e.length<2?i:Sy(i,My(e,0,-1))}var Sx=yP;var xP=Fg(function(i,e,t){vx(i,e,t)}),vo=xP;function vP(i,e){return e=ls(e,i),i=Sx(i,e),i==null||delete i[rc(bx(e))]}var wx=vP;function bP(i){return nc(i)?void 0:i}var Nx=bP;var SP=1,wP=2,NP=4,CP=Ty(function(i,e){var t={};if(i==null)return t;var r=!1;e=kl(e,function(s){return s=ls(s,i),r||(r=s.length>1),s}),dn(i,cc(i),t),r&&(t=gc(t,SP|wP|NP,Nx));for(var n=e.length;n--;)wx(t,e[n]);return t}),ms=CP;var gs;(function(t){t.all=["PerspectiveCamera","OrthographicCamera"];function e(r){return t.all.includes(r)}t.is=e})(gs||(gs={}));var bo;(function(n){n.DefaultUp=[0,1,0],n.DefaultTargetOffset=1e3,n.defaultData={far:1e5,type:"OrthographicCamera",perspective:{near:5,fov:45,zoom:1},orthographic:{near:-1e5,zoom:1},up:n.DefaultUp,isUpVectorFlipped:!1,targetOffset:n.DefaultTargetOffset};function r(s){return s.type==="PerspectiveCamera"?s.perspective.zoom:s.orthographic.zoom}n.getZoom=r})(bo||(bo={}));var ys;(function(r){r.x="x",r.y="y",r.z="z"})(ys||(ys={}));var Cx;(function(s){s.Top="top",s.Right="right",s.Bottom="bottom",s.Left="left",s.Center="center"})(Cx||(Cx={}));var Lx;(function(t){function i(r,n){return r[0]===n[0]&&r[1]===n[1]}t.isEqual=i;function e(r,n,s){return[r[0]+(n[0]-r[0])*s,r[1]+(n[1]-r[1])*s]}t.lerp=e})(Lx||(Lx={}));var xs;(function(n){function i(s,l){return s[0]===l[0]&&s[1]===l[1]&&s[2]===l[2]}n.isEqual=i;function e(s,l){return[s[0]+l[0],s[1]+l[1],s[2]+l[2]]}n.add=e;function t(s,l){return[s[0]-l[0],s[1]-l[1],s[2]-l[2]]}n.sub=t;function r(s,l,c){return[s[0]+(l[0]-s[0])*c,s[1]+(l[1]-s[1])*c,s[2]+(l[2]-s[2])*c]}n.lerp=r})(xs||(xs={}));var _x;(function(t){function i(r,n){return r[0]===n[0]&&r[1]===n[1]&&r[2]===n[2]&&r[3]===n[3]}t.isEqual=i;function e(r,n,s){return[r[0]+(n[0]-r[0])*s,r[1]+(n[1]-r[1])*s,r[2]+(n[2]-r[2])*s,r[3]+(n[3]-r[3])*s]}t.lerp=e})(_x||(_x={}));var Ui;(function(s){s.identity=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1];function e(l,c){for(let f=0;f<16;f++)if(l[f]!==c[f])return!1;return!0}s.isEqual=e;function t(l){return l!=null?l:s.identity}s.simplify=t;function r(l,c){let f=c.slice(0);for(var h=0,p=c.length;h<p;h+=3){let y=1/(l[3]*c[h]+l[7]*c[h+1]+l[11]*c[h+2]+l[15]);f[h]=(l[0]*c[h]+l[4]*c[h+1]+l[8]*c[h+2]+l[12])*y,f[h+1]=(l[1]*c[h]+l[5]*c[h+1]+l[9]*c[h+2]+l[13])*y,f[h+2]=(l[2]*c[h]+l[6]*c[h+1]+l[10]*c[h+2]+l[14])*y}return f}s.applyMatrix4=r;function n(l,c){let f=c.slice(0);for(var h=0,p=c.length;h<p;h+=3)f[h]=l[0]*c[h]+l[4]*c[h+1]+l[8]*c[h+2],f[h+1]=l[1]*c[h]+l[5]*c[h+1]+l[9]*c[h+2],f[h+2]=l[2]*c[h]+l[6]*c[h+1]+l[10]*c[h+2];return f}s.applyMatrix3Components=n})(Ui||(Ui={}));var Zr;(function(f){f.white={r:1,g:1,b:1},f.red={r:1,g:0,b:0},f.black={r:0,g:0,b:0};function r(h){return{r:Math.round(h.r*255),g:Math.round(h.g*255),b:Math.round(h.b*255),a:1}}f.toRgb255a1=r;function n(h){return{r:h.r,g:h.g,b:h.b}}f.clone=n;function s(h){return h=Math.floor(h),{r:(h>>16&255)/255,g:(h>>8&255)/255,b:(h&255)/255}}f.fromHex=s;function l(h,p){return h.r===p.r&&h.g===p.g&&h.b===p.b}f.equals=l;function c(h,p,y){return{r:h.r+(p.r-h.r)*y,g:h.g+(p.g-h.g)*y,b:h.b+(p.b-h.b)*y}}f.lerp=c})(Zr||(Zr={}));var Hn;(function(l){l.white=fe(U({},Zr.white),{a:1});function e(c){return{r:c[0],g:c[1],b:c[2],a:c[3]}}l.from0to1=e;function t(c,f){return fe(U({},Zr.fromHex(c)),{a:f})}l.fromHexAndA=t;function r(c){return{r:Math.round(c.r*255),g:Math.round(c.g*255),b:Math.round(c.b*255),a:c.a}}l.toRgb255a1=r;function n(c,f){return Zr.equals(c,f)&&c.a===f.a}l.equals=n;function s(c,f,h){return{r:c.r+(f.r-c.r)*h,g:c.g+(f.g-c.g)*h,b:c.b+(f.b-c.b)*h,a:c.a+(f.a-c.a)*h}}l.lerp=s})(Hn||(Hn={}));var yc;(function(e){e.identity={position:[0,0,0],rotation:[0,0,0],scale:[1,1,1]}})(yc||(yc={}));var Tx;(function(D){D[D.SKIP=0]="SKIP",D[D.ADD=1]="ADD",D[D.ALPHA=2]="ALPHA",D[D.AVERAGE=3]="AVERAGE",D[D.COLOR_BURN=4]="COLOR_BURN",D[D.COLOR_DODGE=5]="COLOR_DODGE",D[D.DARKEN=6]="DARKEN",D[D.DIFFERENCE=7]="DIFFERENCE",D[D.EXCLUSION=8]="EXCLUSION",D[D.LIGHTEN=9]="LIGHTEN",D[D.MULTIPLY=10]="MULTIPLY",D[D.DIVIDE=11]="DIVIDE",D[D.NEGATION=12]="NEGATION",D[D.NORMAL=13]="NORMAL",D[D.OVERLAY=14]="OVERLAY",D[D.REFLECT=15]="REFLECT",D[D.SCREEN=16]="SCREEN",D[D.SOFT_LIGHT=17]="SOFT_LIGHT",D[D.SUBTRACT=18]="SUBTRACT"})(Tx||(Tx={}));var Ix;(function(c){c[c.LINEAR=0]="LINEAR",c[c.EASE=1]="EASE",c[c.EASE_IN=2]="EASE_IN",c[c.EASE_OUT=3]="EASE_OUT",c[c.EASE_IN_OUT=4]="EASE_IN_OUT",c[c.CUBIC=5]="CUBIC",c[c.SPRING=6]="SPRING"})(Ix||(Ix={}));var Mx;(function(e){e.defaultData={mass:1,stiffness:80,damping:10,velocity:0}})(Mx||(Mx={}));var Ax;(function(e){e.defaultData={control1:[.5,.05],control2:[.1,.3]}})(Ax||(Ax={}));var xc;(function(e){function i(t,r=.1){return{type:"radial",hideBase:!1,count:3,radial:{radius:Math.max(t[0],t[1])*2,start:0,end:360,alignment:!1,axis:ys.y,scale:[0,0,0],rotation:[0,0,0],position:[0,0,0]},linear:{scale:[0,0,0],rotation:[0,0,0],position:[t[0]+t[0]*r,0,0]},grid:{count:[2,2,2],size:t.map(n=>n*(1+r)),useCenter:!0}}}e.defaultData=i})(xc||(xc={}));var Wn;(function(e){e[e.Update=0]="Update"})(Wn||(Wn={}));var pn;(function(r){r[r.Add=1]="Add",r[r.Delete=2]="Delete",r[r.Unlink=3]="Unlink"})(pn||(pn={}));var Yr;(function(r){r[r.Add=4]="Add",r[r.Delete=5]="Delete",r[r.Move=6]="Move"})(Yr||(Yr={}));var jr;(function(r){r[r.Add=7]="Add",r[r.Delete=8]="Delete",r[r.Move=9]="Move"})(jr||(jr={}));var On=class{modifyById(e,t){let r=this;if(r[e]===void 0)throw new Error("not expected");{let s=fe(U({},r),{[e]:t});return Object.setPrototypeOf(s,On.prototype),s}}add(e,t){var n;let r=this.runOp({type:pn.Add,id:e,data:t});return(n=r==null?void 0:r.data)!=null?n:this}runOp(e){let t=this;if(e.type===pn.Add){let r=t[e.id],n;r===void 0?n={type:pn.Delete,id:e.id}:n={type:pn.Add,id:e.id,data:r};let{id:s,data:l}=e,c=fe(U({},t),{[s]:l});return Object.setPrototypeOf(c,On.prototype),{data:c,actual:e,reverse:n}}else if(e.type===pn.Delete){let{id:r}=e,n=t[r];if(n===void 0)return null;{let s=U({},t);return Object.setPrototypeOf(s,On.prototype),delete s[r],{data:s,actual:e,reverse:{type:pn.Add,id:r,data:n}}}}throw new Error("illegal arg")}};function ha(i){if(i.deepFreeze!==void 0){i.deepFreeze(i);return}let e=Object.getOwnPropertyNames(i);for(let t of e){let r=i[t];r&&typeof r=="object"&&ha(r)}return Object.freeze(i)}function Ox(i,e){let t=0;for(;t<i.length&&t<e.length;){if(i[t]<e[t])return-1;if(i[t]>e[t])return 1;t+=1}return t!==e.length?-1:t!==i.length?1:0}var lh=class extends Error{};function qn(i,e,t){if(i===void 0?e===void 0?(i=0,e=10):i=e-10:e===void 0&&(e=i+10),i>e){let s=i;i=e,e=s}let r=[],n=1/(t+1);for(let s=0;s<t;s++){let l=i+(e-i)*(s+.75+Math.random()*.5)*n;r.push(l)}return r}function Px(i){return i instanceof Uint8Array||i instanceof Uint16Array||i instanceof Uint32Array||i instanceof Int8Array||i instanceof Int16Array||i instanceof Int32Array||i instanceof Float32Array||i instanceof Float64Array}function Dx(){return typeof process!="undefined"}function Bx(i,e){for(let t of i)e(t.id,t.data),Bx(t.children,e)}function Gx(i,e){e(i.id,i.data);for(let t of i.children)Gx(t,e)}var Pn=class extends Array{constructor(...e){super(...e);Object.setPrototypeOf(this,Pn.prototype)}deepFreeze(){let e=0;for(;e<this.length;)ha(this[e]),e++}fillCaches0(e,t){var r;if((r=this.objCaches)==null?void 0:r.has(e.id))throw new Error("duplicated item");this.objCaches.set(e.id,e),this.parentCaches.set(e.id,t);for(let n of e.children)this.fillCaches0(n,e.id)}fillCaches(){if(this.objCaches===void 0){this.objCaches=new Map,this.parentCaches=new Map;for(let e of this)this.fillCaches0(e,null)}}randomId(){this.fillCaches();let e=Array.from(this.objCaches.keys());if(e.length!==0)return e[Math.max(0,Math.floor(Math.random()*e.length)-1)]}isDescendantOf(e,t){for(;e;){let r=this.parent(e);if(r===t)return!0;e=r}return!1}data(e){var t;return(t=this.get(e))==null?void 0:t.data}has(e){return this.childrenOf(e)!==void 0}get(e){return this.fillCaches(),this.objCaches.get(e)}childrenOf(e){var t;return e===null?this:(t=this.get(e))==null?void 0:t.children}traverseFrom(e,t){if(e===null)this.traverse(t);else{let r=this.get(e);r&&Gx(r,t)}}traverse(e){Bx(this,e)}totalSize(){return this.fillCaches(),this.objCaches.size}parent(e){return this.fillCaches(),this.parentCaches.get(e)}childrenArray(e){return e===null?this:this.get(e).children}modifyById(e,t){if(this.get(e)===void 0)throw new Error("not expected");{let n=this.parent(e),s=this.childrenArray(n),l=s.findIndex(h=>h.id===e);if(l<0)throw new Error("not expected");let c=s[l];return s=[...s],s[l]=fe(U({},c),{data:t}),this.modifyArrayBy(n,s)}}modifyArrayBy(e,t){let r=e,n=t;for(;r!==null;){let l=n,c=r;if(r=this.parent(r),r===void 0)throw new Error;n=this.childrenArray(r);let f=n.findIndex(h=>h.id===c);if(f<0)throw new Error;n=[...n],n[f]=fe(U({},n[f]),{children:l})}Object.setPrototypeOf(n,Pn.prototype);let s=n;return s.fillCaches(),s}runOp(e){switch(e.type){case jr.Add:return this.addOp(e);case jr.Delete:return this.deleteOp(e);case jr.Move:return this.moveOp(e)}}addOp(e){let{parent:t,fi:r,id:n,data:s,children:l}=e;if(t!==null&&this.get(t)===void 0)return null;if(this.get(n)!==void 0)return null;{let c=t,f=this.childrenArray(c),h={fi:r,id:n,data:s,children:l};return f=[...f,h],f.sort((y,g)=>y.fi-g.fi),e.localIndex=f.indexOf(h),{data:this.modifyArrayBy(c,f),actual:e,reverse:{type:jr.Delete,id:n}}}}deleteOp(e){let{id:t}=e;if(this.get(t)===null)return null;{let r=this.parent(t);if(r===void 0)return null;let n=this.childrenArray(r),s=n.findIndex(f=>f.id===t);e.localIndex=s,n=[...n];let l=n.splice(s,1)[0];return{data:this.modifyArrayBy(r,n),actual:e,reverse:fe(U({type:jr.Add},l),{parent:r})}}}moveOp(e){let{parent:t,fi:r,id:n}=e;if(t!==null&&this.get(t)===void 0)return this.deleteOp({type:jr.Delete,id:n});if(t!==null){let g=t;for(;g!==null;){if(g===void 0)throw new Error;if(g===n)throw new lh("cyclic tree");g=this.parent(g)}}let s=this.parent(n);if(s===void 0)return null;let l=s,c=this.childrenArray(s),f=c.findIndex(g=>g.id===n);c=[...c];let h=c.splice(f,1)[0],p=this.modifyArrayBy(s,c);s=t,c=p.childrenArray(s);let y=h.fi;return h=fe(U({},h),{fi:r}),c=[...c,h],c.sort((g,w)=>g.fi-w.fi),e.localIndex=c.indexOf(h),p=p.modifyArrayBy(s,c),{data:p,actual:e,reverse:{type:jr.Move,parent:l,fi:y,id:n}}}previous(e,t){if(t===null){let n=this.childrenArray(e);return n.length===0?null:n[n.length-1].id}let r=null;for(let n of this.childrenArray(e)){if(n.id===t)return r;r=n.id}return null}traverseSortNext(e){let t=this.parent(e);if(t!==void 0){let r=this.childrenArray(t),n=r.findIndex(s=>s.id===e)+1;if(n<r.length)return r[n].id;if(t)return this.traverseSortNext(t)}}sortNext(e){let t=this.childrenArray(e);return t.length>0?t[0].id:this.traverseSortNext(e)}traverseSortPrevious(e){let t=this.childrenArray(e);return t.length>0?this.traverseSortPrevious(t[t.length-1].id):e}sortPrevious(e){let t=this.parent(e);if(t!==void 0){let r=this.childrenArray(t),n=r.findIndex(s=>s.id===e)-1;return n>=0?this.traverseSortPrevious(r[n].id):t}}getAllSorted(e){let t=[];for(let r of e){let n=this.getWithSortKey(r.id);n!==void 0&&t.push(U(U({},r),n))}t.sort((r,n)=>Ox(r.sortKey,n.sortKey));for(let r of t)delete r.sortKey;return t}getWithSortKey(e){var t=e;let r=[],n=this.get(t),s=n;if(n!==void 0){for(;t;)r.splice(0,0,n.fi),t=this.parent(t),t!==null&&(n=this.get(t));return fe(U({},s),{sortKey:r})}}insertBeforeHelper(e,t,r){return this.insertAfterHelper(e,this.previous(e,t),r)}insertAfterHelper(e,t,r){let n=this.childrenArray(e);if(t===null){if(n.length===0)return qn(0,r,r);{let s=n[0].fi;return qn(s-r,s,r)}}else{let s=this.get(t);if(s===void 0||this.parent(t)!==e)throw new Error("illegal args");let l=n.find(c=>c.fi>s.fi);if(l===void 0){let c=n[n.length-1].fi;return qn(c,c+r,r)}else return qn(s.fi,l.fi,r)}}};var vc;(function(e){function i(t,r){if(Array.isArray(t)){let n=r.props,s={},l=[...t],c=!1;if(n)for(let f of Object.keys(n)){let h=parseInt(f);if(isNaN(h))throw new Error("wrong index");s[f]=l[h],l[h]=n[f],c=!0}return c?{data:l,actual:r,reverse:{type:Wn.Update,props:s}}:null}else{let n=r.props,s={},l=U({},t),c=!1;if(n)for(let f of Object.keys(n)){s[f]=l[f];let h=n[f];h===void 0?delete l[f]:l[f]=h,c=!0}return c?{data:l,actual:r,reverse:{type:Wn.Update,props:s}}:null}}e.runOp=i})(vc||(vc={}));var jt=class extends Array{constructor(...e){super(...e);Object.setPrototypeOf(this,jt.prototype)}deepFreeze(){let e=0;for(;e<this.length;)ha(this[e]),e++}fillCaches0(e){this.objCaches.set(e.id,e)}fillCaches(){if(this.objCaches===void 0){this.objCaches=new Map,Object.getOwnPropertyDescriptor(this,"objCaches").enumerable=!1;for(let e of this)this.fillCaches0(e)}}randomId(){this.fillCaches();let e=Array.from(this.objCaches.keys());if(e.length!==0)return e[Math.max(0,Math.floor(Math.random()*e.length)-1)]}data(e){var t;return(t=this.get(e))==null?void 0:t.data}get(e){return this.fillCaches(),this.objCaches.get(e)}modifyById(e,t){if(this.get(e)===void 0)throw new Error("not expected");{let n=this,s=n.findIndex(f=>f.id===e);if(s<0)throw new Error("not expected");let l=n[s];return n=[...n],n[s]=fe(U({},l),{data:t}),this.modifyArrayBy(n)}}modifyArrayBy(e){Object.setPrototypeOf(e,jt.prototype);let t=e;return Dx()||t.fillCaches(),t}runOp(e){switch(e.type){case Yr.Add:return this.addOp(e);case Yr.Delete:return this.deleteOp(e);case Yr.Move:return this.moveOp(e)}}addOp(e){let{fi:t,id:r,data:n}=e,s=this,l={fi:t,id:r,data:n};return s=[...s,l],s.sort((f,h)=>f.fi-h.fi),e.localIndex=s.indexOf(l),{data:this.modifyArrayBy(s),actual:e,reverse:{type:Yr.Delete,id:r}}}deleteOp(e){let{id:t}=e,r=this,n=r.findIndex(c=>c.id===t);if(n===-1)return null;e.localIndex=n,r=[...r];let s=r.splice(n,1)[0];return{data:this.modifyArrayBy(r),actual:e,reverse:U({type:Yr.Add},s)}}moveOp(e){let{fi:t,id:r}=e,n=this;n=[...n];let s=n.findIndex(h=>h.id===r);if(s===-1)return null;let l=n[s].fi,c=fe(U({},n[s]),{fi:t});return n[s]=c,n.sort((h,p)=>h.fi-p.fi),e.localIndex=n.indexOf(c),{data:this.modifyArrayBy(n),actual:e,reverse:{type:Yr.Move,fi:l,id:r}}}previous(e){if(e===null)return this.length===0?null:this[this.length-1].id;let t=null;for(let r of this){if(r.id===e)return t;t=r.id}return null}insertBeforeHelper(e,t){return this.insertAfterHelper(this.previous(e),t)}insertAfterHelper(e,t){let r=this;if(e===null){if(r.length===0)return qn(0,t,t);{let n=r[0].fi;return qn(n-t,n,t)}}else{let n=this.get(e);if(n===void 0)throw new Error("illegal args");let s=r.find(l=>l.fi>n.fi);if(s===void 0){let l=r[r.length-1].fi;return qn(l,l+t,t)}else return qn(n.fi,s.fi,t)}}};var jx=Symbol(),bc=Symbol(),da=class{reportOp(e,t){let r=this;if(t===null)return;r._current=t.data;let n=[];for(;!(r instanceof uh);){let s=r._path,l=r._current;if(s!==""&&n.splice(0,0,s),r=r._parent,r===null)return;r.update(s,l)}r.push(n,e,t.actual,t.reverse)}deleteChildren(e){if(this._children){let t=this._children[e];if(t){let r=t[bc];r&&r(),delete this._children[e]}}}},Ex=class extends da{constructor(e,t,r){super();this._parent=e,this._path=t,this._current=r}update(e,t){if(Array.isArray(this._current)){if(typeof e=="string"&&(e=parseInt(e),isNaN(e)))throw new Error("Invalid path");this._current=[...this._current],this._current[e]=t}else this._current=fe(U({},this._current),{[e]:t})}runOp(e){this.reportOp(e,vc.runOp(this._current,e))}},Rx=class extends da{constructor(e,t,r){super();this._parent=e,this._path=t,this._current=r}update(e,t){this._current=fe(U({},this._current),{[e]:t}),Object.setPrototypeOf(this._current,On.prototype)}runOp(e){this.reportOp(e,this._current.runOp(e))}},zx={get(i,e){if(e===bc)return()=>{i._parent=null};if(e===jx)return i._current;let{_current:t,_children:r}=i;if(e==="push"&&Array.isArray(t))throw new Error("not supported to expand array");let n=r===void 0?void 0:r[e];if(n!==void 0)return n;let s=t[e],l=Sc(i,e,s);return l!==s?(r===void 0&&(r={},i._children=r),r[e]=l,l):s},has(i,e){return e in i._current},ownKeys(i){return Reflect.ownKeys(i._current)},defineProperty(){throw Error("not supported")},getPrototypeOf(i){return Object.getPrototypeOf(i._current)},setPrototypeOf(){throw Error("not supported")},getOwnPropertyDescriptor(i,e){let t=i._current,r=Reflect.getOwnPropertyDescriptor(t,e);return r&&{writable:!0,configurable:!0,enumerable:r.enumerable,value:t[e]}}},LP=fe(U({},zx),{set(i,e,t){var n;let r={type:Wn.Update,props:{[e]:(n=IP(t))!=null?n:t}};return i.deleteChildren(e),i.runOp(r),!0},deleteProperty(i,e){let t={type:Wn.Update,props:{[e]:void 0}};return i.deleteChildren(e),i.runOp(t),!0}}),_P=fe(U({},zx),{set(i,e,t){return t===void 0?this.deleteProperty(i,e):(i.deleteChildren(e),i.runOp({type:pn.Add,id:e,data:t})),!0},deleteProperty(i,e){return i.runOp({type:pn.Delete,id:e}),!0}}),pa=class extends da{constructor(e,t,r){super();this._children={},this._parent=e,this._path=t,this._current=r,this[bc]=()=>{this._parent=null}}unproxy(){return this._current}update(e,t){this._current=this._current.modifyById(e,t)}runOp(e){this.reportOp(e,this._current.runOp(e))}randomId(){return this._current.randomId()}isDescendantOf(e,t){return this._current.isDescendantOf(e,t)}childrenOf(e){return this._current.childrenOf(e)}traverse(e){return this._current.traverse(e)}get(e){return this._current.get(e)}parent(e){return this._current.parent(e)}traverse(e){this._current.traverse((t,r)=>{e(t,this.data(t))})}data(e){var c;let{_current:t,_children:r}=this,n=r===void 0?void 0:r[e];if(n!==void 0)return n;let s=(c=t.get(e))==null?void 0:c.data,l=Sc(this,e,s);return l!==s?(r===void 0&&(r={},this._children=r),r[e]=l,l):s}add(e,t,r,n,s){this.runOp({type:jr.Add,parent:e,fi:t,id:r,data:n,children:s})}move(e,t,r){this.runOp({type:jr.Move,parent:e,fi:t,id:r})}insertAfter(e,t,r){let n=this._current.insertAfterHelper(e,t,r.length);for(let s=0;s<r.length;s++){let l=r[s];this.add(e,n[s],l.id,l.data,l.children)}}insertBefore(e,t,r){let n=this._current.insertBeforeHelper(e,t,r.length);for(let s=0;s<r.length;s++){let l=r[s];this.add(e,n[s],l.id,l.data,l.children)}}moveAfter(e,t,r){let n=this._current.insertAfterHelper(e,t,r.length);for(let s=0;s<r.length;s++){let l=r[s];this.move(e,n[s],l)}}moveBefore(e,t,r){let n=this._current.insertBeforeHelper(e,t,r.length);for(let s=0;s<r.length;s++){let l=r[s];this.move(e,n[s],l)}}delete(e){this.deleteChildren(e),this.runOp({type:jr.Delete,id:e})}sortNext(e){return this._current.sortNext(e)}sortPrevious(e){return this._current.sortPrevious(e)}getAllSorted(e){return this._current.getAllSorted(e)}},ma=class extends da{constructor(e,t,r){super();this._children={},this._parent=e,this._path=t,this._current=r,this[bc]=()=>{this._parent=null}}unproxy(){return this._current}get length(){return this._current.length}forEach(e){let t=this.length;for(let r=0;r<t;r++){let n=this._current[r].id;e(this.data(this._current[r].id),n)}}update(e,t){this._current=this._current.modifyById(e,t)}randomId(){return this._current.randomId()}get(e){return fe(U({},this._current.get(e)),{data:this.data(e)})}data(e){var c;let{_current:t,_children:r}=this,n=r===void 0?void 0:r[e];if(n!==void 0)return n;let s=(c=t.get(e))==null?void 0:c.data,l=Sc(this,e,s);return l!==s?(r===void 0&&(r={},this._children=r),r[e]=l,l):s}runOp(e){this.reportOp(e,this._current.runOp(e))}add(e,t,r){this.runOp({type:Yr.Add,fi:e,id:t,data:r})}move(e,t){this.runOp({type:Yr.Move,fi:e,id:t})}insertAfter(e,t){let r=this._current.insertAfterHelper(e,t.length);for(let n=0;n<t.length;n++){let s=t[n];this.add(r[n],s.id,s.data)}}insertBefore(e,t){let r=this._current.insertBeforeHelper(e,t.length);for(let n=0;n<t.length;n++){let s=t[n];this.add(r[n],s.id,s.data)}}moveAfter(e,t){let r=this._current.insertAfterHelper(e,t.length);for(let n=0;n<t.length;n++){let s=t[n];this.move(r[n],s)}}moveBefore(e,t){let r=this._current.insertBeforeHelper(e,t.length);for(let n=0;n<t.length;n++){let s=t[n];this.move(r[n],s)}}delete(e){this.deleteChildren(e),this.runOp({type:Yr.Delete,id:e})}};function ch(i,e,t){if(i.length>0){let r=i[i.length-1];if(r.type===Wn.Update&&e.type===Wn.Update&&wc.equal(r.path,t)){Object.assign(r.props,e.props);return}}i.push(fe(U({},e),{path:t}))}var uh=class{constructor(e){this.ts=[],this.actual=[],this.reverse=[],this._current=e}update(e,t){if(e!=="")throw new Error("");this._current=t}push(e,t,r,n){ch(this.ts,t,e),ch(this.actual,r,e),ch(this.reverse,n,e)}result(){return{data:this._current,ts:this.ts,actual:this.actual,reverse:this.reverse.reverse()}}};function Sc(i,e,t){return t instanceof Pn?new pa(i,e,t):t instanceof jt?new ma(i,e,t):t instanceof On?new Proxy(new Rx(i,e,t),_P):t!==null&&typeof t=="object"?Px(t)?t:new Proxy(new Ex(i,e,t),LP):t}function TP(i){let e=new uh(i);return[Sc(e,"",i),e]}function fh(i,e){let[t,r]=TP(i);return e(t),r.result()}function IP(i){return i instanceof pa||i instanceof ma?i._current:i!==null&&typeof i=="object"?i[jx]:i}var wc;(function(r){function i(n,s){if(s.length===n.length)for(var l=0;l<n.length;){if(n[l]!==s[l])return!1;l+=1}else return!1;return!0}r.equal=i;function e(n,s,l){let c=t(l,n);if(c!==void 0&&typeof c=="object"&&c!==null){let f=U({},s);return Object.keys(c).forEach(h=>{delete f[h]}),f}else return s}r.removeOverridden=e;function t(n,s,l=0){if(s.length<=l)return n;if((n instanceof Pn||n instanceof pa)&&typeof s[l]=="string")return t(n.data(s[l]),s,l+1);if((n instanceof jt||n instanceof ma)&&typeof s[l]=="string")return t(n.data(s[l]),s,l+1);if(typeof s[l]=="number"&&Array.isArray(n))return t(n[s[l]],s,l+1);if(typeof s[l]=="string"&&typeof n=="object")return t(n[s[l]],s,l+1)}r.zoom=t})(wc||(wc={}));var hh=class{},Nc=class extends hh{constructor(e){super();this.id=e}},Cc=class extends hh{constructor(e){super();this.data=e}};"use strict";var dh;try{dh=new TextDecoder}catch(i){}var ge,ki,j=0;var Fx=[],ph=Fx,mh=0,Er={},ot,Hi,mn=0,$n=0,Qr,gi,Cr=[],ft,Vx={useRecords:!1,mapsAsObjects:!0},Lc=class{},gh=new Lc;gh.name="MessagePack 0xC1";var vs=!1,yi=class{constructor(e){e&&(e.useRecords===!1&&e.mapsAsObjects===void 0&&(e.mapsAsObjects=!0),e.structures?e.structures.sharedLength=e.structures.length:e.getStructures&&((e.structures=[]).uninitialized=!0,e.structures.sharedLength=0)),Object.assign(this,e)}unpack(e,t){if(ge)return Yx(()=>(Ic(),this?this.unpack(e,t):yi.prototype.unpack.call(Vx,e,t)));ki=t>-1?t:e.length,j=0,mh=0,$n=0,Hi=null,ph=Fx,Qr=null,ge=e;try{ft=e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))}catch(r){throw ge=null,e instanceof Uint8Array?r:new Error("Source must be a Uint8Array or Buffer but was a "+(e&&typeof e=="object"?e.constructor.name:typeof e))}if(this instanceof yi){if(Er=this,this.structures)return ot=this.structures,_c();(!ot||ot.length>0)&&(ot=[])}else Er=Vx,(!ot||ot.length>0)&&(ot=[]);return _c()}unpackMultiple(e,t){let r,n=0;try{vs=!0;let s=e.length,l=this?this.unpack(e,s):Ac.unpack(e,s);if(t){for(t(l);j<s;)if(n=j,t(_c())===!1)return}else{for(r=[l];j<s;)n=j,r.push(_c());return r}}catch(s){throw s.lastPosition=n,s.values=r,s}finally{vs=!1,Ic()}}_mergeStructures(e,t){e=e||[];for(let r=0,n=e.length;r<n;r++){let s=e[r];s&&(s.isShared=!0,r>=32&&(s.highByte=r-32>>5))}e.sharedLength=e.length;for(let r in t||[])if(r>=0){let n=e[r],s=t[r];s&&(n&&((e.restoreStructures||(e.restoreStructures=[]))[r]=n),e[r]=s)}return this.structures=e}decode(e,t){return this.unpack(e,t)}};function _c(){try{if(!Er.trusted&&!vs){let e=ot.sharedLength||0;e<ot.length&&(ot.length=e)}let i=Et();if(j==ki)ot.restoreStructures&&Ux(),ot=null,ge=null,gi&&(gi=null);else if(j>ki){let e=new Error("Unexpected end of MessagePack data");throw e.incomplete=!0,e}else if(!vs)throw new Error("Data read, but end of buffer not reached");return i}catch(i){throw ot.restoreStructures&&Ux(),Ic(),(i instanceof RangeError||i.message.startsWith("Unexpected end of buffer"))&&(i.incomplete=!0),i}}function Ux(){for(let i in ot.restoreStructures)ot[i]=ot.restoreStructures[i];ot.restoreStructures=null}function Et(){let i=ge[j++];if(i<160)if(i<128){if(i<64)return i;{let e=ot[i&63]||Er.getStructures&&Hx()[i&63];return e?(e.read||(e.read=yh(e,i&63)),e.read()):i}}else if(i<144)if(i-=128,Er.mapsAsObjects){let e={};for(let t=0;t<i;t++)e[Kx()]=Et();return e}else{let e=new Map;for(let t=0;t<i;t++)e.set(Et(),Et());return e}else{i-=144;let e=new Array(i);for(let t=0;t<i;t++)e[t]=Et();return e}else if(i<192){let e=i-160;if($n>=j)return Hi.slice(j-mn,(j+=e)-mn);if($n==0&&ki<140){let t=e<16?vh(e):$x(e);if(t!=null)return t}return xh(e)}else{let e;switch(i){case 192:return null;case 193:return Qr?(e=Et(),e>0?Qr[1].slice(Qr.position1,Qr.position1+=e):Qr[0].slice(Qr.position0,Qr.position0-=e)):gh;case 194:return!1;case 195:return!0;case 196:return bh(ge[j++]);case 197:return e=ft.getUint16(j),j+=2,bh(e);case 198:return e=ft.getUint32(j),j+=4,bh(e);case 199:return So(ge[j++]);case 200:return e=ft.getUint16(j),j+=2,So(e);case 201:return e=ft.getUint32(j),j+=4,So(e);case 202:if(e=ft.getFloat32(j),Er.useFloat32>2){let t=Mc[(ge[j]&127)<<1|ge[j+1]>>7];return j+=4,(t*e+(e>0?.5:-.5)>>0)/t}return j+=4,e;case 203:return e=ft.getFloat64(j),j+=8,e;case 204:return ge[j++];case 205:return e=ft.getUint16(j),j+=2,e;case 206:return e=ft.getUint32(j),j+=4,e;case 207:return Er.int64AsNumber?(e=ft.getUint32(j)*4294967296,e+=ft.getUint32(j+4)):e=ft.getBigUint64(j),j+=8,e;case 208:return ft.getInt8(j++);case 209:return e=ft.getInt16(j),j+=2,e;case 210:return e=ft.getInt32(j),j+=4,e;case 211:return Er.int64AsNumber?(e=ft.getInt32(j)*4294967296,e+=ft.getUint32(j+4)):e=ft.getBigInt64(j),j+=8,e;case 212:if(e=ge[j++],e==114)return Xx(ge[j++]&63);{let t=Cr[e];if(t)return t.read?(j++,t.read(Et())):t.noBuffer?(j++,t()):t(ge.subarray(j,++j));throw new Error("Unknown extension "+e)}case 213:return e=ge[j],e==114?(j++,Xx(ge[j++]&63,ge[j++])):So(2);case 214:return So(4);case 215:return So(8);case 216:return So(16);case 217:return e=ge[j++],$n>=j?Hi.slice(j-mn,(j+=e)-mn):AP(e);case 218:return e=ft.getUint16(j),j+=2,$n>=j?Hi.slice(j-mn,(j+=e)-mn):OP(e);case 219:return e=ft.getUint32(j),j+=4,$n>=j?Hi.slice(j-mn,(j+=e)-mn):PP(e);case 220:return e=ft.getUint16(j),j+=2,Wx(e);case 221:return e=ft.getUint32(j),j+=4,Wx(e);case 222:return e=ft.getUint16(j),j+=2,qx(e);case 223:return e=ft.getUint32(j),j+=4,qx(e);default:if(i>=224)return i-256;if(i===void 0){let t=new Error("Unexpected end of MessagePack data");throw t.incomplete=!0,t}throw new Error("Unknown MessagePack token "+i)}}}var MP=/^[a-zA-Z_$][a-zA-Z\d_$]*$/;function yh(i,e){function t(){if(t.count++>2){let n=i.read=new Function("r","return function(){return {"+i.map(s=>MP.test(s)?s+":r()":"["+JSON.stringify(s)+"]:r()").join(",")+"}}")(Et);return i.highByte===0&&(i.read=kx(e,i.read)),n()}let r={};for(let n=0,s=i.length;n<s;n++){let l=i[n];r[l]=Et()}return r}return t.count=0,i.highByte===0?kx(e,t):t}var kx=(i,e)=>function(){let t=ge[j++];if(t===0)return e();let r=i<32?-(i+(t<<5)):i+(t<<5),n=ot[r]||Hx()[r];if(!n)throw new Error("Record id is not defined for "+r);return n.read||(n.read=yh(n,i)),n.read()};function Hx(){let i=Yx(()=>(ge=null,Er.getStructures()));return ot=Er._mergeStructures(i,ot)}var xh=Tc,AP=Tc,OP=Tc,PP=Tc;function Tc(i){let e;if(i<16&&(e=vh(i)))return e;if(i>64&&dh)return dh.decode(ge.subarray(j,j+=i));let t=j+i,r=[];for(e="";j<t;){let n=ge[j++];if((n&128)==0)r.push(n);else if((n&224)==192){let s=ge[j++]&63;r.push((n&31)<<6|s)}else if((n&240)==224){let s=ge[j++]&63,l=ge[j++]&63;r.push((n&31)<<12|s<<6|l)}else if((n&248)==240){let s=ge[j++]&63,l=ge[j++]&63,c=ge[j++]&63,f=(n&7)<<18|s<<12|l<<6|c;f>65535&&(f-=65536,r.push(f>>>10&1023|55296),f=56320|f&1023),r.push(f)}else r.push(n);r.length>=4096&&(e+=ir.apply(String,r),r.length=0)}return r.length>0&&(e+=ir.apply(String,r)),e}function Wx(i){let e=new Array(i);for(let t=0;t<i;t++)e[t]=Et();return e}function qx(i){if(Er.mapsAsObjects){let e={};for(let t=0;t<i;t++)e[Kx()]=Et();return e}else{let e=new Map;for(let t=0;t<i;t++)e.set(Et(),Et());return e}}var ir=String.fromCharCode;function $x(i){let e=j,t=new Array(i);for(let r=0;r<i;r++){let n=ge[j++];if((n&128)>0){j=e;return}t[r]=n}return ir.apply(String,t)}function vh(i){if(i<4)if(i<2){if(i===0)return"";{let e=ge[j++];if((e&128)>1){j-=1;return}return ir(e)}}else{let e=ge[j++],t=ge[j++];if((e&128)>0||(t&128)>0){j-=2;return}if(i<3)return ir(e,t);let r=ge[j++];if((r&128)>0){j-=3;return}return ir(e,t,r)}else{let e=ge[j++],t=ge[j++],r=ge[j++],n=ge[j++];if((e&128)>0||(t&128)>0||(r&128)>0||(n&128)>0){j-=4;return}if(i<6){if(i===4)return ir(e,t,r,n);{let s=ge[j++];if((s&128)>0){j-=5;return}return ir(e,t,r,n,s)}}else if(i<8){let s=ge[j++],l=ge[j++];if((s&128)>0||(l&128)>0){j-=6;return}if(i<7)return ir(e,t,r,n,s,l);let c=ge[j++];if((c&128)>0){j-=7;return}return ir(e,t,r,n,s,l,c)}else{let s=ge[j++],l=ge[j++],c=ge[j++],f=ge[j++];if((s&128)>0||(l&128)>0||(c&128)>0||(f&128)>0){j-=8;return}if(i<10){if(i===8)return ir(e,t,r,n,s,l,c,f);{let h=ge[j++];if((h&128)>0){j-=9;return}return ir(e,t,r,n,s,l,c,f,h)}}else if(i<12){let h=ge[j++],p=ge[j++];if((h&128)>0||(p&128)>0){j-=10;return}if(i<11)return ir(e,t,r,n,s,l,c,f,h,p);let y=ge[j++];if((y&128)>0){j-=11;return}return ir(e,t,r,n,s,l,c,f,h,p,y)}else{let h=ge[j++],p=ge[j++],y=ge[j++],g=ge[j++];if((h&128)>0||(p&128)>0||(y&128)>0||(g&128)>0){j-=12;return}if(i<14){if(i===12)return ir(e,t,r,n,s,l,c,f,h,p,y,g);{let w=ge[j++];if((w&128)>0){j-=13;return}return ir(e,t,r,n,s,l,c,f,h,p,y,g,w)}}else{let w=ge[j++],S=ge[j++];if((w&128)>0||(S&128)>0){j-=14;return}if(i<15)return ir(e,t,r,n,s,l,c,f,h,p,y,g,w,S);let T=ge[j++];if((T&128)>0){j-=15;return}return ir(e,t,r,n,s,l,c,f,h,p,y,g,w,S,T)}}}}}function bh(i){return Er.copyBuffers?Uint8Array.prototype.slice.call(ge,j,j+=i):ge.subarray(j,j+=i)}function So(i){let e=ge[j++];if(Cr[e])return Cr[e](ge.subarray(j,j+=i));throw new Error("Unknown extension type "+e)}var Jx=new Array(4096);function Kx(){let i=ge[j++];if(i>=160&&i<192){if(i=i-160,$n>=j)return Hi.slice(j-mn,(j+=i)-mn);if(!($n==0&&ki<180))return xh(i)}else return j--,Et();let e=(i<<5^(i>1?ft.getUint16(j):i>0?ge[j]:0))&4095,t=Jx[e],r=j,n=j+i-3,s,l=0;if(t&&t.bytes==i){for(;r<n;){if(s=ft.getUint32(r),s!=t[l++]){r=1879048192;break}r+=4}for(n+=3;r<n;)if(s=ge[r++],s!=t[l++]){r=1879048192;break}if(r===n)return j=r,t.string;n-=3,r=j}for(t=[],Jx[e]=t,t.bytes=i;r<n;)s=ft.getUint32(r),t.push(s),r+=4;for(n+=3;r<n;)s=ge[r++],t.push(s);let c=i<16?vh(i):$x(i);return c!=null?t.string=c:t.string=xh(i)}var Xx=(i,e)=>{var t=Et();let r=i;e!==void 0&&(i=i<32?-((e<<5)+i):(e<<5)+i,t.highByte=e);let n=ot[i];return n&&n.isShared&&((ot.restoreStructures||(ot.restoreStructures=[]))[i]=n),ot[i]=t,t.read=yh(t,r),t.read()},Zx=typeof self=="object"?self:global;Cr[0]=()=>{};Cr[0].noBuffer=!0;Cr[101]=()=>{let i=Et();return(Zx[i[0]]||Error)(i[1])};Cr[105]=i=>{let e=ft.getUint32(j-4);gi||(gi=new Map);let t=ge[j],r;t>=144&&t<160||t==220||t==221?r=[]:r={};let n={target:r};gi.set(e,n);let s=Et();return n.used?Object.assign(r,s):(n.target=s,s)};Cr[112]=i=>{let e=ft.getUint32(j-4),t=gi.get(e);return t.used=!0,t.target};Cr[115]=()=>new Set(Et());var Sh=["Int8","Uint8","Uint8Clamped","Int16","Uint16","Int32","Uint32","Float32","Float64","BigInt64","BigUint64"].map(i=>i+"Array");Cr[116]=i=>{let e=i[0],t=Sh[e];if(!t)throw new Error("Could not find typed array for code "+e);return new Zx[t](Uint8Array.prototype.slice.call(i,1).buffer)};Cr[120]=()=>{let i=Et();return new RegExp(i[0],i[1])};Cr[98]=i=>{let e=(i[0]<<24)+(i[1]<<16)+(i[2]<<8)+i[3],t=j;j+=e-4,Qr=[Et(),Et()],Qr.position0=0,Qr.position1=0;let r=j;j=t;try{return Et()}finally{j=r}};Cr[255]=i=>i.length==4?new Date((i[0]*16777216+(i[1]<<16)+(i[2]<<8)+i[3])*1e3):i.length==8?new Date(((i[0]<<22)+(i[1]<<14)+(i[2]<<6)+(i[3]>>2))/1e6+((i[3]&3)*4294967296+i[4]*16777216+(i[5]<<16)+(i[6]<<8)+i[7])*1e3):i.length==12?new Date(((i[0]<<24)+(i[1]<<16)+(i[2]<<8)+i[3])/1e6+((i[4]&128?-281474976710656:0)+i[6]*1099511627776+i[7]*4294967296+i[8]*16777216+(i[9]<<16)+(i[10]<<8)+i[11])*1e3):new Date("invalid");function Yx(i){let e=ki,t=j,r=mh,n=mn,s=$n,l=Hi,c=ph,f=gi,h=Qr,p=new Uint8Array(ge.slice(0,ki)),y=ot,g=ot.slice(0,ot.length),w=Er,S=vs,T=i();return ki=e,j=t,mh=r,mn=n,$n=s,Hi=l,ph=c,gi=f,Qr=h,ge=p,vs=S,ot=y,ot.splice(0,ot.length,...g),Er=w,ft=new DataView(ge.buffer,ge.byteOffset,ge.byteLength),T}function Ic(){ge=null,gi=null,ot=null}function Qx(i){i.unpack?Cr[i.type]=i.unpack:Cr[i.type]=i}var Mc=new Array(147);for(let i=0;i<256;i++)Mc[i]=+("1e"+Math.floor(45.15-i*.30103));var Ac=new yi({useRecords:!1}),DP=Ac.unpack,BP=Ac.unpackMultiple,GP=Ac.unpack;var jP=new Float32Array(1),u4=new Uint8Array(jP.buffer,0,4);"use strict";var Oc;try{Oc=new TextEncoder}catch(i){}var Pc,wh,Dc=typeof Buffer!="undefined",Nh=Dc?Buffer.allocUnsafeSlow:Uint8Array,t0=Dc?Buffer:Uint8Array,r0=Dc?4294967296:2144337920,Z,Vt,F=0,Jn,Kn=null,EP=/[\u0080-\uFFFF]/,ga=Symbol("record-id"),bs=class extends yi{constructor(e){super(e);this.offset=0;let t,r,n,s,l,c,f=0,h=t0.prototype.utf8Write?function(b,R,I){return Z.utf8Write(b,R,I)}:Oc&&Oc.encodeInto?function(b,R){return Oc.encodeInto(b,Z.subarray(R)).written}:!1,p=this;e||(e={});let y=e&&e.sequential,g=e.structures||e.saveStructures,w=e.maxSharedStructures;if(w==null&&(w=g?32:0),w>8160)throw new Error("Maximum maxSharedStructure is 8160");let S=e.maxOwnStructures;S==null&&(S=g?32:64),y&&!e.saveStructures&&(this.structures=[]);let T=w>32||S+w>64,C=w+64,B=w+S+64;if(B>8256)throw new Error("Maximum maxSharedStructure + maxOwnStructure is 8192");let G=[],D=0,W=0;this.pack=this.encode=function(b,R){if(Z||(Z=new Nh(8192),Vt=new DataView(Z.buffer,0,8192),F=0),Jn=Z.length-10,Jn-F<2048?(Z=new Nh(Z.length),Vt=new DataView(Z.buffer,0,Z.length),Jn=Z.length-10,F=0):F=F+7&2147483640,r=F,c=p.structuredClone?new Map:null,p.bundleStrings?(Kn=["",""],Z[F++]=214,Z[F++]=98,Kn.position=F-r,F+=4):Kn=null,n=p.structures,n){n.uninitialized&&(n=p._mergeStructures(p.getStructures()));let I=n.sharedLength||0;if(I>w)throw new Error("Shared structures is larger than maximum shared structures, try increasing maxSharedStructures to "+n.sharedLength);if(!n.transitions){n.transitions=Object.create(null);for(let z=0;z<I;z++){let O=n[z];if(!O)continue;let $,he=n.transitions;for(let re=0,Ne=O.length;re<Ne;re++){let ye=O[re];$=he[ye],$||($=he[ye]=Object.create(null)),he=$}he[ga]=z+64}f=I}y||(n.nextId=I+64)}s&&(s=!1),l=n||[];try{if(A(b),Kn){Vt.setUint32(Kn.position+r,F-Kn.position-r);let I=Kn;Kn=null,A(I[0]),A(I[1])}if(p.offset=F,c&&c.idsToInsert){F+=c.idsToInsert.length*6,F>Jn&&E(F),p.offset=F;let I=zP(Z.subarray(r,F),c.idsToInsert);return c=null,I}return R&s0?(Z.start=r,Z.end=F,Z):Z.subarray(r,F)}finally{if(n){if(W<10&&W++,D>1e4)n.transitions=null,W=0,D=0,G.length>0&&(G=[]);else if(G.length>0&&!y){for(let I=0,z=G.length;I<z;I++)G[I][ga]=0;G=[]}if(s&&p.saveStructures){let I=n.sharedLength||w;n.length>I&&(n=n.slice(0,I));let z=Z.subarray(r,F);return p.saveStructures(n,f)===!1?(p._mergeStructures(p.getStructures()),p.pack(b)):(f=I,z)}}R&UP&&(F=r)}};let A=b=>{F>Jn&&(Z=E(F));var R=typeof b,I;if(R==="string"){let z=b.length;if(Kn&&z>=8&&z<4096){let he=EP.test(b);Kn[he?0:1]+=b,Z[F++]=193,A(he?-z:z);return}let O;z<32?O=1:z<256?O=2:z<65536?O=3:O=5;let $=z*3;if(F+$>Jn&&(Z=E(F+$)),z<64||!h){let he,re,Ne,ye=F+O;for(he=0;he<z;he++)re=b.charCodeAt(he),re<128?Z[ye++]=re:re<2048?(Z[ye++]=re>>6|192,Z[ye++]=re&63|128):(re&64512)==55296&&((Ne=b.charCodeAt(he+1))&64512)==56320?(re=65536+((re&1023)<<10)+(Ne&1023),he++,Z[ye++]=re>>18|240,Z[ye++]=re>>12&63|128,Z[ye++]=re>>6&63|128,Z[ye++]=re&63|128):(Z[ye++]=re>>12|224,Z[ye++]=re>>6&63|128,Z[ye++]=re&63|128);I=ye-F-O}else I=h(b,F+O,$);I<32?Z[F++]=160|I:I<256?(O<2&&Z.copyWithin(F+2,F+1,F+1+I),Z[F++]=217,Z[F++]=I):I<65536?(O<3&&Z.copyWithin(F+3,F+2,F+2+I),Z[F++]=218,Z[F++]=I>>8,Z[F++]=I&255):(O<5&&Z.copyWithin(F+5,F+3,F+3+I),Z[F++]=219,Vt.setUint32(F,I),F+=4),F+=I}else if(R==="number")if(b>>>0===b)b<64?Z[F++]=b:b<256?(Z[F++]=204,Z[F++]=b):b<65536?(Z[F++]=205,Z[F++]=b>>8,Z[F++]=b&255):(Z[F++]=206,Vt.setUint32(F,b),F+=4);else if(b>>0===b)b>=-32?Z[F++]=256+b:b>=-128?(Z[F++]=208,Z[F++]=b+256):b>=-32768?(Z[F++]=209,Vt.setInt16(F,b),F+=2):(Z[F++]=210,Vt.setInt32(F,b),F+=4);else{let z;if((z=this.useFloat32)>0&&b<4294967296&&b>=-2147483648){Z[F++]=202,Vt.setFloat32(F,b);let O;if(z<4||(O=b*Mc[(Z[F]&127)<<1|Z[F+1]>>7])>>0===O){F+=4;return}else F--}Z[F++]=203,Vt.setFloat64(F,b),F+=8}else if(R==="object")if(!b)Z[F++]=192;else{if(c){let O=c.get(b);if(O){if(!O.id){let $=c.idsToInsert||(c.idsToInsert=[]);O.id=$.push(O)}Z[F++]=214,Z[F++]=112,Vt.setUint32(F,O.id),F+=4;return}else c.set(b,{offset:F-r})}let z=b.constructor;if(z===Object)q(b,!0);else if(z===Array){I=b.length,I<16?Z[F++]=144|I:I<65536?(Z[F++]=220,Z[F++]=I>>8,Z[F++]=I&255):(Z[F++]=221,Vt.setUint32(F,I),F+=4);for(let O=0;O<I;O++)A(b[O])}else if(z===Map){I=b.size,I<16?Z[F++]=128|I:I<65536?(Z[F++]=222,Z[F++]=I>>8,Z[F++]=I&255):(Z[F++]=223,Vt.setUint32(F,I),F+=4);for(let[O,$]of b)A(O),A($)}else{for(let O=0,$=Pc.length;O<$;O++){let he=wh[O];if(b instanceof he){let re=Pc[O];if(re.write){re.type&&(Z[F++]=212,Z[F++]=re.type,Z[F++]=0),A(re.write.call(this,b));return}let Ne=Z,ye=Vt,Me=F;Z=null;let Fe;try{Fe=re.pack.call(this,b,k=>(Z=Ne,Ne=null,F+=k,F>Jn&&E(F),{target:Z,targetView:Vt,position:F-k}),A)}finally{Ne&&(Z=Ne,Vt=ye,F=Me,Jn=Z.length-10)}Fe&&(Fe.length+F>Jn&&E(Fe.length+F),F=RP(Fe,Z,F,re.type));return}}q(b,!b.hasOwnProperty)}}else if(R==="boolean")Z[F++]=b?195:194;else if(R==="bigint"){if(b<BigInt(1)<<BigInt(63)&&b>=-(BigInt(1)<<BigInt(63)))Z[F++]=211,Vt.setBigInt64(F,b);else if(b<BigInt(1)<<BigInt(64)&&b>0)Z[F++]=207,Vt.setBigUint64(F,b);else if(this.largeBigIntToFloat)Z[F++]=203,Vt.setFloat64(F,Number(b));else throw new RangeError(b+" was too large to fit in MessagePack 64-bit integer format, set largeBigIntToFloat to convert to float-64");F+=8}else if(R==="undefined")this.encodeUndefinedAsNil?Z[F++]=192:(Z[F++]=212,Z[F++]=0,Z[F++]=0);else if(R==="function")A(this.writeFunction&&this.writeFunction());else throw new Error("Unknown type: "+R)},q=this.useRecords===!1?this.variableMapSize?b=>{let R=Object.keys(b),I=R.length;I<16?Z[F++]=128|I:I<65536?(Z[F++]=222,Z[F++]=I>>8,Z[F++]=I&255):(Z[F++]=223,Vt.setUint32(F,I),F+=4);let z;for(let O=0;O<I;O++)A(z=R[O]),A(b[z])}:(b,R)=>{Z[F++]=222;let I=F-r;F+=2;let z=0;for(let O in b)(R||b.hasOwnProperty(O))&&(A(O),A(b[O]),z++);Z[I+++r]=z>>8,Z[I+r]=z&255}:b=>{let R=Object.keys(b),I,z=l.transitions||(l.transitions=Object.create(null)),O=0;for(let he=0,re=R.length;he<re;he++){let Ne=R[he];I=z[Ne],I||(I=z[Ne]=Object.create(null),O++),z=I}let $=z[ga];if($)$>=96&&T?(Z[F++]=(($-=96)&31)+96,Z[F++]=$>>5):Z[F++]=$;else{$=l.nextId,$||($=64),$<C&&this.shouldShareStructure&&!this.shouldShareStructure(R)?($=l.nextOwnId,$<B||($=C),l.nextOwnId=$+1):($>=B&&($=C),l.nextId=$+1);let he=R.highByte=$>=96&&T?$-96>>5:-1;z[ga]=$,l[$-64]=R,$<C?(R.isShared=!0,l.sharedLength=$-63,s=!0,he>=0?(Z[F++]=($&31)+96,Z[F++]=he):Z[F++]=$):(he>=0?(Z[F++]=213,Z[F++]=114,Z[F++]=($&31)+96,Z[F++]=he):(Z[F++]=212,Z[F++]=114,Z[F++]=$),O&&(D+=W*O),G.length>=S&&(G.shift()[ga]=0),G.push(z),A(R))}for(let he=0,re=R.length;he<re;he++)A(b[R[he]])},E=b=>{let R;if(b>16777216){if(b-r>r0)throw new Error("Packed buffer would be larger than maximum buffer size");R=Math.min(r0,Math.round(Math.max((b-r)*(b>67108864?1.25:2),4194304)/4096)*4096)}else R=(Math.max(b-r<<2,Z.length-1)>>12)+1<<12;let I=new Nh(R);return Vt=new DataView(I.buffer,0,R),Z.copy?Z.copy(I,0,r,b):I.set(Z.slice(r,b)),F-=r,r=0,Jn=I.length-10,Z=I}}useBuffer(e){Z=e,Vt=new DataView(Z.buffer,Z.byteOffset,Z.byteLength),F=0}};wh=[Date,Set,Error,RegExp,ArrayBuffer,Object.getPrototypeOf(Uint8Array.prototype).constructor,Lc];Pc=[{pack(i,e,t){let r=i.getTime()/1e3;if((this.useTimestamp32||i.getMilliseconds()===0)&&r>=0&&r<4294967296){let{target:n,targetView:s,position:l}=e(6);n[l++]=214,n[l++]=255,s.setUint32(l,r)}else if(r>0&&r<17179869184){let{target:n,targetView:s,position:l}=e(10);n[l++]=215,n[l++]=255,s.setUint32(l,i.getMilliseconds()*4e6+(r/1e3/4294967296>>0)),s.setUint32(l+4,r)}else if(isNaN(r)){if(this.onInvalidDate)return e(0),t(this.onInvalidDate());let{target:n,targetView:s,position:l}=e(3);n[l++]=212,n[l++]=255,n[l++]=255}else{let{target:n,targetView:s,position:l}=e(15);n[l++]=199,n[l++]=12,n[l++]=255,s.setUint32(l,i.getMilliseconds()*1e6),s.setBigInt64(l+4,BigInt(Math.floor(r)))}}},{pack(i,e,t){let r=Array.from(i),{target:n,position:s}=e(this.structuredClone?3:0);this.structuredClone&&(n[s++]=212,n[s++]=115,n[s++]=0),t(r)}},{pack(i,e,t){let{target:r,position:n}=e(this.structuredClone?3:0);this.structuredClone&&(r[n++]=212,r[n++]=101,r[n++]=0),t([i.name,i.message])}},{pack(i,e,t){let{target:r,position:n}=e(this.structuredClone?3:0);this.structuredClone&&(r[n++]=212,r[n++]=120,r[n++]=0),t([i.source,i.flags])}},{pack(i,e){this.structuredClone?n0(i,16,e):i0(Dc?Buffer.from(i):new Uint8Array(i),e)}},{pack(i,e){let t=i.constructor;t!==t0&&this.structuredClone?n0(i,Sh.indexOf(t.name),e):i0(i,e)}},{pack(i,e){let{target:t,position:r}=e(1);t[r]=193}}];function n0(i,e,t,r){let n=i.byteLength;if(n+1<256){var{target:s,position:l}=t(4+n);s[l++]=199,s[l++]=n+1}else if(n+1<65536){var{target:s,position:l}=t(5+n);s[l++]=200,s[l++]=n+1>>8,s[l++]=n+1&255}else{var{target:s,position:l,targetView:c}=t(7+n);s[l++]=201,c.setUint32(l,n+1),l+=4}s[l++]=116,s[l++]=e,s.set(new Uint8Array(i.buffer,i.byteOffset,i.byteLength),l)}function i0(i,e){let t=i.byteLength;var r,n;if(t<256){var{target:r,position:n}=e(t+2);r[n++]=196,r[n++]=t}else if(t<65536){var{target:r,position:n}=e(t+3);r[n++]=197,r[n++]=t>>8,r[n++]=t&255}else{var{target:r,position:n,targetView:s}=e(t+5);r[n++]=198,s.setUint32(n,t),n+=4}r.set(i,n)}function RP(i,e,t,r){let n=i.length;switch(n){case 1:e[t++]=212;break;case 2:e[t++]=213;break;case 4:e[t++]=214;break;case 8:e[t++]=215;break;case 16:e[t++]=216;break;default:n<256?(e[t++]=199,e[t++]=n):n<65536?(e[t++]=200,e[t++]=n>>8,e[t++]=n&255):(e[t++]=201,e[t++]=n>>24,e[t++]=n>>16&255,e[t++]=n>>8&255,e[t++]=n&255)}return e[t++]=r,e.set(i,t),t+=n,t}function zP(i,e){let t,r=e.length*6,n=i.length-r;for(e.sort((s,l)=>s.offset>l.offset?1:-1);t=e.pop();){let s=t.offset,l=t.id;i.copyWithin(s+r,s,n),r-=6;let c=s+r;i[c++]=214,i[c++]=105,i[c++]=l>>24,i[c++]=l>>16&255,i[c++]=l>>8&255,i[c++]=l&255,n=s}return i}function wo(i){if(i.Class){if(!i.pack&&!i.write)throw new Error("Extension has no pack or write function");if(i.pack&&!i.type)throw new Error("Extension has no type (numeric code to identify the extension)");wh.unshift(i.Class),Pc.unshift(i)}Qx(i)}var o0=new bs({useRecords:!1}),FP=o0.pack,VP=o0.pack;var s0=512,UP=1024;var a0=new bs({structuredClone:!0});wo({Class:On.prototype.constructor,type:1,write(i){return U({},i)},read(i){return Object.setPrototypeOf(i,On.prototype),i}});wo({Class:jt.prototype.constructor,type:2,write(i){return[...i]},read(i){return Object.setPrototypeOf(i,jt.prototype),i}});wo({Class:Pn.prototype.constructor,type:3,write(i){return[...i]},read(i){return Object.setPrototypeOf(i,Pn.prototype),i}});wo({Class:Nc.prototype.constructor,type:4,write(i){return i.id},read(i){return new Nc(i)}});wo({Class:Cc.prototype.constructor,type:5,write(i){return i.data},read(i){return new Cc(i)}});function kP(i){var e=0;if(i.length===0)return e;for(let t=0;t<i.length;t++){let r=i[t];e=(e<<5)-e+r,e=e&e}return e}var Bc;(function(r){function i(n){return a0.pack(n)}r.serialize=i;function e(n){return a0.unpack(n)}r.deserialize=e;function t(n){return kP(i(n)).toString()}r.checksum=t})(Bc||(Bc={}));var Gc;(function(t){t.all=["PointLight","SpotLight","DirectionalLight","HemisphereLight"];function e(r){return t.all.includes(r)}t.is=e})(Gc||(Gc={}));var jc;(function(t){function i(r){return e(r)}t.defaultData=i;function e(r){if(r==="PointLight")return{type:r,color:Hn.white,intensity:1,distance:2e3,decay:1,shadows:!0,shadowResolution:1024,shadowRadius:1,depth:2500,helper:!0};if(r==="SpotLight")return{type:r,color:Hn.white,intensity:1,distance:2e3,decay:1,shadows:!0,penumbra:0,angle:30/180*Math.PI,depth:2500,helper:!0};if(r==="DirectionalLight")return{type:r,color:Hn.white,intensity:1,shadows:!0,size:2500,depth:2500,helper:!0};throw new Error("not implemented")}})(jc||(jc={}));var Ss;(function(r){r[r.Front=0]="Front",r[r.Back=1]="Back",r[r.Double=2]="Double"})(Ss||(Ss={}));var Ch;(function(t){t.defaultData={castShadow:!0,receiveShadow:!0};function e(r,n){return r.castShadow===n.castShadow&&r.receiveShadow===n.receiveShadow}t.equals=e})(Ch||(Ch={}));var Lh;(function(t){t.defaultData={flatShading:!1,wireframe:!1,side:0};function e(r,n){return r.flatShading===n.flatShading&&r.side===n.side&&r.wireframe===n.wireframe}t.equals=e})(Lh||(Lh={}));var Ec;(function(e){e.defaultData=fe(U(U({},Lh.defaultData),Ch.defaultData),{cloner:null})})(Ec||(Ec={}));var Lr;(function(n){n[n.Left=1]="Left",n[n.Right=2]="Right",n[n.Center=3]="Center",n[n.Justify=4]="Justify"})(Lr||(Lr={}));var xi;(function(r){r[r.Top=1]="Top",r[r.Center=2]="Center",r[r.Bottom=3]="Bottom"})(xi||(xi={}));var Wi;(function(r){r[r.None=1]="None",r[r.Upper=2]="Upper",r[r.Lower=3]="Lower"})(Wi||(Wi={}));var Rc;(function(e){e.defaultData={width:100,height:100,horizontalAlign:1,verticalAlign:1,fontSize:16,lineHeight:1.5,letterSpacing:1,text:"",textTransform:1,color:Hn.fromHexAndA(6974058,1),alpha:1,font:"roboto_regular"}})(Rc||(Rc={}));var Zt;(function(n){n[n.Normal=0]="Normal",n[n.Multiply=1]="Multiply",n[n.Screen=2]="Screen",n[n.Overlay=3]="Overlay"})(Zt||(Zt={}));var ws;(function(r){r[r.Linear=0]="Linear",r[r.Radial=1]="Radial",r[r.Polar=2]="Polar"})(ws||(ws={}));var zc;(function(r){r[r.RepeatWrapping=1e3]="RepeatWrapping",r[r.ClampToEdgeWrapping=1001]="ClampToEdgeWrapping",r[r.MirroredRepeatWrapping=1002]="MirroredRepeatWrapping"})(zc||(zc={}));var Fc;(function(n){n[n.UV=0]="UV",n[n.Planar=1]="Planar",n[n.Spherical=2]="Spherical",n[n.Cylindrical=3]="Cylindrical"})(Fc||(Fc={}));var Vc;(function(s){s[s.Simplex=0]="Simplex",s[s.SimplexFractal=1]="SimplexFractal",s[s.Ashima=2]="Ashima",s[s.Fbm=3]="Fbm",s[s.Perlin=4]="Perlin"})(Vc||(Vc={}));var Ns;(function(r){function i(n,s){return n==="light"&&s?e(s):t(n)}r.defaultData=i;function e(n){switch(n){case"basic":return{type:"light",category:"basic",alpha:1,visible:!0,mode:0};case"phong":return{category:"phong",specular:{r:.2,g:.2,b:.2},shininess:10,type:"light",alpha:1,visible:!0,mode:0};case"toon":return{category:"toon",specular:{r:.2,g:.2,b:.2},shininess:10,type:"light",alpha:1,visible:!0,mode:0};case"lambert":return{category:"lambert",emissive:{r:.2,g:.2,b:.2,a:1},type:"light",alpha:1,visible:!0,mode:0};case"physical":return{category:"physical",roughness:.2,metalness:.2,reflectivity:.2,type:"light",alpha:1,visible:!0,mode:0}}}function t(n){switch(n){case"texture":return{alpha:1,visible:!0,size:[128,128],mode:0,axis:ys.x,type:"texture",projection:0,texture:{image:"image_0",wrapping:1001,repeat:[1,1],offset:[0,0]},crop:!0};case"color":return{type:"color",alpha:1,visible:!0,mode:0,color:Zr.fromHex(4737101)};case"depth":return{type:"depth",alpha:1,visible:!0,mode:0,gradientType:1,smooth:!1,isVector:!0,isWorldSpace:!1,origin:[0,0,0],direction:[1,0,0],colors:[[1,1,1,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1]],steps:[0,1,1,1,1,1,1,1,1,1],num:2,near:50,far:200};case"normal":return{type:"normal",alpha:1,visible:!0,mode:0,cnormal:[1,1,1]};case"gradient":return{type:"gradient",alpha:1,visible:!0,mode:0,gradientType:0,smooth:!1,colors:[[0,0,0,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1]],steps:[0,1,1,1,1,1,1,1,1,1],num:2,angle:0,offset:[0,0],morph:[0,0]};case"noise":return{type:"noise",alpha:1,visible:!0,mode:0,size:[100,100,100],noiseType:0,scale:1,move:1,colorA:fe(U({},Zr.fromHex(6710886)),{a:1}),colorB:fe(U({},Zr.fromHex(6710886)),{a:1}),colorC:fe(U({},Zr.fromHex(16777215)),{a:1}),colorD:fe(U({},Zr.fromHex(16777215)),{a:1}),distortion:[1,1],fA:[1.7,9.2],fB:[8.3,2.8]};case"fresnel":return{type:"fresnel",alpha:1,visible:!0,mode:0,color:Hn.fromHexAndA(16777215,1),bias:.1,scale:1,intensity:2,factor:1};case"rainbow":return{type:"rainbow",alpha:1,visible:!0,mode:0,filmThickness:30,movement:0,wavelengths:[0,0,0],noiseStrength:0,noiseScale:1,offset:[0,0,0]};case"matcap":return{type:"matcap",alpha:1,visible:!0,mode:0,texture:{image:"matcap_0",wrapping:1001,repeat:[1,1],offset:[0,0]}};case"transmission":return{type:"transmission",alpha:1,visible:!0,mode:0,thickness:10,ior:1.5,roughness:1};case"displace":return{type:"displace",displacementType:"noise",noiseType:0,scale:10,movement:1,offset:[0,0,0],intensity:8,visible:!0}}}})(Ns||(Ns={}));var Cs;(function(c){function i(f){return!f.layers.some(p=>{if(p.data.type==="texture"&&p.data.projection!==0||p.data.type==="depth"&&!p.data.isWorldSpace||p.data.type==="noise"||p.data.type==="displace")return!0})&&!t(f)}c.isMergable=i;function e(f){let h="";return f.layers.forEach(p=>{Object.entries(p.data).forEach(([y,g])=>{h+=`${y}${g}`,Array.isArray(g)?g.forEach(w=>h+=`${w}`):typeof g=="object"?Object.values(g).forEach(w=>{typeof w=="number"?h+=`${w.toFixed(4)}`:h+=`${w}`}):h+=`${g}`})}),h}c.getHash=e;function t(f){let h=0;for(let p of f.layers)"alpha"in p.data&&p.data.type!=="light"&&p.data.type!=="fresnel"&&(h+=(1-h)*p.data.alpha);return h<1}c.isTransparent=t;function r(){return{layers:new jt}}c.defaultEmptyData=r;function n(f="layer1",h="layer2"){return s("phong",f,h)}c.defaultData=n;function s(f,h="layer1",p="layer2"){let y=new jt;return y.push({fi:0,data:Ns.defaultData("light",f),id:h}),y.push({fi:1,data:Ns.defaultData("color"),id:p}),{layers:y}}c.defaultTwoLayerData=s;function l(f,h="basic",p="layer1",y="layer2"){let g=Ns.defaultData("texture");Object.assign(g.texture,{image:f});let w=new jt;return w.push({fi:0,data:g,id:p}),w.push({fi:1,data:Ns.defaultData("light",h),id:y}),{layers:w}}c.defaultTwoLayerTextureData=l})(Cs||(Cs={}));var Ls;(function(r){function i(){return{points:new jt,roundness:0,shapeHoles:[],isClosed:!1}}r.defaultData=i;function e(n,s){let{points:l}=s;if(l){for(let c of l)if(c.data.position[0]===n[0]&&c.data.position[1]===n[1])return!0}return!1}r.isOverlappingExistingPoint=e;function t(n,s){let l=n.controlNext,c=s.controlPrevious;return n.position[0]===l.position[0]&&n.position[1]===l.position[1]&&s.position[0]===c.position[0]&&s.position[1]===c.position[1]}r.isStraightLine=t})(Ls||(Ls={}));var Uc;(function(e){function i(t){return t==="PolygonGeometry"||t==="RectangleGeometry"||t==="StarGeometry"||t==="TriangleGeometry"||t==="EllipseGeometry"}e.is2DParametricMesh=i})(Uc||(Uc={}));var kc;(function(e){function i(t){if(t==="RectangleGeometry")return{width:320,height:320,type:t,cornerRadius:[0,0,0,0],cornerType:0,depth:0,extrudeBevelSize:0,extrudeBevelSegments:1,surfaceMaxCount:1};if(t==="VectorGeometry")return{width:100,height:100,type:t,subdivisions:12,shape:Ls.defaultData(),depth:0,extrudeBevelSize:0,extrudeBevelSegments:1,surfaceMaxCount:1};throw new Error("not implemented")}e.defaultData=i})(kc||(kc={}));var ya;(function(n){n.identity=fe(U({},yc.identity),{hiddenMatrix:Ui.identity});function e(s){return{position:s.position,rotation:s.rotation,scale:s.scale,hiddenMatrix:s.hiddenMatrix}}n.fromObject=e;function t(s,l){return{position:(l==null?void 0:l.position)||s.position,rotation:(l==null?void 0:l.rotation)||s.rotation,scale:(l==null?void 0:l.scale)||s.scale,hiddenMatrix:(l==null?void 0:l.hiddenMatrix)||s.hiddenMatrix}}n.merge=t;function r(s,l){return{position:xs.isEqual(s.position,l.position)?null:l.position,rotation:xs.isEqual(s.rotation,l.rotation)?null:l.rotation,scale:xs.isEqual(s.scale,l.scale)?null:l.scale,hiddenMatrix:Ui.isEqual(s.hiddenMatrix,l.hiddenMatrix)?null:l.hiddenMatrix}}n.diff=r})(ya||(ya={}));var qi;(function(e){e.defaultData=U({states:new jt,events:new jt,visible:!0,raycastLock:!1},ya.identity)})(qi||(qi={}));var l0;(function(e){e.defaultData=U({type:"Empty"},qi.defaultData)})(l0||(l0={}));var _h;(function(e){e.defaultData=U(U({type:"Mesh"},qi.defaultData),Ec.defaultData)})(_h||(_h={}));var c0;(function(e){e.defaultData=U(U({type:"TextFrame"},qi.defaultData),Rc.defaultData)})(c0||(c0={}));var Hc;(function(e){e.defaultData=U(U(U({},qi.defaultData),ya.identity),bo.defaultData)})(Hc||(Hc={}));var u0;(function(e){function i(t){return U(U({},qi.defaultData),jc.defaultData(t))}e.defaultData=i})(u0||(u0={}));var f0;(function(t){t.defaultCamera=U({position:[0,0,1e3],scale:[1,1,1],rotation:[0,0,0],hiddenMatrix:Ui.identity,name:"Play Camera",visible:!0,raycastLock:!1,states:new jt,events:new jt},bo.defaultData),t.defaultMeshObject=fe(U(U({name:"Rectangle"},qi.defaultData),_h.defaultData),{geometry:kc.defaultData("RectangleGeometry"),material:Cs.defaultTwoLayerData("basic","layer1","layer2")})})(f0||(f0={}));var h0;(function(t){function i(r,n){if(n===void 0)return r;let s=U({},r);return"material"in s&&"material"in n&&n.material&&(s.material=fh(s.material,l=>{if(typeof l!="string")for(let[c,f]of Object.entries(n.material.layers)){let h=l.layers.data(c);h&&vo(h,f)}}).data),s.materials&&n.materials&&(s.materials=fh(s.materials,l=>{var c,f;for(let h=0;h<s.materials.length;h++){let p=n.materials[h];if(typeof p!="string")for(let[y,g]of Object.entries(p.layers)){let w=(f=(c=l[h])==null?void 0:c.layers)==null?void 0:f.data(y);w&&vo(w,g)}}}).data),s}t.patchMaterialState=i;function e(r,n){var l,c;if(n===void 0)return r;let s=U({},r);if(Object.assign(s,ya.merge(s,n)),gs.is(r.type)){s.orthographic=U({},s.orthographic),s.perspective=U({},s.perspective);let f=n;((l=f.orthographic)==null?void 0:l.zoom)!==void 0&&(s.orthographic.zoom=f.orthographic.zoom),((c=f.perspective)==null?void 0:c.zoom)!==void 0&&(s.perspective.zoom=f.perspective.zoom)}else if(r.type==="Mesh")s.geometry=U({},s.geometry),Object.assign(s.geometry,n.geometry),s=i(s,n);else if(Gc.is(r.type)){let f=n;s.intensity!==void 0&&(s.intensity=f.intensity),f.color!==void 0&&(typeof f.color=="string"?s.color=f.color:s.color=Zr.clone(f.color))}return s}t.patch=e})(h0||(h0={}));var Yt=5855577;var d0=2857471;var Th=15711266;import{DoubleSide as HP,Mesh as WP,MeshBasicMaterial as qP,ShapeBufferGeometry as $P,Vector2 as JP,Vector3 as KP}from"three";import{FontLoader as XP}from"three/examples/jsm/loaders/FontLoader.js";var Ut=class extends WP{constructor({char:e,originalChar:t,fontFamily:r,letterSpacing:n,fontSize:s,LOD:l=16},c=new qP({color:0,opacity:1,visible:!0,transparent:!0,side:HP})){let f=Ut.loadChar(e,r,l);super(f.geometry,c);this.char=e,this.originalChar=t!=null?t:e,this.fontFamily=r,this.letterSpacing=n,this.fontSize=s,this.LOD=l,this.resolution=f.resolution,this.glyphsHa=f.glyphsHa,this.localPosition=new JP,this.charSize=0,this.geometry.userData={type:"CharacterGeometry",parameters:{char:this.char,fontFamily:this.fontFamily,letterSpacing:this.letterSpacing,fontSize:this.fontSize,lod:this.LOD,resolution:this.resolution,charSize:this.charSize,localPosition:this.localPosition}},this.updateFontSize(this.fontSize)}static get FONTS_PATH(){return Ut._fontPath}static set FONTS_PATH(e){Ut._fontPath=e}updatePosition(e,t){this.localPosition.copy(e);let r=new KP(this.localPosition.x,-this.localPosition.y,0);this.position.copy(r).add(t)}updateFontSize(e){let t=e/this.resolution;this.fontSize=e,this.scale.set(this.fontSize,this.fontSize,1),this.charSize=this.glyphsHa*t*this.letterSpacing}updateFontFamily(e){if(this.fontFamily===e)return;this.fontFamily=e;let t=Ut.loadChar(this.char,e,this.LOD);this.geometry=t.geometry,this.resolution=t.resolution,this.glyphsHa=t.glyphsHa,this.geometry.userData={type:"CharacterGeometry",parameters:{char:this.char,fontFamily:this.fontFamily,letterSpacing:this.letterSpacing,fontSize:this.fontSize,lod:this.LOD,resolution:this.resolution,charSize:this.charSize,localPosition:this.localPosition}},this.updateFontSize(this.fontSize)}updateChar(e){if(this.char===e)return;this.char=e;let t=Ut.loadChar(e,this.fontFamily,this.LOD);this.geometry=t.geometry,this.resolution=t.resolution,this.glyphsHa=t.glyphsHa,this.geometry.userData={type:"CharacterGeometry",parameters:{char:this.char,fontFamily:this.fontFamily,letterSpacing:this.letterSpacing,fontSize:this.fontSize,lod:this.LOD,resolution:this.resolution,charSize:this.charSize,localPosition:this.localPosition}},this.updateFontSize(this.fontSize)}updateLetterSpacing(e){this.letterSpacing!==e&&(this.letterSpacing=e,this.updateFontSize(this.fontSize))}updateLOD(e){if(this.LOD===e)return;this.LOD=e;let t=Ut.loadChar(this.char,this.fontFamily,this.LOD);this.geometry=t.geometry,this.resolution=t.resolution,this.glyphsHa=t.glyphsHa,this.geometry.userData={type:"CharacterGeometry",parameters:{char:this.char,fontFamily:this.fontFamily,letterSpacing:this.letterSpacing,fontSize:this.fontSize,lod:this.LOD,resolution:this.resolution,charSize:this.charSize,localPosition:this.localPosition}},this.updateFontSize(this.fontSize)}clone(){let e={char:this.char,originalChar:this.originalChar,fontFamily:this.fontFamily,letterSpacing:this.letterSpacing,fontSize:this.fontSize,LOD:this.LOD};return new Ut(e).copy(this)}static loadFont(e){return new Promise(function(t,r){Ut.fontCache[e]?t(Ut.fontCache[e]):new XP().load(Ut.FONTS_PATH+e+".json",s=>{Ut.fontCache[e]=s,t(s)},void 0,r)})}static loadChar(e,t,r){if(Ut.charCache[e]){if(Ut.charCache[e][r]&&Ut.charCache[e][r].fontFamily===t)return Ut.charCache[e][r]}else Ut.charCache[e]={};let n=Ut.fontCache[t],s=n.generateShapes(e,1);return Ut.charCache[e][r]={geometry:new $P(s,r),fontFamily:t,resolution:n.data.resolution,glyphsHa:n.data.glyphs[e].ha},Ut.charCache[e][r]}},Rr=Ut;Rr.charCache={},Rr.fontCache={},Rr._fontPath="/_assets/_fonts/";import{DoubleSide as Vu,MeshBasicMaterial as fb,Vector3 as hb,Object3D as Q3}from"three";import{Mesh as AD}from"three";import{BufferGeometry as Dk,ConeBufferGeometry as QP,Float32BufferAttribute as Bk,Vector2 as Gk,Vector3 as jk}from"three";import{BufferGeometry as ZP,CylinderBufferGeometry as YP,Float32BufferAttribute as Ih,Vector2 as Dn,Vector3 as Wc}from"three";var p0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var l,c,f,h,p;let t=Object.assign({},(l=e==null?void 0:e.parameters)!=null?l:{width:100,radialSegments:64,heightSegments:1,openEnded:!1,thetaStart:0,thetaLength:360,cornerRadius:0,cornerSegments:8,hollow:0},i.parameters),r=t.width/2,n=(c=t.radiusTop)!=null?c:r,s=(f=t.radiusBottom)!=null?f:r;return n===s?(n=r,s=r):n>s?(n=r,s=s*r/n):(n=n*r/s,s=r),{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((h=t.height)!=null?h:t.width),depth:Math.abs((p=t.depth)!=null?p:t.width),radiusTop:n,radiusBottom:s})}}static build(i){let{width:e,depth:t,height:r,radialSegments:n,heightSegments:s,openEnded:l,thetaStart:c,thetaLength:f,radiusTop:h,radiusBottom:p,cornerRadius:y,cornerSegments:g,hollow:w}=i.parameters,S;return y||w?S=new qc(h,p,r,n,s,l,c,f*Math.PI/180,y,y,g,w):S=new YP(h,p,r,n,s,l,c,f*Math.PI/180),S.scale(1,1,t/e),Object.assign(S,{userData:fe(U({},i),{type:"CylinderGeometry"})})}};function $i(i,e,t){t.x=i.x*e.x,t.y=i.y,t.z=i.x*e.y}function m0(i){return new Dn(i.y,-i.x)}var qc=class extends ZP{constructor(e,t,r,n,s,l,c,f,h,p,y,g,w=!1){super();this.type="RoundedCylinderBufferGeometry",e=e!==void 0?e:1,t=t!==void 0?t:1,r=r||1,n=Math.floor(n)||8,s=Math.floor(s)||1,l=l!==void 0?l:!1,c=c!==void 0?c:0,f=f!==void 0?f:Math.PI*2,l&&(h=0,p=0);let S=[],T=[],C=[],B=[],G=0,D=r/2,W=new Wc,A=new Wc;w&&e==0&&(e=h),w&&t==0&&(t=p);let q=new Dn(e,D),E=new Dn(t,-D),b=null,R=null,I=null,z=null,O=q.clone().sub(E),$=0,he=0,re=0;g>0&&($=Math.min(e,t)*(1-g),he=e-$,re=t-$);let Ne=q.clone();Ne.x-=$;let ye=Math.PI-O.angle(),Me=O.angle(),Fe=Math.tan(Me/2),k=Math.tan(ye/2),H=Fe+k,_=g?H:k,J=g?H:Fe;if(h=Math.min(h,(e-he)/_,O.length()/H),p=Math.min(p,(t-re)/J,O.length()/H),h>0){let K=h/Fe;b=q.clone().sub(new Dn(K,h)),g&&(I=b.clone(),I.x-=$-H*h),q.sub(O.clone().setLength(K))}if(p>0){let K=p/k;R=E.clone().sub(new Dn(K,-p)),E.add(O.clone().setLength(K)),g&&(z=R.clone(),z.x-=$-H*p,Ne.sub(O.clone().setLength(K)))}O=q.clone().sub(E);let ee=O.length()<.5,oe=[];for(let K=0;K<=n;K++){let ae=[],ne=K/n,Ce=ne*f+c,Y=new Dn(Math.sin(Ce),Math.cos(Ce));z&&R?(se(ae,ne,Y,ye,p,z,-1,!0),se(ae,ne,Y,Me,p,R,-1,!1)):R?(ce(ae,Y,R.x,0,-1),se(ae,ne,Y,Me,p,R,-1,!1)):l||ce(ae,Y,t,re,-1);let le=m0(O).normalize();if($i(le,Y,W),!ee)for(let de=0;de<=s;de++){let xe=de/s,_e=O.clone().multiplyScalar(xe).add(E);$i(_e,Y,A),T.push(A.x,A.y,A.z),C.push(W.x,W.y,W.z),B.push(ne,.5+A.y/r),ae.push(G++)}if(I&&b?(se(ae,ne,Y,ye,h,b,1,!1),se(ae,ne,Y,Me,h,I,1,!0)):b?(se(ae,ne,Y,ye,h,b,1,!1),ce(ae,Y,b.x,0,1)):l||ce(ae,Y,e,he,1),g&&!ee){let de=m0(O).multiplyScalar(-1).normalize();$i(de,Y,W);for(let xe=0;xe<=s;xe++){let _e=xe/s,pe=O.clone().multiplyScalar(-_e).add(Ne);$i(pe,Y,A),T.push(A.x,A.y,A.z),C.push(W.x,W.y,W.z),B.push(ne,.5+A.y/r),ae.push(G++)}}g&&!l&&ae.push(ae[0]),oe.push(ae)}for(let K=0;K<oe.length-1;K++)for(let ae=0;ae<oe[0].length-1;ae++){if(l&&g&&ae==s)continue;let ne=oe[K][ae],Ce=oe[K+1][ae],Y=oe[K+1][ae+1],le=oe[K][ae+1],de=T[Y*3+0],xe=T[Y*3+2];S.push(ne,Ce,le),(de!=0||xe!=0)&&S.push(Ce,Y,le)}f<Math.PI*2&&(ue(-1,oe[0],c),ue(1,oe[oe.length-1],c+f)),this.setIndex(S),this.setAttribute("position",new Ih(T,3)),this.setAttribute("normal",new Ih(C,3)),this.setAttribute("uv",new Ih(B,2));function se(K,ae,ne,Ce,Y,le,de,xe){for(let _e=0;_e<y+1;_e++){let pe=_e/y,we=de<0?pe:1-pe;xe&&(we-=1),we*=Ce;let Ve=new Dn(Math.sin(we),Math.cos(we)*de),Ge=Ve.clone().multiplyScalar(Y).add(le);$i(Ge,ne,A),T.push(A.x,A.y,A.z),$i(Ve,ne,W),C.push(W.x,W.y,W.z),B.push(ae,.5+A.y/r),K.push(G++)}}function ce(K,ae,ne,Ce,Y){let le=new Wc,de=new Dn,xe=[ne,Ce];Y<0&&xe.reverse();for(let _e of xe)de.set(_e,D*Y),$i(de,ae,le),T.push(le.x,le.y,le.z),C.push(0,Y,0),B.push(.5,.5),K.push(G++)}function ue(K,ae,ne){let Ce=new Dn(Math.sin(ne),Math.cos(ne)),Y=new Dn(-Math.cos(ne),Math.sin(ne)),le=new Wc,de=K<0?(pe,we,Ve)=>S.push(pe,we,Ve):(pe,we,Ve)=>S.push(pe,Ve,we),xe=new Dn((e+t+he+re)/4,0);$i(xe,Ce,le),T.push(le.x,le.y,le.z),C.push(Y.x,0,Y.y),B.push(.5,.5);let _e=G++;for(let pe of ae){let we=T.slice(pe*3,pe*3+3);T.push(...we),C.push(Y.x,0,Y.y);let Ve=B.slice(pe*2,pe*2+2);B.push(...Ve),G++}for(let pe=_e+1;pe<G-1;pe++)de(_e,pe,pe+1);de(_e,G-1,_e+1)}}};var g0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,radialSegments:32,heightSegments:8,openEnded:!1,thetaStart:0,thetaLength:360,cornerRadiusTop:0,cornerRadiusBottom:0,cornerSegments:8},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e,depth:t,height:r,radialSegments:n,heightSegments:s,openEnded:l,thetaStart:c,thetaLength:f,cornerRadiusTop:h,cornerRadiusBottom:p,cornerSegments:y}=i.parameters,g;return h>0||p>0||f<360?g=new qc(0,e/2,r,n,s,l,c,f*Math.PI/180,h,p,y,0,!0):g=new QP(e/2,r,n,s,l),g.scale(1,1,t/e),Object.assign(g,{userData:fe(U({},i),{type:"ConeGeometry"})})}};import{BoxBufferGeometry as e2,BufferGeometry as t2,Float32BufferAttribute as Mh,Vector3 as xa}from"three";var y0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,widthSegments:1,heightSegments:1,depthSegments:1,cornerRadius:0,cornerSegments:8},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e,height:t,depth:r,widthSegments:n,heightSegments:s,depthSegments:l,cornerRadius:c,cornerSegments:f}=i.parameters,h;return c==0?h=new e2(e,t,r,n,s,l):h=new x0(e,t,r,n,s,l,c,f),Object.assign(h,{userData:fe(U({},i),{type:"CubeGeometry"})})}},Ah=Math.PI/2,x0=class extends t2{constructor(e=1,t=1,r=1,n=1,s=1,l=1,c=0,f=4){super();this.type="BoxBufferGeometry";let h=this;n=Math.floor(n),s=Math.floor(s),l=Math.floor(l),f=Math.floor(f),c=Math.min(c,e/2,t/2,r/2);let p=[],y=[],g=[],w=[],S=0,T=0;C("z","y","x",-1,-1,r,t,e,l,s,0),C("z","y","x",1,-1,r,t,-e,l,s,1),C("x","z","y",1,1,e,r,t,n,l,2),C("x","z","y",1,-1,e,r,-t,n,l,3),C("x","y","z",1,-1,e,t,r,n,s,4),C("x","y","z",-1,-1,e,t,-r,n,s,5),c>0&&(B("z","y","x",-1,-1,1,r,t,e,l,0),B("z","y","x",1,-1,-1,r,t,e,l,1),B("z","y","x",-1,1,-1,r,t,e,l,1),B("z","y","x",1,1,1,r,t,e,l,0),B("x","y","z",-1,-1,-1,e,t,r,n,0),B("x","y","z",1,-1,1,e,t,r,n,1),B("x","y","z",-1,1,1,e,t,r,n,0),B("x","y","z",1,1,-1,e,t,r,n,1),B("y","x","z",-1,-1,1,t,e,r,s,0),B("y","x","z",1,-1,-1,t,e,r,s,1),B("y","x","z",1,1,1,t,e,r,s,1),B("y","x","z",-1,1,-1,t,e,r,s,0),G(1,1,1),G(-1,1,1),G(1,-1,1),G(-1,-1,1),G(1,1,-1),G(-1,1,-1),G(1,-1,-1),G(-1,-1,-1)),this.setIndex(p),this.setAttribute("position",new Mh(y,3)),this.setAttribute("normal",new Mh(g,3)),this.setAttribute("uv",new Mh(w,2));function C(D,W,A,q,E,b,R,I,z,O,$){let he=(b-2*c)/z,re=(R-2*c)/O,Ne=b/2-c,ye=R/2-c,Me=I/2,Fe=z+1,k=O+1,H=0,_=0,J=new xa;for(let ee=0;ee<k;ee++){let oe=ee*re-ye;for(let se=0;se<Fe;se++){let ce=se*he-Ne;J[D]=ce*q,J[W]=oe*E,J[A]=Me,y.push(J.x,J.y,J.z),J[D]=0,J[W]=0,J[A]=I>0?1:-1,g.push(J.x,J.y,J.z),w.push(se/z),w.push(1-ee/O),H+=1}}for(let ee=0;ee<O;ee++)for(let oe=0;oe<z;oe++){let se=S+oe+Fe*ee,ce=S+oe+Fe*(ee+1),ue=S+(oe+1)+Fe*(ee+1),K=S+(oe+1)+Fe*ee;p.push(se,ce,K),p.push(ce,ue,K),_+=6}h.addGroup(T,_,$),T+=_,S+=H}function B(D,W,A,q,E,b,R,I,z,O,$){let he=(R-2*c)/O,re=R/2-c,Ne=I/2-c,ye=z/2,Me=O+1,Fe=0,k=0,H=new xa,_=new xa;for(let J=0;J<f+1;J++){let ee=J/f*Ah,oe=Math.sin(ee)*c,se=(1-Math.cos(ee))*c,ce=Math.sin(ee),ue=Math.cos(ee);H[W]=(Ne+oe)*E,H[A]=(ye-se)*b,_[D]=0,_[W]=ce*Math.sign(H[W]),_[A]=ue*Math.sign(H[A]);for(let K=0;K<Me;K++){let ae=K*he-re;H[D]=ae*q,y.push(H.x,H.y,H.z),g.push(_.x,_.y,_.z),w.push(K/O),w.push(0),Fe+=1}}for(let J=0;J<f;J++)for(let ee=0;ee<O;ee++){let oe=S+ee+Me*J,se=S+ee+Me*(J+1),ce=S+(ee+1)+Me*(J+1),ue=S+(ee+1)+Me*J;p.push(oe,se,ue),p.push(se,ce,ue),k+=6}h.addGroup(T,k,$),T+=k,S+=Fe}function G(D,W,A){let q=new xa,E=new xa(e/2,t/2,r/2);E.subScalar(c);let b=[],R=D*W*A>0?(z,O,$)=>p.push(z,O,$):(z,O,$)=>p.push(z,$,O);for(let z=0;z<=f;z++){let O=[],$=Ah*(1-z/f),he=Math.cos($),re=Math.sin($),Ne=0;for(let ye=0;ye<=z;ye++){let Me=Math.cos(Ne),Fe=Math.sin(Ne);q.x=he*Me,q.y=re,q.z=he*Fe;let k=E.clone().addScaledVector(q,c);y.push(D*k.x,W*k.y,A*k.z),g.push(D*q.x,W*q.y,A*q.z),w.push(0,0),O.push(S++),Ne+=Ah/z}b.push(O)}let I=b.length-1;for(let z=0;z<I;z++){let O=b[z],$=b[z+1],he=O.length-1;R(O[0],$[1],$[0]);for(let re=1;re<=he;re++)R(O[re-1],O[re],$[re]),R(O[re],$[re+1],$[re])}}}};import{BufferGeometry as r2,Float32BufferAttribute as Oh,Triangle as n2,Vector3 as vi,Vector2 as Ph}from"three";var No=class extends r2{constructor(e=[],t=[],r="",n=1,s=.2,l=4){super();this.type="PolyhedronGeometryRound";let c=[],f=[],h=[];p(),y(),this.setAttribute("position",new Oh(c,3)),this.setAttribute("normal",new Oh(h,3)),this.setAttribute("uv",new Oh(f,2));return;function p(){var Fe;s=Math.min(1-1e-5,s),s==0&&(l=0);let w={IcosahedronGeometry:5,DodecahedronGeometry:3,HexahedronGeometry:3,OctahedronGeometry:4,TetrahedronGeometry:3}[r],S=new vi,T=S.clone(),C=new n2,B=s*n,G=n-B,D=l+1,W=new vi,A=(k,H)=>W.subVectors(k,H).normalize(),q=(k,H)=>Array(k).fill(void 0).map(H),E=q(e.length/3,(k,H)=>new vi().fromArray(e,H*3).setLength(n)),b=[],R=1e6;for(let k=0;k<E.length;k++){let H=E[k],_=[],J,ee,oe,se=1e10,ce=-1;for(;(ce=t.indexOf(k,ce+1))!=-1;){let ne=ce-ce%3;J=t[ne+(ce+1)%3],ee=t[ne+(ce+2)%3],oe=H.distanceToSquared(E[J]),se=Math.min(se,oe),_.push([J,ee,oe])}se+=1e-6;let ue=[],K=0,ae=_.length;for(let ne=0;ne<ae;ne++){[J,ee,oe]=_[K];let Ce=((Fe=b[J])==null?void 0:Fe.includes(k))==!0;oe<=se&&ue.push(J+ +Ce*R),K=_.findIndex(Y=>Y[0]==ee)}b.push(ue)}let I=[];{let k=0,H=0,_,J,ee=w==3;for(let oe=0;oe<=l;oe++){_=oe*(oe+1)/2,J=(oe+1)*(oe+2)/2;for(let se=0;se<l-oe;se++)[k,H]=[_+se+oe+2,J+se+oe+3],I.push(_,J,...ee?[H,_]:[k,J],H,k),[_,J]=[k,H];I.push(_,J,_+l+2)}}let z=S.clone(),O=S.clone(),$=S.clone(),he=S.clone(),re=S.clone(),Ne=[],ye=q(E.length,()=>q(w,()=>S.clone()));for(let k=0;k<E.length;k++){S.copy(E[k]).normalize(),z.copy(S).multiplyScalar(G);let H=b[k];for(let ue=0;ue<H.length;ue++){let K=H[ue],ae=H[(ue+1)%w];C.setFromPointsAndIndices(E,k,K%R,ae%R),C.b.sub(C.a).setLength(1e10).add(C.a),C.c.sub(C.a).setLength(1e10).add(C.a),C.closestPointToPoint(z,ye[k][ue])}let _=[],J=[],ee=[],oe=new vi;l==0&&[...ye[k]].reduce((ue,K)=>ue.add(K),oe).multiplyScalar(1/w);for(let ue=0;ue<w;ue++){let K=[],ae=(ue-1+w)%w,ne=ye[k][ae],Ce=ye[k][ue];S.copy(ne).sub(z),T.copy(Ce).sub(z);let Y=z.angleTo(S),le=S.angleTo(T),de=Math.cos(Y)*B;l==0?O.copy(oe):O.copy(z).setLength(G+de),J.push(de);let xe=[O,ne,Ce];for(let _e=0;_e<2;_e++){let pe=xe[_e],we=xe[_e+1];he.subVectors(pe,z),re.subVectors(we,z),$.crossVectors(he,re).normalize();for(let Ve=0;Ve<D;Ve++){let Ge=[Y,le][_e]*Ve/D;S.copy(he).applyAxisAngle($,Ge).add(z),_.push(S.clone()),_e&&(A(S,z),K.push([Ve==0?pe:S.clone(),W.clone()]))}_e&&(A(we,z),K.push([we,W.clone()]))}ee.push(K)}Ne.push(ee);let se=2*D,ce=2;for(let ue=0;ue<w;ue++){let K=se*ue,ae=se*((ue+1)%w),ne=[_[K]];for(let Y=1;Y<D;Y++){he=_[K+Y],re=_[ae+Y],ne.push(he);for(let le=1,de=Y-ce+1;le<=de;le++)S.lerpVectors(he,re,le/(de+1)),S.sub(z).setLength(J[ue]).add(z),ne.push(S.clone());ne.push(re)}for(let Y=0;Y<D;Y++)ne.push(_[Y+D+K]);ne.push(_[ae+D]);let Ce=I.map(Y=>ne[Y]);c.push(...Ce.map(Y=>[Y.x,Y.y,Y.z]).flat()),h.push(...Ce.map(Y=>(A(Y,z),[W.x,W.y,W.z])).flat())}}let Me=[];for(let k=0;k<b.length;k++)for(let H=0;H<w;H++){let _=b[k][H];if(_<R){let J=b[_].findIndex(se=>se%R==k),ee=Ne[k][H],oe=Ne[_][J];for(let se=0;se<D;se++){let ce=ee[se],ue=oe[D-se],K=ee[se+1],ae=oe[D-(se+1)];[ce,ue,K,K,ue,ae].forEach(ne=>{c.push(ne[0].x,ne[0].y,ne[0].z),h.push(ne[1].x,ne[1].y,ne[1].z)})}Me.push(ee[0][0],oe[D][0],ee[D][0],oe[0][0])}}for(;Me.length;){let k,H,_,J;[k,H]=Me.splice(0,2);let ee=[k];for(;k!=H;)ee.push(H),_=Me.indexOf(H),J=_%2,H=Me.splice(_-J,2)[1-J];W.subVectors(ee[0],ee[1]).cross(S.subVectors(ee[0],ee[2])).normalize();let oe=W.dot(ee[0])<0;oe&&W.negate();for(let se=1;se<=ee.length-2;se++)[ee[se+ +oe],ee[se+1-+oe],ee[0]].forEach(ce=>{c.push(ce.x,ce.y,ce.z),h.push(W.x,W.y,W.z)})}}function y(){let g=new vi;for(let E=0;E<c.length;E+=3){g.x=c[E+0],g.y=c[E+1],g.z=c[E+2];let b=A(g)/2/Math.PI+.5,R=q(g)/Math.PI+.5;f.push(b,1-R)}let w=new vi,S=new vi,T=new vi,C=new vi,B=new Ph,G=new Ph,D=new Ph,W=(E,b,R,I)=>{I<0&&E.x===1&&(f[b]=E.x-1),R.x===0&&R.z===0&&(f[b]=I/2/Math.PI+.5)};for(let E=0,b=0;E<c.length;E+=9,b+=6){w.set(c[E+0],c[E+1],c[E+2]),S.set(c[E+3],c[E+4],c[E+5]),T.set(c[E+6],c[E+7],c[E+8]),B.set(f[b+0],f[b+1]),G.set(f[b+2],f[b+3]),D.set(f[b+4],f[b+5]),C.copy(w).add(S).add(T).divideScalar(3);let R=A(C);W(B,b+0,w,R),W(G,b+2,S,R),W(D,b+4,T,R)}for(let E=0;E<f.length;E+=6){let b=f[E+0],R=f[E+2],I=f[E+4],z=Math.max(b,R,I),O=Math.min(b,R,I);z>.9&&O<.1&&(b<.2&&(f[E+0]+=1),R<.2&&(f[E+2]+=1),I<.2&&(f[E+4]+=1))}function A(E){return Math.atan2(E.z,-E.x)}function q(E){return Math.atan2(-E.y,Math.sqrt(E.x*E.x+E.z*E.z))}}}static fromJSON(e){return new No(e.vertices,e.indices,e.radius,e.corner,e.cornerSides)}};import{DodecahedronBufferGeometry as i2}from"three";var v0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,detail:0,corner:0,cornerSides:4},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e,height:t,depth:r,detail:n,corner:s,cornerSides:l}=i.parameters,c=n===0&&s!==0?new $c(e*.5,s,l):new i2(e*.5,n);return c.scale(1,t/e,r/e),Object.assign(c,{userData:fe(U({},i),{type:"DodecahedronGeometry"})})}},$c=class extends No{constructor(e=1,t=.2,r=4){let n=(1+Math.sqrt(5))/2,s=1/n,l=[-1,-1,-1,-1,-1,1,-1,1,-1,-1,1,1,1,-1,-1,1,-1,1,1,1,-1,1,1,1,0,-s,-n,0,-s,n,0,s,-n,0,s,n,-s,-n,0,-s,n,0,s,-n,0,s,n,0,-n,0,-s,n,0,-s,-n,0,s,n,0,s],c=[3,11,7,3,7,15,3,15,13,7,19,17,7,17,6,7,6,15,17,4,8,17,8,10,17,10,6,8,0,16,8,16,2,8,2,10,0,12,1,0,1,18,0,18,16,6,10,2,6,2,13,6,13,15,2,16,18,2,18,3,2,3,13,18,1,9,18,9,11,18,11,3,4,14,12,4,12,0,4,0,8,11,9,5,11,5,19,11,19,7,19,5,14,19,14,4,19,4,17,1,12,14,1,14,5,1,5,9],f="DodecahedronGeometry";super(l,c,f,e,t,r);this.type=f}static fromJSON(e){return new $c(e.radius,e.corner,e.cornerSides)}};import{EventDispatcher as m2,Plane as g2,Shape as O0,Vector2 as bi,Vector3 as y2,MathUtils as zh,LineCurve as Fh,QuadraticBezierCurve as P0,CubicBezierCurve as Xc}from"three";import{CubicBezierCurve as Jc,EllipseCurve as o2,LineCurve as Kc,LineCurve3 as s2,MathUtils as a2,QuadraticBezierCurve as Dh,SplineCurve as l2,Vector2 as Bn,Vector3 as b0}from"three";var va=1e-12,ba=class{constructor(e){this.position=new Bn;this.startPosition=new Bn;this.uuid=a2.generateUUID();this.position=e.clone()}start(){this.reset()}reset(){this.startPosition.copy(this.position)}applyOffset(e){this.position.copy(this.startPosition).add(e)}copy(e){return this.position.copy(e.position),this.startPosition.copy(e.startPosition),this}clone(){return new ba(this.position).copy(this)}toJSON(){return[this.position.x,this.position.y]}},Sa=class extends ba{constructor(e){super(e.position);this.parent=e}copy(e){return super.copy(e),this}clone(){return new Sa(this.parent).copy(this)}},Xn=class extends ba{constructor(e,t){super(t);this.controls=[];this.roundness=0;this.areControlsDirectionsMirrored=!0;this.uuid=e,this.controls.push(new Sa(this),new Sa(this))}static create(e,t){let r=new Xn(e,new Bn(...t.position));return r.controls[0].position.set(...t.controlPrevious.position),r.controls[1].position.set(...t.controlNext.position),r.roundness=t.roundness,r.areControlsDirectionsMirrored=t.areControlsDirectionsMirrored,r}getOppositeControl(e){let t=this.controls.indexOf(e);return t===0?this.controls[1]:t===1?this.controls[0]:null}applyOffsetToControls(e,t=1){for(let r=0,n=this.controls.length;r<n;r++){let s=this.controls[r];this.position.distanceTo(s.position)<=t?s.position.copy(this.position):s.applyOffset(e)}}controlsMoved(){return!(this.position.equals(this.controls[0].position)&&this.position.equals(this.controls[1].position))}copy(e){return super.copy(e),this.controls[0].copy(e.controls[0]),this.controls[1].copy(e.controls[1]),this.roundness=e.roundness,this.uuid=e.uuid,this}clone(){return new Xn(this.uuid,this.position).copy(this)}toJSON(){return super.toJSON().concat(this.controls[0].toJSON(),this.controls[1].toJSON(),[this.roundness])}},Bh=i=>i,wa=new Bn,Gh=new Bn,c2=new Bn,u2=new Bn,f2=new Bn,h2=new Bn,S0=new b0,w0=new b0;function N0(i){let e=new Bn;e.addVectors(i.v0,wa.subVectors(i.v1,i.v0).multiplyScalar(2/3));let t=new Bn;return t.addVectors(i.v2,Gh.subVectors(i.v1,i.v2).multiplyScalar(2/3)),new Jc(i.v0,e,t,i.v2)}function Na(i,e,t=Number.EPSILON){return Math.abs(i-e)<t}function d2(i,e,t=Number.EPSILON){return i.distanceTo(e)<t}function p2(i,e,t=Number.EPSILON){return i.distanceTo(e)<t}function jh(i,e,t){let r=Math.sqrt(Math.pow(e.x-i.x,2)+Math.pow(e.y-i.y,2)),n=Math.sqrt(Math.pow(e.x-t.x,2)+Math.pow(e.y-t.y,2)),s=Math.sqrt(Math.pow(t.x-i.x,2)+Math.pow(t.y-i.y,2));return Math.acos((n*n+r*r-s*s)/(2*n*r))}function C0(i,e,t,r,n){let s=Math.sqrt(Math.pow(e.x-i.x,2)+Math.pow(e.y-i.y,2)),l=(i.y+e.y)/2,c=(i.x+e.x)/2,f=Math.sqrt(Math.pow(t,2)-Math.pow(s/2,2))*(i.y-e.y)/s,h=Math.sqrt(Math.pow(t,2)-Math.pow(s/2,2))*(e.x-i.x)/s;return r.set(c+f,l+h),n.set(c-f,l-h),[r,n]}function L0(i,e,t){let r=i.distanceTo(t),n=e.distanceTo(t);return r<n?e:i}function _0(i,e,t,r,n,s){let l=e.x-i.x,c=e.y-i.y,f=t.x-i.x,h=t.y-i.y,p=Math.sqrt((l+f)*(l+f)+(c+h)*(c+h)),y;return jh(e,i,t)>Math.PI&&(p*=-1),Na(h,c)?y=(c+h)*(r/p-.5)*8/3/(l-f):y=(l+f)*(r/p-.5)*8/3/(h-c),n.set(e.x-y*c,e.y+y*l),s.set(t.x+y*h,t.y-y*f),[n,s]}function Eh(i,e){return i.position.equals(i.controls[1].position)&&e.position.equals(e.controls[0].position)}function T0(i,e,t,r,n=.5){let s=wa.subVectors(e,i).multiplyScalar(n).add(i),l=Gh.subVectors(t,e).multiplyScalar(n).add(e),c=c2.subVectors(r,t).multiplyScalar(n).add(t),f=s,h=u2.subVectors(l,s).multiplyScalar(n).add(s),p=f2.subVectors(c,l).multiplyScalar(n).add(l),y=c,g=h2.subVectors(p,h).multiplyScalar(n).add(h);return[i.x,i.y,f.x,f.y,h.x,h.y,g.x,g.y,p.x,p.y,y.x,y.y,r.x,r.y]}function I0(i,e,t=12,r=!0){let n=w0.set(0,0,0),s,l=0,c=[];for(let f=0;f<e.length;f++){let h=Bh(e[f]),p=wa,y=Ji(h,t);c.push(y);for(let g=0;g<=y;g++)if(h instanceof Jc||h instanceof Dh||h instanceof Kc){if(h.getPoint(g/y,p),n.set(p.x,p.y,0),s!==void 0&&p2(s,n))continue;s===void 0&&(s=S0),s.copy(n),i.setXYZ(l,n.x,n.y,n.z),l++}}return r&&l>1&&!(i.getX(l-1)===i.getX(0)&&i.getY(l-1)===i.getY(0)&&i.getZ(l-1)===i.getZ(0))&&(i.setXYZ(l,i.getX(0),i.getY(0),i.getZ(0)),l++),i}function M0(i,e,t,r=12,n=!0){let s=w0.set(0,0,0),l=0,c=[];for(let f=0;f<e.length;f++){if(t[f]===!1)continue;let h,p=Bh(e[f]),y=wa,g=Ji(p,r);c.push(g);for(let w=0;w<=g;w++)if(p instanceof Jc||p instanceof Dh||p instanceof Kc){if(p.getPoint(w/g,y),s.set(y.x,y.y,0),h==null?void 0:h.equals(s))continue;h===void 0?h=S0:(i.setXYZ(l,h.x,h.y,h.z),l++,i.setXYZ(l,s.x,s.y,s.z),l++),h.copy(s)}}return n&&l>1&&!(i.getX(l-1)===i.getX(0)&&i.getY(l-1)===i.getY(0)&&i.getZ(l-1)===i.getZ(0))&&(i.setXYZ(l,i.getX(0),i.getY(0),i.getZ(0)),l++),c}function Rh(i,e=12,t=!1){let r=[];for(let n=0,s=i.length;n<s;n++){let l=i[n],c=0;if(t&&l.roundedCurveCorner!==void 0){let f=Ji(l.roundedCurveCorner,e)*.5;n>0&&(r[n-1]+=f),c+=f}l.curveAfter!==void 0&&(c+=Ji(l.curveAfter,e)),r.push(c)}return i.length>0&&t&&i[0].roundedCurveCorner!==void 0&&(r[i.length-1]+=Ji(i[0].roundedCurveCorner,e)*.5),r}function Ji(i,e=12){return i&&i instanceof o2?e*2:i&&(i instanceof Kc||i instanceof s2)?1:i&&i instanceof l2?e*i.points.length:e}function A0(i,e,t=12,r=!0){let n,s=0;for(let l=0;l<e.length;l++){let c=Bh(e[l]),f=Ji(c,t),h=wa;for(let p=0;p<=f;p++)if(c instanceof Jc||c instanceof Dh||c instanceof Kc){if(c.getPoint(p/f,h),n!==void 0&&d2(n,h,va))continue;n===void 0&&(n=Gh),n.copy(h),i.push(h.x,h.y),s++}}return Na(i[0],i[i.length-2],va)&&Na(i[1],i[i.length-1],va)&&(i.pop(),i.pop()),r&&s>1&&!(Na(i[s-1],i[1],va)&&Na(i[s-2],i[0],va))&&(i.push(i[0],i[1]),s++),i}var Vh=new bi,x2=new bi,v2=new bi,b2=new bi,S2=new bi,w2=new bi,st=class extends O0{constructor(e=100,t=100){super();this.points=[];this.shapeHoles=[];this.eventDispatcher=new m2;this.plane=new g2(new y2(0,0,-1));this.subdivision=0;this.controlSnapDistance=4;this.pointIDs=0;this.isMesh2D=!1;this._roundness=0;this.isClosed=!1;this.useCubicForRoundedCorners=!0;this.uuid=zh.generateUUID();this.needsUpdate=!1;this.roundedCurves=[];this._width=e,this._height=t}static createFromState(e,t,r){let n=new st;return n.isClosed=e.isClosed,n.points=e.points.map(s=>Xn.create(s.id,s.data)),typeof e.roundness=="number"&&(n.roundness=e.roundness),n.shapeHoles=e.shapeHoles.map(s=>st.createFromState(s)),t!==void 0&&r!==void 0&&n.applySize(t,r),n.update(),n}get width(){return this._width}get height(){return this._height}get roundness(){return this._roundness}set roundness(e){if(this._roundness!==e){this._roundness=e;for(let t=0,r=this.points.length;t<r;t++)this.points[t].roundness=e;this.needsUpdate=!0}}getPointsIndexesByIds(e){return e.map(t=>this.getPointIndexById(t)).filter(t=>t>=0)}getPointIndexById(e){return this.points.findIndex(t=>t.uuid===e)}getLineIndexById(e){return this.getPointIndexById(e)}getBezierPoint(e){if(e<=this.points.length-1)return this.points[e];if(this.shapeHoles.length>0)for(let t=0,r=this.shapeHoles.length;t<r;t++){let n=this.shapeHoles[t],s=e-this.points.length;if(s<=n.points.length-1)return n.points[s]}throw new Error("This shape does not have a point for this index: "+e)}getBezierPointIndex(e){let t=this.points.indexOf(e);if(t>=0)return t;if(t=this.points.length,this.shapeHoles.length>0)for(let r=0,n=this.shapeHoles.length;r<n;r++){let s=this.shapeHoles[r],l=s.points.indexOf(e);if(l>=0)return t+l;t+=s.points.length}return-1}getAllPoints(){let e=[].concat(...this.shapeHoles.map(t=>t.points));return[...this.points,...e]}applySize(e,t){e===0&&(e=.001),t===0&&(t=.001),this._width=e,this._height=t}applyScale(e,t){let r=Vh.set(e,t);for(let n=0,s=this.points.length;n<s;n++){let l=this.points[n];l.position.multiply(r),l.controls[0].position.multiply(r),l.controls[1].position.multiply(r)}for(let n=0,s=this.shapeHoles.length;n<s;n++)this.shapeHoles[n].applyScale(e,t);this._update(!1)}createPoint(e,t=0,r=zh.generateUUID()){let n;e instanceof bi?n=e:n=new bi(e,t);let s=new Xn(r,n);return s.roundness=this.roundness,s}addPoint(e){this.points.push(e),this.needsUpdate=!0}addPointAt(e,t){this.points.splice(t,0,e),this.needsUpdate=!0}getPointByUuid(e){for(let t=0,r=this.points.length;t<r;t++){let n=this.points[t];if(n.uuid===e)return n}}getFirstPoint(){return this.points[0]}getLastPoint(){return this.points[this.points.length-1]}removePoint(e){let t=this.points.indexOf(e);t>=0&&this.points.splice(t,1),this.needsUpdate=!0}removePointById(e){let t=this.points.find(r=>r.uuid===e);t&&this.removePoint(t)}update(e=!0){for(let t=0,r=this.shapeHoles.length;t<r;t++)this.shapeHoles[t].update(!1);this._update(e)}extractShapePointsToBuffer(e,t=12,r=!1){this.subdivision=t,this.curveDivisions===void 0&&this.computeCurveDivisions(t);let n=r?this.roundedCurveDivisions:this.curveDivisions;return I0(e,r?this.roundedCurves:this.curves,t,this.autoClose),n.reduce((s,l)=>s+l,0)+1}computeCurveDivisions(e=12){return this.curveDivisions=Rh(this.points,e,!1),this.roundedCurveDivisions=Rh(this.points,e,!0),this.curveDivisions}extractFilteredShapePointsToBuffer(e,t,r=12){return M0(e,this.curves,t,r,this.autoClose).reduce((s,l)=>s+l,0)*2}extractShapePointsToFlatArray(e,t=12){return this.subdivision=t,this.curveDivisions===void 0&&this.computeCurveDivisions(t),A0(e,this.roundedCurves,t,this.autoClose)}getCurveIndexFromVertexId(e,t=!1){let r=0;this.curveDivisions===void 0&&this.computeCurveDivisions(this.subdivision);let n=t?this.roundedCurveDivisions:this.curveDivisions,s=0;t&&this.points[0].roundedCurveCorner!==void 0&&(s=Ji(this.points[0].roundedCurveCorner,this.subdivision)*.5);let l=e-s;l<0&&(l+=n.reduce((c,f)=>c+f,0));for(let c=0,f=n.length;c<f;c++){let h=n[c];if(l<r+h)return[c,(l-r+1)/h];r+=h}return[0,1]}getCurveT(e,t,r){let n=this.points[e],s=this.points[e>=this.points.length-1?0:e+1],l=this.curveDivisions,c=l[e];if(Eh(n,s)){let p=n.position.distanceTo(s.position);return n.position.distanceTo(Vh.set(r.x,r.y))/p}let f=0;for(let p=0;p<e;p++)f+=l[p];return(t-f)/c}dispose(){this.eventDispatcher=null}_applyCurveForPoint(e,t){Eh(t,e)?this.lineTo(e.position.x,e.position.y):this.bezierCurveTo(t.controls[1].position.x,t.controls[1].position.y,e.controls[0].position.x,e.controls[0].position.y,e.position.x,e.position.y);let r=this.curves[this.curves.length-1];e.curveBefore=r,t.curveAfter=r;let n=r.clone();e.roundedCurveBefore=n,t.roundedCurveAfter=n,e.roundedCurveCorner=void 0,this.roundedCurves.push(n)}_update(e=!0){var r;if(this.curves=[],this.roundedCurves=[],!this.points.length)return;for(let n=0,s=this.points.length;n<s;n++){let l=this.points[n];if(n===0)this.moveTo(l.position.x,l.position.y);else{let c=this.points[n-1];this._applyCurveForPoint(l,c)}}let t=this.getLastPoint();if((t==null?void 0:t.curveAfter)&&(t.curveAfter=void 0),this.isClosed){let n=this.points[0],s=this.points[this.points.length-1];this._applyCurveForPoint(n,s)}if(this.points.length>2){let n=0;for(let s=0,l=this.points.length;s<l;s++){let c=this.points[s],f=c.roundness;if(!c.controlsMoved()&&f>0){let h=c.curveBefore,p=c.curveAfter;if(h===void 0||p===void 0)continue;let y=c.roundedCurveBefore,g=c.roundedCurveAfter,w=h.getLength(),S=p.getLength(),T=Math.min(f,w*.499),C=Math.min(f,S*.499),B=Math.min(T,C),G=1-B/w,D=B/S,W=h.getPointAt(G,Vh),A=p.getPointAt(D,x2);this._subSplitCurve(h,y,G,W,void 0),this._subSplitCurve(p,g,D,void 0,A);let q;if(this.useCubicForRoundedCorners){let E=jh(W,c.position,A)/2,b=Math.tan(E)*W.distanceTo(c.position),[R,I]=C0(W,A,b,v2,b2),z=L0(R,I,c.position),[O,$]=_0(z,W,A,b,S2,w2);q=new Xc(W.clone(),O.clone(),$.clone(),A.clone())}else q=new P0(W.clone(),c.position.clone(),A.clone());c.roundedCurveCorner=q,this.roundedCurves.splice(s+n,0,q),n++}}}e&&((r=this.eventDispatcher)==null||r.dispatchEvent({type:"update"}))}_subSplitCurve(e,t,r,n,s){if(e instanceof Fh)n!==void 0&&t.v2.copy(n),s!==void 0&&t.v1.copy(s);else{let l=e,c=t,f=l.getUtoTmapping(r,0),h=T0(l.v0,l.v1,l.v2,l.v3,f);return n!==void 0&&(c.v0.set(h[0],h[1]),c.v1.set(h[2],h[3]),c.v2.set(h[4],h[5]),c.v3.set(h[6],h[7])),s!==void 0&&(c.v0.set(h[6],h[7]),c.v1.set(h[8],h[9]),c.v2.set(h[10],h[11]),c.v3.set(h[12],h[13])),c}return t}clone(){let e=new st(this._width,this._height);return e.points=this.points.map(t=>t.clone()),e.isClosed=this.isClosed,e.roundness=this.roundness,e.isMesh2D=this.isMesh2D,e.shapeHoles=this.shapeHoles.map(t=>t.clone()),e}toJSON(){return{points:this.points.reduce((e,t)=>e.concat(t.toJSON()),[]),shapeHoles:this.shapeHoles.map(e=>e.toJSON()),isClosed:this.isClosed,roundness:this.roundness}}fromJSON(e){var r;this.points=[],this.pointIDs=0;let t=e.points.length/7;for(let n=0;n<t;n++){let s=n*7,l=e.points[s+0],c=e.points[s+1],f=e.points[s+2],h=e.points[s+3],p=e.points[s+4],y=e.points[s+5],g=e.points[s+6],w=new Xn(zh.generateUUID(),new bi(l,c));w.controls[0].position.set(f,h),w.controls[1].position.set(p,y),w.roundness=g,this.points.push(w)}return this.shapeHoles=((r=e.shapeHoles)==null?void 0:r.length)?e.shapeHoles.map(n=>{let s=new st;return s.fromJSON(n),s}):[],this.isClosed=e.isClosed,this._roundness=e.roundness,this._update(),this}fromShape(e){let t=(n,s)=>{s instanceof Xc&&s.v3.equals(n.position)&&n.controls[0].position.copy(s.v2)},r=n=>{let s=[],l,c;for(l=0,c=n.length;l<c;l++)n[l]instanceof P0&&(n[l]=N0(n[l]));for(l=0,c=n.length;l<c;l++){let p=n[l],y=l>0?n[l-1]:null,g;p instanceof Xc?(g=this.createPoint(p.v0),g.controls[1].position.copy(p.v1)):p instanceof Fh&&(g=this.createPoint(p.v1)),g!==void 0&&(y!==null&&t(g,y),s.push(g))}let f=n[n.length-1],h=!1;return f instanceof Xc?f.v3.equals(s[0].position)&&(s[0].controls[0].position.copy(f.v2),h=!0):f instanceof Fh&&f.v2.equals(s[0].position)&&(h=!0),this.isClosed=h,s};return this.points=r(e.curves),e instanceof O0&&(this.shapeHoles=e.holes.map(n=>{let s=new st;return s.fromShape(n),s})),this.update(),this}};var Uh=Math.PI*2;function kh({x:i,y:e},t,r,n,s){return{x:i*t+n,y:e*r+s}}function N2(i,e){let t=e===1.5707963267948966?.551915024494:e===-1.5707963267948966?-.551915024494:4/3*Math.tan(e/4),r=Math.cos(i),n=Math.sin(i),s=Math.cos(i+e),l=Math.sin(i+e);return[{x:r-n*t,y:n+r*t},{x:s+l*t,y:l-s*t},{x:s,y:l}]}function D0(i,e,t,r){let n=i*r-e*t<0?-1:1,s=Math.min(1,Math.max(-1,i*t+e*r));return n*Math.acos(s)}function C2(i,e,t,r,n,s,l,c,f,h){let p=Math.pow(n,2),y=Math.pow(s,2),g=Math.pow(l,2),w=Math.pow(c,2),S=p*y-p*w-y*g;S<0&&(S=0),S/=p*w+y*g,S=Math.sqrt(S)*(f===h?-1:1);let T=S*n/s*c,C=S*-s/n*l,B=T+(i+t)/2,G=C+(e+r)/2,D=(l-T)/n,W=(c-C)/s,A=(-l-T)/n,q=(-c-C)/s,E=D0(1,0,D,W),b=D0(D,W,A,q);return!h&&b>0&&(b-=Uh),h&&b<0&&(b+=Uh),{centerx:B,centery:G,ang1:E,ang2:b}}function B0({px:i,py:e,cx:t,cy:r,rx:n,ry:s,largeArcFlag:l,sweepFlag:c}){let f=[];if(n===0||s===0)return[];let h=(i-t)/2,p=(e-r)/2;if(h===0&&p===0)return[];n=Math.abs(n),s=Math.abs(s);let y=Math.pow(h,2)/Math.pow(n,2)+Math.pow(p,2)/Math.pow(s,2);y>1&&(n*=Math.sqrt(y),s*=Math.sqrt(y));let g=C2(i,e,t,r,n,s,h,p,l,c),{ang1:w,ang2:S}=g,{centerx:T,centery:C}=g,B=Math.abs(S)/(Uh/4);Math.abs(1-B)<1e-7&&(B=1);let G=Math.max(Math.ceil(B),1);S/=G;for(let D=0;D<G;D++)f.push(N2(w,S)),w+=S;return f.map(D=>{let{x:W,y:A}=kh(D[0],n,s,T,C),{x:q,y:E}=kh(D[1],n,s,T,C),{x:b,y:R}=kh(D[2],n,s,T,C);return{x1:W,y1:A,x2:q,y2:E,x:b,y:R}})}import{BufferAttribute as Yc,BufferGeometry as M2}from"three";var Pt;(function(i){i[i.ODD=0]="ODD",i[i.NONZERO=1]="NONZERO",i[i.POSITIVE=2]="POSITIVE",i[i.NEGATIVE=3]="NEGATIVE",i[i.ABS_GEQ_TWO=4]="ABS_GEQ_TWO"})(Pt||(Pt={}));var Qt;(function(i){i[i.POLYGONS=0]="POLYGONS",i[i.CONNECTED_POLYGONS=1]="CONNECTED_POLYGONS",i[i.BOUNDARY_CONTOURS=2]="BOUNDARY_CONTOURS"})(Qt||(Qt={}));function Ae(i,e){if(!i)throw e||"Assertion Failed!"}var Te=function(){function i(){}return i.vertEq=function(e,t){return e.s===t.s&&e.t===t.t},i.vertLeq=function(e,t){return e.s<t.s||e.s===t.s&&e.t<=t.t},i.transLeq=function(e,t){return e.t<t.t||e.t===t.t&&e.s<=t.s},i.edgeGoesLeft=function(e){return i.vertLeq(e.Dst,e.Org)},i.edgeGoesRight=function(e){return i.vertLeq(e.Org,e.Dst)},i.vertL1dist=function(e,t){return Math.abs(e.s-t.s)+Math.abs(e.t-t.t)},i.edgeEval=function(e,t,r){Ae(i.vertLeq(e,t)&&i.vertLeq(t,r));var n=t.s-e.s,s=r.s-t.s;return n+s>0?n<s?t.t-e.t+(e.t-r.t)*(n/(n+s)):t.t-r.t+(r.t-e.t)*(s/(n+s)):0},i.edgeSign=function(e,t,r){Ae(i.vertLeq(e,t)&&i.vertLeq(t,r));var n=t.s-e.s,s=r.s-t.s;return n+s>0?(t.t-r.t)*n+(t.t-e.t)*s:0},i.transEval=function(e,t,r){Ae(i.transLeq(e,t)&&i.transLeq(t,r));var n=t.t-e.t,s=r.t-t.t;return n+s>0?n<s?t.s-e.s+(e.s-r.s)*(n/(n+s)):t.s-r.s+(r.s-e.s)*(s/(n+s)):0},i.transSign=function(e,t,r){Ae(i.transLeq(e,t)&&i.transLeq(t,r));var n=t.t-e.t,s=r.t-t.t;return n+s>0?(t.s-r.s)*n+(t.s-e.s)*s:0},i.vertCCW=function(e,t,r){return e.s*(t.t-r.t)+t.s*(r.t-e.t)+r.s*(e.t-t.t)>=0},i.interpolate=function(e,t,r,n){return e=e<0?0:e,r=r<0?0:r,e<=r?r===0?(t+n)/2:t+(n-t)*(e/(e+r)):n+(t-n)*(r/(e+r))},i.intersect=function(e,t,r,n,s){var l,c,f;i.vertLeq(e,t)||(f=e,e=t,t=f),i.vertLeq(r,n)||(f=r,r=n,n=f),i.vertLeq(e,r)||(f=e,e=r,r=f,f=t,t=n,n=f),i.vertLeq(r,t)?i.vertLeq(t,n)?(l=i.edgeEval(e,r,t),c=i.edgeEval(r,t,n),l+c<0&&(l=-l,c=-c),s.s=i.interpolate(l,r.s,c,t.s)):(l=i.edgeSign(e,r,t),c=-i.edgeSign(e,n,t),l+c<0&&(l=-l,c=-c),s.s=i.interpolate(l,r.s,c,n.s)):s.s=(r.s+t.s)/2,i.transLeq(e,t)||(f=e,e=t,t=f),i.transLeq(r,n)||(f=r,r=n,n=f),i.transLeq(e,r)||(f=e,e=r,r=f,f=t,t=n,n=f),i.transLeq(r,t)?i.transLeq(t,n)?(l=i.transEval(e,r,t),c=i.transEval(r,t,n),l+c<0&&(l=-l,c=-c),s.t=i.interpolate(l,r.t,c,t.t)):(l=i.transSign(e,r,t),c=-i.transSign(e,n,t),l+c<0&&(l=-l,c=-c),s.t=i.interpolate(l,r.t,c,n.t)):s.t=(r.t+t.t)/2},i}(),Ca=function(){function i(){this.next=null,this.prev=null,this.anEdge=null,this.trail=null,this.n=0,this.marked=!1,this.inside=!1}return i}(),Zc=function(){function i(e){this.side=e,this.next=null,this.Org=null,this.Sym=null,this.Onext=null,this.Lnext=null,this.Lface=null,this.activeRegion=null,this.winding=0}return Object.defineProperty(i.prototype,"Rface",{get:function(){return this.Sym.Lface},set:function(e){this.Sym.Lface=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Dst",{get:function(){return this.Sym.Org},set:function(e){this.Sym.Org=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Oprev",{get:function(){return this.Sym.Lnext},set:function(e){this.Sym.Lnext=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Lprev",{get:function(){return this.Onext.Sym},set:function(e){this.Onext.Sym=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Dprev",{get:function(){return this.Lnext.Sym},set:function(e){this.Lnext.Sym=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Rprev",{get:function(){return this.Sym.Onext},set:function(e){this.Sym.Onext=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Dnext",{get:function(){return this.Sym.Onext.Sym},set:function(e){this.Sym.Onext.Sym=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Rnext",{get:function(){return this.Sym.Lnext.Sym},set:function(e){this.Sym.Lnext.Sym=e},enumerable:!0,configurable:!0}),i}(),_s=function(){function i(){this.next=null,this.prev=null,this.anEdge=null,this.coords=[0,0,0],this.s=0,this.t=0,this.pqHandle=0,this.n=0,this.idx=0}return i}(),G0=function(){function i(){var e=new _s,t=new Ca,r=new Zc(0),n=new Zc(1);e.next=e.prev=e,e.anEdge=null,t.next=t.prev=t,r.next=r,r.Sym=n,n.next=n,n.Sym=r,this.vHead=e,this.fHead=t,this.eHead=r,this.eHeadSym=n}return i.prototype.makeEdge_=function(e){var t=new Zc(0),r=new Zc(1);e.Sym.side<e.side&&(e=e.Sym);var n=e.Sym.next;return r.next=n,n.Sym.next=t,t.next=e,e.Sym.next=r,t.Sym=r,t.Onext=t,t.Lnext=r,t.Org=null,t.Lface=null,t.winding=0,t.activeRegion=null,r.Sym=t,r.Onext=r,r.Lnext=t,r.Org=null,r.Lface=null,r.winding=0,r.activeRegion=null,t},i.prototype.splice_=function(e,t){var r=e.Onext,n=t.Onext;r.Sym.Lnext=t,n.Sym.Lnext=e,e.Onext=n,t.Onext=r},i.prototype.makeVertex_=function(e,t,r){var n=e;Ae(n,"Vertex can't be null!");var s=r.prev;n.prev=s,s.next=n,n.next=r,r.prev=n,n.anEdge=t;var l=t;do l.Org=n,l=l.Onext;while(l!==t)},i.prototype.makeFace_=function(e,t,r){var n=e;Ae(n,"Face can't be null");var s=r.prev;n.prev=s,s.next=n,n.next=r,r.prev=n,n.anEdge=t,n.trail=null,n.marked=!1,n.inside=r.inside;var l=t;do l.Lface=n,l=l.Lnext;while(l!==t)},i.prototype.killEdge_=function(e){e.Sym.side<e.side&&(e=e.Sym);var t=e.next,r=e.Sym.next;t.Sym.next=r,r.Sym.next=t},i.prototype.killVertex_=function(e,t){var r=e.anEdge,n=r;do n.Org=t,n=n.Onext;while(n!==r);var s=e.prev,l=e.next;l.prev=s,s.next=l},i.prototype.killFace_=function(e,t){var r=e.anEdge,n=r;do n.Lface=t,n=n.Lnext;while(n!==r);var s=e.prev,l=e.next;l.prev=s,s.next=l},i.prototype.makeEdge=function(){var e=new _s,t=new _s,r=new Ca,n=this.makeEdge_(this.eHead);return this.makeVertex_(e,n,this.vHead),this.makeVertex_(t,n.Sym,this.vHead),this.makeFace_(r,n,this.fHead),n},i.prototype.splice=function(e,t){var r=!1,n=!1;if(e!==t){if(t.Org!==e.Org&&(n=!0,this.killVertex_(t.Org,e.Org)),t.Lface!==e.Lface&&(r=!0,this.killFace_(t.Lface,e.Lface)),this.splice_(t,e),!n){var s=new _s;this.makeVertex_(s,t,e.Org),e.Org.anEdge=e}if(!r){var l=new Ca;this.makeFace_(l,t,e.Lface),e.Lface.anEdge=e}}},i.prototype.delete=function(e){var t=e.Sym,r=!1;if(e.Lface!==e.Rface&&(r=!0,this.killFace_(e.Lface,e.Rface)),e.Onext===e)this.killVertex_(e.Org,null);else if(e.Rface.anEdge=e.Oprev,e.Org.anEdge=e.Onext,this.splice_(e,e.Oprev),!r){var n=new Ca;this.makeFace_(n,e,e.Lface)}t.Onext===t?(this.killVertex_(t.Org,null),this.killFace_(t.Lface,null)):(e.Lface.anEdge=t.Oprev,t.Org.anEdge=t.Onext,this.splice_(t,t.Oprev)),this.killEdge_(e)},i.prototype.addEdgeVertex=function(e){var t=this.makeEdge_(e),r=t.Sym;this.splice_(t,e.Lnext),t.Org=e.Dst;var n=new _s;return this.makeVertex_(n,r,t.Org),t.Lface=r.Lface=e.Lface,t},i.prototype.splitEdge=function(e){var t=this.addEdgeVertex(e),r=t.Sym;return this.splice_(e.Sym,e.Sym.Oprev),this.splice_(e.Sym,r),e.Dst=r.Org,r.Dst.anEdge=r.Sym,r.Rface=e.Rface,r.winding=e.winding,r.Sym.winding=e.Sym.winding,r.idx=e.idx,r.Sym.idx=e.Sym.idx,r},i.prototype.connect=function(e,t){var r=!1,n=this.makeEdge_(e),s=n.Sym;if(t.Lface!==e.Lface&&(r=!0,this.killFace_(t.Lface,e.Lface)),this.splice_(n,e.Lnext),this.splice_(s,t),n.Org=e.Dst,s.Org=t.Org,n.Lface=s.Lface=e.Lface,e.Lface.anEdge=s,!r){var l=new Ca;this.makeFace_(l,n,e.Lface)}return n},i.prototype.zapFace=function(e){var t=e.anEdge,r,n,s,l,c;n=t.Lnext;do r=n,n=r.Lnext,r.Lface=null,r.Rface===null&&(r.Onext===r?this.killVertex_(r.Org,null):(r.Org.anEdge=r.Onext,this.splice_(r,r.Oprev)),s=r.Sym,s.Onext===s?this.killVertex_(s.Org,null):(s.Org.anEdge=s.Onext,this.splice_(s,s.Oprev)),this.killEdge_(r));while(r!=t);l=e.prev,c=e.next,c.prev=l,l.next=c},i.prototype.countFaceVerts_=function(e){var t=e.anEdge,r=0;do r++,t=t.Lnext;while(t!==e.anEdge);return r},i.prototype.mergeConvexFaces=function(e){var t,r,n,s,l,c,f;for(t=this.fHead.next;t!==this.fHead;t=t.next)if(!!t.inside)for(r=t.anEdge,l=r.Org;n=r.Lnext,s=r.Sym,s&&s.Lface&&s.Lface.inside&&(c=this.countFaceVerts_(t),f=this.countFaceVerts_(s.Lface),c+f-2<=e&&Te.vertCCW(r.Lprev.Org,r.Org,s.Lnext.Lnext.Org)&&Te.vertCCW(s.Lprev.Org,s.Org,r.Lnext.Lnext.Org)&&(n=s.Lnext,this.delete(s),r=null,s=null)),!(r&&r.Lnext.Org===l);)r=n;return!0},i.prototype.check=function(){var e=this.fHead,t=this.vHead,r=this.eHead,n,s,l,c,f,h;for(s=e,s=e;(n=s.next)!==e;s=n){Ae(n.prev===s),f=n.anEdge;do Ae(f.Sym!==f),Ae(f.Sym.Sym===f),Ae(f.Lnext.Onext.Sym===f),Ae(f.Onext.Sym.Lnext===f),Ae(f.Lface===n),f=f.Lnext;while(f!==n.anEdge)}for(Ae(n.prev===s&&n.anEdge===null),c=t,c=t;(l=c.next)!==t;c=l){Ae(l.prev===c),f=l.anEdge;do Ae(f.Sym!==f),Ae(f.Sym.Sym===f),Ae(f.Lnext.Onext.Sym===f),Ae(f.Onext.Sym.Lnext===f),Ae(f.Org===l),f=f.Onext;while(f!==l.anEdge)}for(Ae(l.prev===c&&l.anEdge===null),h=r,h=r;(f=h.next)!==r;h=f)Ae(f.Sym.next===h.Sym),Ae(f.Sym!==f),Ae(f.Sym.Sym===f),Ae(f.Org!==null),Ae(f.Dst!==null),Ae(f.Lnext.Onext.Sym===f),Ae(f.Onext.Sym.Lnext===f);Ae(f.Sym.next===h.Sym&&f.Sym===this.eHeadSym&&f.Sym.Sym===f&&f.Org===null&&f.Dst===null&&f.Lface===null&&f.Rface===null)},i}(),j0=function(){function i(){this.handle=null}return i}(),E0=function(){function i(){this.key=null,this.node=0}return i}(),L2=function(){function i(e,t){this.leq=t,this.max=0,this.nodes=[],this.handles=[],this.initialized=!1,this.freeList=0,this.size=0,this.max=e,this.nodes=[],this.handles=[];for(var r=0;r<e+1;r++)this.nodes[r]=new j0,this.handles[r]=new E0;this.initialized=!1,this.nodes[1].handle=1,this.handles[1].key=null}return i.prototype.floatDown_=function(e){var t=this.nodes,r=this.handles,n,s,l;for(n=t[e].handle;;){if(l=e<<1,l<this.size&&this.leq(r[t[l+1].handle].key,r[t[l].handle].key)&&++l,Ae(l<=this.max),s=t[l].handle,l>this.size||this.leq(r[n].key,r[s].key)){t[e].handle=n,r[n].node=e;break}t[e].handle=s,r[s].node=e,e=l}},i.prototype.floatUp_=function(e){var t=this.nodes,r=this.handles,n,s,l;for(n=t[e].handle;;){if(l=e>>1,s=t[l].handle,l===0||this.leq(r[s].key,r[n].key)){t[e].handle=n,r[n].node=e;break}t[e].handle=s,r[s].node=e,e=l}},i.prototype.init=function(){for(var e=this.size;e>=1;--e)this.floatDown_(e);this.initialized=!0},i.prototype.min=function(){return this.handles[this.nodes[1].handle].key},i.prototype.insert=function(e){var t,r;if(t=++this.size,t*2>this.max){this.max*=2;var n,s;for(s=this.nodes.length,this.nodes.length=this.max+1,n=s;n<this.nodes.length;n++)this.nodes[n]=new j0;for(s=this.handles.length,this.handles.length=this.max+1,n=s;n<this.handles.length;n++)this.handles[n]=new E0}return this.freeList===0?r=t:(r=this.freeList,this.freeList=this.handles[r].node),this.nodes[t].handle=r,this.handles[r].node=t,this.handles[r].key=e,this.initialized&&this.floatUp_(t),r},i.prototype.extractMin=function(){var e=this.nodes,t=this.handles,r=e[1].handle,n=t[r].key;return this.size>0&&(e[1].handle=e[this.size].handle,t[e[1].handle].node=1,t[r].key=null,t[r].node=this.freeList,this.freeList=r,--this.size,this.size>0&&this.floatDown_(1)),n},i.prototype.delete=function(e){var t=this.nodes,r=this.handles,n;Ae(e>=1&&e<=this.max&&r[e].key!==null),n=r[e].node,t[n].handle=t[this.size].handle,r[t[n].handle].node=n,--this.size,n<=this.size&&(n<=1||this.leq(r[t[n>>1].handle].key,r[t[n].handle].key)?this.floatDown_(n):this.floatUp_(n)),r[e].key=null,r[e].node=this.freeList,this.freeList=e},i}(),Hh=function(){function i(){this.eUp=null,this.nodeUp=null,this.windingNumber=0,this.inside=!1,this.sentinel=!1,this.dirty=!1,this.fixUpperEdge=!1}return i}(),R0=function(){function i(){this.key=null,this.next=null,this.prev=null}return i}(),_2=function(){function i(e,t){this.frame=e,this.leq=t,this.head=new R0,this.head.next=this.head,this.head.prev=this.head}return i.prototype.min=function(){return this.head.next},i.prototype.max=function(){return this.head.prev},i.prototype.insert=function(e){return this.insertBefore(this.head,e)},i.prototype.search=function(e){var t=this.head;do t=t.next;while(t.key!==null&&!this.leq(this.frame,e,t.key));return t},i.prototype.insertBefore=function(e,t){do e=e.prev;while(e.key!==null&&!this.leq(this.frame,e.key,t));var r=new R0;return r.key=t,r.next=e.next,e.next.prev=r,r.prev=e,e.next=r,r},i.prototype.delete=function(e){e.next.prev=e.prev,e.prev.next=e.next},i}(),T2=function(){function i(){}return i.regionBelow=function(e){return e.nodeUp.prev.key},i.regionAbove=function(e){return e.nodeUp.next.key},i.debugEvent=function(e){},i.addWinding=function(e,t){e.winding+=t.winding,e.Sym.winding+=t.Sym.winding},i.edgeLeq=function(e,t,r){var n=e.event,s=t.eUp,l=r.eUp;if(s.Dst===n)return l.Dst===n?Te.vertLeq(s.Org,l.Org)?Te.edgeSign(l.Dst,s.Org,l.Org)<=0:Te.edgeSign(s.Dst,l.Org,s.Org)>=0:Te.edgeSign(l.Dst,n,l.Org)<=0;if(l.Dst===n)return Te.edgeSign(s.Dst,n,s.Org)>=0;var c=Te.edgeEval(s.Dst,n,s.Org),f=Te.edgeEval(l.Dst,n,l.Org);return c>=f},i.deleteRegion=function(e,t){t.fixUpperEdge&&Ae(t.eUp.winding===0),t.eUp.activeRegion=null,e.dict.delete(t.nodeUp)},i.fixUpperEdge=function(e,t,r){Ae(t.fixUpperEdge),e.mesh.delete(t.eUp),t.fixUpperEdge=!1,t.eUp=r,r.activeRegion=t},i.topLeftRegion=function(e,t){var r=t.eUp.Org,n;do t=i.regionAbove(t);while(t.eUp.Org===r);if(t.fixUpperEdge){if(n=e.mesh.connect(i.regionBelow(t).eUp.Sym,t.eUp.Lnext),n===null)return null;i.fixUpperEdge(e,t,n),t=i.regionAbove(t)}return t},i.topRightRegion=function(e){var t=e.eUp.Dst;do e=i.regionAbove(e);while(e.eUp.Dst===t);return e},i.addRegionBelow=function(e,t,r){var n=new Hh;return n.eUp=r,n.nodeUp=e.dict.insertBefore(t.nodeUp,n),n.fixUpperEdge=!1,n.sentinel=!1,n.dirty=!1,r.activeRegion=n,n},i.isWindingInside=function(e,t){switch(e.windingRule){case Pt.ODD:return(t&1)!=0;case Pt.NONZERO:return t!==0;case Pt.POSITIVE:return t>0;case Pt.NEGATIVE:return t<0;case Pt.ABS_GEQ_TWO:return t>=2||t<=-2}throw new Error("Invalid winding rulle")},i.computeWinding=function(e,t){t.windingNumber=i.regionAbove(t).windingNumber+t.eUp.winding,t.inside=i.isWindingInside(e,t.windingNumber)},i.finishRegion=function(e,t){var r=t.eUp,n=r.Lface;n.inside=t.inside,n.anEdge=r,i.deleteRegion(e,t)},i.finishLeftRegions=function(e,t,r){for(var n,s=null,l=t,c=t.eUp;l!==r;){if(l.fixUpperEdge=!1,s=i.regionBelow(l),n=s.eUp,n.Org!=c.Org){if(!s.fixUpperEdge){i.finishRegion(e,l);break}n=e.mesh.connect(c.Lprev,n.Sym),i.fixUpperEdge(e,s,n)}c.Onext!==n&&(e.mesh.splice(n.Oprev,n),e.mesh.splice(c,n)),i.finishRegion(e,l),c=s.eUp,l=s}return c},i.addRightEdges=function(e,t,r,n,s,l){var c,f,h,p,y=!0;h=r;do Ae(Te.vertLeq(h.Org,h.Dst)),i.addRegionBelow(e,t,h.Sym),h=h.Onext;while(h!==n);for(s===null&&(s=i.regionBelow(t).eUp.Rprev),f=t,p=s;c=i.regionBelow(f),h=c.eUp.Sym,h.Org===p.Org;)h.Onext!==p&&(e.mesh.splice(h.Oprev,h),e.mesh.splice(p.Oprev,h)),c.windingNumber=f.windingNumber-h.winding,c.inside=i.isWindingInside(e,c.windingNumber),f.dirty=!0,!y&&i.checkForRightSplice(e,f)&&(i.addWinding(h,p),i.deleteRegion(e,f),e.mesh.delete(p)),y=!1,f=c,p=h;f.dirty=!0,Ae(f.windingNumber-h.winding===c.windingNumber),l&&i.walkDirtyRegions(e,f)},i.spliceMergeVertices=function(e,t,r){e.mesh.splice(t,r)},i.vertexWeights=function(e,t,r){var n=Te.vertL1dist(t,e),s=Te.vertL1dist(r,e),l=.5*s/(n+s),c=.5*n/(n+s);e.coords[0]+=l*t.coords[0]+c*r.coords[0],e.coords[1]+=l*t.coords[1]+c*r.coords[1],e.coords[2]+=l*t.coords[2]+c*r.coords[2]},i.getIntersectData=function(e,t,r,n,s,l){t.coords[0]=t.coords[1]=t.coords[2]=0,t.idx=-1,i.vertexWeights(t,r,n),i.vertexWeights(t,s,l)},i.checkForRightSplice=function(e,t){var r=i.regionBelow(t),n=t.eUp,s=r.eUp;if(Te.vertLeq(n.Org,s.Org)){if(Te.edgeSign(s.Dst,n.Org,s.Org)>0)return!1;Te.vertEq(n.Org,s.Org)?n.Org!==s.Org&&(e.pq.delete(n.Org.pqHandle),i.spliceMergeVertices(e,s.Oprev,n)):(e.mesh.splitEdge(s.Sym),e.mesh.splice(n,s.Oprev),t.dirty=r.dirty=!0)}else{if(Te.edgeSign(n.Dst,s.Org,n.Org)<0)return!1;i.regionAbove(t).dirty=t.dirty=!0,e.mesh.splitEdge(n.Sym),e.mesh.splice(s.Oprev,n)}return!0},i.checkForLeftSplice=function(e,t){var r=i.regionBelow(t),n=t.eUp,s=r.eUp,l;if(Ae(!Te.vertEq(n.Dst,s.Dst)),Te.vertLeq(n.Dst,s.Dst)){if(Te.edgeSign(n.Dst,s.Dst,n.Org)<0)return!1;i.regionAbove(t).dirty=t.dirty=!0,l=e.mesh.splitEdge(n),e.mesh.splice(s.Sym,l),l.Lface.inside=t.inside}else{if(Te.edgeSign(s.Dst,n.Dst,s.Org)>0)return!1;t.dirty=r.dirty=!0,l=e.mesh.splitEdge(s),e.mesh.splice(n.Lnext,s.Sym),l.Rface.inside=t.inside}return!0},i.checkForIntersect=function(e,t){var r=i.regionBelow(t),n=t.eUp,s=r.eUp,l=n.Org,c=s.Org,f=n.Dst,h=s.Dst,p,y,g=new _s,w,S;if(Ae(!Te.vertEq(h,f)),Ae(Te.edgeSign(f,e.event,l)<=0),Ae(Te.edgeSign(h,e.event,c)>=0),Ae(l!==e.event&&c!==e.event),Ae(!t.fixUpperEdge&&!r.fixUpperEdge),l===c||(p=Math.min(l.t,f.t),y=Math.max(c.t,h.t),p>y))return!1;if(Te.vertLeq(l,c)){if(Te.edgeSign(h,l,c)>0)return!1}else if(Te.edgeSign(f,c,l)<0)return!1;return i.debugEvent(e),Te.intersect(f,l,h,c,g),Ae(Math.min(l.t,f.t)<=g.t),Ae(g.t<=Math.max(c.t,h.t)),Ae(Math.min(h.s,f.s)<=g.s),Ae(g.s<=Math.max(c.s,l.s)),Te.vertLeq(g,e.event)&&(g.s=e.event.s,g.t=e.event.t),w=Te.vertLeq(l,c)?l:c,Te.vertLeq(w,g)&&(g.s=w.s,g.t=w.t),Te.vertEq(g,l)||Te.vertEq(g,c)?(i.checkForRightSplice(e,t),!1):!Te.vertEq(f,e.event)&&Te.edgeSign(f,e.event,g)>=0||!Te.vertEq(h,e.event)&&Te.edgeSign(h,e.event,g)<=0?h===e.event?(e.mesh.splitEdge(n.Sym),e.mesh.splice(s.Sym,n),t=i.topLeftRegion(e,t),n=i.regionBelow(t).eUp,i.finishLeftRegions(e,i.regionBelow(t),r),i.addRightEdges(e,t,n.Oprev,n,n,!0),!0):f===e.event?(e.mesh.splitEdge(s.Sym),e.mesh.splice(n.Lnext,s.Oprev),r=t,t=i.topRightRegion(t),S=i.regionBelow(t).eUp.Rprev,r.eUp=s.Oprev,s=i.finishLeftRegions(e,r,null),i.addRightEdges(e,t,s.Onext,n.Rprev,S,!0),!0):(Te.edgeSign(f,e.event,g)>=0&&(i.regionAbove(t).dirty=t.dirty=!0,e.mesh.splitEdge(n.Sym),n.Org.s=e.event.s,n.Org.t=e.event.t),Te.edgeSign(h,e.event,g)<=0&&(t.dirty=r.dirty=!0,e.mesh.splitEdge(s.Sym),s.Org.s=e.event.s,s.Org.t=e.event.t),!1):(e.mesh.splitEdge(n.Sym),e.mesh.splitEdge(s.Sym),e.mesh.splice(s.Oprev,n),n.Org.s=g.s,n.Org.t=g.t,n.Org.pqHandle=e.pq.insert(n.Org),i.getIntersectData(e,n.Org,l,f,c,h),i.regionAbove(t).dirty=t.dirty=r.dirty=!0,!1)},i.walkDirtyRegions=function(e,t){for(var r=i.regionBelow(t),n,s;;){for(;r.dirty;)t=r,r=i.regionBelow(r);if(!t.dirty&&(r=t,t=i.regionAbove(t),t===null||!t.dirty))return;if(t.dirty=!1,n=t.eUp,s=r.eUp,n.Dst!==s.Dst&&i.checkForLeftSplice(e,t)&&(r.fixUpperEdge?(i.deleteRegion(e,r),e.mesh.delete(s),r=i.regionBelow(t),s=r.eUp):t.fixUpperEdge&&(i.deleteRegion(e,t),e.mesh.delete(n),t=i.regionAbove(r),n=t.eUp)),n.Org!==s.Org)if(n.Dst!==s.Dst&&!t.fixUpperEdge&&!r.fixUpperEdge&&(n.Dst===e.event||s.Dst===e.event)){if(i.checkForIntersect(e,t))return}else i.checkForRightSplice(e,t);n.Org===s.Org&&n.Dst===s.Dst&&(i.addWinding(s,n),i.deleteRegion(e,t),e.mesh.delete(n),t=i.regionAbove(r))}},i.connectRightVertex=function(e,t,r){var n,s=r.Onext,l=i.regionBelow(t),c=t.eUp,f=l.eUp,h=!1;if(c.Dst!==f.Dst&&i.checkForIntersect(e,t),Te.vertEq(c.Org,e.event)&&(e.mesh.splice(s.Oprev,c),t=i.topLeftRegion(e,t),s=i.regionBelow(t).eUp,i.finishLeftRegions(e,i.regionBelow(t),l),h=!0),Te.vertEq(f.Org,e.event)&&(e.mesh.splice(r,f.Oprev),r=i.finishLeftRegions(e,l,null),h=!0),h){i.addRightEdges(e,t,r.Onext,s,s,!0);return}Te.vertLeq(f.Org,c.Org)?n=f.Oprev:n=c,n=e.mesh.connect(r.Lprev,n),i.addRightEdges(e,t,n,n.Onext,n.Onext,!1),n.Sym.activeRegion.fixUpperEdge=!0,i.walkDirtyRegions(e,t)},i.connectLeftDegenerate=function(e,t,r){var n,s,l,c,f;if(n=t.eUp,Te.vertEq(n.Org,r)){Ae(!1),i.spliceMergeVertices(e,n,r.anEdge);return}if(!Te.vertEq(n.Dst,r)){e.mesh.splitEdge(n.Sym),t.fixUpperEdge&&(e.mesh.delete(n.Onext),t.fixUpperEdge=!1),e.mesh.splice(r.anEdge,n),i.sweepEvent(e,r);return}Ae(!1),t=i.topRightRegion(t),f=i.regionBelow(t),l=f.eUp.Sym,s=c=l.Onext,f.fixUpperEdge&&(Ae(s!==l),i.deleteRegion(e,f),e.mesh.delete(l),l=s.Oprev),e.mesh.splice(r.anEdge,l),Te.edgeGoesLeft(s)||(s=null),i.addRightEdges(e,t,l.Onext,c,s,!0)},i.connectLeftVertex=function(e,t){var r,n,s,l,c,f,h=new Hh;if(h.eUp=t.anEdge.Sym,r=e.dict.search(h).key,n=i.regionBelow(r),!!n){if(l=r.eUp,c=n.eUp,Te.edgeSign(l.Dst,t,l.Org)===0){i.connectLeftDegenerate(e,r,t);return}if(s=Te.vertLeq(c.Dst,l.Dst)?r:n,r.inside||s.fixUpperEdge){if(s===r)f=e.mesh.connect(t.anEdge.Sym,l.Lnext);else{var p=e.mesh.connect(c.Dnext,t.anEdge);f=p.Sym}s.fixUpperEdge?i.fixUpperEdge(e,s,f):i.computeWinding(e,i.addRegionBelow(e,r,f)),i.sweepEvent(e,t)}else i.addRightEdges(e,r,t.anEdge,t.anEdge,null,!0)}},i.sweepEvent=function(e,t){e.event=t,i.debugEvent(e);for(var r=t.anEdge;r.activeRegion===null;)if(r=r.Onext,r===t.anEdge){i.connectLeftVertex(e,t);return}var n=i.topLeftRegion(e,r.activeRegion);Ae(n!==null);var s=i.regionBelow(n),l=s.eUp,c=i.finishLeftRegions(e,s,null);c.Onext===l?i.connectRightVertex(e,n,c):i.addRightEdges(e,n,c.Onext,l,l,!0)},i.addSentinel=function(e,t,r,n){var s=new Hh,l=e.mesh.makeEdge();l.Org.s=r,l.Org.t=n,l.Dst.s=t,l.Dst.t=n,e.event=l.Dst,s.eUp=l,s.windingNumber=0,s.inside=!1,s.fixUpperEdge=!1,s.sentinel=!0,s.dirty=!1,s.nodeUp=e.dict.insert(s)},i.initEdgeDict=function(e){e.dict=new _2(e,i.edgeLeq);var t=e.bmax[0]-e.bmin[0],r=e.bmax[1]-e.bmin[1],n=e.bmin[0]-t,s=e.bmax[0]+t,l=e.bmin[1]-r,c=e.bmax[1]+r;i.addSentinel(e,n,s,l),i.addSentinel(e,n,s,c)},i.doneEdgeDict=function(e){for(var t,r=0;(t=e.dict.min().key)!==null;)t.sentinel||(Ae(t.fixUpperEdge),Ae(++r==1)),Ae(t.windingNumber===0),i.deleteRegion(e,t)},i.removeDegenerateEdges=function(e){var t,r,n,s=e.mesh.eHead;for(t=s.next;t!==s;t=r)r=t.next,n=t.Lnext,Te.vertEq(t.Org,t.Dst)&&t.Lnext.Lnext!==t&&(i.spliceMergeVertices(e,n,t),e.mesh.delete(t),t=n,n=t.Lnext),n.Lnext===t&&(n!==t&&((n===r||n===r.Sym)&&(r=r.next),e.mesh.delete(n)),(t===r||t===r.Sym)&&(r=r.next),e.mesh.delete(t))},i.initPriorityQ=function(e){var t,r,n,s=0;for(n=e.mesh.vHead,r=n.next;r!==n;r=r.next)s++;for(s+=8,t=e.pq=new L2(s,Te.vertLeq),n=e.mesh.vHead,r=n.next;r!==n;r=r.next)r.pqHandle=t.insert(r);return r!==n?!1:(t.init(),!0)},i.donePriorityQ=function(e){e.pq=null},i.removeDegenerateFaces=function(e,t){var r,n,s;for(r=t.fHead.next;r!==t.fHead;r=n)n=r.next,s=r.anEdge,Ae(s.Lnext!==s),s.Lnext.Lnext===s&&(i.addWinding(s.Onext,s),e.mesh.delete(s));return!0},i.computeInterior=function(e,t){t===void 0&&(t=!0);var r,n;if(i.removeDegenerateEdges(e),!i.initPriorityQ(e))return!1;for(i.initEdgeDict(e);(r=e.pq.extractMin())!==null;){for(;n=e.pq.min(),!(n===null||!Te.vertEq(n,r));)n=e.pq.extractMin(),i.spliceMergeVertices(e,r.anEdge,n.anEdge);i.sweepEvent(e,r)}return e.event=e.dict.min().key.eUp.Org,i.debugEvent(e),i.doneEdgeDict(e),i.donePriorityQ(e),i.removeDegenerateFaces(e,e.mesh)?(t&&e.mesh.check(),!0):!1},i}(),I2=function(){function i(){this.mesh=new G0,this.normal=[0,0,0],this.sUnit=[0,0,0],this.tUnit=[0,0,0],this.bmin=[0,0],this.bmax=[0,0],this.windingRule=Pt.ODD,this.dict=null,this.pq=null,this.event=null,this.vertexIndexCounter=0,this.vertices=[],this.vertexIndices=[],this.vertexCount=0,this.elements=[],this.elementCount=0}return i.prototype.dot_=function(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]},i.prototype.normalize_=function(e){var t=e[0]*e[0]+e[1]*e[1]+e[2]*e[2];if(!t)throw"Zero-size vector!";t=Math.sqrt(t),e[0]/=t,e[1]/=t,e[2]/=t},i.prototype.longAxis_=function(e){var t=0;return Math.abs(e[1])>Math.abs(e[0])&&(t=1),Math.abs(e[2])>Math.abs(e[t])&&(t=2),t},i.prototype.computeNormal_=function(e){var t,r,n,s,l,c,f=[0,0,0],h=[0,0,0],p=[0,0,0],y=[0,0,0],g=[0,0,0],w=[null,null,null],S=[null,null,null],T=this.mesh.vHead;t=T.next;for(var C=0;C<3;++C)s=t.coords[C],h[C]=s,S[C]=t,f[C]=s,w[C]=t;for(t=T.next;t!==T;t=t.next)for(var B=0;B<3;++B)s=t.coords[B],s<h[B]&&(h[B]=s,S[B]=t),s>f[B]&&(f[B]=s,w[B]=t);var G=0;if(f[1]-h[1]>f[0]-h[0]&&(G=1),f[2]-h[2]>f[G]-h[G]&&(G=2),h[G]>=f[G]){e[0]=0,e[1]=0,e[2]=1;return}for(c=0,r=S[G],n=w[G],p[0]=r.coords[0]-n.coords[0],p[1]=r.coords[1]-n.coords[1],p[2]=r.coords[2]-n.coords[2],t=T.next;t!==T;t=t.next)y[0]=t.coords[0]-n.coords[0],y[1]=t.coords[1]-n.coords[1],y[2]=t.coords[2]-n.coords[2],g[0]=p[1]*y[2]-p[2]*y[1],g[1]=p[2]*y[0]-p[0]*y[2],g[2]=p[0]*y[1]-p[1]*y[0],l=g[0]*g[0]+g[1]*g[1]+g[2]*g[2],l>c&&(c=l,e[0]=g[0],e[1]=g[1],e[2]=g[2]);c<=0&&(e[0]=e[1]=e[2]=0,e[this.longAxis_(p)]=1)},i.prototype.checkOrientation_=function(){for(var e=this.mesh.fHead,t,r=this.mesh.vHead,n,s=0,l=e.next;l!==e;l=l.next)if(n=l.anEdge,!(n.winding<=0))do s+=(n.Org.s-n.Dst.s)*(n.Org.t+n.Dst.t),n=n.Lnext;while(n!==l.anEdge);if(s<0){for(t=r.next;t!==r;t=t.next)t.t=-t.t;this.tUnit[0]=-this.tUnit[0],this.tUnit[1]=-this.tUnit[1],this.tUnit[2]=-this.tUnit[2]}},i.prototype.projectPolygon_=function(){var e=this.mesh.vHead,t=[0,0,0],r,n,s=!1;t[0]=this.normal[0],t[1]=this.normal[1],t[2]=this.normal[2],!t[0]&&!t[1]&&!t[2]&&(this.computeNormal_(t),s=!0),r=this.sUnit,n=this.tUnit;var l=this.longAxis_(t);r[l]=0,r[(l+1)%3]=1,r[(l+2)%3]=0,n[l]=0,n[(l+1)%3]=0,n[(l+2)%3]=t[l]>0?1:-1;for(var c=e.next;c!==e;c=c.next)c.s=this.dot_(c.coords,r),c.t=this.dot_(c.coords,n);s&&this.checkOrientation_();for(var f=!0,h=e.next;h!==e;h=h.next)f?(this.bmin[0]=this.bmax[0]=h.s,this.bmin[1]=this.bmax[1]=h.t,f=!1):(h.s<this.bmin[0]&&(this.bmin[0]=h.s),h.s>this.bmax[0]&&(this.bmax[0]=h.s),h.t<this.bmin[1]&&(this.bmin[1]=h.t),h.t>this.bmax[1]&&(this.bmax[1]=h.t))},i.prototype.addWinding_=function(e,t){e.winding+=t.winding,e.Sym.winding+=t.Sym.winding},i.prototype.tessellateMonoRegion_=function(e,t){var r,n;if(r=t.anEdge,!(r.Lnext!==r&&r.Lnext.Lnext!==r))throw"Mono region invalid";for(;Te.vertLeq(r.Dst,r.Org);r=r.Lprev);for(;Te.vertLeq(r.Org,r.Dst);r=r.Lnext);n=r.Lprev;for(var s=void 0;r.Lnext!==n;)if(Te.vertLeq(r.Dst,n.Org)){for(;n.Lnext!==r&&(Te.edgeGoesLeft(n.Lnext)||Te.edgeSign(n.Org,n.Dst,n.Lnext.Dst)<=0);)s=e.connect(n.Lnext,n),n=s.Sym;n=n.Lprev}else{for(;n.Lnext!==r&&(Te.edgeGoesRight(r.Lprev)||Te.edgeSign(r.Dst,r.Org,r.Lprev.Org)>=0);)s=e.connect(r,r.Lprev),r=s.Sym;r=r.Lnext}if(n.Lnext===r)throw"Mono region invalid";for(;n.Lnext.Lnext!==r;)s=e.connect(n.Lnext,n),n=s.Sym;return!0},i.prototype.tessellateInterior_=function(e){for(var t,r=e.fHead.next;r!==e.fHead;r=t)if(t=r.next,r.inside&&!this.tessellateMonoRegion_(e,r))return!1;return!0},i.prototype.discardExterior_=function(e){for(var t,r=e.fHead.next;r!==e.fHead;r=t)t=r.next,r.inside||e.zapFace(r)},i.prototype.setWindingNumber_=function(e,t,r){for(var n,s=e.eHead.next;s!==e.eHead;s=n)n=s.next,s.Rface.inside!==s.Lface.inside?s.winding=s.Lface.inside?t:-t:r?e.delete(s):s.winding=0},i.prototype.getNeighbourFace_=function(e){return!e.Rface||!e.Rface.inside?-1:e.Rface.n},i.prototype.outputPolymesh_=function(e,t,r,n){var s,l=0,c=0,f;r>3&&e.mergeConvexFaces(r);for(var h=e.vHead.next;h!==e.vHead;h=h.next)h.n=-1;for(var p=e.fHead.next;p!==e.fHead;p=p.next)if(p.n=-1,!!p.inside){s=p.anEdge,f=0;do{var h=s.Org;h.n===-1&&(h.n=c,c++),f++,s=s.Lnext}while(s!==p.anEdge);if(f>r)throw"Face vertex greater that support polygon";p.n=l,++l}this.elementCount=l,t===Qt.CONNECTED_POLYGONS&&(l*=2),this.elements=[],this.elements.length=l*r,this.vertexCount=c,this.vertices=[],this.vertices.length=c*n,this.vertexIndices=[],this.vertexIndices.length=c;for(var h=e.vHead.next;h!==e.vHead;h=h.next)if(h.n!==-1){var y=h.n*n;this.vertices[y+0]=h.coords[0],this.vertices[y+1]=h.coords[1],n>2&&(this.vertices[y+2]=h.coords[2]),this.vertexIndices[h.n]=h.idx}for(var g=0,p=e.fHead.next;p!==e.fHead;p=p.next)if(!!p.inside){s=p.anEdge,f=0;do{var h=s.Org;this.elements[g++]=h.n,f++,s=s.Lnext}while(s!==p.anEdge);for(var w=f;w<r;++w)this.elements[g++]=-1;if(t===Qt.CONNECTED_POLYGONS){s=p.anEdge;do this.elements[g++]=this.getNeighbourFace_(s),s=s.Lnext;while(s!==p.anEdge);for(var S=f;S<r;++S)this.elements[g++]=-1}}},i.prototype.outputContours_=function(e,t){var r,n,s=0,l=0;this.vertexCount=0,this.elementCount=0;for(var c=e.fHead.next;c!==e.fHead;c=c.next)if(!!c.inside){n=r=c.anEdge;do this.vertexCount++,r=r.Lnext;while(r!==n);this.elementCount++}this.elements=[],this.elements.length=this.elementCount*2,this.vertices=[],this.vertices.length=this.vertexCount*t,this.vertexIndices=[],this.vertexIndices.length=this.vertexCount;var f=0,h=0,p=0;s=0;for(var c=e.fHead.next;c!==e.fHead;c=c.next)if(!!c.inside){l=0,n=r=c.anEdge;do this.vertices[f++]=r.Org.coords[0],this.vertices[f++]=r.Org.coords[1],t>2&&(this.vertices[f++]=r.Org.coords[2]),this.vertexIndices[h++]=this.vertexIdCallback?this.vertexIdCallback(r):r.Org.idx,l++,r=r.Lnext;while(r!==n);this.elements[p++]=s,this.elements[p++]=l,s+=l}},i.prototype.addContour=function(e,t){this.mesh===null&&(this.mesh=new G0),e<2&&(e=2),e>3&&(e=3);for(var r=null,n=0;n<t.length;n+=e)r===null?(r=this.mesh.makeEdge(),this.mesh.splice(r,r.Sym)):(this.mesh.splitEdge(r),r=r.Lnext),r.Org.coords[0]=t[n+0],r.Org.coords[1]=t[n+1],e>2?r.Org.coords[2]=t[n+2]:r.Org.coords[2]=0,r.Org.idx=this.vertexIndexCounter++,this.edgeCreateCallback&&this.edgeCreateCallback(r),r.winding=1,r.Sym.winding=-1},i.prototype.tesselate=function(e,t,r,n,s,l){if(e===void 0&&(e=Pt.ODD),t===void 0&&(t=Qt.POLYGONS),l===void 0&&(l=!0),this.vertices=[],this.elements=[],this.vertexIndices=[],this.vertexIndexCounter=0,s&&(this.normal[0]=s[0],this.normal[1]=s[1],this.normal[2]=s[2]),this.windingRule=e,n<2&&(n=2),n>3&&(n=3),!this.mesh)return!1;this.projectPolygon_(),T2.computeInterior(this,l);var c=this.mesh;return t===Qt.BOUNDARY_CONTOURS?this.setWindingNumber_(c,1,!0):this.tessellateInterior_(c),l&&c.check(),t===Qt.BOUNDARY_CONTOURS?this.outputContours_(c,n):this.outputPolymesh_(c,t,r,n),!0},i}();function Co(i){var e=i.windingRule,t=e===void 0?Pt.ODD:e,r=i.elementType,n=r===void 0?Qt.POLYGONS:r,s=i.polySize,l=s===void 0?3:s,c=i.vertexSize,f=c===void 0?2:c,h=i.normal,p=h===void 0?[0,0,1]:h,y=i.contours,g=y===void 0?[]:y,w=i.strict,S=w===void 0?!0:w,T=i.debug,C=T===void 0?!1:T;if(!g&&S)throw new Error("Contours can't be empty");if(!!g){var B=new I2;i.edgeCreateCallback&&(B.edgeCreateCallback=i.edgeCreateCallback),i.vertexIdCallback&&(B.vertexIdCallback=i.vertexIdCallback);for(var G=0;G<g.length;G++)B.addContour(f||2,g[G]);return B.tesselate(t,n,l,f,p,S),{vertices:B.vertices,vertexIndices:B.vertexIndices,vertexCount:B.vertexCount,elements:B.elements,elementCount:B.elementCount,mesh:C?B.mesh:void 0}}}var nH=Pt.ODD,iH=Pt.NONZERO,oH=Pt.POSITIVE,sH=Pt.NEGATIVE,aH=Pt.ABS_GEQ_TWO,lH=Qt.POLYGONS,cH=Qt.CONNECTED_POLYGONS,uH=Qt.BOUNDARY_CONTOURS;var Lo=class extends M2{constructor(e,t=12,r=100,n={}){super();this.type="ShapeGeometry";this.windingRule=Pt.ODD;this.elementType=Qt.POLYGONS;this.polySize=3;this.vertexSize=2;this.strict=!0;this._drawCount=0,this._shape=e,this._curveSegments=t,this._maxCount=r,this._maxDrawCount=r*3,this._triangulationOptions=Object.assign({windingRule:Pt.ODD,elementType:Qt.POLYGONS,polySize:3,vertexSize:2,strict:!0},n),this._positionAttribute=new Yc(new Float32Array(r*3),3),this._normalAttribute=new Yc(new Float32Array(r*3),3),this._uvAttribute=new Yc(new Float32Array(r*2),2),this._indexAttribute=new Yc(new Uint32Array(r*3),1),this.setAttribute("position",this._positionAttribute),this.setAttribute("normal",this._normalAttribute),this.setAttribute("uv",this._uvAttribute),this.setIndex(this._indexAttribute),this.updateFromShape()}copy(e){return this._drawCount=e.drawCount,this._maxDrawCount=e._maxDrawCount,this._maxCount=e.maxCount,super.copy(e)}get curveSegments(){return this._curveSegments}set curveSegments(e){this._curveSegments=e,this.updateFromShape()}get drawCount(){return this._drawCount}get maxDrawCount(){return this._maxDrawCount}get maxCount(){return this._maxCount}updateFromShape(){let e=this._shape.extractShapePointsToFlatArray([],this._curveSegments),t=this._shape.shapeHoles.map(f=>f.extractShapePointsToFlatArray([],this._curveSegments)),r,n=!0,s=!0,l,c;for(let f=0,h=e.length/2;f<h;f++){let p=f*2,y=e[p+0],g=e[p+1];if(l!==void 0&&y!==l&&(n=!1),c!==void 0&&g!==c&&(s=!1),l=y,c=g,!n&&!s)break}if(!n&&!s&&(r=Co({contours:[e,...t],windingRule:this._triangulationOptions.windingRule,elementType:this._triangulationOptions.elementType,polySize:this._triangulationOptions.polySize,vertexSize:this._triangulationOptions.vertexSize,strict:this._triangulationOptions.strict})),this._positionAttribute.array.fill(0),this._normalAttribute.array.fill(0),this._uvAttribute.array.fill(0),this._indexAttribute.array.fill(0),this._drawCount=0,r){let f=1/0,h=-1/0,p=1/0,y=-1/0;for(let S=0,T=r.vertexCount;S<T;S++){let C=S*2,B=r.vertices[C+0],G=r.vertices[C+1];B<f&&(f=B),B>h&&(h=B),G<p&&(p=G),G>y&&(y=G)}let g=h-f,w=y-p;for(let S=0,T=r.vertexCount;S<T;S++){let C=S*2,B=r.vertices[C+0],G=r.vertices[C+1],D=(B-f)/g,W=(G-p)/w;this._positionAttribute.setXYZ(S,B,G,0),this._normalAttribute.setXYZ(S,0,0,1),this._uvAttribute.setXY(S,D,W)}for(let S=0,T=r.elementCount;S<T;S++){let C=S*3,B=r.elements[C+0],G=r.elements[C+1],D=r.elements[C+2];this._indexAttribute.setX(C+0,B),this._indexAttribute.setX(C+1,G),this._indexAttribute.setX(C+2,D),this._drawCount+=3}}return this._positionAttribute.needsUpdate=!0,this._normalAttribute.needsUpdate=!0,this._uvAttribute.needsUpdate=!0,this._indexAttribute.needsUpdate=!0,this.setDrawRange(0,this._drawCount),this._drawCount>this._maxDrawCount}clone(){let e=new Lo(this._shape,this._curveSegments,this._maxCount);return e.userData=xo(this.userData),e}};import{BufferAttribute as tu,BufferGeometry as A2}from"three";var eu=class{constructor(e=256,t=!1){this.capacity=e,this.size=0,this.debug=t,this.debug&&console.log(`allocating with cap ${e}`);let r=e*eu.eSize;this.buffer=new ArrayBuffer(r);let n=Float32Array.BYTES_PER_ELEMENT,s=0;this.positions=new Float32Array(this.buffer,s*n,3*e),s+=3*e,this.normals=new Float32Array(this.buffer,s*n,3*e),s+=3*e,this.uvs=new Float32Array(this.buffer,s*n,2*e)}realloc(e,t=!1){if(e<this.size)throw Error("cannot shrink buffer");if(e<=this.capacity&&!t)return;this.debug&&console.log(`resizing from ${this.capacity} \u2192 ${e}`);let r=e*eu.eSize,n=new ArrayBuffer(r),s=Float32Array.BYTES_PER_ELEMENT,l=0,c=new Float32Array(n,l*s,3*e);l+=3*e;let f=new Float32Array(n,l*s,3*e);l+=3*e;let h=new Float32Array(n,l*s,2*e);c.set(this.positions.slice(0,this.size*3)),f.set(this.normals.slice(0,this.size*3)),h.set(this.uvs.slice(0,this.size*2)),this.buffer=n,this.positions=c,this.normals=f,this.uvs=h,this.capacity=e}get(e=1){let t=this.size+e;if(t>this.capacity){let n=this.capacity;for(;t>n;)n*=2;this.realloc(n)}let r=this.size;return this.size=t,r}reserve(e){let t=this.size+e;t>this.capacity&&this.realloc(t)}shrink(){this.debug&&console.log(`shrinking ${this.capacity} \u2192 ${this.size}`),this.realloc(this.size,!0)}},Qc=eu;Qc.eSize=(3+3+2)*Float32Array.BYTES_PER_ELEMENT;var Wh=(i,e)=>([t,r])=>(r<t&&(r+=e),(i>=t?i:i+e)<=r),La=class extends A2{constructor(e,t,r=0,n=12,s=3){super();this.type="ShapeGeometry";this.vertexCache={};this._shape=e,this._depth=t,this._bevel=r,this._curveSegments=n,this._bevelSegmentsInput=s,r<=0?(this._bevelSize=0,this._bevelSegments=0):(this._bevelSize=Math.min(r,t/2-1e-12),this._bevelSegments=Math.floor(s));let l=this._shape.extractShapePointsToFlatArray([],n),c=this._shape.shapeHoles.map(q=>{let E=q.extractShapePointsToFlatArray([],n),b=[];for(let R=E.length-1;R>=1;R-=2){let I=E[R-1],z=E[R-0];b.push(I,z)}return b}),f=Co({windingRule:Pt.ODD,elementType:Qt.BOUNDARY_CONTOURS,vertexSize:2,strict:!0,contours:[l]}),h=Co({windingRule:Pt.ODD,elementType:Qt.BOUNDARY_CONTOURS,vertexSize:2,strict:!0,contours:[...c]});if(!f)throw new Error("error generating geometry");let p=f.elementCount;if(h){f.elementCount+=h.elementCount;for(let q=0;q<h.elements.length;q++){let E=h.elements[q],b=q%2==0?f.vertexCount:0;f.elements.push(E+b)}for(let q=0;q<h.vertexIndices.length;q++){let E=h.vertexIndices[q],b=f.vertexCount;f.vertexIndices.push(E+b)}for(let q=0;q<h.vertices.length;q++){let E=h.vertices[q];f.vertices.push(E)}}let y=1/0,g=-1/0,w=1/0,S=-1/0;for(let q=0,E=f.vertexCount;q<E;q++){let b=q*2,R=f.vertices[b+0],I=f.vertices[b+1];R<y&&(y=R),R>g&&(g=R),I<w&&(w=I),I>S&&(S=I)}this._minX=y,this._minY=w,this._width=g-y,this._height=S-w;let T=f.vertexCount*2*(2+this._bevelSegments);this._buffer=new Qc(T);let C=[],B=[];for(let q=f.elementCount-1;q>=0;q--){let E=q>=p,b=q*2,R=f.elements[b+0],I=f.elements[b+1],z=R+I,O={start:R,count:I,normals:[],continuous:[],concave:[]},$=R,he=z-1,re=R+1,Ne=this._shape.roundedCurves.length;do{let k=$-R,H=f.vertices[he*2+0],_=f.vertices[he*2+1],J=f.vertices[$*2+0],ee=f.vertices[$*2+1],oe=f.vertices[re*2+0],se=f.vertices[re*2+1],ce=J-H,ue=ee-_,K=Math.sqrt(ce*ce+ue*ue);ce/=K,ue/=K;let ae=J-oe,ne=ee-se,Ce=Math.sqrt(ae*ae+ne*ne);ae/=Ce,ne/=Ce,O.normals[k*2+0]=-ne,O.normals[k*2+1]=ae,O.concave[k]=ce*ne-ue*ae>0;let Y=f.vertexIndices[$];if(Array.isArray(Y))O.continuous[k]=!1;else{let[le,de]=this._shape.getCurveIndexFromVertexId(Y-1,!0);if(de>0&&de<1)O.continuous[k]=!0;else{let xe=de===1?le+1:le-1;xe=(xe+Ne)%Ne;let _e=de===1?0:1,pe=this._shape.roundedCurves[le].getTangent(de),we=this._shape.roundedCurves[xe].getTangent(_e);O.continuous[k]=pe.dot(we)>.95}}E&&(O.normals[k*2+0]*=-1,O.normals[k*2+1]*=-1),[he,$,re]=[$,re,re+1],re>=z&&(re-=I)}while(re!==R+1);let ye=[];ye.push({bevelI:0,angle:0,size:0,boundary:{vertices:f.vertices.slice(R*2,z*2),vertexCount:I,vertexIndices:new Array(I).fill(!0).map((k,H)=>[H,H]),elements:[0,I],elementCount:1,mesh:null},reverseMap:[],insetPoints:f.vertices.slice(R*2,z*2)});for(let k=1;k<=this._bevelSegments;k++){let H=k/this._bevelSegments*Math.PI/2,_=(1-Math.cos(H))*this._bevelSize,J=[],ee=[],oe=[],se=[],ce=0;for(let K=0;K<I;K++){let ae=K*2,ne=(K-1+I)%I*2,Ce=f.vertices[O.start*2+ae+0],Y=f.vertices[O.start*2+ae+1],le=-O.normals[ne+0]*_,de=-O.normals[ne+1]*_,xe=-O.normals[ae+0]*_,_e=-O.normals[ae+1]*_;if(O.concave[K]||!O.concave[K]&&E){let pe=Math.atan2(de,le),we=Math.atan2(_e,xe);we>pe&&(we-=Math.PI*2);let Ve=we-pe;if(O.continuous[K]||E){let Ge=pe+Ve/2,Qe=Math.cos(Ge)*_,bt=Math.sin(Ge)*_;J[2*ce+0]=Ce+Qe*(E?-1:1),J[2*ce+1]=Y+bt*(E?-1:1),se[ce]=K,ce++}else{let Ge=Math.max(1,Math.floor(n/4*Math.abs(Ve)/Math.PI));for(let Qe=0;Qe<=Ge;Qe++){let bt=pe+Ve*(Qe/Ge),Lt=Math.cos(bt)*_,At=Math.sin(bt)*_;J[2*ce+0]=Ce+Lt,J[2*ce+1]=Y+At,se[ce]=K,ce++}}}else J[2*ce+0]=Ce+le,J[2*ce+1]=Y+de,se[ce]=K,ee[K]=ce,ce++,J[2*ce+0]=Ce,J[2*ce+1]=Y,se[ce]=K,ce++,J[2*ce+0]=Ce+xe,J[2*ce+1]=Y+_e,se[ce]=K,oe[K]=ce,ce++}let ue=Co({windingRule:Pt.POSITIVE,elementType:Qt.BOUNDARY_CONTOURS,vertexSize:2,strict:!0,contours:[J],edgeCreateCallback:K=>{let ne=K.Org.idx,Ce=se[ne],Y=se[(ne+1)%se.length];K.idx=[Ce,Y],K.Sym.idx=[Y,Ce]},vertexIdCallback:K=>{let ae=K.Lprev.idx;return[ae?ae[1]:0,K.idx[0]]}});if(!ue)throw console.log("Error"),new Error(`error generating bevel geometry for ${k}'th loop`);if(!ue.vertexCount)break;for(let K=0;K<ue.vertexIndices.length;K++){let[ae,ne]=ue.vertexIndices[K];if(ae===ne)continue;let Ce=ne;ne<ae&&(Ce+=I);for(let Y=ae;Y<Ce;Y++){let le=Y%I,de=(Y+1)%I;if(!O.continuous[le]||!O.continuous[de]){ue.vertexIndices[K]=[ae,le],ue.vertexIndices.splice(K+1,0,[de,ne]),ue.vertices.splice((K+1)*2,0,ue.vertices[K*2],ue.vertices[K*2+1]);break}}}ye.push({bevelI:k,angle:H,size:_,boundary:ue,reverseMap:se,insetPoints:J})}let Me=(k,H,_)=>{let J=0,ee=k.boundary.vertexIndices.length;for(;J<ee&&_(k.boundary.vertexIndices[H]);)H=(H+1)%ee,J++;return J},Fe=C.length;for(let k=1;k<ye.length;k++){let H=ye[k-1],_=ye[k],J=H.boundary.vertexIndices.length,ee=_.boundary.vertexIndices.length;if(!J||!ee)break;let oe=O.concave.length,se=0,ce=Wh(se,I);for(;!H.boundary.vertexIndices.filter(ce).length||!_.boundary.vertexIndices.filter(ce).length;)se++,ce=Wh(se,I);let ue=H.boundary.vertexIndices.findIndex(ce),K=_.boundary.vertexIndices.findIndex(ce);do ue=(ue+1)%J;while(ce(H.boundary.vertexIndices[ue]));do K=(K+1)%ee;while(ce(_.boundary.vertexIndices[K]));se=(se+1)%I;let ae=se,ne=this.buildBevelVert(O,H,(ue-1+J)%J),Ce=this.buildBevelVert(O,_,(K-1+ee)%ee),Y=ne,le=Ce,de,xe,_e=!1;do{ce=Wh(se,I);let pe=Me(H,ue,ce),we=Me(_,K,ce),Ve=_e;if(_e=!1,pe&&!we){for(let Ge=0;Ge<pe;Ge++)de=this.buildBevelVert(O,H,(ue+Ge)%J,Ge/(pe-1)),C.push(Y.topN,de.topP,le.topN),C.push(de.bottomP,Y.bottomN,le.bottomN),Y=de;_e=!0}else if(!pe&&we)for(let Ge=0;Ge<we;Ge++)xe=this.buildBevelVert(O,_,(K+Ge)%ee,Ge/(we-1)),C.push(le.topN,Y.topP,xe.topP),C.push(Y.bottomP,le.bottomN,xe.bottomP),le=xe;else if(pe&&we)if(de=this.buildBevelVert(O,H,ue,0),xe=this.buildBevelVert(O,_,K,0),Ve?(C.push(Y.topN,xe.topP,le.topN),C.push(Y.topN,de.topP,xe.topP),C.push(xe.bottomP,Y.bottomN,le.bottomN),C.push(de.bottomP,Y.bottomN,xe.bottomP)):(C.push(Y.topN,de.topP,le.topN),C.push(le.topN,de.topP,xe.topP),C.push(de.bottomP,Y.bottomN,le.bottomN),C.push(de.bottomP,le.bottomN,xe.bottomP)),Y=de,le=xe,pe===we)for(let Ge=1;Ge<pe;Ge++)de=this.buildBevelVert(O,H,(ue+Ge)%J,Ge/(pe-1)),xe=this.buildBevelVert(O,_,(K+Ge)%ee,Ge/(we-1)),C.push(Y.topN,de.topP,le.topN),C.push(le.topN,de.topP,xe.topP),C.push(de.bottomP,Y.bottomN,le.bottomN),C.push(de.bottomP,le.bottomN,xe.bottomP),Y=de,le=xe;else if(pe>we){let Ge=pe/we,Qe=0;for(let bt=1;bt<pe;bt++)de=this.buildBevelVert(O,H,(ue+bt)%J,bt/(pe-1)),C.push(Y.topN,de.topP,le.topN),C.push(de.bottomP,Y.bottomN,le.bottomN),Y=de,bt>(Qe+1)*Ge&&(Qe++,xe=this.buildBevelVert(O,_,(K+Qe)%ee,Qe/(we-1)),C.push(le.topN,de.topP,xe.topP),C.push(de.bottomP,le.bottomN,xe.bottomP),le=xe)}else{let Ge=we/pe,Qe=0;for(let bt=1;bt<we;bt++)xe=this.buildBevelVert(O,_,(K+bt)%ee,bt/(we-1)),C.push(le.topN,de.topP,xe.topP),C.push(de.bottomP,le.bottomN,xe.bottomP),le=xe,bt>(Qe+1)*Ge&&(Qe++,de=this.buildBevelVert(O,H,(ue+Qe)%J,Qe/(pe-1)),C.push(Y.topN,de.topP,le.topN),C.push(de.bottomP,Y.bottomN,le.bottomN),Y=de)}ue=(ue+pe)%J,K=(K+we)%ee,se=(se+1)%oe}while(se!==ae)}{let k=ye[0];for(let H=0,_=k.boundary.vertexCount;H<_;H++){let J=this.buildBevelVert(O,k,H),ee=this.buildBevelVert(O,k,(H+1)%_);C.push(ee.topP,J.topN,J.bottomN),C.push(ee.topP,J.bottomN,ee.bottomP)}}if(E){let k=[];for(let H=C.length-1;H>=Fe+2;H-=3){let _=C[H-2],J=C[H-1],ee=C[H-0];k.push(ee,J,_)}C.splice(Fe,C.length-Fe,...k)}if(E){let k=[];for(let H=ye[ye.length-1].boundary.vertices.length-1;H>=1;H-=2){let _=ye[ye.length-1].boundary.vertices[H-1],J=ye[ye.length-1].boundary.vertices[H-0];k.push(_,J)}B.push(k)}if(!E){let k=ye[ye.length-1],H=Co({windingRule:ye.length>1?Pt.POSITIVE:Pt.ODD,elementType:Qt.POLYGONS,vertexSize:2,strict:!0,contours:[k.insetPoints,...B]});if(!H)throw new Error("Error generating geometry for surface");for(let _=0;_<H.elementCount*3;_+=3){let J=this.buildSurfaceVert(H,H.elements[_+0]),ee=this.buildSurfaceVert(H,H.elements[_+1]),oe=this.buildSurfaceVert(H,H.elements[_+2]);C.push(J.top,ee.top,oe.top),C.push(oe.bottom,ee.bottom,J.bottom)}}this.vertexCache={}}this._buffer.shrink();let G=new tu(Uint32Array.from(C),1),D=new tu(this._buffer.positions,3),W=new tu(this._buffer.normals,3),A=new tu(this._buffer.uvs,2);D.needsUpdate=!0,W.needsUpdate=!0,A.needsUpdate=!0,G.needsUpdate=!0,this.setAttribute("position",D),this.setAttribute("normal",W),this.setAttribute("uv",A),this.setIndex(G)}buildSurfaceVert(e,t){let r=t.toString();if(r in this.vertexCache)return this.vertexCache[r];let n=e.vertices[t*2+0],s=e.vertices[t*2+1],l=(n-this._minX)/this._width,c=(s-this._minY)/this._height,f=this._buffer.get(2),h=f*3,p=f*2,y={top:f+0,bottom:f+1};return this._buffer.positions[h+0]=n,this._buffer.positions[h+1]=s,this._buffer.positions[h+2]=this._depth,this._buffer.normals[h+0]=0,this._buffer.normals[h+1]=0,this._buffer.normals[h+2]=1,this._buffer.uvs[p+0]=l,this._buffer.uvs[p+1]=c,this._buffer.positions[h+3]=n,this._buffer.positions[h+4]=s,this._buffer.positions[h+5]=0,this._buffer.normals[h+3]=0,this._buffer.normals[h+4]=0,this._buffer.normals[h+5]=-1,this._buffer.uvs[p+2]=l,this._buffer.uvs[p+3]=c,this.vertexCache[r]=y,y}buildBevelVert(e,t,r,n=1){let s=`${t.bevelI}:${r}`;if(s in this.vertexCache)return this.vertexCache[s];let[l,c]=t.boundary.vertexIndices[r],f,h,p,y;l!==c?(h=l,f=c,y=!1,p=e.continuous[h]&&e.continuous[f]):(f=l,h=(f-1+e.count)%e.count,y=e.concave[f]&&t.bevelI>0,p=e.continuous[f]||y);let g=Math.cos(t.angle),w=Math.sin(t.angle),S=r*2,T=f*2,C=h*2,B=t.boundary.vertices[S+0],G=t.boundary.vertices[S+1],D=(1-w)*this._bevelSize,W=(B-this._minX)/this._width,A=(G-this._minY)/this._height,q=e.normals[T+0],E=e.normals[T+1],b=e.normals[C+0],R=e.normals[C+1];if(y){let he=b-q,re=R-E;q=q+he*(1-n),E=E+re*(1-n);let Ne=Math.sqrt(q*q+E*E);q/=Ne,E/=Ne}let I=this._buffer.get(p?2:4),z=I*3,O=I*2,$={i:r,fi:f,topP:I+0,topN:I+0,bottomP:I+1,bottomN:I+1};return this._buffer.positions[z+0]=B,this._buffer.positions[z+1]=G,this._buffer.positions[z+2]=this._depth-D,this._buffer.normals[z+0]=q*g,this._buffer.normals[z+1]=E*g,this._buffer.normals[z+2]=w,this._buffer.uvs[O+0]=W,this._buffer.uvs[O+1]=A,this._buffer.positions[z+3]=B,this._buffer.positions[z+4]=G,this._buffer.positions[z+5]=D,this._buffer.normals[z+3]=q*g,this._buffer.normals[z+4]=E*g,this._buffer.normals[z+5]=-w,this._buffer.uvs[O+2]=A,this._buffer.uvs[O+3]=W,p||(I+=2,z+=6,O+=4,$.topP=I+0,$.bottomP=I+1,this._buffer.positions[z+0]=B,this._buffer.positions[z+1]=G,this._buffer.positions[z+2]=this._depth-D,this._buffer.normals[z+0]=b*g,this._buffer.normals[z+1]=R*g,this._buffer.normals[z+2]=w,this._buffer.uvs[O+0]=W,this._buffer.uvs[O+1]=A,this._buffer.positions[z+3]=B,this._buffer.positions[z+4]=G,this._buffer.positions[z+5]=D,this._buffer.normals[z+3]=b*g,this._buffer.normals[z+4]=R*g,this._buffer.normals[z+5]=-w,this._buffer.uvs[O+2]=A,this._buffer.uvs[O+3]=W),this.vertexCache[s]=$,$}clone(){let e=new La(this._shape,this._depth,this._bevel,this._curveSegments,this._bevelSegmentsInput);return e.userData=xo(this.userData),e}};var ur=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var h,p,y,g,w,S,T;let t=Object.assign({},(h=e==null?void 0:e.parameters)!=null?h:{width:100,subdivisions:40,roundness:0,extrudeDepth:0,surfaceMaxCount:100,extrudeBevelSize:0,extrudeBevelSegments:3},i.parameters),r=Math.abs(t.width),n=Math.abs((p=t.height)!=null?p:t.width),s=Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(y=t.depth)!=null?y:0),l=(g=i.shape)!=null?g:e==null?void 0:e.shape,c=(w=l==null?void 0:l.roundness)!=null?w:t.roundness;l!==void 0&&(l instanceof st?(l.width!==r||l.height!==n)&&l.applySize(r,n):l=new st(r,n).fromJSON(l),((S=i.parameters)==null?void 0:S.roundness)!==void 0&&((T=i.parameters)==null?void 0:T.roundness)>0&&l.update(!1));let f=l!=null?l:new st(r,n);return{parameters:Object.assign(t,{width:r,height:n,depth:s,extrudeDepth:s,roundness:c}),shape:f}}static build(i){let{extrudeDepth:e,extrudeBevelSize:t,extrudeBevelSegments:r,subdivisions:n,roundness:s,surfaceMaxCount:l}=i.parameters;i.shape.roundness=s;let c;return e<=0?c=new Lo(i.shape,n,l):c=new La(i.shape,e,t,n,r),Object.assign(c,{userData:fe(U({},i),{type:"VectorGeometry"})})}};import{MathUtils as z0,Vector2 as F0}from"three";var V0=Math.PI*2,U0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var n,s,l;let t=Object.assign({},(n=e==null?void 0:e.parameters)!=null?n:{width:100,depth:0,spikes:64,angle:360,innerRadius:0,extrudeDepth:0,extrudeBevelSize:0,extrudeBevelSegments:1,surfaceMaxCount:1e3},i.parameters);return{shape:i.shape&&i.shape instanceof st?i.shape:new st,parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((s=t.height)!=null?s:t.width),depth:Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(l=t.depth)!=null?l:0)})}}static build(i){let{width:e,height:t,spikes:r,angle:n,innerRadius:s,depth:l,extrudeBevelSize:c,extrudeBevelSegments:f,surfaceMaxCount:h}=i.parameters,p=i.shape,y=e*.5,g=t*.5,w=O2(p,y,g,n*Math.PI/180,r,s);p.isClosed=!0,p.update();let S=ur.create({shape:p,parameters:{subdivisions:w,surfaceMaxCount:h,depth:l,extrudeBevelSize:c,extrudeBevelSegments:f}});return Object.assign(S,{userData:fe(U({},i),{type:"EllipseGeometry"})})}};function O2(i,e,t,r,n,s){if(r>=V0)return n>30||n%4==0?(D2(i,e,t,s),Math.round(n/4)):k0(i,r,n,e,t,s);let l={x:0,y:t},c=r+Math.PI*.5,f={x:Math.cos(c)*e,y:Math.sin(c)*t},h=B0({px:l.x,py:l.y,cx:f.x,cy:f.y,rx:e,ry:t,largeArcFlag:r>Math.PI,sweepFlag:!0});return n>30||n%h.length==0?P2(i,l.x,l.y,h,n,e,t,s):k0(i,r,n,e,t,s)}function P2(i,e,t,r,n,s,l,c){let f=Math.round(n/r.length);i.addPoint(Ts(e,t));for(let h=0,p=r.length;h<p;h++){let y=r[h],g=i.points[h],w=Ts(y.x,y.y);g.controls[1].position.set(y.x1,y.y1),w.controls[0].position.set(y.x2,y.y2),i.addPoint(w)}return c>0?H0(i,s,l,c):i.addPoint(Ts(0,0)),f}function k0(i,e,t,r,n,s){let l=-e/t;for(let c=0;c<=t;c++){let f=l*c,h=Math.sin(f)*r,p=Math.cos(f)*n;i.addPoint(Ts(h,p))}return e<V0?s>0?H0(i,r,n,s):i.addPoint(Ts(0,0)):(i.removePoint(i.points[i.points.length-1]),s>0&&W0(i,r,n,s)),1}function D2(i,e,t,r=0,n=0,s=0){let l=.5522847498,c=e*l,f=t*l;i.addPoint(ru(n-e,s,n-e,s-f,n-e,s+f)),i.addPoint(ru(n,s+t,n-c,s+t,n+c,s+t)),i.addPoint(ru(n+e,s,n+e,s+f,n+e,s-f)),i.addPoint(ru(n,s-t,n+c,s-t,n-c,s-t)),r>0&&W0(i,e,t,r)}function Ts(i,e){return new Xn(z0.generateUUID(),new F0(i,e))}function ru(i,e,t,r,n,s){let l=Ts(i,e);return l.controls[0].position.set(t,r),l.controls[1].position.set(n,s),l}function H0(i,e,t,r){q0(i,e,t,r).forEach(s=>i.addPoint(s))}function W0(i,e,t,r){let n=q0(i,e,t,r),s=new st;n.forEach(l=>s.addPoint(l)),s.isClosed=!0,i.shapeHoles.push(s)}function q0(i,e,t,r){let n=r*e/100,s=n*(Math.abs(t)/Math.abs(e)),l=new F0(n/e,s/t),c=i.points.map(f=>{let h=f.clone();return h.uuid=z0.generateUUID(),h}).reverse();return c.forEach(f=>{f.position.multiply(l);let h=f.controls[0].position.clone().multiply(l),p=f.controls[1].position.clone().multiply(l);f.controls[0].position.copy(p),f.controls[1].position.copy(h)}),c}import{BufferGeometry as B2,Float32BufferAttribute as qh,Vector3 as $0}from"three";var J0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var c,f,h;let t=Object.assign({},(c=e==null?void 0:e.parameters)!=null?c:{width:100,revolutions:2,segments:40,pathRadius:10,pathType:0,pathSegments:30,cornerRadius:30,cornerSegments:4},i.parameters),r=Math.abs(t.width),n=Math.abs((f=t.height)!=null?f:r),s=Math.abs((h=t.depth)!=null?h:r),l=Math.abs(Math.min(r,s))/2;return{parameters:Object.assign(t,{width:r,height:n,depth:s,radius:l,segments:Math.round(t.segments),pathSegments:Math.round(t.pathSegments),cornerSegments:Math.round(t.cornerSegments)})}}static build(i){let{width:e,height:t,depth:r,radius:n,revolutions:s,segments:l,pathRadius:c,pathType:f,pathSegments:h,cornerRadius:p,cornerSegments:y}=i.parameters,g=new nu(!1,e,t,r,n,s,l,c,f,h,p,y);return Object.assign(g,{userData:fe(U({},i),{type:"HelixGeometry"})})}},nu=class extends B2{constructor(e=!0,t=1,r=1,n=1,s=1,l=1,c=1,f=1,h=1,p=1,y=1,g=1){super();let w=e&&l===1;w&&(g=0),y>100&&(y=100);let S=()=>new $0,T=new $0,C=S(),B=S(),G=S(),D,W,A,q,E,b,R,I,z=S(),O=S(),$=S(),he=S(),re=S(),Ne=S(),ye=S(),Me=S(),Fe=r-2*f+.001,k=Fe/l,H=Math.ceil(c*l),_=H+1,J=Fe/H,ee=-Fe/2,oe=p+1,se=2*Math.PI/p,ce=Math.PI/2/g,ue=.01,K=Math.min((1-y/100)*f,f-ue),ae=f-K,ne=0,Ce=2,Y=g*Ce+Ce,le=oe*Y/Ce,de=le+oe*_,xe=oe*(_+Y),[_e,pe,we]=[3,3,2].map(pt=>Array(xe*pt).fill(0)),Ve=[],Ge=s-f;function Qe(pt,Wt){let ar=Math.PI/2;b=Wt*J,I=2*Math.PI*(b%k)/k+ar,b+=ee,R=Math.sin(I)*Ge,E=Math.cos(I)*Ge,e?pt.set(E,R,b):pt.set(E,b,R)}Qe(T,-1e-10),Qe(C,0),z.copy(T),Qe(T,1);let bt=T.distanceTo(C),Lt=ae+K,At=bt*H+2*Lt,sr=K,Ur=At-Lt;for(let pt=0;pt<=H;pt++){Qe(B,pt),Me.subVectors(B,z).normalize(),z.copy(B),Ne.copy(B).setComponent(+e+1,0).normalize(),ye.crossVectors(Me,Ne).normalize();let Wt=pt===0,ar=pt===H,Do=Wt?3*Math.PI/2:ce,Bo=Wt?sr:Ur,Go=Wt?oe:de,no=Wt?0:xe-oe,io=Me.clone().multiplyScalar(Wt?-ae:ae).add(B),jo=Me.clone().multiplyScalar(Wt?-1:1).normalize();for(let Mr=0;Mr<oe;Mr++){let oo=Mr*se;if(O.addVectors(T.copy(Ne).multiplyScalar(f*Math.cos(oo)),C.copy(ye).multiplyScalar(f*Math.sin(oo))),$.copy(O).normalize(),Wt||ar){w||(ne=no+Mr,[0,1,2].forEach(Jt=>{_e[ne*3+Jt]=io.getComponent(Jt),pe[ne*3+Jt]=jo.getComponent(Jt)}),we[ne*2]=+ar,we[ne*2+1]=Mr/p),C.copy($).multiplyScalar(K),G.addVectors(B,C);for(let Jt=0;Jt<g;Jt++){let ni=Jt*ce+Do;he.addVectors(T.copy(Me).multiplyScalar(ae*Math.sin(ni)),C.copy($).multiplyScalar(ae*Math.cos(ni))),re.copy(he).normalize(),C.addVectors(G,he),he.normalize(),ne=Go+Jt*oe+Mr,[0,1,2].forEach(Ee=>{_e[ne*3+Ee]=C.getComponent(Ee),pe[ne*3+Ee]=re.getComponent(Ee)});let Eo=+Wt+Math.sin(ni);we[ne*2]=(Bo+ae*Eo)/At,we[ne*2+1]=Mr/p}}C.addVectors(B,O),ne=le+pt*oe+Mr,[0,1,2].forEach(Jt=>{_e[ne*3+Jt]=C.getComponent(Jt),pe[ne*3+Jt]=$.getComponent(Jt)}),we[ne*2]=(Lt+pt*bt)/At,we[ne*2+1]=Mr/p}}let Ht=_+2*g+Ce,kr=1,[Nn,Cn]=w?[kr,kr+_-1]:[0,Ht-1];for(let pt=Nn;pt<=Cn-1;pt++){let Wt=w&&pt===Cn-1;for(let ar=0;ar<oe-1;ar++)D=pt*oe+ar,W=D+1,A=(Wt?ar:D)+oe,q=(Wt?ar+1:W)+oe,pt===0?Ve.push(W,q,A):pt===Ht-2?Ve.push(D,W,A):Ve.push(D,W,A,W,q,A)}this.setIndex(Ve),this.setAttribute("position",new qh(_e,3)),this.setAttribute("normal",new qh(pe,3)),this.setAttribute("uv",new qh(we,2))}};import{IcosahedronBufferGeometry as G2}from"three";var K0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,detail:0,corner:0,cornerSides:4},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e,height:t,depth:r,detail:n,corner:s,cornerSides:l}=i.parameters,c=n===0&&s!==0?new iu(e*.5,s,l):new G2(e*.5,n);return c.scale(1,t/e,r/e),Object.assign(c,{userData:fe(U({},i),{type:"IcosahedronGeometry"})})}},iu=class extends No{constructor(e=1,t=.2,r=4){let n=(1+Math.sqrt(5))/2,s=[-1,n,0,1,n,0,-1,-n,0,1,-n,0,0,-1,n,0,1,n,0,-1,-n,0,1,-n,n,0,-1,n,0,1,-n,0,-1,-n,0,1],l=[0,11,5,0,5,1,0,1,7,0,7,10,0,10,11,1,5,9,5,11,4,11,10,2,10,7,6,7,1,8,3,9,4,3,4,2,3,2,6,3,6,8,3,8,9,4,9,5,2,4,11,6,2,10,8,6,7,9,8,1],c="IcosahedronGeometry";super(s,l,c,e,t,r);this.type=c}static fromJSON(e){return new iu(e.radius,e.corner,e.cornerSides)}};import{LatheBufferGeometry as j2,Shape as E2}from"three";var X0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s,l,c;((n=(r=i.parameters)==null?void 0:r.points)!=null?n:[]).forEach(f=>{Array.isArray(f)&&(f.x=f[0],f.y=f[1])});let t=Object.assign({},(s=e==null?void 0:e.parameters)!=null?s:{width:100,segments:64,verticalSegments:64,points:[{x:0,y:-50,id:0},{x:50,y:-50,id:1},{x:50,y:50,id:2},{x:0,y:50,id:3}]},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((l=t.height)!=null?l:t.width),depth:Math.abs((c=t.depth)!=null?c:t.width)})}}static build(i){let{points:e,segments:t,verticalSegments:r}=i.parameters,n=new E2;n.moveTo(e[0].x,e[0].y),n.bezierCurveTo(e[1].x,e[1].y,e[2].x,e[2].y,e[3].x,e[3].y);let s=new j2(n.extractPoints(r).shape,t);return s.rotateZ(Math.PI),Object.assign(s,{userData:fe(U({},i),{type:"LatheGeometry"})})}};import{BufferGeometry as Y0,BufferGeometryLoader as H2,Vector3 as W2,BoxBufferGeometry as Q0}from"three";import{BufferGeometry as R2,Vector2 as $h,Vector3 as Z0}from"three";import{Geometry as z2,Face3 as F2}from"three/examples/jsm/deprecated/Geometry.js";var V2=["a","b","c"];function U2(i,e){switch(e){case"c":return i.c;case"b":return i.b;case"a":default:return i.a}}function Jh(i,e,t){let r=Math.min(i,e),n=Math.max(i,e),s=r+"_"+n;return t.get(s)}function Kh(i,e,t,r,n,s){let l=Math.min(i,e),c=Math.max(i,e),f=l+"_"+c,h;if(r.has(f))h=r.get(f);else{let p=t[l],y=t[c];h={a:p,b:y,newEdge:null,faces:[]},r.set(f,h)}h.faces.push(n),s[i].edges.push(h),s[e].edges.push(h)}function k2(i,e,t,r){let n,s,l;for(n=0,s=i.length;n<s;n++)t[n]={edges:[]};for(n=0,s=e.length;n<s;n++)l=e[n],Kh(l.a,l.b,i,r,l,t),Kh(l.b,l.c,i,r,l,t),Kh(l.c,l.a,i,r,l,t)}function ou(i,e,t,r,n){i.push(new F2(e,t,r,void 0,void 0,n))}function Is(i,e){return Math.abs(e-i)/2+Math.min(i,e)}function su(i,e,t,r){i.push([e.clone(),t.clone(),r.clone()])}var Xh=class{constructor(e=1){this.subdivisions=e}modify(e){e instanceof R2?e=new z2().fromBufferGeometry(e):e=e.clone(),e.mergeVertices();let t=this.subdivisions;for(;t-- >0;)this._smooth(e);return e.computeFaceNormals(),e.computeVertexNormals(),e}_smooth(e){let t=new Z0,r,n,s,l,c,f=e.vertices,h=e.faces,p=e.faceVertexUvs[0],y=p!==void 0&&p.length>0,g=[],w=new Map;k2(f,h,g,w);let S=[],T,C,B,G,D,W,A;for(let ue of Array.from(w.keys())){for(C=w.get(ue),B=new Z0,D=3/8,W=1/8,A=C.faces.length,A!=2&&(D=.5,W=0,A!=1),B.addVectors(C.a,C.b).multiplyScalar(D),t.set(0,0,0),l=0;l<A;l++){for(G=C.faces[l],c=0;c<3&&(T=f[U2(G,V2[c])],!(T!==C.a&&T!==C.b));c++);T&&t.add(T)}t.multiplyScalar(W),B.add(t),C.newEdge=S.length,S.push(B)}let q,E,b,R,I,z,O,$=[];for(n=0,s=f.length;n<s;n++){for(z=f[n],I=g[n].edges,r=I.length,r==3?q=3/16:r>3&&(q=3/(8*r)),E=1-r*Number(q),b=q,r<=2&&(r==2?(E=3/4,b=1/8):r==1||r==0),O=z.clone().multiplyScalar(E),t.set(0,0,0),l=0;l<r;l++)R=I[l],T=R.a!==z?R.a:R.b,t.add(T);t.multiplyScalar(Number(b)),O.add(t),$.push(O)}let he=$.concat(S),re=$.length,Ne,ye,Me,Fe=[],k=[],H,_,J,ee,oe=new $h,se=new $h,ce=new $h;for(n=0,s=h.length;n<s;n++)G=h[n],Ne=Number(Jh(G.a,G.b,w).newEdge)+re,ye=Number(Jh(G.b,G.c,w).newEdge)+re,Me=Number(Jh(G.c,G.a,w).newEdge)+re,ou(Fe,Ne,ye,Me,G.materialIndex),ou(Fe,G.a,Ne,Me,G.materialIndex),ou(Fe,G.b,ye,Ne,G.materialIndex),ou(Fe,G.c,Me,ye,G.materialIndex),y&&(H=p[n],_=H[0],J=H[1],ee=H[2],oe.set(Is(_.x,J.x),Is(_.y,J.y)),se.set(Is(J.x,ee.x),Is(J.y,ee.y)),ce.set(Is(_.x,ee.x),Is(_.y,ee.y)),su(k,oe,se,ce),su(k,_,oe,ce),su(k,J,se,oe),su(k,ee,ce,se));e.vertices=he,e.faces=Fe,y&&(e.faceVertexUvs[0]=k)}};var er=new W2,au=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var s,l;let t=(l=(s=i.geometry)!=null?s:e==null?void 0:e.geometry)!=null?l:new Y0().copy(new Q0(100,100,100)),r;e===void 0?(t.computeBoundingBox(),t.boundingBox.getSize(er),r={width:er.x,height:er.y,depth:er.z,subdivisions:0}):r=e.parameters;let n=U(U({},r),i.parameters);return{parameters:{width:Math.abs(n.width),height:Math.abs(n.height),depth:Math.abs(n.depth),subdivisions:Math.abs(n.subdivisions)},geometry:t}}static build(i){var f;let{width:e,height:t,depth:r,subdivisions:n}=i.parameters,s=(f=i.geometry)!=null?f:new Y0().copy(new Q0(100,100,100)),l=s.userData.parameters;l===void 0?(s.computeBoundingBox(),s.boundingBox.getSize(er)):er.set(l.width,l.height,l.depth),(e!==er.x||t!==er.y||r!==er.z)&&s.scale(er.x===0?1:e/er.x,er.y===0?1:t/er.y,er.z===0?1:r/er.z);let c=s.originalGeometry;return n>0?(c===void 0||(l==null?void 0:l.subdivisions)!==n)&&(c===void 0&&(c=s),s=new Xh(n).modify(c).toBufferGeometry()):(c!==void 0&&(s=c),c=void 0,s.getAttribute("normal")===void 0&&s.computeVertexNormals()),c!==void 0&&Object.assign(s,{originalGeometry:c}),delete i.geometry,Object.assign(s,{userData:fe(U({},i),{type:"NonParametricGeometry"})})}static loadFromUrl(i,e,t){new H2(t).load(i,n=>{let s=this.normalizeInputs({geometry:n});n.boundingBox.getSize(er);let l=100/er.x;Object.assign(s.parameters,{width:100,height:er.y*l,depth:er.z*l}),e(this.build(s))})}};var ev=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var n,s,l,c;let t=Object.assign({},(n=e==null?void 0:e.parameters)!=null?n:{width:100,depth:0,spikes:5,cornerRadius:0,extrudeDepth:0,extrudeBevelSize:0,extrudeBevelSegments:3},i.parameters);return{shape:i.shape&&i.shape instanceof st?i.shape:new st,parameters:Object.assign(t,{surfaceMaxCount:((s=t.surfaceMaxCount)!=null?s:t.cornerRadius>0)?1e3:100,width:Math.abs(t.width),height:Math.abs((l=t.height)!=null?l:t.width),depth:Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(c=t.depth)!=null?c:0)})}}static build(i){let{width:e,height:t,spikes:r,cornerRadius:n,depth:s,extrudeBevelSize:l,extrudeBevelSegments:c,surfaceMaxCount:f}=i.parameters,h=i.shape,p=e*.5,y=t*.5,g=0,w=0,S=2*Math.PI/r;for(let C=0;C<r;C++){let B=S*C,G=g+Math.sin(B)*p,D=w+Math.cos(B)*y;h.addPoint(h.createPoint(G,D))}h.isClosed=!0;for(let C=0,B=h.points.length;C<B;C++)h.points[C].roundness=n;h.roundness=n,h.update();let T=ur.create({shape:h,parameters:{surfaceMaxCount:f,roundness:n,depth:s,extrudeBevelSize:l,extrudeBevelSegments:c}});return Object.assign(T,{userData:fe(U({},i),{type:"PolygonGeometry"})})}};import{BufferGeometry as q2,Float32BufferAttribute as Zh,Vector2 as Zn,Vector3 as or}from"three";var tv=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,radialSegments:4,heightSegments:1,cornerRadius:0,cornerSegments:8,openEnded:!1},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e,height:t,depth:r,radialSegments:n,heightSegments:s,openEnded:l,cornerRadius:c,cornerSegments:f}=i.parameters,h=new rv(e*.5,t,n,s,l,c,f);return h.scale(1,1,r/e),Object.assign(h,{userData:fe(U({},i),{type:"PyramidGeometry"})})}};function _a(i,e,t){t.x=i.x*e.x,t.y=i.y,t.z=i.x*e.y}function Yh(i,e,t,r,n,s){let l=e.clone().sub(i),c=t.clone().sub(i),f=l.angleTo(c);if(l.normalize(),c.normalize(),r===n){let h=l.add(c).normalize();s.copy(i).addScaledVector(h,r/Math.sin(f/2))}else{let h=l.angleTo(c);s.copy(i),s.addScaledVector(l,n/Math.sin(h)),s.addScaledVector(c,r/Math.sin(h))}}function $2(i,e,t){let r=i.clone().sub(e),n=t.clone().sub(e);return r.projectOnVector(n),r.add(e)}var rv=class extends q2{constructor(e=.5,t=1,r=4,n=1,s=!1,l=0,c=4){super();r=Math.floor(Math.max(3,r)),n=Math.floor(n),c=Math.floor(c);let f=[],h=[],p=[],y=[],g=0,w=t/2,S=Math.PI/r,T=e*Math.cos(Math.PI/r),C=2*Math.PI/r,B=(r-2)*Math.PI/r,G=Math.PI-B,D=new or(0,-w,0),W=new or(0,w,0),A=new Zn(e,-w),q=new Zn(T,-w),E=new Zn(0,W.y).sub(q),b=new Zn(0,W.y).sub(A),R=new Zn(E.y,-E.x).normalize(),I=new Zn(b.y,-b.x).normalize(),O=e*Math.cos(Math.PI/r)*Math.tan((Math.PI-E.angle())/2)-1e-8;l=Math.min(l,O);let $;{let k=new or(R.x,R.y,0),H=new or(Math.cos(C)*k.x,k.y,Math.sin(C)*k.x);$=k.angleTo(H)}let he=l/Math.tan((Math.PI-E.angle())/2),re=l/Math.tan((Math.PI-$)/2),Ne=new or;if(!s){h.push(D.x,D.y,D.z),p.push(0,-1,0),y.push(0,0);let k=g++,H=[],_=A.clone(),J=he/Math.cos(Math.PI/r);_.x-=J;for(let ee=0;ee<r;ee++){let oe=ee/r*Math.PI*2+S,se=new Zn(Math.sin(oe),Math.cos(oe));_a(_,se,Ne),h.push(Ne.x,Ne.y,Ne.z),p.push(0,-1,0),y.push(0,0),H.push(g++)}for(let ee=0;ee<H.length;ee++)f.push(H[ee],k,H[(ee+1)%H.length])}let ye=[];{let k=new or,H=new or,_=new or,J=new or,ee=new or,oe=new or;for(let se=0;se<r;se++){let ce=se/r*Math.PI*2+S,ue=(se+.5)/r*Math.PI*2+S,K=(se+1)/r*Math.PI*2+S,ae=new Zn(Math.sin(ce),Math.cos(ce)),ne=new Zn(Math.sin(ue),Math.cos(ue)),Ce=new Zn(Math.sin(K),Math.cos(K));_a(A,ae,H),_a(A,Ce,_),_a(R,ne,k),Yh(W,H,_,re,re,J),h.push(J.x,J.y,J.z),Yh(H,W,_,re,he,ee),h.push(ee.x,ee.y,ee.z),Yh(_,H,W,he,re,oe),h.push(oe.x,oe.y,oe.z),p.push(k.x,k.y,k.z),p.push(k.x,k.y,k.z),p.push(k.x,k.y,k.z),y.push(0,0),y.push(0,0),y.push(0,0);let Y=g++,le=g++,de=g++;if(f.push(Y,le,de),l>0){{let pe=H.clone().add(_).multiplyScalar(.5),we=W.clone().sub(pe).normalize(),Ge=D.clone().sub(pe).normalize().add(we).normalize().multiplyScalar(-1),Qe=oe.clone().sub(ee);Me(pe,Qe,Ge,E.angle())}let xe,_e;{let pe=new or;_a(I,Ce,pe);let we=oe.clone().add(J).multiplyScalar(.5);we=$2(we,_,W);let Ve=oe.clone().sub(J);[xe,_e]=Me(we,Ve,pe,$,J.y)}{let pe=xe,we=pe.clone().setY(0).normalize(),Ve=new or(0,-1,0),Ge=we.clone().cross(Ve);Fe(pe,we,Ve,Ge)}ye.concat(_e);{let pe=E.angle(),we=Math.PI-pe,Ve=W.clone();Ve.y-=l/Math.sin(pe-Math.PI/2);let Ge=new or,Qe=[];for(let Lt=0;Lt<c;Lt++){let At=[],sr=Math.PI/2-we*Lt/c,Ur=Math.cos(sr),Ht=Math.sin(sr),kr=ue;for(let Nn=0;Nn<=Lt;Nn++){let Cn=Math.cos(kr),pt=Math.sin(kr);k.x=Ur*pt,k.y=Ht,k.z=Ur*Cn,Ge.copy(Ve).addScaledVector(k,l),h.push(Ge.x,Ge.y,Ge.z),p.push(k.x,k.y,k.z),y.push(0,0),At.push(g++),kr+=Math.PI*2/Lt/r}Qe.push(At)}_e.reverse(),Qe.push(_e);let bt=Qe.length-1;for(let Lt=0;Lt<bt;Lt++){let At=Qe[Lt],sr=Qe[Lt+1],Ur=At.length-1;f.push(sr[1],At[0],sr[0]);for(let Ht=1;Ht<=Ur;Ht++)f.push(At[Ht],At[Ht-1],sr[Ht]),f.push(sr[Ht+1],At[Ht],sr[Ht])}}}}}this.setIndex(f),this.setAttribute("position",new Zh(h,3)),this.setAttribute("normal",new Zh(p,3)),this.setAttribute("uv",new Zh(y,2));function Me(k,H,_,J,ee){let oe=-J/2,se=(Math.PI-J)/2,ce=H.clone().normalize().cross(_);k.addScaledVector(_,-l/Math.sin(se));let ue=new or,K=new or,ae=1,ne=g,Ce=[];for(let Y=0;Y<=c;Y++){let le=oe+Y/c*J;K.set(0,0,0),K.addScaledVector(ce,Math.sin(le)),K.addScaledVector(_,Math.cos(le));for(let de=0;de<=ae;de++){let xe=de/ae-.5;if(ue.copy(k),ue.addScaledVector(H,xe),ue.addScaledVector(K,l),ee!=null){let _e=Math.max(0,ue.y-ee);ue.addScaledVector(H,-_e/H.y)}h.push(ue.x,ue.y,ue.z),p.push(K.x,K.y,K.z),y.push(0,0),de===0&&Ce.push(g),g++}}for(let Y=0;Y<c;Y++)for(let le=0;le<ae;le++){let de=ne+le+(ae+1)*Y,xe=de+(ae+1),_e=xe+1,pe=de+1;f.push(de,xe,pe),f.push(xe,_e,pe)}return[k.clone().addScaledVector(H,.5),Ce]}function Fe(k,H,_,J){let ee=Math.PI/2,oe=b.angle()-ee,se=[],ce=new or,ue=new or;for(let ae=0;ae<=c;ae++){let ne=[],Ce=ae/c;for(let Y=0;Y<=ae;Y++){let de=((ae?Y/ae:0)-.5)*G,xe=Math.cos(de),_e=Math.sin(de),pe=Math.atan(Math.tan(oe)*xe),we=(ee+pe)*Ce,Ve=Math.cos(we),Ge=Math.sin(we);ce.set(0,0,0),ce.addScaledVector(H,Ge*xe),ce.addScaledVector(_,Ve),ce.addScaledVector(J,Ge*_e),ue.copy(k).addScaledVector(ce,l),h.push(ue.x,ue.y,ue.z),p.push(ce.x,ce.y,ce.z),y.push(0,0),ne.push(g++)}se.push(ne)}let K=se.length-1;for(let ae=0;ae<K;ae++){let ne=se[ae],Ce=se[ae+1],Y=ne.length-1;f.push(ne[0],Ce[1],Ce[0]);for(let le=1;le<=Y;le++)f.push(ne[le-1],ne[le],Ce[le]),f.push(ne[le],Ce[le+1],Ce[le])}}}};var lu=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var l,c,f,h,p;let t=Object.assign({},(l=e==null?void 0:e.parameters)!=null?l:{width:100,depth:0,cornerRadius:[0,0,0,0],cornerType:1,extrudeDepth:0,extrudeBevelSize:0,extrudeBevelSegments:1},i.parameters),r=Object.assign((c=e==null?void 0:e.ui)!=null?c:{enabledIndieCorners:!1},i.ui),n=t.cornerRadius.reduce((y,g)=>y+g,0);return{shape:i.shape&&i.shape instanceof st?i.shape:new st,parameters:Object.assign(t,{surfaceMaxCount:((f=t.surfaceMaxCount)!=null?f:n>0)?1e3:100,width:Math.abs(t.width),height:Math.abs((h=t.height)!=null?h:t.width),depth:Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(p=t.depth)!=null?p:0)}),ui:r}}static build(i){let e=i.shape,{width:t,height:r,cornerRadius:n,cornerType:s,depth:l,extrudeBevelSize:c,extrudeBevelSegments:f,surfaceMaxCount:h}=i.parameters,p={x:t*.5,y:r*.5},y={x:-p.x,y:-p.y},g={x:p.x,y:p.y};function w(A,q,E){return q>t&&E>r?Math.min(A*t/q,A*r/E):q>t?A*t/q:E>r?A*r/E:A}let S=[];S[0]=n[0]===0?0:w(n[0],n[0]+n[3],n[0]+n[1]),S[1]=n[1]===0?0:w(n[1],n[1]+n[2],n[1]+n[0]),S[2]=n[2]===0?0:w(n[2],n[2]+n[1],n[2]+n[3]),S[3]=n[3]===0?0:w(n[3],n[3]+n[0],n[3]+n[2]);let T=y.x,C=g.x,B=g.y,G=y.y;e.addPoint(e.createPoint(T,B)),e.addPoint(e.createPoint(C,B)),e.addPoint(e.createPoint(C,G)),e.addPoint(e.createPoint(T,G)),e.isClosed=!0;let D=!0;for(let A=0,q=e.points.length;A<q;A++)e.points[A].roundness=S[A],A>0&&S[A]!==S[A-1]&&(D=!1);D&&(e.roundness=S[0]),e.useCubicForRoundedCorners=s!==1,e.update();let W=ur.create({shape:e,parameters:{surfaceMaxCount:h,depth:l,extrudeBevelSize:c,extrudeBevelSegments:f}});return Object.assign(W,{userData:fe(U({},i),{type:"RectangleGeometry"})})}};import{SphereBufferGeometry as J2}from"three";var nv=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,widthSegments:64,heightSegments:64,phiStart:0,phiLength:2*Math.PI,thetaStart:0,thetaLength:Math.PI},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e=100,height:t=e,depth:r=e,widthSegments:n=64,heightSegments:s=64,phiStart:l,phiLength:c,thetaStart:f,thetaLength:h}=i.parameters,p=new J2(.5*e,n,s,l,c,f,h);return p.scale(1,t/e,r/e),Object.assign(p,{userData:fe(U({},i),{type:"SphereGeometry"})})}};import{PlaneBufferGeometry as K2}from"three";var iv=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,depth:0,widthSegments:8,heightSegments:8},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:0})}}static build(i){let{width:e=100,height:t=e,widthSegments:r=8,heightSegments:n=8}=i.parameters,s=new K2(e,t,r,n);return s.scale(1,1,1),Object.assign(s,{userData:fe(U({},i),{type:"PlaneGeometry"})})}};var ov=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var n,s,l,c;let t=Object.assign({},(n=e==null?void 0:e.parameters)!=null?n:{width:100,depth:0,innerRadiusPercent:38.19,spikes:5,cornerRadius:0,angle:360,extrudeDepth:0,extrudeBevelSize:0,extrudeBevelSegments:1},i.parameters);return{shape:i.shape&&i.shape instanceof st?i.shape:new st,parameters:Object.assign(t,{surfaceMaxCount:((s=t.surfaceMaxCount)!=null?s:t.cornerRadius>0)?1e3:100,width:Math.abs(t.width),height:Math.abs((l=t.height)!=null?l:t.width),depth:Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(c=t.depth)!=null?c:0)})}}static build(i){let{width:e,height:t,innerRadiusPercent:r,spikes:n,cornerRadius:s,angle:l,depth:c,extrudeBevelSize:f,extrudeBevelSegments:h,surfaceMaxCount:p}=i.parameters,y=i.shape,g=e*.5,w=t*.5,S=0,T=0,C=l*Math.PI/360/n,B=Math.PI/2*3*-1,G=g*r/100,D=w*r/100;if(n==3&&r==50){C=2*Math.PI/n;for(let A=0;A<n;A++){let q=C*A,E=S+Math.sin(q)*g,b=T+Math.cos(q)*w;y.addPoint(y.createPoint(E,b))}}else for(let A=0;A<n;A++){let q=S+Math.cos(B)*g,E=T+Math.sin(B)*w;y.addPoint(y.createPoint(q,E)),B+=C,q=S+Math.cos(B)*G,E=T+Math.sin(B)*D,A<=n,y.addPoint(y.createPoint(q,E)),B+=C}y.isClosed=!0;for(let A=0,q=y.points.length;A<q;A++)y.points[A].roundness=s;y.roundness=s,y.update();let W=ur.create({shape:y,parameters:{surfaceMaxCount:p,roundness:s,depth:c,extrudeBevelSize:f,extrudeBevelSegments:h}});return Object.assign(W,{userData:fe(U({},i),{type:"StarGeometry"})})}};import{PlaneBufferGeometry as X2}from"three";var cu=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,depth:0},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:0)})}}static build(i){let{width:e,height:t}=i.parameters,r=new X2(e,t);return Object.assign(r,{userData:fe(U({},i),{type:"TextFrameGeometry"})})}};var sv=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var l,c,f;let t=Object.assign({},(l=e==null?void 0:e.parameters)!=null?l:{width:100,radialSegments:32,tubularSegments:64,arc:Math.PI*2,cornerRadius:30,cornerSegments:8},i.parameters),r=Math.abs(t.width),n=Math.abs((c=t.height)!=null?c:t.width),s=Math.abs((f=t.depth)!=null?f:t.width*.25);return{parameters:Object.assign(t,{width:r,height:n,depth:s})}}static build(i){let{width:e,height:t,depth:r,radialSegments:n,tubularSegments:s,arc:l,cornerRadius:c,cornerSegments:f}=i.parameters,h=Z2(e,t,r,e*.5,l,s,0,0,n,c,f);return h.scale(1,t/e,1),Object.assign(h,{userData:fe(U({},i),{type:"TorusGeometry"})})}};function Z2(i,e,t,r,n,s,l,c,f,h,p){return[e,t]=[t,e],l=e/2,n/=2*Math.PI,n==1&&(h=0),new nu(!0,i,e,t,r,n,s,l,c,f,h,p)}import{TorusKnotBufferGeometry as Y2}from"three";var av=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s,l;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,tubularSegments:64,radialSegments:32,p:2,q:3},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width),tube:(l=t.tube)!=null?l:t.width*.125})}}static build(i){let{width:e,tube:t,tubularSegments:r,radialSegments:n,p:s,q:l}=i.parameters,c=e*.5;c!==t&&(c-=t);let f=new Y2(c,t,r,n,s,l);return Object.assign(f,{userData:fe(U({},i),{type:"TorusKnotGeometry"})})}};var lv=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var n,s,l,c;let t=Object.assign({},(n=e==null?void 0:e.parameters)!=null?n:{width:100,depth:0,spikes:5,cornerRadius:0,extrudeDepth:0,extrudeBevelSize:0,extrudeBevelSegments:1,isRect:!1},i.parameters);return{shape:i.shape&&i.shape instanceof st?i.shape:new st,parameters:Object.assign(t,{surfaceMaxCount:((s=t.surfaceMaxCount)!=null?s:t.cornerRadius>0)?1e3:100,width:Math.abs(t.width),height:Math.abs((l=t.height)!=null?l:t.width*(t.isRect?1:Math.sqrt(3)/2)),depth:Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(c=t.depth)!=null?c:0)})}}static build(i){let{width:e=100,height:t,cornerRadius:r,depth:n,extrudeBevelSize:s,extrudeBevelSegments:l,isRect:c,surfaceMaxCount:f}=i.parameters,h=i.shape,p=e*.5,y=t*.5;c?(h.addPoint(h.createPoint(-p,y)),h.addPoint(h.createPoint(p,-y)),h.addPoint(h.createPoint(-p,-y))):(h.addPoint(h.createPoint(0,y)),h.addPoint(h.createPoint(p,-y)),h.addPoint(h.createPoint(-p,-y))),h.isClosed=!0;for(let w=0,S=h.points.length;w<S;w++)h.points[w].roundness=r;h.roundness=r,h.update();let g=ur.create({shape:h,parameters:{surfaceMaxCount:f,roundness:r,depth:n,extrudeBevelSize:s,extrudeBevelSegments:l}});return Object.assign(g,{userData:fe(U({},i),{type:"TriangleGeometry"})})}};var Ta={};tT(Ta,{addBarycentricAttribute:()=>nD,fixUvs:()=>oD,loadFromUrl:()=>iD,resizeGeometry:()=>rD,roundShapePolygon:()=>tD});import{BufferGeometryLoader as Q2,Float32BufferAttribute as eD,Vector3 as Qh}from"three";var cv=function(i,e){let t=e.x-i.x,r=e.y-i.y,n=Math.sqrt(t*t+r*r),s=t/n,l=r/n,c=Math.atan2(l,s);return{x:t,y:r,len:n,nx:s,ny:l,ang:c}},tD=(i,e,t)=>{let r,n,s,l,c,f,h,p,y,g,w,S,T,C,B=e.length;for(l=e[B-2],i.curves=[],r=1;r<B-1;r++){c=e[r%B],f=e[(r+1)%B];let G=cv(c,l),D=cv(c,f);h=G.nx*D.ny-G.ny*D.nx,p=G.nx*D.nx-G.ny*-D.ny,w=Math.asin(h),y=1,g=!1,p<0?w<0?w=Math.PI+w:(w=Math.PI-w,y=-1,g=!0):w>0&&(y=-1,g=!0),S=w/2,C=Math.abs(Math.cos(S)*t/Math.sin(S)),C>Math.min(G.len/2,D.len/2)?(C=Math.min(G.len/2,D.len/2),T=Math.abs(C*Math.sin(S)/Math.cos(S))):T=t,n=c.x+D.nx*C,s=c.y+D.ny*C,n+=-D.ny*T*y,s+=D.nx*T*y,i.absarc(n,s,T,G.ang+Math.PI/2*y,D.ang-Math.PI/2*y,g),l=c,c=f}i.closePath()},rD=(i,{width:e,height:t,depth:r})=>{e=Math.abs(e),t=Math.abs(t),r=Math.abs(r);let n=i.userData.parameters,s,l,c;e===0?(e=n.width,s=1):s=e/n.width,t===0?(t=n.height,l=1):l=t/n.height,r===0?(r=n.depth,c=1):c=r/n.depth,i.scale(s,l,c),n.width=e,n.height=t,n.depth=r},nD=(i,e)=>{let t=[new Qh(1,0,0),new Qh(0,1,0),new Qh(0,0,1)],r=i.attributes.position,n=new Float32Array(r.count*3);for(let s=0,l=r.count;s<l;s++)t[s%3].toArray(n,s*3);i.setAttribute(e,new eD(n,3))},iD=i=>new Promise(e=>{new Q2().load(i,r=>e(r))}),oD=(i,e,t)=>{let r=i.getAttribute("uv");if(r)for(let n=0;n<r.count;n++){let s=r.getX(n),l=r.getY(n);r.setXY(n,(s+e/2)/e,1-(l-t/2)/t*-1)}};import{BufferGeometry as uv,BufferAttribute as fv,Uint32BufferAttribute as ed,Float32BufferAttribute as td,Matrix4 as aD}from"three";import{mergeVertices as lD}from"three/examples/jsm/utils/BufferGeometryUtils.js";var sD,uu=new Promise(i=>{sD=i});var Oe;uu.then(i=>{Oe=i});var hv=new Float32Array([10,10,0,-10,10,0,-10,-10,0,10,-10,0]),dv=new Uint32Array([0,1,2,3]),pv=new Uint8Array([4]),en=class{static build(i,e,t,r,n){let s,l,c;if(i===void 0)s=en.allocate(n,t),Oe.set_destination_refinement_level(s,0),l=en.buildLevel(s,!0,r);else if(i.positionWASM!==void 0){e&&e!==0&&(Oe.free_bvh(e),Oe.free_subdivision_surface(e));try{s=en.allocate(n,void 0,i)}catch(f){console.error(f,i),s=en.allocate(n,void 0,{positionWASM:hv,indexWASM:dv,verticesPerFaceWASM:pv})}Oe.set_destination_refinement_level(s,0),l=en.buildLevel(s,!0,r)}else s=e;if(i!==void 0&&i.subdivisions!==void 0){let f=cD(i.subdivisions,i.positionWASM.length);Oe.set_destination_refinement_level(s,f),f>0?c=en.buildLevel(s,!1,r):c=null}return{subdivPointer:s,originalGeometry:l,subdividedGeometry:c}}static allocate(i,e,t){var A;let r,n,s,l=[],c=[];if(t)t.positionWASM&&t.positionWASM.length>0?(r=t.positionWASM,n=t.indexWASM,s=t.verticesPerFaceWASM):(r=hv,n=dv,s=pv);else{e.deleteAttribute("normal"),e.deleteAttribute("uv");let q=lD(e);r=q.attributes.position.array;let E=q.getIndex().array,b=E.length;switch(e.userData.type==="TorusGeometry"&&(e==null?void 0:e.userData.parameters.arc)===Math.PI*2&&(e.userData.type="ClosedTorusGeometry"),e.userData.type){case"ClosedTorusGeometry":case"PlaneGeometry":case"TorusKnotGeometry":case"CubeGeometry":n=new Uint32Array(b/3*2),s=new Uint8Array(b/6).fill(4);for(let re=0,Ne=0;re<b;re+=6)n[Ne++]=E[re],n[Ne++]=E[re+1],n[Ne++]=E[re+4],n[Ne++]=E[re+5];break;case"TorusGeometry":case"SphereGeometry":case"HelixGeometry":case"CylinderGeometry":case"ConeGeometry":let R,I,z;if(e.userData.type==="SphereGeometry")I=e.parameters.heightSegments,R=e.parameters.widthSegments,e.parameters.thetaLength!==Math.PI&&(z=!0);else if(e.userData.type==="CylinderGeometry")I=e.parameters.heightSegments+2,R=e.parameters.radialSegments;else if(e.userData.type==="ConeGeometry")I=e.parameters.heightSegments+1,R=e.parameters.radialSegments;else if(e.userData.type==="TorusGeometry"){let re=e.userData.parameters;I=Math.ceil(re.tubularSegments*re.arc/(2*Math.PI))+2,R=re.radialSegments}else{let{pathSegments:re,segments:Ne,revolutions:ye}=e.userData.parameters;I=Math.ceil(Ne*ye)+2,R=re}z?(n=new Uint32Array(1*R*3+(I-1)*R*4),s=new Uint8Array(1*R+(I-1)*R)):(n=new Uint32Array(2*R*3+(I-2)*R*4),s=new Uint8Array(2*R+(I-2)*R));let O=0,$=0,he=0;if(e.userData.type==="SphereGeometry"||e.userData.type==="HelixGeometry"||e.userData.type==="TorusGeometry"){for(;$<3*R;)n[$++]=E[O++],n[$++]=E[O++],n[$++]=E[O++],s[he++]=3;let re=z?n.length:3*R+4*(I-2)*R;for(;$<re;O+=6)n[$++]=E[O],n[$++]=E[O+1],n[$++]=E[O+4],n[$++]=E[O+5],s[he++]=4}else for(;$<4*(I-2)*R;O+=6)n[$++]=E[O],n[$++]=E[O+1],n[$++]=E[O+4],n[$++]=E[O+5],s[he++]=4;for(;$<n.length;)n[$++]=E[O++],n[$++]=E[O++],n[$++]=E[O++],s[he++]=3;break;default:n=E,s=new Uint8Array(b/3).fill(3);break}}let f=r.length,h=n.length,p=s.length,y=r.length+l.length+c.length,g=n.length+s.length,w=y*Float32Array.BYTES_PER_ELEMENT+g*Uint32Array.BYTES_PER_ELEMENT,S=y*Float32Array.BYTES_PER_ELEMENT,T=g*Uint32Array.BYTES_PER_ELEMENT,C=Oe._malloc(w),B=new Float32Array(Oe.HEAPF32.buffer,C,y),G=new Uint32Array(Oe.HEAPU32.buffer,C+S,g);B.set(r,0),B.set(l,r.length),B.set(c,r.length+l.length),G.set(n,0),G.set(s,n.length);let D;((A=t==null?void 0:t.scaleBaked)==null?void 0:A.some(q=>q!==1))&&(D=new aD().makeScale(...t.scaleBaked)),i&&(D?D.premultiply(i):D=i);let W=D?Oe.alloc_subdivision_surface2(C,f,C+S,h,C+S+n.length*Uint32Array.BYTES_PER_ELEMENT,p,D.elements):Oe.alloc_subdivision_surface(C,f,C+S,h,C+S+n.length*Uint32Array.BYTES_PER_ELEMENT,p);return Oe._free(C),W}static buildLevel(i,e,t,r,n){let s=n?Oe.get_mesh_data2(i,e?Oe.Level.CONTROL:Oe.Level.REFINED,t!=null?t:!e,n.elements):Oe.get_mesh_data(i,e?Oe.Level.CONTROL:Oe.Level.REFINED,t!=null?t:!e),l=8,c=Oe.HEAPU32.subarray(s>>2,(s>>2)+l),f=c.subarray(4,4+4),h=0,p=Oe.HEAPU32[c[h]>>2],y=Oe.HEAPF32.subarray(p>>2,(p>>2)+f[h]);h++;let g=Oe.HEAPU32[c[h]>>2],w=Oe.HEAPF32.subarray(g>>2,(g>>2)+f[h]);h++;let S=Oe.HEAPU32[c[h]>>2],T=Oe.HEAPU32.subarray(S>>2,(S>>2)+f[h]);h++;let C=Oe.HEAPU32[c[h]>>2],B=Oe.HEAPU32.subarray(C>>2,(C>>2)+f[h]);if(h++,r===void 0){let G=new uv;if(G.setIndex(new ed(B,1)),G.setAttribute("position",new td(y,3)),G.setAttribute("normal",new td(w,3)),e){G.setAttribute("faceMap",new ed(T,1));let D=new Float32Array(w.length/3*4).fill(0);G.setAttribute("color",new fv(D,4))}return Oe.free_mesh_data(s),G.userData.type="SubdivGeometry",G}r.getAttribute("position").copyArray(y),r.getAttribute("normal").copyArray(w),r.attributes.position.needsUpdate=!0,r.attributes.normal.needsUpdate=!0,Oe.free_mesh_data(s)}static buildControlCageWireframe(i,e,t){let r=Oe.get_wireframe_data_for_base_level(i),n=4,s=Oe.HEAPU32.subarray(r>>2,(r>>2)+n),l=s.subarray(2,2+2),c=0,f=Oe.HEAPU32[s[c]>>2],h=Oe.HEAPF32.subarray(f>>2,(f>>2)+l[c]);c++;let p=Oe.HEAPU32[s[c]>>2],y=Oe.HEAPU32.subarray(p>>2,(p>>2)+l[c]);if(e===void 0){let g=new uv;g.setAttribute("position",new td(h,3));let w=new Float32Array(h.length);for(let S=0,T=h.length;S<T;)w[S++]=t.r,w[S++]=t.g,w[S++]=t.b;return g.setAttribute("color",new fv(w,3)),g.setIndex(new ed(y,1)),Oe.free_wireframe_data_for_base_level(r),g}e.getAttribute("position").copyArray(h),e.attributes.position.needsUpdate=!0,Oe.free_wireframe_data_for_base_level(r)}static updateCollabMesh(i,e,t){e||Oe.set_destination_refinement_level(i,1);let r=t?Oe.get_topological_data2(i,e?Oe.Level.CONTROL:Oe.Level.REFINED,t.elements):Oe.get_topological_data(i,e?Oe.Level.CONTROL:Oe.Level.REFINED),n=6,s=Oe.HEAPU32.subarray(r>>2,(r>>2)+n),l=s.subarray(3,3+3),c=0,f=Oe.HEAPU32[s[c]>>2],h=new Float32Array(Oe.HEAPF32.subarray(f>>2,(f>>2)+l[c]));c++;let p=Oe.HEAPU32[s[c]>>2],y=new Uint32Array(Oe.HEAPU32.subarray(p>>2,(p>>2)+l[c]));c++;let g=Oe.HEAPU32[s[c]>>2],w=new Uint8Array(Oe.HEAPU32.subarray(g>>2,(g>>2)+l[c]));return Oe.free_topological_data(r),{positions:h,indices:y,verticesPerFace:w}}};function cD(i,e){let t=i;return t=Math.min(t,3-Math.ceil(Math.log(e/172e3)/Math.log(4))),Math.max(t,0)}var rd={ConeGeometry:g0,CubeGeometry:y0,CylinderGeometry:p0,DodecahedronGeometry:v0,EllipseGeometry:U0,HelixGeometry:J0,IcosahedronGeometry:K0,LatheGeometry:X0,NonParametricGeometry:au,PolygonGeometry:ev,PyramidGeometry:tv,RectangleGeometry:lu,SphereGeometry:nv,PlaneGeometry:iv,StarGeometry:ov,TextFrameGeometry:cu,TorusGeometry:sv,TorusKnotGeometry:av,TriangleGeometry:lv,VectorGeometry:ur},Ia=i=>rd[i.type].create(i);import{Matrix4 as ad}from"three";import{Box3 as xv,Line3 as gn,Matrix4 as nd,Vector3 as Ct}from"three";import{HemisphereLight as mv}from"three";import{Color as uD}from"three";var tn=class extends uD{constructor(e,t,r,n){super(e,t,r);this.isColorA=!0;this.a=n}setRGBA(e,t,r,n){super.setRGB(e,t,r),this.a=n}copy(e){return super.copy(e),this.a="a"in e?e.a:1,this}clone(){return new this.constructor(this.r,this.g,this.b,this.a)}get x(){return this.r}get y(){return this.g}get z(){return this.b}get w(){return this.a}set x(e){this.r=e}set y(e){this.g=e}set z(e){this.b=e}set w(e){this.a=e}};function kt(i,e){let t;if(typeof i=="string"){let r=e==null?void 0:e.getColor(i);r?t=r:(console.warn("Tried to create color layer params with a color key that does not exist in the assets manager"),t=new tn(0,0,0,0))}else return"a"in i?new tn(i.r,i.g,i.b,i.a):new tn(i.r,i.g,i.b,1);return t}var fu=i=>"isEntity"in i,Ms=i=>"isAbstractMesh"in i;var Si=i=>"objectHelper"in i;function fD(i,e){var r;let t=!1;e.position&&(i.position.fromArray(e.position),t=!0),e.rotation&&(i.rotation.fromArray(e.rotation),t=!0),e.scale&&(t=!0,i.scale.fromArray(e.scale)),e.hiddenMatrix!==void 0&&"hiddenMatrix"in i&&(t=!0,i.hiddenMatrix.fromArray((r=e.hiddenMatrix)!=null?r:Ui.identity)),t&&i.updateMatrix(),e.position&&e.rotation&&e.scale&&e.hiddenMatrix!==void 0&&i.updateWorldMatrix(!1,!0),i.objectType==="CombinedCamera"&&(e.isUpVectorFlipped!==void 0&&(i.isUpVectorFlipped=e.isUpVectorFlipped),i.updateUp())}function hD(i,e){fD(i,e),e.name!==void 0&&(i.name=e.name),e.visible!==void 0&&(i.isEntity?i.visibility=e.visible:i.visible=e.visible)}function gv(i,e,t){hD(i,e),e.color!==void 0&&(i.color=kt(e.color,t)),e.intensity!==void 0&&(i.intensity=e.intensity),e.shadows!==void 0&&!(i instanceof mv)&&(i.castShadow=e.shadows),i.shadow&&!(i instanceof mv)&&e.depth!==void 0&&(i.shadow.camera.far=e.depth,i.shadow.needsUpdate=!0),e.helper!==void 0&&Si(i)&&(i.enableHelper=e.helper,i.gizmos.shadowmap.visible=e.helper)}function yv(i,e){i.shadow.camera.right=e/2,i.shadow.camera.left=-e/2,i.shadow.camera.top=e/2,i.shadow.camera.bottom=-e/2,i.shadow.needsUpdate=!0}var As=new xv,fr=new Ct,Ie=new Ct,$t=new nd;function dD(i,e,t=0,r=e.count){let n=1/0,s=1/0,l=1/0,c=-1/0,f=-1/0,h=-1/0;for(let p=t;p<r;p++){let y=e.getX(p),g=e.getY(p),w=e.getZ(p);y<n&&(n=y),g<s&&(s=g),w<l&&(l=w),y>c&&(c=y),g>f&&(f=g),w>h&&(h=w)}return i.min.set(n,s,l),i.max.set(c,f,h),i}var vv=(i,e,t,r)=>{var n;if(Ms(i)){let s=i.geometry.userData.parameters,l=i.geometry.getAttribute("position");i.geometry.userData.type==="SubdivGeometry"?fr.copy(i.originalGeometry.boundingSphere.center):(dD(As,l,i.geometry.drawRange.start,i.geometry.drawRange.count<1/0?i.geometry.drawRange.count:l.count),As.getCenter(fr)),i.forceComputeSize?As.getSize(Ie).multiplyScalar(.5):Ie.set(s.width,s.height,(n=s.depth)!=null?n:0).multiplyScalar(.5)}else if(Si(i)&&r===!0){let s=i.geometryHelper.getAttribute("position");As.setFromArray(s.array),As.getCenter(fr),As.getSize(Ie).multiplyScalar(.5)}else fr.setScalar(0),Ie.setScalar(0);$t.copy(e).multiply(i.matrixWorld),Ie.x===0&&Ie.y===0&&Ie.z===0?t.push(new Ct(fr.x,fr.y,fr.z).applyMatrix4($t)):t.push(new Ct(-Ie.x,Ie.y,Ie.z).add(fr).applyMatrix4($t),new Ct(-Ie.x,-Ie.y,Ie.z).add(fr).applyMatrix4($t),new Ct(Ie.x,-Ie.y,Ie.z).add(fr).applyMatrix4($t),new Ct(Ie.x,Ie.y,Ie.z).add(fr).applyMatrix4($t),new Ct(-Ie.x,Ie.y,-Ie.z).add(fr).applyMatrix4($t),new Ct(-Ie.x,-Ie.y,-Ie.z).add(fr).applyMatrix4($t),new Ct(Ie.x,-Ie.y,-Ie.z).add(fr).applyMatrix4($t),new Ct(Ie.x,Ie.y,-Ie.z).add(fr).applyMatrix4($t))},hu=class extends xv{constructor(){super(...arguments);this.matrix=new nd;this.vertices=[];this.faces=[];this.edges=[];this.centerEdges=[]}copy(e){return super.copy(e),this.matrix.copy(e.matrix),this.vertices=e.vertices.map(t=>t.clone()),this.faces=e.faces.map(t=>t.clone()),this.edges=e.edges.map(t=>t.clone()),this.centerEdges=e.centerEdges.map(t=>t.clone()),this}setFromObjectSize(e,t=!1){e.updateWorldMatrix(!1,t),this.makeEmpty(),this.matrix.copy(e.matrixWorld);let r=new nd().copy(e.matrixWorld).invert();return this.expandByObjectSize(e,r,t)}expandByObjectSize(e,t,r=!1){let n=[];return r===!0?e.traverseEntity(s=>vv(s,t,n,e.enableHelper===!0)):vv(e,t,n,e.enableHelper===!0),this.setFromPoints(n)}getCenter(e){return e=super.getCenter(e),e.applyMatrix4(this.matrix),e}getPositionToCenter(e){return e=super.getCenter(e),e.applyMatrix4($t.copy(this.matrix).setPosition(0,0,0)),e}computeVertices(){this.getSize(Ie).multiplyScalar(.5),this.getCenter(fr),$t.copy(this.matrix).setPosition(fr),this.vertices=[new Ct(-Ie.x,Ie.y,Ie.z).applyMatrix4($t),new Ct(-Ie.x,-Ie.y,Ie.z).applyMatrix4($t),new Ct(Ie.x,-Ie.y,Ie.z).applyMatrix4($t),new Ct(Ie.x,Ie.y,Ie.z).applyMatrix4($t),new Ct(-Ie.x,Ie.y,-Ie.z).applyMatrix4($t),new Ct(-Ie.x,-Ie.y,-Ie.z).applyMatrix4($t),new Ct(Ie.x,-Ie.y,-Ie.z).applyMatrix4($t),new Ct(Ie.x,Ie.y,-Ie.z).applyMatrix4($t)]}computeEdges(){this.vertices.length>0&&this.computeVertices(),this.edges=[new gn(this.vertices[0],this.vertices[3]),new gn(this.vertices[1],this.vertices[2]),new gn(this.vertices[5],this.vertices[6]),new gn(this.vertices[4],this.vertices[7]),new gn(this.vertices[0],this.vertices[1]),new gn(this.vertices[3],this.vertices[2]),new gn(this.vertices[7],this.vertices[6]),new gn(this.vertices[4],this.vertices[5]),new gn(this.vertices[0],this.vertices[4]),new gn(this.vertices[1],this.vertices[5]),new gn(this.vertices[2],this.vertices[6]),new gn(this.vertices[3],this.vertices[7])],this.centerEdges=this.edges.map(e=>e.getCenter(new Ct))}computeFaces(){this.vertices.length>0&&this.computeVertices(),this.faces=[new Ct().copy(this.vertices[0]).sub(this.vertices[2]).multiplyScalar(.5).add(this.vertices[2]),new Ct().copy(this.vertices[7]).sub(this.vertices[5]).multiplyScalar(.5).add(this.vertices[5]),new Ct().copy(this.vertices[4]).sub(this.vertices[1]).multiplyScalar(.5).add(this.vertices[1]),new Ct().copy(this.vertices[3]).sub(this.vertices[6]).multiplyScalar(.5).add(this.vertices[6]),new Ct().copy(this.vertices[4]).sub(this.vertices[3]).multiplyScalar(.5).add(this.vertices[3]),new Ct().copy(this.vertices[1]).sub(this.vertices[6]).multiplyScalar(.5).add(this.vertices[6])]}};import{Object3D as _D,Matrix4 as TD,Light as ID}from"three";import{Group as ND,Mesh as Lv,MeshStandardMaterial as _v}from"three";import{BufferGeometry as pD,Float32BufferAttribute as id}from"three";function bv(i){var l;let e=[],t=i.groups,r=i.getAttribute("position").array,n=i.getAttribute("normal").array,s=(l=i.getAttribute("uv"))==null?void 0:l.array;return t.forEach(c=>{let f=c.count,h=new pD,p=new Float32Array(f*3),y=new Float32Array(f*3),g=new Float32Array(f*2);for(let w=0;w<f;w++){let S=3*(c.start+w),T=3*w;if(p[T]=r[S],p[T+1]=r[S+1],p[T+2]=r[S+2],y[T]=n[S],y[T+1]=n[S+1],y[T+2]=n[S+2],s){let C=2*(c.start+w),B=2*w;g[B]=s[C],g[B+1]=s[C+1]}}h.setAttribute("position",new id(p,3)),h.setAttribute("normal",new id(y,3)),s&&h.setAttribute("uv",new id(g,2)),e.push(h)}),e}import{GLTFExporter as CD}from"three/examples/jsm/exporters/GLTFExporter.js";var mD,Sv=new Promise(i=>{mD=i});var Tv=rh(Cv());var pu={isPublish:!1,gltfQueue:[]};function sd(i,e,t){return i[e.uuid]===void 0&&(i[e.uuid]=e.toJSON(t)),e.uuid}var LD=new CD;function Iv(i,e,t){if(i[e.uuid]===void 0)if(e.userData.type==="NonParametricGeometry"||e.userData.type==="SubdivGeometry"){if(e.userData.type==="SubdivGeometry")if(pu.isPublish)e=au.create({geometry:e.clone()}),e.userData.parameters.subdivisions===0&&(delete e.attributes.color,delete e.attributes.faceMap,delete e.attributes.positionWASM,delete e.attributes.indexWASM,delete e.attributes.verticesPerFaceWASM);else{let n=e.originalGeometry;if(n){let s=e.userData;e=n.clone(),e.userData=s}else e=e.clone();delete e.attributes.color,delete e.attributes.faceMap,delete e.attributes.position,delete e.attributes.normal,e.index=null}let r=e.originalGeometry;if(r!==void 0){let n=e.userData;e=r,e.userData=n}if(!pu.isPublish)i[e.uuid]=e.toJSON();else{let n={type:"NonParametricGeometry",uuid:e.uuid,userData:{}};e.name!==""&&(n.name=e.name),Object.keys(e.userData).length>0&&(n.userData=U({},e.userData));let s=e.index===null,l=new ND;if(Array.isArray(t))bv(e).forEach((f,h)=>{let p=new Lv(f,new _v);l.add(p),f.userData.groupIndex=h,f.userData.materialIndex=e.groups[h].materialIndex,f.index===null&&(s=!0)});else{let c=new Lv(e,new _v);l.add(c)}pu.gltfQueue.push(new Promise(async c=>{await Promise.all(pu.gltfQueue),LD.parse(l,async f=>{let{gltfTransform:h,DracoMeshCompressionExtension:p,addIndex:y}=await Sv,g=h.readJSON({json:xo(f),resources:{}});g.createExtension(p).setRequired(!0).setEncoderOptions({quantizationVolume:"scene"}),s&&await g.transform(y);try{let{json:w,resources:S}=h.writeJSON(g),T=Tv.default.fromByteArray(new Uint8Array(S[".bin"]));w.buffers[0].uri=`data:application/octet-stream;base64,${T}`,c()}catch(w){c()}},{})})),i[e.uuid]=n}}else{let r=e.userData;if(r.type==="VectorGeometry"){let n=e.userData.shape;r=Object.assign({},r,{shape:n.toJSON()})}i[e.uuid]={uuid:e.uuid,userData:r}}return e.uuid}function Os(i){let e=[];for(let t in i){let r=i[t];delete r.metadata,e.push(r)}return e}function Mv(i){let e=[];for(let t in i)e.push(i[t]);return e}var mu=i=>class extends i{hasEntityChild(){return this.children.some(t=>fu(t))}isDescendantOf(t){t instanceof _D&&(t=t.uuid);let r=this;for(;r.parent;){if(r.parent.uuid===t)return!0;r=r.parent}return!1}attach(t,r){this.updateWorldMatrix(!0,!1);let n=new TD().copy(this.matrixWorld).invert();return t.parent!==null&&(t.parent.updateWorldMatrix(!0,!1),n.multiply(t.parent.matrixWorld)),fu(t)?t.hiddenMatrix.premultiply(n):t.applyMatrix4(n),t.updateWorldMatrix(!1,!1),this.add(t),r!==void 0&&(this.children.pop(),this.children.splice(r,0,t)),this}copy(t,r=!0){if(this.name=t.name,this.up.copy(t.up),this.position.copy(t.position),this.rotation.order=t.rotation.order,this.quaternion.copy(t.quaternion),this.scale.copy(t.scale),this.matrix.copy(t.matrix),this.matrixWorld.copy(t.matrixWorld),this.matrixAutoUpdate=t.matrixAutoUpdate,this.matrixWorldNeedsUpdate=t.matrixWorldNeedsUpdate,this.layers.mask=t.layers.mask,this.visible=t.visible,this.castShadow=t.castShadow,this.receiveShadow=t.receiveShadow,this.frustumCulled=t.frustumCulled,this.renderOrder=t.renderOrder,this.userData=JSON.parse(JSON.stringify(t.userData)),r===!0)for(let n=0;n<t.children.length;n++){let s=t.children[n];this.add(s.clone())}return this}toJSON(t){let r=t===void 0,n={object:{uuid:"",objectType:""}};t===void 0&&(t={geometries:{},materials:{},textures:{},images:{},interactionStates:{},nodes:{}},n.metadata={version:1.5,type:"Object",generator:"Object3D.toJSON"});let s={uuid:this.uuid,objectType:this.type};if(this.name!==""&&(s.name=this.name),s.matrix=this.matrix.toArray(),this.castShadow===!0&&(s.castShadow=!0),this.receiveShadow===!0&&(s.receiveShadow=!0),this.visible===!1&&(s.visible=!1),this.frustumCulled===!1&&(s.frustumCulled=!1),this.renderOrder!==0&&(s.renderOrder=this.renderOrder),s.layers=this.layers.mask,JSON.stringify(this.userData)!=="{}"&&(s.userData=this.userData),this.children.length>0){s.children=[];for(let l of this.children)(fu(l)||l instanceof ID)&&s.children.push(l.toJSON(t).object)}if(r){let l=Os(t.geometries),c=Os(t.materials),f=Os(t.textures),h=Os(t.images),p=Os(t.interactionStates),y=Mv(t.nodes);l.length>0&&(n.geometries=l),c.length>0&&(n.materials=c),f.length>0&&(n.textures=f),h.length>0&&(n.images=h),p.length>0&&(n.interactionStates=p),y.length>0&&(n.nodes=y)}return n.object=s,n}fromJSON(t){return this.uuid=t.uuid,t.name!==void 0&&(this.name=t.name),t.matrix!==void 0?(this.matrix.fromArray(t.matrix),t.matrixAutoUpdate!==void 0&&(this.matrixAutoUpdate=t.matrixAutoUpdate),this.matrixAutoUpdate&&this.matrix.decompose(this.position,this.quaternion,this.scale)):(t.position!==void 0&&this.position.fromArray(t.position),t.rotation!==void 0&&this.rotation.fromArray(t.rotation),t.quaternion!==void 0&&this.quaternion.fromArray(t.quaternion),t.scale!==void 0&&this.scale.fromArray(t.scale)),this.castShadow=t.castShadow!==void 0,this.receiveShadow=t.receiveShadow!==void 0,t.visible!==void 0&&(this.visible=t.visible),t.frustumCulled!==void 0&&(this.frustumCulled=t.frustumCulled),t.renderOrder!==void 0&&(this.renderOrder=t.renderOrder),t.layers!==void 0&&(this.layers.mask=t.layers),t.userData!==void 0&&(this.userData=t.userData),this}};var xn=i=>"isEntity"in i;var vn=i=>class extends mu(i){constructor(){super(...arguments);this.objectType="";this.isEntity=!0;this.raycastLock=!1;this.scaleLock=!1;this.hiddenMatrix=new ad;this._singleBBox=new hu;this._recursiveBBox=new hu;this.singleBBoxNeedsUpdate=!0;this.recursiveBBoxNeedsUpdate=!0;this.forceComputeSize=!1}set visibility(t){this.visible=t;for(let r of this.children)xn(r)&&r.traverseEntity(n=>{Si(n)&&n.visible&&(n.objectHelper.visible=t)})}get visibility(){return this.visible}get singleBBox(){return this.singleBBoxNeedsUpdate&&(this.singleBBoxNeedsUpdate=!1,this._singleBBox.setFromObjectSize(this,!1),this._singleBBox.computeVertices(),this._singleBBox.computeEdges(),this._singleBBox.computeFaces()),this._singleBBox}get recursiveBBox(){return this.recursiveBBoxNeedsUpdate&&(this.recursiveBBoxNeedsUpdate=!1,this._recursiveBBox.setFromObjectSize(this,!0),this._recursiveBBox.computeVertices(),this._recursiveBBox.computeEdges(),this._recursiveBBox.computeFaces()),this._recursiveBBox}resetBBoxNeedsUpdate(){this.singleBBoxNeedsUpdate=!0,this.recursiveBBoxNeedsUpdate=!0,this.traverseAncestors(t=>{xn(t)&&(t.singleBBoxNeedsUpdate=!0,t.recursiveBBoxNeedsUpdate=!0)}),this.traverseEntity(t=>{t.singleBBoxNeedsUpdate=!0,t.recursiveBBoxNeedsUpdate=!0})}traverseEntity(t){t(this);for(let r of this.children)xn(r)&&r.traverseEntity(t)}updateMatrixWorld(t){this.matrixAutoUpdate&&this.updateMatrix(),(this.matrixWorldNeedsUpdate||t)&&(this.parent===null?this.matrixWorld.multiplyMatrices(this.hiddenMatrix,this.matrix):(this.matrixWorld.multiplyMatrices(this.parent.matrixWorld,this.hiddenMatrix),this.matrixWorld.multiplyMatrices(this.matrixWorld,this.matrix)),this.matrixWorldNeedsUpdate=!1,t=!0);for(let r of this.children)r.updateMatrixWorld(t)}updateWorldMatrix(t,r){let n=this.parent;if(t&&n!==null&&n.updateWorldMatrix(!0,!1),this.matrixAutoUpdate&&this.updateMatrix(),this.parent===null?this.matrixWorld.multiplyMatrices(this.hiddenMatrix,this.matrix):(this.matrixWorld.multiplyMatrices(this.parent.matrixWorld,this.hiddenMatrix),this.matrixWorld.multiplyMatrices(this.matrixWorld,this.matrix)),r)for(let s of this.children)s.updateWorldMatrix(!1,!0)}shallowClone(t){return new this.constructor().shallowCopy(this,t)}shallowCopy(t,r=!0){if(super.copy(t,!1),this.raycastLock=t.raycastLock,this.scaleLock=t.scaleLock,this.hiddenMatrix.copy(t.hiddenMatrix),r===!0)for(let n of t.children)xn(n)&&this.add(n.shallowClone());return this}clone(t){return new this.constructor().copy(this,t)}copy(t,r=!0){if(super.copy(t,!1),this.raycastLock=t.raycastLock,this.scaleLock=t.scaleLock,this.hiddenMatrix.copy(t.hiddenMatrix),r===!0)for(let n of t.children)xn(n)&&this.add(n.clone());return this}keepChildrenMatrixWorld(){let t=new ad,r=this.matrixWorld.clone();this.updateWorldMatrix(!1,!1),t.copy(this.matrixWorld).invert(),t.multiply(r);for(let n of this.children)xn(n)&&n.hiddenMatrix.premultiply(t)}toJSON(t){let r=super.toJSON(t),n=r.object;return this.raycastLock===!0&&(n.raycastLock=!0),this.scaleLock===!0&&(n.scaleLock=!0),n.hiddenMatrix=this.hiddenMatrix.toArray(),r}fromJSON(t){return super.fromJSON(t),t.raycastLock!==void 0&&(this.raycastLock=t.raycastLock),t.scaleLock!==void 0&&(this.scaleLock=t.scaleLock),this.hiddenMatrix.fromArray(t.hiddenMatrix),this}fromObject3D(t){let r=t.children;return t.children=[],Object.assign(t,{raycastLock:!1,scaleLock:!1,hiddenMatrix:new ad}),this.copy(t),t.children=r,this}toObjectTransformState(t=[]){this.updateWorldMatrix(!0,!1);let r={position:this.position.toArray(),rotation:[this.rotation.x,this.rotation.y,this.rotation.z],scale:this.scale.toArray(),hiddenMatrix:this.hiddenMatrix.toArray()};return ms(r,t)}fromObjectTransformState(t){return t.position&&this.position.fromArray(t.position),t.rotation&&this.rotation.fromArray(t.rotation),t.scale&&this.scale.fromArray(t.scale),t.hiddenMatrix&&this.hiddenMatrix.fromArray(t.hiddenMatrix),this.updateMatrix(),this}toState(t=[]){let r=U({name:this.name,visible:this.visible,raycastLock:this.raycastLock},this.toObjectTransformState(t));return ms(r,t)}fromState(t,r){return t.name&&(this.name=t.name),t.raycastLock!==void 0&&(this.raycastLock=t.raycastLock),t.type!=="OrthographicCamera"&&t.type!=="PerspectiveCamera"&&(this.matrixAutoUpdate=!1),t.visible!==void 0&&(this.visibility=t.visible),this.fromObjectTransformState(t),this}};import{Object3D as MD,Vector3 as Ma,Euler as Av,MathUtils as Ki}from"three";var gu=class extends MD{constructor(e,t={}){super();this.object=e;let r=e.recursiveBBox.getSize(new Ma),n=.1;this.parameters=xc.defaultData(r.toArray(),n),vo(this.parameters,t),this.update(),this.setHideBase(this.parameters.hideBase)}refreshMaterial(){if("material"in this.object)for(let e of this.children)e.material=this.object.material}setHideBase(e){if("material"in this.object){if(Array.isArray(this.object.material)){if(this.children.length>0){for(let t of this.object.material)t.visible=!0;if(e){let t=this.object.material.map(r=>r.clone());for(let r of this.children)r.material=t}else for(let t of this.children)t.material=this.object.material}for(let t of this.object.material)t.visible=!e}else{if(this.children.length>0)if(this.object.material.visible=!0,e){let t=this.object.material.clone();for(let r of this.children)r.material=t}else for(let t of this.children)t.material=this.object.material;this.object.material.visible=!e}this.parameters.hideBase=e}}update(){switch(this._updateCount(),this.parameters.type){case"radial":this._updateRadial(this.parameters);break;case"linear":this._updateLinear(this.parameters);break;case"grid":this._updateGrid(this.parameters)}this.children.forEach(e=>e.updateMatrix())}_updateCount(){let e=this.parameters.type==="grid"?this.parameters.grid.count[0]*this.parameters.grid.count[1]*this.parameters.grid.count[2]:this.parameters.count;if(this.children.length!==e)if(this.children.length<e)for(let t=0,r=e-this.children.length;t<r;++t){let n=this.object.shallowClone(!1);n.visible=!0,this.add(n),this.parameters.hideBase&&this.setHideBase(!0)}else for(let t=0,r=this.children.length-e;t<r;++t)this.remove(this.children[0])}_updateRadial(e){let t=e.radial,r=t.start*Ki.DEG2RAD,n=t.end*Ki.DEG2RAD,s=r-n,l=new Av(t.rotation[0]*Ki.DEG2RAD,t.rotation[1]*Ki.DEG2RAD,t.rotation[2]*Ki.DEG2RAD),c;switch(t.axis){case"z":c=new Ma(0,0,1);break;case"y":c=new Ma(0,1,0);break;default:case"x":c=new Ma(1,0,0);break}for(let[f,h]of this.children.entries()){h.hiddenMatrix.identity(),h.scale.x=t.scale[0]+1,h.scale.y=t.scale[1]+1,h.scale.z=t.scale[2]+1,h.position.setScalar(0);let p=s/e.count*f-r;switch(t.axis){case"x":h.rotation.set(0,p,0);break;case"y":h.rotation.set(0,0,p);break;case"z":h.rotation.set(p,0,0);break}h.translateOnAxis(c,t.radius),h.position.x+=t.position[0],h.position.y+=t.position[1],h.position.z+=t.position[2],t.alignment===!0?(h.rotation.x+=l.x,h.rotation.y+=l.y,h.rotation.z+=l.z):h.rotation.copy(l)}}_updateLinear(e){if(e.type!=="linear")throw new Error;let t=e.linear,r=new Av(t.rotation[0]*Ki.DEG2RAD,t.rotation[1]*Ki.DEG2RAD,t.rotation[2]*Ki.DEG2RAD);for(let[n,s]of this.children.entries())s.hiddenMatrix.identity(),s.scale.x=t.scale[0]*n+1,s.scale.y=t.scale[1]*n+1,s.scale.z=t.scale[2]*n+1,s.rotation.x=r.x*n,s.rotation.y=r.y*n,s.rotation.z=r.z*n,s.position.x=t.position[0]*n,s.position.y=t.position[1]*n,s.position.z=t.position[2]*n}_updateGrid(e){let t=0,r=e.grid;if(r.useCenter===!0){let n={x:r.count[0]%2==0?2:1,y:r.count[1]%2==0?2:1,z:r.count[2]%2==0?2:1},s=new Ma(r.size[0]*(r.count[0]-n.x)*.5,r.size[1]*(r.count[1]-n.y)*.5,r.size[2]*(r.count[2]-n.z)*.5);for(let l=0;l<r.count[0];l++)for(let c=0;c<r.count[1];c++)for(let f=0;f<r.count[2];f++){let h=this.children[t++];h.hiddenMatrix.identity(),h.scale.setScalar(1),h.rotation.set(0,0,0),h.position.x=r.size[0]*l-s.x,h.position.y=r.size[1]*c-s.y,h.position.z=r.size[2]*f-s.z}}else for(let n=0;n<r.count[0];n++)for(let s=0;s<r.count[1];s++)for(let l=0;l<r.count[2];l++){let c=this.children[t++];c.hiddenMatrix.identity(),c.scale.setScalar(1),c.rotation.set(0,0,0),c.position.x=r.size[0]*n,c.position.y=-r.size[1]*s,c.position.z=-r.size[2]*l}}fromJSON(e){return this}toJSON(){return{}}fromClonerState(e){return e.hideBase!==void 0&&this.setHideBase(e.hideBase),vo(this.parameters,e),this.update(),this}};var hr=class extends vn(AD){constructor(e,t){super(e,t);this.isAbstractMesh=!0;Array.isArray(t)&&(this.selectedMaterial=0,e.groups.length===0&&e.addGroup(0,e.getAttribute("position").count,0))}get cloner(){return this._cloner}set cloner(e){this._cloner&&this.remove(this._cloner),e&&this.add(e),this._cloner=e}getSelectedMaterial(e){return Array.isArray(this.material)?(this.selectedMaterial===void 0&&(this.selectedMaterial=e!=null?e:0),this.material[e!=null?e:this.selectedMaterial]):this.material}setSelectedMaterial(e,t){Array.isArray(this.material)?(this.selectedMaterial===void 0&&(this.selectedMaterial=t!=null?t:0),t=t!=null?t:this.selectedMaterial,this.material[t].dispose(),this.material[t]=e):(this.material.dispose(),this.material=e)}updateGeometry(e){let t=this.geometry,r=rd[t.userData.type],n=this.objectType==="NonParametric"?Object.assign({},t.userData,{geometry:t}):t.userData,s=r.build(r.normalizeInputs(e,n)),l=t.uuid;if(this.geometry.dispose(),this.geometry=s,this.geometry.uuid=l,this.geometry.computeBoundingSphere(),this.cloner)for(let c of this.cloner.children)c.geometry=this.geometry}resizeGeometry(e,t,r){Ta.resizeGeometry(this.geometry,{width:e,height:t,depth:r})}shallowClone(e){return new this.constructor(this.geometry,this.material).shallowCopy(this,e)}clone(e){let t=this.objectType==="NonParametric"?Object.assign({},this.geometry.userData,{geometry:this.geometry.clone()}):this.geometry.userData,r=Ia(t),n=Array.isArray(this.material)?this.material.map(s=>s.clone()):this.material.clone();return new this.constructor(r,n).copy(this,e)}copy(e,t=!0){return super.copy(e,t),e.cloner&&(this.cloner=new gu(e,e.cloner.parameters),this.add(this.cloner)),this}toJSON(e){let t=super.toJSON(e),r=t.object;if(r.geometry=Iv(e.geometries,this.geometry,this.material),Array.isArray(this.material)){let n=[];for(let s=0,l=this.material.length;s<l;s++)n.push(sd(e.materials,this.material[s],e));r.material=n}else r.material=sd(e.materials,this.material,e);return t}fromJSON(e){return super.fromJSON(e),e.selectedMaterial!==void 0&&(this.selectedMaterial=e.selectedMaterial),this}setFromClonerState(e){e===null?this.cloner=void 0:(this.cloner===void 0&&(this.cloner=new gu(this)),this.cloner.fromClonerState(e))}fromState(e,t){var r,n;return super.fromState(e),e.type==="Mesh"&&(this.setFromClonerState(e.cloner),this.castShadow=(r=e.castShadow)!=null?r:!0,this.receiveShadow=(n=e.receiveShadow)!=null?n:!0),this}};import{NormalBlending as YD,ShaderMaterial as QD,FrontSide as e3}from"three";import{CubeReflectionMapping as UD,CubeRefractionMapping as kD,CubeUVReflectionMapping as HD,CubeUVRefractionMapping as WD,LinearEncoding as jv,sRGBEncoding as qD}from"three";var yu=class{constructor(e){e=e!=null?e:{},this.name=e.name,this.type=e.type,this.node=e.node,this.size=e.size,this.needsUpdate=e.needsUpdate}get value(){return this.node.value}set value(e){this.node.value=e}};import{MathUtils as OD}from"three";var Pe=class{constructor(e){this.hashProperties=void 0;this.isNode=!0;this.shortcuts={};this.uuid=OD.generateUUID(),this.type=e,this.name="",this.userData={}}analyze(e,t){t=t!=null?t:{},e.analyzing=!0,this.build(e.addFlow(t.slot,t.cache,t.context),"v4"),e.clearVertexNodeCode(),e.clearFragmentNodeCode(),e.removeFlow(),e.analyzing=!1}analyzeAndFlow(e,t,r){return r=r!=null?r:{},this.analyze(e,r),this.flow(e,t,r)}flow(e,t,r){r=r!=null?r:{},e.addFlow(r.slot,r.cache,r.context);let n={result:this.build(e,t),code:e.clearNodeCode(),extra:e.context.extra};return e.removeFlow(),n}build(e,t,r){t=t!=null?t:this.getType(e,t);let n=e.getNodeData(r!=null?r:this);return e.analyzing&&this.appendDepsNode(e,n,t),e.nodes.indexOf(this)===-1&&e.nodes.push(this),this.updateFrame!==void 0&&e.updaters.indexOf(this)===-1&&e.updaters.push(this),this.generate(e,t,r)}updateFrame(e){}generateReadonly(e,t,r,n,s,l){return""}generate(e,t,r,n,s){return""}parse(e,t,r,n){}appendDepsNode(e,t,r){t.deps=(t.deps||0)+1;let n=e.getTypeLength(r);(n>(t.outputMax||0)||this.getType(e,r))&&(t.outputMax=n,t.output=r)}setName(e){this.name=e}getName(){return this.name}getType(e,t){return t==="sampler2D"||t==="samplerCube"?t:this.type}getJSONNode(e){if((e==null?void 0:e.materials)&&(e==null?void 0:e.materials[this.uuid])!==void 0)return e.materials[this.uuid]}getHash(){let e="{",t,r;for(t in this)r=this[t],r instanceof Pe&&(e+='"'+t+'":'+r.getHash()+",");if(this.hashProperties)for(let n=0;n<this.hashProperties.length;n++)t=this.hashProperties[n],r=this[t],e+='"'+t+'":"'+String(r)+'",';return e+='"id":"'+this.uuid+'"}',e}copy(e){return this.name=e.name,e.type&&(this.type=e.type),e.frameId&&(this.frameId=e.frameId),e.hashProperties&&(this.hashProperties=e.hashProperties.map(t=>t)),this.userData=JSON.parse(JSON.stringify(e.userData)),this.shortcuts=JSON.parse(JSON.stringify(e.shortcuts)),this}clone(){return new this.constructor().copy(this)}createJSONNode(e){let t=e===void 0||typeof e=="string";if(typeof this.type!="string")throw new Error("Node does not allow serialization.");let r={};return r.uuid=this.uuid,r.type=this.type,this.name!==""&&(r.name=this.name),JSON.stringify(this.userData)!=="{}"&&(r.userData=this.userData),!t&&e&&(e.nodes[this.uuid]=r),r}toJSON(e){var t;return(t=this.getJSONNode(e))!=null?t:this.createJSONNode(e)}fromJSON(e,t){return this.uuid=e.uuid,this.type=e.type,e.name&&(this.name=e.name),e.userData&&(this.userData=e.userData),this}};var Ov=class{constructor(){this.nodes={};this.keywords={}}add(e){this.nodes[e.name]=e}addKeyword(e,t,r){r=r!==void 0?r:!0,this.keywords[e]={callback:t,cache:r}}remove(e){delete this.nodes[e.name]}removeKeyword(e){delete this.keywords[e]}get(e){return this.nodes[e]}getKeyword(e,t){return this.keywords[e].callback(t)}getKeywordData(e){return this.keywords[e]}contains(e){return this.nodes[e]!==void 0}containsKeyword(e){return this.keywords[e]!==void 0}},tr=new Ov;import{Vector2 as Pv}from"three";import{MathUtils as PD}from"three";var Be=class extends Pe{constructor(e,t){super(e);this.scope="";t=t!=null?t:{},this.shared=t.shared!==void 0?t.shared:!0,this.unique=t.unique!==void 0?t.unique:!1}build(e,t,r,n){if(t=t!=null?t:this.getType(e),this.getShared(e,t)){let s=this.getUnique(e,t);s&&this.uuid===void 0&&(this.uuid=PD.generateUUID()),r=e.getUUID(r!=null?r:this.getUUID(),!s);let l=e.getNodeData(r),c=l.output||this.getType(e);if(e.analyzing)return(l.deps||0)>0||this.getLabel()?(this.appendDepsNode(e,l,t),this.generate(e,t,r)):super.build(e,t,r);if(s)return l.name=l.name||super.build(e,t,r),l.name;if(!this.getLabel()&&(!this.getShared(e,c)||e.context.ignoreCache||l.deps===1))return super.build(e,t,r);r=this.getUUID(!1);let f=this.getTemp(e,r);if(f)return e.format(f,c,t);{f=super.generate(e,t,r,l.output,n);let h=this.generate(e,c,r);return e.addNodeCode(f+" = "+h+";"),e.format(f,c,t)}}return super.build(e,t,r)}getShared(e,t){return t!=="sampler2D"&&t!=="samplerCube"&&this.shared}getUnique(e,t){return this.unique}setLabel(e){return this.label=e,this}getLabel(){return this.label}getUUID(e){let t=this.uuid;return typeof this.scope=="string"&&(t=this.scope+"-"+t),t}getTemp(e,t){t=t||this.uuid;let r=e.getVars()[t];return r?r.name:void 0}generate(e,t,r,n,s){return this.getShared(e,t)||console.error("TempNode is not shared"),r=r!=null?r:this.uuid,e.getTempVar(r,n!=null?n:this.getType(e),s,this.getLabel()).name}};var It=class extends Be{constructor(e,t){t=t!=null?t:{},t.shared=t.shared!==void 0?t.shared:!1;super(e,t);this.readonly=!1}setReadonly(e){return this.readonly=e,this.hashProperties=this.readonly?["value"]:void 0,this}getReadonly(){return this.readonly}createJSONNode(e){let t=super.createJSONNode(e);return this.readonly===!0&&(t.readonly=this.readonly),t}fromJSON(e,t){return super.fromJSON(e,t),e.readonly!==void 0&&this.setReadonly(e.readonly),this}generate(e,t,r,n,s,l){r=e.getUUID(r!=null?r:this.getUUID()),n=n!=null?n:this.getType(e);let c=e.getNodeData(r);return this.getReadonly()&&this.generateReadonly!==void 0?this.generateReadonly(e,t,r,n,s,l):e.isShader("vertex")?(c.vertex||(c.vertex=e.createVertexUniform(n,this,s,l,this.getLabel())),e.format(c.vertex.name,n,t)):(c.fragment||(c.fragment=e.createFragmentUniform(n,this,s,l,this.getLabel())),e.format(c.fragment.name,n,t))}copy(e){return super.copy(e),this.readonly=e.readonly,this}};var _r=class extends It{constructor(e=0,t){super("v2");this.nodeType="Vector2";this.value=e instanceof Pv?e:new Pv(e,t)}get x(){return this.value.x}set x(e){this.value.x=e}get y(){return this.value.y}set y(e){this.value.y=e}generateReadonly(e,t,r,n,s,l){return e.format("vec2("+this.value.x+", "+this.value.y+")",n,t)}copy(e){return super.copy(e),this.value.copy(e.value),this}};import{Vector3 as Dv}from"three";var Tr=class extends It{constructor(e=0,t,r){super("v3");this.nodeType="Vector3";this.value=e instanceof Dv?e:new Dv(e,t,r)}get x(){return this.value.x}set x(e){this.value.x=e}get y(){return this.value.y}set y(e){this.value.y=e}get z(){return this.value.z}set z(e){this.value.z=e}generateReadonly(e,t,r,n,s,l){return e.format("vec3("+this.value.x+", "+this.value.y+", "+this.value.z+")",n,t)}copy(e){return super.copy(e),this.value.copy(e.value),this}};var Xi=class extends It{constructor(e){super("v4");this.nodeType="Vector4";this.value=e instanceof tn?e:new tn(e.r,e.g,e.b,e.a)}generateReadonly(e,t,r,n,s,l){return e.format("vec4("+this.value.r+", "+this.value.g+", "+this.value.b+", "+this.value.a+")",n,t)}copy(e){return super.copy(e),this.value.copy(e.value),this}};var DD=/^\s*([a-z_0-9]+)\s([a-z_0-9]+)\s*\((.*?)\)/i,Bv=/[a-z_0-9]+/gi,Se=class extends Be{constructor(e,t,r,n,s){super(s);this.src="";this.nodeType="Function";this.useKeywords=!0;this.includes=[];this.extensions={};this.keywords={};this.isMethod=s===void 0,this.isInterface=!1,this.parse(e,t,r,n)}getShared(e,t){return!this.isMethod}getType(e){return e.getTypeByFormat(this.type)}getInputByName(e){if(this.inputs){let t=this.inputs.length;for(;t--;)if(this.inputs[t].name===e)return this.inputs[t]}}getIncludeByName(e){if(this.includes){let t=this.includes.length;for(;t--;)if(this.includes[t].name===e)return this.includes[t]}}generate(e,t,r,n,s){let l,c=0,f=this.src;if(this.includes)for(let p=0;p<this.includes.length;p++)e.include(this.includes[p],this);for(let p in this.extensions)e.extensions[p]=!0;let h=[];for(;l=Bv.exec(this.src);)h.push(l);for(let p=0;p<h.length;p++){let y=h[p],g=y[0],w=this.isMethod?!this.getInputByName(g):!0,S=g;if(this.keywords[g]||this.useKeywords&&w&&tr.containsKeyword(g)){let T=this.keywords[g];if(!T){let C=tr.getKeywordData(g);C.cache&&(T=e.keywords[g]),T=T||tr.getKeyword(g,e),C.cache&&(e.keywords[g]=T)}S=T.build(e)}g!==S&&(f=f.substring(0,y.index+c)+S+f.substring(y.index+g.length+c),c+=S.length-g.length),this.getIncludeByName(S)===void 0&&tr.contains(S)&&e.include(tr.get(S))}return t==="source"?f:this.isMethod?(this.isInterface||e.include(this,void 0,f),this.name):e.format("( "+f+" )",this.getType(e),t)}parse(e,t,r,n){if(this.src=e||"",this.includes=t!=null?t:[],this.extensions=r!=null?r:{},this.keywords=n!=null?n:{},this.isMethod){let s=DD.exec(this.src);if(this.inputs=[],s&&s.length==4){this.type=s[1],this.name=s[2];let l=s[3].match(Bv);if(l){let c=0;for(;c<l.length;){let f=l[c++],h;f==="in"||f==="out"||f==="inout"?h=l[c++]:(h=f,f="");let p=l[c++];this.inputs.push({name:p,type:h,qualifier:f})}}this.isInterface=this.src.indexOf("{")===-1}else this.type="",this.name=""}}copy(e){return super.copy(e),this.isMethod=e.isMethod,this.useKeywords=e.useKeywords,e.type!==void 0&&(this.type=e.type),this.parse(e.src,e.includes,e.extensions,e.keywords),this}toJSON(e){var r;let t=this.getJSONNode(e);if(!t){t=this.createJSONNode(e),t.src=this.src,t.isMethod=this.isMethod,t.useKeywords=this.useKeywords,this.isMethod||(t.type=this.type),t.extensions=JSON.parse(JSON.stringify(this.extensions));let n={};for(let s in this.keywords)n[s]=this.keywords[s].toJSON(e).uuid;if(t.keywords=n,(r=this.includes)==null?void 0:r.length){let s=[];for(let l=0;l<this.includes.length;l++)s.push(this.includes[l].toJSON(e).uuid);t.includes=s}t.isMethod=this.isMethod,t.inputs=this.inputs}return t.nodeType=this.nodeType,t}fromJSON(e,t){if(super.fromJSON(e,t),e.inputs!==void 0&&(this.inputs=e.inputs),e.isMethod!==void 0&&(this.isMethod=e.isMethod),e.src&&(this.src=e.src),e.isMethod&&(this.isMethod=e.isMethod),e.useKeywords&&(this.useKeywords=e.useKeywords),e.type&&(this.type=e.type),e.extensions&&(this.extensions=e.extensions),e.keywords&&t){this.keywords={};for(let r in e.keywords)this.keywords[r]=t.getNode(e.keywords[r])}return e.includes&&t&&(this.includes=e.includes.map(r=>t.getNode(r))),this}};var BD=/^([a-z_0-9]+)\s([a-z_0-9]+)\s?\=?\s?(.*?)(\;|$)/i,ld=class extends Be{constructor(e="",t){super();this.src="";this.useDefine=!1;this.nodeType="Const";this.parse(e||ld.PI,void 0,void 0,void 0,t)}getType(e){return e.getTypeByFormat(this.type)}parse(e,t,r,n,s){this.src=e||"";let l,c,f="",h=BD.exec(e);this.useDefine=s!=null?s:this.src.charAt(0)==="#",h&&h.length>1?(c=h[1],l=h[2],f=h[3]):(l=this.src,c="f"),this.name=l,this.type=c,this.value=f}build(e,t){if(t==="source"){if(this.value)return this.useDefine?"#define "+this.name+" "+this.value:"const "+this.type+" "+this.name+" = "+this.value+";";if(this.useDefine)return this.src}return e.include(this),e.format(this.name,this.getType(e),t)}generate(e,t,r,n,s){return e.format(this.name,this.getType(e),t)}copy(e){return super.copy(e),this.parse(e.src,void 0,void 0,void 0,e.useDefine),this}},it=ld;it.PI="PI",it.PI2="PI2",it.RECIPROCAL_PI="RECIPROCAL_PI",it.RECIPROCAL_PI2="RECIPROCAL_PI2",it.LOG2="LOG2",it.EPSILON="EPSILON";var GD=new RegExp(`^structs*([a-z_0-9]+)s*{s*((.|
|
|
21
|
-
)*?)}`,"gim"),
|
|
20
|
+
}`;var Je=rg(function(){return lt(v,Le+"return "+ie).apply(i,N)});if(Je.source=ie,zf(Je))throw Je;return Je}function VL(o){return ut(o).toLowerCase()}function UL(o){return ut(o).toUpperCase()}function kL(o,a,u){if(o=ut(o),o&&(u||a===i))return o.replace(tt,"");if(!o||!(a=qr(a)))return o;var p=_n(o),m=_n(a),v=pd(p,m),N=dd(p,m)+1;return Pi(p,v,N).join("")}function HL(o,a,u){if(o=ut(o),o&&(u||a===i))return o.replace(mt,"");if(!o||!(a=qr(a)))return o;var p=_n(o),m=dd(p,_n(a))+1;return Pi(p,0,m).join("")}function WL(o,a,u){if(o=ut(o),o&&(u||a===i))return o.replace(at,"");if(!o||!(a=qr(a)))return o;var p=_n(o),m=pd(p,_n(a));return Pi(p,m).join("")}function qL(o,a){var u=E,p=b;if(Dt(a)){var m="separator"in a?a.separator:m;u="length"in a?We(a.length):u,p="omission"in a?qr(a.omission):p}o=ut(o);var v=o.length;if(Eo(o)){var N=_n(o);v=N.length}if(u>=v)return o;var L=u-Ro(p);if(L<1)return p;var I=N?Pi(N,0,L).join(""):o.slice(0,L);if(m===i)return I+p;if(N&&(L+=I.length-L),Ff(m)){if(o.slice(L).search(m)){var Q,te=I;for(m.global||(m=tf(m.source,ut(Ln.exec(m))+"g")),m.lastIndex=0;Q=m.exec(te);)var ie=Q.index;I=I.slice(0,ie===i?L:ie)}}else if(o.indexOf(qr(m),L)!=L){var me=I.lastIndexOf(m);me>-1&&(I=I.slice(0,me))}return I+p}function $L(o){return o=ut(o),o&&Do.test(o)?o.replace(ro,wS):o}var JL=Ho(function(o,a,u){return o+(u?" ":"")+a.toUpperCase()}),kf=nm("toUpperCase");function tg(o,a,u){return o=ut(o),a=u?i:a,a===i?yS(o)?LS(o):lS(o):o.match(a)||[]}var rg=Ze(function(o,a){try{return Hr(o,i,a)}catch(u){return zf(u)?u:new Ue(u)}}),KL=si(function(o,a){return sn(a,function(u){u=Vn(u),ii(o,u,Ef(o[u],o))}),o});function XL(o){var a=o==null?0:o.length,u=De();return o=a?Ot(o,function(p){if(typeof p[1]!="function")throw new an(n);return[u(p[0]),p[1]]}):[],Ze(function(p){for(var m=-1;++m<a;){var v=o[m];if(Hr(v[0],this,p))return Hr(v[1],this,p)}})}function ZL(o){return ww(cn(o,f))}function Hf(o){return function(){return o}}function YL(o,a){return o==null||o!==o?a:o}var QL=om(),e_=om(!0);function Br(o){return o}function Wf(o){return Gd(typeof o=="function"?o:cn(o,f))}function t_(o){return Ed(cn(o,f))}function r_(o,a){return Rd(o,cn(a,f))}var n_=Ze(function(o,a){return function(u){return Ks(u,o,a)}}),i_=Ze(function(o,a){return function(u){return Ks(o,u,a)}});function qf(o,a,u){var p=nr(a),m=bl(a,p);u==null&&!(Dt(a)&&(m.length||!p.length))&&(u=a,a=o,o=this,m=bl(a,nr(a)));var v=!(Dt(u)&&"chain"in u)||!!u.chain,N=li(o);return sn(m,function(L){var I=a[L];o[L]=I,N&&(o.prototype[L]=function(){var Q=this.__chain__;if(v||Q){var te=o(this.__wrapped__),ie=te.__actions__=Or(this.__actions__);return ie.push({func:I,args:arguments,thisArg:o}),te.__chain__=Q,te}return I.apply(o,Li([this.value()],arguments))})}),o}function o_(){return rr._===this&&(rr._=OS),this}function $f(){}function s_(o){return o=We(o),Ze(function(a){return zd(a,o)})}var a_=Cf(Ot),l_=Cf(ld),c_=Cf(Ju);function ng(o){return Of(o)?Ku(Vn(o)):zw(o)}function u_(o){return function(a){return o==null?i:uo(o,a)}}var f_=am(),h_=am(!0);function Jf(){return[]}function Kf(){return!1}function p_(){return{}}function d_(){return""}function m_(){return!0}function g_(o,a){if(o=We(o),o<1||o>re)return[];var u=Me,p=dr(o,Me);a=De(a),o-=Me;for(var m=Yu(p,a);++u<o;)a(u);return m}function y_(o){return ke(o)?Ot(o,Vn):$r(o)?[o]:Or(Nm(ut(o)))}function x_(o){var a=++MS;return ut(o)+a}var v_=_l(function(o,a){return o+a},0),b_=Lf("ceil"),S_=_l(function(o,a){return o/a},1),w_=Lf("floor");function N_(o){return o&&o.length?vl(o,Br,uf):i}function C_(o,a){return o&&o.length?vl(o,De(a,2),uf):i}function L_(o){return fd(o,Br)}function __(o,a){return fd(o,De(a,2))}function T_(o){return o&&o.length?vl(o,Br,df):i}function I_(o,a){return o&&o.length?vl(o,De(a,2),df):i}var M_=_l(function(o,a){return o*a},1),A_=Lf("round"),O_=_l(function(o,a){return o-a},0);function P_(o){return o&&o.length?Zu(o,Br):0}function D_(o,a){return o&&o.length?Zu(o,De(a,2)):0}return y.after=tC,y.ary=Bm,y.assign=UC,y.assignIn=Jm,y.assignInWith=zl,y.assignWith=kC,y.at=HC,y.before=Gm,y.bind=Ef,y.bindAll=KL,y.bindKey=jm,y.castArray=pC,y.chain=Om,y.chunk=w1,y.compact=N1,y.concat=C1,y.cond=XL,y.conforms=ZL,y.constant=Hf,y.countBy=PN,y.create=WC,y.curry=Em,y.curryRight=Rm,y.debounce=zm,y.defaults=qC,y.defaultsDeep=$C,y.defer=rC,y.delay=nC,y.difference=L1,y.differenceBy=_1,y.differenceWith=T1,y.drop=I1,y.dropRight=M1,y.dropRightWhile=A1,y.dropWhile=O1,y.fill=P1,y.filter=BN,y.flatMap=EN,y.flatMapDeep=RN,y.flatMapDepth=zN,y.flatten=Tm,y.flattenDeep=D1,y.flattenDepth=B1,y.flip=iC,y.flow=QL,y.flowRight=e_,y.fromPairs=G1,y.functions=eL,y.functionsIn=tL,y.groupBy=FN,y.initial=E1,y.intersection=R1,y.intersectionBy=z1,y.intersectionWith=F1,y.invert=nL,y.invertBy=iL,y.invokeMap=UN,y.iteratee=Wf,y.keyBy=kN,y.keys=nr,y.keysIn=Dr,y.map=Dl,y.mapKeys=sL,y.mapValues=aL,y.matches=t_,y.matchesProperty=r_,y.memoize=Gl,y.merge=lL,y.mergeWith=Km,y.method=n_,y.methodOf=i_,y.mixin=qf,y.negate=jl,y.nthArg=s_,y.omit=cL,y.omitBy=uL,y.once=oC,y.orderBy=HN,y.over=a_,y.overArgs=sC,y.overEvery=l_,y.overSome=c_,y.partial=Rf,y.partialRight=Fm,y.partition=WN,y.pick=fL,y.pickBy=Xm,y.property=ng,y.propertyOf=u_,y.pull=H1,y.pullAll=Mm,y.pullAllBy=W1,y.pullAllWith=q1,y.pullAt=$1,y.range=f_,y.rangeRight=h_,y.rearg=aC,y.reject=JN,y.remove=J1,y.rest=lC,y.reverse=Gf,y.sampleSize=XN,y.set=pL,y.setWith=dL,y.shuffle=ZN,y.slice=K1,y.sortBy=eC,y.sortedUniq=rN,y.sortedUniqBy=nN,y.split=EL,y.spread=cC,y.tail=iN,y.take=oN,y.takeRight=sN,y.takeRightWhile=aN,y.takeWhile=lN,y.tap=NN,y.throttle=uC,y.thru=Pl,y.toArray=Wm,y.toPairs=Zm,y.toPairsIn=Ym,y.toPath=y_,y.toPlainObject=$m,y.transform=mL,y.unary=fC,y.union=cN,y.unionBy=uN,y.unionWith=fN,y.uniq=hN,y.uniqBy=pN,y.uniqWith=dN,y.unset=gL,y.unzip=jf,y.unzipWith=Am,y.update=yL,y.updateWith=xL,y.values=$o,y.valuesIn=vL,y.without=mN,y.words=tg,y.wrap=hC,y.xor=gN,y.xorBy=yN,y.xorWith=xN,y.zip=vN,y.zipObject=bN,y.zipObjectDeep=SN,y.zipWith=wN,y.entries=Zm,y.entriesIn=Ym,y.extend=Jm,y.extendWith=zl,qf(y,y),y.add=v_,y.attempt=rg,y.camelCase=NL,y.capitalize=Qm,y.ceil=b_,y.clamp=bL,y.clone=dC,y.cloneDeep=gC,y.cloneDeepWith=yC,y.cloneWith=mC,y.conformsTo=xC,y.deburr=eg,y.defaultTo=YL,y.divide=S_,y.endsWith=CL,y.eq=In,y.escape=LL,y.escapeRegExp=_L,y.every=DN,y.find=GN,y.findIndex=Lm,y.findKey=JC,y.findLast=jN,y.findLastIndex=_m,y.findLastKey=KC,y.floor=w_,y.forEach=Pm,y.forEachRight=Dm,y.forIn=XC,y.forInRight=ZC,y.forOwn=YC,y.forOwnRight=QC,y.get=Vf,y.gt=vC,y.gte=bC,y.has=rL,y.hasIn=Uf,y.head=Im,y.identity=Br,y.includes=VN,y.indexOf=j1,y.inRange=SL,y.invoke=oL,y.isArguments=po,y.isArray=ke,y.isArrayBuffer=SC,y.isArrayLike=Pr,y.isArrayLikeObject=zt,y.isBoolean=wC,y.isBuffer=Di,y.isDate=NC,y.isElement=CC,y.isEmpty=LC,y.isEqual=_C,y.isEqualWith=TC,y.isError=zf,y.isFinite=IC,y.isFunction=li,y.isInteger=Vm,y.isLength=El,y.isMap=Um,y.isMatch=MC,y.isMatchWith=AC,y.isNaN=OC,y.isNative=PC,y.isNil=BC,y.isNull=DC,y.isNumber=km,y.isObject=Dt,y.isObjectLike=Gt,y.isPlainObject=ta,y.isRegExp=Ff,y.isSafeInteger=GC,y.isSet=Hm,y.isString=Rl,y.isSymbol=$r,y.isTypedArray=qo,y.isUndefined=jC,y.isWeakMap=EC,y.isWeakSet=RC,y.join=V1,y.kebabCase=TL,y.last=fn,y.lastIndexOf=U1,y.lowerCase=IL,y.lowerFirst=ML,y.lt=zC,y.lte=FC,y.max=N_,y.maxBy=C_,y.mean=L_,y.meanBy=__,y.min=T_,y.minBy=I_,y.stubArray=Jf,y.stubFalse=Kf,y.stubObject=p_,y.stubString=d_,y.stubTrue=m_,y.multiply=M_,y.nth=k1,y.noConflict=o_,y.noop=$f,y.now=Bl,y.pad=AL,y.padEnd=OL,y.padStart=PL,y.parseInt=DL,y.random=wL,y.reduce=qN,y.reduceRight=$N,y.repeat=BL,y.replace=GL,y.result=hL,y.round=A_,y.runInContext=O,y.sample=KN,y.size=YN,y.snakeCase=jL,y.some=QN,y.sortedIndex=X1,y.sortedIndexBy=Z1,y.sortedIndexOf=Y1,y.sortedLastIndex=Q1,y.sortedLastIndexBy=eN,y.sortedLastIndexOf=tN,y.startCase=RL,y.startsWith=zL,y.subtract=O_,y.sum=P_,y.sumBy=D_,y.template=FL,y.times=g_,y.toFinite=ci,y.toInteger=We,y.toLength=qm,y.toLower=VL,y.toNumber=hn,y.toSafeInteger=VC,y.toString=ut,y.toUpper=UL,y.trim=kL,y.trimEnd=HL,y.trimStart=WL,y.truncate=qL,y.unescape=$L,y.uniqueId=x_,y.upperCase=JL,y.upperFirst=kf,y.each=Pm,y.eachRight=Dm,y.first=Im,qf(y,function(){var o={};return zn(y,function(a,u){pt.call(y.prototype,u)||(o[u]=a)}),o}(),{chain:!1}),y.VERSION=e,sn(["bind","bindKey","curry","curryRight","partial","partialRight"],function(o){y[o].placeholder=y}),sn(["drop","take"],function(o,a){rt.prototype[o]=function(u){u=u===i?1:Xt(We(u),0);var p=this.__filtered__&&!a?new rt(this):this.clone();return p.__filtered__?p.__takeCount__=dr(u,p.__takeCount__):p.__views__.push({size:dr(u,Me),type:o+(p.__dir__<0?"Right":"")}),p},rt.prototype[o+"Right"]=function(u){return this.reverse()[o](u).reverse()}}),sn(["filter","map","takeWhile"],function(o,a){var u=a+1,p=u==z||u==$;rt.prototype[o]=function(m){var v=this.clone();return v.__iteratees__.push({iteratee:De(m,3),type:u}),v.__filtered__=v.__filtered__||p,v}}),sn(["head","last"],function(o,a){var u="take"+(a?"Right":"");rt.prototype[o]=function(){return this[u](1).value()[0]}}),sn(["initial","tail"],function(o,a){var u="drop"+(a?"":"Right");rt.prototype[o]=function(){return this.__filtered__?new rt(this):this[u](1)}}),rt.prototype.compact=function(){return this.filter(Br)},rt.prototype.find=function(o){return this.filter(o).head()},rt.prototype.findLast=function(o){return this.reverse().find(o)},rt.prototype.invokeMap=Ze(function(o,a){return typeof o=="function"?new rt(this):this.map(function(u){return Ks(u,o,a)})}),rt.prototype.reject=function(o){return this.filter(jl(De(o)))},rt.prototype.slice=function(o,a){o=We(o);var u=this;return u.__filtered__&&(o>0||a<0)?new rt(u):(o<0?u=u.takeRight(-o):o&&(u=u.drop(o)),a!==i&&(a=We(a),u=a<0?u.dropRight(-a):u.take(a-o)),u)},rt.prototype.takeRightWhile=function(o){return this.reverse().takeWhile(o).reverse()},rt.prototype.toArray=function(){return this.take(Me)},zn(rt.prototype,function(o,a){var u=/^(?:filter|find|map|reject)|While$/.test(a),p=/^(?:head|last)$/.test(a),m=y[p?"take"+(a=="last"?"Right":""):a],v=p||/^find/.test(a);!m||(y.prototype[a]=function(){var N=this.__wrapped__,L=p?[1]:arguments,I=N instanceof rt,Q=L[0],te=I||ke(N),ie=function(et){var nt=m.apply(y,Li([et],L));return p&&me?nt[0]:nt};te&&u&&typeof Q=="function"&&Q.length!=1&&(I=te=!1);var me=this.__chain__,Le=!!this.__actions__.length,Re=v&&!me,Je=I&&!Le;if(!v&&te){N=Je?N:new rt(this);var je=o.apply(N,L);return je.__actions__.push({func:Pl,args:[ie],thisArg:i}),new ln(je,me)}return Re&&Je?o.apply(this,L):(je=this.thru(ie),Re?p?je.value()[0]:je.value():je)})}),sn(["pop","push","shift","sort","splice","unshift"],function(o){var a=il[o],u=/^(?:push|sort|unshift)$/.test(o)?"tap":"thru",p=/^(?:pop|shift)$/.test(o);y.prototype[o]=function(){var m=arguments;if(p&&!this.__chain__){var v=this.value();return a.apply(ke(v)?v:[],m)}return this[u](function(N){return a.apply(ke(N)?N:[],m)})}}),zn(rt.prototype,function(o,a){var u=y[a];if(u){var p=u.name+"";pt.call(Vo,p)||(Vo[p]=[]),Vo[p].push({name:a,func:u})}}),Vo[Ll(i,S).name]=[{name:"wrapper",func:i}],rt.prototype.clone=$S,rt.prototype.reverse=JS,rt.prototype.value=KS,y.prototype.at=CN,y.prototype.chain=LN,y.prototype.commit=_N,y.prototype.next=TN,y.prototype.plant=MN,y.prototype.reverse=AN,y.prototype.toJSON=y.prototype.valueOf=y.prototype.value=ON,y.prototype.first=y.prototype.head,Us&&(y.prototype[Us]=IN),y},Ti=_S();typeof define=="function"&&typeof define.amd=="object"&&define.amd?(rr._=Ti,define(function(){return Ti})):oo?((oo.exports=Ti)._=Ti,Hu._=Ti):rr._=Ti}).call(Fs)});import{FileLoader as tB,Loader as rB}from"three";function fg(i){return Array.isArray(i)?i:[i]}var k_=typeof global=="object"&&global&&global.Object===Object&&global,Fl=k_;var H_=typeof self=="object"&&self&&self.Object===Object&&self,W_=Fl||H_||Function("return this")(),qt=W_;var q_=qt.Symbol,Nr=q_;var hg=Object.prototype,$_=hg.hasOwnProperty,J_=hg.toString,na=Nr?Nr.toStringTag:void 0;function K_(i){var e=$_.call(i,na),t=i[na];try{i[na]=void 0;var r=!0}catch(s){}var n=J_.call(i);return r&&(e?i[na]=t:delete i[na]),n}var pg=K_;var X_=Object.prototype,Z_=X_.toString;function Y_(i){return Z_.call(i)}var dg=Y_;var Q_="[object Null]",eT="[object Undefined]",mg=Nr?Nr.toStringTag:void 0;function tT(i){return i==null?i===void 0?eT:Q_:mg&&mg in Object(i)?pg(i):dg(i)}var Xr=tT;function rT(i){return i!=null&&typeof i=="object"}var gr=rT;var nT="[object Symbol]";function iT(i){return typeof i=="symbol"||gr(i)&&Xr(i)==nT}var Jo=iT;function oT(i,e){for(var t=-1,r=i==null?0:i.length,n=Array(r);++t<r;)n[t]=e(i[t],t,i);return n}var Vl=oT;var sT=Array.isArray,cr=sT;var aT=1/0,gg=Nr?Nr.prototype:void 0,yg=gg?gg.toString:void 0;function xg(i){if(typeof i=="string")return i;if(cr(i))return Vl(i,xg)+"";if(Jo(i))return yg?yg.call(i):"";var e=i+"";return e=="0"&&1/i==-aT?"-0":e}var vg=xg;function lT(i){var e=typeof i;return i!=null&&(e=="object"||e=="function")}var yr=lT;function cT(i){return i}var Ul=cT;var uT="[object AsyncFunction]",fT="[object Function]",hT="[object GeneratorFunction]",pT="[object Proxy]";function dT(i){if(!yr(i))return!1;var e=Xr(i);return e==fT||e==hT||e==uT||e==pT}var Ko=dT;var mT=qt["__core-js_shared__"],kl=mT;var bg=function(){var i=/[^.]+$/.exec(kl&&kl.keys&&kl.keys.IE_PROTO||"");return i?"Symbol(src)_1."+i:""}();function gT(i){return!!bg&&bg in i}var Sg=gT;var yT=Function.prototype,xT=yT.toString;function vT(i){if(i!=null){try{return xT.call(i)}catch(e){}try{return i+""}catch(e){}}return""}var fi=vT;var bT=/[\\^$.*+?()[\]{}|]/g,ST=/^\[object .+?Constructor\]$/,wT=Function.prototype,NT=Object.prototype,CT=wT.toString,LT=NT.hasOwnProperty,_T=RegExp("^"+CT.call(LT).replace(bT,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function TT(i){if(!yr(i)||Sg(i))return!1;var e=Ko(i)?_T:ST;return e.test(fi(i))}var wg=TT;function IT(i,e){return i==null?void 0:i[e]}var Ng=IT;function MT(i,e){var t=Ng(i,e);return wg(t)?t:void 0}var Gr=MT;var AT=Gr(qt,"WeakMap"),Hl=AT;var Cg=Object.create,OT=function(){function i(){}return function(e){if(!yr(e))return{};if(Cg)return Cg(e);i.prototype=e;var t=new i;return i.prototype=void 0,t}}(),Lg=OT;function PT(i,e,t){switch(t.length){case 0:return i.call(e);case 1:return i.call(e,t[0]);case 2:return i.call(e,t[0],t[1]);case 3:return i.call(e,t[0],t[1],t[2])}return i.apply(e,t)}var _g=PT;function DT(i,e){var t=-1,r=i.length;for(e||(e=Array(r));++t<r;)e[t]=i[t];return e}var Wl=DT;var BT=800,GT=16,jT=Date.now;function ET(i){var e=0,t=0;return function(){var r=jT(),n=GT-(r-t);if(t=r,n>0){if(++e>=BT)return arguments[0]}else e=0;return i.apply(void 0,arguments)}}var Tg=ET;function RT(i){return function(){return i}}var Ig=RT;var zT=function(){try{var i=Gr(Object,"defineProperty");return i({},"",{}),i}catch(e){}}(),Xo=zT;var FT=Xo?function(i,e){return Xo(i,"toString",{configurable:!0,enumerable:!1,value:Ig(e),writable:!0})}:Ul,Mg=FT;var VT=Tg(Mg),ql=VT;function UT(i,e){for(var t=-1,r=i==null?0:i.length;++t<r&&e(i[t],t,i)!==!1;);return i}var Ag=UT;var kT=9007199254740991,HT=/^(?:0|[1-9]\d*)$/;function WT(i,e){var t=typeof i;return e=e==null?kT:e,!!e&&(t=="number"||t!="symbol"&&HT.test(i))&&i>-1&&i%1==0&&i<e}var $l=WT;function qT(i,e,t){e=="__proto__"&&Xo?Xo(i,e,{configurable:!0,enumerable:!0,value:t,writable:!0}):i[e]=t}var Zo=qT;function $T(i,e){return i===e||i!==i&&e!==e}var Bi=$T;var JT=Object.prototype,KT=JT.hasOwnProperty;function XT(i,e,t){var r=i[e];(!(KT.call(i,e)&&Bi(r,t))||t===void 0&&!(e in i))&&Zo(i,e,t)}var Jl=XT;function ZT(i,e,t,r){var n=!t;t||(t={});for(var s=-1,l=e.length;++s<l;){var c=e[s],f=r?r(t[c],i[c],c,t,i):void 0;f===void 0&&(f=i[c]),n?Zo(t,c,f):Jl(t,c,f)}return t}var pn=ZT;var Og=Math.max;function YT(i,e,t){return e=Og(e===void 0?i.length-1:e,0),function(){for(var r=arguments,n=-1,s=Og(r.length-e,0),l=Array(s);++n<s;)l[n]=r[e+n];n=-1;for(var c=Array(e+1);++n<e;)c[n]=r[n];return c[e]=t(l),_g(i,this,c)}}var Kl=YT;function QT(i,e){return ql(Kl(i,e,Ul),i+"")}var Pg=QT;var eI=9007199254740991;function tI(i){return typeof i=="number"&&i>-1&&i%1==0&&i<=eI}var Xl=tI;function rI(i){return i!=null&&Xl(i.length)&&!Ko(i)}var Gi=rI;function nI(i,e,t){if(!yr(t))return!1;var r=typeof e;return(r=="number"?Gi(t)&&$l(e,t.length):r=="string"&&e in t)?Bi(t[e],i):!1}var Dg=nI;function iI(i){return Pg(function(e,t){var r=-1,n=t.length,s=n>1?t[n-1]:void 0,l=n>2?t[2]:void 0;for(s=i.length>3&&typeof s=="function"?(n--,s):void 0,l&&Dg(t[0],t[1],l)&&(s=n<3?void 0:s,n=1),e=Object(e);++r<n;){var c=t[r];c&&i(e,c,r,s)}return e})}var Bg=iI;var oI=Object.prototype;function sI(i){var e=i&&i.constructor,t=typeof e=="function"&&e.prototype||oI;return i===t}var Yo=sI;function aI(i,e){for(var t=-1,r=Array(i);++t<i;)r[t]=e(t);return r}var Gg=aI;var lI="[object Arguments]";function cI(i){return gr(i)&&Xr(i)==lI}var Xf=cI;var jg=Object.prototype,uI=jg.hasOwnProperty,fI=jg.propertyIsEnumerable,hI=Xf(function(){return arguments}())?Xf:function(i){return gr(i)&&uI.call(i,"callee")&&!fI.call(i,"callee")},mo=hI;function pI(){return!1}var Eg=pI;var Rg=typeof exports=="object"&&exports&&!exports.nodeType&&exports,zg=Rg&&typeof module=="object"&&module&&!module.nodeType&&module,dI=zg&&zg.exports===Rg,Fg=dI?qt.Buffer:void 0,mI=Fg?Fg.isBuffer:void 0,gI=mI||Eg,Qo=gI;var yI="[object Arguments]",xI="[object Array]",vI="[object Boolean]",bI="[object Date]",SI="[object Error]",wI="[object Function]",NI="[object Map]",CI="[object Number]",LI="[object Object]",_I="[object RegExp]",TI="[object Set]",II="[object String]",MI="[object WeakMap]",AI="[object ArrayBuffer]",OI="[object DataView]",PI="[object Float32Array]",DI="[object Float64Array]",BI="[object Int8Array]",GI="[object Int16Array]",jI="[object Int32Array]",EI="[object Uint8Array]",RI="[object Uint8ClampedArray]",zI="[object Uint16Array]",FI="[object Uint32Array]",Tt={};Tt[PI]=Tt[DI]=Tt[BI]=Tt[GI]=Tt[jI]=Tt[EI]=Tt[RI]=Tt[zI]=Tt[FI]=!0;Tt[yI]=Tt[xI]=Tt[AI]=Tt[vI]=Tt[OI]=Tt[bI]=Tt[SI]=Tt[wI]=Tt[NI]=Tt[CI]=Tt[LI]=Tt[_I]=Tt[TI]=Tt[II]=Tt[MI]=!1;function VI(i){return gr(i)&&Xl(i.length)&&!!Tt[Xr(i)]}var Vg=VI;function UI(i){return function(e){return i(e)}}var es=UI;var Ug=typeof exports=="object"&&exports&&!exports.nodeType&&exports,ia=Ug&&typeof module=="object"&&module&&!module.nodeType&&module,kI=ia&&ia.exports===Ug,Zf=kI&&Fl.process,HI=function(){try{var i=ia&&ia.require&&ia.require("util").types;return i||Zf&&Zf.binding&&Zf.binding("util")}catch(e){}}(),hi=HI;var kg=hi&&hi.isTypedArray,WI=kg?es(kg):Vg,Zl=WI;var qI=Object.prototype,$I=qI.hasOwnProperty;function JI(i,e){var t=cr(i),r=!t&&mo(i),n=!t&&!r&&Qo(i),s=!t&&!r&&!n&&Zl(i),l=t||r||n||s,c=l?Gg(i.length,String):[],f=c.length;for(var h in i)(e||$I.call(i,h))&&!(l&&(h=="length"||n&&(h=="offset"||h=="parent")||s&&(h=="buffer"||h=="byteLength"||h=="byteOffset")||$l(h,f)))&&c.push(h);return c}var Yl=JI;function KI(i,e){return function(t){return i(e(t))}}var Ql=KI;var XI=Ql(Object.keys,Object),Hg=XI;var ZI=Object.prototype,YI=ZI.hasOwnProperty;function QI(i){if(!Yo(i))return Hg(i);var e=[];for(var t in Object(i))YI.call(i,t)&&t!="constructor"&&e.push(t);return e}var Wg=QI;function eM(i){return Gi(i)?Yl(i):Wg(i)}var ts=eM;function tM(i){var e=[];if(i!=null)for(var t in Object(i))e.push(t);return e}var qg=tM;var rM=Object.prototype,nM=rM.hasOwnProperty;function iM(i){if(!yr(i))return qg(i);var e=Yo(i),t=[];for(var r in i)r=="constructor"&&(e||!nM.call(i,r))||t.push(r);return t}var $g=iM;function oM(i){return Gi(i)?Yl(i,!0):$g(i)}var Un=oM;var sM=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,aM=/^\w*$/;function lM(i,e){if(cr(i))return!1;var t=typeof i;return t=="number"||t=="symbol"||t=="boolean"||i==null||Jo(i)?!0:aM.test(i)||!sM.test(i)||e!=null&&i in Object(e)}var Jg=lM;var cM=Gr(Object,"create"),pi=cM;function uM(){this.__data__=pi?pi(null):{},this.size=0}var Kg=uM;function fM(i){var e=this.has(i)&&delete this.__data__[i];return this.size-=e?1:0,e}var Xg=fM;var hM="__lodash_hash_undefined__",pM=Object.prototype,dM=pM.hasOwnProperty;function mM(i){var e=this.__data__;if(pi){var t=e[i];return t===hM?void 0:t}return dM.call(e,i)?e[i]:void 0}var Zg=mM;var gM=Object.prototype,yM=gM.hasOwnProperty;function xM(i){var e=this.__data__;return pi?e[i]!==void 0:yM.call(e,i)}var Yg=xM;var vM="__lodash_hash_undefined__";function bM(i,e){var t=this.__data__;return this.size+=this.has(i)?0:1,t[i]=pi&&e===void 0?vM:e,this}var Qg=bM;function rs(i){var e=-1,t=i==null?0:i.length;for(this.clear();++e<t;){var r=i[e];this.set(r[0],r[1])}}rs.prototype.clear=Kg;rs.prototype.delete=Xg;rs.prototype.get=Zg;rs.prototype.has=Yg;rs.prototype.set=Qg;var Yf=rs;function SM(){this.__data__=[],this.size=0}var ey=SM;function wM(i,e){for(var t=i.length;t--;)if(Bi(i[t][0],e))return t;return-1}var ji=wM;var NM=Array.prototype,CM=NM.splice;function LM(i){var e=this.__data__,t=ji(e,i);if(t<0)return!1;var r=e.length-1;return t==r?e.pop():CM.call(e,t,1),--this.size,!0}var ty=LM;function _M(i){var e=this.__data__,t=ji(e,i);return t<0?void 0:e[t][1]}var ry=_M;function TM(i){return ji(this.__data__,i)>-1}var ny=TM;function IM(i,e){var t=this.__data__,r=ji(t,i);return r<0?(++this.size,t.push([i,e])):t[r][1]=e,this}var iy=IM;function ns(i){var e=-1,t=i==null?0:i.length;for(this.clear();++e<t;){var r=i[e];this.set(r[0],r[1])}}ns.prototype.clear=ey;ns.prototype.delete=ty;ns.prototype.get=ry;ns.prototype.has=ny;ns.prototype.set=iy;var Ei=ns;var MM=Gr(qt,"Map"),Ri=MM;function AM(){this.size=0,this.__data__={hash:new Yf,map:new(Ri||Ei),string:new Yf}}var oy=AM;function OM(i){var e=typeof i;return e=="string"||e=="number"||e=="symbol"||e=="boolean"?i!=="__proto__":i===null}var sy=OM;function PM(i,e){var t=i.__data__;return sy(e)?t[typeof e=="string"?"string":"hash"]:t.map}var zi=PM;function DM(i){var e=zi(this,i).delete(i);return this.size-=e?1:0,e}var ay=DM;function BM(i){return zi(this,i).get(i)}var ly=BM;function GM(i){return zi(this,i).has(i)}var cy=GM;function jM(i,e){var t=zi(this,i),r=t.size;return t.set(i,e),this.size+=t.size==r?0:1,this}var uy=jM;function is(i){var e=-1,t=i==null?0:i.length;for(this.clear();++e<t;){var r=i[e];this.set(r[0],r[1])}}is.prototype.clear=oy;is.prototype.delete=ay;is.prototype.get=ly;is.prototype.has=cy;is.prototype.set=uy;var oa=is;var EM="Expected a function";function Qf(i,e){if(typeof i!="function"||e!=null&&typeof e!="function")throw new TypeError(EM);var t=function(){var r=arguments,n=e?e.apply(this,r):r[0],s=t.cache;if(s.has(n))return s.get(n);var l=i.apply(this,r);return t.cache=s.set(n,l)||s,l};return t.cache=new(Qf.Cache||oa),t}Qf.Cache=oa;var fy=Qf;var RM=500;function zM(i){var e=fy(i,function(r){return t.size===RM&&t.clear(),r}),t=e.cache;return e}var hy=zM;var FM=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,VM=/\\(\\)?/g,UM=hy(function(i){var e=[];return i.charCodeAt(0)===46&&e.push(""),i.replace(FM,function(t,r,n,s){e.push(n?s.replace(VM,"$1"):r||t)}),e}),py=UM;function kM(i){return i==null?"":vg(i)}var dy=kM;function HM(i,e){return cr(i)?i:Jg(i,e)?[i]:py(dy(i))}var os=HM;var WM=1/0;function qM(i){if(typeof i=="string"||Jo(i))return i;var e=i+"";return e=="0"&&1/i==-WM?"-0":e}var ec=qM;function $M(i,e){e=os(e,i);for(var t=0,r=e.length;i!=null&&t<r;)i=i[ec(e[t++])];return t&&t==r?i:void 0}var my=$M;function JM(i,e){for(var t=-1,r=e.length,n=i.length;++t<r;)i[n+t]=e[t];return i}var ss=JM;var gy=Nr?Nr.isConcatSpreadable:void 0;function KM(i){return cr(i)||mo(i)||!!(gy&&i&&i[gy])}var yy=KM;function xy(i,e,t,r,n){var s=-1,l=i.length;for(t||(t=yy),n||(n=[]);++s<l;){var c=i[s];e>0&&t(c)?e>1?xy(c,e-1,t,r,n):ss(n,c):r||(n[n.length]=c)}return n}var vy=xy;function XM(i){var e=i==null?0:i.length;return e?vy(i,1):[]}var by=XM;function ZM(i){return ql(Kl(i,void 0,by),i+"")}var Sy=ZM;var YM=Ql(Object.getPrototypeOf,Object),as=YM;var QM="[object Object]",eA=Function.prototype,tA=Object.prototype,wy=eA.toString,rA=tA.hasOwnProperty,nA=wy.call(Object);function iA(i){if(!gr(i)||Xr(i)!=QM)return!1;var e=as(i);if(e===null)return!0;var t=rA.call(e,"constructor")&&e.constructor;return typeof t=="function"&&t instanceof t&&wy.call(t)==nA}var tc=iA;function oA(i,e,t){var r=-1,n=i.length;e<0&&(e=-e>n?0:n+e),t=t>n?n:t,t<0&&(t+=n),n=e>t?0:t-e>>>0,e>>>=0;for(var s=Array(n);++r<n;)s[r]=i[r+e];return s}var Ny=oA;function sA(){this.__data__=new Ei,this.size=0}var Cy=sA;function aA(i){var e=this.__data__,t=e.delete(i);return this.size=e.size,t}var Ly=aA;function lA(i){return this.__data__.get(i)}var _y=lA;function cA(i){return this.__data__.has(i)}var Ty=cA;var uA=200;function fA(i,e){var t=this.__data__;if(t instanceof Ei){var r=t.__data__;if(!Ri||r.length<uA-1)return r.push([i,e]),this.size=++t.size,this;t=this.__data__=new oa(r)}return t.set(i,e),this.size=t.size,this}var Iy=fA;function ls(i){var e=this.__data__=new Ei(i);this.size=e.size}ls.prototype.clear=Cy;ls.prototype.delete=Ly;ls.prototype.get=_y;ls.prototype.has=Ty;ls.prototype.set=Iy;var rc=ls;function hA(i,e){return i&&pn(e,ts(e),i)}var My=hA;function pA(i,e){return i&&pn(e,Un(e),i)}var Ay=pA;var Oy=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Py=Oy&&typeof module=="object"&&module&&!module.nodeType&&module,dA=Py&&Py.exports===Oy,Dy=dA?qt.Buffer:void 0,By=Dy?Dy.allocUnsafe:void 0;function mA(i,e){if(e)return i.slice();var t=i.length,r=By?By(t):new i.constructor(t);return i.copy(r),r}var nc=mA;function gA(i,e){for(var t=-1,r=i==null?0:i.length,n=0,s=[];++t<r;){var l=i[t];e(l,t,i)&&(s[n++]=l)}return s}var Gy=gA;function yA(){return[]}var ic=yA;var xA=Object.prototype,vA=xA.propertyIsEnumerable,jy=Object.getOwnPropertySymbols,bA=jy?function(i){return i==null?[]:(i=Object(i),Gy(jy(i),function(e){return vA.call(i,e)}))}:ic,cs=bA;function SA(i,e){return pn(i,cs(i),e)}var Ey=SA;var wA=Object.getOwnPropertySymbols,NA=wA?function(i){for(var e=[];i;)ss(e,cs(i)),i=as(i);return e}:ic,oc=NA;function CA(i,e){return pn(i,oc(i),e)}var Ry=CA;function LA(i,e,t){var r=e(i);return cr(i)?r:ss(r,t(i))}var sc=LA;function _A(i){return sc(i,ts,cs)}var zy=_A;function TA(i){return sc(i,Un,oc)}var ac=TA;var IA=Gr(qt,"DataView"),lc=IA;var MA=Gr(qt,"Promise"),cc=MA;var AA=Gr(qt,"Set"),uc=AA;var Fy="[object Map]",OA="[object Object]",Vy="[object Promise]",Uy="[object Set]",ky="[object WeakMap]",Hy="[object DataView]",PA=fi(lc),DA=fi(Ri),BA=fi(cc),GA=fi(uc),jA=fi(Hl),go=Xr;(lc&&go(new lc(new ArrayBuffer(1)))!=Hy||Ri&&go(new Ri)!=Fy||cc&&go(cc.resolve())!=Vy||uc&&go(new uc)!=Uy||Hl&&go(new Hl)!=ky)&&(go=function(i){var e=Xr(i),t=e==OA?i.constructor:void 0,r=t?fi(t):"";if(r)switch(r){case PA:return Hy;case DA:return Fy;case BA:return Vy;case GA:return Uy;case jA:return ky}return e});var us=go;var EA=Object.prototype,RA=EA.hasOwnProperty;function zA(i){var e=i.length,t=new i.constructor(e);return e&&typeof i[0]=="string"&&RA.call(i,"index")&&(t.index=i.index,t.input=i.input),t}var Wy=zA;var FA=qt.Uint8Array,eh=FA;function VA(i){var e=new i.constructor(i.byteLength);return new eh(e).set(new eh(i)),e}var fs=VA;function UA(i,e){var t=e?fs(i.buffer):i.buffer;return new i.constructor(t,i.byteOffset,i.byteLength)}var qy=UA;var kA=/\w*$/;function HA(i){var e=new i.constructor(i.source,kA.exec(i));return e.lastIndex=i.lastIndex,e}var $y=HA;var Jy=Nr?Nr.prototype:void 0,Ky=Jy?Jy.valueOf:void 0;function WA(i){return Ky?Object(Ky.call(i)):{}}var Xy=WA;function qA(i,e){var t=e?fs(i.buffer):i.buffer;return new i.constructor(t,i.byteOffset,i.length)}var fc=qA;var $A="[object Boolean]",JA="[object Date]",KA="[object Map]",XA="[object Number]",ZA="[object RegExp]",YA="[object Set]",QA="[object String]",eO="[object Symbol]",tO="[object ArrayBuffer]",rO="[object DataView]",nO="[object Float32Array]",iO="[object Float64Array]",oO="[object Int8Array]",sO="[object Int16Array]",aO="[object Int32Array]",lO="[object Uint8Array]",cO="[object Uint8ClampedArray]",uO="[object Uint16Array]",fO="[object Uint32Array]";function hO(i,e,t){var r=i.constructor;switch(e){case tO:return fs(i);case $A:case JA:return new r(+i);case rO:return qy(i,t);case nO:case iO:case oO:case sO:case aO:case lO:case cO:case uO:case fO:return fc(i,t);case KA:return new r;case XA:case QA:return new r(i);case ZA:return $y(i);case YA:return new r;case eO:return Xy(i)}}var Zy=hO;function pO(i){return typeof i.constructor=="function"&&!Yo(i)?Lg(as(i)):{}}var hc=pO;var dO="[object Map]";function mO(i){return gr(i)&&us(i)==dO}var Yy=mO;var Qy=hi&&hi.isMap,gO=Qy?es(Qy):Yy,ex=gO;var yO="[object Set]";function xO(i){return gr(i)&&us(i)==yO}var tx=xO;var rx=hi&&hi.isSet,vO=rx?es(rx):tx,nx=vO;var bO=1,SO=2,wO=4,ix="[object Arguments]",NO="[object Array]",CO="[object Boolean]",LO="[object Date]",_O="[object Error]",ox="[object Function]",TO="[object GeneratorFunction]",IO="[object Map]",MO="[object Number]",sx="[object Object]",AO="[object RegExp]",OO="[object Set]",PO="[object String]",DO="[object Symbol]",BO="[object WeakMap]",GO="[object ArrayBuffer]",jO="[object DataView]",EO="[object Float32Array]",RO="[object Float64Array]",zO="[object Int8Array]",FO="[object Int16Array]",VO="[object Int32Array]",UO="[object Uint8Array]",kO="[object Uint8ClampedArray]",HO="[object Uint16Array]",WO="[object Uint32Array]",Nt={};Nt[ix]=Nt[NO]=Nt[GO]=Nt[jO]=Nt[CO]=Nt[LO]=Nt[EO]=Nt[RO]=Nt[zO]=Nt[FO]=Nt[VO]=Nt[IO]=Nt[MO]=Nt[sx]=Nt[AO]=Nt[OO]=Nt[PO]=Nt[DO]=Nt[UO]=Nt[kO]=Nt[HO]=Nt[WO]=!0;Nt[_O]=Nt[ox]=Nt[BO]=!1;function pc(i,e,t,r,n,s){var l,c=e&bO,f=e&SO,h=e&wO;if(t&&(l=n?t(i,r,n,s):t(i)),l!==void 0)return l;if(!yr(i))return i;var d=cr(i);if(d){if(l=Wy(i),!c)return Wl(i,l)}else{var x=us(i),g=x==ox||x==TO;if(Qo(i))return nc(i,c);if(x==sx||x==ix||g&&!n){if(l=f||g?{}:hc(i),!c)return f?Ry(i,Ay(l,i)):Ey(i,My(l,i))}else{if(!Nt[x])return n?i:{};l=Zy(i,x,c)}}s||(s=new rc);var w=s.get(i);if(w)return w;s.set(i,l),nx(i)?i.forEach(function(C){l.add(pc(C,e,t,C,i,s))}):ex(i)&&i.forEach(function(C,G){l.set(G,pc(C,e,t,G,i,s))});var S=h?f?ac:zy:f?Un:ts,D=d?void 0:S(i);return Ag(D||i,function(C,G){D&&(G=C,C=i[G]),Jl(l,G,pc(C,e,t,G,i,s))}),l}var dc=pc;var qO=1,$O=4;function JO(i){return dc(i,qO|$O)}var sa=JO;function KO(i){return function(e,t,r){for(var n=-1,s=Object(e),l=r(e),c=l.length;c--;){var f=l[i?c:++n];if(t(s[f],f,s)===!1)break}return e}}var ax=KO;var XO=ax(),lx=XO;function ZO(i,e,t){(t!==void 0&&!Bi(i[e],t)||t===void 0&&!(e in i))&&Zo(i,e,t)}var aa=ZO;function YO(i){return gr(i)&&Gi(i)}var cx=YO;function QO(i,e){if(!(e==="constructor"&&typeof i[e]=="function")&&e!="__proto__")return i[e]}var la=QO;function eP(i){return pn(i,Un(i))}var ux=eP;function tP(i,e,t,r,n,s,l){var c=la(i,t),f=la(e,t),h=l.get(f);if(h){aa(i,t,h);return}var d=s?s(c,f,t+"",i,e,l):void 0,x=d===void 0;if(x){var g=cr(f),w=!g&&Qo(f),S=!g&&!w&&Zl(f);d=f,g||w||S?cr(c)?d=c:cx(c)?d=Wl(c):w?(x=!1,d=nc(f,!0)):S?(x=!1,d=fc(f,!0)):d=[]:tc(f)||mo(f)?(d=c,mo(c)?d=ux(c):(!yr(c)||Ko(c))&&(d=hc(f))):x=!1}x&&(l.set(f,d),n(d,f,r,s,l),l.delete(f)),aa(i,t,d)}var fx=tP;function hx(i,e,t,r,n){i!==e&&lx(e,function(s,l){if(n||(n=new rc),yr(s))fx(i,e,l,t,hx,r,n);else{var c=r?r(la(i,l),s,l+"",i,e,n):void 0;c===void 0&&(c=s),aa(i,l,c)}},Un)}var px=hx;function rP(i){var e=i==null?0:i.length;return e?i[e-1]:void 0}var dx=rP;function nP(i,e){return e.length<2?i:my(i,Ny(e,0,-1))}var mx=nP;var iP=Bg(function(i,e,t){px(i,e,t)}),yo=iP;function oP(i,e){return e=os(e,i),i=mx(i,e),i==null||delete i[ec(dx(e))]}var gx=oP;function sP(i){return tc(i)?void 0:i}var yx=sP;var aP=1,lP=2,cP=4,uP=Sy(function(i,e){var t={};if(i==null)return t;var r=!1;e=Vl(e,function(s){return s=os(s,i),r||(r=s.length>1),s}),pn(i,ac(i),t),r&&(t=dc(t,aP|lP|cP,yx));for(var n=e.length;n--;)gx(t,e[n]);return t}),hs=uP;var ps;(function(t){t.all=["PerspectiveCamera","OrthographicCamera"];function e(r){return t.all.includes(r)}t.is=e})(ps||(ps={}));var xo;(function(n){n.DefaultUp=[0,1,0],n.DefaultTargetOffset=1e3,n.defaultData={far:1e5,type:"OrthographicCamera",perspective:{near:5,fov:45,zoom:1},orthographic:{near:-1e5,zoom:1},up:n.DefaultUp,isUpVectorFlipped:!1,targetOffset:n.DefaultTargetOffset};function r(s){return s.type==="PerspectiveCamera"?s.perspective.zoom:s.orthographic.zoom}n.getZoom=r})(xo||(xo={}));var ds;(function(r){r.x="x",r.y="y",r.z="z"})(ds||(ds={}));var xx;(function(s){s.Top="top",s.Right="right",s.Bottom="bottom",s.Left="left",s.Center="center"})(xx||(xx={}));var vx;(function(t){function i(r,n){return r[0]===n[0]&&r[1]===n[1]}t.isEqual=i;function e(r,n,s){return[r[0]+(n[0]-r[0])*s,r[1]+(n[1]-r[1])*s]}t.lerp=e})(vx||(vx={}));var ms;(function(n){function i(s,l){return s[0]===l[0]&&s[1]===l[1]&&s[2]===l[2]}n.isEqual=i;function e(s,l){return[s[0]+l[0],s[1]+l[1],s[2]+l[2]]}n.add=e;function t(s,l){return[s[0]-l[0],s[1]-l[1],s[2]-l[2]]}n.sub=t;function r(s,l,c){return[s[0]+(l[0]-s[0])*c,s[1]+(l[1]-s[1])*c,s[2]+(l[2]-s[2])*c]}n.lerp=r})(ms||(ms={}));var bx;(function(t){function i(r,n){return r[0]===n[0]&&r[1]===n[1]&&r[2]===n[2]&&r[3]===n[3]}t.isEqual=i;function e(r,n,s){return[r[0]+(n[0]-r[0])*s,r[1]+(n[1]-r[1])*s,r[2]+(n[2]-r[2])*s,r[3]+(n[3]-r[3])*s]}t.lerp=e})(bx||(bx={}));var Fi;(function(s){s.identity=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1];function e(l,c){for(let f=0;f<16;f++)if(l[f]!==c[f])return!1;return!0}s.isEqual=e;function t(l){return l!=null?l:s.identity}s.simplify=t;function r(l,c){let f=c.slice(0);for(var h=0,d=c.length;h<d;h+=3){let x=1/(l[3]*c[h]+l[7]*c[h+1]+l[11]*c[h+2]+l[15]);f[h]=(l[0]*c[h]+l[4]*c[h+1]+l[8]*c[h+2]+l[12])*x,f[h+1]=(l[1]*c[h]+l[5]*c[h+1]+l[9]*c[h+2]+l[13])*x,f[h+2]=(l[2]*c[h]+l[6]*c[h+1]+l[10]*c[h+2]+l[14])*x}return f}s.applyMatrix4=r;function n(l,c){let f=c.slice(0);for(var h=0,d=c.length;h<d;h+=3)f[h]=l[0]*c[h]+l[4]*c[h+1]+l[8]*c[h+2],f[h+1]=l[1]*c[h]+l[5]*c[h+1]+l[9]*c[h+2],f[h+2]=l[2]*c[h]+l[6]*c[h+1]+l[10]*c[h+2];return f}s.applyMatrix3Components=n})(Fi||(Fi={}));var Zr;(function(f){f.white={r:1,g:1,b:1},f.red={r:1,g:0,b:0},f.black={r:0,g:0,b:0};function r(h){return{r:Math.round(h.r*255),g:Math.round(h.g*255),b:Math.round(h.b*255),a:1}}f.toRgb255a1=r;function n(h){return{r:h.r,g:h.g,b:h.b}}f.clone=n;function s(h){return h=Math.floor(h),{r:(h>>16&255)/255,g:(h>>8&255)/255,b:(h&255)/255}}f.fromHex=s;function l(h,d){return h.r===d.r&&h.g===d.g&&h.b===d.b}f.equals=l;function c(h,d,x){return{r:h.r+(d.r-h.r)*x,g:h.g+(d.g-h.g)*x,b:h.b+(d.b-h.b)*x}}f.lerp=c})(Zr||(Zr={}));var kn;(function(l){l.white=fe(U({},Zr.white),{a:1});function e(c){return{r:c[0],g:c[1],b:c[2],a:c[3]}}l.from0to1=e;function t(c,f){return fe(U({},Zr.fromHex(c)),{a:f})}l.fromHexAndA=t;function r(c){return{r:Math.round(c.r*255),g:Math.round(c.g*255),b:Math.round(c.b*255),a:c.a}}l.toRgb255a1=r;function n(c,f){return Zr.equals(c,f)&&c.a===f.a}l.equals=n;function s(c,f,h){return{r:c.r+(f.r-c.r)*h,g:c.g+(f.g-c.g)*h,b:c.b+(f.b-c.b)*h,a:c.a+(f.a-c.a)*h}}l.lerp=s})(kn||(kn={}));var mc;(function(e){e.identity={position:[0,0,0],rotation:[0,0,0],scale:[1,1,1]}})(mc||(mc={}));var Sx;(function(P){P[P.SKIP=0]="SKIP",P[P.ADD=1]="ADD",P[P.ALPHA=2]="ALPHA",P[P.AVERAGE=3]="AVERAGE",P[P.COLOR_BURN=4]="COLOR_BURN",P[P.COLOR_DODGE=5]="COLOR_DODGE",P[P.DARKEN=6]="DARKEN",P[P.DIFFERENCE=7]="DIFFERENCE",P[P.EXCLUSION=8]="EXCLUSION",P[P.LIGHTEN=9]="LIGHTEN",P[P.MULTIPLY=10]="MULTIPLY",P[P.DIVIDE=11]="DIVIDE",P[P.NEGATION=12]="NEGATION",P[P.NORMAL=13]="NORMAL",P[P.OVERLAY=14]="OVERLAY",P[P.REFLECT=15]="REFLECT",P[P.SCREEN=16]="SCREEN",P[P.SOFT_LIGHT=17]="SOFT_LIGHT",P[P.SUBTRACT=18]="SUBTRACT"})(Sx||(Sx={}));var wx;(function(c){c[c.LINEAR=0]="LINEAR",c[c.EASE=1]="EASE",c[c.EASE_IN=2]="EASE_IN",c[c.EASE_OUT=3]="EASE_OUT",c[c.EASE_IN_OUT=4]="EASE_IN_OUT",c[c.CUBIC=5]="CUBIC",c[c.SPRING=6]="SPRING"})(wx||(wx={}));var Nx;(function(e){e.defaultData={mass:1,stiffness:80,damping:10,velocity:0}})(Nx||(Nx={}));var Cx;(function(e){e.defaultData={control1:[.5,.05],control2:[.1,.3]}})(Cx||(Cx={}));var gc;(function(e){function i(t,r=.1){return{type:"radial",hideBase:!1,count:3,radial:{radius:Math.max(t[0],t[1])*2,start:0,end:360,alignment:!1,axis:ds.y,scale:[1,1,1],rotation:[0,0,0],position:[0,0,0]},linear:{scale:[1,1,1],rotation:[0,0,0],position:[t[0]+t[0]*r,0,0]},grid:{count:[2,2,2],size:t.map(n=>n*(1+r)),useCenter:!0}}}e.defaultData=i})(gc||(gc={}));var Hn;(function(e){e[e.Update=0]="Update"})(Hn||(Hn={}));var dn;(function(r){r[r.Add=1]="Add",r[r.Delete=2]="Delete",r[r.Unlink=3]="Unlink"})(dn||(dn={}));var Yr;(function(r){r[r.Add=4]="Add",r[r.Delete=5]="Delete",r[r.Move=6]="Move"})(Yr||(Yr={}));var jr;(function(r){r[r.Add=7]="Add",r[r.Delete=8]="Delete",r[r.Move=9]="Move"})(jr||(jr={}));var An=class{modifyById(e,t){let r=this;if(r[e]===void 0)throw new Error("not expected");{let s=fe(U({},r),{[e]:t});return Object.setPrototypeOf(s,An.prototype),s}}add(e,t){var n;let r=this.runOp({type:dn.Add,id:e,data:t});return(n=r==null?void 0:r.data)!=null?n:this}runOp(e){let t=this;if(e.type===dn.Add){let r=t[e.id],n;r===void 0?n={type:dn.Delete,id:e.id}:n={type:dn.Add,id:e.id,data:r};let{id:s,data:l}=e,c=fe(U({},t),{[s]:l});return Object.setPrototypeOf(c,An.prototype),{data:c,actual:e,reverse:n}}else if(e.type===dn.Delete){let{id:r}=e,n=t[r];if(n===void 0)return null;{let s=U({},t);return Object.setPrototypeOf(s,An.prototype),delete s[r],{data:s,actual:e,reverse:{type:dn.Add,id:r,data:n}}}}throw new Error("illegal arg")}};function ca(i){if(i.deepFreeze!==void 0){i.deepFreeze(i);return}let e=Object.getOwnPropertyNames(i);for(let t of e){let r=i[t];r&&typeof r=="object"&&ca(r)}return Object.freeze(i)}function Lx(i,e){let t=0;for(;t<i.length&&t<e.length;){if(i[t]<e[t])return-1;if(i[t]>e[t])return 1;t+=1}return t!==e.length?-1:t!==i.length?1:0}var th=class extends Error{};function Wn(i,e,t){if(i===void 0?e===void 0?(i=0,e=10):i=e-10:e===void 0&&(e=i+10),i>e){let s=i;i=e,e=s}let r=[],n=1/(t+1);for(let s=0;s<t;s++){let l=i+(e-i)*(s+.75+Math.random()*.5)*n;r.push(l)}return r}function _x(i){return i instanceof Uint8Array||i instanceof Uint16Array||i instanceof Uint32Array||i instanceof Int8Array||i instanceof Int16Array||i instanceof Int32Array||i instanceof Float32Array||i instanceof Float64Array}function Tx(){return typeof process!="undefined"}function Ix(i,e){for(let t of i)e(t.id,t.data),Ix(t.children,e)}function Mx(i,e){e(i.id,i.data);for(let t of i.children)Mx(t,e)}var On=class extends Array{constructor(...e){super(...e);Object.setPrototypeOf(this,On.prototype)}deepFreeze(){let e=0;for(;e<this.length;)ca(this[e]),e++}fillCaches0(e,t){var r;if((r=this.objCaches)==null?void 0:r.has(e.id))throw new Error("duplicated item");this.objCaches.set(e.id,e),this.parentCaches.set(e.id,t);for(let n of e.children)this.fillCaches0(n,e.id)}fillCaches(){if(this.objCaches===void 0){this.objCaches=new Map,this.parentCaches=new Map;for(let e of this)this.fillCaches0(e,null)}}randomId(){this.fillCaches();let e=Array.from(this.objCaches.keys());if(e.length!==0)return e[Math.max(0,Math.floor(Math.random()*e.length)-1)]}isDescendantOf(e,t){for(;e;){let r=this.parent(e);if(r===t)return!0;e=r}return!1}data(e){var t;return(t=this.get(e))==null?void 0:t.data}has(e){return this.childrenOf(e)!==void 0}get(e){return this.fillCaches(),this.objCaches.get(e)}childrenOf(e){var t;return e===null?this:(t=this.get(e))==null?void 0:t.children}traverseFrom(e,t){if(e===null)this.traverse(t);else{let r=this.get(e);r&&Mx(r,t)}}traverse(e){Ix(this,e)}totalSize(){return this.fillCaches(),this.objCaches.size}parent(e){return this.fillCaches(),this.parentCaches.get(e)}childrenArray(e){return e===null?this:this.get(e).children}modifyById(e,t){if(this.get(e)===void 0)throw new Error("not expected");{let n=this.parent(e),s=this.childrenArray(n),l=s.findIndex(h=>h.id===e);if(l<0)throw new Error("not expected");let c=s[l];return s=[...s],s[l]=fe(U({},c),{data:t}),this.modifyArrayBy(n,s)}}modifyArrayBy(e,t){let r=e,n=t;for(;r!==null;){let l=n,c=r;if(r=this.parent(r),r===void 0)throw new Error;n=this.childrenArray(r);let f=n.findIndex(h=>h.id===c);if(f<0)throw new Error;n=[...n],n[f]=fe(U({},n[f]),{children:l})}Object.setPrototypeOf(n,On.prototype);let s=n;return s.fillCaches(),s}runOp(e){switch(e.type){case jr.Add:return this.addOp(e);case jr.Delete:return this.deleteOp(e);case jr.Move:return this.moveOp(e)}}addOp(e){let{parent:t,fi:r,id:n,data:s,children:l}=e;if(t!==null&&this.get(t)===void 0)return null;if(this.get(n)!==void 0)return null;{let c=t,f=this.childrenArray(c),h={fi:r,id:n,data:s,children:l};return f=[...f,h],f.sort((x,g)=>x.fi-g.fi),e.localIndex=f.indexOf(h),{data:this.modifyArrayBy(c,f),actual:e,reverse:{type:jr.Delete,id:n}}}}deleteOp(e){let{id:t}=e;if(this.get(t)===null)return null;{let r=this.parent(t);if(r===void 0)return null;let n=this.childrenArray(r),s=n.findIndex(f=>f.id===t);e.localIndex=s,n=[...n];let l=n.splice(s,1)[0];return{data:this.modifyArrayBy(r,n),actual:e,reverse:fe(U({type:jr.Add},l),{parent:r})}}}moveOp(e){let{parent:t,fi:r,id:n}=e;if(t!==null&&this.get(t)===void 0)return this.deleteOp({type:jr.Delete,id:n});if(t!==null){let g=t;for(;g!==null;){if(g===void 0)throw new Error;if(g===n)throw new th("cyclic tree");g=this.parent(g)}}let s=this.parent(n);if(s===void 0)return null;let l=s,c=this.childrenArray(s),f=c.findIndex(g=>g.id===n);c=[...c];let h=c.splice(f,1)[0],d=this.modifyArrayBy(s,c);s=t,c=d.childrenArray(s);let x=h.fi;return h=fe(U({},h),{fi:r}),c=[...c,h],c.sort((g,w)=>g.fi-w.fi),e.localIndex=c.indexOf(h),d=d.modifyArrayBy(s,c),{data:d,actual:e,reverse:{type:jr.Move,parent:l,fi:x,id:n}}}previous(e,t){if(t===null){let n=this.childrenArray(e);return n.length===0?null:n[n.length-1].id}let r=null;for(let n of this.childrenArray(e)){if(n.id===t)return r;r=n.id}return null}traverseSortNext(e){let t=this.parent(e);if(t!==void 0){let r=this.childrenArray(t),n=r.findIndex(s=>s.id===e)+1;if(n<r.length)return r[n].id;if(t)return this.traverseSortNext(t)}}sortNext(e){let t=this.childrenArray(e);return t.length>0?t[0].id:this.traverseSortNext(e)}traverseSortPrevious(e){let t=this.childrenArray(e);return t.length>0?this.traverseSortPrevious(t[t.length-1].id):e}sortPrevious(e){let t=this.parent(e);if(t!==void 0){let r=this.childrenArray(t),n=r.findIndex(s=>s.id===e)-1;return n>=0?this.traverseSortPrevious(r[n].id):t}}getAllSorted(e){let t=[];for(let r of e){let n=this.getWithSortKey(r.id);n!==void 0&&t.push(U(U({},r),n))}t.sort((r,n)=>Lx(r.sortKey,n.sortKey));for(let r of t)delete r.sortKey;return t}getWithSortKey(e){var t=e;let r=[],n=this.get(t),s=n;if(n!==void 0){for(;t;)r.splice(0,0,n.fi),t=this.parent(t),t!==null&&(n=this.get(t));return fe(U({},s),{sortKey:r})}}insertBeforeHelper(e,t,r){return this.insertAfterHelper(e,this.previous(e,t),r)}insertAfterHelper(e,t,r){let n=this.childrenArray(e);if(t===null){if(n.length===0)return Wn(0,r,r);{let s=n[0].fi;return Wn(s-r,s,r)}}else{let s=this.get(t);if(s===void 0||this.parent(t)!==e)throw new Error("illegal args");let l=n.find(c=>c.fi>s.fi);if(l===void 0){let c=n[n.length-1].fi;return Wn(c,c+r,r)}else return Wn(s.fi,l.fi,r)}}};var yc;(function(e){function i(t,r){if(Array.isArray(t)){let n=r.props,s={},l=[...t],c=!1;if(n)for(let f of Object.keys(n)){let h=parseInt(f);if(isNaN(h))throw new Error("wrong index");s[f]=l[h],l[h]=n[f],c=!0}return c?{data:l,actual:r,reverse:{type:Hn.Update,props:s}}:null}else{let n=r.props,s={},l=U({},t),c=!1;if(n)for(let f of Object.keys(n)){s[f]=l[f];let h=n[f];h===void 0?delete l[f]:l[f]=h,c=!0}return c?{data:l,actual:r,reverse:{type:Hn.Update,props:s}}:null}}e.runOp=i})(yc||(yc={}));var jt=class extends Array{constructor(...e){super(...e);Object.setPrototypeOf(this,jt.prototype)}deepFreeze(){let e=0;for(;e<this.length;)ca(this[e]),e++}fillCaches0(e){this.objCaches.set(e.id,e)}fillCaches(){if(this.objCaches===void 0){this.objCaches=new Map,Object.getOwnPropertyDescriptor(this,"objCaches").enumerable=!1;for(let e of this)this.fillCaches0(e)}}randomId(){this.fillCaches();let e=Array.from(this.objCaches.keys());if(e.length!==0)return e[Math.max(0,Math.floor(Math.random()*e.length)-1)]}data(e){var t;return(t=this.get(e))==null?void 0:t.data}get(e){return this.fillCaches(),this.objCaches.get(e)}modifyById(e,t){if(this.get(e)===void 0)throw new Error("not expected");{let n=this,s=n.findIndex(f=>f.id===e);if(s<0)throw new Error("not expected");let l=n[s];return n=[...n],n[s]=fe(U({},l),{data:t}),this.modifyArrayBy(n)}}modifyArrayBy(e){Object.setPrototypeOf(e,jt.prototype);let t=e;return Tx()||t.fillCaches(),t}runOp(e){switch(e.type){case Yr.Add:return this.addOp(e);case Yr.Delete:return this.deleteOp(e);case Yr.Move:return this.moveOp(e)}}addOp(e){let{fi:t,id:r,data:n}=e,s=this,l={fi:t,id:r,data:n};return s=[...s,l],s.sort((f,h)=>f.fi-h.fi),e.localIndex=s.indexOf(l),{data:this.modifyArrayBy(s),actual:e,reverse:{type:Yr.Delete,id:r}}}deleteOp(e){let{id:t}=e,r=this,n=r.findIndex(c=>c.id===t);if(n===-1)return null;e.localIndex=n,r=[...r];let s=r.splice(n,1)[0];return{data:this.modifyArrayBy(r),actual:e,reverse:U({type:Yr.Add},s)}}moveOp(e){let{fi:t,id:r}=e,n=this;n=[...n];let s=n.findIndex(h=>h.id===r);if(s===-1)return null;let l=n[s].fi,c=fe(U({},n[s]),{fi:t});return n[s]=c,n.sort((h,d)=>h.fi-d.fi),e.localIndex=n.indexOf(c),{data:this.modifyArrayBy(n),actual:e,reverse:{type:Yr.Move,fi:l,id:r}}}previous(e){if(e===null)return this.length===0?null:this[this.length-1].id;let t=null;for(let r of this){if(r.id===e)return t;t=r.id}return null}insertBeforeHelper(e,t){return this.insertAfterHelper(this.previous(e),t)}insertAfterHelper(e,t){let r=this;if(e===null){if(r.length===0)return Wn(0,t,t);{let n=r[0].fi;return Wn(n-t,n,t)}}else{let n=this.get(e);if(n===void 0)throw new Error("illegal args");let s=r.find(l=>l.fi>n.fi);if(s===void 0){let l=r[r.length-1].fi;return Wn(l,l+t,t)}else return Wn(n.fi,s.fi,t)}}};var Ax=Symbol(),xc=Symbol(),ua=class{reportOp(e,t){let r=this;if(t===null)return;r._current=t.data;let n=[];for(;!(r instanceof nh);){let s=r._path,l=r._current;if(s!==""&&n.splice(0,0,s),r=r._parent,r===null)return;r.update(s,l)}r.push(n,e,t.actual,t.reverse)}deleteChildren(e){if(this._children){let t=this._children[e];if(t){let r=t[xc];r&&r(),delete this._children[e]}}}},Ox=class extends ua{constructor(e,t,r){super();this._parent=e,this._path=t,this._current=r}update(e,t){if(Array.isArray(this._current)){if(typeof e=="string"&&(e=parseInt(e),isNaN(e)))throw new Error("Invalid path");this._current=[...this._current],this._current[e]=t}else this._current=fe(U({},this._current),{[e]:t})}runOp(e){this.reportOp(e,yc.runOp(this._current,e))}},Px=class extends ua{constructor(e,t,r){super();this._parent=e,this._path=t,this._current=r}update(e,t){this._current=fe(U({},this._current),{[e]:t}),Object.setPrototypeOf(this._current,An.prototype)}runOp(e){this.reportOp(e,this._current.runOp(e))}},Dx={get(i,e){if(e===xc)return()=>{i._parent=null};if(e===Ax)return i._current;let{_current:t,_children:r}=i;if(e==="push"&&Array.isArray(t))throw new Error("not supported to expand array");let n=r===void 0?void 0:r[e];if(n!==void 0)return n;let s=t[e],l=vc(i,e,s);return l!==s?(r===void 0&&(r={},i._children=r),r[e]=l,l):s},has(i,e){return e in i._current},ownKeys(i){return Reflect.ownKeys(i._current)},defineProperty(){throw Error("not supported")},getPrototypeOf(i){return Object.getPrototypeOf(i._current)},setPrototypeOf(){throw Error("not supported")},getOwnPropertyDescriptor(i,e){let t=i._current,r=Reflect.getOwnPropertyDescriptor(t,e);return r&&{writable:!0,configurable:!0,enumerable:r.enumerable,value:t[e]}}},fP=fe(U({},Dx),{set(i,e,t){var n;let r={type:Hn.Update,props:{[e]:(n=sh(t))!=null?n:t}};return i.deleteChildren(e),i.runOp(r),!0},deleteProperty(i,e){let t={type:Hn.Update,props:{[e]:void 0}};return i.deleteChildren(e),i.runOp(t),!0}}),hP=fe(U({},Dx),{set(i,e,t){return t===void 0?this.deleteProperty(i,e):(i.deleteChildren(e),i.runOp({type:dn.Add,id:e,data:t})),!0},deleteProperty(i,e){return i.runOp({type:dn.Delete,id:e}),!0}}),fa=class extends ua{constructor(e,t,r){super();this._children={},this._parent=e,this._path=t,this._current=r,this[xc]=()=>{this._parent=null}}unproxy(){return this._current}update(e,t){this._current=this._current.modifyById(e,t)}runOp(e){this.reportOp(e,this._current.runOp(e))}randomId(){return this._current.randomId()}isDescendantOf(e,t){return this._current.isDescendantOf(e,t)}childrenOf(e){return this._current.childrenOf(e)}traverse(e){return this._current.traverse(e)}get(e){return this._current.get(e)}parent(e){return this._current.parent(e)}traverse(e){this._current.traverse((t,r)=>{e(t,this.data(t))})}data(e){var c;let{_current:t,_children:r}=this,n=r===void 0?void 0:r[e];if(n!==void 0)return n;let s=(c=t.get(e))==null?void 0:c.data,l=vc(this,e,s);return l!==s?(r===void 0&&(r={},this._children=r),r[e]=l,l):s}add(e,t,r,n,s){this.runOp({type:jr.Add,parent:e,fi:t,id:r,data:n,children:s})}move(e,t,r){this.runOp({type:jr.Move,parent:e,fi:t,id:r})}insertAfter(e,t,r){let n=this._current.insertAfterHelper(e,t,r.length);for(let s=0;s<r.length;s++){let l=r[s];this.add(e,n[s],l.id,l.data,l.children)}}insertBefore(e,t,r){let n=this._current.insertBeforeHelper(e,t,r.length);for(let s=0;s<r.length;s++){let l=r[s];this.add(e,n[s],l.id,l.data,l.children)}}moveAfter(e,t,r){let n=this._current.insertAfterHelper(e,t,r.length);for(let s=0;s<r.length;s++){let l=r[s];this.move(e,n[s],l)}}moveBefore(e,t,r){let n=this._current.insertBeforeHelper(e,t,r.length);for(let s=0;s<r.length;s++){let l=r[s];this.move(e,n[s],l)}}delete(e){this.deleteChildren(e),this.runOp({type:jr.Delete,id:e})}sortNext(e){return this._current.sortNext(e)}sortPrevious(e){return this._current.sortPrevious(e)}getAllSorted(e){return this._current.getAllSorted(e)}},ha=class extends ua{constructor(e,t,r){super();this._children={},this._parent=e,this._path=t,this._current=r,this[xc]=()=>{this._parent=null}}unproxy(){return this._current}get length(){return this._current.length}forEach(e){let t=this.length;for(let r=0;r<t;r++){let n=this._current[r].id;e(this.data(this._current[r].id),n)}}update(e,t){this._current=this._current.modifyById(e,t)}randomId(){return this._current.randomId()}get(e){return fe(U({},this._current.get(e)),{data:this.data(e)})}data(e){var c;let{_current:t,_children:r}=this,n=r===void 0?void 0:r[e];if(n!==void 0)return n;let s=(c=t.get(e))==null?void 0:c.data,l=vc(this,e,s);return l!==s?(r===void 0&&(r={},this._children=r),r[e]=l,l):s}runOp(e){this.reportOp(e,this._current.runOp(e))}add(e,t,r){this.runOp({type:Yr.Add,fi:e,id:t,data:r})}move(e,t){this.runOp({type:Yr.Move,fi:e,id:t})}insertAfter(e,t){let r=this._current.insertAfterHelper(e,t.length);for(let n=0;n<t.length;n++){let s=t[n];this.add(r[n],s.id,s.data)}}insertBefore(e,t){let r=this._current.insertBeforeHelper(e,t.length);for(let n=0;n<t.length;n++){let s=t[n];this.add(r[n],s.id,s.data)}}moveAfter(e,t){let r=this._current.insertAfterHelper(e,t.length);for(let n=0;n<t.length;n++){let s=t[n];this.move(r[n],s)}}moveBefore(e,t){let r=this._current.insertBeforeHelper(e,t.length);for(let n=0;n<t.length;n++){let s=t[n];this.move(r[n],s)}}delete(e){this.deleteChildren(e),this.runOp({type:Yr.Delete,id:e})}};function rh(i,e,t){if(i.length>0){let r=i[i.length-1];if(r.type===Hn.Update&&e.type===Hn.Update&&bc.equal(r.path,t)){Object.assign(r.props,e.props);return}}i.push(fe(U({},e),{path:t}))}var nh=class{constructor(e){this.ts=[],this.actual=[],this.reverse=[],this._current=e}update(e,t){if(e!=="")throw new Error("");this._current=t}push(e,t,r,n){rh(this.ts,t,e),rh(this.actual,r,e),rh(this.reverse,n,e)}result(){return{data:this._current,ts:this.ts,actual:this.actual,reverse:this.reverse.reverse()}}};function vc(i,e,t){return t instanceof On?new fa(i,e,t):t instanceof jt?new ha(i,e,t):t instanceof An?new Proxy(new Px(i,e,t),hP):t!==null&&typeof t=="object"?_x(t)?t:new Proxy(new Ox(i,e,t),fP):t}function ih(i){let e=new nh(i);return[vc(e,"",i),e]}function oh(i,e){let[t,r]=ih(i);return e(t),r.result()}function sh(i){return i instanceof fa||i instanceof ha?i._current:i!==null&&typeof i=="object"?i[Ax]:i}var bc;(function(r){function i(n,s){if(s.length===n.length)for(var l=0;l<n.length;){if(n[l]!==s[l])return!1;l+=1}else return!1;return!0}r.equal=i;function e(n,s,l){let c=t(l,n);if(c!==void 0&&typeof c=="object"&&c!==null){let f=U({},s);return Object.keys(c).forEach(h=>{delete f[h]}),f}else return s}r.removeOverridden=e;function t(n,s,l=0){if(s.length<=l)return n;if((n instanceof On||n instanceof fa)&&typeof s[l]=="string")return t(n.data(s[l]),s,l+1);if((n instanceof jt||n instanceof ha)&&typeof s[l]=="string")return t(n.data(s[l]),s,l+1);if(typeof s[l]=="number"&&Array.isArray(n))return t(n[s[l]],s,l+1);if(typeof s[l]=="string"&&typeof n=="object")return t(n[s[l]],s,l+1)}r.zoom=t})(bc||(bc={}));var ah=class{},Sc=class extends ah{constructor(e){super();this.id=e}},wc=class extends ah{constructor(e){super();this.data=e}};"use strict";var lh;try{lh=new TextDecoder}catch(i){}var ge,Vi,j=0;var Bx=[],ch=Bx,uh=0,Er={},ot,Ui,mn=0,qn=0,Qr,di,Cr=[],ft,Gx={useRecords:!1,mapsAsObjects:!0},Nc=class{},fh=new Nc;fh.name="MessagePack 0xC1";var gs=!1,mi=class{constructor(e){e&&(e.useRecords===!1&&e.mapsAsObjects===void 0&&(e.mapsAsObjects=!0),e.structures?e.structures.sharedLength=e.structures.length:e.getStructures&&((e.structures=[]).uninitialized=!0,e.structures.sharedLength=0)),Object.assign(this,e)}unpack(e,t){if(ge)return qx(()=>(_c(),this?this.unpack(e,t):mi.prototype.unpack.call(Gx,e,t)));Vi=t>-1?t:e.length,j=0,uh=0,qn=0,Ui=null,ch=Bx,Qr=null,ge=e;try{ft=e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))}catch(r){throw ge=null,e instanceof Uint8Array?r:new Error("Source must be a Uint8Array or Buffer but was a "+(e&&typeof e=="object"?e.constructor.name:typeof e))}if(this instanceof mi){if(Er=this,this.structures)return ot=this.structures,Cc();(!ot||ot.length>0)&&(ot=[])}else Er=Gx,(!ot||ot.length>0)&&(ot=[]);return Cc()}unpackMultiple(e,t){let r,n=0;try{gs=!0;let s=e.length,l=this?this.unpack(e,s):Ic.unpack(e,s);if(t){for(t(l);j<s;)if(n=j,t(Cc())===!1)return}else{for(r=[l];j<s;)n=j,r.push(Cc());return r}}catch(s){throw s.lastPosition=n,s.values=r,s}finally{gs=!1,_c()}}_mergeStructures(e,t){e=e||[];for(let r=0,n=e.length;r<n;r++){let s=e[r];s&&(s.isShared=!0,r>=32&&(s.highByte=r-32>>5))}e.sharedLength=e.length;for(let r in t||[])if(r>=0){let n=e[r],s=t[r];s&&(n&&((e.restoreStructures||(e.restoreStructures=[]))[r]=n),e[r]=s)}return this.structures=e}decode(e,t){return this.unpack(e,t)}};function Cc(){try{if(!Er.trusted&&!gs){let e=ot.sharedLength||0;e<ot.length&&(ot.length=e)}let i=Et();if(j==Vi)ot.restoreStructures&&jx(),ot=null,ge=null,di&&(di=null);else if(j>Vi){let e=new Error("Unexpected end of MessagePack data");throw e.incomplete=!0,e}else if(!gs)throw new Error("Data read, but end of buffer not reached");return i}catch(i){throw ot.restoreStructures&&jx(),_c(),(i instanceof RangeError||i.message.startsWith("Unexpected end of buffer"))&&(i.incomplete=!0),i}}function jx(){for(let i in ot.restoreStructures)ot[i]=ot.restoreStructures[i];ot.restoreStructures=null}function Et(){let i=ge[j++];if(i<160)if(i<128){if(i<64)return i;{let e=ot[i&63]||Er.getStructures&&Rx()[i&63];return e?(e.read||(e.read=hh(e,i&63)),e.read()):i}}else if(i<144)if(i-=128,Er.mapsAsObjects){let e={};for(let t=0;t<i;t++)e[kx()]=Et();return e}else{let e=new Map;for(let t=0;t<i;t++)e.set(Et(),Et());return e}else{i-=144;let e=new Array(i);for(let t=0;t<i;t++)e[t]=Et();return e}else if(i<192){let e=i-160;if(qn>=j)return Ui.slice(j-mn,(j+=e)-mn);if(qn==0&&Vi<140){let t=e<16?dh(e):Vx(e);if(t!=null)return t}return ph(e)}else{let e;switch(i){case 192:return null;case 193:return Qr?(e=Et(),e>0?Qr[1].slice(Qr.position1,Qr.position1+=e):Qr[0].slice(Qr.position0,Qr.position0-=e)):fh;case 194:return!1;case 195:return!0;case 196:return mh(ge[j++]);case 197:return e=ft.getUint16(j),j+=2,mh(e);case 198:return e=ft.getUint32(j),j+=4,mh(e);case 199:return vo(ge[j++]);case 200:return e=ft.getUint16(j),j+=2,vo(e);case 201:return e=ft.getUint32(j),j+=4,vo(e);case 202:if(e=ft.getFloat32(j),Er.useFloat32>2){let t=Tc[(ge[j]&127)<<1|ge[j+1]>>7];return j+=4,(t*e+(e>0?.5:-.5)>>0)/t}return j+=4,e;case 203:return e=ft.getFloat64(j),j+=8,e;case 204:return ge[j++];case 205:return e=ft.getUint16(j),j+=2,e;case 206:return e=ft.getUint32(j),j+=4,e;case 207:return Er.int64AsNumber?(e=ft.getUint32(j)*4294967296,e+=ft.getUint32(j+4)):e=ft.getBigUint64(j),j+=8,e;case 208:return ft.getInt8(j++);case 209:return e=ft.getInt16(j),j+=2,e;case 210:return e=ft.getInt32(j),j+=4,e;case 211:return Er.int64AsNumber?(e=ft.getInt32(j)*4294967296,e+=ft.getUint32(j+4)):e=ft.getBigInt64(j),j+=8,e;case 212:if(e=ge[j++],e==114)return Hx(ge[j++]&63);{let t=Cr[e];if(t)return t.read?(j++,t.read(Et())):t.noBuffer?(j++,t()):t(ge.subarray(j,++j));throw new Error("Unknown extension "+e)}case 213:return e=ge[j],e==114?(j++,Hx(ge[j++]&63,ge[j++])):vo(2);case 214:return vo(4);case 215:return vo(8);case 216:return vo(16);case 217:return e=ge[j++],qn>=j?Ui.slice(j-mn,(j+=e)-mn):dP(e);case 218:return e=ft.getUint16(j),j+=2,qn>=j?Ui.slice(j-mn,(j+=e)-mn):mP(e);case 219:return e=ft.getUint32(j),j+=4,qn>=j?Ui.slice(j-mn,(j+=e)-mn):gP(e);case 220:return e=ft.getUint16(j),j+=2,zx(e);case 221:return e=ft.getUint32(j),j+=4,zx(e);case 222:return e=ft.getUint16(j),j+=2,Fx(e);case 223:return e=ft.getUint32(j),j+=4,Fx(e);default:if(i>=224)return i-256;if(i===void 0){let t=new Error("Unexpected end of MessagePack data");throw t.incomplete=!0,t}throw new Error("Unknown MessagePack token "+i)}}}var pP=/^[a-zA-Z_$][a-zA-Z\d_$]*$/;function hh(i,e){function t(){if(t.count++>2){let n=i.read=new Function("r","return function(){return {"+i.map(s=>pP.test(s)?s+":r()":"["+JSON.stringify(s)+"]:r()").join(",")+"}}")(Et);return i.highByte===0&&(i.read=Ex(e,i.read)),n()}let r={};for(let n=0,s=i.length;n<s;n++){let l=i[n];r[l]=Et()}return r}return t.count=0,i.highByte===0?Ex(e,t):t}var Ex=(i,e)=>function(){let t=ge[j++];if(t===0)return e();let r=i<32?-(i+(t<<5)):i+(t<<5),n=ot[r]||Rx()[r];if(!n)throw new Error("Record id is not defined for "+r);return n.read||(n.read=hh(n,i)),n.read()};function Rx(){let i=qx(()=>(ge=null,Er.getStructures()));return ot=Er._mergeStructures(i,ot)}var ph=Lc,dP=Lc,mP=Lc,gP=Lc;function Lc(i){let e;if(i<16&&(e=dh(i)))return e;if(i>64&&lh)return lh.decode(ge.subarray(j,j+=i));let t=j+i,r=[];for(e="";j<t;){let n=ge[j++];if((n&128)==0)r.push(n);else if((n&224)==192){let s=ge[j++]&63;r.push((n&31)<<6|s)}else if((n&240)==224){let s=ge[j++]&63,l=ge[j++]&63;r.push((n&31)<<12|s<<6|l)}else if((n&248)==240){let s=ge[j++]&63,l=ge[j++]&63,c=ge[j++]&63,f=(n&7)<<18|s<<12|l<<6|c;f>65535&&(f-=65536,r.push(f>>>10&1023|55296),f=56320|f&1023),r.push(f)}else r.push(n);r.length>=4096&&(e+=ir.apply(String,r),r.length=0)}return r.length>0&&(e+=ir.apply(String,r)),e}function zx(i){let e=new Array(i);for(let t=0;t<i;t++)e[t]=Et();return e}function Fx(i){if(Er.mapsAsObjects){let e={};for(let t=0;t<i;t++)e[kx()]=Et();return e}else{let e=new Map;for(let t=0;t<i;t++)e.set(Et(),Et());return e}}var ir=String.fromCharCode;function Vx(i){let e=j,t=new Array(i);for(let r=0;r<i;r++){let n=ge[j++];if((n&128)>0){j=e;return}t[r]=n}return ir.apply(String,t)}function dh(i){if(i<4)if(i<2){if(i===0)return"";{let e=ge[j++];if((e&128)>1){j-=1;return}return ir(e)}}else{let e=ge[j++],t=ge[j++];if((e&128)>0||(t&128)>0){j-=2;return}if(i<3)return ir(e,t);let r=ge[j++];if((r&128)>0){j-=3;return}return ir(e,t,r)}else{let e=ge[j++],t=ge[j++],r=ge[j++],n=ge[j++];if((e&128)>0||(t&128)>0||(r&128)>0||(n&128)>0){j-=4;return}if(i<6){if(i===4)return ir(e,t,r,n);{let s=ge[j++];if((s&128)>0){j-=5;return}return ir(e,t,r,n,s)}}else if(i<8){let s=ge[j++],l=ge[j++];if((s&128)>0||(l&128)>0){j-=6;return}if(i<7)return ir(e,t,r,n,s,l);let c=ge[j++];if((c&128)>0){j-=7;return}return ir(e,t,r,n,s,l,c)}else{let s=ge[j++],l=ge[j++],c=ge[j++],f=ge[j++];if((s&128)>0||(l&128)>0||(c&128)>0||(f&128)>0){j-=8;return}if(i<10){if(i===8)return ir(e,t,r,n,s,l,c,f);{let h=ge[j++];if((h&128)>0){j-=9;return}return ir(e,t,r,n,s,l,c,f,h)}}else if(i<12){let h=ge[j++],d=ge[j++];if((h&128)>0||(d&128)>0){j-=10;return}if(i<11)return ir(e,t,r,n,s,l,c,f,h,d);let x=ge[j++];if((x&128)>0){j-=11;return}return ir(e,t,r,n,s,l,c,f,h,d,x)}else{let h=ge[j++],d=ge[j++],x=ge[j++],g=ge[j++];if((h&128)>0||(d&128)>0||(x&128)>0||(g&128)>0){j-=12;return}if(i<14){if(i===12)return ir(e,t,r,n,s,l,c,f,h,d,x,g);{let w=ge[j++];if((w&128)>0){j-=13;return}return ir(e,t,r,n,s,l,c,f,h,d,x,g,w)}}else{let w=ge[j++],S=ge[j++];if((w&128)>0||(S&128)>0){j-=14;return}if(i<15)return ir(e,t,r,n,s,l,c,f,h,d,x,g,w,S);let D=ge[j++];if((D&128)>0){j-=15;return}return ir(e,t,r,n,s,l,c,f,h,d,x,g,w,S,D)}}}}}function mh(i){return Er.copyBuffers?Uint8Array.prototype.slice.call(ge,j,j+=i):ge.subarray(j,j+=i)}function vo(i){let e=ge[j++];if(Cr[e])return Cr[e](ge.subarray(j,j+=i));throw new Error("Unknown extension type "+e)}var Ux=new Array(4096);function kx(){let i=ge[j++];if(i>=160&&i<192){if(i=i-160,qn>=j)return Ui.slice(j-mn,(j+=i)-mn);if(!(qn==0&&Vi<180))return ph(i)}else return j--,Et();let e=(i<<5^(i>1?ft.getUint16(j):i>0?ge[j]:0))&4095,t=Ux[e],r=j,n=j+i-3,s,l=0;if(t&&t.bytes==i){for(;r<n;){if(s=ft.getUint32(r),s!=t[l++]){r=1879048192;break}r+=4}for(n+=3;r<n;)if(s=ge[r++],s!=t[l++]){r=1879048192;break}if(r===n)return j=r,t.string;n-=3,r=j}for(t=[],Ux[e]=t,t.bytes=i;r<n;)s=ft.getUint32(r),t.push(s),r+=4;for(n+=3;r<n;)s=ge[r++],t.push(s);let c=i<16?dh(i):Vx(i);return c!=null?t.string=c:t.string=ph(i)}var Hx=(i,e)=>{var t=Et();let r=i;e!==void 0&&(i=i<32?-((e<<5)+i):(e<<5)+i,t.highByte=e);let n=ot[i];return n&&n.isShared&&((ot.restoreStructures||(ot.restoreStructures=[]))[i]=n),ot[i]=t,t.read=hh(t,r),t.read()},Wx=typeof self=="object"?self:global;Cr[0]=()=>{};Cr[0].noBuffer=!0;Cr[101]=()=>{let i=Et();return(Wx[i[0]]||Error)(i[1])};Cr[105]=i=>{let e=ft.getUint32(j-4);di||(di=new Map);let t=ge[j],r;t>=144&&t<160||t==220||t==221?r=[]:r={};let n={target:r};di.set(e,n);let s=Et();return n.used?Object.assign(r,s):(n.target=s,s)};Cr[112]=i=>{let e=ft.getUint32(j-4),t=di.get(e);return t.used=!0,t.target};Cr[115]=()=>new Set(Et());var gh=["Int8","Uint8","Uint8Clamped","Int16","Uint16","Int32","Uint32","Float32","Float64","BigInt64","BigUint64"].map(i=>i+"Array");Cr[116]=i=>{let e=i[0],t=gh[e];if(!t)throw new Error("Could not find typed array for code "+e);return new Wx[t](Uint8Array.prototype.slice.call(i,1).buffer)};Cr[120]=()=>{let i=Et();return new RegExp(i[0],i[1])};Cr[98]=i=>{let e=(i[0]<<24)+(i[1]<<16)+(i[2]<<8)+i[3],t=j;j+=e-4,Qr=[Et(),Et()],Qr.position0=0,Qr.position1=0;let r=j;j=t;try{return Et()}finally{j=r}};Cr[255]=i=>i.length==4?new Date((i[0]*16777216+(i[1]<<16)+(i[2]<<8)+i[3])*1e3):i.length==8?new Date(((i[0]<<22)+(i[1]<<14)+(i[2]<<6)+(i[3]>>2))/1e6+((i[3]&3)*4294967296+i[4]*16777216+(i[5]<<16)+(i[6]<<8)+i[7])*1e3):i.length==12?new Date(((i[0]<<24)+(i[1]<<16)+(i[2]<<8)+i[3])/1e6+((i[4]&128?-281474976710656:0)+i[6]*1099511627776+i[7]*4294967296+i[8]*16777216+(i[9]<<16)+(i[10]<<8)+i[11])*1e3):new Date("invalid");function qx(i){let e=Vi,t=j,r=uh,n=mn,s=qn,l=Ui,c=ch,f=di,h=Qr,d=new Uint8Array(ge.slice(0,Vi)),x=ot,g=ot.slice(0,ot.length),w=Er,S=gs,D=i();return Vi=e,j=t,uh=r,mn=n,qn=s,Ui=l,ch=c,di=f,Qr=h,ge=d,gs=S,ot=x,ot.splice(0,ot.length,...g),Er=w,ft=new DataView(ge.buffer,ge.byteOffset,ge.byteLength),D}function _c(){ge=null,di=null,ot=null}function $x(i){i.unpack?Cr[i.type]=i.unpack:Cr[i.type]=i}var Tc=new Array(147);for(let i=0;i<256;i++)Tc[i]=+("1e"+Math.floor(45.15-i*.30103));var Ic=new mi({useRecords:!1}),yP=Ic.unpack,xP=Ic.unpackMultiple,vP=Ic.unpack;var bP=new Float32Array(1),zU=new Uint8Array(bP.buffer,0,4);"use strict";var Mc;try{Mc=new TextEncoder}catch(i){}var Ac,yh,Oc=typeof Buffer!="undefined",xh=Oc?Buffer.allocUnsafeSlow:Uint8Array,Kx=Oc?Buffer:Uint8Array,Xx=Oc?4294967296:2144337920,Z,Vt,F=0,$n,Jn=null,SP=/[\u0080-\uFFFF]/,pa=Symbol("record-id"),ys=class extends mi{constructor(e){super(e);this.offset=0;let t,r,n,s,l,c,f=0,h=Kx.prototype.utf8Write?function(b,R,T){return Z.utf8Write(b,R,T)}:Mc&&Mc.encodeInto?function(b,R){return Mc.encodeInto(b,Z.subarray(R)).written}:!1,d=this;e||(e={});let x=e&&e.sequential,g=e.structures||e.saveStructures,w=e.maxSharedStructures;if(w==null&&(w=g?32:0),w>8160)throw new Error("Maximum maxSharedStructure is 8160");let S=e.maxOwnStructures;S==null&&(S=g?32:64),x&&!e.saveStructures&&(this.structures=[]);let D=w>32||S+w>64,C=w+64,G=w+S+64;if(G>8256)throw new Error("Maximum maxSharedStructure + maxOwnStructure is 8192");let B=[],P=0,W=0;this.pack=this.encode=function(b,R){if(Z||(Z=new xh(8192),Vt=new DataView(Z.buffer,0,8192),F=0),$n=Z.length-10,$n-F<2048?(Z=new xh(Z.length),Vt=new DataView(Z.buffer,0,Z.length),$n=Z.length-10,F=0):F=F+7&2147483640,r=F,c=d.structuredClone?new Map:null,d.bundleStrings?(Jn=["",""],Z[F++]=214,Z[F++]=98,Jn.position=F-r,F+=4):Jn=null,n=d.structures,n){n.uninitialized&&(n=d._mergeStructures(d.getStructures()));let T=n.sharedLength||0;if(T>w)throw new Error("Shared structures is larger than maximum shared structures, try increasing maxSharedStructures to "+n.sharedLength);if(!n.transitions){n.transitions=Object.create(null);for(let z=0;z<T;z++){let A=n[z];if(!A)continue;let $,he=n.transitions;for(let re=0,Ne=A.length;re<Ne;re++){let ye=A[re];$=he[ye],$||($=he[ye]=Object.create(null)),he=$}he[pa]=z+64}f=T}x||(n.nextId=T+64)}s&&(s=!1),l=n||[];try{if(M(b),Jn){Vt.setUint32(Jn.position+r,F-Jn.position-r);let T=Jn;Jn=null,M(T[0]),M(T[1])}if(d.offset=F,c&&c.idsToInsert){F+=c.idsToInsert.length*6,F>$n&&E(F),d.offset=F;let T=NP(Z.subarray(r,F),c.idsToInsert);return c=null,T}return R&e0?(Z.start=r,Z.end=F,Z):Z.subarray(r,F)}finally{if(n){if(W<10&&W++,P>1e4)n.transitions=null,W=0,P=0,B.length>0&&(B=[]);else if(B.length>0&&!x){for(let T=0,z=B.length;T<z;T++)B[T][pa]=0;B=[]}if(s&&d.saveStructures){let T=n.sharedLength||w;n.length>T&&(n=n.slice(0,T));let z=Z.subarray(r,F);return d.saveStructures(n,f)===!1?(d._mergeStructures(d.getStructures()),d.pack(b)):(f=T,z)}}R&_P&&(F=r)}};let M=b=>{F>$n&&(Z=E(F));var R=typeof b,T;if(R==="string"){let z=b.length;if(Jn&&z>=8&&z<4096){let he=SP.test(b);Jn[he?0:1]+=b,Z[F++]=193,M(he?-z:z);return}let A;z<32?A=1:z<256?A=2:z<65536?A=3:A=5;let $=z*3;if(F+$>$n&&(Z=E(F+$)),z<64||!h){let he,re,Ne,ye=F+A;for(he=0;he<z;he++)re=b.charCodeAt(he),re<128?Z[ye++]=re:re<2048?(Z[ye++]=re>>6|192,Z[ye++]=re&63|128):(re&64512)==55296&&((Ne=b.charCodeAt(he+1))&64512)==56320?(re=65536+((re&1023)<<10)+(Ne&1023),he++,Z[ye++]=re>>18|240,Z[ye++]=re>>12&63|128,Z[ye++]=re>>6&63|128,Z[ye++]=re&63|128):(Z[ye++]=re>>12|224,Z[ye++]=re>>6&63|128,Z[ye++]=re&63|128);T=ye-F-A}else T=h(b,F+A,$);T<32?Z[F++]=160|T:T<256?(A<2&&Z.copyWithin(F+2,F+1,F+1+T),Z[F++]=217,Z[F++]=T):T<65536?(A<3&&Z.copyWithin(F+3,F+2,F+2+T),Z[F++]=218,Z[F++]=T>>8,Z[F++]=T&255):(A<5&&Z.copyWithin(F+5,F+3,F+3+T),Z[F++]=219,Vt.setUint32(F,T),F+=4),F+=T}else if(R==="number")if(b>>>0===b)b<64?Z[F++]=b:b<256?(Z[F++]=204,Z[F++]=b):b<65536?(Z[F++]=205,Z[F++]=b>>8,Z[F++]=b&255):(Z[F++]=206,Vt.setUint32(F,b),F+=4);else if(b>>0===b)b>=-32?Z[F++]=256+b:b>=-128?(Z[F++]=208,Z[F++]=b+256):b>=-32768?(Z[F++]=209,Vt.setInt16(F,b),F+=2):(Z[F++]=210,Vt.setInt32(F,b),F+=4);else{let z;if((z=this.useFloat32)>0&&b<4294967296&&b>=-2147483648){Z[F++]=202,Vt.setFloat32(F,b);let A;if(z<4||(A=b*Tc[(Z[F]&127)<<1|Z[F+1]>>7])>>0===A){F+=4;return}else F--}Z[F++]=203,Vt.setFloat64(F,b),F+=8}else if(R==="object")if(!b)Z[F++]=192;else{if(c){let A=c.get(b);if(A){if(!A.id){let $=c.idsToInsert||(c.idsToInsert=[]);A.id=$.push(A)}Z[F++]=214,Z[F++]=112,Vt.setUint32(F,A.id),F+=4;return}else c.set(b,{offset:F-r})}let z=b.constructor;if(z===Object)q(b,!0);else if(z===Array){T=b.length,T<16?Z[F++]=144|T:T<65536?(Z[F++]=220,Z[F++]=T>>8,Z[F++]=T&255):(Z[F++]=221,Vt.setUint32(F,T),F+=4);for(let A=0;A<T;A++)M(b[A])}else if(z===Map){T=b.size,T<16?Z[F++]=128|T:T<65536?(Z[F++]=222,Z[F++]=T>>8,Z[F++]=T&255):(Z[F++]=223,Vt.setUint32(F,T),F+=4);for(let[A,$]of b)M(A),M($)}else{for(let A=0,$=Ac.length;A<$;A++){let he=yh[A];if(b instanceof he){let re=Ac[A];if(re.write){re.type&&(Z[F++]=212,Z[F++]=re.type,Z[F++]=0),M(re.write.call(this,b));return}let Ne=Z,ye=Vt,Me=F;Z=null;let Fe;try{Fe=re.pack.call(this,b,k=>(Z=Ne,Ne=null,F+=k,F>$n&&E(F),{target:Z,targetView:Vt,position:F-k}),M)}finally{Ne&&(Z=Ne,Vt=ye,F=Me,$n=Z.length-10)}Fe&&(Fe.length+F>$n&&E(Fe.length+F),F=wP(Fe,Z,F,re.type));return}}q(b,!b.hasOwnProperty)}}else if(R==="boolean")Z[F++]=b?195:194;else if(R==="bigint"){if(b<BigInt(1)<<BigInt(63)&&b>=-(BigInt(1)<<BigInt(63)))Z[F++]=211,Vt.setBigInt64(F,b);else if(b<BigInt(1)<<BigInt(64)&&b>0)Z[F++]=207,Vt.setBigUint64(F,b);else if(this.largeBigIntToFloat)Z[F++]=203,Vt.setFloat64(F,Number(b));else throw new RangeError(b+" was too large to fit in MessagePack 64-bit integer format, set largeBigIntToFloat to convert to float-64");F+=8}else if(R==="undefined")this.encodeUndefinedAsNil?Z[F++]=192:(Z[F++]=212,Z[F++]=0,Z[F++]=0);else if(R==="function")M(this.writeFunction&&this.writeFunction());else throw new Error("Unknown type: "+R)},q=this.useRecords===!1?this.variableMapSize?b=>{let R=Object.keys(b),T=R.length;T<16?Z[F++]=128|T:T<65536?(Z[F++]=222,Z[F++]=T>>8,Z[F++]=T&255):(Z[F++]=223,Vt.setUint32(F,T),F+=4);let z;for(let A=0;A<T;A++)M(z=R[A]),M(b[z])}:(b,R)=>{Z[F++]=222;let T=F-r;F+=2;let z=0;for(let A in b)(R||b.hasOwnProperty(A))&&(M(A),M(b[A]),z++);Z[T+++r]=z>>8,Z[T+r]=z&255}:b=>{let R=Object.keys(b),T,z=l.transitions||(l.transitions=Object.create(null)),A=0;for(let he=0,re=R.length;he<re;he++){let Ne=R[he];T=z[Ne],T||(T=z[Ne]=Object.create(null),A++),z=T}let $=z[pa];if($)$>=96&&D?(Z[F++]=(($-=96)&31)+96,Z[F++]=$>>5):Z[F++]=$;else{$=l.nextId,$||($=64),$<C&&this.shouldShareStructure&&!this.shouldShareStructure(R)?($=l.nextOwnId,$<G||($=C),l.nextOwnId=$+1):($>=G&&($=C),l.nextId=$+1);let he=R.highByte=$>=96&&D?$-96>>5:-1;z[pa]=$,l[$-64]=R,$<C?(R.isShared=!0,l.sharedLength=$-63,s=!0,he>=0?(Z[F++]=($&31)+96,Z[F++]=he):Z[F++]=$):(he>=0?(Z[F++]=213,Z[F++]=114,Z[F++]=($&31)+96,Z[F++]=he):(Z[F++]=212,Z[F++]=114,Z[F++]=$),A&&(P+=W*A),B.length>=S&&(B.shift()[pa]=0),B.push(z),M(R))}for(let he=0,re=R.length;he<re;he++)M(b[R[he]])},E=b=>{let R;if(b>16777216){if(b-r>Xx)throw new Error("Packed buffer would be larger than maximum buffer size");R=Math.min(Xx,Math.round(Math.max((b-r)*(b>67108864?1.25:2),4194304)/4096)*4096)}else R=(Math.max(b-r<<2,Z.length-1)>>12)+1<<12;let T=new xh(R);return Vt=new DataView(T.buffer,0,R),Z.copy?Z.copy(T,0,r,b):T.set(Z.slice(r,b)),F-=r,r=0,$n=T.length-10,Z=T}}useBuffer(e){Z=e,Vt=new DataView(Z.buffer,Z.byteOffset,Z.byteLength),F=0}};yh=[Date,Set,Error,RegExp,ArrayBuffer,Object.getPrototypeOf(Uint8Array.prototype).constructor,Nc];Ac=[{pack(i,e,t){let r=i.getTime()/1e3;if((this.useTimestamp32||i.getMilliseconds()===0)&&r>=0&&r<4294967296){let{target:n,targetView:s,position:l}=e(6);n[l++]=214,n[l++]=255,s.setUint32(l,r)}else if(r>0&&r<17179869184){let{target:n,targetView:s,position:l}=e(10);n[l++]=215,n[l++]=255,s.setUint32(l,i.getMilliseconds()*4e6+(r/1e3/4294967296>>0)),s.setUint32(l+4,r)}else if(isNaN(r)){if(this.onInvalidDate)return e(0),t(this.onInvalidDate());let{target:n,targetView:s,position:l}=e(3);n[l++]=212,n[l++]=255,n[l++]=255}else{let{target:n,targetView:s,position:l}=e(15);n[l++]=199,n[l++]=12,n[l++]=255,s.setUint32(l,i.getMilliseconds()*1e6),s.setBigInt64(l+4,BigInt(Math.floor(r)))}}},{pack(i,e,t){let r=Array.from(i),{target:n,position:s}=e(this.structuredClone?3:0);this.structuredClone&&(n[s++]=212,n[s++]=115,n[s++]=0),t(r)}},{pack(i,e,t){let{target:r,position:n}=e(this.structuredClone?3:0);this.structuredClone&&(r[n++]=212,r[n++]=101,r[n++]=0),t([i.name,i.message])}},{pack(i,e,t){let{target:r,position:n}=e(this.structuredClone?3:0);this.structuredClone&&(r[n++]=212,r[n++]=120,r[n++]=0),t([i.source,i.flags])}},{pack(i,e){this.structuredClone?Zx(i,16,e):Yx(Oc?Buffer.from(i):new Uint8Array(i),e)}},{pack(i,e){let t=i.constructor;t!==Kx&&this.structuredClone?Zx(i,gh.indexOf(t.name),e):Yx(i,e)}},{pack(i,e){let{target:t,position:r}=e(1);t[r]=193}}];function Zx(i,e,t,r){let n=i.byteLength;if(n+1<256){var{target:s,position:l}=t(4+n);s[l++]=199,s[l++]=n+1}else if(n+1<65536){var{target:s,position:l}=t(5+n);s[l++]=200,s[l++]=n+1>>8,s[l++]=n+1&255}else{var{target:s,position:l,targetView:c}=t(7+n);s[l++]=201,c.setUint32(l,n+1),l+=4}s[l++]=116,s[l++]=e,s.set(new Uint8Array(i.buffer,i.byteOffset,i.byteLength),l)}function Yx(i,e){let t=i.byteLength;var r,n;if(t<256){var{target:r,position:n}=e(t+2);r[n++]=196,r[n++]=t}else if(t<65536){var{target:r,position:n}=e(t+3);r[n++]=197,r[n++]=t>>8,r[n++]=t&255}else{var{target:r,position:n,targetView:s}=e(t+5);r[n++]=198,s.setUint32(n,t),n+=4}r.set(i,n)}function wP(i,e,t,r){let n=i.length;switch(n){case 1:e[t++]=212;break;case 2:e[t++]=213;break;case 4:e[t++]=214;break;case 8:e[t++]=215;break;case 16:e[t++]=216;break;default:n<256?(e[t++]=199,e[t++]=n):n<65536?(e[t++]=200,e[t++]=n>>8,e[t++]=n&255):(e[t++]=201,e[t++]=n>>24,e[t++]=n>>16&255,e[t++]=n>>8&255,e[t++]=n&255)}return e[t++]=r,e.set(i,t),t+=n,t}function NP(i,e){let t,r=e.length*6,n=i.length-r;for(e.sort((s,l)=>s.offset>l.offset?1:-1);t=e.pop();){let s=t.offset,l=t.id;i.copyWithin(s+r,s,n),r-=6;let c=s+r;i[c++]=214,i[c++]=105,i[c++]=l>>24,i[c++]=l>>16&255,i[c++]=l>>8&255,i[c++]=l&255,n=s}return i}function bo(i){if(i.Class){if(!i.pack&&!i.write)throw new Error("Extension has no pack or write function");if(i.pack&&!i.type)throw new Error("Extension has no type (numeric code to identify the extension)");yh.unshift(i.Class),Ac.unshift(i)}$x(i)}var Qx=new ys({useRecords:!1}),CP=Qx.pack,LP=Qx.pack;var e0=512,_P=1024;var t0=new ys({structuredClone:!0});bo({Class:An.prototype.constructor,type:1,write(i){return U({},i)},read(i){return Object.setPrototypeOf(i,An.prototype),i}});bo({Class:jt.prototype.constructor,type:2,write(i){return[...i]},read(i){return Object.setPrototypeOf(i,jt.prototype),i}});bo({Class:On.prototype.constructor,type:3,write(i){return[...i]},read(i){return Object.setPrototypeOf(i,On.prototype),i}});bo({Class:Sc.prototype.constructor,type:4,write(i){return i.id},read(i){return new Sc(i)}});bo({Class:wc.prototype.constructor,type:5,write(i){return i.data},read(i){return new wc(i)}});function TP(i){var e=0;if(i.length===0)return e;for(let t=0;t<i.length;t++){let r=i[t];e=(e<<5)-e+r,e=e&e}return e}var Pc;(function(r){function i(n){return t0.pack(n)}r.serialize=i;function e(n){return t0.unpack(n)}r.deserialize=e;function t(n){return TP(i(n)).toString()}r.checksum=t})(Pc||(Pc={}));var Dc;(function(t){t.all=["PointLight","SpotLight","DirectionalLight","HemisphereLight"];function e(r){return t.all.includes(r)}t.is=e})(Dc||(Dc={}));var Bc;(function(t){function i(r){return e(r)}t.defaultData=i;function e(r){if(r==="PointLight")return{type:r,color:kn.white,intensity:1,distance:2e3,decay:1,shadows:!0,shadowResolution:1024,shadowRadius:1,depth:2500,helper:!0};if(r==="SpotLight")return{type:r,color:kn.white,intensity:1,distance:2e3,decay:1,shadows:!0,penumbra:0,angle:30/180*Math.PI,depth:2500,helper:!0};if(r==="DirectionalLight")return{type:r,color:kn.white,intensity:1,shadows:!0,size:2500,depth:2500,helper:!0};throw new Error("not implemented")}})(Bc||(Bc={}));var xs;(function(r){r[r.Front=0]="Front",r[r.Back=1]="Back",r[r.Double=2]="Double"})(xs||(xs={}));var vh;(function(t){t.defaultData={castShadow:!0,receiveShadow:!0};function e(r,n){return r.castShadow===n.castShadow&&r.receiveShadow===n.receiveShadow}t.equals=e})(vh||(vh={}));var bh;(function(t){t.defaultData={flatShading:!1,wireframe:!1,side:0};function e(r,n){return r.flatShading===n.flatShading&&r.side===n.side&&r.wireframe===n.wireframe}t.equals=e})(bh||(bh={}));var Gc;(function(e){e.defaultData=fe(U(U({},bh.defaultData),vh.defaultData),{cloner:null})})(Gc||(Gc={}));var Lr;(function(n){n[n.Left=1]="Left",n[n.Right=2]="Right",n[n.Center=3]="Center",n[n.Justify=4]="Justify"})(Lr||(Lr={}));var gi;(function(r){r[r.Top=1]="Top",r[r.Center=2]="Center",r[r.Bottom=3]="Bottom"})(gi||(gi={}));var ki;(function(r){r[r.None=1]="None",r[r.Upper=2]="Upper",r[r.Lower=3]="Lower"})(ki||(ki={}));var jc;(function(e){e.defaultData={width:100,height:100,horizontalAlign:1,verticalAlign:1,fontSize:16,lineHeight:1.5,letterSpacing:1,text:"",textTransform:1,color:kn.fromHexAndA(6974058,1),alpha:1,font:"roboto_regular"}})(jc||(jc={}));var Zt;(function(n){n[n.Normal=0]="Normal",n[n.Multiply=1]="Multiply",n[n.Screen=2]="Screen",n[n.Overlay=3]="Overlay"})(Zt||(Zt={}));var vs;(function(r){r[r.Linear=0]="Linear",r[r.Radial=1]="Radial",r[r.Polar=2]="Polar"})(vs||(vs={}));var Ec;(function(r){r[r.RepeatWrapping=1e3]="RepeatWrapping",r[r.ClampToEdgeWrapping=1001]="ClampToEdgeWrapping",r[r.MirroredRepeatWrapping=1002]="MirroredRepeatWrapping"})(Ec||(Ec={}));var Rc;(function(n){n[n.UV=0]="UV",n[n.Planar=1]="Planar",n[n.Spherical=2]="Spherical",n[n.Cylindrical=3]="Cylindrical"})(Rc||(Rc={}));var zc;(function(s){s[s.Simplex=0]="Simplex",s[s.SimplexFractal=1]="SimplexFractal",s[s.Ashima=2]="Ashima",s[s.Fbm=3]="Fbm",s[s.Perlin=4]="Perlin"})(zc||(zc={}));var bs;(function(r){function i(n,s){return n==="light"&&s?e(s):t(n)}r.defaultData=i;function e(n){switch(n){case"basic":return{type:"light",category:"basic",alpha:1,visible:!0,mode:0};case"phong":return{category:"phong",specular:{r:.2,g:.2,b:.2},shininess:10,type:"light",alpha:1,visible:!0,mode:0};case"toon":return{category:"toon",specular:{r:.2,g:.2,b:.2},shininess:10,type:"light",alpha:1,visible:!0,mode:0};case"lambert":return{category:"lambert",emissive:{r:.2,g:.2,b:.2,a:1},type:"light",alpha:1,visible:!0,mode:0};case"physical":return{category:"physical",roughness:.2,metalness:.2,reflectivity:.2,type:"light",alpha:1,visible:!0,mode:0}}}function t(n){switch(n){case"texture":return{alpha:1,visible:!0,size:[128,128],mode:0,axis:ds.x,type:"texture",projection:0,texture:{image:"image_0",wrapping:1001,repeat:[1,1],offset:[0,0]},crop:!0};case"color":return{type:"color",alpha:1,visible:!0,mode:0,color:Zr.fromHex(4737101)};case"depth":return{type:"depth",alpha:1,visible:!0,mode:0,gradientType:1,smooth:!1,isVector:!0,isWorldSpace:!1,origin:[0,0,0],direction:[1,0,0],colors:[[1,1,1,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1]],steps:[0,1,1,1,1,1,1,1,1,1],num:2,near:50,far:200};case"normal":return{type:"normal",alpha:1,visible:!0,mode:0,cnormal:[1,1,1]};case"gradient":return{type:"gradient",alpha:1,visible:!0,mode:0,gradientType:0,smooth:!1,colors:[[0,0,0,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1],[1,1,1,1]],steps:[0,1,1,1,1,1,1,1,1,1],num:2,angle:0,offset:[0,0],morph:[0,0]};case"noise":return{type:"noise",alpha:1,visible:!0,mode:0,size:[100,100,100],noiseType:0,scale:1,move:1,colorA:fe(U({},Zr.fromHex(6710886)),{a:1}),colorB:fe(U({},Zr.fromHex(6710886)),{a:1}),colorC:fe(U({},Zr.fromHex(16777215)),{a:1}),colorD:fe(U({},Zr.fromHex(16777215)),{a:1}),distortion:[1,1],fA:[1.7,9.2],fB:[8.3,2.8]};case"fresnel":return{type:"fresnel",alpha:1,visible:!0,mode:0,color:kn.fromHexAndA(16777215,1),bias:.1,scale:1,intensity:2,factor:1};case"rainbow":return{type:"rainbow",alpha:1,visible:!0,mode:0,filmThickness:30,movement:0,wavelengths:[0,0,0],noiseStrength:0,noiseScale:1,offset:[0,0,0]};case"matcap":return{type:"matcap",alpha:1,visible:!0,mode:0,texture:{image:"matcap_0",wrapping:1001,repeat:[1,1],offset:[0,0]}};case"transmission":return{type:"transmission",alpha:1,visible:!0,mode:0,thickness:10,ior:1.5,roughness:1};case"displace":return{type:"displace",displacementType:"noise",noiseType:0,scale:10,movement:1,offset:[0,0,0],intensity:8,visible:!0}}}})(bs||(bs={}));var Ss;(function(c){function i(f){return!f.layers.some(d=>{if(d.data.type==="texture"&&d.data.projection!==0||d.data.type==="depth"&&!d.data.isWorldSpace||d.data.type==="noise"||d.data.type==="displace")return!0})&&!t(f)}c.isMergable=i;function e(f){let h="";return f.layers.forEach(d=>{Object.entries(d.data).forEach(([x,g])=>{h+=`${x}${g}`,Array.isArray(g)?g.forEach(w=>h+=`${w}`):typeof g=="object"?Object.values(g).forEach(w=>{typeof w=="number"?h+=`${w.toFixed(4)}`:h+=`${w}`}):h+=`${g}`})}),h}c.getHash=e;function t(f){let h=0;for(let d of f.layers)"alpha"in d.data&&d.data.type!=="light"&&d.data.type!=="fresnel"&&(h+=(1-h)*d.data.alpha);return h<1}c.isTransparent=t;function r(){return{layers:new jt}}c.defaultEmptyData=r;function n(f="layer1",h="layer2"){return s("phong",f,h)}c.defaultData=n;function s(f,h="layer1",d="layer2"){let x=new jt;return x.push({fi:0,data:bs.defaultData("light",f),id:h}),x.push({fi:1,data:bs.defaultData("color"),id:d}),{layers:x}}c.defaultTwoLayerData=s;function l(f,h="basic",d="layer1",x="layer2"){let g=bs.defaultData("texture");Object.assign(g.texture,{image:f});let w=new jt;return w.push({fi:0,data:g,id:d}),w.push({fi:1,data:bs.defaultData("light",h),id:x}),{layers:w}}c.defaultTwoLayerTextureData=l})(Ss||(Ss={}));var ws;(function(r){function i(){return{points:new jt,roundness:0,shapeHoles:[],isClosed:!1}}r.defaultData=i;function e(n,s){let{points:l}=s;if(l){for(let c of l)if(c.data.position[0]===n[0]&&c.data.position[1]===n[1])return!0}return!1}r.isOverlappingExistingPoint=e;function t(n,s){let l=n.controlNext,c=s.controlPrevious;return n.position[0]===l.position[0]&&n.position[1]===l.position[1]&&s.position[0]===c.position[0]&&s.position[1]===c.position[1]}r.isStraightLine=t})(ws||(ws={}));var Fc;(function(e){function i(t){return t==="PolygonGeometry"||t==="RectangleGeometry"||t==="StarGeometry"||t==="TriangleGeometry"||t==="EllipseGeometry"}e.is2DParametricMesh=i})(Fc||(Fc={}));var Vc;(function(e){function i(t){if(t==="RectangleGeometry")return{width:320,height:320,type:t,cornerRadius:[0,0,0,0],cornerType:0,depth:0,extrudeBevelSize:0,extrudeBevelSegments:1,surfaceMaxCount:1};if(t==="VectorGeometry")return{width:100,height:100,type:t,subdivisions:12,shape:ws.defaultData(),depth:0,extrudeBevelSize:0,extrudeBevelSegments:1,surfaceMaxCount:1};throw new Error("not implemented")}e.defaultData=i})(Vc||(Vc={}));var da;(function(n){n.identity=fe(U({},mc.identity),{hiddenMatrix:Fi.identity});function e(s){return{position:s.position,rotation:s.rotation,scale:s.scale,hiddenMatrix:s.hiddenMatrix}}n.fromObject=e;function t(s,l){return{position:(l==null?void 0:l.position)||s.position,rotation:(l==null?void 0:l.rotation)||s.rotation,scale:(l==null?void 0:l.scale)||s.scale,hiddenMatrix:(l==null?void 0:l.hiddenMatrix)||s.hiddenMatrix}}n.merge=t;function r(s,l){return{position:ms.isEqual(s.position,l.position)?null:l.position,rotation:ms.isEqual(s.rotation,l.rotation)?null:l.rotation,scale:ms.isEqual(s.scale,l.scale)?null:l.scale,hiddenMatrix:Fi.isEqual(s.hiddenMatrix,l.hiddenMatrix)?null:l.hiddenMatrix}}n.diff=r})(da||(da={}));var Hi;(function(e){e.defaultData=U({states:new jt,events:new jt,visible:!0,raycastLock:!1},da.identity)})(Hi||(Hi={}));var r0;(function(e){e.defaultData=U({type:"Empty"},Hi.defaultData)})(r0||(r0={}));var Sh;(function(e){e.defaultData=U(U({type:"Mesh"},Hi.defaultData),Gc.defaultData)})(Sh||(Sh={}));var n0;(function(e){e.defaultData=U(U({type:"TextFrame"},Hi.defaultData),jc.defaultData)})(n0||(n0={}));var Uc;(function(e){e.defaultData=U(U(U({},Hi.defaultData),da.identity),xo.defaultData)})(Uc||(Uc={}));var i0;(function(e){function i(t){return U(U({},Hi.defaultData),Bc.defaultData(t))}e.defaultData=i})(i0||(i0={}));var o0;(function(t){t.defaultCamera=U({position:[0,0,1e3],scale:[1,1,1],rotation:[0,0,0],hiddenMatrix:Fi.identity,name:"Play Camera",visible:!0,raycastLock:!1,states:new jt,events:new jt},xo.defaultData),t.defaultMeshObject=fe(U(U({name:"Rectangle"},Hi.defaultData),Sh.defaultData),{geometry:Vc.defaultData("RectangleGeometry"),material:Ss.defaultTwoLayerData("basic","layer1","layer2")})})(o0||(o0={}));var s0;(function(t){function i(r,n){if(n===void 0)return r;let s=U({},r);return"material"in s&&"material"in n&&n.material&&(s.material=oh(s.material,l=>{if(typeof l!="string")for(let[c,f]of Object.entries(n.material.layers)){let h=l.layers.data(c);h&&yo(h,f)}}).data),s.materials&&n.materials&&(s.materials=oh(s.materials,l=>{var c,f;for(let h=0;h<s.materials.length;h++){let d=n.materials[h];if(typeof d!="string")for(let[x,g]of Object.entries(d.layers)){let w=(f=(c=l[h])==null?void 0:c.layers)==null?void 0:f.data(x);w&&yo(w,g)}}}).data),s}t.patchMaterialState=i;function e(r,n){var l,c;if(n===void 0)return r;let s=U({},r);if(Object.assign(s,da.merge(s,n)),ps.is(r.type)){s.orthographic=U({},s.orthographic),s.perspective=U({},s.perspective);let f=n;((l=f.orthographic)==null?void 0:l.zoom)!==void 0&&(s.orthographic.zoom=f.orthographic.zoom),((c=f.perspective)==null?void 0:c.zoom)!==void 0&&(s.perspective.zoom=f.perspective.zoom)}else if(r.type==="Mesh")s.geometry=U({},s.geometry),Object.assign(s.geometry,n.geometry),s=i(s,n);else if(Dc.is(r.type)){let f=n;s.intensity!==void 0&&(s.intensity=f.intensity),f.color!==void 0&&(typeof f.color=="string"?s.color=f.color:s.color=Zr.clone(f.color))}return s}t.patch=e})(s0||(s0={}));var Yt=5855577;var a0=2857471;var wh=15711266;import{DoubleSide as IP,Mesh as MP,MeshBasicMaterial as AP,ShapeBufferGeometry as OP,Vector2 as PP,Vector3 as DP}from"three";import{FontLoader as BP}from"three/examples/jsm/loaders/FontLoader.js";var Ut=class extends MP{constructor({char:e,originalChar:t,fontFamily:r,letterSpacing:n,fontSize:s,LOD:l=16},c=new AP({color:0,opacity:1,visible:!0,transparent:!0,side:IP})){let f=Ut.loadChar(e,r,l);super(f.geometry,c);this.char=e,this.originalChar=t!=null?t:e,this.fontFamily=r,this.letterSpacing=n,this.fontSize=s,this.LOD=l,this.resolution=f.resolution,this.glyphsHa=f.glyphsHa,this.localPosition=new PP,this.charSize=0,this.geometry.userData={type:"CharacterGeometry",parameters:{char:this.char,fontFamily:this.fontFamily,letterSpacing:this.letterSpacing,fontSize:this.fontSize,lod:this.LOD,resolution:this.resolution,charSize:this.charSize,localPosition:this.localPosition}},this.updateFontSize(this.fontSize)}static get FONTS_PATH(){return Ut._fontPath}static set FONTS_PATH(e){Ut._fontPath=e}updatePosition(e,t){this.localPosition.copy(e);let r=new DP(this.localPosition.x,-this.localPosition.y,0);this.position.copy(r).add(t)}updateFontSize(e){let t=e/this.resolution;this.fontSize=e,this.scale.set(this.fontSize,this.fontSize,1),this.charSize=this.glyphsHa*t*this.letterSpacing}updateFontFamily(e){if(this.fontFamily===e)return;this.fontFamily=e;let t=Ut.loadChar(this.char,e,this.LOD);this.geometry=t.geometry,this.resolution=t.resolution,this.glyphsHa=t.glyphsHa,this.geometry.userData={type:"CharacterGeometry",parameters:{char:this.char,fontFamily:this.fontFamily,letterSpacing:this.letterSpacing,fontSize:this.fontSize,lod:this.LOD,resolution:this.resolution,charSize:this.charSize,localPosition:this.localPosition}},this.updateFontSize(this.fontSize)}updateChar(e){if(this.char===e)return;this.char=e;let t=Ut.loadChar(e,this.fontFamily,this.LOD);this.geometry=t.geometry,this.resolution=t.resolution,this.glyphsHa=t.glyphsHa,this.geometry.userData={type:"CharacterGeometry",parameters:{char:this.char,fontFamily:this.fontFamily,letterSpacing:this.letterSpacing,fontSize:this.fontSize,lod:this.LOD,resolution:this.resolution,charSize:this.charSize,localPosition:this.localPosition}},this.updateFontSize(this.fontSize)}updateLetterSpacing(e){this.letterSpacing!==e&&(this.letterSpacing=e,this.updateFontSize(this.fontSize))}updateLOD(e){if(this.LOD===e)return;this.LOD=e;let t=Ut.loadChar(this.char,this.fontFamily,this.LOD);this.geometry=t.geometry,this.resolution=t.resolution,this.glyphsHa=t.glyphsHa,this.geometry.userData={type:"CharacterGeometry",parameters:{char:this.char,fontFamily:this.fontFamily,letterSpacing:this.letterSpacing,fontSize:this.fontSize,lod:this.LOD,resolution:this.resolution,charSize:this.charSize,localPosition:this.localPosition}},this.updateFontSize(this.fontSize)}clone(){let e={char:this.char,originalChar:this.originalChar,fontFamily:this.fontFamily,letterSpacing:this.letterSpacing,fontSize:this.fontSize,LOD:this.LOD};return new Ut(e).copy(this)}static loadFont(e){return new Promise(function(t,r){Ut.fontCache[e]?t(Ut.fontCache[e]):new BP().load(Ut.FONTS_PATH+e+".json",s=>{Ut.fontCache[e]=s,t(s)},void 0,r)})}static loadChar(e,t,r){if(Ut.charCache[e]){if(Ut.charCache[e][r]&&Ut.charCache[e][r].fontFamily===t)return Ut.charCache[e][r]}else Ut.charCache[e]={};let n=Ut.fontCache[t],s=n.generateShapes(e,1);return Ut.charCache[e][r]={geometry:new OP(s,r),fontFamily:t,resolution:n.data.resolution,glyphsHa:n.data.glyphs[e].ha},Ut.charCache[e][r]}},Rr=Ut;Rr.charCache={},Rr.fontCache={},Rr._fontPath="/_assets/_fonts/";import{DoubleSide as ju,MeshBasicMaterial as Xv,Vector3 as Zv,Object3D as L3}from"three";import{Mesh as nD}from"three";import{BufferGeometry as lk,ConeBufferGeometry as EP,Float32BufferAttribute as ck,Vector2 as uk,Vector3 as fk}from"three";import{BufferGeometry as GP,CylinderBufferGeometry as jP,Float32BufferAttribute as Nh,Vector2 as Pn,Vector3 as kc}from"three";var l0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var l,c,f,h,d;let t=Object.assign({},(l=e==null?void 0:e.parameters)!=null?l:{width:100,radialSegments:64,heightSegments:1,openEnded:!1,thetaStart:0,thetaLength:360,cornerRadius:0,cornerSegments:8,hollow:0},i.parameters),r=t.width/2,n=(c=t.radiusTop)!=null?c:r,s=(f=t.radiusBottom)!=null?f:r;return n===s?(n=r,s=r):n>s?(n=r,s=s*r/n):(n=n*r/s,s=r),{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((h=t.height)!=null?h:t.width),depth:Math.abs((d=t.depth)!=null?d:t.width),radiusTop:n,radiusBottom:s})}}static build(i){let{width:e,depth:t,height:r,radialSegments:n,heightSegments:s,openEnded:l,thetaStart:c,thetaLength:f,radiusTop:h,radiusBottom:d,cornerRadius:x,cornerSegments:g,hollow:w}=i.parameters,S;return x||w?S=new Hc(h,d,r,n,s,l,c,f*Math.PI/180,x,x,g,w):S=new jP(h,d,r,n,s,l,c,f*Math.PI/180),S.scale(1,1,t/e),Object.assign(S,{userData:fe(U({},i),{type:"CylinderGeometry"})})}};function Wi(i,e,t){t.x=i.x*e.x,t.y=i.y,t.z=i.x*e.y}function c0(i){return new Pn(i.y,-i.x)}var Hc=class extends GP{constructor(e,t,r,n,s,l,c,f,h,d,x,g,w=!1){super();this.type="RoundedCylinderBufferGeometry",e=e!==void 0?e:1,t=t!==void 0?t:1,r=r||1,n=Math.floor(n)||8,s=Math.floor(s)||1,l=l!==void 0?l:!1,c=c!==void 0?c:0,f=f!==void 0?f:Math.PI*2,l&&(h=0,d=0);let S=[],D=[],C=[],G=[],B=0,P=r/2,W=new kc,M=new kc;w&&e==0&&(e=h),w&&t==0&&(t=d);let q=new Pn(e,P),E=new Pn(t,-P),b=null,R=null,T=null,z=null,A=q.clone().sub(E),$=0,he=0,re=0;g>0&&($=Math.min(e,t)*(1-g),he=e-$,re=t-$);let Ne=q.clone();Ne.x-=$;let ye=Math.PI-A.angle(),Me=A.angle(),Fe=Math.tan(Me/2),k=Math.tan(ye/2),H=Fe+k,_=g?H:k,J=g?H:Fe;if(h=Math.min(h,(e-he)/_,A.length()/H),d=Math.min(d,(t-re)/J,A.length()/H),h>0){let K=h/Fe;b=q.clone().sub(new Pn(K,h)),g&&(T=b.clone(),T.x-=$-H*h),q.sub(A.clone().setLength(K))}if(d>0){let K=d/k;R=E.clone().sub(new Pn(K,-d)),E.add(A.clone().setLength(K)),g&&(z=R.clone(),z.x-=$-H*d,Ne.sub(A.clone().setLength(K)))}A=q.clone().sub(E);let ee=A.length()<.5,oe=[];for(let K=0;K<=n;K++){let ae=[],ne=K/n,Ce=ne*f+c,Y=new Pn(Math.sin(Ce),Math.cos(Ce));z&&R?(se(ae,ne,Y,ye,d,z,-1,!0),se(ae,ne,Y,Me,d,R,-1,!1)):R?(ce(ae,Y,R.x,0,-1),se(ae,ne,Y,Me,d,R,-1,!1)):l||ce(ae,Y,t,re,-1);let le=c0(A).normalize();if(Wi(le,Y,W),!ee)for(let pe=0;pe<=s;pe++){let xe=pe/s,_e=A.clone().multiplyScalar(xe).add(E);Wi(_e,Y,M),D.push(M.x,M.y,M.z),C.push(W.x,W.y,W.z),G.push(ne,.5+M.y/r),ae.push(B++)}if(T&&b?(se(ae,ne,Y,ye,h,b,1,!1),se(ae,ne,Y,Me,h,T,1,!0)):b?(se(ae,ne,Y,ye,h,b,1,!1),ce(ae,Y,b.x,0,1)):l||ce(ae,Y,e,he,1),g&&!ee){let pe=c0(A).multiplyScalar(-1).normalize();Wi(pe,Y,W);for(let xe=0;xe<=s;xe++){let _e=xe/s,de=A.clone().multiplyScalar(-_e).add(Ne);Wi(de,Y,M),D.push(M.x,M.y,M.z),C.push(W.x,W.y,W.z),G.push(ne,.5+M.y/r),ae.push(B++)}}g&&!l&&ae.push(ae[0]),oe.push(ae)}for(let K=0;K<oe.length-1;K++)for(let ae=0;ae<oe[0].length-1;ae++){if(l&&g&&ae==s)continue;let ne=oe[K][ae],Ce=oe[K+1][ae],Y=oe[K+1][ae+1],le=oe[K][ae+1],pe=D[Y*3+0],xe=D[Y*3+2];S.push(ne,Ce,le),(pe!=0||xe!=0)&&S.push(Ce,Y,le)}f<Math.PI*2&&(ue(-1,oe[0],c),ue(1,oe[oe.length-1],c+f)),this.setIndex(S),this.setAttribute("position",new Nh(D,3)),this.setAttribute("normal",new Nh(C,3)),this.setAttribute("uv",new Nh(G,2));function se(K,ae,ne,Ce,Y,le,pe,xe){for(let _e=0;_e<x+1;_e++){let de=_e/x,we=pe<0?de:1-de;xe&&(we-=1),we*=Ce;let Ve=new Pn(Math.sin(we),Math.cos(we)*pe),Ge=Ve.clone().multiplyScalar(Y).add(le);Wi(Ge,ne,M),D.push(M.x,M.y,M.z),Wi(Ve,ne,W),C.push(W.x,W.y,W.z),G.push(ae,.5+M.y/r),K.push(B++)}}function ce(K,ae,ne,Ce,Y){let le=new kc,pe=new Pn,xe=[ne,Ce];Y<0&&xe.reverse();for(let _e of xe)pe.set(_e,P*Y),Wi(pe,ae,le),D.push(le.x,le.y,le.z),C.push(0,Y,0),G.push(.5,.5),K.push(B++)}function ue(K,ae,ne){let Ce=new Pn(Math.sin(ne),Math.cos(ne)),Y=new Pn(-Math.cos(ne),Math.sin(ne)),le=new kc,pe=K<0?(de,we,Ve)=>S.push(de,we,Ve):(de,we,Ve)=>S.push(de,Ve,we),xe=new Pn((e+t+he+re)/4,0);Wi(xe,Ce,le),D.push(le.x,le.y,le.z),C.push(Y.x,0,Y.y),G.push(.5,.5);let _e=B++;for(let de of ae){let we=D.slice(de*3,de*3+3);D.push(...we),C.push(Y.x,0,Y.y);let Ve=G.slice(de*2,de*2+2);G.push(...Ve),B++}for(let de=_e+1;de<B-1;de++)pe(_e,de,de+1);pe(_e,B-1,_e+1)}}};var u0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,radialSegments:32,heightSegments:8,openEnded:!1,thetaStart:0,thetaLength:360,cornerRadiusTop:0,cornerRadiusBottom:0,cornerSegments:8},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e,depth:t,height:r,radialSegments:n,heightSegments:s,openEnded:l,thetaStart:c,thetaLength:f,cornerRadiusTop:h,cornerRadiusBottom:d,cornerSegments:x}=i.parameters,g;return h>0||d>0||f<360?g=new Hc(0,e/2,r,n,s,l,c,f*Math.PI/180,h,d,x,0,!0):g=new EP(e/2,r,n,s,l),g.scale(1,1,t/e),Object.assign(g,{userData:fe(U({},i),{type:"ConeGeometry"})})}};import{BoxBufferGeometry as RP,BufferGeometry as zP,Float32BufferAttribute as Ch,Vector3 as ma}from"three";var f0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,widthSegments:1,heightSegments:1,depthSegments:1,cornerRadius:0,cornerSegments:8},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e,height:t,depth:r,widthSegments:n,heightSegments:s,depthSegments:l,cornerRadius:c,cornerSegments:f}=i.parameters,h;return c==0?h=new RP(e,t,r,n,s,l):h=new h0(e,t,r,n,s,l,c,f),Object.assign(h,{userData:fe(U({},i),{type:"CubeGeometry"})})}},Lh=Math.PI/2,h0=class extends zP{constructor(e=1,t=1,r=1,n=1,s=1,l=1,c=0,f=4){super();this.type="BoxBufferGeometry";let h=this;n=Math.floor(n),s=Math.floor(s),l=Math.floor(l),f=Math.floor(f),c=Math.min(c,e/2,t/2,r/2);let d=[],x=[],g=[],w=[],S=0,D=0;C("z","y","x",-1,-1,r,t,e,l,s,0),C("z","y","x",1,-1,r,t,-e,l,s,1),C("x","z","y",1,1,e,r,t,n,l,2),C("x","z","y",1,-1,e,r,-t,n,l,3),C("x","y","z",1,-1,e,t,r,n,s,4),C("x","y","z",-1,-1,e,t,-r,n,s,5),c>0&&(G("z","y","x",-1,-1,1,r,t,e,l,0),G("z","y","x",1,-1,-1,r,t,e,l,1),G("z","y","x",-1,1,-1,r,t,e,l,1),G("z","y","x",1,1,1,r,t,e,l,0),G("x","y","z",-1,-1,-1,e,t,r,n,0),G("x","y","z",1,-1,1,e,t,r,n,1),G("x","y","z",-1,1,1,e,t,r,n,0),G("x","y","z",1,1,-1,e,t,r,n,1),G("y","x","z",-1,-1,1,t,e,r,s,0),G("y","x","z",1,-1,-1,t,e,r,s,1),G("y","x","z",1,1,1,t,e,r,s,1),G("y","x","z",-1,1,-1,t,e,r,s,0),B(1,1,1),B(-1,1,1),B(1,-1,1),B(-1,-1,1),B(1,1,-1),B(-1,1,-1),B(1,-1,-1),B(-1,-1,-1)),this.setIndex(d),this.setAttribute("position",new Ch(x,3)),this.setAttribute("normal",new Ch(g,3)),this.setAttribute("uv",new Ch(w,2));function C(P,W,M,q,E,b,R,T,z,A,$){let he=(b-2*c)/z,re=(R-2*c)/A,Ne=b/2-c,ye=R/2-c,Me=T/2,Fe=z+1,k=A+1,H=0,_=0,J=new ma;for(let ee=0;ee<k;ee++){let oe=ee*re-ye;for(let se=0;se<Fe;se++){let ce=se*he-Ne;J[P]=ce*q,J[W]=oe*E,J[M]=Me,x.push(J.x,J.y,J.z),J[P]=0,J[W]=0,J[M]=T>0?1:-1,g.push(J.x,J.y,J.z),w.push(se/z),w.push(1-ee/A),H+=1}}for(let ee=0;ee<A;ee++)for(let oe=0;oe<z;oe++){let se=S+oe+Fe*ee,ce=S+oe+Fe*(ee+1),ue=S+(oe+1)+Fe*(ee+1),K=S+(oe+1)+Fe*ee;d.push(se,ce,K),d.push(ce,ue,K),_+=6}h.addGroup(D,_,$),D+=_,S+=H}function G(P,W,M,q,E,b,R,T,z,A,$){let he=(R-2*c)/A,re=R/2-c,Ne=T/2-c,ye=z/2,Me=A+1,Fe=0,k=0,H=new ma,_=new ma;for(let J=0;J<f+1;J++){let ee=J/f*Lh,oe=Math.sin(ee)*c,se=(1-Math.cos(ee))*c,ce=Math.sin(ee),ue=Math.cos(ee);H[W]=(Ne+oe)*E,H[M]=(ye-se)*b,_[P]=0,_[W]=ce*Math.sign(H[W]),_[M]=ue*Math.sign(H[M]);for(let K=0;K<Me;K++){let ae=K*he-re;H[P]=ae*q,x.push(H.x,H.y,H.z),g.push(_.x,_.y,_.z),w.push(K/A),w.push(0),Fe+=1}}for(let J=0;J<f;J++)for(let ee=0;ee<A;ee++){let oe=S+ee+Me*J,se=S+ee+Me*(J+1),ce=S+(ee+1)+Me*(J+1),ue=S+(ee+1)+Me*J;d.push(oe,se,ue),d.push(se,ce,ue),k+=6}h.addGroup(D,k,$),D+=k,S+=Fe}function B(P,W,M){let q=new ma,E=new ma(e/2,t/2,r/2);E.subScalar(c);let b=[],R=P*W*M>0?(z,A,$)=>d.push(z,A,$):(z,A,$)=>d.push(z,$,A);for(let z=0;z<=f;z++){let A=[],$=Lh*(1-z/f),he=Math.cos($),re=Math.sin($),Ne=0;for(let ye=0;ye<=z;ye++){let Me=Math.cos(Ne),Fe=Math.sin(Ne);q.x=he*Me,q.y=re,q.z=he*Fe;let k=E.clone().addScaledVector(q,c);x.push(P*k.x,W*k.y,M*k.z),g.push(P*q.x,W*q.y,M*q.z),w.push(0,0),A.push(S++),Ne+=Lh/z}b.push(A)}let T=b.length-1;for(let z=0;z<T;z++){let A=b[z],$=b[z+1],he=A.length-1;R(A[0],$[1],$[0]);for(let re=1;re<=he;re++)R(A[re-1],A[re],$[re]),R(A[re],$[re+1],$[re])}}}};import{BufferGeometry as FP,Float32BufferAttribute as _h,Triangle as VP,Vector3 as yi,Vector2 as Th}from"three";var So=class extends FP{constructor(e=[],t=[],r="",n=1,s=.2,l=4){super();this.type="PolyhedronGeometryRound";let c=[],f=[],h=[];d(),x(),this.setAttribute("position",new _h(c,3)),this.setAttribute("normal",new _h(h,3)),this.setAttribute("uv",new _h(f,2));return;function d(){var Fe;s=Math.min(1-1e-5,s),s==0&&(l=0);let w={IcosahedronGeometry:5,DodecahedronGeometry:3,HexahedronGeometry:3,OctahedronGeometry:4,TetrahedronGeometry:3}[r],S=new yi,D=S.clone(),C=new VP,G=s*n,B=n-G,P=l+1,W=new yi,M=(k,H)=>W.subVectors(k,H).normalize(),q=(k,H)=>Array(k).fill(void 0).map(H),E=q(e.length/3,(k,H)=>new yi().fromArray(e,H*3).setLength(n)),b=[],R=1e6;for(let k=0;k<E.length;k++){let H=E[k],_=[],J,ee,oe,se=1e10,ce=-1;for(;(ce=t.indexOf(k,ce+1))!=-1;){let ne=ce-ce%3;J=t[ne+(ce+1)%3],ee=t[ne+(ce+2)%3],oe=H.distanceToSquared(E[J]),se=Math.min(se,oe),_.push([J,ee,oe])}se+=1e-6;let ue=[],K=0,ae=_.length;for(let ne=0;ne<ae;ne++){[J,ee,oe]=_[K];let Ce=((Fe=b[J])==null?void 0:Fe.includes(k))==!0;oe<=se&&ue.push(J+ +Ce*R),K=_.findIndex(Y=>Y[0]==ee)}b.push(ue)}let T=[];{let k=0,H=0,_,J,ee=w==3;for(let oe=0;oe<=l;oe++){_=oe*(oe+1)/2,J=(oe+1)*(oe+2)/2;for(let se=0;se<l-oe;se++)[k,H]=[_+se+oe+2,J+se+oe+3],T.push(_,J,...ee?[H,_]:[k,J],H,k),[_,J]=[k,H];T.push(_,J,_+l+2)}}let z=S.clone(),A=S.clone(),$=S.clone(),he=S.clone(),re=S.clone(),Ne=[],ye=q(E.length,()=>q(w,()=>S.clone()));for(let k=0;k<E.length;k++){S.copy(E[k]).normalize(),z.copy(S).multiplyScalar(B);let H=b[k];for(let ue=0;ue<H.length;ue++){let K=H[ue],ae=H[(ue+1)%w];C.setFromPointsAndIndices(E,k,K%R,ae%R),C.b.sub(C.a).setLength(1e10).add(C.a),C.c.sub(C.a).setLength(1e10).add(C.a),C.closestPointToPoint(z,ye[k][ue])}let _=[],J=[],ee=[],oe=new yi;l==0&&[...ye[k]].reduce((ue,K)=>ue.add(K),oe).multiplyScalar(1/w);for(let ue=0;ue<w;ue++){let K=[],ae=(ue-1+w)%w,ne=ye[k][ae],Ce=ye[k][ue];S.copy(ne).sub(z),D.copy(Ce).sub(z);let Y=z.angleTo(S),le=S.angleTo(D),pe=Math.cos(Y)*G;l==0?A.copy(oe):A.copy(z).setLength(B+pe),J.push(pe);let xe=[A,ne,Ce];for(let _e=0;_e<2;_e++){let de=xe[_e],we=xe[_e+1];he.subVectors(de,z),re.subVectors(we,z),$.crossVectors(he,re).normalize();for(let Ve=0;Ve<P;Ve++){let Ge=[Y,le][_e]*Ve/P;S.copy(he).applyAxisAngle($,Ge).add(z),_.push(S.clone()),_e&&(M(S,z),K.push([Ve==0?de:S.clone(),W.clone()]))}_e&&(M(we,z),K.push([we,W.clone()]))}ee.push(K)}Ne.push(ee);let se=2*P,ce=2;for(let ue=0;ue<w;ue++){let K=se*ue,ae=se*((ue+1)%w),ne=[_[K]];for(let Y=1;Y<P;Y++){he=_[K+Y],re=_[ae+Y],ne.push(he);for(let le=1,pe=Y-ce+1;le<=pe;le++)S.lerpVectors(he,re,le/(pe+1)),S.sub(z).setLength(J[ue]).add(z),ne.push(S.clone());ne.push(re)}for(let Y=0;Y<P;Y++)ne.push(_[Y+P+K]);ne.push(_[ae+P]);let Ce=T.map(Y=>ne[Y]);c.push(...Ce.map(Y=>[Y.x,Y.y,Y.z]).flat()),h.push(...Ce.map(Y=>(M(Y,z),[W.x,W.y,W.z])).flat())}}let Me=[];for(let k=0;k<b.length;k++)for(let H=0;H<w;H++){let _=b[k][H];if(_<R){let J=b[_].findIndex(se=>se%R==k),ee=Ne[k][H],oe=Ne[_][J];for(let se=0;se<P;se++){let ce=ee[se],ue=oe[P-se],K=ee[se+1],ae=oe[P-(se+1)];[ce,ue,K,K,ue,ae].forEach(ne=>{c.push(ne[0].x,ne[0].y,ne[0].z),h.push(ne[1].x,ne[1].y,ne[1].z)})}Me.push(ee[0][0],oe[P][0],ee[P][0],oe[0][0])}}for(;Me.length;){let k,H,_,J;[k,H]=Me.splice(0,2);let ee=[k];for(;k!=H;)ee.push(H),_=Me.indexOf(H),J=_%2,H=Me.splice(_-J,2)[1-J];W.subVectors(ee[0],ee[1]).cross(S.subVectors(ee[0],ee[2])).normalize();let oe=W.dot(ee[0])<0;oe&&W.negate();for(let se=1;se<=ee.length-2;se++)[ee[se+ +oe],ee[se+1-+oe],ee[0]].forEach(ce=>{c.push(ce.x,ce.y,ce.z),h.push(W.x,W.y,W.z)})}}function x(){let g=new yi;for(let E=0;E<c.length;E+=3){g.x=c[E+0],g.y=c[E+1],g.z=c[E+2];let b=M(g)/2/Math.PI+.5,R=q(g)/Math.PI+.5;f.push(b,1-R)}let w=new yi,S=new yi,D=new yi,C=new yi,G=new Th,B=new Th,P=new Th,W=(E,b,R,T)=>{T<0&&E.x===1&&(f[b]=E.x-1),R.x===0&&R.z===0&&(f[b]=T/2/Math.PI+.5)};for(let E=0,b=0;E<c.length;E+=9,b+=6){w.set(c[E+0],c[E+1],c[E+2]),S.set(c[E+3],c[E+4],c[E+5]),D.set(c[E+6],c[E+7],c[E+8]),G.set(f[b+0],f[b+1]),B.set(f[b+2],f[b+3]),P.set(f[b+4],f[b+5]),C.copy(w).add(S).add(D).divideScalar(3);let R=M(C);W(G,b+0,w,R),W(B,b+2,S,R),W(P,b+4,D,R)}for(let E=0;E<f.length;E+=6){let b=f[E+0],R=f[E+2],T=f[E+4],z=Math.max(b,R,T),A=Math.min(b,R,T);z>.9&&A<.1&&(b<.2&&(f[E+0]+=1),R<.2&&(f[E+2]+=1),T<.2&&(f[E+4]+=1))}function M(E){return Math.atan2(E.z,-E.x)}function q(E){return Math.atan2(-E.y,Math.sqrt(E.x*E.x+E.z*E.z))}}}static fromJSON(e){return new So(e.vertices,e.indices,e.radius,e.corner,e.cornerSides)}};import{DodecahedronBufferGeometry as UP}from"three";var p0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,detail:0,corner:0,cornerSides:4},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e,height:t,depth:r,detail:n,corner:s,cornerSides:l}=i.parameters,c=n===0&&s!==0?new Wc(e*.5,s,l):new UP(e*.5,n);return c.scale(1,t/e,r/e),Object.assign(c,{userData:fe(U({},i),{type:"DodecahedronGeometry"})})}},Wc=class extends So{constructor(e=1,t=.2,r=4){let n=(1+Math.sqrt(5))/2,s=1/n,l=[-1,-1,-1,-1,-1,1,-1,1,-1,-1,1,1,1,-1,-1,1,-1,1,1,1,-1,1,1,1,0,-s,-n,0,-s,n,0,s,-n,0,s,n,-s,-n,0,-s,n,0,s,-n,0,s,n,0,-n,0,-s,n,0,-s,-n,0,s,n,0,s],c=[3,11,7,3,7,15,3,15,13,7,19,17,7,17,6,7,6,15,17,4,8,17,8,10,17,10,6,8,0,16,8,16,2,8,2,10,0,12,1,0,1,18,0,18,16,6,10,2,6,2,13,6,13,15,2,16,18,2,18,3,2,3,13,18,1,9,18,9,11,18,11,3,4,14,12,4,12,0,4,0,8,11,9,5,11,5,19,11,19,7,19,5,14,19,14,4,19,4,17,1,12,14,1,14,5,1,5,9],f="DodecahedronGeometry";super(l,c,f,e,t,r);this.type=f}static fromJSON(e){return new Wc(e.radius,e.corner,e.cornerSides)}};import{EventDispatcher as QP,Plane as e2,Shape as L0,Vector2 as xi,Vector3 as t2,MathUtils as Bh,LineCurve as Gh,QuadraticBezierCurve as _0,CubicBezierCurve as Jc}from"three";import{CubicBezierCurve as qc,EllipseCurve as kP,LineCurve as $c,LineCurve3 as HP,MathUtils as WP,QuadraticBezierCurve as Ih,SplineCurve as qP,Vector2 as Dn,Vector3 as d0}from"three";var ga=1e-12,ya=class{constructor(e){this.position=new Dn;this.startPosition=new Dn;this.uuid=WP.generateUUID();this.position=e.clone()}start(){this.reset()}reset(){this.startPosition.copy(this.position)}applyOffset(e){this.position.copy(this.startPosition).add(e)}copy(e){return this.position.copy(e.position),this.startPosition.copy(e.startPosition),this}clone(){return new ya(this.position).copy(this)}toJSON(){return[this.position.x,this.position.y]}},xa=class extends ya{constructor(e){super(e.position);this.parent=e}copy(e){return super.copy(e),this}clone(){return new xa(this.parent).copy(this)}},Kn=class extends ya{constructor(e,t){super(t);this.controls=[];this.roundness=0;this.areControlsDirectionsMirrored=!0;this.uuid=e,this.controls.push(new xa(this),new xa(this))}static create(e,t){let r=new Kn(e,new Dn(...t.position));return r.controls[0].position.set(...t.controlPrevious.position),r.controls[1].position.set(...t.controlNext.position),r.roundness=t.roundness,r.areControlsDirectionsMirrored=t.areControlsDirectionsMirrored,r}getOppositeControl(e){let t=this.controls.indexOf(e);return t===0?this.controls[1]:t===1?this.controls[0]:null}applyOffsetToControls(e,t=1){for(let r=0,n=this.controls.length;r<n;r++){let s=this.controls[r];this.position.distanceTo(s.position)<=t?s.position.copy(this.position):s.applyOffset(e)}}controlsMoved(){return!(this.position.equals(this.controls[0].position)&&this.position.equals(this.controls[1].position))}copy(e){return super.copy(e),this.controls[0].copy(e.controls[0]),this.controls[1].copy(e.controls[1]),this.roundness=e.roundness,this.uuid=e.uuid,this}clone(){return new Kn(this.uuid,this.position).copy(this)}toJSON(){return super.toJSON().concat(this.controls[0].toJSON(),this.controls[1].toJSON(),[this.roundness])}},Mh=i=>i,va=new Dn,Ah=new Dn,$P=new Dn,JP=new Dn,KP=new Dn,XP=new Dn,m0=new d0,g0=new d0;function y0(i){let e=new Dn;e.addVectors(i.v0,va.subVectors(i.v1,i.v0).multiplyScalar(2/3));let t=new Dn;return t.addVectors(i.v2,Ah.subVectors(i.v1,i.v2).multiplyScalar(2/3)),new qc(i.v0,e,t,i.v2)}function ba(i,e,t=Number.EPSILON){return Math.abs(i-e)<t}function ZP(i,e,t=Number.EPSILON){return i.distanceTo(e)<t}function YP(i,e,t=Number.EPSILON){return i.distanceTo(e)<t}function Oh(i,e,t){let r=Math.sqrt(Math.pow(e.x-i.x,2)+Math.pow(e.y-i.y,2)),n=Math.sqrt(Math.pow(e.x-t.x,2)+Math.pow(e.y-t.y,2)),s=Math.sqrt(Math.pow(t.x-i.x,2)+Math.pow(t.y-i.y,2));return Math.acos((n*n+r*r-s*s)/(2*n*r))}function x0(i,e,t,r,n){let s=Math.sqrt(Math.pow(e.x-i.x,2)+Math.pow(e.y-i.y,2)),l=(i.y+e.y)/2,c=(i.x+e.x)/2,f=Math.sqrt(Math.pow(t,2)-Math.pow(s/2,2))*(i.y-e.y)/s,h=Math.sqrt(Math.pow(t,2)-Math.pow(s/2,2))*(e.x-i.x)/s;return r.set(c+f,l+h),n.set(c-f,l-h),[r,n]}function v0(i,e,t){let r=i.distanceTo(t),n=e.distanceTo(t);return r<n?e:i}function b0(i,e,t,r,n,s){let l=e.x-i.x,c=e.y-i.y,f=t.x-i.x,h=t.y-i.y,d=Math.sqrt((l+f)*(l+f)+(c+h)*(c+h)),x;return Oh(e,i,t)>Math.PI&&(d*=-1),ba(h,c)?x=(c+h)*(r/d-.5)*8/3/(l-f):x=(l+f)*(r/d-.5)*8/3/(h-c),n.set(e.x-x*c,e.y+x*l),s.set(t.x+x*h,t.y-x*f),[n,s]}function Ph(i,e){return i.position.equals(i.controls[1].position)&&e.position.equals(e.controls[0].position)}function S0(i,e,t,r,n=.5){let s=va.subVectors(e,i).multiplyScalar(n).add(i),l=Ah.subVectors(t,e).multiplyScalar(n).add(e),c=$P.subVectors(r,t).multiplyScalar(n).add(t),f=s,h=JP.subVectors(l,s).multiplyScalar(n).add(s),d=KP.subVectors(c,l).multiplyScalar(n).add(l),x=c,g=XP.subVectors(d,h).multiplyScalar(n).add(h);return[i.x,i.y,f.x,f.y,h.x,h.y,g.x,g.y,d.x,d.y,x.x,x.y,r.x,r.y]}function w0(i,e,t=12,r=!0){let n=g0.set(0,0,0),s,l=0,c=[];for(let f=0;f<e.length;f++){let h=Mh(e[f]),d=va,x=qi(h,t);c.push(x);for(let g=0;g<=x;g++)if(h instanceof qc||h instanceof Ih||h instanceof $c){if(h.getPoint(g/x,d),n.set(d.x,d.y,0),s!==void 0&&YP(s,n))continue;s===void 0&&(s=m0),s.copy(n),i.setXYZ(l,n.x,n.y,n.z),l++}}return r&&l>1&&!(i.getX(l-1)===i.getX(0)&&i.getY(l-1)===i.getY(0)&&i.getZ(l-1)===i.getZ(0))&&(i.setXYZ(l,i.getX(0),i.getY(0),i.getZ(0)),l++),i}function N0(i,e,t,r=12,n=!0){let s=g0.set(0,0,0),l=0,c=[];for(let f=0;f<e.length;f++){if(t[f]===!1)continue;let h,d=Mh(e[f]),x=va,g=qi(d,r);c.push(g);for(let w=0;w<=g;w++)if(d instanceof qc||d instanceof Ih||d instanceof $c){if(d.getPoint(w/g,x),s.set(x.x,x.y,0),h==null?void 0:h.equals(s))continue;h===void 0?h=m0:(i.setXYZ(l,h.x,h.y,h.z),l++,i.setXYZ(l,s.x,s.y,s.z),l++),h.copy(s)}}return n&&l>1&&!(i.getX(l-1)===i.getX(0)&&i.getY(l-1)===i.getY(0)&&i.getZ(l-1)===i.getZ(0))&&(i.setXYZ(l,i.getX(0),i.getY(0),i.getZ(0)),l++),c}function Dh(i,e=12,t=!1){let r=[];for(let n=0,s=i.length;n<s;n++){let l=i[n],c=0;if(t&&l.roundedCurveCorner!==void 0){let f=qi(l.roundedCurveCorner,e)*.5;n>0&&(r[n-1]+=f),c+=f}l.curveAfter!==void 0&&(c+=qi(l.curveAfter,e)),r.push(c)}return i.length>0&&t&&i[0].roundedCurveCorner!==void 0&&(r[i.length-1]+=qi(i[0].roundedCurveCorner,e)*.5),r}function qi(i,e=12){return i&&i instanceof kP?e*2:i&&(i instanceof $c||i instanceof HP)?1:i&&i instanceof qP?e*i.points.length:e}function C0(i,e,t=12,r=!0){let n,s=0;for(let l=0;l<e.length;l++){let c=Mh(e[l]),f=qi(c,t),h=va;for(let d=0;d<=f;d++)if(c instanceof qc||c instanceof Ih||c instanceof $c){if(c.getPoint(d/f,h),n!==void 0&&ZP(n,h,ga))continue;n===void 0&&(n=Ah),n.copy(h),i.push(h.x,h.y),s++}}return ba(i[0],i[i.length-2],ga)&&ba(i[1],i[i.length-1],ga)&&(i.pop(),i.pop()),r&&s>1&&!(ba(i[s-1],i[1],ga)&&ba(i[s-2],i[0],ga))&&(i.push(i[0],i[1]),s++),i}var jh=new xi,r2=new xi,n2=new xi,i2=new xi,o2=new xi,s2=new xi,st=class extends L0{constructor(e=100,t=100){super();this.points=[];this.shapeHoles=[];this.eventDispatcher=new QP;this.plane=new e2(new t2(0,0,-1));this.subdivision=0;this.controlSnapDistance=4;this.pointIDs=0;this.isMesh2D=!1;this._roundness=0;this.isClosed=!1;this.useCubicForRoundedCorners=!0;this.uuid=Bh.generateUUID();this.needsUpdate=!1;this.roundedCurves=[];this._width=e,this._height=t}static createFromState(e,t,r){let n=new st;return n.isClosed=e.isClosed,n.points=e.points.map(s=>Kn.create(s.id,s.data)),typeof e.roundness=="number"&&(n.roundness=e.roundness),n.shapeHoles=e.shapeHoles.map(s=>st.createFromState(s)),t!==void 0&&r!==void 0&&n.applySize(t,r),n.update(),n}get width(){return this._width}get height(){return this._height}get roundness(){return this._roundness}set roundness(e){if(this._roundness!==e){this._roundness=e;for(let t=0,r=this.points.length;t<r;t++)this.points[t].roundness=e;this.needsUpdate=!0}}getPointsIndexesByIds(e){return e.map(t=>this.getPointIndexById(t)).filter(t=>t>=0)}getPointIndexById(e){return this.points.findIndex(t=>t.uuid===e)}getLineIndexById(e){return this.getPointIndexById(e)}getBezierPoint(e){if(e<=this.points.length-1)return this.points[e];if(this.shapeHoles.length>0)for(let t=0,r=this.shapeHoles.length;t<r;t++){let n=this.shapeHoles[t],s=e-this.points.length;if(s<=n.points.length-1)return n.points[s]}throw new Error("This shape does not have a point for this index: "+e)}getBezierPointIndex(e){let t=this.points.indexOf(e);if(t>=0)return t;if(t=this.points.length,this.shapeHoles.length>0)for(let r=0,n=this.shapeHoles.length;r<n;r++){let s=this.shapeHoles[r],l=s.points.indexOf(e);if(l>=0)return t+l;t+=s.points.length}return-1}getAllPoints(){let e=[].concat(...this.shapeHoles.map(t=>t.points));return[...this.points,...e]}applySize(e,t){e===0&&(e=.001),t===0&&(t=.001),this._width=e,this._height=t}applyScale(e,t){let r=jh.set(e,t);for(let n=0,s=this.points.length;n<s;n++){let l=this.points[n];l.position.multiply(r),l.controls[0].position.multiply(r),l.controls[1].position.multiply(r)}for(let n=0,s=this.shapeHoles.length;n<s;n++)this.shapeHoles[n].applyScale(e,t);this._update(!1)}createPoint(e,t=0,r=Bh.generateUUID()){let n;e instanceof xi?n=e:n=new xi(e,t);let s=new Kn(r,n);return s.roundness=this.roundness,s}addPoint(e){this.points.push(e),this.needsUpdate=!0}addPointAt(e,t){this.points.splice(t,0,e),this.needsUpdate=!0}getPointByUuid(e){for(let t=0,r=this.points.length;t<r;t++){let n=this.points[t];if(n.uuid===e)return n}}getFirstPoint(){return this.points[0]}getLastPoint(){return this.points[this.points.length-1]}removePoint(e){let t=this.points.indexOf(e);t>=0&&this.points.splice(t,1),this.needsUpdate=!0}removePointById(e){let t=this.points.find(r=>r.uuid===e);t&&this.removePoint(t)}update(e=!0){for(let t=0,r=this.shapeHoles.length;t<r;t++)this.shapeHoles[t].update(!1);this._update(e)}extractShapePointsToBuffer(e,t=12,r=!1){this.subdivision=t,this.curveDivisions===void 0&&this.computeCurveDivisions(t);let n=r?this.roundedCurveDivisions:this.curveDivisions;return w0(e,r?this.roundedCurves:this.curves,t,this.autoClose),n.reduce((s,l)=>s+l,0)+1}computeCurveDivisions(e=12){return this.curveDivisions=Dh(this.points,e,!1),this.roundedCurveDivisions=Dh(this.points,e,!0),this.curveDivisions}extractFilteredShapePointsToBuffer(e,t,r=12){return N0(e,this.curves,t,r,this.autoClose).reduce((s,l)=>s+l,0)*2}extractShapePointsToFlatArray(e,t=12){return this.subdivision=t,this.curveDivisions===void 0&&this.computeCurveDivisions(t),C0(e,this.roundedCurves,t,this.autoClose)}getCurveIndexFromVertexId(e,t=!1){let r=0;this.curveDivisions===void 0&&this.computeCurveDivisions(this.subdivision);let n=t?this.roundedCurveDivisions:this.curveDivisions,s=0;t&&this.points[0].roundedCurveCorner!==void 0&&(s=qi(this.points[0].roundedCurveCorner,this.subdivision)*.5);let l=e-s;l<0&&(l+=n.reduce((c,f)=>c+f,0));for(let c=0,f=n.length;c<f;c++){let h=n[c];if(l<r+h)return[c,(l-r+1)/h];r+=h}return[0,1]}getCurveT(e,t,r){let n=this.points[e],s=this.points[e>=this.points.length-1?0:e+1],l=this.curveDivisions,c=l[e];if(Ph(n,s)){let d=n.position.distanceTo(s.position);return n.position.distanceTo(jh.set(r.x,r.y))/d}let f=0;for(let d=0;d<e;d++)f+=l[d];return(t-f)/c}dispose(){this.eventDispatcher=null}_applyCurveForPoint(e,t){Ph(t,e)?this.lineTo(e.position.x,e.position.y):this.bezierCurveTo(t.controls[1].position.x,t.controls[1].position.y,e.controls[0].position.x,e.controls[0].position.y,e.position.x,e.position.y);let r=this.curves[this.curves.length-1];e.curveBefore=r,t.curveAfter=r;let n=r.clone();e.roundedCurveBefore=n,t.roundedCurveAfter=n,e.roundedCurveCorner=void 0,this.roundedCurves.push(n)}_update(e=!0){var r;if(this.curves=[],this.roundedCurves=[],!this.points.length)return;for(let n=0,s=this.points.length;n<s;n++){let l=this.points[n];if(n===0)this.moveTo(l.position.x,l.position.y);else{let c=this.points[n-1];this._applyCurveForPoint(l,c)}}let t=this.getLastPoint();if((t==null?void 0:t.curveAfter)&&(t.curveAfter=void 0),this.isClosed){let n=this.points[0],s=this.points[this.points.length-1];this._applyCurveForPoint(n,s)}if(this.points.length>2){let n=0;for(let s=0,l=this.points.length;s<l;s++){let c=this.points[s],f=c.roundness;if(!c.controlsMoved()&&f>0){let h=c.curveBefore,d=c.curveAfter;if(h===void 0||d===void 0)continue;let x=c.roundedCurveBefore,g=c.roundedCurveAfter,w=h.getLength(),S=d.getLength(),D=Math.min(f,w*.499),C=Math.min(f,S*.499),G=Math.min(D,C),B=1-G/w,P=G/S,W=h.getPointAt(B,jh),M=d.getPointAt(P,r2);this._subSplitCurve(h,x,B,W,void 0),this._subSplitCurve(d,g,P,void 0,M);let q;if(this.useCubicForRoundedCorners){let E=Oh(W,c.position,M)/2,b=Math.tan(E)*W.distanceTo(c.position),[R,T]=x0(W,M,b,n2,i2),z=v0(R,T,c.position),[A,$]=b0(z,W,M,b,o2,s2);q=new Jc(W.clone(),A.clone(),$.clone(),M.clone())}else q=new _0(W.clone(),c.position.clone(),M.clone());c.roundedCurveCorner=q,this.roundedCurves.splice(s+n,0,q),n++}}}e&&((r=this.eventDispatcher)==null||r.dispatchEvent({type:"update"}))}_subSplitCurve(e,t,r,n,s){if(e instanceof Gh)n!==void 0&&t.v2.copy(n),s!==void 0&&t.v1.copy(s);else{let l=e,c=t,f=l.getUtoTmapping(r,0),h=S0(l.v0,l.v1,l.v2,l.v3,f);return n!==void 0&&(c.v0.set(h[0],h[1]),c.v1.set(h[2],h[3]),c.v2.set(h[4],h[5]),c.v3.set(h[6],h[7])),s!==void 0&&(c.v0.set(h[6],h[7]),c.v1.set(h[8],h[9]),c.v2.set(h[10],h[11]),c.v3.set(h[12],h[13])),c}return t}clone(){let e=new st(this._width,this._height);return e.points=this.points.map(t=>t.clone()),e.isClosed=this.isClosed,e.roundness=this.roundness,e.isMesh2D=this.isMesh2D,e.shapeHoles=this.shapeHoles.map(t=>t.clone()),e}toJSON(){return{points:this.points.reduce((e,t)=>e.concat(t.toJSON()),[]),shapeHoles:this.shapeHoles.map(e=>e.toJSON()),isClosed:this.isClosed,roundness:this.roundness}}fromJSON(e){var r;this.points=[],this.pointIDs=0;let t=e.points.length/7;for(let n=0;n<t;n++){let s=n*7,l=e.points[s+0],c=e.points[s+1],f=e.points[s+2],h=e.points[s+3],d=e.points[s+4],x=e.points[s+5],g=e.points[s+6],w=new Kn(Bh.generateUUID(),new xi(l,c));w.controls[0].position.set(f,h),w.controls[1].position.set(d,x),w.roundness=g,this.points.push(w)}return this.shapeHoles=((r=e.shapeHoles)==null?void 0:r.length)?e.shapeHoles.map(n=>{let s=new st;return s.fromJSON(n),s}):[],this.isClosed=e.isClosed,this._roundness=e.roundness,this._update(),this}fromShape(e){let t=(n,s)=>{s instanceof Jc&&s.v3.equals(n.position)&&n.controls[0].position.copy(s.v2)},r=n=>{let s=[],l,c;for(l=0,c=n.length;l<c;l++)n[l]instanceof _0&&(n[l]=y0(n[l]));for(l=0,c=n.length;l<c;l++){let d=n[l],x=l>0?n[l-1]:null,g;d instanceof Jc?(g=this.createPoint(d.v0),g.controls[1].position.copy(d.v1)):d instanceof Gh&&(g=this.createPoint(d.v1)),g!==void 0&&(x!==null&&t(g,x),s.push(g))}let f=n[n.length-1],h=!1;return f instanceof Jc?f.v3.equals(s[0].position)&&(s[0].controls[0].position.copy(f.v2),h=!0):f instanceof Gh&&f.v2.equals(s[0].position)&&(h=!0),this.isClosed=h,s};return this.points=r(e.curves),e instanceof L0&&(this.shapeHoles=e.holes.map(n=>{let s=new st;return s.fromShape(n),s})),this.update(),this}};var Eh=Math.PI*2;function Rh({x:i,y:e},t,r,n,s){return{x:i*t+n,y:e*r+s}}function a2(i,e){let t=e===1.5707963267948966?.551915024494:e===-1.5707963267948966?-.551915024494:4/3*Math.tan(e/4),r=Math.cos(i),n=Math.sin(i),s=Math.cos(i+e),l=Math.sin(i+e);return[{x:r-n*t,y:n+r*t},{x:s+l*t,y:l-s*t},{x:s,y:l}]}function T0(i,e,t,r){let n=i*r-e*t<0?-1:1,s=Math.min(1,Math.max(-1,i*t+e*r));return n*Math.acos(s)}function l2(i,e,t,r,n,s,l,c,f,h){let d=Math.pow(n,2),x=Math.pow(s,2),g=Math.pow(l,2),w=Math.pow(c,2),S=d*x-d*w-x*g;S<0&&(S=0),S/=d*w+x*g,S=Math.sqrt(S)*(f===h?-1:1);let D=S*n/s*c,C=S*-s/n*l,G=D+(i+t)/2,B=C+(e+r)/2,P=(l-D)/n,W=(c-C)/s,M=(-l-D)/n,q=(-c-C)/s,E=T0(1,0,P,W),b=T0(P,W,M,q);return!h&&b>0&&(b-=Eh),h&&b<0&&(b+=Eh),{centerx:G,centery:B,ang1:E,ang2:b}}function I0({px:i,py:e,cx:t,cy:r,rx:n,ry:s,largeArcFlag:l,sweepFlag:c}){let f=[];if(n===0||s===0)return[];let h=(i-t)/2,d=(e-r)/2;if(h===0&&d===0)return[];n=Math.abs(n),s=Math.abs(s);let x=Math.pow(h,2)/Math.pow(n,2)+Math.pow(d,2)/Math.pow(s,2);x>1&&(n*=Math.sqrt(x),s*=Math.sqrt(x));let g=l2(i,e,t,r,n,s,h,d,l,c),{ang1:w,ang2:S}=g,{centerx:D,centery:C}=g,G=Math.abs(S)/(Eh/4);Math.abs(1-G)<1e-7&&(G=1);let B=Math.max(Math.ceil(G),1);S/=B;for(let P=0;P<B;P++)f.push(a2(w,S)),w+=S;return f.map(P=>{let{x:W,y:M}=Rh(P[0],n,s,D,C),{x:q,y:E}=Rh(P[1],n,s,D,C),{x:b,y:R}=Rh(P[2],n,s,D,C);return{x1:W,y1:M,x2:q,y2:E,x:b,y:R}})}import{BufferAttribute as Xc,BufferGeometry as p2}from"three";var Pt;(function(i){i[i.ODD=0]="ODD",i[i.NONZERO=1]="NONZERO",i[i.POSITIVE=2]="POSITIVE",i[i.NEGATIVE=3]="NEGATIVE",i[i.ABS_GEQ_TWO=4]="ABS_GEQ_TWO"})(Pt||(Pt={}));var Qt;(function(i){i[i.POLYGONS=0]="POLYGONS",i[i.CONNECTED_POLYGONS=1]="CONNECTED_POLYGONS",i[i.BOUNDARY_CONTOURS=2]="BOUNDARY_CONTOURS"})(Qt||(Qt={}));function Ae(i,e){if(!i)throw e||"Assertion Failed!"}var Te=function(){function i(){}return i.vertEq=function(e,t){return e.s===t.s&&e.t===t.t},i.vertLeq=function(e,t){return e.s<t.s||e.s===t.s&&e.t<=t.t},i.transLeq=function(e,t){return e.t<t.t||e.t===t.t&&e.s<=t.s},i.edgeGoesLeft=function(e){return i.vertLeq(e.Dst,e.Org)},i.edgeGoesRight=function(e){return i.vertLeq(e.Org,e.Dst)},i.vertL1dist=function(e,t){return Math.abs(e.s-t.s)+Math.abs(e.t-t.t)},i.edgeEval=function(e,t,r){Ae(i.vertLeq(e,t)&&i.vertLeq(t,r));var n=t.s-e.s,s=r.s-t.s;return n+s>0?n<s?t.t-e.t+(e.t-r.t)*(n/(n+s)):t.t-r.t+(r.t-e.t)*(s/(n+s)):0},i.edgeSign=function(e,t,r){Ae(i.vertLeq(e,t)&&i.vertLeq(t,r));var n=t.s-e.s,s=r.s-t.s;return n+s>0?(t.t-r.t)*n+(t.t-e.t)*s:0},i.transEval=function(e,t,r){Ae(i.transLeq(e,t)&&i.transLeq(t,r));var n=t.t-e.t,s=r.t-t.t;return n+s>0?n<s?t.s-e.s+(e.s-r.s)*(n/(n+s)):t.s-r.s+(r.s-e.s)*(s/(n+s)):0},i.transSign=function(e,t,r){Ae(i.transLeq(e,t)&&i.transLeq(t,r));var n=t.t-e.t,s=r.t-t.t;return n+s>0?(t.s-r.s)*n+(t.s-e.s)*s:0},i.vertCCW=function(e,t,r){return e.s*(t.t-r.t)+t.s*(r.t-e.t)+r.s*(e.t-t.t)>=0},i.interpolate=function(e,t,r,n){return e=e<0?0:e,r=r<0?0:r,e<=r?r===0?(t+n)/2:t+(n-t)*(e/(e+r)):n+(t-n)*(r/(e+r))},i.intersect=function(e,t,r,n,s){var l,c,f;i.vertLeq(e,t)||(f=e,e=t,t=f),i.vertLeq(r,n)||(f=r,r=n,n=f),i.vertLeq(e,r)||(f=e,e=r,r=f,f=t,t=n,n=f),i.vertLeq(r,t)?i.vertLeq(t,n)?(l=i.edgeEval(e,r,t),c=i.edgeEval(r,t,n),l+c<0&&(l=-l,c=-c),s.s=i.interpolate(l,r.s,c,t.s)):(l=i.edgeSign(e,r,t),c=-i.edgeSign(e,n,t),l+c<0&&(l=-l,c=-c),s.s=i.interpolate(l,r.s,c,n.s)):s.s=(r.s+t.s)/2,i.transLeq(e,t)||(f=e,e=t,t=f),i.transLeq(r,n)||(f=r,r=n,n=f),i.transLeq(e,r)||(f=e,e=r,r=f,f=t,t=n,n=f),i.transLeq(r,t)?i.transLeq(t,n)?(l=i.transEval(e,r,t),c=i.transEval(r,t,n),l+c<0&&(l=-l,c=-c),s.t=i.interpolate(l,r.t,c,t.t)):(l=i.transSign(e,r,t),c=-i.transSign(e,n,t),l+c<0&&(l=-l,c=-c),s.t=i.interpolate(l,r.t,c,n.t)):s.t=(r.t+t.t)/2},i}(),Sa=function(){function i(){this.next=null,this.prev=null,this.anEdge=null,this.trail=null,this.n=0,this.marked=!1,this.inside=!1}return i}(),Kc=function(){function i(e){this.side=e,this.next=null,this.Org=null,this.Sym=null,this.Onext=null,this.Lnext=null,this.Lface=null,this.activeRegion=null,this.winding=0}return Object.defineProperty(i.prototype,"Rface",{get:function(){return this.Sym.Lface},set:function(e){this.Sym.Lface=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Dst",{get:function(){return this.Sym.Org},set:function(e){this.Sym.Org=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Oprev",{get:function(){return this.Sym.Lnext},set:function(e){this.Sym.Lnext=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Lprev",{get:function(){return this.Onext.Sym},set:function(e){this.Onext.Sym=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Dprev",{get:function(){return this.Lnext.Sym},set:function(e){this.Lnext.Sym=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Rprev",{get:function(){return this.Sym.Onext},set:function(e){this.Sym.Onext=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Dnext",{get:function(){return this.Sym.Onext.Sym},set:function(e){this.Sym.Onext.Sym=e},enumerable:!0,configurable:!0}),Object.defineProperty(i.prototype,"Rnext",{get:function(){return this.Sym.Lnext.Sym},set:function(e){this.Sym.Lnext.Sym=e},enumerable:!0,configurable:!0}),i}(),Ns=function(){function i(){this.next=null,this.prev=null,this.anEdge=null,this.coords=[0,0,0],this.s=0,this.t=0,this.pqHandle=0,this.n=0,this.idx=0}return i}(),M0=function(){function i(){var e=new Ns,t=new Sa,r=new Kc(0),n=new Kc(1);e.next=e.prev=e,e.anEdge=null,t.next=t.prev=t,r.next=r,r.Sym=n,n.next=n,n.Sym=r,this.vHead=e,this.fHead=t,this.eHead=r,this.eHeadSym=n}return i.prototype.makeEdge_=function(e){var t=new Kc(0),r=new Kc(1);e.Sym.side<e.side&&(e=e.Sym);var n=e.Sym.next;return r.next=n,n.Sym.next=t,t.next=e,e.Sym.next=r,t.Sym=r,t.Onext=t,t.Lnext=r,t.Org=null,t.Lface=null,t.winding=0,t.activeRegion=null,r.Sym=t,r.Onext=r,r.Lnext=t,r.Org=null,r.Lface=null,r.winding=0,r.activeRegion=null,t},i.prototype.splice_=function(e,t){var r=e.Onext,n=t.Onext;r.Sym.Lnext=t,n.Sym.Lnext=e,e.Onext=n,t.Onext=r},i.prototype.makeVertex_=function(e,t,r){var n=e;Ae(n,"Vertex can't be null!");var s=r.prev;n.prev=s,s.next=n,n.next=r,r.prev=n,n.anEdge=t;var l=t;do l.Org=n,l=l.Onext;while(l!==t)},i.prototype.makeFace_=function(e,t,r){var n=e;Ae(n,"Face can't be null");var s=r.prev;n.prev=s,s.next=n,n.next=r,r.prev=n,n.anEdge=t,n.trail=null,n.marked=!1,n.inside=r.inside;var l=t;do l.Lface=n,l=l.Lnext;while(l!==t)},i.prototype.killEdge_=function(e){e.Sym.side<e.side&&(e=e.Sym);var t=e.next,r=e.Sym.next;t.Sym.next=r,r.Sym.next=t},i.prototype.killVertex_=function(e,t){var r=e.anEdge,n=r;do n.Org=t,n=n.Onext;while(n!==r);var s=e.prev,l=e.next;l.prev=s,s.next=l},i.prototype.killFace_=function(e,t){var r=e.anEdge,n=r;do n.Lface=t,n=n.Lnext;while(n!==r);var s=e.prev,l=e.next;l.prev=s,s.next=l},i.prototype.makeEdge=function(){var e=new Ns,t=new Ns,r=new Sa,n=this.makeEdge_(this.eHead);return this.makeVertex_(e,n,this.vHead),this.makeVertex_(t,n.Sym,this.vHead),this.makeFace_(r,n,this.fHead),n},i.prototype.splice=function(e,t){var r=!1,n=!1;if(e!==t){if(t.Org!==e.Org&&(n=!0,this.killVertex_(t.Org,e.Org)),t.Lface!==e.Lface&&(r=!0,this.killFace_(t.Lface,e.Lface)),this.splice_(t,e),!n){var s=new Ns;this.makeVertex_(s,t,e.Org),e.Org.anEdge=e}if(!r){var l=new Sa;this.makeFace_(l,t,e.Lface),e.Lface.anEdge=e}}},i.prototype.delete=function(e){var t=e.Sym,r=!1;if(e.Lface!==e.Rface&&(r=!0,this.killFace_(e.Lface,e.Rface)),e.Onext===e)this.killVertex_(e.Org,null);else if(e.Rface.anEdge=e.Oprev,e.Org.anEdge=e.Onext,this.splice_(e,e.Oprev),!r){var n=new Sa;this.makeFace_(n,e,e.Lface)}t.Onext===t?(this.killVertex_(t.Org,null),this.killFace_(t.Lface,null)):(e.Lface.anEdge=t.Oprev,t.Org.anEdge=t.Onext,this.splice_(t,t.Oprev)),this.killEdge_(e)},i.prototype.addEdgeVertex=function(e){var t=this.makeEdge_(e),r=t.Sym;this.splice_(t,e.Lnext),t.Org=e.Dst;var n=new Ns;return this.makeVertex_(n,r,t.Org),t.Lface=r.Lface=e.Lface,t},i.prototype.splitEdge=function(e){var t=this.addEdgeVertex(e),r=t.Sym;return this.splice_(e.Sym,e.Sym.Oprev),this.splice_(e.Sym,r),e.Dst=r.Org,r.Dst.anEdge=r.Sym,r.Rface=e.Rface,r.winding=e.winding,r.Sym.winding=e.Sym.winding,r.idx=e.idx,r.Sym.idx=e.Sym.idx,r},i.prototype.connect=function(e,t){var r=!1,n=this.makeEdge_(e),s=n.Sym;if(t.Lface!==e.Lface&&(r=!0,this.killFace_(t.Lface,e.Lface)),this.splice_(n,e.Lnext),this.splice_(s,t),n.Org=e.Dst,s.Org=t.Org,n.Lface=s.Lface=e.Lface,e.Lface.anEdge=s,!r){var l=new Sa;this.makeFace_(l,n,e.Lface)}return n},i.prototype.zapFace=function(e){var t=e.anEdge,r,n,s,l,c;n=t.Lnext;do r=n,n=r.Lnext,r.Lface=null,r.Rface===null&&(r.Onext===r?this.killVertex_(r.Org,null):(r.Org.anEdge=r.Onext,this.splice_(r,r.Oprev)),s=r.Sym,s.Onext===s?this.killVertex_(s.Org,null):(s.Org.anEdge=s.Onext,this.splice_(s,s.Oprev)),this.killEdge_(r));while(r!=t);l=e.prev,c=e.next,c.prev=l,l.next=c},i.prototype.countFaceVerts_=function(e){var t=e.anEdge,r=0;do r++,t=t.Lnext;while(t!==e.anEdge);return r},i.prototype.mergeConvexFaces=function(e){var t,r,n,s,l,c,f;for(t=this.fHead.next;t!==this.fHead;t=t.next)if(!!t.inside)for(r=t.anEdge,l=r.Org;n=r.Lnext,s=r.Sym,s&&s.Lface&&s.Lface.inside&&(c=this.countFaceVerts_(t),f=this.countFaceVerts_(s.Lface),c+f-2<=e&&Te.vertCCW(r.Lprev.Org,r.Org,s.Lnext.Lnext.Org)&&Te.vertCCW(s.Lprev.Org,s.Org,r.Lnext.Lnext.Org)&&(n=s.Lnext,this.delete(s),r=null,s=null)),!(r&&r.Lnext.Org===l);)r=n;return!0},i.prototype.check=function(){var e=this.fHead,t=this.vHead,r=this.eHead,n,s,l,c,f,h;for(s=e,s=e;(n=s.next)!==e;s=n){Ae(n.prev===s),f=n.anEdge;do Ae(f.Sym!==f),Ae(f.Sym.Sym===f),Ae(f.Lnext.Onext.Sym===f),Ae(f.Onext.Sym.Lnext===f),Ae(f.Lface===n),f=f.Lnext;while(f!==n.anEdge)}for(Ae(n.prev===s&&n.anEdge===null),c=t,c=t;(l=c.next)!==t;c=l){Ae(l.prev===c),f=l.anEdge;do Ae(f.Sym!==f),Ae(f.Sym.Sym===f),Ae(f.Lnext.Onext.Sym===f),Ae(f.Onext.Sym.Lnext===f),Ae(f.Org===l),f=f.Onext;while(f!==l.anEdge)}for(Ae(l.prev===c&&l.anEdge===null),h=r,h=r;(f=h.next)!==r;h=f)Ae(f.Sym.next===h.Sym),Ae(f.Sym!==f),Ae(f.Sym.Sym===f),Ae(f.Org!==null),Ae(f.Dst!==null),Ae(f.Lnext.Onext.Sym===f),Ae(f.Onext.Sym.Lnext===f);Ae(f.Sym.next===h.Sym&&f.Sym===this.eHeadSym&&f.Sym.Sym===f&&f.Org===null&&f.Dst===null&&f.Lface===null&&f.Rface===null)},i}(),A0=function(){function i(){this.handle=null}return i}(),O0=function(){function i(){this.key=null,this.node=0}return i}(),c2=function(){function i(e,t){this.leq=t,this.max=0,this.nodes=[],this.handles=[],this.initialized=!1,this.freeList=0,this.size=0,this.max=e,this.nodes=[],this.handles=[];for(var r=0;r<e+1;r++)this.nodes[r]=new A0,this.handles[r]=new O0;this.initialized=!1,this.nodes[1].handle=1,this.handles[1].key=null}return i.prototype.floatDown_=function(e){var t=this.nodes,r=this.handles,n,s,l;for(n=t[e].handle;;){if(l=e<<1,l<this.size&&this.leq(r[t[l+1].handle].key,r[t[l].handle].key)&&++l,Ae(l<=this.max),s=t[l].handle,l>this.size||this.leq(r[n].key,r[s].key)){t[e].handle=n,r[n].node=e;break}t[e].handle=s,r[s].node=e,e=l}},i.prototype.floatUp_=function(e){var t=this.nodes,r=this.handles,n,s,l;for(n=t[e].handle;;){if(l=e>>1,s=t[l].handle,l===0||this.leq(r[s].key,r[n].key)){t[e].handle=n,r[n].node=e;break}t[e].handle=s,r[s].node=e,e=l}},i.prototype.init=function(){for(var e=this.size;e>=1;--e)this.floatDown_(e);this.initialized=!0},i.prototype.min=function(){return this.handles[this.nodes[1].handle].key},i.prototype.insert=function(e){var t,r;if(t=++this.size,t*2>this.max){this.max*=2;var n,s;for(s=this.nodes.length,this.nodes.length=this.max+1,n=s;n<this.nodes.length;n++)this.nodes[n]=new A0;for(s=this.handles.length,this.handles.length=this.max+1,n=s;n<this.handles.length;n++)this.handles[n]=new O0}return this.freeList===0?r=t:(r=this.freeList,this.freeList=this.handles[r].node),this.nodes[t].handle=r,this.handles[r].node=t,this.handles[r].key=e,this.initialized&&this.floatUp_(t),r},i.prototype.extractMin=function(){var e=this.nodes,t=this.handles,r=e[1].handle,n=t[r].key;return this.size>0&&(e[1].handle=e[this.size].handle,t[e[1].handle].node=1,t[r].key=null,t[r].node=this.freeList,this.freeList=r,--this.size,this.size>0&&this.floatDown_(1)),n},i.prototype.delete=function(e){var t=this.nodes,r=this.handles,n;Ae(e>=1&&e<=this.max&&r[e].key!==null),n=r[e].node,t[n].handle=t[this.size].handle,r[t[n].handle].node=n,--this.size,n<=this.size&&(n<=1||this.leq(r[t[n>>1].handle].key,r[t[n].handle].key)?this.floatDown_(n):this.floatUp_(n)),r[e].key=null,r[e].node=this.freeList,this.freeList=e},i}(),zh=function(){function i(){this.eUp=null,this.nodeUp=null,this.windingNumber=0,this.inside=!1,this.sentinel=!1,this.dirty=!1,this.fixUpperEdge=!1}return i}(),P0=function(){function i(){this.key=null,this.next=null,this.prev=null}return i}(),u2=function(){function i(e,t){this.frame=e,this.leq=t,this.head=new P0,this.head.next=this.head,this.head.prev=this.head}return i.prototype.min=function(){return this.head.next},i.prototype.max=function(){return this.head.prev},i.prototype.insert=function(e){return this.insertBefore(this.head,e)},i.prototype.search=function(e){var t=this.head;do t=t.next;while(t.key!==null&&!this.leq(this.frame,e,t.key));return t},i.prototype.insertBefore=function(e,t){do e=e.prev;while(e.key!==null&&!this.leq(this.frame,e.key,t));var r=new P0;return r.key=t,r.next=e.next,e.next.prev=r,r.prev=e,e.next=r,r},i.prototype.delete=function(e){e.next.prev=e.prev,e.prev.next=e.next},i}(),f2=function(){function i(){}return i.regionBelow=function(e){return e.nodeUp.prev.key},i.regionAbove=function(e){return e.nodeUp.next.key},i.debugEvent=function(e){},i.addWinding=function(e,t){e.winding+=t.winding,e.Sym.winding+=t.Sym.winding},i.edgeLeq=function(e,t,r){var n=e.event,s=t.eUp,l=r.eUp;if(s.Dst===n)return l.Dst===n?Te.vertLeq(s.Org,l.Org)?Te.edgeSign(l.Dst,s.Org,l.Org)<=0:Te.edgeSign(s.Dst,l.Org,s.Org)>=0:Te.edgeSign(l.Dst,n,l.Org)<=0;if(l.Dst===n)return Te.edgeSign(s.Dst,n,s.Org)>=0;var c=Te.edgeEval(s.Dst,n,s.Org),f=Te.edgeEval(l.Dst,n,l.Org);return c>=f},i.deleteRegion=function(e,t){t.fixUpperEdge&&Ae(t.eUp.winding===0),t.eUp.activeRegion=null,e.dict.delete(t.nodeUp)},i.fixUpperEdge=function(e,t,r){Ae(t.fixUpperEdge),e.mesh.delete(t.eUp),t.fixUpperEdge=!1,t.eUp=r,r.activeRegion=t},i.topLeftRegion=function(e,t){var r=t.eUp.Org,n;do t=i.regionAbove(t);while(t.eUp.Org===r);if(t.fixUpperEdge){if(n=e.mesh.connect(i.regionBelow(t).eUp.Sym,t.eUp.Lnext),n===null)return null;i.fixUpperEdge(e,t,n),t=i.regionAbove(t)}return t},i.topRightRegion=function(e){var t=e.eUp.Dst;do e=i.regionAbove(e);while(e.eUp.Dst===t);return e},i.addRegionBelow=function(e,t,r){var n=new zh;return n.eUp=r,n.nodeUp=e.dict.insertBefore(t.nodeUp,n),n.fixUpperEdge=!1,n.sentinel=!1,n.dirty=!1,r.activeRegion=n,n},i.isWindingInside=function(e,t){switch(e.windingRule){case Pt.ODD:return(t&1)!=0;case Pt.NONZERO:return t!==0;case Pt.POSITIVE:return t>0;case Pt.NEGATIVE:return t<0;case Pt.ABS_GEQ_TWO:return t>=2||t<=-2}throw new Error("Invalid winding rulle")},i.computeWinding=function(e,t){t.windingNumber=i.regionAbove(t).windingNumber+t.eUp.winding,t.inside=i.isWindingInside(e,t.windingNumber)},i.finishRegion=function(e,t){var r=t.eUp,n=r.Lface;n.inside=t.inside,n.anEdge=r,i.deleteRegion(e,t)},i.finishLeftRegions=function(e,t,r){for(var n,s=null,l=t,c=t.eUp;l!==r;){if(l.fixUpperEdge=!1,s=i.regionBelow(l),n=s.eUp,n.Org!=c.Org){if(!s.fixUpperEdge){i.finishRegion(e,l);break}n=e.mesh.connect(c.Lprev,n.Sym),i.fixUpperEdge(e,s,n)}c.Onext!==n&&(e.mesh.splice(n.Oprev,n),e.mesh.splice(c,n)),i.finishRegion(e,l),c=s.eUp,l=s}return c},i.addRightEdges=function(e,t,r,n,s,l){var c,f,h,d,x=!0;h=r;do Ae(Te.vertLeq(h.Org,h.Dst)),i.addRegionBelow(e,t,h.Sym),h=h.Onext;while(h!==n);for(s===null&&(s=i.regionBelow(t).eUp.Rprev),f=t,d=s;c=i.regionBelow(f),h=c.eUp.Sym,h.Org===d.Org;)h.Onext!==d&&(e.mesh.splice(h.Oprev,h),e.mesh.splice(d.Oprev,h)),c.windingNumber=f.windingNumber-h.winding,c.inside=i.isWindingInside(e,c.windingNumber),f.dirty=!0,!x&&i.checkForRightSplice(e,f)&&(i.addWinding(h,d),i.deleteRegion(e,f),e.mesh.delete(d)),x=!1,f=c,d=h;f.dirty=!0,Ae(f.windingNumber-h.winding===c.windingNumber),l&&i.walkDirtyRegions(e,f)},i.spliceMergeVertices=function(e,t,r){e.mesh.splice(t,r)},i.vertexWeights=function(e,t,r){var n=Te.vertL1dist(t,e),s=Te.vertL1dist(r,e),l=.5*s/(n+s),c=.5*n/(n+s);e.coords[0]+=l*t.coords[0]+c*r.coords[0],e.coords[1]+=l*t.coords[1]+c*r.coords[1],e.coords[2]+=l*t.coords[2]+c*r.coords[2]},i.getIntersectData=function(e,t,r,n,s,l){t.coords[0]=t.coords[1]=t.coords[2]=0,t.idx=-1,i.vertexWeights(t,r,n),i.vertexWeights(t,s,l)},i.checkForRightSplice=function(e,t){var r=i.regionBelow(t),n=t.eUp,s=r.eUp;if(Te.vertLeq(n.Org,s.Org)){if(Te.edgeSign(s.Dst,n.Org,s.Org)>0)return!1;Te.vertEq(n.Org,s.Org)?n.Org!==s.Org&&(e.pq.delete(n.Org.pqHandle),i.spliceMergeVertices(e,s.Oprev,n)):(e.mesh.splitEdge(s.Sym),e.mesh.splice(n,s.Oprev),t.dirty=r.dirty=!0)}else{if(Te.edgeSign(n.Dst,s.Org,n.Org)<0)return!1;i.regionAbove(t).dirty=t.dirty=!0,e.mesh.splitEdge(n.Sym),e.mesh.splice(s.Oprev,n)}return!0},i.checkForLeftSplice=function(e,t){var r=i.regionBelow(t),n=t.eUp,s=r.eUp,l;if(Ae(!Te.vertEq(n.Dst,s.Dst)),Te.vertLeq(n.Dst,s.Dst)){if(Te.edgeSign(n.Dst,s.Dst,n.Org)<0)return!1;i.regionAbove(t).dirty=t.dirty=!0,l=e.mesh.splitEdge(n),e.mesh.splice(s.Sym,l),l.Lface.inside=t.inside}else{if(Te.edgeSign(s.Dst,n.Dst,s.Org)>0)return!1;t.dirty=r.dirty=!0,l=e.mesh.splitEdge(s),e.mesh.splice(n.Lnext,s.Sym),l.Rface.inside=t.inside}return!0},i.checkForIntersect=function(e,t){var r=i.regionBelow(t),n=t.eUp,s=r.eUp,l=n.Org,c=s.Org,f=n.Dst,h=s.Dst,d,x,g=new Ns,w,S;if(Ae(!Te.vertEq(h,f)),Ae(Te.edgeSign(f,e.event,l)<=0),Ae(Te.edgeSign(h,e.event,c)>=0),Ae(l!==e.event&&c!==e.event),Ae(!t.fixUpperEdge&&!r.fixUpperEdge),l===c||(d=Math.min(l.t,f.t),x=Math.max(c.t,h.t),d>x))return!1;if(Te.vertLeq(l,c)){if(Te.edgeSign(h,l,c)>0)return!1}else if(Te.edgeSign(f,c,l)<0)return!1;return i.debugEvent(e),Te.intersect(f,l,h,c,g),Ae(Math.min(l.t,f.t)<=g.t),Ae(g.t<=Math.max(c.t,h.t)),Ae(Math.min(h.s,f.s)<=g.s),Ae(g.s<=Math.max(c.s,l.s)),Te.vertLeq(g,e.event)&&(g.s=e.event.s,g.t=e.event.t),w=Te.vertLeq(l,c)?l:c,Te.vertLeq(w,g)&&(g.s=w.s,g.t=w.t),Te.vertEq(g,l)||Te.vertEq(g,c)?(i.checkForRightSplice(e,t),!1):!Te.vertEq(f,e.event)&&Te.edgeSign(f,e.event,g)>=0||!Te.vertEq(h,e.event)&&Te.edgeSign(h,e.event,g)<=0?h===e.event?(e.mesh.splitEdge(n.Sym),e.mesh.splice(s.Sym,n),t=i.topLeftRegion(e,t),n=i.regionBelow(t).eUp,i.finishLeftRegions(e,i.regionBelow(t),r),i.addRightEdges(e,t,n.Oprev,n,n,!0),!0):f===e.event?(e.mesh.splitEdge(s.Sym),e.mesh.splice(n.Lnext,s.Oprev),r=t,t=i.topRightRegion(t),S=i.regionBelow(t).eUp.Rprev,r.eUp=s.Oprev,s=i.finishLeftRegions(e,r,null),i.addRightEdges(e,t,s.Onext,n.Rprev,S,!0),!0):(Te.edgeSign(f,e.event,g)>=0&&(i.regionAbove(t).dirty=t.dirty=!0,e.mesh.splitEdge(n.Sym),n.Org.s=e.event.s,n.Org.t=e.event.t),Te.edgeSign(h,e.event,g)<=0&&(t.dirty=r.dirty=!0,e.mesh.splitEdge(s.Sym),s.Org.s=e.event.s,s.Org.t=e.event.t),!1):(e.mesh.splitEdge(n.Sym),e.mesh.splitEdge(s.Sym),e.mesh.splice(s.Oprev,n),n.Org.s=g.s,n.Org.t=g.t,n.Org.pqHandle=e.pq.insert(n.Org),i.getIntersectData(e,n.Org,l,f,c,h),i.regionAbove(t).dirty=t.dirty=r.dirty=!0,!1)},i.walkDirtyRegions=function(e,t){for(var r=i.regionBelow(t),n,s;;){for(;r.dirty;)t=r,r=i.regionBelow(r);if(!t.dirty&&(r=t,t=i.regionAbove(t),t===null||!t.dirty))return;if(t.dirty=!1,n=t.eUp,s=r.eUp,n.Dst!==s.Dst&&i.checkForLeftSplice(e,t)&&(r.fixUpperEdge?(i.deleteRegion(e,r),e.mesh.delete(s),r=i.regionBelow(t),s=r.eUp):t.fixUpperEdge&&(i.deleteRegion(e,t),e.mesh.delete(n),t=i.regionAbove(r),n=t.eUp)),n.Org!==s.Org)if(n.Dst!==s.Dst&&!t.fixUpperEdge&&!r.fixUpperEdge&&(n.Dst===e.event||s.Dst===e.event)){if(i.checkForIntersect(e,t))return}else i.checkForRightSplice(e,t);n.Org===s.Org&&n.Dst===s.Dst&&(i.addWinding(s,n),i.deleteRegion(e,t),e.mesh.delete(n),t=i.regionAbove(r))}},i.connectRightVertex=function(e,t,r){var n,s=r.Onext,l=i.regionBelow(t),c=t.eUp,f=l.eUp,h=!1;if(c.Dst!==f.Dst&&i.checkForIntersect(e,t),Te.vertEq(c.Org,e.event)&&(e.mesh.splice(s.Oprev,c),t=i.topLeftRegion(e,t),s=i.regionBelow(t).eUp,i.finishLeftRegions(e,i.regionBelow(t),l),h=!0),Te.vertEq(f.Org,e.event)&&(e.mesh.splice(r,f.Oprev),r=i.finishLeftRegions(e,l,null),h=!0),h){i.addRightEdges(e,t,r.Onext,s,s,!0);return}Te.vertLeq(f.Org,c.Org)?n=f.Oprev:n=c,n=e.mesh.connect(r.Lprev,n),i.addRightEdges(e,t,n,n.Onext,n.Onext,!1),n.Sym.activeRegion.fixUpperEdge=!0,i.walkDirtyRegions(e,t)},i.connectLeftDegenerate=function(e,t,r){var n,s,l,c,f;if(n=t.eUp,Te.vertEq(n.Org,r)){Ae(!1),i.spliceMergeVertices(e,n,r.anEdge);return}if(!Te.vertEq(n.Dst,r)){e.mesh.splitEdge(n.Sym),t.fixUpperEdge&&(e.mesh.delete(n.Onext),t.fixUpperEdge=!1),e.mesh.splice(r.anEdge,n),i.sweepEvent(e,r);return}Ae(!1),t=i.topRightRegion(t),f=i.regionBelow(t),l=f.eUp.Sym,s=c=l.Onext,f.fixUpperEdge&&(Ae(s!==l),i.deleteRegion(e,f),e.mesh.delete(l),l=s.Oprev),e.mesh.splice(r.anEdge,l),Te.edgeGoesLeft(s)||(s=null),i.addRightEdges(e,t,l.Onext,c,s,!0)},i.connectLeftVertex=function(e,t){var r,n,s,l,c,f,h=new zh;if(h.eUp=t.anEdge.Sym,r=e.dict.search(h).key,n=i.regionBelow(r),!!n){if(l=r.eUp,c=n.eUp,Te.edgeSign(l.Dst,t,l.Org)===0){i.connectLeftDegenerate(e,r,t);return}if(s=Te.vertLeq(c.Dst,l.Dst)?r:n,r.inside||s.fixUpperEdge){if(s===r)f=e.mesh.connect(t.anEdge.Sym,l.Lnext);else{var d=e.mesh.connect(c.Dnext,t.anEdge);f=d.Sym}s.fixUpperEdge?i.fixUpperEdge(e,s,f):i.computeWinding(e,i.addRegionBelow(e,r,f)),i.sweepEvent(e,t)}else i.addRightEdges(e,r,t.anEdge,t.anEdge,null,!0)}},i.sweepEvent=function(e,t){e.event=t,i.debugEvent(e);for(var r=t.anEdge;r.activeRegion===null;)if(r=r.Onext,r===t.anEdge){i.connectLeftVertex(e,t);return}var n=i.topLeftRegion(e,r.activeRegion);Ae(n!==null);var s=i.regionBelow(n),l=s.eUp,c=i.finishLeftRegions(e,s,null);c.Onext===l?i.connectRightVertex(e,n,c):i.addRightEdges(e,n,c.Onext,l,l,!0)},i.addSentinel=function(e,t,r,n){var s=new zh,l=e.mesh.makeEdge();l.Org.s=r,l.Org.t=n,l.Dst.s=t,l.Dst.t=n,e.event=l.Dst,s.eUp=l,s.windingNumber=0,s.inside=!1,s.fixUpperEdge=!1,s.sentinel=!0,s.dirty=!1,s.nodeUp=e.dict.insert(s)},i.initEdgeDict=function(e){e.dict=new u2(e,i.edgeLeq);var t=e.bmax[0]-e.bmin[0],r=e.bmax[1]-e.bmin[1],n=e.bmin[0]-t,s=e.bmax[0]+t,l=e.bmin[1]-r,c=e.bmax[1]+r;i.addSentinel(e,n,s,l),i.addSentinel(e,n,s,c)},i.doneEdgeDict=function(e){for(var t,r=0;(t=e.dict.min().key)!==null;)t.sentinel||(Ae(t.fixUpperEdge),Ae(++r==1)),Ae(t.windingNumber===0),i.deleteRegion(e,t)},i.removeDegenerateEdges=function(e){var t,r,n,s=e.mesh.eHead;for(t=s.next;t!==s;t=r)r=t.next,n=t.Lnext,Te.vertEq(t.Org,t.Dst)&&t.Lnext.Lnext!==t&&(i.spliceMergeVertices(e,n,t),e.mesh.delete(t),t=n,n=t.Lnext),n.Lnext===t&&(n!==t&&((n===r||n===r.Sym)&&(r=r.next),e.mesh.delete(n)),(t===r||t===r.Sym)&&(r=r.next),e.mesh.delete(t))},i.initPriorityQ=function(e){var t,r,n,s=0;for(n=e.mesh.vHead,r=n.next;r!==n;r=r.next)s++;for(s+=8,t=e.pq=new c2(s,Te.vertLeq),n=e.mesh.vHead,r=n.next;r!==n;r=r.next)r.pqHandle=t.insert(r);return r!==n?!1:(t.init(),!0)},i.donePriorityQ=function(e){e.pq=null},i.removeDegenerateFaces=function(e,t){var r,n,s;for(r=t.fHead.next;r!==t.fHead;r=n)n=r.next,s=r.anEdge,Ae(s.Lnext!==s),s.Lnext.Lnext===s&&(i.addWinding(s.Onext,s),e.mesh.delete(s));return!0},i.computeInterior=function(e,t){t===void 0&&(t=!0);var r,n;if(i.removeDegenerateEdges(e),!i.initPriorityQ(e))return!1;for(i.initEdgeDict(e);(r=e.pq.extractMin())!==null;){for(;n=e.pq.min(),!(n===null||!Te.vertEq(n,r));)n=e.pq.extractMin(),i.spliceMergeVertices(e,r.anEdge,n.anEdge);i.sweepEvent(e,r)}return e.event=e.dict.min().key.eUp.Org,i.debugEvent(e),i.doneEdgeDict(e),i.donePriorityQ(e),i.removeDegenerateFaces(e,e.mesh)?(t&&e.mesh.check(),!0):!1},i}(),h2=function(){function i(){this.mesh=new M0,this.normal=[0,0,0],this.sUnit=[0,0,0],this.tUnit=[0,0,0],this.bmin=[0,0],this.bmax=[0,0],this.windingRule=Pt.ODD,this.dict=null,this.pq=null,this.event=null,this.vertexIndexCounter=0,this.vertices=[],this.vertexIndices=[],this.vertexCount=0,this.elements=[],this.elementCount=0}return i.prototype.dot_=function(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]},i.prototype.normalize_=function(e){var t=e[0]*e[0]+e[1]*e[1]+e[2]*e[2];if(!t)throw"Zero-size vector!";t=Math.sqrt(t),e[0]/=t,e[1]/=t,e[2]/=t},i.prototype.longAxis_=function(e){var t=0;return Math.abs(e[1])>Math.abs(e[0])&&(t=1),Math.abs(e[2])>Math.abs(e[t])&&(t=2),t},i.prototype.computeNormal_=function(e){var t,r,n,s,l,c,f=[0,0,0],h=[0,0,0],d=[0,0,0],x=[0,0,0],g=[0,0,0],w=[null,null,null],S=[null,null,null],D=this.mesh.vHead;t=D.next;for(var C=0;C<3;++C)s=t.coords[C],h[C]=s,S[C]=t,f[C]=s,w[C]=t;for(t=D.next;t!==D;t=t.next)for(var G=0;G<3;++G)s=t.coords[G],s<h[G]&&(h[G]=s,S[G]=t),s>f[G]&&(f[G]=s,w[G]=t);var B=0;if(f[1]-h[1]>f[0]-h[0]&&(B=1),f[2]-h[2]>f[B]-h[B]&&(B=2),h[B]>=f[B]){e[0]=0,e[1]=0,e[2]=1;return}for(c=0,r=S[B],n=w[B],d[0]=r.coords[0]-n.coords[0],d[1]=r.coords[1]-n.coords[1],d[2]=r.coords[2]-n.coords[2],t=D.next;t!==D;t=t.next)x[0]=t.coords[0]-n.coords[0],x[1]=t.coords[1]-n.coords[1],x[2]=t.coords[2]-n.coords[2],g[0]=d[1]*x[2]-d[2]*x[1],g[1]=d[2]*x[0]-d[0]*x[2],g[2]=d[0]*x[1]-d[1]*x[0],l=g[0]*g[0]+g[1]*g[1]+g[2]*g[2],l>c&&(c=l,e[0]=g[0],e[1]=g[1],e[2]=g[2]);c<=0&&(e[0]=e[1]=e[2]=0,e[this.longAxis_(d)]=1)},i.prototype.checkOrientation_=function(){for(var e=this.mesh.fHead,t,r=this.mesh.vHead,n,s=0,l=e.next;l!==e;l=l.next)if(n=l.anEdge,!(n.winding<=0))do s+=(n.Org.s-n.Dst.s)*(n.Org.t+n.Dst.t),n=n.Lnext;while(n!==l.anEdge);if(s<0){for(t=r.next;t!==r;t=t.next)t.t=-t.t;this.tUnit[0]=-this.tUnit[0],this.tUnit[1]=-this.tUnit[1],this.tUnit[2]=-this.tUnit[2]}},i.prototype.projectPolygon_=function(){var e=this.mesh.vHead,t=[0,0,0],r,n,s=!1;t[0]=this.normal[0],t[1]=this.normal[1],t[2]=this.normal[2],!t[0]&&!t[1]&&!t[2]&&(this.computeNormal_(t),s=!0),r=this.sUnit,n=this.tUnit;var l=this.longAxis_(t);r[l]=0,r[(l+1)%3]=1,r[(l+2)%3]=0,n[l]=0,n[(l+1)%3]=0,n[(l+2)%3]=t[l]>0?1:-1;for(var c=e.next;c!==e;c=c.next)c.s=this.dot_(c.coords,r),c.t=this.dot_(c.coords,n);s&&this.checkOrientation_();for(var f=!0,h=e.next;h!==e;h=h.next)f?(this.bmin[0]=this.bmax[0]=h.s,this.bmin[1]=this.bmax[1]=h.t,f=!1):(h.s<this.bmin[0]&&(this.bmin[0]=h.s),h.s>this.bmax[0]&&(this.bmax[0]=h.s),h.t<this.bmin[1]&&(this.bmin[1]=h.t),h.t>this.bmax[1]&&(this.bmax[1]=h.t))},i.prototype.addWinding_=function(e,t){e.winding+=t.winding,e.Sym.winding+=t.Sym.winding},i.prototype.tessellateMonoRegion_=function(e,t){var r,n;if(r=t.anEdge,!(r.Lnext!==r&&r.Lnext.Lnext!==r))throw"Mono region invalid";for(;Te.vertLeq(r.Dst,r.Org);r=r.Lprev);for(;Te.vertLeq(r.Org,r.Dst);r=r.Lnext);n=r.Lprev;for(var s=void 0;r.Lnext!==n;)if(Te.vertLeq(r.Dst,n.Org)){for(;n.Lnext!==r&&(Te.edgeGoesLeft(n.Lnext)||Te.edgeSign(n.Org,n.Dst,n.Lnext.Dst)<=0);)s=e.connect(n.Lnext,n),n=s.Sym;n=n.Lprev}else{for(;n.Lnext!==r&&(Te.edgeGoesRight(r.Lprev)||Te.edgeSign(r.Dst,r.Org,r.Lprev.Org)>=0);)s=e.connect(r,r.Lprev),r=s.Sym;r=r.Lnext}if(n.Lnext===r)throw"Mono region invalid";for(;n.Lnext.Lnext!==r;)s=e.connect(n.Lnext,n),n=s.Sym;return!0},i.prototype.tessellateInterior_=function(e){for(var t,r=e.fHead.next;r!==e.fHead;r=t)if(t=r.next,r.inside&&!this.tessellateMonoRegion_(e,r))return!1;return!0},i.prototype.discardExterior_=function(e){for(var t,r=e.fHead.next;r!==e.fHead;r=t)t=r.next,r.inside||e.zapFace(r)},i.prototype.setWindingNumber_=function(e,t,r){for(var n,s=e.eHead.next;s!==e.eHead;s=n)n=s.next,s.Rface.inside!==s.Lface.inside?s.winding=s.Lface.inside?t:-t:r?e.delete(s):s.winding=0},i.prototype.getNeighbourFace_=function(e){return!e.Rface||!e.Rface.inside?-1:e.Rface.n},i.prototype.outputPolymesh_=function(e,t,r,n){var s,l=0,c=0,f;r>3&&e.mergeConvexFaces(r);for(var h=e.vHead.next;h!==e.vHead;h=h.next)h.n=-1;for(var d=e.fHead.next;d!==e.fHead;d=d.next)if(d.n=-1,!!d.inside){s=d.anEdge,f=0;do{var h=s.Org;h.n===-1&&(h.n=c,c++),f++,s=s.Lnext}while(s!==d.anEdge);if(f>r)throw"Face vertex greater that support polygon";d.n=l,++l}this.elementCount=l,t===Qt.CONNECTED_POLYGONS&&(l*=2),this.elements=[],this.elements.length=l*r,this.vertexCount=c,this.vertices=[],this.vertices.length=c*n,this.vertexIndices=[],this.vertexIndices.length=c;for(var h=e.vHead.next;h!==e.vHead;h=h.next)if(h.n!==-1){var x=h.n*n;this.vertices[x+0]=h.coords[0],this.vertices[x+1]=h.coords[1],n>2&&(this.vertices[x+2]=h.coords[2]),this.vertexIndices[h.n]=h.idx}for(var g=0,d=e.fHead.next;d!==e.fHead;d=d.next)if(!!d.inside){s=d.anEdge,f=0;do{var h=s.Org;this.elements[g++]=h.n,f++,s=s.Lnext}while(s!==d.anEdge);for(var w=f;w<r;++w)this.elements[g++]=-1;if(t===Qt.CONNECTED_POLYGONS){s=d.anEdge;do this.elements[g++]=this.getNeighbourFace_(s),s=s.Lnext;while(s!==d.anEdge);for(var S=f;S<r;++S)this.elements[g++]=-1}}},i.prototype.outputContours_=function(e,t){var r,n,s=0,l=0;this.vertexCount=0,this.elementCount=0;for(var c=e.fHead.next;c!==e.fHead;c=c.next)if(!!c.inside){n=r=c.anEdge;do this.vertexCount++,r=r.Lnext;while(r!==n);this.elementCount++}this.elements=[],this.elements.length=this.elementCount*2,this.vertices=[],this.vertices.length=this.vertexCount*t,this.vertexIndices=[],this.vertexIndices.length=this.vertexCount;var f=0,h=0,d=0;s=0;for(var c=e.fHead.next;c!==e.fHead;c=c.next)if(!!c.inside){l=0,n=r=c.anEdge;do this.vertices[f++]=r.Org.coords[0],this.vertices[f++]=r.Org.coords[1],t>2&&(this.vertices[f++]=r.Org.coords[2]),this.vertexIndices[h++]=this.vertexIdCallback?this.vertexIdCallback(r):r.Org.idx,l++,r=r.Lnext;while(r!==n);this.elements[d++]=s,this.elements[d++]=l,s+=l}},i.prototype.addContour=function(e,t){this.mesh===null&&(this.mesh=new M0),e<2&&(e=2),e>3&&(e=3);for(var r=null,n=0;n<t.length;n+=e)r===null?(r=this.mesh.makeEdge(),this.mesh.splice(r,r.Sym)):(this.mesh.splitEdge(r),r=r.Lnext),r.Org.coords[0]=t[n+0],r.Org.coords[1]=t[n+1],e>2?r.Org.coords[2]=t[n+2]:r.Org.coords[2]=0,r.Org.idx=this.vertexIndexCounter++,this.edgeCreateCallback&&this.edgeCreateCallback(r),r.winding=1,r.Sym.winding=-1},i.prototype.tesselate=function(e,t,r,n,s,l){if(e===void 0&&(e=Pt.ODD),t===void 0&&(t=Qt.POLYGONS),l===void 0&&(l=!0),this.vertices=[],this.elements=[],this.vertexIndices=[],this.vertexIndexCounter=0,s&&(this.normal[0]=s[0],this.normal[1]=s[1],this.normal[2]=s[2]),this.windingRule=e,n<2&&(n=2),n>3&&(n=3),!this.mesh)return!1;this.projectPolygon_(),f2.computeInterior(this,l);var c=this.mesh;return t===Qt.BOUNDARY_CONTOURS?this.setWindingNumber_(c,1,!0):this.tessellateInterior_(c),l&&c.check(),t===Qt.BOUNDARY_CONTOURS?this.outputContours_(c,n):this.outputPolymesh_(c,t,r,n),!0},i}();function wo(i){var e=i.windingRule,t=e===void 0?Pt.ODD:e,r=i.elementType,n=r===void 0?Qt.POLYGONS:r,s=i.polySize,l=s===void 0?3:s,c=i.vertexSize,f=c===void 0?2:c,h=i.normal,d=h===void 0?[0,0,1]:h,x=i.contours,g=x===void 0?[]:x,w=i.strict,S=w===void 0?!0:w,D=i.debug,C=D===void 0?!1:D;if(!g&&S)throw new Error("Contours can't be empty");if(!!g){var G=new h2;i.edgeCreateCallback&&(G.edgeCreateCallback=i.edgeCreateCallback),i.vertexIdCallback&&(G.vertexIdCallback=i.vertexIdCallback);for(var B=0;B<g.length;B++)G.addContour(f||2,g[B]);return G.tesselate(t,n,l,f,d,S),{vertices:G.vertices,vertexIndices:G.vertexIndices,vertexCount:G.vertexCount,elements:G.elements,elementCount:G.elementCount,mesh:C?G.mesh:void 0}}}var Pk=Pt.ODD,Dk=Pt.NONZERO,Bk=Pt.POSITIVE,Gk=Pt.NEGATIVE,jk=Pt.ABS_GEQ_TWO,Ek=Qt.POLYGONS,Rk=Qt.CONNECTED_POLYGONS,zk=Qt.BOUNDARY_CONTOURS;var No=class extends p2{constructor(e,t=12,r=100,n={}){super();this.type="ShapeGeometry";this.windingRule=Pt.ODD;this.elementType=Qt.POLYGONS;this.polySize=3;this.vertexSize=2;this.strict=!0;this._drawCount=0,this._shape=e,this._curveSegments=t,this._maxCount=r,this._maxDrawCount=r*3,this._triangulationOptions=Object.assign({windingRule:Pt.ODD,elementType:Qt.POLYGONS,polySize:3,vertexSize:2,strict:!0},n),this._positionAttribute=new Xc(new Float32Array(r*3),3),this._normalAttribute=new Xc(new Float32Array(r*3),3),this._uvAttribute=new Xc(new Float32Array(r*2),2),this._indexAttribute=new Xc(new Uint32Array(r*3),1),this.setAttribute("position",this._positionAttribute),this.setAttribute("normal",this._normalAttribute),this.setAttribute("uv",this._uvAttribute),this.setIndex(this._indexAttribute),this.updateFromShape()}copy(e){return this._drawCount=e.drawCount,this._maxDrawCount=e._maxDrawCount,this._maxCount=e.maxCount,super.copy(e)}get curveSegments(){return this._curveSegments}set curveSegments(e){this._curveSegments=e,this.updateFromShape()}get drawCount(){return this._drawCount}get maxDrawCount(){return this._maxDrawCount}get maxCount(){return this._maxCount}updateFromShape(){let e=this._shape.extractShapePointsToFlatArray([],this._curveSegments),t=this._shape.shapeHoles.map(f=>f.extractShapePointsToFlatArray([],this._curveSegments)),r,n=!0,s=!0,l,c;for(let f=0,h=e.length/2;f<h;f++){let d=f*2,x=e[d+0],g=e[d+1];if(l!==void 0&&x!==l&&(n=!1),c!==void 0&&g!==c&&(s=!1),l=x,c=g,!n&&!s)break}if(!n&&!s&&(r=wo({contours:[e,...t],windingRule:this._triangulationOptions.windingRule,elementType:this._triangulationOptions.elementType,polySize:this._triangulationOptions.polySize,vertexSize:this._triangulationOptions.vertexSize,strict:this._triangulationOptions.strict})),this._positionAttribute.array.fill(0),this._normalAttribute.array.fill(0),this._uvAttribute.array.fill(0),this._indexAttribute.array.fill(0),this._drawCount=0,r){let f=1/0,h=-1/0,d=1/0,x=-1/0;for(let S=0,D=r.vertexCount;S<D;S++){let C=S*2,G=r.vertices[C+0],B=r.vertices[C+1];G<f&&(f=G),G>h&&(h=G),B<d&&(d=B),B>x&&(x=B)}let g=h-f,w=x-d;for(let S=0,D=r.vertexCount;S<D;S++){let C=S*2,G=r.vertices[C+0],B=r.vertices[C+1],P=(G-f)/g,W=(B-d)/w;this._positionAttribute.setXYZ(S,G,B,0),this._normalAttribute.setXYZ(S,0,0,1),this._uvAttribute.setXY(S,P,W)}for(let S=0,D=r.elementCount;S<D;S++){let C=S*3,G=r.elements[C+0],B=r.elements[C+1],P=r.elements[C+2];this._indexAttribute.setX(C+0,G),this._indexAttribute.setX(C+1,B),this._indexAttribute.setX(C+2,P),this._drawCount+=3}}return this._positionAttribute.needsUpdate=!0,this._normalAttribute.needsUpdate=!0,this._uvAttribute.needsUpdate=!0,this._indexAttribute.needsUpdate=!0,this.setDrawRange(0,this._drawCount),this._drawCount>this._maxDrawCount}clone(){let e=new No(this._shape,this._curveSegments,this._maxCount);return e.userData=sa(this.userData),e}};import{BufferAttribute as Qc,BufferGeometry as d2}from"three";var Yc=class{constructor(e=256,t=!1){this.capacity=e,this.size=0,this.debug=t,this.debug&&console.log(`allocating with cap ${e}`);let r=e*Yc.eSize;this.buffer=new ArrayBuffer(r);let n=Float32Array.BYTES_PER_ELEMENT,s=0;this.positions=new Float32Array(this.buffer,s*n,3*e),s+=3*e,this.normals=new Float32Array(this.buffer,s*n,3*e),s+=3*e,this.uvs=new Float32Array(this.buffer,s*n,2*e)}realloc(e,t=!1){if(e<this.size)throw Error("cannot shrink buffer");if(e<=this.capacity&&!t)return;this.debug&&console.log(`resizing from ${this.capacity} \u2192 ${e}`);let r=e*Yc.eSize,n=new ArrayBuffer(r),s=Float32Array.BYTES_PER_ELEMENT,l=0,c=new Float32Array(n,l*s,3*e);l+=3*e;let f=new Float32Array(n,l*s,3*e);l+=3*e;let h=new Float32Array(n,l*s,2*e);c.set(this.positions.slice(0,this.size*3)),f.set(this.normals.slice(0,this.size*3)),h.set(this.uvs.slice(0,this.size*2)),this.buffer=n,this.positions=c,this.normals=f,this.uvs=h,this.capacity=e}get(e=1){let t=this.size+e;if(t>this.capacity){let n=this.capacity;for(;t>n;)n*=2;this.realloc(n)}let r=this.size;return this.size=t,r}reserve(e){let t=this.size+e;t>this.capacity&&this.realloc(t)}shrink(){this.debug&&console.log(`shrinking ${this.capacity} \u2192 ${this.size}`),this.realloc(this.size,!0)}},Zc=Yc;Zc.eSize=(3+3+2)*Float32Array.BYTES_PER_ELEMENT;var Fh=(i,e)=>([t,r])=>(r<t&&(r+=e),(i>=t?i:i+e)<=r),wa=class extends d2{constructor(e,t,r=0,n=12,s=3){super();this.type="ShapeGeometry";this.vertexCache={};this._shape=e,this._depth=t,this._bevel=r,this._curveSegments=n,this._bevelSegmentsInput=s,r<=0?(this._bevelSize=0,this._bevelSegments=0):(this._bevelSize=Math.min(r,t/2-1e-12),this._bevelSegments=Math.floor(s));let l=this._shape.extractShapePointsToFlatArray([],n),c=this._shape.shapeHoles.map(q=>{let E=q.extractShapePointsToFlatArray([],n),b=[];for(let R=E.length-1;R>=1;R-=2){let T=E[R-1],z=E[R-0];b.push(T,z)}return b}),f=wo({windingRule:Pt.ODD,elementType:Qt.BOUNDARY_CONTOURS,vertexSize:2,strict:!0,contours:[l]}),h=wo({windingRule:Pt.ODD,elementType:Qt.BOUNDARY_CONTOURS,vertexSize:2,strict:!0,contours:[...c]});if(!f)throw new Error("error generating geometry");let d=f.elementCount;if(h){f.elementCount+=h.elementCount;for(let q=0;q<h.elements.length;q++){let E=h.elements[q],b=q%2==0?f.vertexCount:0;f.elements.push(E+b)}for(let q=0;q<h.vertexIndices.length;q++){let E=h.vertexIndices[q],b=f.vertexCount;f.vertexIndices.push(E+b)}for(let q=0;q<h.vertices.length;q++){let E=h.vertices[q];f.vertices.push(E)}}let x=1/0,g=-1/0,w=1/0,S=-1/0;for(let q=0,E=f.vertexCount;q<E;q++){let b=q*2,R=f.vertices[b+0],T=f.vertices[b+1];R<x&&(x=R),R>g&&(g=R),T<w&&(w=T),T>S&&(S=T)}this._minX=x,this._minY=w,this._width=g-x,this._height=S-w;let D=f.vertexCount*2*(2+this._bevelSegments);this._buffer=new Zc(D);let C=[],G=[];for(let q=f.elementCount-1;q>=0;q--){let E=q>=d,b=q*2,R=f.elements[b+0],T=f.elements[b+1],z=R+T,A={start:R,count:T,normals:[],continuous:[],concave:[]},$=R,he=z-1,re=R+1,Ne=this._shape.roundedCurves.length;do{let k=$-R,H=f.vertices[he*2+0],_=f.vertices[he*2+1],J=f.vertices[$*2+0],ee=f.vertices[$*2+1],oe=f.vertices[re*2+0],se=f.vertices[re*2+1],ce=J-H,ue=ee-_,K=Math.sqrt(ce*ce+ue*ue);ce/=K,ue/=K;let ae=J-oe,ne=ee-se,Ce=Math.sqrt(ae*ae+ne*ne);ae/=Ce,ne/=Ce,A.normals[k*2+0]=-ne,A.normals[k*2+1]=ae,A.concave[k]=ce*ne-ue*ae>0;let Y=f.vertexIndices[$];if(Array.isArray(Y))A.continuous[k]=!1;else{let[le,pe]=this._shape.getCurveIndexFromVertexId(Y-1,!0);if(pe>0&&pe<1)A.continuous[k]=!0;else{let xe=pe===1?le+1:le-1;xe=(xe+Ne)%Ne;let _e=pe===1?0:1,de=this._shape.roundedCurves[le].getTangent(pe),we=this._shape.roundedCurves[xe].getTangent(_e);A.continuous[k]=de.dot(we)>.95}}E&&(A.normals[k*2+0]*=-1,A.normals[k*2+1]*=-1),[he,$,re]=[$,re,re+1],re>=z&&(re-=T)}while(re!==R+1);let ye=[];ye.push({bevelI:0,angle:0,size:0,boundary:{vertices:f.vertices.slice(R*2,z*2),vertexCount:T,vertexIndices:new Array(T).fill(!0).map((k,H)=>[H,H]),elements:[0,T],elementCount:1,mesh:null},reverseMap:[],insetPoints:f.vertices.slice(R*2,z*2)});for(let k=1;k<=this._bevelSegments;k++){let H=k/this._bevelSegments*Math.PI/2,_=(1-Math.cos(H))*this._bevelSize,J=[],ee=[],oe=[],se=[],ce=0;for(let K=0;K<T;K++){let ae=K*2,ne=(K-1+T)%T*2,Ce=f.vertices[A.start*2+ae+0],Y=f.vertices[A.start*2+ae+1],le=-A.normals[ne+0]*_,pe=-A.normals[ne+1]*_,xe=-A.normals[ae+0]*_,_e=-A.normals[ae+1]*_;if(A.concave[K]||!A.concave[K]&&E){let de=Math.atan2(pe,le),we=Math.atan2(_e,xe);we>de&&(we-=Math.PI*2);let Ve=we-de;if(A.continuous[K]||E){let Ge=de+Ve/2,Qe=Math.cos(Ge)*_,bt=Math.sin(Ge)*_;J[2*ce+0]=Ce+Qe*(E?-1:1),J[2*ce+1]=Y+bt*(E?-1:1),se[ce]=K,ce++}else{let Ge=Math.max(1,Math.floor(n/4*Math.abs(Ve)/Math.PI));for(let Qe=0;Qe<=Ge;Qe++){let bt=de+Ve*(Qe/Ge),Lt=Math.cos(bt)*_,At=Math.sin(bt)*_;J[2*ce+0]=Ce+Lt,J[2*ce+1]=Y+At,se[ce]=K,ce++}}}else J[2*ce+0]=Ce+le,J[2*ce+1]=Y+pe,se[ce]=K,ee[K]=ce,ce++,J[2*ce+0]=Ce,J[2*ce+1]=Y,se[ce]=K,ce++,J[2*ce+0]=Ce+xe,J[2*ce+1]=Y+_e,se[ce]=K,oe[K]=ce,ce++}let ue=wo({windingRule:Pt.POSITIVE,elementType:Qt.BOUNDARY_CONTOURS,vertexSize:2,strict:!0,contours:[J],edgeCreateCallback:K=>{let ne=K.Org.idx,Ce=se[ne],Y=se[(ne+1)%se.length];K.idx=[Ce,Y],K.Sym.idx=[Y,Ce]},vertexIdCallback:K=>{let ae=K.Lprev.idx;return[ae?ae[1]:0,K.idx[0]]}});if(!ue)throw console.log("Error"),new Error(`error generating bevel geometry for ${k}'th loop`);if(!ue.vertexCount)break;for(let K=0;K<ue.vertexIndices.length;K++){let[ae,ne]=ue.vertexIndices[K];if(ae===ne)continue;let Ce=ne;ne<ae&&(Ce+=T);for(let Y=ae;Y<Ce;Y++){let le=Y%T,pe=(Y+1)%T;if(!A.continuous[le]||!A.continuous[pe]){ue.vertexIndices[K]=[ae,le],ue.vertexIndices.splice(K+1,0,[pe,ne]),ue.vertices.splice((K+1)*2,0,ue.vertices[K*2],ue.vertices[K*2+1]);break}}}ye.push({bevelI:k,angle:H,size:_,boundary:ue,reverseMap:se,insetPoints:J})}let Me=(k,H,_)=>{let J=0,ee=k.boundary.vertexIndices.length;for(;J<ee&&_(k.boundary.vertexIndices[H]);)H=(H+1)%ee,J++;return J},Fe=C.length;for(let k=1;k<ye.length;k++){let H=ye[k-1],_=ye[k],J=H.boundary.vertexIndices.length,ee=_.boundary.vertexIndices.length;if(!J||!ee)break;let oe=A.concave.length,se=0,ce=Fh(se,T);for(;!H.boundary.vertexIndices.filter(ce).length||!_.boundary.vertexIndices.filter(ce).length;)se++,ce=Fh(se,T);let ue=H.boundary.vertexIndices.findIndex(ce),K=_.boundary.vertexIndices.findIndex(ce);do ue=(ue+1)%J;while(ce(H.boundary.vertexIndices[ue]));do K=(K+1)%ee;while(ce(_.boundary.vertexIndices[K]));se=(se+1)%T;let ae=se,ne=this.buildBevelVert(A,H,(ue-1+J)%J),Ce=this.buildBevelVert(A,_,(K-1+ee)%ee),Y=ne,le=Ce,pe,xe,_e=!1;do{ce=Fh(se,T);let de=Me(H,ue,ce),we=Me(_,K,ce),Ve=_e;if(_e=!1,de&&!we){for(let Ge=0;Ge<de;Ge++)pe=this.buildBevelVert(A,H,(ue+Ge)%J,Ge/(de-1)),C.push(Y.topN,pe.topP,le.topN),C.push(pe.bottomP,Y.bottomN,le.bottomN),Y=pe;_e=!0}else if(!de&&we)for(let Ge=0;Ge<we;Ge++)xe=this.buildBevelVert(A,_,(K+Ge)%ee,Ge/(we-1)),C.push(le.topN,Y.topP,xe.topP),C.push(Y.bottomP,le.bottomN,xe.bottomP),le=xe;else if(de&&we)if(pe=this.buildBevelVert(A,H,ue,0),xe=this.buildBevelVert(A,_,K,0),Ve?(C.push(Y.topN,xe.topP,le.topN),C.push(Y.topN,pe.topP,xe.topP),C.push(xe.bottomP,Y.bottomN,le.bottomN),C.push(pe.bottomP,Y.bottomN,xe.bottomP)):(C.push(Y.topN,pe.topP,le.topN),C.push(le.topN,pe.topP,xe.topP),C.push(pe.bottomP,Y.bottomN,le.bottomN),C.push(pe.bottomP,le.bottomN,xe.bottomP)),Y=pe,le=xe,de===we)for(let Ge=1;Ge<de;Ge++)pe=this.buildBevelVert(A,H,(ue+Ge)%J,Ge/(de-1)),xe=this.buildBevelVert(A,_,(K+Ge)%ee,Ge/(we-1)),C.push(Y.topN,pe.topP,le.topN),C.push(le.topN,pe.topP,xe.topP),C.push(pe.bottomP,Y.bottomN,le.bottomN),C.push(pe.bottomP,le.bottomN,xe.bottomP),Y=pe,le=xe;else if(de>we){let Ge=de/we,Qe=0;for(let bt=1;bt<de;bt++)pe=this.buildBevelVert(A,H,(ue+bt)%J,bt/(de-1)),C.push(Y.topN,pe.topP,le.topN),C.push(pe.bottomP,Y.bottomN,le.bottomN),Y=pe,bt>(Qe+1)*Ge&&(Qe++,xe=this.buildBevelVert(A,_,(K+Qe)%ee,Qe/(we-1)),C.push(le.topN,pe.topP,xe.topP),C.push(pe.bottomP,le.bottomN,xe.bottomP),le=xe)}else{let Ge=we/de,Qe=0;for(let bt=1;bt<we;bt++)xe=this.buildBevelVert(A,_,(K+bt)%ee,bt/(we-1)),C.push(le.topN,pe.topP,xe.topP),C.push(pe.bottomP,le.bottomN,xe.bottomP),le=xe,bt>(Qe+1)*Ge&&(Qe++,pe=this.buildBevelVert(A,H,(ue+Qe)%J,Qe/(de-1)),C.push(Y.topN,pe.topP,le.topN),C.push(pe.bottomP,Y.bottomN,le.bottomN),Y=pe)}ue=(ue+de)%J,K=(K+we)%ee,se=(se+1)%oe}while(se!==ae)}{let k=ye[0];for(let H=0,_=k.boundary.vertexCount;H<_;H++){let J=this.buildBevelVert(A,k,H),ee=this.buildBevelVert(A,k,(H+1)%_);C.push(ee.topP,J.topN,J.bottomN),C.push(ee.topP,J.bottomN,ee.bottomP)}}if(E){let k=[];for(let H=C.length-1;H>=Fe+2;H-=3){let _=C[H-2],J=C[H-1],ee=C[H-0];k.push(ee,J,_)}C.splice(Fe,C.length-Fe,...k)}if(E){let k=[];for(let H=ye[ye.length-1].boundary.vertices.length-1;H>=1;H-=2){let _=ye[ye.length-1].boundary.vertices[H-1],J=ye[ye.length-1].boundary.vertices[H-0];k.push(_,J)}G.push(k)}if(!E){let k=ye[ye.length-1],H=wo({windingRule:ye.length>1?Pt.POSITIVE:Pt.ODD,elementType:Qt.POLYGONS,vertexSize:2,strict:!0,contours:[k.insetPoints,...G]});if(!H)throw new Error("Error generating geometry for surface");for(let _=0;_<H.elementCount*3;_+=3){let J=this.buildSurfaceVert(H,H.elements[_+0]),ee=this.buildSurfaceVert(H,H.elements[_+1]),oe=this.buildSurfaceVert(H,H.elements[_+2]);C.push(J.top,ee.top,oe.top),C.push(oe.bottom,ee.bottom,J.bottom)}}this.vertexCache={}}this._buffer.shrink();let B=new Qc(Uint32Array.from(C),1),P=new Qc(this._buffer.positions,3),W=new Qc(this._buffer.normals,3),M=new Qc(this._buffer.uvs,2);P.needsUpdate=!0,W.needsUpdate=!0,M.needsUpdate=!0,B.needsUpdate=!0,this.setAttribute("position",P),this.setAttribute("normal",W),this.setAttribute("uv",M),this.setIndex(B)}buildSurfaceVert(e,t){let r=t.toString();if(r in this.vertexCache)return this.vertexCache[r];let n=e.vertices[t*2+0],s=e.vertices[t*2+1],l=(n-this._minX)/this._width,c=(s-this._minY)/this._height,f=this._buffer.get(2),h=f*3,d=f*2,x={top:f+0,bottom:f+1};return this._buffer.positions[h+0]=n,this._buffer.positions[h+1]=s,this._buffer.positions[h+2]=this._depth,this._buffer.normals[h+0]=0,this._buffer.normals[h+1]=0,this._buffer.normals[h+2]=1,this._buffer.uvs[d+0]=l,this._buffer.uvs[d+1]=c,this._buffer.positions[h+3]=n,this._buffer.positions[h+4]=s,this._buffer.positions[h+5]=0,this._buffer.normals[h+3]=0,this._buffer.normals[h+4]=0,this._buffer.normals[h+5]=-1,this._buffer.uvs[d+2]=l,this._buffer.uvs[d+3]=c,this.vertexCache[r]=x,x}buildBevelVert(e,t,r,n=1){let s=`${t.bevelI}:${r}`;if(s in this.vertexCache)return this.vertexCache[s];let[l,c]=t.boundary.vertexIndices[r],f,h,d,x;l!==c?(h=l,f=c,x=!1,d=e.continuous[h]&&e.continuous[f]):(f=l,h=(f-1+e.count)%e.count,x=e.concave[f]&&t.bevelI>0,d=e.continuous[f]||x);let g=Math.cos(t.angle),w=Math.sin(t.angle),S=r*2,D=f*2,C=h*2,G=t.boundary.vertices[S+0],B=t.boundary.vertices[S+1],P=(1-w)*this._bevelSize,W=(G-this._minX)/this._width,M=(B-this._minY)/this._height,q=e.normals[D+0],E=e.normals[D+1],b=e.normals[C+0],R=e.normals[C+1];if(x){let he=b-q,re=R-E;q=q+he*(1-n),E=E+re*(1-n);let Ne=Math.sqrt(q*q+E*E);q/=Ne,E/=Ne}let T=this._buffer.get(d?2:4),z=T*3,A=T*2,$={i:r,fi:f,topP:T+0,topN:T+0,bottomP:T+1,bottomN:T+1};return this._buffer.positions[z+0]=G,this._buffer.positions[z+1]=B,this._buffer.positions[z+2]=this._depth-P,this._buffer.normals[z+0]=q*g,this._buffer.normals[z+1]=E*g,this._buffer.normals[z+2]=w,this._buffer.uvs[A+0]=W,this._buffer.uvs[A+1]=M,this._buffer.positions[z+3]=G,this._buffer.positions[z+4]=B,this._buffer.positions[z+5]=P,this._buffer.normals[z+3]=q*g,this._buffer.normals[z+4]=E*g,this._buffer.normals[z+5]=-w,this._buffer.uvs[A+2]=M,this._buffer.uvs[A+3]=W,d||(T+=2,z+=6,A+=4,$.topP=T+0,$.bottomP=T+1,this._buffer.positions[z+0]=G,this._buffer.positions[z+1]=B,this._buffer.positions[z+2]=this._depth-P,this._buffer.normals[z+0]=b*g,this._buffer.normals[z+1]=R*g,this._buffer.normals[z+2]=w,this._buffer.uvs[A+0]=W,this._buffer.uvs[A+1]=M,this._buffer.positions[z+3]=G,this._buffer.positions[z+4]=B,this._buffer.positions[z+5]=P,this._buffer.normals[z+3]=b*g,this._buffer.normals[z+4]=R*g,this._buffer.normals[z+5]=-w,this._buffer.uvs[A+2]=M,this._buffer.uvs[A+3]=W),this.vertexCache[s]=$,$}clone(){let e=new wa(this._shape,this._depth,this._bevel,this._curveSegments,this._bevelSegmentsInput);return e.userData=sa(this.userData),e}};var ur=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var h,d,x,g,w,S,D;let t=Object.assign({},(h=e==null?void 0:e.parameters)!=null?h:{width:100,subdivisions:40,roundness:0,extrudeDepth:0,surfaceMaxCount:100,extrudeBevelSize:0,extrudeBevelSegments:3},i.parameters),r=Math.abs(t.width),n=Math.abs((d=t.height)!=null?d:t.width),s=Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(x=t.depth)!=null?x:0),l=(g=i.shape)!=null?g:e==null?void 0:e.shape,c=(w=l==null?void 0:l.roundness)!=null?w:t.roundness;l!==void 0&&(l instanceof st?(l.width!==r||l.height!==n)&&l.applySize(r,n):l=new st(r,n).fromJSON(l),((S=i.parameters)==null?void 0:S.roundness)!==void 0&&((D=i.parameters)==null?void 0:D.roundness)>0&&l.update(!1));let f=l!=null?l:new st(r,n);return{parameters:Object.assign(t,{width:r,height:n,depth:s,extrudeDepth:s,roundness:c}),shape:f}}static build(i){let{extrudeDepth:e,extrudeBevelSize:t,extrudeBevelSegments:r,subdivisions:n,roundness:s,surfaceMaxCount:l}=i.parameters;i.shape.roundness=s;let c;return e<=0?c=new No(i.shape,n,l):c=new wa(i.shape,e,t,n,r),Object.assign(c,{userData:fe(U({},i),{type:"VectorGeometry"})})}};import{MathUtils as D0,Vector2 as B0}from"three";var G0=Math.PI*2,j0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var n,s,l;let t=Object.assign({},(n=e==null?void 0:e.parameters)!=null?n:{width:100,depth:0,spikes:64,angle:360,innerRadius:0,extrudeDepth:0,extrudeBevelSize:0,extrudeBevelSegments:1,surfaceMaxCount:1e3},i.parameters);return{shape:i.shape&&i.shape instanceof st?i.shape:new st,parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((s=t.height)!=null?s:t.width),depth:Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(l=t.depth)!=null?l:0)})}}static build(i){let{width:e,height:t,spikes:r,angle:n,innerRadius:s,depth:l,extrudeBevelSize:c,extrudeBevelSegments:f,surfaceMaxCount:h}=i.parameters,d=i.shape,x=e*.5,g=t*.5,w=m2(d,x,g,n*Math.PI/180,r,s);d.isClosed=!0,d.update();let S=ur.create({shape:d,parameters:{subdivisions:w,surfaceMaxCount:h,depth:l,extrudeBevelSize:c,extrudeBevelSegments:f}});return Object.assign(S,{userData:fe(U({},i),{type:"EllipseGeometry"})})}};function m2(i,e,t,r,n,s){if(r>=G0)return n>30||n%4==0?(y2(i,e,t,s),Math.round(n/4)):E0(i,r,n,e,t,s);let l={x:0,y:t},c=r+Math.PI*.5,f={x:Math.cos(c)*e,y:Math.sin(c)*t},h=I0({px:l.x,py:l.y,cx:f.x,cy:f.y,rx:e,ry:t,largeArcFlag:r>Math.PI,sweepFlag:!0});return n>30||n%h.length==0?g2(i,l.x,l.y,h,n,e,t,s):E0(i,r,n,e,t,s)}function g2(i,e,t,r,n,s,l,c){let f=Math.round(n/r.length);i.addPoint(Cs(e,t));for(let h=0,d=r.length;h<d;h++){let x=r[h],g=i.points[h],w=Cs(x.x,x.y);g.controls[1].position.set(x.x1,x.y1),w.controls[0].position.set(x.x2,x.y2),i.addPoint(w)}return c>0?R0(i,s,l,c):i.addPoint(Cs(0,0)),f}function E0(i,e,t,r,n,s){let l=-e/t;for(let c=0;c<=t;c++){let f=l*c,h=Math.sin(f)*r,d=Math.cos(f)*n;i.addPoint(Cs(h,d))}return e<G0?s>0?R0(i,r,n,s):i.addPoint(Cs(0,0)):(i.removePoint(i.points[i.points.length-1]),s>0&&z0(i,r,n,s)),1}function y2(i,e,t,r=0,n=0,s=0){let l=.5522847498,c=e*l,f=t*l;i.addPoint(eu(n-e,s,n-e,s-f,n-e,s+f)),i.addPoint(eu(n,s+t,n-c,s+t,n+c,s+t)),i.addPoint(eu(n+e,s,n+e,s+f,n+e,s-f)),i.addPoint(eu(n,s-t,n+c,s-t,n-c,s-t)),r>0&&z0(i,e,t,r)}function Cs(i,e){return new Kn(D0.generateUUID(),new B0(i,e))}function eu(i,e,t,r,n,s){let l=Cs(i,e);return l.controls[0].position.set(t,r),l.controls[1].position.set(n,s),l}function R0(i,e,t,r){F0(i,e,t,r).forEach(s=>i.addPoint(s))}function z0(i,e,t,r){let n=F0(i,e,t,r),s=new st;n.forEach(l=>s.addPoint(l)),s.isClosed=!0,i.shapeHoles.push(s)}function F0(i,e,t,r){let n=r*e/100,s=n*(Math.abs(t)/Math.abs(e)),l=new B0(n/e,s/t),c=i.points.map(f=>{let h=f.clone();return h.uuid=D0.generateUUID(),h}).reverse();return c.forEach(f=>{f.position.multiply(l);let h=f.controls[0].position.clone().multiply(l),d=f.controls[1].position.clone().multiply(l);f.controls[0].position.copy(d),f.controls[1].position.copy(h)}),c}import{BufferGeometry as x2,Float32BufferAttribute as Vh,Vector3 as V0}from"three";var U0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var c,f,h;let t=Object.assign({},(c=e==null?void 0:e.parameters)!=null?c:{width:100,revolutions:2,segments:40,pathRadius:10,pathType:0,pathSegments:30,cornerRadius:30,cornerSegments:4},i.parameters),r=Math.abs(t.width),n=Math.abs((f=t.height)!=null?f:r),s=Math.abs((h=t.depth)!=null?h:r),l=Math.abs(Math.min(r,s))/2;return{parameters:Object.assign(t,{width:r,height:n,depth:s,radius:l,segments:Math.round(t.segments),pathSegments:Math.round(t.pathSegments),cornerSegments:Math.round(t.cornerSegments)})}}static build(i){let{width:e,height:t,depth:r,radius:n,revolutions:s,segments:l,pathRadius:c,pathType:f,pathSegments:h,cornerRadius:d,cornerSegments:x}=i.parameters,g=new tu(!1,e,t,r,n,s,l,c,f,h,d,x);return Object.assign(g,{userData:fe(U({},i),{type:"HelixGeometry"})})}},tu=class extends x2{constructor(e=!0,t=1,r=1,n=1,s=1,l=1,c=1,f=1,h=1,d=1,x=1,g=1){super();let w=e&&l===1;w&&(g=0),x>100&&(x=100);let S=()=>new V0,D=new V0,C=S(),G=S(),B=S(),P,W,M,q,E,b,R,T,z=S(),A=S(),$=S(),he=S(),re=S(),Ne=S(),ye=S(),Me=S(),Fe=r-2*f+.001,k=Fe/l,H=Math.ceil(c*l),_=H+1,J=Fe/H,ee=-Fe/2,oe=d+1,se=2*Math.PI/d,ce=Math.PI/2/g,ue=.01,K=Math.min((1-x/100)*f,f-ue),ae=f-K,ne=0,Ce=2,Y=g*Ce+Ce,le=oe*Y/Ce,pe=le+oe*_,xe=oe*(_+Y),[_e,de,we]=[3,3,2].map(dt=>Array(xe*dt).fill(0)),Ve=[],Ge=s-f;function Qe(dt,Wt){let ar=Math.PI/2;b=Wt*J,T=2*Math.PI*(b%k)/k+ar,b+=ee,R=Math.sin(T)*Ge,E=Math.cos(T)*Ge,e?dt.set(E,R,b):dt.set(E,b,R)}Qe(D,-1e-10),Qe(C,0),z.copy(D),Qe(D,1);let bt=D.distanceTo(C),Lt=ae+K,At=bt*H+2*Lt,sr=K,Ur=At-Lt;for(let dt=0;dt<=H;dt++){Qe(G,dt),Me.subVectors(G,z).normalize(),z.copy(G),Ne.copy(G).setComponent(+e+1,0).normalize(),ye.crossVectors(Me,Ne).normalize();let Wt=dt===0,ar=dt===H,Ao=Wt?3*Math.PI/2:ce,Oo=Wt?sr:Ur,Po=Wt?oe:pe,ro=Wt?0:xe-oe,no=Me.clone().multiplyScalar(Wt?-ae:ae).add(G),Do=Me.clone().multiplyScalar(Wt?-1:1).normalize();for(let Mr=0;Mr<oe;Mr++){let io=Mr*se;if(A.addVectors(D.copy(Ne).multiplyScalar(f*Math.cos(io)),C.copy(ye).multiplyScalar(f*Math.sin(io))),$.copy(A).normalize(),Wt||ar){w||(ne=ro+Mr,[0,1,2].forEach(Jt=>{_e[ne*3+Jt]=no.getComponent(Jt),de[ne*3+Jt]=Do.getComponent(Jt)}),we[ne*2]=+ar,we[ne*2+1]=Mr/d),C.copy($).multiplyScalar(K),B.addVectors(G,C);for(let Jt=0;Jt<g;Jt++){let ti=Jt*ce+Ao;he.addVectors(D.copy(Me).multiplyScalar(ae*Math.sin(ti)),C.copy($).multiplyScalar(ae*Math.cos(ti))),re.copy(he).normalize(),C.addVectors(B,he),he.normalize(),ne=Po+Jt*oe+Mr,[0,1,2].forEach(Ee=>{_e[ne*3+Ee]=C.getComponent(Ee),de[ne*3+Ee]=re.getComponent(Ee)});let Bo=+Wt+Math.sin(ti);we[ne*2]=(Oo+ae*Bo)/At,we[ne*2+1]=Mr/d}}C.addVectors(G,A),ne=le+dt*oe+Mr,[0,1,2].forEach(Jt=>{_e[ne*3+Jt]=C.getComponent(Jt),de[ne*3+Jt]=$.getComponent(Jt)}),we[ne*2]=(Lt+dt*bt)/At,we[ne*2+1]=Mr/d}}let Ht=_+2*g+Ce,kr=1,[wn,Nn]=w?[kr,kr+_-1]:[0,Ht-1];for(let dt=wn;dt<=Nn-1;dt++){let Wt=w&&dt===Nn-1;for(let ar=0;ar<oe-1;ar++)P=dt*oe+ar,W=P+1,M=(Wt?ar:P)+oe,q=(Wt?ar+1:W)+oe,dt===0?Ve.push(W,q,M):dt===Ht-2?Ve.push(P,W,M):Ve.push(P,W,M,W,q,M)}this.setIndex(Ve),this.setAttribute("position",new Vh(_e,3)),this.setAttribute("normal",new Vh(de,3)),this.setAttribute("uv",new Vh(we,2))}};import{IcosahedronBufferGeometry as v2}from"three";var k0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,detail:0,corner:0,cornerSides:4},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e,height:t,depth:r,detail:n,corner:s,cornerSides:l}=i.parameters,c=n===0&&s!==0?new ru(e*.5,s,l):new v2(e*.5,n);return c.scale(1,t/e,r/e),Object.assign(c,{userData:fe(U({},i),{type:"IcosahedronGeometry"})})}},ru=class extends So{constructor(e=1,t=.2,r=4){let n=(1+Math.sqrt(5))/2,s=[-1,n,0,1,n,0,-1,-n,0,1,-n,0,0,-1,n,0,1,n,0,-1,-n,0,1,-n,n,0,-1,n,0,1,-n,0,-1,-n,0,1],l=[0,11,5,0,5,1,0,1,7,0,7,10,0,10,11,1,5,9,5,11,4,11,10,2,10,7,6,7,1,8,3,9,4,3,4,2,3,2,6,3,6,8,3,8,9,4,9,5,2,4,11,6,2,10,8,6,7,9,8,1],c="IcosahedronGeometry";super(s,l,c,e,t,r);this.type=c}static fromJSON(e){return new ru(e.radius,e.corner,e.cornerSides)}};import{LatheBufferGeometry as b2,Shape as S2}from"three";var H0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s,l,c;((n=(r=i.parameters)==null?void 0:r.points)!=null?n:[]).forEach(f=>{Array.isArray(f)&&(f.x=f[0],f.y=f[1])});let t=Object.assign({},(s=e==null?void 0:e.parameters)!=null?s:{width:100,segments:64,verticalSegments:64,points:[{x:0,y:-50,id:0},{x:50,y:-50,id:1},{x:50,y:50,id:2},{x:0,y:50,id:3}]},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((l=t.height)!=null?l:t.width),depth:Math.abs((c=t.depth)!=null?c:t.width)})}}static build(i){let{points:e,segments:t,verticalSegments:r}=i.parameters,n=new S2;n.moveTo(e[0].x,e[0].y),n.bezierCurveTo(e[1].x,e[1].y,e[2].x,e[2].y,e[3].x,e[3].y);let s=new b2(n.extractPoints(r).shape,t);return s.rotateZ(Math.PI),Object.assign(s,{userData:fe(U({},i),{type:"LatheGeometry"})})}};import{BufferGeometry as q0,BufferGeometryLoader as I2,Vector3 as M2,BoxBufferGeometry as $0}from"three";import{BufferGeometry as w2,Vector2 as Uh,Vector3 as W0}from"three";import{Geometry as N2,Face3 as C2}from"three/examples/jsm/deprecated/Geometry.js";var L2=["a","b","c"];function _2(i,e){switch(e){case"c":return i.c;case"b":return i.b;case"a":default:return i.a}}function kh(i,e,t){let r=Math.min(i,e),n=Math.max(i,e),s=r+"_"+n;return t.get(s)}function Hh(i,e,t,r,n,s){let l=Math.min(i,e),c=Math.max(i,e),f=l+"_"+c,h;if(r.has(f))h=r.get(f);else{let d=t[l],x=t[c];h={a:d,b:x,newEdge:null,faces:[]},r.set(f,h)}h.faces.push(n),s[i].edges.push(h),s[e].edges.push(h)}function T2(i,e,t,r){let n,s,l;for(n=0,s=i.length;n<s;n++)t[n]={edges:[]};for(n=0,s=e.length;n<s;n++)l=e[n],Hh(l.a,l.b,i,r,l,t),Hh(l.b,l.c,i,r,l,t),Hh(l.c,l.a,i,r,l,t)}function nu(i,e,t,r,n){i.push(new C2(e,t,r,void 0,void 0,n))}function Ls(i,e){return Math.abs(e-i)/2+Math.min(i,e)}function iu(i,e,t,r){i.push([e.clone(),t.clone(),r.clone()])}var Wh=class{constructor(e=1){this.subdivisions=e}modify(e){e instanceof w2?e=new N2().fromBufferGeometry(e):e=e.clone(),e.mergeVertices();let t=this.subdivisions;for(;t-- >0;)this._smooth(e);return e.computeFaceNormals(),e.computeVertexNormals(),e}_smooth(e){let t=new W0,r,n,s,l,c,f=e.vertices,h=e.faces,d=e.faceVertexUvs[0],x=d!==void 0&&d.length>0,g=[],w=new Map;T2(f,h,g,w);let S=[],D,C,G,B,P,W,M;for(let ue of Array.from(w.keys())){for(C=w.get(ue),G=new W0,P=3/8,W=1/8,M=C.faces.length,M!=2&&(P=.5,W=0,M!=1),G.addVectors(C.a,C.b).multiplyScalar(P),t.set(0,0,0),l=0;l<M;l++){for(B=C.faces[l],c=0;c<3&&(D=f[_2(B,L2[c])],!(D!==C.a&&D!==C.b));c++);D&&t.add(D)}t.multiplyScalar(W),G.add(t),C.newEdge=S.length,S.push(G)}let q,E,b,R,T,z,A,$=[];for(n=0,s=f.length;n<s;n++){for(z=f[n],T=g[n].edges,r=T.length,r==3?q=3/16:r>3&&(q=3/(8*r)),E=1-r*Number(q),b=q,r<=2&&(r==2?(E=3/4,b=1/8):r==1||r==0),A=z.clone().multiplyScalar(E),t.set(0,0,0),l=0;l<r;l++)R=T[l],D=R.a!==z?R.a:R.b,t.add(D);t.multiplyScalar(Number(b)),A.add(t),$.push(A)}let he=$.concat(S),re=$.length,Ne,ye,Me,Fe=[],k=[],H,_,J,ee,oe=new Uh,se=new Uh,ce=new Uh;for(n=0,s=h.length;n<s;n++)B=h[n],Ne=Number(kh(B.a,B.b,w).newEdge)+re,ye=Number(kh(B.b,B.c,w).newEdge)+re,Me=Number(kh(B.c,B.a,w).newEdge)+re,nu(Fe,Ne,ye,Me,B.materialIndex),nu(Fe,B.a,Ne,Me,B.materialIndex),nu(Fe,B.b,ye,Ne,B.materialIndex),nu(Fe,B.c,Me,ye,B.materialIndex),x&&(H=d[n],_=H[0],J=H[1],ee=H[2],oe.set(Ls(_.x,J.x),Ls(_.y,J.y)),se.set(Ls(J.x,ee.x),Ls(J.y,ee.y)),ce.set(Ls(_.x,ee.x),Ls(_.y,ee.y)),iu(k,oe,se,ce),iu(k,_,oe,ce),iu(k,J,se,oe),iu(k,ee,ce,se));e.vertices=he,e.faces=Fe,x&&(e.faceVertexUvs[0]=k)}};var er=new M2,J0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var s,l;let t=(l=(s=i.geometry)!=null?s:e==null?void 0:e.geometry)!=null?l:new q0().copy(new $0(100,100,100)),r;e===void 0?(t.computeBoundingBox(),t.boundingBox.getSize(er),r={width:er.x,height:er.y,depth:er.z,subdivisions:0}):r=e.parameters;let n=U(U({},r),i.parameters);return{parameters:{width:Math.abs(n.width),height:Math.abs(n.height),depth:Math.abs(n.depth),subdivisions:Math.abs(n.subdivisions)},geometry:t}}static build(i){var f;let{width:e,height:t,depth:r,subdivisions:n}=i.parameters,s=(f=i.geometry)!=null?f:new q0().copy(new $0(100,100,100)),l=s.userData.parameters;l===void 0?(s.computeBoundingBox(),s.boundingBox.getSize(er)):er.set(l.width,l.height,l.depth),(e!==er.x||t!==er.y||r!==er.z)&&s.scale(er.x===0?1:e/er.x,er.y===0?1:t/er.y,er.z===0?1:r/er.z);let c=s.originalGeometry;return n>0?(c===void 0||(l==null?void 0:l.subdivisions)!==n)&&(c===void 0&&(c=s),s=new Wh(n).modify(c).toBufferGeometry()):(c!==void 0&&(s=c),c=void 0,s.getAttribute("normal")===void 0&&s.computeVertexNormals()),c!==void 0&&Object.assign(s,{originalGeometry:c}),delete i.geometry,Object.assign(s,{userData:fe(U({},i),{type:"NonParametricGeometry"})})}static loadFromUrl(i,e,t){new I2(t).load(i,n=>{let s=this.normalizeInputs({geometry:n});n.boundingBox.getSize(er);let l=100/er.x;Object.assign(s.parameters,{width:100,height:er.y*l,depth:er.z*l}),e(this.build(s))})}};var K0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var n,s,l,c;let t=Object.assign({},(n=e==null?void 0:e.parameters)!=null?n:{width:100,depth:0,spikes:5,cornerRadius:0,extrudeDepth:0,extrudeBevelSize:0,extrudeBevelSegments:3},i.parameters);return{shape:i.shape&&i.shape instanceof st?i.shape:new st,parameters:Object.assign(t,{surfaceMaxCount:((s=t.surfaceMaxCount)!=null?s:t.cornerRadius>0)?1e3:100,width:Math.abs(t.width),height:Math.abs((l=t.height)!=null?l:t.width),depth:Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(c=t.depth)!=null?c:0)})}}static build(i){let{width:e,height:t,spikes:r,cornerRadius:n,depth:s,extrudeBevelSize:l,extrudeBevelSegments:c,surfaceMaxCount:f}=i.parameters,h=i.shape,d=e*.5,x=t*.5,g=0,w=0,S=2*Math.PI/r;for(let C=0;C<r;C++){let G=S*C,B=g+Math.sin(G)*d,P=w+Math.cos(G)*x;h.addPoint(h.createPoint(B,P))}h.isClosed=!0;for(let C=0,G=h.points.length;C<G;C++)h.points[C].roundness=n;h.roundness=n,h.update();let D=ur.create({shape:h,parameters:{surfaceMaxCount:f,roundness:n,depth:s,extrudeBevelSize:l,extrudeBevelSegments:c}});return Object.assign(D,{userData:fe(U({},i),{type:"PolygonGeometry"})})}};import{BufferGeometry as A2,Float32BufferAttribute as qh,Vector2 as Xn,Vector3 as or}from"three";var X0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,radialSegments:4,heightSegments:1,cornerRadius:0,cornerSegments:8,openEnded:!1},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e,height:t,depth:r,radialSegments:n,heightSegments:s,openEnded:l,cornerRadius:c,cornerSegments:f}=i.parameters,h=new Z0(e*.5,t,n,s,l,c,f);return h.scale(1,1,r/e),Object.assign(h,{userData:fe(U({},i),{type:"PyramidGeometry"})})}};function Na(i,e,t){t.x=i.x*e.x,t.y=i.y,t.z=i.x*e.y}function $h(i,e,t,r,n,s){let l=e.clone().sub(i),c=t.clone().sub(i),f=l.angleTo(c);if(l.normalize(),c.normalize(),r===n){let h=l.add(c).normalize();s.copy(i).addScaledVector(h,r/Math.sin(f/2))}else{let h=l.angleTo(c);s.copy(i),s.addScaledVector(l,n/Math.sin(h)),s.addScaledVector(c,r/Math.sin(h))}}function O2(i,e,t){let r=i.clone().sub(e),n=t.clone().sub(e);return r.projectOnVector(n),r.add(e)}var Z0=class extends A2{constructor(e=.5,t=1,r=4,n=1,s=!1,l=0,c=4){super();r=Math.floor(Math.max(3,r)),n=Math.floor(n),c=Math.floor(c);let f=[],h=[],d=[],x=[],g=0,w=t/2,S=Math.PI/r,D=e*Math.cos(Math.PI/r),C=2*Math.PI/r,G=(r-2)*Math.PI/r,B=Math.PI-G,P=new or(0,-w,0),W=new or(0,w,0),M=new Xn(e,-w),q=new Xn(D,-w),E=new Xn(0,W.y).sub(q),b=new Xn(0,W.y).sub(M),R=new Xn(E.y,-E.x).normalize(),T=new Xn(b.y,-b.x).normalize(),A=e*Math.cos(Math.PI/r)*Math.tan((Math.PI-E.angle())/2)-1e-8;l=Math.min(l,A);let $;{let k=new or(R.x,R.y,0),H=new or(Math.cos(C)*k.x,k.y,Math.sin(C)*k.x);$=k.angleTo(H)}let he=l/Math.tan((Math.PI-E.angle())/2),re=l/Math.tan((Math.PI-$)/2),Ne=new or;if(!s){h.push(P.x,P.y,P.z),d.push(0,-1,0),x.push(0,0);let k=g++,H=[],_=M.clone(),J=he/Math.cos(Math.PI/r);_.x-=J;for(let ee=0;ee<r;ee++){let oe=ee/r*Math.PI*2+S,se=new Xn(Math.sin(oe),Math.cos(oe));Na(_,se,Ne),h.push(Ne.x,Ne.y,Ne.z),d.push(0,-1,0),x.push(0,0),H.push(g++)}for(let ee=0;ee<H.length;ee++)f.push(H[ee],k,H[(ee+1)%H.length])}let ye=[];{let k=new or,H=new or,_=new or,J=new or,ee=new or,oe=new or;for(let se=0;se<r;se++){let ce=se/r*Math.PI*2+S,ue=(se+.5)/r*Math.PI*2+S,K=(se+1)/r*Math.PI*2+S,ae=new Xn(Math.sin(ce),Math.cos(ce)),ne=new Xn(Math.sin(ue),Math.cos(ue)),Ce=new Xn(Math.sin(K),Math.cos(K));Na(M,ae,H),Na(M,Ce,_),Na(R,ne,k),$h(W,H,_,re,re,J),h.push(J.x,J.y,J.z),$h(H,W,_,re,he,ee),h.push(ee.x,ee.y,ee.z),$h(_,H,W,he,re,oe),h.push(oe.x,oe.y,oe.z),d.push(k.x,k.y,k.z),d.push(k.x,k.y,k.z),d.push(k.x,k.y,k.z),x.push(0,0),x.push(0,0),x.push(0,0);let Y=g++,le=g++,pe=g++;if(f.push(Y,le,pe),l>0){{let de=H.clone().add(_).multiplyScalar(.5),we=W.clone().sub(de).normalize(),Ge=P.clone().sub(de).normalize().add(we).normalize().multiplyScalar(-1),Qe=oe.clone().sub(ee);Me(de,Qe,Ge,E.angle())}let xe,_e;{let de=new or;Na(T,Ce,de);let we=oe.clone().add(J).multiplyScalar(.5);we=O2(we,_,W);let Ve=oe.clone().sub(J);[xe,_e]=Me(we,Ve,de,$,J.y)}{let de=xe,we=de.clone().setY(0).normalize(),Ve=new or(0,-1,0),Ge=we.clone().cross(Ve);Fe(de,we,Ve,Ge)}ye.concat(_e);{let de=E.angle(),we=Math.PI-de,Ve=W.clone();Ve.y-=l/Math.sin(de-Math.PI/2);let Ge=new or,Qe=[];for(let Lt=0;Lt<c;Lt++){let At=[],sr=Math.PI/2-we*Lt/c,Ur=Math.cos(sr),Ht=Math.sin(sr),kr=ue;for(let wn=0;wn<=Lt;wn++){let Nn=Math.cos(kr),dt=Math.sin(kr);k.x=Ur*dt,k.y=Ht,k.z=Ur*Nn,Ge.copy(Ve).addScaledVector(k,l),h.push(Ge.x,Ge.y,Ge.z),d.push(k.x,k.y,k.z),x.push(0,0),At.push(g++),kr+=Math.PI*2/Lt/r}Qe.push(At)}_e.reverse(),Qe.push(_e);let bt=Qe.length-1;for(let Lt=0;Lt<bt;Lt++){let At=Qe[Lt],sr=Qe[Lt+1],Ur=At.length-1;f.push(sr[1],At[0],sr[0]);for(let Ht=1;Ht<=Ur;Ht++)f.push(At[Ht],At[Ht-1],sr[Ht]),f.push(sr[Ht+1],At[Ht],sr[Ht])}}}}}this.setIndex(f),this.setAttribute("position",new qh(h,3)),this.setAttribute("normal",new qh(d,3)),this.setAttribute("uv",new qh(x,2));function Me(k,H,_,J,ee){let oe=-J/2,se=(Math.PI-J)/2,ce=H.clone().normalize().cross(_);k.addScaledVector(_,-l/Math.sin(se));let ue=new or,K=new or,ae=1,ne=g,Ce=[];for(let Y=0;Y<=c;Y++){let le=oe+Y/c*J;K.set(0,0,0),K.addScaledVector(ce,Math.sin(le)),K.addScaledVector(_,Math.cos(le));for(let pe=0;pe<=ae;pe++){let xe=pe/ae-.5;if(ue.copy(k),ue.addScaledVector(H,xe),ue.addScaledVector(K,l),ee!=null){let _e=Math.max(0,ue.y-ee);ue.addScaledVector(H,-_e/H.y)}h.push(ue.x,ue.y,ue.z),d.push(K.x,K.y,K.z),x.push(0,0),pe===0&&Ce.push(g),g++}}for(let Y=0;Y<c;Y++)for(let le=0;le<ae;le++){let pe=ne+le+(ae+1)*Y,xe=pe+(ae+1),_e=xe+1,de=pe+1;f.push(pe,xe,de),f.push(xe,_e,de)}return[k.clone().addScaledVector(H,.5),Ce]}function Fe(k,H,_,J){let ee=Math.PI/2,oe=b.angle()-ee,se=[],ce=new or,ue=new or;for(let ae=0;ae<=c;ae++){let ne=[],Ce=ae/c;for(let Y=0;Y<=ae;Y++){let pe=((ae?Y/ae:0)-.5)*B,xe=Math.cos(pe),_e=Math.sin(pe),de=Math.atan(Math.tan(oe)*xe),we=(ee+de)*Ce,Ve=Math.cos(we),Ge=Math.sin(we);ce.set(0,0,0),ce.addScaledVector(H,Ge*xe),ce.addScaledVector(_,Ve),ce.addScaledVector(J,Ge*_e),ue.copy(k).addScaledVector(ce,l),h.push(ue.x,ue.y,ue.z),d.push(ce.x,ce.y,ce.z),x.push(0,0),ne.push(g++)}se.push(ne)}let K=se.length-1;for(let ae=0;ae<K;ae++){let ne=se[ae],Ce=se[ae+1],Y=ne.length-1;f.push(ne[0],Ce[1],Ce[0]);for(let le=1;le<=Y;le++)f.push(ne[le-1],ne[le],Ce[le]),f.push(ne[le],Ce[le+1],Ce[le])}}}};var ou=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var l,c,f,h,d;let t=Object.assign({},(l=e==null?void 0:e.parameters)!=null?l:{width:100,depth:0,cornerRadius:[0,0,0,0],cornerType:1,extrudeDepth:0,extrudeBevelSize:0,extrudeBevelSegments:1},i.parameters),r=Object.assign((c=e==null?void 0:e.ui)!=null?c:{enabledIndieCorners:!1},i.ui),n=t.cornerRadius.reduce((x,g)=>x+g,0);return{shape:i.shape&&i.shape instanceof st?i.shape:new st,parameters:Object.assign(t,{surfaceMaxCount:((f=t.surfaceMaxCount)!=null?f:n>0)?1e3:100,width:Math.abs(t.width),height:Math.abs((h=t.height)!=null?h:t.width),depth:Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(d=t.depth)!=null?d:0)}),ui:r}}static build(i){let e=i.shape,{width:t,height:r,cornerRadius:n,cornerType:s,depth:l,extrudeBevelSize:c,extrudeBevelSegments:f,surfaceMaxCount:h}=i.parameters,d={x:t*.5,y:r*.5},x={x:-d.x,y:-d.y},g={x:d.x,y:d.y};function w(M,q,E){return q>t&&E>r?Math.min(M*t/q,M*r/E):q>t?M*t/q:E>r?M*r/E:M}let S=[];S[0]=n[0]===0?0:w(n[0],n[0]+n[3],n[0]+n[1]),S[1]=n[1]===0?0:w(n[1],n[1]+n[2],n[1]+n[0]),S[2]=n[2]===0?0:w(n[2],n[2]+n[1],n[2]+n[3]),S[3]=n[3]===0?0:w(n[3],n[3]+n[0],n[3]+n[2]);let D=x.x,C=g.x,G=g.y,B=x.y;e.addPoint(e.createPoint(D,G)),e.addPoint(e.createPoint(C,G)),e.addPoint(e.createPoint(C,B)),e.addPoint(e.createPoint(D,B)),e.isClosed=!0;let P=!0;for(let M=0,q=e.points.length;M<q;M++)e.points[M].roundness=S[M],M>0&&S[M]!==S[M-1]&&(P=!1);P&&(e.roundness=S[0]),e.useCubicForRoundedCorners=s!==1,e.update();let W=ur.create({shape:e,parameters:{surfaceMaxCount:h,depth:l,extrudeBevelSize:c,extrudeBevelSegments:f}});return Object.assign(W,{userData:fe(U({},i),{type:"RectangleGeometry"})})}};import{SphereBufferGeometry as P2}from"three";var Y0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,widthSegments:64,heightSegments:64,phiStart:0,phiLength:2*Math.PI,thetaStart:0,thetaLength:Math.PI},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width)})}}static build(i){let{width:e=100,height:t=e,depth:r=e,widthSegments:n=64,heightSegments:s=64,phiStart:l,phiLength:c,thetaStart:f,thetaLength:h}=i.parameters,d=new P2(.5*e,n,s,l,c,f,h);return d.scale(1,t/e,r/e),Object.assign(d,{userData:fe(U({},i),{type:"SphereGeometry"})})}};import{PlaneBufferGeometry as D2}from"three";var Q0=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,depth:0,widthSegments:8,heightSegments:8},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:0})}}static build(i){let{width:e=100,height:t=e,widthSegments:r=8,heightSegments:n=8}=i.parameters,s=new D2(e,t,r,n);return s.scale(1,1,1),Object.assign(s,{userData:fe(U({},i),{type:"PlaneGeometry"})})}};var ev=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var n,s,l,c;let t=Object.assign({},(n=e==null?void 0:e.parameters)!=null?n:{width:100,depth:0,innerRadiusPercent:38.19,spikes:5,cornerRadius:0,angle:360,extrudeDepth:0,extrudeBevelSize:0,extrudeBevelSegments:1},i.parameters);return{shape:i.shape&&i.shape instanceof st?i.shape:new st,parameters:Object.assign(t,{surfaceMaxCount:((s=t.surfaceMaxCount)!=null?s:t.cornerRadius>0)?1e3:100,width:Math.abs(t.width),height:Math.abs((l=t.height)!=null?l:t.width),depth:Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(c=t.depth)!=null?c:0)})}}static build(i){let{width:e,height:t,innerRadiusPercent:r,spikes:n,cornerRadius:s,angle:l,depth:c,extrudeBevelSize:f,extrudeBevelSegments:h,surfaceMaxCount:d}=i.parameters,x=i.shape,g=e*.5,w=t*.5,S=0,D=0,C=l*Math.PI/360/n,G=Math.PI/2*3*-1,B=g*r/100,P=w*r/100;if(n==3&&r==50){C=2*Math.PI/n;for(let M=0;M<n;M++){let q=C*M,E=S+Math.sin(q)*g,b=D+Math.cos(q)*w;x.addPoint(x.createPoint(E,b))}}else for(let M=0;M<n;M++){let q=S+Math.cos(G)*g,E=D+Math.sin(G)*w;x.addPoint(x.createPoint(q,E)),G+=C,q=S+Math.cos(G)*B,E=D+Math.sin(G)*P,M<=n,x.addPoint(x.createPoint(q,E)),G+=C}x.isClosed=!0;for(let M=0,q=x.points.length;M<q;M++)x.points[M].roundness=s;x.roundness=s,x.update();let W=ur.create({shape:x,parameters:{surfaceMaxCount:d,roundness:s,depth:c,extrudeBevelSize:f,extrudeBevelSegments:h}});return Object.assign(W,{userData:fe(U({},i),{type:"StarGeometry"})})}};import{PlaneBufferGeometry as B2}from"three";var su=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,depth:0},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:0)})}}static build(i){let{width:e,height:t}=i.parameters,r=new B2(e,t);return Object.assign(r,{userData:fe(U({},i),{type:"TextFrameGeometry"})})}};var tv=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var l,c,f;let t=Object.assign({},(l=e==null?void 0:e.parameters)!=null?l:{width:100,radialSegments:32,tubularSegments:64,arc:Math.PI*2,cornerRadius:30,cornerSegments:8},i.parameters),r=Math.abs(t.width),n=Math.abs((c=t.height)!=null?c:t.width),s=Math.abs((f=t.depth)!=null?f:t.width*.25);return{parameters:Object.assign(t,{width:r,height:n,depth:s})}}static build(i){let{width:e,height:t,depth:r,radialSegments:n,tubularSegments:s,arc:l,cornerRadius:c,cornerSegments:f}=i.parameters,h=G2(e,t,r,e*.5,l,s,0,0,n,c,f);return h.scale(1,t/e,1),Object.assign(h,{userData:fe(U({},i),{type:"TorusGeometry"})})}};function G2(i,e,t,r,n,s,l,c,f,h,d){return[e,t]=[t,e],l=e/2,n/=2*Math.PI,n==1&&(h=0),new tu(!0,i,e,t,r,n,s,l,c,f,h,d)}import{TorusKnotBufferGeometry as j2}from"three";var rv=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var r,n,s,l;let t=Object.assign({},(r=e==null?void 0:e.parameters)!=null?r:{width:100,tubularSegments:64,radialSegments:32,p:2,q:3},i.parameters);return{parameters:Object.assign(t,{width:Math.abs(t.width),height:Math.abs((n=t.height)!=null?n:t.width),depth:Math.abs((s=t.depth)!=null?s:t.width),tube:(l=t.tube)!=null?l:t.width*.125})}}static build(i){let{width:e,tube:t,tubularSegments:r,radialSegments:n,p:s,q:l}=i.parameters,c=e*.5;c!==t&&(c-=t);let f=new j2(c,t,r,n,s,l);return Object.assign(f,{userData:fe(U({},i),{type:"TorusKnotGeometry"})})}};var nv=class{static create(i){return this.build(this.normalizeInputs(i))}static normalizeInputs(i,e){var n,s,l,c;let t=Object.assign({},(n=e==null?void 0:e.parameters)!=null?n:{width:100,depth:0,spikes:5,cornerRadius:0,extrudeDepth:0,extrudeBevelSize:0,extrudeBevelSegments:1,isRect:!1},i.parameters);return{shape:i.shape&&i.shape instanceof st?i.shape:new st,parameters:Object.assign(t,{surfaceMaxCount:((s=t.surfaceMaxCount)!=null?s:t.cornerRadius>0)?1e3:100,width:Math.abs(t.width),height:Math.abs((l=t.height)!=null?l:t.width*(t.isRect?1:Math.sqrt(3)/2)),depth:Math.abs(t.depth!==void 0&&t.depth===0&&t.extrudeDepth>0?t.extrudeDepth:(c=t.depth)!=null?c:0)})}}static build(i){let{width:e=100,height:t,cornerRadius:r,depth:n,extrudeBevelSize:s,extrudeBevelSegments:l,isRect:c,surfaceMaxCount:f}=i.parameters,h=i.shape,d=e*.5,x=t*.5;c?(h.addPoint(h.createPoint(-d,x)),h.addPoint(h.createPoint(d,-x)),h.addPoint(h.createPoint(-d,-x))):(h.addPoint(h.createPoint(0,x)),h.addPoint(h.createPoint(d,-x)),h.addPoint(h.createPoint(-d,-x))),h.isClosed=!0;for(let w=0,S=h.points.length;w<S;w++)h.points[w].roundness=r;h.roundness=r,h.update();let g=ur.create({shape:h,parameters:{surfaceMaxCount:f,roundness:r,depth:n,extrudeBevelSize:s,extrudeBevelSegments:l}});return Object.assign(g,{userData:fe(U({},i),{type:"TriangleGeometry"})})}};var Ca={};V_(Ca,{addBarycentricAttribute:()=>V2,fixUvs:()=>k2,loadFromUrl:()=>U2,resizeGeometry:()=>F2,roundShapePolygon:()=>z2});import{BufferGeometryLoader as E2,Float32BufferAttribute as R2,Vector3 as Jh}from"three";var iv=function(i,e){let t=e.x-i.x,r=e.y-i.y,n=Math.sqrt(t*t+r*r),s=t/n,l=r/n,c=Math.atan2(l,s);return{x:t,y:r,len:n,nx:s,ny:l,ang:c}},z2=(i,e,t)=>{let r,n,s,l,c,f,h,d,x,g,w,S,D,C,G=e.length;for(l=e[G-2],i.curves=[],r=1;r<G-1;r++){c=e[r%G],f=e[(r+1)%G];let B=iv(c,l),P=iv(c,f);h=B.nx*P.ny-B.ny*P.nx,d=B.nx*P.nx-B.ny*-P.ny,w=Math.asin(h),x=1,g=!1,d<0?w<0?w=Math.PI+w:(w=Math.PI-w,x=-1,g=!0):w>0&&(x=-1,g=!0),S=w/2,C=Math.abs(Math.cos(S)*t/Math.sin(S)),C>Math.min(B.len/2,P.len/2)?(C=Math.min(B.len/2,P.len/2),D=Math.abs(C*Math.sin(S)/Math.cos(S))):D=t,n=c.x+P.nx*C,s=c.y+P.ny*C,n+=-P.ny*D*x,s+=P.nx*D*x,i.absarc(n,s,D,B.ang+Math.PI/2*x,P.ang-Math.PI/2*x,g),l=c,c=f}i.closePath()},F2=(i,{width:e,height:t,depth:r})=>{e=Math.abs(e),t=Math.abs(t),r=Math.abs(r);let n=i.userData.parameters,s,l,c;e===0?(e=n.width,s=1):s=e/n.width,t===0?(t=n.height,l=1):l=t/n.height,r===0?(r=n.depth,c=1):c=r/n.depth,i.scale(s,l,c),n.width=e,n.height=t,n.depth=r},V2=(i,e)=>{let t=[new Jh(1,0,0),new Jh(0,1,0),new Jh(0,0,1)],r=i.attributes.position,n=new Float32Array(r.count*3);for(let s=0,l=r.count;s<l;s++)t[s%3].toArray(n,s*3);i.setAttribute(e,new R2(n,3))},U2=i=>new Promise(e=>{new E2().load(i,r=>e(r))}),k2=(i,e,t)=>{let r=i.getAttribute("uv");if(r)for(let n=0;n<r.count;n++){let s=r.getX(n),l=r.getY(n);r.setXY(n,(s+e/2)/e,1-(l-t/2)/t*-1)}};import{BufferGeometry as ov,BufferAttribute as sv,Uint32BufferAttribute as Kh,Float32BufferAttribute as Xh,Matrix4 as W2}from"three";import{mergeVertices as q2}from"three/examples/jsm/utils/BufferGeometryUtils.js";var H2,au=new Promise(i=>{H2=i});var Oe;au.then(i=>{Oe=i});var av=new Float32Array([10,10,0,-10,10,0,-10,-10,0,10,-10,0]),lv=new Uint32Array([0,1,2,3]),cv=new Uint8Array([4]),en=class{static build(i,e,t,r,n){let s,l,c;if(i===void 0)s=en.allocate(n,t),Oe.set_destination_refinement_level(s,0),l=en.buildLevel(s,!0,r);else if(i.positionWASM!==void 0){e&&e!==0&&(Oe.free_bvh(e),Oe.free_subdivision_surface(e));try{s=en.allocate(n,void 0,i)}catch(f){console.error(f,i),s=en.allocate(n,void 0,{positionWASM:av,indexWASM:lv,verticesPerFaceWASM:cv})}Oe.set_destination_refinement_level(s,0),l=en.buildLevel(s,!0,r)}else s=e;if(i!==void 0&&i.subdivisions!==void 0){let f=$2(i.subdivisions,i.positionWASM.length);Oe.set_destination_refinement_level(s,f),f>0?c=en.buildLevel(s,!1,r):c=null}return{subdivPointer:s,originalGeometry:l,subdividedGeometry:c}}static allocate(i,e,t){var M;let r,n,s,l=[],c=[];if(t)t.positionWASM&&t.positionWASM.length>0?(r=t.positionWASM,n=t.indexWASM,s=t.verticesPerFaceWASM):(r=av,n=lv,s=cv);else{e.deleteAttribute("normal"),e.deleteAttribute("uv");let q=q2(e);r=q.attributes.position.array;let E=q.getIndex().array,b=E.length;switch(e.userData.type==="TorusGeometry"&&(e==null?void 0:e.userData.parameters.arc)===Math.PI*2&&(e.userData.type="ClosedTorusGeometry"),e.userData.type){case"ClosedTorusGeometry":case"PlaneGeometry":case"TorusKnotGeometry":case"CubeGeometry":n=new Uint32Array(b/3*2),s=new Uint8Array(b/6).fill(4);for(let re=0,Ne=0;re<b;re+=6)n[Ne++]=E[re],n[Ne++]=E[re+1],n[Ne++]=E[re+4],n[Ne++]=E[re+5];break;case"TorusGeometry":case"SphereGeometry":case"HelixGeometry":case"CylinderGeometry":case"ConeGeometry":let R,T,z;if(e.userData.type==="SphereGeometry")T=e.parameters.heightSegments,R=e.parameters.widthSegments,e.parameters.thetaLength!==Math.PI&&(z=!0);else if(e.userData.type==="CylinderGeometry")T=e.parameters.heightSegments+2,R=e.parameters.radialSegments;else if(e.userData.type==="ConeGeometry")T=e.parameters.heightSegments+1,R=e.parameters.radialSegments;else if(e.userData.type==="TorusGeometry"){let re=e.userData.parameters;T=Math.ceil(re.tubularSegments*re.arc/(2*Math.PI))+2,R=re.radialSegments}else{let{pathSegments:re,segments:Ne,revolutions:ye}=e.userData.parameters;T=Math.ceil(Ne*ye)+2,R=re}z?(n=new Uint32Array(1*R*3+(T-1)*R*4),s=new Uint8Array(1*R+(T-1)*R)):(n=new Uint32Array(2*R*3+(T-2)*R*4),s=new Uint8Array(2*R+(T-2)*R));let A=0,$=0,he=0;if(e.userData.type==="SphereGeometry"||e.userData.type==="HelixGeometry"||e.userData.type==="TorusGeometry"){for(;$<3*R;)n[$++]=E[A++],n[$++]=E[A++],n[$++]=E[A++],s[he++]=3;let re=z?n.length:3*R+4*(T-2)*R;for(;$<re;A+=6)n[$++]=E[A],n[$++]=E[A+1],n[$++]=E[A+4],n[$++]=E[A+5],s[he++]=4}else for(;$<4*(T-2)*R;A+=6)n[$++]=E[A],n[$++]=E[A+1],n[$++]=E[A+4],n[$++]=E[A+5],s[he++]=4;for(;$<n.length;)n[$++]=E[A++],n[$++]=E[A++],n[$++]=E[A++],s[he++]=3;break;default:n=E,s=new Uint8Array(b/3).fill(3);break}}let f=r.length,h=n.length,d=s.length,x=r.length+l.length+c.length,g=n.length+s.length,w=x*Float32Array.BYTES_PER_ELEMENT+g*Uint32Array.BYTES_PER_ELEMENT,S=x*Float32Array.BYTES_PER_ELEMENT,D=g*Uint32Array.BYTES_PER_ELEMENT,C=Oe._malloc(w),G=new Float32Array(Oe.HEAPF32.buffer,C,x),B=new Uint32Array(Oe.HEAPU32.buffer,C+S,g);G.set(r,0),G.set(l,r.length),G.set(c,r.length+l.length),B.set(n,0),B.set(s,n.length);let P;((M=t==null?void 0:t.scaleBaked)==null?void 0:M.some(q=>q!==1))&&(P=new W2().makeScale(...t.scaleBaked)),i&&(P?P.premultiply(i):P=i);let W=P?Oe.alloc_subdivision_surface2(C,f,C+S,h,C+S+n.length*Uint32Array.BYTES_PER_ELEMENT,d,P.elements):Oe.alloc_subdivision_surface(C,f,C+S,h,C+S+n.length*Uint32Array.BYTES_PER_ELEMENT,d);return Oe._free(C),W}static buildLevel(i,e,t,r,n){let s=n?Oe.get_mesh_data2(i,e?Oe.Level.CONTROL:Oe.Level.REFINED,t!=null?t:!e,n.elements):Oe.get_mesh_data(i,e?Oe.Level.CONTROL:Oe.Level.REFINED,t!=null?t:!e),l=8,c=Oe.HEAPU32.subarray(s>>2,(s>>2)+l),f=c.subarray(4,4+4),h=0,d=Oe.HEAPU32[c[h]>>2],x=Oe.HEAPF32.subarray(d>>2,(d>>2)+f[h]);h++;let g=Oe.HEAPU32[c[h]>>2],w=Oe.HEAPF32.subarray(g>>2,(g>>2)+f[h]);h++;let S=Oe.HEAPU32[c[h]>>2],D=Oe.HEAPU32.subarray(S>>2,(S>>2)+f[h]);h++;let C=Oe.HEAPU32[c[h]>>2],G=Oe.HEAPU32.subarray(C>>2,(C>>2)+f[h]);if(h++,r===void 0){let B=new ov;if(B.setIndex(new Kh(G,1)),B.setAttribute("position",new Xh(x,3)),B.setAttribute("normal",new Xh(w,3)),e){B.setAttribute("faceMap",new Kh(D,1));let P=new Float32Array(w.length/3*4).fill(0);B.setAttribute("color",new sv(P,4))}return Oe.free_mesh_data(s),B.userData.type="SubdivGeometry",B}r.getAttribute("position").copyArray(x),r.getAttribute("normal").copyArray(w),r.attributes.position.needsUpdate=!0,r.attributes.normal.needsUpdate=!0,Oe.free_mesh_data(s)}static buildControlCageWireframe(i,e,t){let r=Oe.get_wireframe_data_for_base_level(i),n=4,s=Oe.HEAPU32.subarray(r>>2,(r>>2)+n),l=s.subarray(2,2+2),c=0,f=Oe.HEAPU32[s[c]>>2],h=Oe.HEAPF32.subarray(f>>2,(f>>2)+l[c]);c++;let d=Oe.HEAPU32[s[c]>>2],x=Oe.HEAPU32.subarray(d>>2,(d>>2)+l[c]);if(e===void 0){let g=new ov;g.setAttribute("position",new Xh(h,3));let w=new Float32Array(h.length);for(let S=0,D=h.length;S<D;)w[S++]=t.r,w[S++]=t.g,w[S++]=t.b;return g.setAttribute("color",new sv(w,3)),g.setIndex(new Kh(x,1)),Oe.free_wireframe_data_for_base_level(r),g}e.getAttribute("position").copyArray(h),e.attributes.position.needsUpdate=!0,Oe.free_wireframe_data_for_base_level(r)}static updateCollabMesh(i,e,t){e||Oe.set_destination_refinement_level(i,1);let r=t?Oe.get_topological_data2(i,e?Oe.Level.CONTROL:Oe.Level.REFINED,t.elements):Oe.get_topological_data(i,e?Oe.Level.CONTROL:Oe.Level.REFINED),n=6,s=Oe.HEAPU32.subarray(r>>2,(r>>2)+n),l=s.subarray(3,3+3),c=0,f=Oe.HEAPU32[s[c]>>2],h=new Float32Array(Oe.HEAPF32.subarray(f>>2,(f>>2)+l[c]));c++;let d=Oe.HEAPU32[s[c]>>2],x=new Uint32Array(Oe.HEAPU32.subarray(d>>2,(d>>2)+l[c]));c++;let g=Oe.HEAPU32[s[c]>>2],w=new Uint8Array(Oe.HEAPU32.subarray(g>>2,(g>>2)+l[c]));return Oe.free_topological_data(r),{positions:h,indices:x,verticesPerFace:w}}};function $2(i,e){let t=i;return t=Math.min(t,3-Math.ceil(Math.log(e/172e3)/Math.log(4))),Math.max(t,0)}var Zh={ConeGeometry:u0,CubeGeometry:f0,CylinderGeometry:l0,DodecahedronGeometry:p0,EllipseGeometry:j0,HelixGeometry:U0,IcosahedronGeometry:k0,LatheGeometry:H0,NonParametricGeometry:J0,PolygonGeometry:K0,PyramidGeometry:X0,RectangleGeometry:ou,SphereGeometry:Y0,PlaneGeometry:Q0,StarGeometry:ev,TextFrameGeometry:su,TorusGeometry:tv,TorusKnotGeometry:rv,TriangleGeometry:nv,VectorGeometry:ur},La=i=>Zh[i.type].create(i);import{Matrix4 as Qh}from"three";import{Box3 as pv,Line3 as gn,Matrix4 as Yh,Vector3 as Ct}from"three";import{HemisphereLight as uv}from"three";import{Color as J2}from"three";var tn=class extends J2{constructor(e,t,r,n){super(e,t,r);this.isColorA=!0;this.a=n}setRGBA(e,t,r,n){super.setRGB(e,t,r),this.a=n}copy(e){return super.copy(e),this.a="a"in e?e.a:1,this}clone(){return new this.constructor(this.r,this.g,this.b,this.a)}get x(){return this.r}get y(){return this.g}get z(){return this.b}get w(){return this.a}set x(e){this.r=e}set y(e){this.g=e}set z(e){this.b=e}set w(e){this.a=e}};function kt(i,e){let t;if(typeof i=="string"){let r=e==null?void 0:e.getColor(i);r?t=r:(console.warn("Tried to create color layer params with a color key that does not exist in the assets manager"),t=new tn(0,0,0,0))}else return"a"in i?new tn(i.r,i.g,i.b,i.a):new tn(i.r,i.g,i.b,1);return t}var lu=i=>"isEntity"in i,_s=i=>"isAbstractMesh"in i;var vi=i=>"objectHelper"in i;function K2(i,e){var r;let t=!1;e.position&&(i.position.fromArray(e.position),t=!0),e.rotation&&(i.rotation.fromArray(e.rotation),t=!0),e.scale&&(t=!0,i.scale.fromArray(e.scale)),e.hiddenMatrix!==void 0&&"hiddenMatrix"in i&&(t=!0,i.hiddenMatrix.fromArray((r=e.hiddenMatrix)!=null?r:Fi.identity)),t&&i.updateMatrix(),e.position&&e.rotation&&e.scale&&e.hiddenMatrix!==void 0&&i.updateWorldMatrix(!1,!0),i.objectType==="CombinedCamera"&&(e.isUpVectorFlipped!==void 0&&(i.isUpVectorFlipped=e.isUpVectorFlipped),i.updateUp())}function X2(i,e){K2(i,e),e.name!==void 0&&(i.name=e.name),e.visible!==void 0&&(i.isEntity?i.visibility=e.visible:i.visible=e.visible)}function fv(i,e,t){X2(i,e),e.color!==void 0&&(i.color=kt(e.color,t)),e.intensity!==void 0&&(i.intensity=e.intensity),e.shadows!==void 0&&!(i instanceof uv)&&(i.castShadow=e.shadows),i.shadow&&!(i instanceof uv)&&e.depth!==void 0&&(i.shadow.camera.far=e.depth,i.shadow.needsUpdate=!0),e.helper!==void 0&&vi(i)&&(i.enableHelper=e.helper,i.gizmos.shadowmap.visible=e.helper)}function hv(i,e){i.shadow.camera.right=e/2,i.shadow.camera.left=-e/2,i.shadow.camera.top=e/2,i.shadow.camera.bottom=-e/2,i.shadow.needsUpdate=!0}var Ts=new pv,fr=new Ct,Ie=new Ct,$t=new Yh;function Z2(i,e,t=0,r=e.count){let n=1/0,s=1/0,l=1/0,c=-1/0,f=-1/0,h=-1/0;for(let d=t;d<r;d++){let x=e.getX(d),g=e.getY(d),w=e.getZ(d);x<n&&(n=x),g<s&&(s=g),w<l&&(l=w),x>c&&(c=x),g>f&&(f=g),w>h&&(h=w)}return i.min.set(n,s,l),i.max.set(c,f,h),i}var dv=(i,e,t,r)=>{var n;if(_s(i)){let s=i.geometry.userData.parameters,l=i.geometry.getAttribute("position");i.geometry.userData.type==="SubdivGeometry"?fr.copy(i.originalGeometry.boundingSphere.center):(Z2(Ts,l,i.geometry.drawRange.start,i.geometry.drawRange.count<1/0?i.geometry.drawRange.count:l.count),Ts.getCenter(fr)),i.forceComputeSize?Ts.getSize(Ie).multiplyScalar(.5):Ie.set(s.width,s.height,(n=s.depth)!=null?n:0).multiplyScalar(.5)}else if(vi(i)&&r===!0){let s=i.geometryHelper.getAttribute("position");Ts.setFromArray(s.array),Ts.getCenter(fr),Ts.getSize(Ie).multiplyScalar(.5)}else fr.setScalar(0),Ie.setScalar(0);$t.copy(e).multiply(i.matrixWorld),Ie.x===0&&Ie.y===0&&Ie.z===0?t.push(new Ct(fr.x,fr.y,fr.z).applyMatrix4($t)):t.push(new Ct(-Ie.x,Ie.y,Ie.z).add(fr).applyMatrix4($t),new Ct(-Ie.x,-Ie.y,Ie.z).add(fr).applyMatrix4($t),new Ct(Ie.x,-Ie.y,Ie.z).add(fr).applyMatrix4($t),new Ct(Ie.x,Ie.y,Ie.z).add(fr).applyMatrix4($t),new Ct(-Ie.x,Ie.y,-Ie.z).add(fr).applyMatrix4($t),new Ct(-Ie.x,-Ie.y,-Ie.z).add(fr).applyMatrix4($t),new Ct(Ie.x,-Ie.y,-Ie.z).add(fr).applyMatrix4($t),new Ct(Ie.x,Ie.y,-Ie.z).add(fr).applyMatrix4($t))},cu=class extends pv{constructor(){super(...arguments);this.matrix=new Yh;this.vertices=[];this.faces=[];this.edges=[];this.centerEdges=[]}copy(e){return super.copy(e),this.matrix.copy(e.matrix),this.vertices=e.vertices.map(t=>t.clone()),this.faces=e.faces.map(t=>t.clone()),this.edges=e.edges.map(t=>t.clone()),this.centerEdges=e.centerEdges.map(t=>t.clone()),this}setFromObjectSize(e,t=!1){e.updateWorldMatrix(!1,t),this.makeEmpty(),this.matrix.copy(e.matrixWorld);let r=new Yh().copy(e.matrixWorld).invert();return this.expandByObjectSize(e,r,t)}expandByObjectSize(e,t,r=!1){let n=[];return r===!0?e.traverseEntity(s=>dv(s,t,n,e.enableHelper===!0)):dv(e,t,n,e.enableHelper===!0),this.setFromPoints(n)}getCenter(e){return e=super.getCenter(e),e.applyMatrix4(this.matrix),e}getPositionToCenter(e){return e=super.getCenter(e),e.applyMatrix4($t.copy(this.matrix).setPosition(0,0,0)),e}computeVertices(){this.getSize(Ie).multiplyScalar(.5),this.getCenter(fr),$t.copy(this.matrix).setPosition(fr),this.vertices=[new Ct(-Ie.x,Ie.y,Ie.z).applyMatrix4($t),new Ct(-Ie.x,-Ie.y,Ie.z).applyMatrix4($t),new Ct(Ie.x,-Ie.y,Ie.z).applyMatrix4($t),new Ct(Ie.x,Ie.y,Ie.z).applyMatrix4($t),new Ct(-Ie.x,Ie.y,-Ie.z).applyMatrix4($t),new Ct(-Ie.x,-Ie.y,-Ie.z).applyMatrix4($t),new Ct(Ie.x,-Ie.y,-Ie.z).applyMatrix4($t),new Ct(Ie.x,Ie.y,-Ie.z).applyMatrix4($t)]}computeEdges(){this.vertices.length>0&&this.computeVertices(),this.edges=[new gn(this.vertices[0],this.vertices[3]),new gn(this.vertices[1],this.vertices[2]),new gn(this.vertices[5],this.vertices[6]),new gn(this.vertices[4],this.vertices[7]),new gn(this.vertices[0],this.vertices[1]),new gn(this.vertices[3],this.vertices[2]),new gn(this.vertices[7],this.vertices[6]),new gn(this.vertices[4],this.vertices[5]),new gn(this.vertices[0],this.vertices[4]),new gn(this.vertices[1],this.vertices[5]),new gn(this.vertices[2],this.vertices[6]),new gn(this.vertices[3],this.vertices[7])],this.centerEdges=this.edges.map(e=>e.getCenter(new Ct))}computeFaces(){this.vertices.length>0&&this.computeVertices(),this.faces=[new Ct().copy(this.vertices[0]).sub(this.vertices[2]).multiplyScalar(.5).add(this.vertices[2]),new Ct().copy(this.vertices[7]).sub(this.vertices[5]).multiplyScalar(.5).add(this.vertices[5]),new Ct().copy(this.vertices[4]).sub(this.vertices[1]).multiplyScalar(.5).add(this.vertices[1]),new Ct().copy(this.vertices[3]).sub(this.vertices[6]).multiplyScalar(.5).add(this.vertices[6]),new Ct().copy(this.vertices[4]).sub(this.vertices[3]).multiplyScalar(.5).add(this.vertices[3]),new Ct().copy(this.vertices[1]).sub(this.vertices[6]).multiplyScalar(.5).add(this.vertices[6])]}};import{Object3D as Y2,Matrix4 as Q2,Light as eD}from"three";function _a(i){let e=[];for(let t in i){let r=i[t];delete r.metadata,e.push(r)}return e}function tD(i){let e=[];for(let t in i)e.push(i[t]);return e}var uu=i=>class extends i{hasEntityChild(){return this.children.some(t=>lu(t))}isDescendantOf(t){t instanceof Y2&&(t=t.uuid);let r=this;for(;r.parent;){if(r.parent.uuid===t)return!0;r=r.parent}return!1}attach(t,r){this.updateWorldMatrix(!0,!1);let n=new Q2().copy(this.matrixWorld).invert();return t.parent!==null&&(t.parent.updateWorldMatrix(!0,!1),n.multiply(t.parent.matrixWorld)),lu(t)?t.hiddenMatrix.premultiply(n):t.applyMatrix4(n),t.updateWorldMatrix(!1,!1),this.add(t),r!==void 0&&(this.children.pop(),this.children.splice(r,0,t)),this}copy(t,r=!0){if(this.name=t.name,this.up.copy(t.up),this.position.copy(t.position),this.rotation.order=t.rotation.order,this.quaternion.copy(t.quaternion),this.scale.copy(t.scale),this.matrix.copy(t.matrix),this.matrixWorld.copy(t.matrixWorld),this.matrixAutoUpdate=t.matrixAutoUpdate,this.matrixWorldNeedsUpdate=t.matrixWorldNeedsUpdate,this.layers.mask=t.layers.mask,this.visible=t.visible,this.castShadow=t.castShadow,this.receiveShadow=t.receiveShadow,this.frustumCulled=t.frustumCulled,this.renderOrder=t.renderOrder,this.userData=JSON.parse(JSON.stringify(t.userData)),r===!0)for(let n=0;n<t.children.length;n++){let s=t.children[n];this.add(s.clone())}return this}toJSON(t){let r=t===void 0,n={object:{uuid:"",objectType:""}};t===void 0&&(t={geometries:{},materials:{},textures:{},images:{},interactionStates:{},nodes:{}},n.metadata={version:1.5,type:"Object",generator:"Object3D.toJSON"});let s={uuid:this.uuid,objectType:this.type};if(this.name!==""&&(s.name=this.name),s.matrix=this.matrix.toArray(),this.castShadow===!0&&(s.castShadow=!0),this.receiveShadow===!0&&(s.receiveShadow=!0),this.visible===!1&&(s.visible=!1),this.frustumCulled===!1&&(s.frustumCulled=!1),this.renderOrder!==0&&(s.renderOrder=this.renderOrder),s.layers=this.layers.mask,JSON.stringify(this.userData)!=="{}"&&(s.userData=this.userData),this.children.length>0){s.children=[];for(let l of this.children)(lu(l)||l instanceof eD)&&s.children.push(l.toJSON(t).object)}if(r){let l=_a(t.geometries),c=_a(t.materials),f=_a(t.textures),h=_a(t.images),d=_a(t.interactionStates),x=tD(t.nodes);l.length>0&&(n.geometries=l),c.length>0&&(n.materials=c),f.length>0&&(n.textures=f),h.length>0&&(n.images=h),d.length>0&&(n.interactionStates=d),x.length>0&&(n.nodes=x)}return n.object=s,n}fromJSON(t){return this.uuid=t.uuid,t.name!==void 0&&(this.name=t.name),t.matrix!==void 0?(this.matrix.fromArray(t.matrix),t.matrixAutoUpdate!==void 0&&(this.matrixAutoUpdate=t.matrixAutoUpdate),this.matrixAutoUpdate&&this.matrix.decompose(this.position,this.quaternion,this.scale)):(t.position!==void 0&&this.position.fromArray(t.position),t.rotation!==void 0&&this.rotation.fromArray(t.rotation),t.quaternion!==void 0&&this.quaternion.fromArray(t.quaternion),t.scale!==void 0&&this.scale.fromArray(t.scale)),this.castShadow=t.castShadow!==void 0,this.receiveShadow=t.receiveShadow!==void 0,t.visible!==void 0&&(this.visible=t.visible),t.frustumCulled!==void 0&&(this.frustumCulled=t.frustumCulled),t.renderOrder!==void 0&&(this.renderOrder=t.renderOrder),t.layers!==void 0&&(this.layers.mask=t.layers),t.userData!==void 0&&(this.userData=t.userData),this}};var yn=i=>"isEntity"in i;var xn=i=>class extends uu(i){constructor(){super(...arguments);this.objectType="";this.isEntity=!0;this.raycastLock=!1;this.scaleLock=!1;this.hiddenMatrix=new Qh;this._singleBBox=new cu;this._recursiveBBox=new cu;this.singleBBoxNeedsUpdate=!0;this.recursiveBBoxNeedsUpdate=!0;this.forceComputeSize=!1}set visibility(t){this.visible=t;for(let r of this.children)yn(r)&&r.traverseEntity(n=>{vi(n)&&n.visible&&(n.objectHelper.visible=t)})}get visibility(){return this.visible}get singleBBox(){return this.singleBBoxNeedsUpdate&&(this.singleBBoxNeedsUpdate=!1,this._singleBBox.setFromObjectSize(this,!1),this._singleBBox.computeVertices(),this._singleBBox.computeEdges(),this._singleBBox.computeFaces()),this._singleBBox}get recursiveBBox(){return this.recursiveBBoxNeedsUpdate&&(this.recursiveBBoxNeedsUpdate=!1,this._recursiveBBox.setFromObjectSize(this,!0),this._recursiveBBox.computeVertices(),this._recursiveBBox.computeEdges(),this._recursiveBBox.computeFaces()),this._recursiveBBox}resetBBoxNeedsUpdate(){this.singleBBoxNeedsUpdate=!0,this.recursiveBBoxNeedsUpdate=!0,this.traverseAncestors(t=>{yn(t)&&(t.singleBBoxNeedsUpdate=!0,t.recursiveBBoxNeedsUpdate=!0)}),this.traverseEntity(t=>{t.singleBBoxNeedsUpdate=!0,t.recursiveBBoxNeedsUpdate=!0})}traverseEntity(t){t(this);for(let r of this.children)yn(r)&&r.traverseEntity(t)}updateMatrixWorld(t){this.matrixAutoUpdate&&this.updateMatrix(),(this.matrixWorldNeedsUpdate||t)&&(this.parent===null?this.matrixWorld.multiplyMatrices(this.hiddenMatrix,this.matrix):(this.matrixWorld.multiplyMatrices(this.parent.matrixWorld,this.hiddenMatrix),this.matrixWorld.multiplyMatrices(this.matrixWorld,this.matrix)),this.matrixWorldNeedsUpdate=!1,t=!0);for(let r of this.children)r.updateMatrixWorld(t)}updateWorldMatrix(t,r){let n=this.parent;if(t&&n!==null&&n.updateWorldMatrix(!0,!1),this.matrixAutoUpdate&&this.updateMatrix(),this.parent===null?this.matrixWorld.multiplyMatrices(this.hiddenMatrix,this.matrix):(this.matrixWorld.multiplyMatrices(this.parent.matrixWorld,this.hiddenMatrix),this.matrixWorld.multiplyMatrices(this.matrixWorld,this.matrix)),r)for(let s of this.children)s.updateWorldMatrix(!1,!0)}shallowClone(t){return new this.constructor().shallowCopy(this,t)}shallowCopy(t,r=!0){if(super.copy(t,!1),this.raycastLock=t.raycastLock,this.scaleLock=t.scaleLock,this.hiddenMatrix.copy(t.hiddenMatrix),r===!0)for(let n of t.children)yn(n)&&this.add(n.shallowClone());return this}clone(t){return new this.constructor().copy(this,t)}copy(t,r=!0){if(super.copy(t,!1),this.raycastLock=t.raycastLock,this.scaleLock=t.scaleLock,this.hiddenMatrix.copy(t.hiddenMatrix),r===!0)for(let n of t.children)yn(n)&&this.add(n.clone());return this}keepChildrenMatrixWorld(){let t=new Qh,r=this.matrixWorld.clone();this.updateWorldMatrix(!1,!1),t.copy(this.matrixWorld).invert(),t.multiply(r);for(let n of this.children)yn(n)&&n.hiddenMatrix.premultiply(t)}toJSON(t){let r=super.toJSON(t),n=r.object;return this.raycastLock===!0&&(n.raycastLock=!0),this.scaleLock===!0&&(n.scaleLock=!0),n.hiddenMatrix=this.hiddenMatrix.toArray(),r}fromJSON(t){return super.fromJSON(t),t.raycastLock!==void 0&&(this.raycastLock=t.raycastLock),t.scaleLock!==void 0&&(this.scaleLock=t.scaleLock),this.hiddenMatrix.fromArray(t.hiddenMatrix),this}fromObject3D(t){let r=t.children;return t.children=[],Object.assign(t,{raycastLock:!1,scaleLock:!1,hiddenMatrix:new Qh}),this.copy(t),t.children=r,this}toObjectTransformState(t=[]){this.updateWorldMatrix(!0,!1);let r={position:this.position.toArray(),rotation:[this.rotation.x,this.rotation.y,this.rotation.z],scale:this.scale.toArray(),hiddenMatrix:this.hiddenMatrix.toArray()};return hs(r,t)}fromObjectTransformState(t){return t.position&&this.position.fromArray(t.position),t.rotation&&this.rotation.fromArray(t.rotation),t.scale&&this.scale.fromArray(t.scale),t.hiddenMatrix&&this.hiddenMatrix.fromArray(t.hiddenMatrix),this.updateMatrix(),this}toState(t=[]){let r=U({name:this.name,visible:this.visible,raycastLock:this.raycastLock},this.toObjectTransformState(t));return hs(r,t)}fromState(t,r){return t.name&&(this.name=t.name),t.raycastLock!==void 0&&(this.raycastLock=t.raycastLock),t.type!=="OrthographicCamera"&&t.type!=="PerspectiveCamera"&&(this.matrixAutoUpdate=!1),t.visible!==void 0&&(this.visibility=t.visible),this.fromObjectTransformState(t),this}};import{Object3D as rD,Vector3 as Ta,Euler as mv,MathUtils as $i}from"three";var fu=class extends rD{constructor(e,t={}){super();this.object=e;let r=e.recursiveBBox.getSize(new Ta),n=.1;this.parameters=gc.defaultData(r.toArray(),n),yo(this.parameters,t),this.update(),this.setHideBase(this.parameters.hideBase)}refreshMaterial(){if("material"in this.object)for(let e of this.children)e.material=this.object.material}setHideBase(e){if("material"in this.object){if(Array.isArray(this.object.material)){if(this.children.length>0){for(let t of this.object.material)t.visible=!0;if(e){let t=this.object.material.map(r=>r.clone());for(let r of this.children)r.material=t}else for(let t of this.children)t.material=this.object.material}for(let t of this.object.material)t.visible=!e}else{if(this.children.length>0)if(this.object.material.visible=!0,e){let t=this.object.material.clone();for(let r of this.children)r.material=t}else for(let t of this.children)t.material=this.object.material;this.object.material.visible=!e}this.parameters.hideBase=e}}update(){switch(this._updateCount(),this.parameters.type){case"radial":this._updateRadial(this.parameters);break;case"linear":this._updateLinear(this.parameters);break;case"grid":this._updateGrid(this.parameters)}this.children.forEach(e=>e.updateMatrix())}_updateCount(){let e=this.parameters.type==="grid"?this.parameters.grid.count[0]*this.parameters.grid.count[1]*this.parameters.grid.count[2]:this.parameters.count;if(this.children.length!==e)if(this.children.length<e)for(let t=0,r=e-this.children.length;t<r;++t){let n=this.object.shallowClone(!1);n.visible=!0,this.add(n),this.parameters.hideBase&&this.setHideBase(!0)}else for(let t=0,r=this.children.length-e;t<r;++t)this.remove(this.children[0])}_updateRadial(e){let t=e.radial,r=t.start*$i.DEG2RAD,n=t.end*$i.DEG2RAD,s=r-n,l=new mv(t.rotation[0]*$i.DEG2RAD,t.rotation[1]*$i.DEG2RAD,t.rotation[2]*$i.DEG2RAD),c;switch(t.axis){case"z":c=new Ta(0,0,1);break;case"y":c=new Ta(0,1,0);break;default:case"x":c=new Ta(1,0,0);break}for(let[f,h]of this.children.entries()){h.hiddenMatrix.identity(),h.scale.x=t.scale[0],h.scale.y=t.scale[1],h.scale.z=t.scale[2],h.position.setScalar(0);let d=s/e.count*f-r;switch(t.axis){case"x":h.rotation.set(0,d,0);break;case"y":h.rotation.set(0,0,d);break;case"z":h.rotation.set(d,0,0);break}h.translateOnAxis(c,t.radius),h.position.x+=t.position[0],h.position.y+=t.position[1],h.position.z+=t.position[2],t.alignment===!0?(h.rotation.x+=l.x,h.rotation.y+=l.y,h.rotation.z+=l.z):h.rotation.copy(l)}}_updateLinear(e){if(e.type!=="linear")throw new Error;let t=e.linear,r=new mv(t.rotation[0]*$i.DEG2RAD,t.rotation[1]*$i.DEG2RAD,t.rotation[2]*$i.DEG2RAD);for(let[n,s]of this.children.entries())s.hiddenMatrix.identity(),s.scale.x=1+(t.scale[0]-1)*n,s.scale.y=1+(t.scale[1]-1)*n,s.scale.z=1+(t.scale[2]-1)*n,s.rotation.x=r.x*n,s.rotation.y=r.y*n,s.rotation.z=r.z*n,s.position.x=t.position[0]*n,s.position.y=t.position[1]*n,s.position.z=t.position[2]*n}_updateGrid(e){let t=0,r=e.grid;if(r.useCenter===!0){let n={x:r.count[0]%2==0?2:1,y:r.count[1]%2==0?2:1,z:r.count[2]%2==0?2:1},s=new Ta(r.size[0]*(r.count[0]-n.x)*.5,r.size[1]*(r.count[1]-n.y)*.5,r.size[2]*(r.count[2]-n.z)*.5);for(let l=0;l<r.count[0];l++)for(let c=0;c<r.count[1];c++)for(let f=0;f<r.count[2];f++){let h=this.children[t++];h.hiddenMatrix.identity(),h.scale.setScalar(1),h.rotation.set(0,0,0),h.position.x=r.size[0]*l-s.x,h.position.y=r.size[1]*c-s.y,h.position.z=r.size[2]*f-s.z}}else for(let n=0;n<r.count[0];n++)for(let s=0;s<r.count[1];s++)for(let l=0;l<r.count[2];l++){let c=this.children[t++];c.hiddenMatrix.identity(),c.scale.setScalar(1),c.rotation.set(0,0,0),c.position.x=r.size[0]*n,c.position.y=-r.size[1]*s,c.position.z=-r.size[2]*l}}fromJSON(e){return this}toJSON(){return{}}fromClonerState(e){return e.hideBase!==void 0&&this.setHideBase(e.hideBase),yo(this.parameters,e),this.update(),this}};var hr=class extends xn(nD){constructor(e,t){super(e,t);this.isAbstractMesh=!0;Array.isArray(t)&&(this.selectedMaterial=0,e.groups.length===0&&e.addGroup(0,e.getAttribute("position").count,0))}get cloner(){return this._cloner}set cloner(e){this._cloner&&this.remove(this._cloner),e&&this.add(e),this._cloner=e}getSelectedMaterial(e){return Array.isArray(this.material)?(this.selectedMaterial===void 0&&(this.selectedMaterial=e!=null?e:0),this.material[e!=null?e:this.selectedMaterial]):this.material}setSelectedMaterial(e,t){Array.isArray(this.material)?(this.selectedMaterial===void 0&&(this.selectedMaterial=t!=null?t:0),t=t!=null?t:this.selectedMaterial,this.material[t].dispose(),this.material[t]=e):(this.material.dispose(),this.material=e)}updateGeometry(e){let t=this.geometry,r=Zh[t.userData.type],n=this.objectType==="NonParametric"?Object.assign({},t.userData,{geometry:t}):t.userData,s=r.build(r.normalizeInputs(e,n)),l=t.uuid;if(this.geometry.dispose(),this.geometry=s,this.geometry.uuid=l,this.geometry.computeBoundingSphere(),this.cloner)for(let c of this.cloner.children)c.geometry=this.geometry}resizeGeometry(e,t,r){Ca.resizeGeometry(this.geometry,{width:e,height:t,depth:r})}shallowClone(e){return new this.constructor(this.geometry,this.material).shallowCopy(this,e)}clone(e){let t=this.objectType==="NonParametric"?Object.assign({},this.geometry.userData,{geometry:this.geometry.clone()}):this.geometry.userData,r=La(t),n=Array.isArray(this.material)?this.material.map(s=>s.clone()):this.material.clone();return new this.constructor(r,n).copy(this,e)}copy(e,t=!0){return super.copy(e,t),e.cloner&&(this.cloner=new fu(e,e.cloner.parameters),this.add(this.cloner)),this}setFromClonerState(e){e===null?this.cloner=void 0:(this.cloner===void 0&&(this.cloner=new fu(this)),this.cloner.fromClonerState(e))}fromState(e,t){var r,n;return super.fromState(e),e.type==="Mesh"&&(this.setFromClonerState(e.cloner),this.castShadow=(r=e.castShadow)!=null?r:!0,this.receiveShadow=(n=e.receiveShadow)!=null?n:!0),this}};import{NormalBlending as CD,ShaderMaterial as LD,FrontSide as _D}from"three";import{CubeReflectionMapping as mD,CubeRefractionMapping as gD,CubeUVReflectionMapping as yD,LinearEncoding as Sv,sRGBEncoding as xD}from"three";var hu=class{constructor(e){e=e!=null?e:{},this.name=e.name,this.type=e.type,this.node=e.node,this.size=e.size,this.needsUpdate=e.needsUpdate}get value(){return this.node.value}set value(e){this.node.value=e}};import{MathUtils as iD}from"three";var Pe=class{constructor(e){this.hashProperties=void 0;this.isNode=!0;this.shortcuts={};this.uuid=iD.generateUUID(),this.type=e,this.name="",this.userData={}}analyze(e,t){t=t!=null?t:{},e.analyzing=!0,this.build(e.addFlow(t.slot,t.cache,t.context),"v4"),e.clearVertexNodeCode(),e.clearFragmentNodeCode(),e.removeFlow(),e.analyzing=!1}analyzeAndFlow(e,t,r){return r=r!=null?r:{},this.analyze(e,r),this.flow(e,t,r)}flow(e,t,r){r=r!=null?r:{},e.addFlow(r.slot,r.cache,r.context);let n={result:this.build(e,t),code:e.clearNodeCode(),extra:e.context.extra};return e.removeFlow(),n}build(e,t,r){t=t!=null?t:this.getType(e,t);let n=e.getNodeData(r!=null?r:this);return e.analyzing&&this.appendDepsNode(e,n,t),e.nodes.indexOf(this)===-1&&e.nodes.push(this),this.updateFrame!==void 0&&e.updaters.indexOf(this)===-1&&e.updaters.push(this),this.generate(e,t,r)}updateFrame(e){}generateReadonly(e,t,r,n,s,l){return""}generate(e,t,r,n,s){return""}parse(e,t,r,n){}appendDepsNode(e,t,r){t.deps=(t.deps||0)+1;let n=e.getTypeLength(r);(n>(t.outputMax||0)||this.getType(e,r))&&(t.outputMax=n,t.output=r)}setName(e){this.name=e}getName(){return this.name}getType(e,t){return t==="sampler2D"||t==="samplerCube"?t:this.type}getJSONNode(e){if((e==null?void 0:e.materials)&&(e==null?void 0:e.materials[this.uuid])!==void 0)return e.materials[this.uuid]}getHash(){let e="{",t,r;for(t in this)r=this[t],r instanceof Pe&&(e+='"'+t+'":'+r.getHash()+",");if(this.hashProperties)for(let n=0;n<this.hashProperties.length;n++)t=this.hashProperties[n],r=this[t],e+='"'+t+'":"'+String(r)+'",';return e+='"id":"'+this.uuid+'"}',e}copy(e){return this.name=e.name,e.type&&(this.type=e.type),e.frameId&&(this.frameId=e.frameId),e.hashProperties&&(this.hashProperties=e.hashProperties.map(t=>t)),this.userData=JSON.parse(JSON.stringify(e.userData)),this.shortcuts=JSON.parse(JSON.stringify(e.shortcuts)),this}clone(){return new this.constructor().copy(this)}createJSONNode(e){let t=e===void 0||typeof e=="string";if(typeof this.type!="string")throw new Error("Node does not allow serialization.");let r={};return r.uuid=this.uuid,r.type=this.type,this.name!==""&&(r.name=this.name),JSON.stringify(this.userData)!=="{}"&&(r.userData=this.userData),!t&&e&&(e.nodes[this.uuid]=r),r}toJSON(e){var t;return(t=this.getJSONNode(e))!=null?t:this.createJSONNode(e)}fromJSON(e,t){return this.uuid=e.uuid,this.type=e.type,e.name&&(this.name=e.name),e.userData&&(this.userData=e.userData),this}};var gv=class{constructor(){this.nodes={};this.keywords={}}add(e){this.nodes[e.name]=e}addKeyword(e,t,r){r=r!==void 0?r:!0,this.keywords[e]={callback:t,cache:r}}remove(e){delete this.nodes[e.name]}removeKeyword(e){delete this.keywords[e]}get(e){return this.nodes[e]}getKeyword(e,t){return this.keywords[e].callback(t)}getKeywordData(e){return this.keywords[e]}contains(e){return this.nodes[e]!==void 0}containsKeyword(e){return this.keywords[e]!==void 0}},tr=new gv;import{Vector2 as yv}from"three";import{MathUtils as oD}from"three";var Be=class extends Pe{constructor(e,t){super(e);this.scope="";t=t!=null?t:{},this.shared=t.shared!==void 0?t.shared:!0,this.unique=t.unique!==void 0?t.unique:!1}build(e,t,r,n){if(t=t!=null?t:this.getType(e),this.getShared(e,t)){let s=this.getUnique(e,t);s&&this.uuid===void 0&&(this.uuid=oD.generateUUID()),r=e.getUUID(r!=null?r:this.getUUID(),!s);let l=e.getNodeData(r),c=l.output||this.getType(e);if(e.analyzing)return(l.deps||0)>0||this.getLabel()?(this.appendDepsNode(e,l,t),this.generate(e,t,r)):super.build(e,t,r);if(s)return l.name=l.name||super.build(e,t,r),l.name;if(!this.getLabel()&&(!this.getShared(e,c)||e.context.ignoreCache||l.deps===1))return super.build(e,t,r);r=this.getUUID(!1);let f=this.getTemp(e,r);if(f)return e.format(f,c,t);{f=super.generate(e,t,r,l.output,n);let h=this.generate(e,c,r);return e.addNodeCode(f+" = "+h+";"),e.format(f,c,t)}}return super.build(e,t,r)}getShared(e,t){return t!=="sampler2D"&&t!=="samplerCube"&&this.shared}getUnique(e,t){return this.unique}setLabel(e){return this.label=e,this}getLabel(){return this.label}getUUID(e){let t=this.uuid;return typeof this.scope=="string"&&(t=this.scope+"-"+t),t}getTemp(e,t){t=t||this.uuid;let r=e.getVars()[t];return r?r.name:void 0}generate(e,t,r,n,s){return this.getShared(e,t)||console.error("TempNode is not shared"),r=r!=null?r:this.uuid,e.getTempVar(r,n!=null?n:this.getType(e),s,this.getLabel()).name}};var It=class extends Be{constructor(e,t){t=t!=null?t:{},t.shared=t.shared!==void 0?t.shared:!1;super(e,t);this.readonly=!1}setReadonly(e){return this.readonly=e,this.hashProperties=this.readonly?["value"]:void 0,this}getReadonly(){return this.readonly}createJSONNode(e){let t=super.createJSONNode(e);return this.readonly===!0&&(t.readonly=this.readonly),t}fromJSON(e,t){return super.fromJSON(e,t),e.readonly!==void 0&&this.setReadonly(e.readonly),this}generate(e,t,r,n,s,l){r=e.getUUID(r!=null?r:this.getUUID()),n=n!=null?n:this.getType(e);let c=e.getNodeData(r);return this.getReadonly()&&this.generateReadonly!==void 0?this.generateReadonly(e,t,r,n,s,l):e.isShader("vertex")?(c.vertex||(c.vertex=e.createVertexUniform(n,this,s,l,this.getLabel())),e.format(c.vertex.name,n,t)):(c.fragment||(c.fragment=e.createFragmentUniform(n,this,s,l,this.getLabel())),e.format(c.fragment.name,n,t))}copy(e){return super.copy(e),this.readonly=e.readonly,this}};var _r=class extends It{constructor(e=0,t){super("v2");this.nodeType="Vector2";this.value=e instanceof yv?e:new yv(e,t)}get x(){return this.value.x}set x(e){this.value.x=e}get y(){return this.value.y}set y(e){this.value.y=e}generateReadonly(e,t,r,n,s,l){return e.format("vec2("+this.value.x+", "+this.value.y+")",n,t)}copy(e){return super.copy(e),this.value.copy(e.value),this}};import{Vector3 as xv}from"three";var Tr=class extends It{constructor(e=0,t,r){super("v3");this.nodeType="Vector3";this.value=e instanceof xv?e:new xv(e,t,r)}get x(){return this.value.x}set x(e){this.value.x=e}get y(){return this.value.y}set y(e){this.value.y=e}get z(){return this.value.z}set z(e){this.value.z=e}generateReadonly(e,t,r,n,s,l){return e.format("vec3("+this.value.x+", "+this.value.y+", "+this.value.z+")",n,t)}copy(e){return super.copy(e),this.value.copy(e.value),this}};var Ji=class extends It{constructor(e){super("v4");this.nodeType="Vector4";this.value=e instanceof tn?e:new tn(e.r,e.g,e.b,e.a)}generateReadonly(e,t,r,n,s,l){return e.format("vec4("+this.value.r+", "+this.value.g+", "+this.value.b+", "+this.value.a+")",n,t)}copy(e){return super.copy(e),this.value.copy(e.value),this}};var sD=/^\s*([a-z_0-9]+)\s([a-z_0-9]+)\s*\((.*?)\)/i,vv=/[a-z_0-9]+/gi,Se=class extends Be{constructor(e,t,r,n,s){super(s);this.src="";this.nodeType="Function";this.useKeywords=!0;this.includes=[];this.extensions={};this.keywords={};this.isMethod=s===void 0,this.isInterface=!1,this.parse(e,t,r,n)}getShared(e,t){return!this.isMethod}getType(e){return e.getTypeByFormat(this.type)}getInputByName(e){if(this.inputs){let t=this.inputs.length;for(;t--;)if(this.inputs[t].name===e)return this.inputs[t]}}getIncludeByName(e){if(this.includes){let t=this.includes.length;for(;t--;)if(this.includes[t].name===e)return this.includes[t]}}generate(e,t,r,n,s){let l,c=0,f=this.src;if(this.includes)for(let d=0;d<this.includes.length;d++)e.include(this.includes[d],this);for(let d in this.extensions)e.extensions[d]=!0;let h=[];for(;l=vv.exec(this.src);)h.push(l);for(let d=0;d<h.length;d++){let x=h[d],g=x[0],w=this.isMethod?!this.getInputByName(g):!0,S=g;if(this.keywords[g]||this.useKeywords&&w&&tr.containsKeyword(g)){let D=this.keywords[g];if(!D){let C=tr.getKeywordData(g);C.cache&&(D=e.keywords[g]),D=D||tr.getKeyword(g,e),C.cache&&(e.keywords[g]=D)}S=D.build(e)}g!==S&&(f=f.substring(0,x.index+c)+S+f.substring(x.index+g.length+c),c+=S.length-g.length),this.getIncludeByName(S)===void 0&&tr.contains(S)&&e.include(tr.get(S))}return t==="source"?f:this.isMethod?(this.isInterface||e.include(this,void 0,f),this.name):e.format("( "+f+" )",this.getType(e),t)}parse(e,t,r,n){if(this.src=e||"",this.includes=t!=null?t:[],this.extensions=r!=null?r:{},this.keywords=n!=null?n:{},this.isMethod){let s=sD.exec(this.src);if(this.inputs=[],s&&s.length==4){this.type=s[1],this.name=s[2];let l=s[3].match(vv);if(l){let c=0;for(;c<l.length;){let f=l[c++],h;f==="in"||f==="out"||f==="inout"?h=l[c++]:(h=f,f="");let d=l[c++];this.inputs.push({name:d,type:h,qualifier:f})}}this.isInterface=this.src.indexOf("{")===-1}else this.type="",this.name=""}}copy(e){return super.copy(e),this.isMethod=e.isMethod,this.useKeywords=e.useKeywords,e.type!==void 0&&(this.type=e.type),this.parse(e.src,e.includes,e.extensions,e.keywords),this}toJSON(e){var r;let t=this.getJSONNode(e);if(!t){t=this.createJSONNode(e),t.src=this.src,t.isMethod=this.isMethod,t.useKeywords=this.useKeywords,this.isMethod||(t.type=this.type),t.extensions=JSON.parse(JSON.stringify(this.extensions));let n={};for(let s in this.keywords)n[s]=this.keywords[s].toJSON(e).uuid;if(t.keywords=n,(r=this.includes)==null?void 0:r.length){let s=[];for(let l=0;l<this.includes.length;l++)s.push(this.includes[l].toJSON(e).uuid);t.includes=s}t.isMethod=this.isMethod,t.inputs=this.inputs}return t.nodeType=this.nodeType,t}fromJSON(e,t){if(super.fromJSON(e,t),e.inputs!==void 0&&(this.inputs=e.inputs),e.isMethod!==void 0&&(this.isMethod=e.isMethod),e.src&&(this.src=e.src),e.isMethod&&(this.isMethod=e.isMethod),e.useKeywords&&(this.useKeywords=e.useKeywords),e.type&&(this.type=e.type),e.extensions&&(this.extensions=e.extensions),e.keywords&&t){this.keywords={};for(let r in e.keywords)this.keywords[r]=t.getNode(e.keywords[r])}return e.includes&&t&&(this.includes=e.includes.map(r=>t.getNode(r))),this}};var aD=/^([a-z_0-9]+)\s([a-z_0-9]+)\s?\=?\s?(.*?)(\;|$)/i,ep=class extends Be{constructor(e="",t){super();this.src="";this.useDefine=!1;this.nodeType="Const";this.parse(e||ep.PI,void 0,void 0,void 0,t)}getType(e){return e.getTypeByFormat(this.type)}parse(e,t,r,n,s){this.src=e||"";let l,c,f="",h=aD.exec(e);this.useDefine=s!=null?s:this.src.charAt(0)==="#",h&&h.length>1?(c=h[1],l=h[2],f=h[3]):(l=this.src,c="f"),this.name=l,this.type=c,this.value=f}build(e,t){if(t==="source"){if(this.value)return this.useDefine?"#define "+this.name+" "+this.value:"const "+this.type+" "+this.name+" = "+this.value+";";if(this.useDefine)return this.src}return e.include(this),e.format(this.name,this.getType(e),t)}generate(e,t,r,n,s){return e.format(this.name,this.getType(e),t)}copy(e){return super.copy(e),this.parse(e.src,void 0,void 0,void 0,e.useDefine),this}},it=ep;it.PI="PI",it.PI2="PI2",it.RECIPROCAL_PI="RECIPROCAL_PI",it.RECIPROCAL_PI2="RECIPROCAL_PI2",it.LOG2="LOG2",it.EPSILON="EPSILON";var lD=new RegExp(`^structs*([a-z_0-9]+)s*{s*((.|
|
|
21
|
+
)*?)}`,"gim"),cD=new RegExp("s*(w*?)s*(w*?)(=|;)","gim"),Ia=class extends Be{constructor(e=""){super();this.inputs=[];this.src="";this.nodeType="Struct";this.parse(e)}getType(e){return e.getTypeByFormat(this.name)}getInputByName(e){let t=this.inputs.length;for(;t--;)if(this.inputs[t].name===e)return this.inputs[t]}generate(e,t,r,n,s){return t==="source"?this.src+";":e.format("( "+this.src+" )",this.getType(e),t)}parse(e=""){this.src=e,this.inputs=[];let t=lD.exec(e);if(t){let r=t[2],n;for(;n=cD.exec(r);)this.inputs.push({type:n[1],name:n[2]});this.name=t[1]}else this.name="";this.type=this.name}};var Ma=class extends Be{constructor(e){super("v2",{shared:!1});this.nodeType="UV";this.index=e!=null?e:0}generate(e,t){e.requires.uv[this.index]=!0;let r=this.index>0?this.index+1:"",n=e.isShader("vertex")?"uv"+r:"vUv"+r;return e.format(n,this.getType(e),t)}copy(e){return super.copy(e),this.index=e.index,this}toJSON(e){let t=this.getJSONNode(e);return t||(t=this.createJSONNode(e),t.index=this.index),t.nodeType=this.nodeType,t}fromJSON(e,t){return super.fromJSON(e,t),e.index&&(this.index=e.index),this}};tr.addKeyword("uv",function(){return new Ma});tr.addKeyword("uv2",function(){return new Ma(1)});import{LinearEncoding as uD,sRGBEncoding as fD}from"three";var Co=class extends Be{constructor(e=new Pe,t){super("v4");this.nodeType="ColorSpace";this.factor=new Pe;this.input=e,this.method=t!=null?t:Co.LINEAR_TO_LINEAR,this.hashProperties=["method"]}static getEncodingComponents(e){switch(e){case uD:return["Linear"];case fD:return["sRGB"];default:return[]}}generate(e,t){var c;let r=this.input.build(e,"v4"),n=this.getType(e),s=Co.Nodes[this.method],l=e.include(s);if(l===Co.LINEAR_TO_LINEAR)return e.format(r,n,t);if(((c=s.inputs)==null?void 0:c.length)===2){let f=this.factor.build(e,"f");return e.format(l+"( "+r+", "+f+" )",n,t)}else return e.format(l+"( "+r+" )",n,t)}fromEncoding(e){let t=Co.getEncodingComponents(e);this.method="LinearTo"+t[0],this.factor=t[1]}fromDecoding(e){let t=Co.getEncodingComponents(e);this.method=t[0]+"ToLinear",this.factor=t[1]}copy(e){return super.copy(e),this.input.copy(e.input),this.method=e.method,this.factor.copy(e.factor),this}},zr=Co;zr.Nodes={LinearToLinear:new Se(["vec4 LinearToLinear( in vec4 value ) {"," return value;","}"].join(`
|
|
22
22
|
`)),sRGBToLinear:new Se(["vec4 sRGBToLinear( in vec4 value ) {"," return vec4( mix( pow( value.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), value.rgb * 0.0773993808, vec3( lessThanEqual( value.rgb, vec3( 0.04045 ) ) ) ), value.w );","}"].join(`
|
|
23
23
|
`)),LinearTosRGB:new Se(["vec4 LinearTosRGB( in vec4 value ) {"," return vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.w );","}"].join(`
|
|
24
|
-
`))},zr.LINEAR_TO_LINEAR="LinearToLinear",zr.SRGB_TO_LINEAR="sRGBToLinear",zr.LINEAR_TO_SRGB="LinearTosRGB";var xt=class extends Se{constructor(e="",t,r,n,s){super(e,s,n,r,t);this.nodeType="Expression"}};import{Texture as zD}from"three";var wi=class extends zD{toJSON(e){let t=super.toJSON(e),r=e===void 0||typeof e=="string";if(this.image!==void 0&&!r){let n=this.image;if(Array.isArray(n)){e.images[n.uuid].url=[];for(let s=0;s<n.length;s++)e.images[n.uuid].url[s]=Gv(n[s])}else e.images[n.uuid].url=Gv(n)}return t}};function Gv(i){return typeof HTMLImageElement!="undefined"&&i instanceof HTMLImageElement||typeof HTMLCanvasElement!="undefined"&&i instanceof HTMLCanvasElement||typeof ImageBitmap!="undefined"&&i instanceof ImageBitmap?FD(i):(console.warn("THREE.Texture: Unable to serialize Texture."),"")}var Ps;function FD(i){if(/^data:/i.test(i.src))return i.src;let e;if(i instanceof HTMLCanvasElement)e=i;else{Ps===void 0&&(Ps=document.createElement("canvas")),Ps.width=i.width,Ps.height=i.height;let r=Ps.getContext("2d");i instanceof ImageData?r.putImageData(i,0,0):r.drawImage(i,0,0,i.width,i.height),e=Ps}let t=i.src.startsWith("blob:")?i.fileName:i.src;return/\.jpe?g$/i.test(t)?e.toDataURL("image/jpeg",.6):e.toDataURL("image/png")}var Fr=class extends It{constructor(e=new wi,t,r,n){super("v4",{shared:!0});this.nodeType="Texture";this.value=e,this.uv=t!=null?t:new Oa,this.bias=r,this.project=n!==void 0?n:!1}getTexture(e,t){return super.generate(e,t,this.value.uuid,"t")}generate(e,t){var p;if(t==="sampler2D")return this.getTexture(e,t);let r=this.getTexture(e,t),n=this.uv.build(e,this.project?"v4":"v2"),s=this.bias?this.bias.build(e,"f"):void 0;s===void 0&&e.context.bias&&(s=e.context.bias.setTexture(this).build(e,"f"));let l,c;this.project?l="texture2DProj":l=s?"tex2DBias":"tex2D",s?c=l+"( "+r+", "+n+", "+s+" )":c=l+"( "+r+", "+n+" )";let f={include:e.isShader("vertex"),ignoreCache:!0},h=this.getType(e);return e.addContext(f),this.colorSpace=(p=this.colorSpace)!=null?p:new zr(new xt("",h)),this.colorSpace.fromDecoding(e.getTextureEncodingFromMap(this.value)),this.colorSpace.input.parse(c),c=this.colorSpace.build(e,h),e.removeContext(),e.format(c,h,t)}copy(e){return super.copy(e),e.value.isRenderTargetTexture?this.value=e.value:this.value.copy(e.value),this.uv.copy(e.uv),e.bias?this.bias?this.bias.copy(e.bias):this.bias=e.bias.clone():this.bias=void 0,e.colorSpace?this.colorSpace?this.colorSpace.copy(e.colorSpace):this.colorSpace=e.colorSpace.clone():this.colorSpace=void 0,this.project=e.project,e.value.isRenderTargetTexture||(this.value.updateMatrix(),this.value.needsUpdate=!0),this}};var ve=class extends It{constructor(e){super("f");this.nodeType="Float";this.value=e!=null?e:0}generateReadonly(e,t,r,n,s,l){return e.format(this.value+(this.value%1?"":".0"),n,t)}copy(e){return super.copy(e),this.value=e.value,this}};var xu=class extends Be{constructor(e,t){super();this.inputs=[];this.nodeType="FunctionCall";this.value=e,this.inputs=t!=null?t:[]}getFunction(){return this.value}getType(e){return this.value.getType(e)}generate(e,t,r,n,s){n=this.getType(e);let l=this.value,c=l.build(e,t)+"( ",f=[];if(l.inputs){for(let h=0;h<l.inputs.length;h++){let p=l.inputs[h],y=this.inputs[h]||this.inputs[p.name];f.push(y.build(e,e.getTypeByFormat(p.type)))}c+=f.join(", ")+" )"}return e.format(c,n,t)}copy(e){return super.copy(e),this.value.copy(e.value),this.inputs=e.inputs.map(t=>t.clone()),this}toJSON(e){var r;let t=this.getJSONNode(e);if(!t){let n=this.value;if(t=this.createJSONNode(e),t.value=this.value.toJSON(e).uuid,(r=n.inputs)==null?void 0:r.length){t.inputs={};for(let s=0;s<n.inputs.length;s++){let l=n.inputs[s],c=this.inputs[s];t.inputs[l.name]=c.toJSON(e).uuid}}}return t}};var Ds;(function(n){n.ADD="+",n.SUB="-",n.MUL="*",n.DIV="/"})(Ds||(Ds={}));var cd=class extends Be{constructor(e=new Pe,t=new Pe,r=cd.ADD){super();this.nodeType="Operator";this.type=e.type,this.a=e,this.b=t,this.op=r}getType(e){let t=this.a.getType(e),r=this.b.getType(e);return e.isTypeMatrix(t)?"v4":e.getTypeLength(r)>e.getTypeLength(t)?r:t}generate(e,t){let r=this.getType(e);this.type=r;let n=this.a.build(e,r),s=this.b.build(e,r);return e.format("( "+n+" "+this.op+" "+s+" )",r,t)}copy(e){return super.copy(e),this.a.copy(e.a),this.b.copy(e.b),this.op=e.op,this}},rn=cd;rn.ADD=Ds.ADD,rn.SUB=Ds.SUB,rn.MUL=Ds.MUL,rn.DIV=Ds.DIV;var Ke;(function(_){_.RAD="radians",_.DEG="degrees",_.EXP="exp",_.EXP2="exp2",_.LOG="log",_.LOG2="log2",_.SQRT="sqrt",_.INV_SQRT="inversesqrt",_.FLOOR="floor",_.CEIL="ceil",_.NORMALIZE="normalize",_.FRACT="fract",_.SATURATE="saturate",_.SIN="sin",_.COS="cos",_.TAN="tan",_.ASIN="asin",_.ACOS="acos",_.ARCTAN="atan",_.ABS="abs",_.SIGN="sign",_.LENGTH="length",_.NEGATE="negate",_.INVERT="invert",_.MIN="min",_.MAX="max",_.MOD="mod",_.STEP="step",_.REFLECT="reflect",_.DISTANCE="distance",_.DOT="dot",_.CROSS="cross",_.POW="pow",_.MIX="mix",_.CLAMP="clamp",_.REFRACT="refract",_.SMOOTHSTEP="smoothstep",_.FACEFORWARD="faceforward"})(Ke||(Ke={}));var ht=class extends Be{constructor(e=new Pe,t=ht.ABS,r,n){super();this.nodeType="Math";this.a=e,typeof t!="string"?this.b=t:n=t,typeof r!="string"?this.c=r:n=r,this.method=n,this.hashProperties=["method"]}getNumInputs(e){switch(this.method){case ht.MIX:case ht.CLAMP:case ht.REFRACT:case ht.SMOOTHSTEP:case ht.FACEFORWARD:return 3;case ht.MIN:case ht.MAX:case ht.MOD:case ht.STEP:case ht.REFLECT:case ht.DISTANCE:case ht.DOT:case ht.CROSS:case ht.POW:return 2;default:return 1}}getInputType(e){let t=e.getTypeLength(this.a.getType(e)),r=this.b?e.getTypeLength(this.b.getType(e)):0,n=this.c?e.getTypeLength(this.c.getType(e)):0;return t>r&&t>n?this.a.getType(e):r>n?this.b.getType(e):this.c.getType(e)}getType(e){switch(this.method){case ht.LENGTH:case ht.DISTANCE:case ht.DOT:return"f";case ht.CROSS:return"v3"}return this.getInputType(e)}generate(e,t){let r,n,s,l=this.a?e.getTypeLength(this.a.getType(e)):0,c=this.b?e.getTypeLength(this.b.getType(e)):0,f=this.c?e.getTypeLength(this.c.getType(e)):0,h=this.getInputType(e),p=this.getType(e);switch(this.type=p,this.method){case ht.NEGATE:return e.format("( -"+this.a.build(e,h)+" )",h,t);case ht.INVERT:return e.format("( 1.0 - "+this.a.build(e,h)+" )",h,t);case ht.CROSS:r=this.a.build(e,"v3"),n=this.b.build(e,"v3");break;case ht.STEP:r=this.a.build(e,l===1?"f":h),n=this.b.build(e,h);break;case ht.MIN:case ht.MAX:case ht.MOD:r=this.a.build(e,h),n=this.b.build(e,c===1?"f":h);break;case ht.REFRACT:r=this.a.build(e,h),n=this.b.build(e,h),s=this.c.build(e,"f");break;case ht.MIX:r=this.a.build(e,h),n=this.b.build(e,h),s=this.c.build(e,f===1?"f":h);break;default:r=this.a.build(e,h),this.b&&(n=this.b.build(e,h)),this.c&&(s=this.c.build(e,h));break}let y=[];y.push(r),n&&y.push(n),s&&y.push(s);let g=this.getNumInputs(e);if(y.length!==g)throw Error(`Arguments not match used in "${this.method}". Require ${g}, currently ${y.length}.`);return e.format(this.method+"( "+y.join(", ")+" )",p,t)}copy(e){return super.copy(e),this.a.copy(e.a),this.b=e.b instanceof Pe?e.b.clone():e.b,this.c=e.c instanceof Pe?e.c.clone():e.c,this.method=e.method,this}},ze=ht;ze.RAD=Ke.RAD,ze.DEG=Ke.DEG,ze.EXP=Ke.EXP,ze.EXP2=Ke.EXP2,ze.LOG=Ke.LOG,ze.LOG2=Ke.LOG2,ze.SQRT=Ke.SQRT,ze.INV_SQRT=Ke.INV_SQRT,ze.FLOOR=Ke.FLOOR,ze.CEIL=Ke.CEIL,ze.NORMALIZE=Ke.NORMALIZE,ze.FRACT=Ke.FRACT,ze.SATURATE=Ke.SATURATE,ze.SIN=Ke.SIN,ze.COS=Ke.COS,ze.TAN=Ke.TAN,ze.ASIN=Ke.ASIN,ze.ACOS=Ke.ACOS,ze.ARCTAN=Ke.ARCTAN,ze.ABS=Ke.ABS,ze.SIGN=Ke.SIGN,ze.LENGTH=Ke.LENGTH,ze.NEGATE=Ke.NEGATE,ze.INVERT=Ke.INVERT,ze.MIN=Ke.MIN,ze.MAX=Ke.MAX,ze.MOD=Ke.MOD,ze.STEP=Ke.STEP,ze.REFLECT=Ke.REFLECT,ze.DISTANCE=Ke.DISTANCE,ze.DOT=Ke.DOT,ze.CROSS=Ke.CROSS,ze.POW=Ke.POW,ze.MIX=Ke.MIX,ze.CLAMP=Ke.CLAMP,ze.REFRACT=Ke.REFRACT,ze.SMOOTHSTEP=Ke.SMOOTHSTEP,ze.FACEFORWARD=Ke.FACEFORWARD;var Bs=class extends Be{constructor(e=new Pe,t=new Pe,r=new Pe){super("v4");this.nodeType="TextureCubeUV";this.value=e,this.uv=t,this.bias=r}bilinearCubeUV(e,t,r,n){var f,h,p,y;let s=new xu(Bs.Nodes.bilinearCubeUV,[t,r,n]);this.colorSpaceTL=(f=this.colorSpaceTL)!=null?f:new zr(new xt("","v4")),this.colorSpaceTL.fromDecoding(e.getTextureEncodingFromMap(this.value.value)),this.colorSpaceTL.input.parse(s.build(e)+".tl"),this.colorSpaceTR=(h=this.colorSpaceTR)!=null?h:new zr(new xt("","v4")),this.colorSpaceTR.fromDecoding(e.getTextureEncodingFromMap(this.value.value)),this.colorSpaceTR.input.parse(s.build(e)+".tr"),this.colorSpaceBL=(p=this.colorSpaceBL)!=null?p:new zr(new xt("","v4")),this.colorSpaceBL.fromDecoding(e.getTextureEncodingFromMap(this.value.value)),this.colorSpaceBL.input.parse(s.build(e)+".bl"),this.colorSpaceBR=(y=this.colorSpaceBR)!=null?y:new zr(new xt("","v4")),this.colorSpaceBR.fromDecoding(e.getTextureEncodingFromMap(this.value.value)),this.colorSpaceBR.input.parse(s.build(e)+".br");let l={include:e.isShader("vertex"),ignoreCache:!0};e.addContext(l),this.colorSpaceTLExp=new xt(this.colorSpaceTL.build(e,"v4"),"v4"),this.colorSpaceTRExp=new xt(this.colorSpaceTR.build(e,"v4"),"v4"),this.colorSpaceBLExp=new xt(this.colorSpaceBL.build(e,"v4"),"v4"),this.colorSpaceBRExp=new xt(this.colorSpaceBR.build(e,"v4"),"v4"),e.removeContext();let c=new xt("mix( mix( cubeUV_TL, cubeUV_TR, cubeUV.f.x ), mix( cubeUV_BL, cubeUV_BR, cubeUV.f.x ), cubeUV.f.y )","v4");return c.keywords.cubeUV_TL=this.colorSpaceTLExp,c.keywords.cubeUV_TR=this.colorSpaceTRExp,c.keywords.cubeUV_BL=this.colorSpaceBLExp,c.keywords.cubeUV_BR=this.colorSpaceBRExp,c.keywords.cubeUV=s,c}generate(e,t){if(e.isShader("fragment")){let r=this.uv,n=this.bias||e.context.roughness,s=new xu(Bs.Nodes.roughnessToMip,[n]),l=new ze(s,Bs.Nodes.m0,Bs.Nodes.cubeUV_maxMipLevel,ze.CLAMP),c=new ze(l,ze.FLOOR),f=new ze(l,ze.FRACT),h=this.bilinearCubeUV(e,this.value,r,c),p=this.bilinearCubeUV(e,this.value,r,new rn(c,new ve(1).setReadonly(!0),rn.ADD)),y=new ze(h,p,f,ze.MIX);return e.format(y.build(e),"v4",t)}else return console.warn("TextureCubeUVNode is not compatible with "+e.shader+" shader."),e.format("vec4( 0.0 )",this.getType(e),t)}copy(e){return super.copy(e),this.uv.copy(e.uv),this.bias.copy(e.bias),this.value.copy(e.value),e.colorSpaceTL?this.colorSpaceTL?this.colorSpaceTL.copy(e.colorSpaceTL):this.colorSpaceTL=e.colorSpaceTL.clone():this.colorSpaceTL=void 0,e.colorSpaceTR?this.colorSpaceTR?this.colorSpaceTR.copy(e.colorSpaceTR):this.colorSpaceTR=e.colorSpaceTR.clone():this.colorSpaceTR=void 0,e.colorSpaceBL?this.colorSpaceBL?this.colorSpaceBL.copy(e.colorSpaceBL):this.colorSpaceBL=e.colorSpaceBL.clone():this.colorSpaceBL=void 0,e.colorSpaceBR?this.colorSpaceBR?this.colorSpaceBR.copy(e.colorSpaceBR):this.colorSpaceBR=e.colorSpaceBR.clone():this.colorSpaceBR=void 0,e.colorSpaceTLExp?this.colorSpaceTLExp?this.colorSpaceTLExp.copy(e.colorSpaceTLExp):this.colorSpaceTLExp=e.colorSpaceTLExp.clone():this.colorSpaceTLExp=void 0,e.colorSpaceTRExp?this.colorSpaceTRExp?this.colorSpaceTRExp.copy(e.colorSpaceTRExp):this.colorSpaceTRExp=e.colorSpaceTRExp.clone():this.colorSpaceTRExp=void 0,e.colorSpaceBLExp?this.colorSpaceBLExp?this.colorSpaceBLExp.copy(e.colorSpaceBLExp):this.colorSpaceBLExp=e.colorSpaceBLExp.clone():this.colorSpaceBLExp=void 0,e.colorSpaceBRExp?this.colorSpaceBRExp?this.colorSpaceBRExp.copy(e.colorSpaceBRExp):this.colorSpaceBRExp=e.colorSpaceBRExp.clone():this.colorSpaceBRExp=void 0,this}},Pa=Bs;Pa.Nodes=function(){let e=new Aa(`struct TextureCubeUVData {
|
|
24
|
+
`))},zr.LINEAR_TO_LINEAR="LinearToLinear",zr.SRGB_TO_LINEAR="sRGBToLinear",zr.LINEAR_TO_SRGB="LinearTosRGB";var xt=class extends Se{constructor(e="",t,r,n,s){super(e,s,n,r,t);this.nodeType="Expression"}};import{Texture as hD}from"three";var bi=class extends hD{toJSON(e){let t=super.toJSON(e),r=e===void 0||typeof e=="string";if(this.image!==void 0&&!r){let n=this.image;if(Array.isArray(n)){e.images[n.uuid].url=[];for(let s=0;s<n.length;s++)e.images[n.uuid].url[s]=bv(n[s])}else e.images[n.uuid].url=bv(n)}return t}};function bv(i){return typeof HTMLImageElement!="undefined"&&i instanceof HTMLImageElement||typeof HTMLCanvasElement!="undefined"&&i instanceof HTMLCanvasElement||typeof ImageBitmap!="undefined"&&i instanceof ImageBitmap?pD(i):(console.warn("THREE.Texture: Unable to serialize Texture."),"")}var Is;function pD(i){if(/^data:/i.test(i.src))return i.src;let e;if(i instanceof HTMLCanvasElement)e=i;else{Is===void 0&&(Is=document.createElement("canvas")),Is.width=i.width,Is.height=i.height;let r=Is.getContext("2d");i instanceof ImageData?r.putImageData(i,0,0):r.drawImage(i,0,0,i.width,i.height),e=Is}let t=i.src.startsWith("blob:")?i.fileName:i.src;return/\.jpe?g$/i.test(t)?e.toDataURL("image/jpeg",.6):e.toDataURL("image/png")}var Fr=class extends It{constructor(e=new bi,t,r,n){super("v4",{shared:!0});this.nodeType="Texture";this.value=e,this.uv=t!=null?t:new Ma,this.bias=r,this.project=n!==void 0?n:!1}getTexture(e,t){return super.generate(e,t,this.value.uuid,"t")}generate(e,t){var d;if(t==="sampler2D")return this.getTexture(e,t);let r=this.getTexture(e,t),n=this.uv.build(e,this.project?"v4":"v2"),s=this.bias?this.bias.build(e,"f"):void 0;s===void 0&&e.context.bias&&(s=e.context.bias.setTexture(this).build(e,"f"));let l,c;this.project?l="texture2DProj":l=s?"tex2DBias":"tex2D",s?c=l+"( "+r+", "+n+", "+s+" )":c=l+"( "+r+", "+n+" )";let f={include:e.isShader("vertex"),ignoreCache:!0},h=this.getType(e);return e.addContext(f),this.colorSpace=(d=this.colorSpace)!=null?d:new zr(new xt("",h)),this.colorSpace.fromDecoding(e.getTextureEncodingFromMap(this.value)),this.colorSpace.input.parse(c),c=this.colorSpace.build(e,h),e.removeContext(),e.format(c,h,t)}copy(e){return super.copy(e),e.value.isRenderTargetTexture?this.value=e.value:this.value.copy(e.value),this.uv.copy(e.uv),e.bias?this.bias?this.bias.copy(e.bias):this.bias=e.bias.clone():this.bias=void 0,e.colorSpace?this.colorSpace?this.colorSpace.copy(e.colorSpace):this.colorSpace=e.colorSpace.clone():this.colorSpace=void 0,this.project=e.project,e.value.isRenderTargetTexture||(this.value.updateMatrix(),this.value.needsUpdate=!0),this}};var ve=class extends It{constructor(e){super("f");this.nodeType="Float";this.value=e!=null?e:0}generateReadonly(e,t,r,n,s,l){return e.format(this.value+(this.value%1?"":".0"),n,t)}copy(e){return super.copy(e),this.value=e.value,this}};var pu=class extends Be{constructor(e,t){super();this.inputs=[];this.nodeType="FunctionCall";this.value=e,this.inputs=t!=null?t:[]}getFunction(){return this.value}getType(e){return this.value.getType(e)}generate(e,t,r,n,s){n=this.getType(e);let l=this.value,c=l.build(e,t)+"( ",f=[];if(l.inputs){for(let h=0;h<l.inputs.length;h++){let d=l.inputs[h],x=this.inputs[h]||this.inputs[d.name];f.push(x.build(e,e.getTypeByFormat(d.type)))}c+=f.join(", ")+" )"}return e.format(c,n,t)}copy(e){return super.copy(e),this.value.copy(e.value),this.inputs=e.inputs.map(t=>t.clone()),this}toJSON(e){var r;let t=this.getJSONNode(e);if(!t){let n=this.value;if(t=this.createJSONNode(e),t.value=this.value.toJSON(e).uuid,(r=n.inputs)==null?void 0:r.length){t.inputs={};for(let s=0;s<n.inputs.length;s++){let l=n.inputs[s],c=this.inputs[s];t.inputs[l.name]=c.toJSON(e).uuid}}}return t}};var Ms;(function(n){n.ADD="+",n.SUB="-",n.MUL="*",n.DIV="/"})(Ms||(Ms={}));var tp=class extends Be{constructor(e=new Pe,t=new Pe,r=tp.ADD){super();this.nodeType="Operator";this.type=e.type,this.a=e,this.b=t,this.op=r}getType(e){let t=this.a.getType(e),r=this.b.getType(e);return e.isTypeMatrix(t)?"v4":e.getTypeLength(r)>e.getTypeLength(t)?r:t}generate(e,t){let r=this.getType(e);this.type=r;let n=this.a.build(e,r),s=this.b.build(e,r);return e.format("( "+n+" "+this.op+" "+s+" )",r,t)}copy(e){return super.copy(e),this.a.copy(e.a),this.b.copy(e.b),this.op=e.op,this}},rn=tp;rn.ADD=Ms.ADD,rn.SUB=Ms.SUB,rn.MUL=Ms.MUL,rn.DIV=Ms.DIV;var Ke;(function(_){_.RAD="radians",_.DEG="degrees",_.EXP="exp",_.EXP2="exp2",_.LOG="log",_.LOG2="log2",_.SQRT="sqrt",_.INV_SQRT="inversesqrt",_.FLOOR="floor",_.CEIL="ceil",_.NORMALIZE="normalize",_.FRACT="fract",_.SATURATE="saturate",_.SIN="sin",_.COS="cos",_.TAN="tan",_.ASIN="asin",_.ACOS="acos",_.ARCTAN="atan",_.ABS="abs",_.SIGN="sign",_.LENGTH="length",_.NEGATE="negate",_.INVERT="invert",_.MIN="min",_.MAX="max",_.MOD="mod",_.STEP="step",_.REFLECT="reflect",_.DISTANCE="distance",_.DOT="dot",_.CROSS="cross",_.POW="pow",_.MIX="mix",_.CLAMP="clamp",_.REFRACT="refract",_.SMOOTHSTEP="smoothstep",_.FACEFORWARD="faceforward"})(Ke||(Ke={}));var ht=class extends Be{constructor(e=new Pe,t=ht.ABS,r,n){super();this.nodeType="Math";this.a=e,typeof t!="string"?this.b=t:n=t,typeof r!="string"?this.c=r:n=r,this.method=n,this.hashProperties=["method"]}getNumInputs(e){switch(this.method){case ht.MIX:case ht.CLAMP:case ht.REFRACT:case ht.SMOOTHSTEP:case ht.FACEFORWARD:return 3;case ht.MIN:case ht.MAX:case ht.MOD:case ht.STEP:case ht.REFLECT:case ht.DISTANCE:case ht.DOT:case ht.CROSS:case ht.POW:return 2;default:return 1}}getInputType(e){let t=e.getTypeLength(this.a.getType(e)),r=this.b?e.getTypeLength(this.b.getType(e)):0,n=this.c?e.getTypeLength(this.c.getType(e)):0;return t>r&&t>n?this.a.getType(e):r>n?this.b.getType(e):this.c.getType(e)}getType(e){switch(this.method){case ht.LENGTH:case ht.DISTANCE:case ht.DOT:return"f";case ht.CROSS:return"v3"}return this.getInputType(e)}generate(e,t){let r,n,s,l=this.a?e.getTypeLength(this.a.getType(e)):0,c=this.b?e.getTypeLength(this.b.getType(e)):0,f=this.c?e.getTypeLength(this.c.getType(e)):0,h=this.getInputType(e),d=this.getType(e);switch(this.type=d,this.method){case ht.NEGATE:return e.format("( -"+this.a.build(e,h)+" )",h,t);case ht.INVERT:return e.format("( 1.0 - "+this.a.build(e,h)+" )",h,t);case ht.CROSS:r=this.a.build(e,"v3"),n=this.b.build(e,"v3");break;case ht.STEP:r=this.a.build(e,l===1?"f":h),n=this.b.build(e,h);break;case ht.MIN:case ht.MAX:case ht.MOD:r=this.a.build(e,h),n=this.b.build(e,c===1?"f":h);break;case ht.REFRACT:r=this.a.build(e,h),n=this.b.build(e,h),s=this.c.build(e,"f");break;case ht.MIX:r=this.a.build(e,h),n=this.b.build(e,h),s=this.c.build(e,f===1?"f":h);break;default:r=this.a.build(e,h),this.b&&(n=this.b.build(e,h)),this.c&&(s=this.c.build(e,h));break}let x=[];x.push(r),n&&x.push(n),s&&x.push(s);let g=this.getNumInputs(e);if(x.length!==g)throw Error(`Arguments not match used in "${this.method}". Require ${g}, currently ${x.length}.`);return e.format(this.method+"( "+x.join(", ")+" )",d,t)}copy(e){return super.copy(e),this.a.copy(e.a),this.b=e.b instanceof Pe?e.b.clone():e.b,this.c=e.c instanceof Pe?e.c.clone():e.c,this.method=e.method,this}},ze=ht;ze.RAD=Ke.RAD,ze.DEG=Ke.DEG,ze.EXP=Ke.EXP,ze.EXP2=Ke.EXP2,ze.LOG=Ke.LOG,ze.LOG2=Ke.LOG2,ze.SQRT=Ke.SQRT,ze.INV_SQRT=Ke.INV_SQRT,ze.FLOOR=Ke.FLOOR,ze.CEIL=Ke.CEIL,ze.NORMALIZE=Ke.NORMALIZE,ze.FRACT=Ke.FRACT,ze.SATURATE=Ke.SATURATE,ze.SIN=Ke.SIN,ze.COS=Ke.COS,ze.TAN=Ke.TAN,ze.ASIN=Ke.ASIN,ze.ACOS=Ke.ACOS,ze.ARCTAN=Ke.ARCTAN,ze.ABS=Ke.ABS,ze.SIGN=Ke.SIGN,ze.LENGTH=Ke.LENGTH,ze.NEGATE=Ke.NEGATE,ze.INVERT=Ke.INVERT,ze.MIN=Ke.MIN,ze.MAX=Ke.MAX,ze.MOD=Ke.MOD,ze.STEP=Ke.STEP,ze.REFLECT=Ke.REFLECT,ze.DISTANCE=Ke.DISTANCE,ze.DOT=Ke.DOT,ze.CROSS=Ke.CROSS,ze.POW=Ke.POW,ze.MIX=Ke.MIX,ze.CLAMP=Ke.CLAMP,ze.REFRACT=Ke.REFRACT,ze.SMOOTHSTEP=Ke.SMOOTHSTEP,ze.FACEFORWARD=Ke.FACEFORWARD;var As=class extends Be{constructor(e=new Pe,t=new Pe,r=new Pe){super("v4");this.nodeType="TextureCubeUV";this.value=e,this.uv=t,this.bias=r}bilinearCubeUV(e,t,r,n){var f,h,d,x;let s=new pu(As.Nodes.bilinearCubeUV,[t,r,n]);this.colorSpaceTL=(f=this.colorSpaceTL)!=null?f:new zr(new xt("","v4")),this.colorSpaceTL.fromDecoding(e.getTextureEncodingFromMap(this.value.value)),this.colorSpaceTL.input.parse(s.build(e)+".tl"),this.colorSpaceTR=(h=this.colorSpaceTR)!=null?h:new zr(new xt("","v4")),this.colorSpaceTR.fromDecoding(e.getTextureEncodingFromMap(this.value.value)),this.colorSpaceTR.input.parse(s.build(e)+".tr"),this.colorSpaceBL=(d=this.colorSpaceBL)!=null?d:new zr(new xt("","v4")),this.colorSpaceBL.fromDecoding(e.getTextureEncodingFromMap(this.value.value)),this.colorSpaceBL.input.parse(s.build(e)+".bl"),this.colorSpaceBR=(x=this.colorSpaceBR)!=null?x:new zr(new xt("","v4")),this.colorSpaceBR.fromDecoding(e.getTextureEncodingFromMap(this.value.value)),this.colorSpaceBR.input.parse(s.build(e)+".br");let l={include:e.isShader("vertex"),ignoreCache:!0};e.addContext(l),this.colorSpaceTLExp=new xt(this.colorSpaceTL.build(e,"v4"),"v4"),this.colorSpaceTRExp=new xt(this.colorSpaceTR.build(e,"v4"),"v4"),this.colorSpaceBLExp=new xt(this.colorSpaceBL.build(e,"v4"),"v4"),this.colorSpaceBRExp=new xt(this.colorSpaceBR.build(e,"v4"),"v4"),e.removeContext();let c=new xt("mix( mix( cubeUV_TL, cubeUV_TR, cubeUV.f.x ), mix( cubeUV_BL, cubeUV_BR, cubeUV.f.x ), cubeUV.f.y )","v4");return c.keywords.cubeUV_TL=this.colorSpaceTLExp,c.keywords.cubeUV_TR=this.colorSpaceTRExp,c.keywords.cubeUV_BL=this.colorSpaceBLExp,c.keywords.cubeUV_BR=this.colorSpaceBRExp,c.keywords.cubeUV=s,c}generate(e,t){if(e.isShader("fragment")){let r=this.uv,n=this.bias||e.context.roughness,s=new pu(As.Nodes.roughnessToMip,[n]),l=new ze(s,As.Nodes.m0,As.Nodes.cubeUV_maxMipLevel,ze.CLAMP),c=new ze(l,ze.FLOOR),f=new ze(l,ze.FRACT),h=this.bilinearCubeUV(e,this.value,r,c),d=this.bilinearCubeUV(e,this.value,r,new rn(c,new ve(1).setReadonly(!0),rn.ADD)),x=new ze(h,d,f,ze.MIX);return e.format(x.build(e),"v4",t)}else return console.warn("TextureCubeUVNode is not compatible with "+e.shader+" shader."),e.format("vec4( 0.0 )",this.getType(e),t)}copy(e){return super.copy(e),this.uv.copy(e.uv),this.bias.copy(e.bias),this.value.copy(e.value),e.colorSpaceTL?this.colorSpaceTL?this.colorSpaceTL.copy(e.colorSpaceTL):this.colorSpaceTL=e.colorSpaceTL.clone():this.colorSpaceTL=void 0,e.colorSpaceTR?this.colorSpaceTR?this.colorSpaceTR.copy(e.colorSpaceTR):this.colorSpaceTR=e.colorSpaceTR.clone():this.colorSpaceTR=void 0,e.colorSpaceBL?this.colorSpaceBL?this.colorSpaceBL.copy(e.colorSpaceBL):this.colorSpaceBL=e.colorSpaceBL.clone():this.colorSpaceBL=void 0,e.colorSpaceBR?this.colorSpaceBR?this.colorSpaceBR.copy(e.colorSpaceBR):this.colorSpaceBR=e.colorSpaceBR.clone():this.colorSpaceBR=void 0,e.colorSpaceTLExp?this.colorSpaceTLExp?this.colorSpaceTLExp.copy(e.colorSpaceTLExp):this.colorSpaceTLExp=e.colorSpaceTLExp.clone():this.colorSpaceTLExp=void 0,e.colorSpaceTRExp?this.colorSpaceTRExp?this.colorSpaceTRExp.copy(e.colorSpaceTRExp):this.colorSpaceTRExp=e.colorSpaceTRExp.clone():this.colorSpaceTRExp=void 0,e.colorSpaceBLExp?this.colorSpaceBLExp?this.colorSpaceBLExp.copy(e.colorSpaceBLExp):this.colorSpaceBLExp=e.colorSpaceBLExp.clone():this.colorSpaceBLExp=void 0,e.colorSpaceBRExp?this.colorSpaceBRExp?this.colorSpaceBRExp.copy(e.colorSpaceBRExp):this.colorSpaceBRExp=e.colorSpaceBRExp.clone():this.colorSpaceBRExp=void 0,this}},Aa=As;Aa.Nodes=function(){let e=new Ia(`struct TextureCubeUVData {
|
|
25
25
|
vec4 tl;
|
|
26
26
|
vec4 tr;
|
|
27
27
|
vec4 br;
|
|
@@ -86,7 +86,7 @@ function print() { __p += __j.call(arguments, '') }
|
|
|
86
86
|
uv.x -= texelSize;
|
|
87
87
|
vec4 bl = texture2D(envMap, uv);
|
|
88
88
|
return TextureCubeUVData( tl, tr, br, bl, f );
|
|
89
|
-
}`,[e,l,c,t,r,n,s]);f.useKeywords=!1;let h=new it("float r0 1.0",!0),
|
|
89
|
+
}`,[e,l,c,t,r,n,s]);f.useKeywords=!1;let h=new it("float r0 1.0",!0),d=new it("float v0 0.339",!0),x=new it("float m0 -2.0",!0),g=new it("float r1 0.8",!0),w=new it("float v1 0.276",!0),S=new it("float m1 -1.0",!0),D=new it("float r4 0.4",!0),C=new it("float v4 0.046",!0),G=new it("float m4 2.0",!0),B=new it("float r5 0.305",!0),P=new it("float v5 0.016",!0),W=new it("float m5 3.0",!0),M=new it("float r6 0.21",!0),q=new it("float v6 0.0038",!0),E=new it("float m6 4.0",!0),b=[h,d,x,g,w,S,D,C,G,B,P,W,M,q,E],R=new Se(`float roughnessToMip(float roughness) {
|
|
90
90
|
float mip = 0.0;
|
|
91
91
|
if (roughness >= r1) {
|
|
92
92
|
mip = (r0 - roughness) * (m1 - m0) / (r0 - r1) + m0;
|
|
@@ -100,7 +100,7 @@ function print() { __p += __j.call(arguments, '') }
|
|
|
100
100
|
mip = -2.0 * log2(1.16 * roughness);// 1.16 = 1.79^0.25
|
|
101
101
|
}
|
|
102
102
|
return mip;
|
|
103
|
-
}`,b);return{bilinearCubeUV:f,roughnessToMip:R,m0:
|
|
103
|
+
}`,b);return{bilinearCubeUV:f,roughnessToMip:R,m0:x,cubeUV_maxMipLevel:t}}();var Lo=class extends Be{constructor(e){super("v3");this.nodeType="Normal";this.scope=e!=null?e:Lo.VIEW}getShared(){return this.scope===Lo.WORLD}build(e,t,r,n){let s=e.context[this.scope+"Normal"];return s?s.build(e,t,r,n):super.build(e,t,r)}generate(e,t,r,n,s){let l;switch(this.scope){case Lo.VIEW:e.isShader("vertex")?l="transformedNormal":l="geometryNormal";break;case Lo.LOCAL:e.isShader("vertex")?l="objectNormal":(e.requires.normal=!0,l="vObjectNormal");break;case Lo.WORLD:e.isShader("vertex")?l="inverseTransformDirection( transformedNormal, viewMatrix ).xyz":(e.requires.worldNormal=!0,l="vWNormal");break}return e.format(l,this.getType(e),t)}copy(e){return super.copy(e),this.scope=e.scope,this}toJSON(e){let t=this.getJSONNode(e);return t||(t=this.createJSONNode(e),t.scope=this.scope),t.nodeType=this.nodeType,t}fromJSON(e,t){return super.fromJSON(e,t),e.scope&&(this.scope=e.scope),this}},pr=Lo;pr.LOCAL="local",pr.WORLD="world",pr.VIEW="view",pr.NORMAL="normal";tr.addKeyword("viewNormal",function(){return new pr(pr.VIEW)});tr.addKeyword("localNormal",function(){return new pr(pr.NORMAL)});tr.addKeyword("worldNormal",function(){return new pr(pr.WORLD)});var Zn=class extends Be{constructor(e){super("v3");this.nodeType="Position";this.scope=e!=null?e:Zn.LOCAL}getType(){switch(this.scope){case Zn.PROJECTION:return"v4"}return this.type}getShader(){switch(this.scope){case Zn.LOCAL:case Zn.WORLD:return!1}return!0}generate(e,t,r,n,s){let l;switch(this.scope){case Zn.LOCAL:e.isShader("vertex")?l="transformed":(e.requires.position=!0,l="vPosition");break;case Zn.WORLD:if(e.isShader("vertex"))return"( modelMatrix * vec4( transformed, 1.0 ) ).xyz";e.requires.worldPosition=!0,l="vWPosition";break;case Zn.VIEW:l=e.isShader("vertex")?"-mvPosition.xyz":"vViewPosition";break;case Zn.PROJECTION:l=e.isShader("vertex")?"( projectionMatrix * modelViewMatrix * vec4( position, 1.0 ) )":"vec4( 0.0 )";break}return e.format(l,this.getType(),t)}copy(e){return super.copy(e),this.scope=e.scope,this}toJSON(e){let t=this.getJSONNode(e);return t||(t=this.createJSONNode(e),t.scope=this.scope),t.nodeType=this.nodeType,t}fromJSON(e,t){return super.fromJSON(e,t),e.scope&&(this.scope=e.scope),this}},xr=Zn;xr.LOCAL="local",xr.WORLD="world",xr.VIEW="view",xr.PROJECTION="projection";tr.addKeyword("position",function(){return new xr});tr.addKeyword("worldPosition",function(){return new xr(xr.WORLD)});tr.addKeyword("viewPosition",function(){return new xr(xr.VIEW)});var Bn=class extends Be{constructor(e){super("v3");this.nodeType="Reflect";this.scope=e!=null?e:Bn.CUBE}getUnique(e){return!e.context.viewNormal}getType(){switch(this.scope){case Bn.SPHERE:return"v2"}return this.type}generate(e,t){let r=this.getUnique(e);if(e.isShader("fragment")){let n;switch(this.scope){case Bn.VECTOR:{let s=new pr(pr.VIEW),l=e.context.roughness,c=s.build(e,"v3"),f=new xr(xr.VIEW).build(e,"v3"),h=l?l.build(e,"f"):void 0,d=`reflect( -normalize( ${f} ), ${c} )`;h&&(d=`normalize( mix( ${d}, ${c}, ${h} * ${h} ) )`);let x=`inverseTransformDirection( ${d}, viewMatrix )`;r?(e.addNodeCode(`vec3 reflectVec = ${x};`),n="reflectVec"):n=x;break}case Bn.CUBE:{let s=new Bn(Bn.VECTOR).build(e,"v3"),l="vec3( -"+s+".x, "+s+".yz )";r?(e.addNodeCode(`vec3 reflectCubeVec = ${l};`),n="reflectCubeVec"):n=l;break}case Bn.SPHERE:{let s=new Bn(Bn.VECTOR).build(e,"v3"),l="normalize( ( viewMatrix * vec4( "+s+", 0.0 ) ).xyz + vec3( 0.0, 0.0, 1.0 ) ).xy * 0.5 + 0.5";r?(e.addNodeCode(`vec2 reflectSphereVec = ${l};`),n="reflectSphereVec"):n=l;break}}return e.format(n,this.getType(),t)}else return console.warn("ReflectNode is not compatible with "+e.shader+" shader."),e.format("vec3( 0.0 )",this.type,t)}copy(e){return super.copy(e),this.scope=e.scope,this}toJSON(e){let t=this.getJSONNode(e);return t||(t=this.createJSONNode(e),t.scope=this.scope),t.nodeType=this.nodeType,t}fromJSON(e,t){return super.fromJSON(e,t),e.scope&&(this.scope=e.scope),this}},Si=Bn;Si.CUBE="cube",Si.SPHERE="sphere",Si.VECTOR="vector";var rp=class extends Be{constructor(e=new Fr,t,r){super("v4");this.nodeType="TextureCube";this.value=e,this.radianceNode=new Aa(this.value,t!=null?t:new Si(Si.VECTOR),r),this.irradianceNode=new Aa(this.value,new pr(pr.WORLD),new ve(1).setReadonly(!0))}generate(e,t){return e.isShader("fragment")?(e.require("irradiance"),e.context.bias&&e.context.bias.setTexture(this.value),(e.slot==="irradiance"?this.irradianceNode:this.radianceNode).build(e,t)):(console.warn("TextureCubeNode is not compatible with "+e.shader+" shader."),e.format("vec4( 0.0 )",this.getType(e),t))}copy(e){return super.copy(e),this.value.copy(e.value),this.radianceNode.copy(e.radianceNode),this.irradianceNode.copy(e.irradianceNode),this}};import{CubeTexture as dD}from"three";var np=class extends It{constructor(e=new dD,t,r){super("v4",{shared:!0});this.nodeType="CubeTexture";this.value=e,this.uv=t!=null?t:new Si,this.bias=r}getTexture(e,t){return super.generate(e,t,this.value.uuid,"tc")}generate(e,t){var h,d;if(t==="samplerCube")return this.getTexture(e,t);let r=this.getTexture(e,t),n=(h=this.uv)==null?void 0:h.build(e,"v3"),s=this.bias?this.bias.build(e,"f"):void 0;s===void 0&&e.context.bias&&(s=e.context.bias.setTexture(this).build(e,"f"));let l;s?l="texCubeBias( "+r+", "+n+", "+s+" )":l="texCube( "+r+", "+n+" )";let c={include:e.isShader("vertex"),ignoreCache:!0},f=this.getType(e);return e.addContext(c),this.colorSpace=(d=this.colorSpace)!=null?d:new zr(new xt("",f)),this.colorSpace.fromDecoding(e.getTextureEncodingFromMap(this.value)),this.colorSpace.input.parse(l),l=this.colorSpace.build(e,f),e.removeContext(),e.format(l,f,t)}copy(e){return super.copy(e),this.value.copy(e.value),e.uv?this.uv?this.uv.copy(e.uv):this.uv=e.uv.clone():this.uv=void 0,e.bias?this.bias?this.bias.copy(e.bias):this.bias=e.bias.clone():this.bias=void 0,this}};var wv=["x","y","z","w"],vD=["float","vec2","vec3","vec4"],bD={float:"f",vec2:"v2",vec3:"v3",vec4:"v4",mat4:"v4",int:"i",bool:"b","float[]":"f[]","vec4[]":"v4[]"},SD={t:"sampler2D",tc:"samplerCube",b:"bool",i:"int",f:"float",c:"vec3",v2:"vec2",v3:"vec3",v4:"vec4",m3:"mat3",m4:"mat4","f[]":"float[]","v4[]":"vec4[]"},ip=class{constructor(){this.includes={consts:{},functions:{},structs:{}};this.cache="";this.slot="";this.shader="";this.context={};this.getIncludesCode=function(){function e(t,r){return t.deps.length-r.deps.length}return function(r,n){let s=this.getIncludes(r,n);if(!s)return"";let l="";s=s.sort(e);for(let c=0;c<s.length;c++)s[c].src&&(l+=s[c].src+`
|
|
104
104
|
`);return l}}();this.slots=[],this.caches=[],this.contexts=[],this.keywords={},this.nodeData={},this.fragmentVariables={},this.requires={uv:[],color:[],lights:!1,fog:!1,transparent:!1,irradiance:!1,position:!1,worldPosition:!1,normal:!1,worldNormal:!1,vWorldViewDir:!1,modelMatrix:!1,viewMatrix:!1,projectionMatrix:!1},this.includes={consts:[],functions:[],structs:[]},this.attributes={},this.prefixCode=["#ifdef TEXTURE_LOD_EXT"," #define texCube(a, b) textureCube(a, b)"," #define texCubeBias(a, b, c) textureCubeLodEXT(a, b, c)"," #define tex2D(a, b) texture2D(a, b)"," #define tex2DBias(a, b, c) texture2DLodEXT(a, b, c)","#else"," #define texCube(a, b) textureCube(a, b)"," #define texCubeBias(a, b, c) textureCube(a, b, c)"," #define tex2D(a, b) texture2D(a, b)"," #define tex2DBias(a, b, c) texture2D(a, b, c)","#endif",`
|
|
105
105
|
// NOTE: Include Spline's blending modes. This could be part of BlendNode
|
|
106
106
|
#define SPE_BLENDING_NORMAL 0
|
|
@@ -143,10 +143,10 @@ function print() { __p += __j.call(arguments, '') }
|
|
|
143
143
|
`}clearNodeCode(e){e=e!=null?e:this.shader;let t=this.nodeCode[e];return this.nodeCode[e]="",t}clearVertexNodeCode(){return this.clearNodeCode("vertex")}clearFragmentNodeCode(){return this.clearNodeCode("fragment")}addVertexFinalCode(e){this.addFinalCode(e,"vertex")}addFragmentFinalCode(e){this.addFinalCode(e,"fragment")}addFinalCode(e,t){this.finalCode[t!=null?t:this.shader]+=e+`
|
|
144
144
|
`}addVertexParsCode(e){this.addParsCode(e,"vertex")}addFragmentParsCode(e){this.addParsCode(e,"fragment")}addParsCode(e,t){this.parsCode[t!=null?t:this.shader]+=e+`
|
|
145
145
|
`}addVaryCode(e){this.addVertexParsCode(e),this.addFragmentParsCode(e)}isCache(e){return this.caches.indexOf(e)!==-1}isSlot(e){return this.slots.indexOf(e)!==-1}define(e,t){this.defines[e]=t===void 0?1:t}require(e){this.requires[e]=!0}isDefined(e){return this.defines[e]!==void 0}getVar(e,t,r,n="varying",s="V",l=""){let c=this.getVars(n),f=c[e];if(!f){let h=c.length;f={name:r||"node"+s+h+(l?"_"+l:""),type:t},c.push(f),c[e]=f}return f}getTempVar(e,t,r,n){return this.getVar(e,t,r,this.shader,"T",n)}getAttribute(e,t){if(!this.attributes[e]){let r=this.getVar(e,t);this.addVertexParsCode("attribute "+t+" "+e+";"),this.addVertexFinalCode(r.name+" = "+e+";"),this.attributes[e]={varying:r,name:e,type:t}}return this.attributes[e]}getCode(e){return[this.prefixCode,this.parsCode[e],this.getVarListCode(this.getVars("varying"),"varying"),this.getVarListCode(this.inputs.uniforms[e],"uniform"),this.getVarListCode(this.inputs.arrayUniforms[e],"uniform"),this.getIncludesCode("consts",e),this.getIncludesCode("structs",e),this.getIncludesCode("functions",e),"void main() {",this.getVarListCode(this.getVars(e)),this.code[e],this.resultCode[e],this.finalCode[e],"}"].join(`
|
|
146
|
-
`)}getVarListCode(e,t){t=t!=null?t:"";let r="";for(let n=0,s=e.length;n<s;++n){let l=e[n],c=l.type,f=l.name,h=l.size,
|
|
147
|
-
`:r+=t+" "+
|
|
148
|
-
`}return r}getVars(e){return this.inputs.vars[e!=null?e:this.shader]}getNodeData(e){let t=e instanceof Pe?e.uuid:e;return this.nodeData[t]=this.nodeData[t]||{}}createUniform(e,t,r,n,s,l){if(t.includes("[]")){let c=this.inputs.arrayUniforms,f=c.list.length,h=new
|
|
149
|
-
`;return e.isShader("vertex")?r+="gl_Position = "+t.result+";":r+="gl_FragColor = "+t.result+";",r}copy(e){return super.copy(e),this.value.copy(e.value),this}};var vt=class extends It{constructor(e=0,t,r,n){super("c");this.nodeType="Color";this.value=e instanceof tn?e:new tn(e||0,t,r,n)}setRGBA(e){this.value.setRGBA(e.r,e.g,e.b,e.a)}generate(e,t,r,n,s,l){r=e.getUUID(r!=null?r:this.getUUID()),n=n!=null?n:this.getType(e);let c=e.getNodeData(r),f=this.getReadonly()&&this.generateReadonly!==void 0;if(this.alpha){let h=this.alpha.build(e,"f");e.addFragmentNodeCode(`accumAlpha += ( 1.0 - accumAlpha ) * ${h};`)}return f?this.generateReadonly(e,t,r,n,s,l):e.isShader("vertex")?(c.vertex||(c.vertex=e.createVertexUniform(n,this,s,l,this.getLabel())),e.format(c.vertex.name,n,t)):(c.fragment||(c.fragment=e.createFragmentUniform(n,this,s,l,this.getLabel())),e.format(c.fragment.name,n,t))}generateReadonly(e,t,r,n,s,l){return e.format("vec3("+this.value.r+", "+this.value.g+", "+this.value.b+")",n,t)}};import{MathUtils as
|
|
146
|
+
`)}getVarListCode(e,t){t=t!=null?t:"";let r="";for(let n=0,s=e.length;n<s;++n){let l=e[n],c=l.type,f=l.name,h=l.size,d=this.getFormatByType(c);if(d===void 0)throw new Error("Node pars "+d+" not found.");d.includes("[]")?r+=t+" "+d.substring(0,d.length-2)+" "+f+`[${h}];
|
|
147
|
+
`:r+=t+" "+d+" "+f+`;
|
|
148
|
+
`}return r}getVars(e){return this.inputs.vars[e!=null?e:this.shader]}getNodeData(e){let t=e instanceof Pe?e.uuid:e;return this.nodeData[t]=this.nodeData[t]||{}}createUniform(e,t,r,n,s,l){if(t.includes("[]")){let c=this.inputs.arrayUniforms,f=c.list.length,h=new hu({type:t,size:r.size,name:n||"nodeUA"+f+(l?"_"+l:""),node:r,needsUpdate:s});return c.list.push(h),c[e].push(h),c[e][h.name]=h,this.uniforms[h.name]=h,h}else{let c=this.inputs.uniforms,f=c.list.length,h=new hu({type:t,name:n||"nodeU"+f+(l?"_"+l:""),node:r,needsUpdate:s});return c.list.push(h),c[e].push(h),c[e][h.name]=h,this.uniforms[h.name]=h,h}}createVertexUniform(e,t,r,n,s){return this.createUniform("vertex",e,t,r,n,s)}createFragmentUniform(e,t,r,n,s){return this.createUniform("fragment",e,t,r,n,s)}include(e,t,r){var l;let n;if(e=typeof e=="string"?tr.get(e):e,this.context.include===!1)return e.name;e instanceof Se?n=this.includes.functions:e instanceof it?n=this.includes.consts:e instanceof Ia&&(n=this.includes.structs);let s=n[this.shader]=n[this.shader]||[];if(e){let c=s[e.name];if(c||(c=s[e.name]={node:e,deps:[]},s.push(c),c.src=e.build(this,"source")),e instanceof Se&&t&&s[t.name]&&s[t.name].deps.indexOf(e)===-1&&(s[t.name].deps.push(e),(l=e.includes)==null?void 0:l.length)){let f=0;do this.include(e.includes[f++],t);while(f<e.includes.length)}return r&&(c.src=r),e.name}else throw new Error("Include not found.")}colorToVectorProperties(e){return e.replace("r","x").replace("g","y").replace("b","z").replace("a","w")}colorToVector(e){return e.replace(/c/g,"v3")}getIncludes(e,t){return this.includes[e][t||this.shader]}getConstructorFromLength(e){return vD[e-1]}isTypeMatrix(e){return/^m/.test(e)}getTypeLength(e){return e==="f"?1:parseInt(this.colorToVector(e).substr(1))}getTypeFromLength(e){return e===1?"f":"v"+e}findNode(...e){for(let t=0;t<arguments.length;t++){let r=e[t];if(r==null?void 0:r.isNode)return r}}resolve(...e){for(let t=0;t<arguments.length;t++){let r=e[t];if(r!==void 0){if(r.isNode)return r;if(r.isTexture)switch(r.mapping){case mD:case gD:return new np(r);case yD:return new rp(new Fr(r));default:return new Fr(r)}else{if(r.isVector2)return new _r(r);if(r.isVector3)return new Tr(r);if(r.isVector4)return new Ji(r)}}}}format(e,t,r){switch(this.colorToVector(r+" <- "+t)){case"f <- v2":return e+".x";case"f <- v3":return e+".x";case"f <- v4":return e+".x";case"f <- i":case"f <- b":return"float( "+e+" )";case"v2 <- f":return"vec2( "+e+" )";case"v2 <- v3":return e+".xy";case"v2 <- v4":return e+".xy";case"v2 <- i":case"v2 <- b":return"vec2( float( "+e+" ) )";case"v3 <- f":return"vec3( "+e+" )";case"v3 <- v2":return"vec3( "+e+", 0.0 )";case"v3 <- v4":return e+".xyz";case"v3 <- i":case"v3 <- b":return"vec2( float( "+e+" ) )";case"v4 <- f":return"vec4( "+e+" )";case"v4 <- v2":return"vec4( "+e+", 0.0, 1.0 )";case"v4 <- v3":return"vec4( "+e+", 1.0 )";case"v4 <- i":case"v4 <- b":return"vec4( float( "+e+" ) )";case"i <- f":case"i <- b":return"int( "+e+" )";case"i <- v2":return"int( "+e+".x )";case"i <- v3":return"int( "+e+".x )";case"i <- v4":return"int( "+e+".x )";case"b <- f":return"( "+e+" != 0.0 )";case"b <- v2":return"( "+e+" != vec2( 0.0 ) )";case"b <- v3":return"( "+e+" != vec3( 0.0 ) )";case"b <- v4":return"( "+e+" != vec4( 0.0 ) )";case"b <- i":return"( "+e+" != 0 )"}return e}getTypeByFormat(e){return bD[e]||e}getFormatByType(e){return SD[e]||e}getUUID(e,t){return t=t!==void 0?t:!0,t&&this.cache&&(e=this.cache+"-"+e),e}getElementByIndex(e){return wv[e]}getIndexByElement(e){return wv.indexOf(e)}isShader(e){return this.shader===e}setShader(e){return this.shader=e,this}mergeDefines(e){for(let t in e)this.defines[t]=e[t];return this.defines}mergeUniform(e){for(let t in e)this.uniforms[t]=e[t];return this.uniforms}getTextureEncodingFromMap(e){let t;return e?e.isTexture&&(t=e.encoding):t=Sv,t===Sv&&this.context.gamma&&(t=xD),t}};var du=class extends Pe{constructor(e=new Pe){super("v4");this.nodeType="Raw";this.value=e}generate(e){let t=this.value.analyzeAndFlow(e,this.type),r=t.code+`
|
|
149
|
+
`;return e.isShader("vertex")?r+="gl_Position = "+t.result+";":r+="gl_FragColor = "+t.result+";",r}copy(e){return super.copy(e),this.value.copy(e.value),this}};var vt=class extends It{constructor(e=0,t,r,n){super("c");this.nodeType="Color";this.value=e instanceof tn?e:new tn(e||0,t,r,n)}setRGBA(e){this.value.setRGBA(e.r,e.g,e.b,e.a)}generate(e,t,r,n,s,l){r=e.getUUID(r!=null?r:this.getUUID()),n=n!=null?n:this.getType(e);let c=e.getNodeData(r),f=this.getReadonly()&&this.generateReadonly!==void 0;if(this.alpha){let h=this.alpha.build(e,"f");e.addFragmentNodeCode(`accumAlpha += ( 1.0 - accumAlpha ) * ${h};`)}return f?this.generateReadonly(e,t,r,n,s,l):e.isShader("vertex")?(c.vertex||(c.vertex=e.createVertexUniform(n,this,s,l,this.getLabel())),e.format(c.vertex.name,n,t)):(c.fragment||(c.fragment=e.createFragmentUniform(n,this,s,l,this.getLabel())),e.format(c.fragment.name,n,t))}generateReadonly(e,t,r,n,s,l){return e.format("vec3("+this.value.r+", "+this.value.g+", "+this.value.b+")",n,t)}};import{MathUtils as wi,Vector2 as Ki,Vector3 as Xi,Vector4 as _u}from"three";import{Texture as wD}from"three";var Ye=class extends It{constructor(e){super("i");this.nodeType="Int";this.value=Math.floor(e!=null?e:0)}generateReadonly(e,t,r,n,s,l){return e.format(this.value.toString(),n,t)}copy(e){return super.copy(e),this.value=e.value,this}};var qe;(function(D){D.POSITION="position",D.LIGHTING="light",D.COLOR="color",D.GRADIENT="gradient",D.NORMAL="normal",D.DEPTH="depth",D.TEXTURE="texture",D.NOISE="noise",D.FRESNEL="fresnel",D.RAINBOW="rainbow",D.TRANSMISSION="transmission",D.POINTS="points",D.MATCAP="matcap",D.LINES="lines",D.DISPLACE="displace"})(qe||(qe={}));var Mt;(function(r){r.POSITION="position",r.LIGHTING="light",r.COLOR="color"})(Mt||(Mt={}));var Bt=class{constructor(e,t,r,n){this.next=void 0;this.uniforms={};this.textures={};this.defines={};if(this.id=e,this.uuid=t,r){this.type=r.type;for(let s in r)s!=="type"&&s!=="calpha"&&(this.uniforms[`f${this.id}_${s}`]=r[s]);for(let s in n)this.defines[s]=n[s]}}copy(e){this.id=e.id,this.type=e.type,this.defines=U({},e.defines);for(let t in e.uniforms)this.getName(t)==="transmissionSamplerMap"||this.getName(t)==="transmissionDepthMap"||(this.uniforms[t]?this.uniforms[t].copy(e.uniforms[t]):this.uniforms[t]=e.uniforms[t].clone());return this}clone(){return new Bt(this.id).copy(this)}fromJSON(e,t){this.id=e.id,this.defines=U({},e.defines);for(let r in e.uniforms)this.uniforms[r]=t.getNode(e.uniforms[r]);if(e.type===qe.TEXTURE){if(!(`f${this.id}_textureSize`in this.uniforms)){let r=this.uniforms[`f${this.id}_texture`].value.image;this.uniforms[`f${e.id}_textureSize`]=new Tr(r.width,r.height)}`f${this.id}_size`in this.uniforms||(this.uniforms[`f${e.id}_size`]=new _r(200,200)),`f${e.id}_axis`in this.uniforms||(this.uniforms[`f${e.id}_axis`]=new Ye(0)),`f${e.id}_projection`in this.uniforms||(this.uniforms[`f${e.id}_projection`]=new Ye(0))}else e.type===qe.NOISE?(`f${e.id}_noiseType`in this.uniforms||(this.uniforms[`f${e.id}_noiseType`]=new Ye(0)),`f${e.id}_size`in this.uniforms||(this.uniforms[`f${e.id}_size`]=new Tr(-1,-1,-1))):e.type===qe.DEPTH&&(`f${e.id}_isWorldSpace`in this.uniforms||(this.uniforms[`f${e.id}_isWorldSpace`]=new ve(1)));return this}toJSON(e){let t={};for(let n in this.uniforms)t[n]=this.uniforms[n].toJSON(e).uuid;return{id:this.id,type:this.type,defines:JSON.parse(JSON.stringify(this.defines)),uniforms:t,next:this.next==null?void 0:this.next.toJSON(e)}}copyUniforms(e){for(let t in this.uniforms){let r=this.getName(t);r!==void 0&&e.uniforms[`f${e.id}_${r}`]&&r!=="transmissionDepthMap"&&r!=="transmissionSamplerMap"&&this.uniforms[t].copy(e.uniforms[`f${e.id}_${r}`])}return this}hasValueByKey(e){return this.uniforms[e]!==void 0}hasValue(e){return this.hasValueByKey(`f${this.id}_${e}`)}setValue(e,t){let r=`f${this.id}_${e}`;this.hasValueByKey(r)&&t!==void 0&&(this.uniforms[r].value=t)}getValue(e){let t=`f${this.id}_${e}`;if(this.hasValueByKey(t))return this.uniforms[t].value}getValues(){let e={type:this.type};for(let t in this.uniforms){let r=this.getName(t);if(r===void 0)continue;let s=this.uniforms[`f${this.id}_${r}`].value;s!==void 0&&(Array.isArray(s)?e[r]=s.map(l=>l.clone?l.clone():l):e[r]=s.clone?s.clone():s)}return e}getName(e){let r=/f\d+_(.*)/.exec(e);if(r&&r.length>1)return r[1];console.log(`Layer.getName: error ${e}`)}getNames(){let e=[];for(let t in this.uniforms){let r=this.getName(t);r&&e.push(r)}return e}isEqual(e){for(let t in e.uniforms){let r=e.getName(t);if(!r)return!1;let n=this.getValue(r),s=e.uniforms[t].value;if(s.value instanceof wD){if(n.image!==s.image)return!1}else if(Array.isArray(s)){let l=n;for(let c=0,f=l.length;c<f;++c)if(l[c]!==s[c])return!1}else{let l=n;if(l.equals){if(!l.equals(s))return!1}else if(n!==s)return!1}}return!0}dispose(){}};function Nv(i){let e=i instanceof Bt?i.type:i;return e==="texture"||e==="displace_map"||e==="matcap"}var mu=class extends It{constructor(e){super("b");this.nodeType="Bool";this.value=e!=null?e:!1}generateReadonly(e,t,r,n){return e.format(this.value?"true":"false",n,t)}copy(e){return super.copy(e),this.value=e.value,this}};import{Vector4 as Cv}from"three";var Os=class extends It{constructor(e=1,t){super("v4[]");this.nodeType="Vector4Array";this.size=e,this.value=Array.isArray(t)?t:t instanceof Cv?new Array(e).fill(t):new Array(e).fill(new Cv(0))}copy(e){return super.copy(e),this.value=e.value.map(t=>t.clone()),this}};var Ps=class extends It{constructor(e=1,t){super("f[]");this.nodeType="FloatArray";this.size=e,this.value=Array.isArray(t)?t:typeof t=="number"?new Array(e).fill(t):new Array(e).fill(0)}copy(e){return super.copy(e),this.size=e.size,this.value=[...e.value],this}};import{Matrix3 as ND}from"three";var Oa=class extends It{constructor(e){super("m3");this.nodeType="Matrix3";this.value=e!=null?e:new ND}generateReadonly(e,t,r,n,s,l){return e.format("mat3("+this.value.elements.join(", ")+")",n,t)}copy(e){return super.copy(e),this.elements=e.elements,this}get elements(){return this.value.elements}set elements(e){this.value.fromArray(e)}};var Ds;(function(n){n[n.UV=0]="UV",n[n.PLANAR=1]="PLANAR",n[n.SPHERICAL=2]="SPHERICAL",n[n.CYLINDRICAL=3]="CYLINDRICAL"})(Ds||(Ds={}));var Pa=class extends Be{constructor(e=new Fr,t,r,n,s,l,c,f){super("v3");this.nodeType="CustomTexture";this.firstTime=!0,this.texture=e,this.textureSize=t,this.crop=r,this.projection=n,this.axis=s,this.size=l,this.mat=new Oa(this.texture.value.matrix),this.alpha=c,this.mode=f,this.calpha=`g${this.uuid.toString().replace(/-/g,"")}_calpha`}generate(e,t){e.require("position"),e.require("uv"),e.requires.uv=[!0],e.extensions.shaderTextureLOD=!0,e.extensions.derivatives=!0;let r;switch(this.projection.value){case 3:r=e.include(Pa.Nodes.cylindrical);break;case 2:r=e.include(Pa.Nodes.spherical);break;case 1:let s=new Se(`
|
|
150
150
|
vec3 g${this.uuid.toString().replace(/-/g,"")}_planarTexture(sampler2D tex, vec2 textureSize, float crop, mat3 mat, vec2 size, float alpha, int mode, out float calpha) {
|
|
151
151
|
|
|
152
152
|
vec2 uvs = ( mat * vec3( (g${this.uuid.toString().replace(/-/g,"")}_vCustomUv * 2. - 1.) / (size * .5), 1. ) / 2. + 0.5 ).xy;
|
|
@@ -163,7 +163,7 @@ function print() { __p += __j.call(arguments, '') }
|
|
|
163
163
|
calpha = lalpha / clamp( lalpha + accumAlpha, 0.00001, 1.0 );
|
|
164
164
|
accumAlpha += ( 1.0 - accumAlpha ) * lalpha;
|
|
165
165
|
return col;
|
|
166
|
-
}`);r=e.include(s);break;default:r=e.include(
|
|
166
|
+
}`);r=e.include(s);break;default:r=e.include(Pa.Nodes.uv);break}if(this.projection.value===1&&this.firstTime){let s=`g${this.uuid.toString().replace(/-/g,"")}`;e.addVertexParsCode(`varying vec2 ${s}_vCustomUv;`),e.addFragmentParsCode(`varying vec2 ${s}_vCustomUv;`),e.addVertexFinalCode(`
|
|
167
167
|
vec3 ${s}_posN = transformed;
|
|
168
168
|
${this.axis.value===0?`
|
|
169
169
|
float ${s}_u = (1. + (${s}_posN.z)) / 2.;
|
|
@@ -181,7 +181,7 @@ ${this.axis.value===2?`
|
|
|
181
181
|
`:""}
|
|
182
182
|
|
|
183
183
|
${s}_vCustomUv = vec2(${s}_u, ${s}_v);
|
|
184
|
-
`)}e.addFragmentVariable(this.calpha,"float");let n=[];return n.push(this.texture.getTexture(e,"t")),n.push(this.textureSize.build(e,"v2")),n.push(this.crop.build(e,"f")),n.push(this.mat.build(e,"mat3")),n.push(this.size.build(e,"v2")),n.push(this.alpha.build(e,"f")),n.push(this.mode.build(e,"i")),n.push(this.calpha),this.firstTime=!this.firstTime,e.format(r+"("+n.join(",")+")",this.getType(e),t)}copy(e){return super.copy(e),this.texture.copy(e.texture),this.textureSize=e.textureSize.clone(),this.crop=e.crop.clone(),this.projection=e.projection.clone(),this.axis=e.axis.clone(),this.size=e.size.clone(),this.alpha=e.alpha.clone(),this.mode=e.mode.clone(),this}},
|
|
184
|
+
`)}e.addFragmentVariable(this.calpha,"float");let n=[];return n.push(this.texture.getTexture(e,"t")),n.push(this.textureSize.build(e,"v2")),n.push(this.crop.build(e,"f")),n.push(this.mat.build(e,"mat3")),n.push(this.size.build(e,"v2")),n.push(this.alpha.build(e,"f")),n.push(this.mode.build(e,"i")),n.push(this.calpha),this.firstTime=!this.firstTime,e.format(r+"("+n.join(",")+")",this.getType(e),t)}copy(e){return super.copy(e),this.texture.copy(e.texture),this.textureSize=e.textureSize.clone(),this.crop=e.crop.clone(),this.projection=e.projection.clone(),this.axis=e.axis.clone(),this.size=e.size.clone(),this.alpha=e.alpha.clone(),this.mode=e.mode.clone(),this}},gu=Pa;gu.Nodes=function(){let e=new Se(`
|
|
185
185
|
vec3 cylindricalTexture(sampler2D tex, vec2 textureSize, float crop, mat3 mat, vec2 size, float alpha, int mode, out float calpha) {
|
|
186
186
|
vec3 posN = normalize(position);
|
|
187
187
|
float u = 0.5 + atan(posN.z, posN.x) / (2.*3.1415);
|
|
@@ -255,14 +255,14 @@ vec3 sphericalTexture(sampler2D tex, vec2 textureSize, float crop, mat3 mat, vec
|
|
|
255
255
|
calpha = lalpha / clamp( lalpha + accumAlpha, 0.00001, 1.0 );
|
|
256
256
|
accumAlpha += ( 1.0 - accumAlpha ) * lalpha;
|
|
257
257
|
return col;
|
|
258
|
-
}`);return{cylindrical:e,spherical:t,uv:r}}();var
|
|
258
|
+
}`);return{cylindrical:e,spherical:t,uv:r}}();var op=class extends Be{constructor(e,t,r,n,s,l,c){super("v3");this.nodeType="Fresnel";this.color=e,this.bias=t,this.scale=r,this.intensity=n,this.factor=s,this.alpha=l,this.mode=c,this.calpha=`g${this.uuid.toString().replace(/-/g,"")}_calpha`}generate(e,t){if(e.require("vWorldViewDir"),e.require("worldNormal"),e.isShader("fragment")){e.addFragmentVariable(this.calpha,"float");let r=e.include(op.Nodes.fresnel),n=[];return n.push(this.color.build(e,"c")),n.push(this.bias.build(e,"f")),n.push(this.scale.build(e,"f")),n.push(this.intensity.build(e,"f")),n.push(this.factor.build(e,"f")),n.push(this.alpha.build(e,"f")),n.push(this.mode.build(e,"i")),n.push(this.calpha),e.format(r+"("+n.join(",")+")",this.getType(e),t)}else return console.warn("FresnelNode is not compatible with "+e.shader+" shader."),e.format("vec3( 0.0 )",this.getType(e),t)}copy(e){return super.copy(e),this.color=e.color.clone(),this.bias=e.bias.clone(),this.scale=e.scale.clone(),this.intensity=e.intensity.clone(),this.factor=e.factor.clone(),this.alpha=e.alpha.clone(),this.mode=e.mode.clone(),this.calpha=e.calpha,this}},yu=op;yu.Nodes=function(){return{fresnel:new Se(`vec3 fresnel(vec3 color, float bias, float scale, float intensity, float factor, float alpha, int mode, out float calpha) {
|
|
259
259
|
float fresnel = bias + scale * pow( abs( factor + dot( normalize( vWorldViewDir ), normalize( vWNormal ) ) ), intensity );
|
|
260
260
|
|
|
261
261
|
float lalpha = clamp( fresnel, 0.0, 1.0 ) * alpha;
|
|
262
262
|
calpha = lalpha / clamp(lalpha + accumAlpha, 0.001, 1.0);
|
|
263
263
|
accumAlpha += (1.0 - accumAlpha) * lalpha;
|
|
264
264
|
return color;
|
|
265
|
-
}`)}}();var
|
|
265
|
+
}`)}}();var Bs;(function(s){s.SIMPLEX="simplex3d",s.SIMPLEX_FRACTAL="simplex3dFractal",s.ASHIMA="simplexAshima",s.FBM="fbm",s.PERLIN="perlin"})(Bs||(Bs={}));var Vr=function(){let i=5,e=new Se(`vec3 random3(vec3 c) {
|
|
266
266
|
float j = 4096.0*sin(dot(c,vec3(17.0, 59.4, 15.0)));
|
|
267
267
|
vec3 r;
|
|
268
268
|
r.z = fract(512.0*j);
|
|
@@ -370,7 +370,7 @@ vec3 sphericalTexture(sampler2D tex, vec2 textureSize, float crop, mat3 mat, vec
|
|
|
370
370
|
vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);
|
|
371
371
|
vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);
|
|
372
372
|
return o4.y * d.y + o4.x * (1.0 - d.y);
|
|
373
|
-
}`,[f]),
|
|
373
|
+
}`,[f]),d=new Se(`float fbm(vec3 x) {
|
|
374
374
|
float v = 0.0;
|
|
375
375
|
float a = 0.5;
|
|
376
376
|
vec3 shift = vec3(100);
|
|
@@ -380,7 +380,7 @@ vec3 sphericalTexture(sampler2D tex, vec2 textureSize, float crop, mat3 mat, vec
|
|
|
380
380
|
a *= 0.5;
|
|
381
381
|
}
|
|
382
382
|
return v;
|
|
383
|
-
}`,[h]);
|
|
383
|
+
}`,[h]);d.keywords.NUM_OCTAVES=new it(`int NUM_OCTAVES ${i}`);let x=new Se("vec3 fade(vec3 t) {return t*t*t*(t*(t*6.0-15.0)+10.0);}"),g=new Se(`float perlin(vec3 P){
|
|
384
384
|
vec3 Pi0 = floor(P);
|
|
385
385
|
vec3 Pi1 = Pi0 + vec3(1.0);
|
|
386
386
|
Pi0 = mod(Pi0, 289.0);
|
|
@@ -439,7 +439,7 @@ vec3 sphericalTexture(sampler2D tex, vec2 textureSize, float crop, mat3 mat, vec
|
|
|
439
439
|
vec2 n_yz = mix(n_z.xy, n_z.zw, fade_xyz.y);
|
|
440
440
|
float n_xyz = mix(n_yz.x, n_yz.y, fade_xyz.x);
|
|
441
441
|
return 2.2 * n_xyz;
|
|
442
|
-
}`,[n,s,
|
|
442
|
+
}`,[n,s,x]);return{simplex:t,simplexFractal:r,simplexAshima:l,fbm:d,perlin:g}}();var sp=class extends Be{constructor(e,t,r,n,s,l,c){super("v3");this.nodeType="Rainbow";this.filmThickness=e,this.movement=t,this.wavelengths=r,this.noiseStrength=n,this.noiseScale=s,this.offset=l,this.alpha=c,this.calpha=`g${this.uuid.toString().replace(/-/g,"")}_calpha`}generate(e,t){if(e.require("vWorldViewDir"),e.require("worldNormal"),e.isShader("fragment")){e.require("uv"),e.requires.uv=[!0],e.addFragmentVariable(this.calpha,"float");let r=e.include(sp.Nodes.rainbow),n=[];return n.push(this.filmThickness.build(e,"f")),n.push(this.movement.build(e,"f")),n.push(this.wavelengths.build(e,"v3")),n.push(this.noiseStrength.build(e,"f")),n.push(this.noiseScale.build(e,"f")),n.push(this.offset.build(e,"v3")),n.push(this.alpha.build(e,"f")),n.push(this.calpha),e.format(r+"("+n.join(",")+")",this.getType(e),t)}else return console.warn("RainbowNode is not compatible with "+e.shader+" shader."),e.format("vec3( 0.0 )",this.getType(e),t)}copy(e){return super.copy(e),this.filmThickness=e.filmThickness.clone(),this.movement=e.movement.clone(),this.wavelengths=e.wavelengths.clone(),this.noiseStrength=e.noiseStrength.clone(),this.noiseScale=e.noiseScale.clone(),this.offset=e.offset.clone(),this.alpha=e.alpha.clone(),this.calpha=e.calpha,this}},xu=sp;xu.Nodes=function(){let e=new Se(`vec3 attenuation(vec3 wavelengths, float filmThickness, float movement, float noiseStrength, float noiseScale, vec3 offset) {
|
|
443
443
|
vec3 st = position / noiseScale;
|
|
444
444
|
vec3 q = vec3(simplex3d(st),
|
|
445
445
|
simplex3d(st + vec3(1.0)),
|
|
@@ -461,7 +461,7 @@ vec3 sphericalTexture(sampler2D tex, vec2 textureSize, float crop, mat3 mat, vec
|
|
|
461
461
|
accumAlpha += ( 1.0 - accumAlpha ) * lalpha;
|
|
462
462
|
|
|
463
463
|
return res;
|
|
464
|
-
}`,[e])}}();var
|
|
464
|
+
}`,[e])}}();var ap=class extends Be{constructor(e,t,r,n,s,l,c,f){super("v3");this.nodeType="Transmission";this.thickness=e,this.ior=t,this.roughness=r,this.transmissionSamplerSize=n,this.transmissionSamplerMap=s,this.transmissionDepthMap=l,this.aspectRatio=c,this.alpha=f,this.calpha=`g${this.uuid.toString().replace(/-/g,"")}_calpha`}generate(e,t){if(e.extensions.shaderTextureLOD=!0,e.extensions.derivatives=!0,e.isShader("fragment")){e.define("NUM_SAMPLES",30),e.require("worldPosition"),e.requires.worldNormal=!0,e.requires.modelMatrix=!0,e.requires.projectionMatrix=!0,e.addFragmentVariable(this.calpha,"float");let r=e.include(ap.Nodes.transmission),n=[];return n.push(this.thickness.build(e,"f")),n.push(this.ior.build(e,"f")),n.push(this.roughness.build(e,"f")),n.push(this.transmissionSamplerSize.build(e,"v2")),n.push(this.transmissionSamplerMap.getTexture(e,"t")),n.push(this.transmissionDepthMap.getTexture(e,"t")),n.push(this.aspectRatio.build(e,"v2")),n.push("normal"),n.push(this.alpha.build(e,"f")),n.push(this.calpha),e.format(r+"("+n.join(",")+")",this.getType(e),t)}else return console.warn("TransmissionNode is not compatible with "+e.shader+" shader."),e.format("vec3( 0.0 )",this.getType(e),t)}copy(e){return super.copy(this),this.thickness=e.thickness.clone(),this.ior=e.ior.clone(),this.roughness=e.roughness.clone(),this.transmissionSamplerSize=e.transmissionSamplerSize.clone(),this.transmissionSamplerMap=e.transmissionSamplerMap,this.transmissionDepthMap=e.transmissionDepthMap,this.alpha=e.alpha.clone(),this.calpha=e.calpha,this}},vu=ap;vu.Nodes=function(){let e=new Se(`
|
|
465
465
|
float gaussian(vec2 i) {
|
|
466
466
|
const float sigma = float(NUM_SAMPLES) * .25;
|
|
467
467
|
return exp( -.5* dot(i/=sigma,i) ) / ( 6.28 * sigma*sigma );
|
|
@@ -548,14 +548,14 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
548
548
|
calpha = lalpha / clamp( lalpha + accumAlpha, 0.00001, 1.0 );
|
|
549
549
|
accumAlpha += ( 1.0 - accumAlpha ) * lalpha;
|
|
550
550
|
return transmission.rgb;
|
|
551
|
-
}`,[l])}}();var
|
|
551
|
+
}`,[l])}}();var lp=class extends Be{constructor(e,t){super("v3");this.nodeType="CustomNormal";this.cnormal=e,this.alpha=t}generate(e,t){if(e.isShader("fragment")){let r=e.include(lp.Nodes.customNormal),n=[];return n.push(this.cnormal.build(e,"v3")),n.push("normal"),n.push(this.alpha.build(e,"f")),e.format(r+"("+n.join(",")+")",this.getType(e),t)}else return console.warn("CustomNormalNode is not compatible with "+e.shader+" shader."),e.format("vec3( 0.0 )",this.getType(e),t)}copy(e){return super.copy(e),this.cnormal.copy(e.cnormal),this.alpha.copy(e.alpha),this}},bu=lp;bu.Nodes=function(){return{customNormal:new Se(`vec3 customNormal(vec3 cnormal, vec3 norm, float alpha) {
|
|
552
552
|
vec3 normal = packNormalToRGB( norm ).rgb;
|
|
553
553
|
normal *= step( vec3(0.5), cnormal );
|
|
554
554
|
|
|
555
555
|
accumAlpha += ( 1.0 - accumAlpha ) * alpha;
|
|
556
556
|
|
|
557
557
|
return normal;
|
|
558
|
-
}`)}}();var
|
|
558
|
+
}`)}}();var cp=class extends Be{constructor(e,t,r,n,s,l,c,f){super("v3");this.nodeType="Gradient";this.gradientType=e,this.smooth=t,this.colors=r,this.steps=n,this.offset=s,this.morph=l,this.angle=c,this.alpha=f,this.calpha=`g${this.uuid.toString().replace(/-/g,"")}_calpha`}generate(e,t){if(e.isShader("fragment")){e.define("GRAD_MAX",10),e.require("uv"),e.requires.uv=[!0],e.addFragmentVariable(this.calpha,"float");let r=e.include(cp.Nodes.gradient),n=[];return n.push(this.gradientType.build(e,"i")),n.push(this.smooth.build(e,"b")),n.push(this.colors.build(e,"v4[]")),n.push(this.steps.build(e,"f[]")),n.push(this.offset.build(e,"v2")),n.push(this.morph.build(e,"v2")),n.push(this.angle.build(e,"f")),n.push(this.alpha.build(e,"f")),n.push(this.calpha),e.format(r+"("+n.join(",")+")",this.getType(e),t)}else return console.warn("GradientNode is not compatible with "+e.shader+" shader."),e.format("vec3( 0.0 )",this.getType(e),t)}copy(e){return super.copy(e),this.gradientType=e.gradientType.clone(),this.smooth=e.smooth.clone(),this.colors=e.colors.clone(),this.steps=e.steps.clone(),this.offset=e.offset.clone(),this.morph=e.morph.clone(),this.angle=e.angle.clone(),this.alpha=e.alpha.clone(),this.calpha=e.calpha,this}},Su=cp;Su.Nodes=function(){return{gradient:new Se(`vec3 gradient(int gradientType, bool smoothed, vec4 colors[GRAD_MAX], float steps[GRAD_MAX], vec2 offset, vec2 morph, float angle, float alpha, out float calpha) {
|
|
559
559
|
vec4 color = colors[0];
|
|
560
560
|
vec2 m = morph / vUv.xy;
|
|
561
561
|
vec2 rot = vec2( 0.5 + m.x, m.y );
|
|
@@ -597,7 +597,7 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
597
597
|
accumAlpha += ( 1.0 - accumAlpha ) * lalpha;
|
|
598
598
|
|
|
599
599
|
return color.xyz;
|
|
600
|
-
}`)}}();var
|
|
600
|
+
}`)}}();var _o;(function(t){t.NOISE="noise",t.MAP="map"})(_o||(_o={}));var up=class extends Be{constructor(e=new Ye(0),t,r,n,s,l){super("v3");this.nodeType="VertexDisplacement";this.displacementTypeIndex=e,this.intensity=t,this.movementOrTexture=r,Object.values(_o)[this.displacementTypeIndex.value]===_o.MAP&&(this.mat=new Oa(this.movementOrTexture.value.matrix)),this.cropOrOffset=n,this.scale=s,this.noiseFunctionIndex=l}generate(e,t){if(e.isShader("vertex")){e.define("USE_LAYER_DISPLACE");let r,n=[];switch(n.push("displaced_position"),n.push("displaced_normal"),Object.values(_o)[this.displacementTypeIndex.value]){case _o.MAP:{r=e.include(up.Nodes.map),n.push(this.movementOrTexture.getTexture(e,"t")),n.push("uv"),n.push(this.cropOrOffset.build(e,"f")),this.mat&&n.push(this.mat.build(e,"mat3"));break}case _o.NOISE:{let l=Object.values(Bs)[this.noiseFunctionIndex.value],c=new Se(`vec3 orthogonal(vec3 v) {
|
|
601
601
|
return normalize(abs(v.x) > abs(v.z) ? vec3(-v.y, v.x, 0.0) : vec3(0.0, -v.z, v.y));
|
|
602
602
|
}`),f=new Se(`vec3 distorted(vec3 p, vec3 n, float scale, float intensity, vec3 offset, float neighbour_offset, float movement) {
|
|
603
603
|
return p + n * ${l}((p + offset) * scale * 0.001 + neighbour_offset + (movement * 0.1)) * intensity;
|
|
@@ -617,7 +617,7 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
617
617
|
vec3 distorted2 = distorted(nearby2, normal, scale, intensity, offset, neighbor_offset, movement);
|
|
618
618
|
displaced_normal = normalize(cross(distorted1 - displaced_position, distorted2 - displaced_position));
|
|
619
619
|
return displaced_position;
|
|
620
|
-
}`,[f,c]);r=e.include(h),n.push(this.scale.build(e,"f")),n.push(this.cropOrOffset.build(e,"v3")),n.push(this.movementOrTexture.build(e,"f"));break}}return n.push(this.intensity.build(e,"f")),n.push("displaced_normal"),e.format(r+"("+n.join(",")+")",this.getType(e),t)}else return console.warn("VertexDisplacementNode is not compatible with "+e.shader+" shader."),e.format("vec3( 0.0 )",this.getType(e),t)}copy(e){var t,r;return super.copy(e),this.noiseFunctionIndex=(t=e.noiseFunctionIndex)==null?void 0:t.clone(),this.scale=(r=e.scale)==null?void 0:r.clone(),this.cropOrOffset=e.cropOrOffset.clone(),this.intensity=e.intensity.clone(),this.movementOrTexture=e.movementOrTexture.clone(),this}},
|
|
620
|
+
}`,[f,c]);r=e.include(h),n.push(this.scale.build(e,"f")),n.push(this.cropOrOffset.build(e,"v3")),n.push(this.movementOrTexture.build(e,"f"));break}}return n.push(this.intensity.build(e,"f")),n.push("displaced_normal"),e.format(r+"("+n.join(",")+")",this.getType(e),t)}else return console.warn("VertexDisplacementNode is not compatible with "+e.shader+" shader."),e.format("vec3( 0.0 )",this.getType(e),t)}copy(e){var t,r;return super.copy(e),this.noiseFunctionIndex=(t=e.noiseFunctionIndex)==null?void 0:t.clone(),this.scale=(r=e.scale)==null?void 0:r.clone(),this.cropOrOffset=e.cropOrOffset.clone(),this.intensity=e.intensity.clone(),this.movementOrTexture=e.movementOrTexture.clone(),this}},Da=up;Da.Nodes=function(){let e=new Se(`vec3 orthogonal(vec3 v) {
|
|
621
621
|
return normalize(abs(v.x) > abs(v.z) ? vec3(-v.y, v.x, 0.0) : vec3(0.0, -v.z, v.y));
|
|
622
622
|
}`),t=new Se(`float displacementMapTexture(sampler2D tex, float crop, vec2 uv, mat3 mat, vec2 offset) {
|
|
623
623
|
vec2 uvs = (mat * vec3(uv * 2.0 - 1.0, 1.0) / 2.0 + 0.5).xy + offset;
|
|
@@ -639,7 +639,7 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
639
639
|
vec3 distorted2 = nearby2 + normal * displacementMapTexture(tex, crop, uv, mat, vec2(neighbor_offset)) * intensity;
|
|
640
640
|
displaced_normal = normalize(cross(distorted1 - displaced_position, distorted2 - displaced_position));
|
|
641
641
|
return displaced_position;
|
|
642
|
-
}`,[e,t])}}();var
|
|
642
|
+
}`,[e,t])}}();var wu=class extends Be{constructor(e=new Pe,t=new Pe,r=new Pe,n=new Pe,s=new Pe,l=new Pe,c=new Pe,f=new Pe,h=new Pe,d=new Pe,x=new Pe,g=new Pe){super("v3");this.nodeType="Noise";this.scale=e,this.size=t,this.move=r,this.fA=n,this.fB=s,this.distortion=l,this.colorA=c,this.colorB=f,this.colorC=h,this.colorD=d,this.alpha=x,this.noiseType=g,this.calpha=`g${this.uuid.toString().replace(/-/g,"")}_calpha`}generate(e,t,r,n,s){e.require("uv"),e.requires.uv=[!0],e.addFragmentVariable(this.calpha,"float");let l=Object.values(Bs)[this.noiseType.value],c=new Se(`vec3 ${l}customNoise(float scale, vec3 size, float move, vec2 fA, vec2 fB, vec2 distortion, vec4 colorA, vec4 colorB, vec4 colorC, vec4 colorD, float alpha, out float calpha) {
|
|
643
643
|
vec3 st = position / size;
|
|
644
644
|
st /= scale;
|
|
645
645
|
vec3 q = vec3(${l}(st),
|
|
@@ -659,7 +659,7 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
659
659
|
|
|
660
660
|
accumAlpha += ( 1.0 - accumAlpha ) * lalpha;
|
|
661
661
|
return clamp(color, 0.0, 1.0).rgb;
|
|
662
|
-
}`,[Vr.simplex,Vr.simplexFractal,Vr.simplexAshima,Vr.fbm,Vr.perlin]),f=e.include(c),h=[];return h.push(this.scale.build(e,"f")),h.push(this.size.build(e,"v3")),h.push(this.move.build(e,"f")),h.push(this.fA.build(e,"v2")),h.push(this.fB.build(e,"v2")),h.push(this.distortion.build(e,"v2")),h.push(this.colorA.build(e,"v4")),h.push(this.colorB.build(e,"v4")),h.push(this.colorC.build(e,"v4")),h.push(this.colorD.build(e,"v4")),h.push(this.alpha.build(e,"f")),h.push(this.calpha),e.format(f+"("+h.join(",")+")",this.getType(e),t)}copy(e){return super.copy(e),this.scale.copy(e.scale),this.size.copy(e.size),this.move.copy(e.move),this.fA.copy(e.fA),this.fB.copy(e.fB),this.distortion.copy(e.distortion),this.colorA.copy(e.colorA),this.colorB.copy(e.colorB),this.colorC.copy(e.colorC),this.colorD.copy(e.colorD),this.alpha.copy(e.alpha),this.calpha=e.calpha,this.noiseType.copy(e.noiseType),this}};
|
|
662
|
+
}`,[Vr.simplex,Vr.simplexFractal,Vr.simplexAshima,Vr.fbm,Vr.perlin]),f=e.include(c),h=[];return h.push(this.scale.build(e,"f")),h.push(this.size.build(e,"v3")),h.push(this.move.build(e,"f")),h.push(this.fA.build(e,"v2")),h.push(this.fB.build(e,"v2")),h.push(this.distortion.build(e,"v2")),h.push(this.colorA.build(e,"v4")),h.push(this.colorB.build(e,"v4")),h.push(this.colorC.build(e,"v4")),h.push(this.colorD.build(e,"v4")),h.push(this.alpha.build(e,"f")),h.push(this.calpha),e.format(f+"("+h.join(",")+")",this.getType(e),t)}copy(e){return super.copy(e),this.scale.copy(e.scale),this.size.copy(e.size),this.move.copy(e.move),this.fA.copy(e.fA),this.fB.copy(e.fB),this.distortion.copy(e.distortion),this.colorA.copy(e.colorA),this.colorB.copy(e.colorB),this.colorC.copy(e.colorC),this.colorD.copy(e.colorD),this.alpha.copy(e.alpha),this.calpha=e.calpha,this.noiseType.copy(e.noiseType),this}};wu.numOctaves=5;var Nu=class extends Be{constructor(e=new Pe,t=new Pe,r=new Pe,n=new Pe){super("v3");this.nodeType="Blend";this.a=e,this.b=t,this.alpha=r,this.mode=n}generate(e,t){if(e.isShader("fragment")){let r=[];return r.push(this.a.build(e,"c")),r.push(this.b.build(e,"c")),r.push(this.alpha.build(e,"f")),r.push(this.mode.build(e,"i")),e.format("spe_blend("+r.join(",")+")",this.getType(e),t)}else return console.warn("BlendNode is not compatible with "+e.shader+" shader."),e.format("vec3( 0.0 )",this.getType(e),t)}copy(e){return super.copy(e),this.a.copy(e.a),this.b.copy(e.b),this.alpha.copy(e.alpha),this.mode.copy(e.mode),this}};var Gs=class extends Be{constructor(e,t,r,n,s,l,c,f,h,d,x,g){super("v3");this.nodeType="Depth";this.gradientType=e,this.smooth=t,this.near=r,this.far=n,this.isVector=s,this.isWorldSpace=l,this.origin=c,this.direction=f,this.colors=h,this.steps=d,this.num=x,this.alpha=g,this.calpha=`g${this.uuid.toString().replace(/-/g,"")}_calpha`}generate(e,t){let r=`g${this.uuid.toString().replace(/-/g,"")}`,n=new Se(`vec3 ${r}_sdepth(float near, float far, vec3 origin, vec3 direction, vec4 colors[${r}_MAX_COLORS], float steps[10], float alpha, out float calpha) {
|
|
663
663
|
vec4 color = colors[0];
|
|
664
664
|
#ifdef ${r}_IS_VECTOR
|
|
665
665
|
#ifdef ${r}_LINEAR
|
|
@@ -699,7 +699,7 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
699
699
|
|
|
700
700
|
accumAlpha += ( 1.0 - accumAlpha ) * lalpha;
|
|
701
701
|
return color.rgb;
|
|
702
|
-
}`,[
|
|
702
|
+
}`,[Gs.Nodes.vectorLinearWorldSpaceDepth,Gs.Nodes.vectorLinearObjectSpaceDepth,Gs.Nodes.vectorSphericalObjectSpaceDepth,Gs.Nodes.vectorSphericalWorldSpaceDepth]);if(e.isShader("fragment")){e.define(`${r}_MAX_COLORS`,this.num.value+1),this.smooth.value&&e.define(`${r}_SMOOTH`),this.isVector.value>.5&&e.define(`${r}_IS_VECTOR`),this.gradientType.value===vs.Linear&&e.define(`${r}_LINEAR`),this.isWorldSpace.value>.5&&e.define(`${r}_WORLDSPACE`),e.require("worldPosition"),e.addFragmentVariable(this.calpha,"float");let s=e.include(n),l=[];return l.push(this.near.build(e,"f")),l.push(this.far.build(e,"f")),l.push(this.origin.build(e,"v3")),l.push(this.direction.build(e,"v3")),l.push(this.colors.build(e,"v4[]")),l.push(this.steps.build(e,"f[]")),l.push(this.alpha.build(e,"f")),l.push(this.calpha),e.format(s+"("+l.join(",")+")",this.getType(e),t)}else return console.warn("DepthNode is not compatible with "+e.shader+" shader."),e.format("vec3( 0.0 )",this.getType(e),t)}copy(e){return super.copy(e),this.gradientType=e.gradientType.clone(),this.smooth=e.smooth.clone(),this.near=e.near.clone(),this.far=e.far.clone(),this.isVector=e.isVector.clone(),this.isWorldSpace=e.isWorldSpace.clone(),this.origin=e.origin.clone(),this.direction=e.direction.clone(),this.colors=e.colors.clone(),this.steps=e.steps.clone(),this.alpha=e.alpha.clone(),this.calpha=e.calpha,this}},Cu=Gs;Cu.Nodes=function(){let e=new Se(`float vectorLinearWorldSpaceDepth(vec3 direction, vec3 origin, float near, float far) {
|
|
703
703
|
vec3 n = normalize(direction);
|
|
704
704
|
float dist = (n.x*(vWPosition.x - origin.x) + n.y*(vWPosition.y - origin.y) + n.z*(vWPosition.z - origin.z));
|
|
705
705
|
return ( dist - near ) / ( far - near );
|
|
@@ -713,7 +713,7 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
713
713
|
}`),n=new Se(`float vectorSphericalObjectSpaceDepth(vec3 origin, float near, float far) {
|
|
714
714
|
float dist = length(position - origin);
|
|
715
715
|
return ( dist - near ) / ( far - near );
|
|
716
|
-
}`);return{vectorLinearWorldSpaceDepth:e,vectorLinearObjectSpaceDepth:t,vectorSphericalWorldSpaceDepth:r,vectorSphericalObjectSpaceDepth:n}}();var
|
|
716
|
+
}`);return{vectorLinearWorldSpaceDepth:e,vectorLinearObjectSpaceDepth:t,vectorSphericalWorldSpaceDepth:r,vectorSphericalObjectSpaceDepth:n}}();var fp=class extends Be{constructor(e,t,r){super("v3");this.nodeType="Matcap";this.texture=e,this.alpha=t,this.mode=r,this.calpha=`g${this.uuid.toString().replace(/-/g,"")}_calpha`}generate(e,t){if(e.isShader("fragment")){e.addFragmentVariable(this.calpha,"float");let r=e.include(fp.Nodes.matcap);e.require("normal"),e.requires.normal=!0;let n=[];return n.push(this.texture.getTexture(e,"t")),n.push("normal"),n.push(this.alpha.build(e,"f")),n.push(this.mode.build(e,"i")),n.push(this.calpha),e.format(r+"("+n.join(",")+")",this.getType(e),t)}else return console.warn("MatcapNode is not compatible with "+e.shader+" shader."),e.format("vec3( 0.0 )",this.getType(e),t)}copy(e){return super.copy(e),this.texture=e.texture.clone(),this.alpha=e.alpha.clone(),this.mode=e.mode.clone(),this.calpha=e.calpha,this}},Lu=fp;Lu.Nodes=function(){return{matcap:new Se(`vec3 matcap(sampler2D matcapTex, vec3 normal, float alpha, int mode, out float calpha) {
|
|
717
717
|
vec3 viewDir = normalize( vViewPosition );
|
|
718
718
|
vec3 x = normalize( vec3( viewDir.z, 0.0, - viewDir.x ) );
|
|
719
719
|
vec3 y = cross( viewDir, x );
|
|
@@ -725,7 +725,7 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
725
725
|
|
|
726
726
|
return matcapColor.rgb;
|
|
727
727
|
}
|
|
728
|
-
`)}}();var Ir=class{constructor(e){this.id=2,this.layerCount=2,this.uuid=Ci.generateUUID(),this.needsUpdate=!1,this._material=e,this._layerNodes=[];let t=this._createLayer({id:0,type:qe.COLOR});this._material.color=t.color,this._material.alpha===void 0&&(this._material.alpha=new ve(1));let r=new ve(1),n=new Ye(0);"shadingAlpha"in this._material&&"shadingBlend"in this._material&&(this._material.shadingAlpha=r,this._material.shadingBlend=n),this._layerNodes.push({id:0,type:Mt.COLOR,color:t.color,alpha:t.alpha,mode:t.mode}),this._layerNodes.push({id:1,type:Mt.LIGHTING,alpha:r,mode:n}),this.head=t.layer,this.head.next=new Bt(1,void 0,{type:qe.LIGHTING,alpha:r,mode:n}),this.attachLightNodes(this.getLightLayer())}get material(){return this._material}set material(e){var s;this._material=e;let t,r,n=this.head;for(;n!==void 0;){if(n.type===qe.LIGHTING){t=n.uniforms[`f${n.id}_alpha`],r=n.uniforms[`f${n.id}_mode`];break}n=n.next}"shadingAlpha"in this._material&&"shadingBlend"in this._material&&(this._material.shadingAlpha=t,this._material.shadingBlend=r),this.attachLightNodes((s=e.userData.layers)==null?void 0:s.getLightLayer()),this.blendColors(),this.blendAfterColors(),this.blendPositions()}getLayersOfType(e){let t=[],r=this.head;for(;r;)r.type===e&&t.push(r),r=r.next;return t}addLayer(e){var n;if(e.id=(n=e.id)!=null?n:++this.id,this.layerCount++,e.type===qe.LIGHTING){let s=this.createLightLayer(e);return this.uuid=Ci.generateUUID(),this.blendColors(),this.blendAfterColors(),this.blendPositions(),s}let t=this._createLayer(e),r=t.layer;if(this.head===void 0)this.head=r;else{let s=this.head;for(;s.next!=null;)s=s.next;s.next=r}return t.color&&this._layerNodes.push({id:r.id,type:Mt.COLOR,color:t.color,alpha:t.alpha,mode:t.mode}),t.position&&this._layerNodes.push({id:r.id,type:Mt.POSITION,position:t.position}),this.uuid=Ci.generateUUID(),this.blendColors(),this.blendAfterColors(),this.blendPositions(),r}addLayerBeforeAt(e,t){var c;let r=this.head;e.id=(c=e.id)!=null?c:++this.id,this.layerCount++;let n=this._createLayer(e),s=n.layer;s.next=t;let l=0;if(r===t)this.head=s,n.color&&this._layerNodes.splice(0,0,{id:s.id,type:Mt.COLOR,color:n.color,alpha:n.alpha,mode:n.mode}),n.position&&this._layerNodes.splice(0,0,{id:s.id,type:Mt.POSITION,position:n.position});else{for(l=1;(r==null?void 0:r.next)!==t;)r=r==null?void 0:r.next,l++;r.next=s,n.color&&this._layerNodes.splice(l,0,{id:s.id,type:Mt.COLOR,color:n.color,alpha:n.alpha,mode:n.mode}),n.position&&this._layerNodes.splice(l,0,{id:s.id,type:Mt.POSITION,position:n.position})}return this.uuid=Ci.generateUUID(),this.blendColors(),this.blendAfterColors(),this.blendPositions(),s}addLayerAt(e,t){var s;t.id=(s=t.id)!=null?s:++this.id,this.layerCount++;let r=this._createLayer(t),n=r.layer;if(r.color&&this._layerNodes.splice(e,0,{id:n.id,type:Mt.COLOR,color:r.color,alpha:r.alpha,mode:r.mode}),r.position&&this._layerNodes.splice(e,0,{id:n.id,type:Mt.POSITION,position:r.position}),e==0)n.next=this.head,this.head=n;else{let l=this.head,c=this.head.next;for(let f=0;f<e-1;f++)l=c,c=c.next;n.next=c,l.next=n}return this.uuid=Ci.generateUUID(),this.blendColors(),this.blendAfterColors(),this.blendPositions(),n}removeLayer(e){let t=this.head,r,n=0;if((t==null?void 0:t.id)==e)this.head=t.next;else for(n=1,r=t,t=t==null?void 0:t.next;t!=null;){if(t.id==e){r.next=t.next;break}n++,r=t,t=t.next}return this.cleanupChangedLayer(t),this.blendColors(),this.blendAfterColors(),this.blendPositions(),this.uuid=Ci.generateUUID(),this.layerCount--,n}changeLayer(e,t){let r,n=this.head,s;if((n==null?void 0:n.id)==e){let l=this._createLayer(U({id:e,uuid:n.uuid},t));s=l.layer,s.next=n.next,this.head=s,l.color&&(this._layerNodes[0]={id:s.id,type:Mt.COLOR,color:l.color,alpha:l.alpha,mode:l.mode}),l.position&&(this._layerNodes[0]={id:s.id,type:Mt.POSITION,position:l.position}),s.uniforms[`f${e}_mode`].value=n.uniforms[`f${e}_mode`].value,s.uniforms[`f${e}_alpha`].value=n.uniforms[`f${e}_alpha`].value}else{r=n,n=n.next;let l=1;for(;n!=null;){if(n.id==e){let c=this._createLayer(U({id:e,uuid:n.uuid},t));s=c.layer,r.next=s,s.next=n.next,c.color&&(this._layerNodes[l]={id:e,type:Mt.COLOR,color:c.color,alpha:c.alpha,mode:c.mode}),c.position&&(this._layerNodes[l]={id:e,type:Mt.POSITION,position:c.position}),s.uniforms[`f${e}_mode`].value=n.uniforms[`f${e}_mode`].value,s.uniforms[`f${e}_alpha`].value=n.uniforms[`f${e}_alpha`].value;break}r=n,n=n.next,l++}}return this.uuid=Ci.generateUUID(),this.blendColors(),this.blendAfterColors(),this.blendPositions(),s}getLayer(e){let t=this.head;for(;t!=null&&t.id!=e;)t=t.next;return t}getLayerByUuid(e){let t=this.head;for(;t!==void 0;){if(t.uuid===e)return t;t=t.next}}getLayers(){let e=[],t=this.head;for(;t!=null;)e.push(t),t=t.next;return e}getLayerPosition(e){let t=this.head,r=0;for(;t!==void 0&&t.id!=e;)r++,t=t.next;return r}getDefines(){}getBeforeProgram(){}getLightingProgram(){}getAfterProgram(){}getVarPrograms(){}getUniforms(){}moveLayer(e,t){let r,n=this.head,s;if(e==0)r=this.head,this.head=r.next;else{for(let c=0;c<e;c++)s=n,n=n.next;s.next=n.next,r=n}if(n=this.head,s=void 0,t==0)r.next=this.head,this.head=r;else{for(let c=0;c<t-1;c++)n=n.next;r.next=n==null?void 0:n.next,n.next=r}let l=this._layerNodes.splice(e,1)[0];this._layerNodes.splice(t,0,l),this.uuid=Ci.generateUUID(),this.blendColors(),this.blendAfterColors()}updateLayerUniform(){this.uuid=Ci.generateUUID(),this.blendColors(),this.blendAfterColors()}copy(e){this.needsUpdate=!1,this.layerCount=e.layerCount,this._layerNodes=[],this.layerCount=0,this.head=void 0,this.rebuildLayerNodes(this.head,e.head);let t=e.head,r=this.head;for(;t.next!=null;)this.rebuildLayerNodes(r,t.next),r=r.next,t=t.next;return this.id=e.id,this.uuid=e.uuid,this.blendColors(),this.blendAfterColors(),this.blendPositions(),this}createLightLayer(e){let t=new ve(e.alpha),r=new Ye(e.mode);this._material.shadingAlpha=t,this._material.shadingBlend=r,this._layerNodes.push({id:e.id,type:Mt.LIGHTING,alpha:t,mode:r});let n=new Bt(e.id,void 0,{type:qe.LIGHTING,alpha:t,mode:r});if(this.head===void 0)this.head=n;else{let s=this.head;for(;s.next!=null;)s=s.next;s.next=n}return this.attachLightNodes(this.getLightLayer()),n}rebuildLayerNodes(e,t,r=!1){if(t.type===qe.LIGHTING){let n=r?t.uniforms[`f${t.id}_alpha`]:new ve(t.uniforms[`f${t.id}_alpha`].value),s=r?t.uniforms[`f${t.id}_mode`]:new Ye(t.uniforms[`f${t.id}_mode`].value);this._material.shadingAlpha=n,this._material.shadingBlend=s,this._layerNodes.push({id:t.id,type:Mt.LIGHTING,alpha:n,mode:s}),this.head===void 0?this.head=new Bt(t.id,t.uuid,{type:qe.LIGHTING,alpha:n,mode:s}):e&&(e.next=new Bt(t.id,t.uuid,{type:qe.LIGHTING,alpha:n,mode:s})),this.attachLightNodes(t)}else{let n={type:t.type,id:t.id};for(let s in t.uniforms){let l=t.getName(s);if(!l)continue;let c=`f${t.id}_${l}`;if(Array.isArray(t.uniforms[c].value))n[l]=t.uniforms[c].value.map(f=>f.clone&&!r?f.clone():f);else{let f=t.uniforms[c].value;if(l==="transmissionDepthMap"){n[l]=f;continue}f!=null&&(n[l]=f.clone&&!r&&!f.isRenderTargetTexture?f.clone():f)}}this.addLayer(n)}}attachLightNodes(e){var n,s,l,c,f,h,p,y,g,w,S;let t={},r=this.getLightLayer();switch(this._material.userData.category){case"Lambert":t.emissive=new vt((s=(n=e==null?void 0:e.getValue("emissive"))==null?void 0:n.clone())!=null?s:0);break;case"Phong":t.shininess=new ve((l=e==null?void 0:e.getValue("shininess"))!=null?l:30),t.specular=new vt((f=(c=e==null?void 0:e.getValue("specular"))==null?void 0:c.clone())!=null?f:1118481);break;case"Toon":t.shininess=new ve((h=e==null?void 0:e.getValue("shininess"))!=null?h:30),t.specular=new vt((y=(p=e==null?void 0:e.getValue("specular"))==null?void 0:p.clone())!=null?y:1118481);break;case"Physical":t.roughness=new ve((g=e==null?void 0:e.getValue("roughness"))!=null?g:.3),t.metalness=new ve((w=e==null?void 0:e.getValue("metalness"))!=null?w:0),t.reflectivity=new ve((S=e==null?void 0:e.getValue("reflectivity"))!=null?S:.5);break;default:break}Object.keys(t).forEach(T=>{this._material[T]=t[T],r.uniforms[`f${r.id}_${T}`]=t[T]})}clone(e){return new Ir(e).copy(this)}toJSON(e){return{id:this.id,uuid:this.uuid,head:this.head.toJSON(e)}}fromJSON(e,t,r){let n=new Bt(e.head.id,void 0,{type:e.head.type}).fromJSON(e.head,t),s=e.head.next,l=n;for(;s!=null;)l.next=new Bt(s.id,void 0,{type:s.type}).fromJSON(s,t),s=s.next,l=l.next;this._layerNodes=[],this.head=void 0,this.rebuildLayerNodes(this.head,n,!0);let c=n;for(l=this.head;c.next!=null;)this.rebuildLayerNodes(l,c.next,!0),l=l.next,c=c.next;return this._material=r,this.id=e.id,this.uuid=e.uuid,this.blendColors(),this.blendAfterColors(),this.blendPositions(),this}getLightLayer(){var t;let e=this.head;for(;e!==void 0&&e.type!=="light";)e=(t=e.next)!=null?t:e;return e}dispose(){let e=this.head;for(this._layerNodes=[],this.layerCount=0;e!==void 0;)e.hasOwnProperty("dispose")===!0&&e.dispose(),e=e.next;this.head=void 0}_createLayer(e){var r,n,s,l,c,f,h,p,y,g,w,S,T,C,B,G,D,W,A,q,E,b,R,I,z,O,$,he,re,Ne,ye,Me,Fe,k,H,_,J,ee,oe,se,ce,ue,K,ae,ne,Ce,Y,le,de,xe,_e,pe,we,Ve,Ge,Qe,bt,Lt,At,sr,Ur,Ht,kr,Nn,Cn,pt,Wt,ar,Do,Bo,Go,no,io,jo,Mr,oo,Jt,ni,Eo;let t=e.type;switch(t){case qe.COLOR:{let Ee=new vt((r=e.color)!=null?r:Yt),Xe=new ve((n=e.alpha)!=null?n:1),He=new xt("alpha / clamp(alpha + accumAlpha, 0.00001, 1.0 )","f");He.keywords.alpha=Xe;let $e=new Ye((s=e.mode)!=null?s:0);return Ee.alpha=Xe,{layer:new Bt(e.id,e.uuid,{type:t,color:Ee,alpha:Xe,calpha:He,mode:$e}),color:Ee,alpha:He,mode:$e}}case qe.TEXTURE:{let Ee=(l=e.texture)!=null?l:new wi,Xe=Ee.matrix;e.mat&&Xe.copy(e.mat),Ee.needsUpdate=!0;let He=new ve((c=e.crop)!=null?c:0),$e=new Ye((f=e.projection)!=null?f:0),tt=new Ye((h=e.axis)!=null?h:0),at=new _r(e.size?new Zi(e.size[0],e.size[1]):new Zi(100,100)),mt=new ve((p=e.alpha)!=null?p:1),gt=new Ye((y=e.mode)!=null?y:0),ct=new Fr(Ee),St=new Tr((g=e.textureSize)!=null?g:new Yi(Ee.image?Ee.image.width:0,Ee.image?Ee.image.height:0)),Rt=new Su(ct,St,He,$e,tt,at,mt,gt),Ar=new xt(Rt.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,texture:ct,textureSize:St,crop:He,projection:$e,axis:tt,size:at,mat:Rt.mat,alpha:mt,calpha:Ar,mode:gt}),color:Rt,alpha:Ar,mode:gt}}case qe.MATCAP:{let Ee=(w=e.texture)!=null?w:new wi;Ee.needsUpdate=!0;let Xe=new ve((S=e.alpha)!=null?S:1),He=new Fr(Ee),$e=new Ye((T=e.mode)!=null?T:0),tt=new Au(He,Xe,$e),at=new xt(tt.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,texture:He,alpha:Xe,calpha:at,mode:$e}),color:tt,alpha:at,mode:$e}}case qe.FRESNEL:{let Ee=new vt((C=e.color)!=null?C:16777215),Xe=new ve((B=e.bias)!=null?B:.1),He=new ve((G=e.scale)!=null?G:1),$e=new ve((D=e.intensity)!=null?D:2),tt=new ve((W=e.factor)!=null?W:1),at=new ve((A=e.alpha)!=null?A:1),mt=new Ye((q=e.mode)!=null?q:0),gt=new wu(Ee,Xe,He,$e,tt,at,mt),ct=new xt(gt.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,color:Ee,bias:Xe,scale:He,intensity:$e,factor:tt,alpha:at,calpha:ct,mode:mt}),color:gt,alpha:ct,mode:mt}}case qe.RAINBOW:{let Ee=new ve((E=e.filmThickness)!=null?E:30),Xe=new ve((b=e.movement)!=null?b:0),He=new Tr((R=e.wavelengths)!=null?R:new Yi(0,0,0)),$e=new ve((I=e.noiseStrength)!=null?I:0),tt=new ve((z=e.noiseScale)!=null?z:1),at=new Tr((O=e.offset)!=null?O:new Yi(0,0,0)),mt=new ve(($=e.alpha)!=null?$:1),gt=new Nu(Ee,Xe,He,$e,tt,at,mt),ct=new xt(gt.calpha,"f"),St=new Ye((he=e.mode)!=null?he:0);return{layer:new Bt(e.id,e.uuid,{type:t,filmThickness:Ee,movement:Xe,wavelengths:He,noiseStrength:$e,noiseScale:tt,offset:at,alpha:mt,calpha:ct,mode:St}),color:gt,alpha:ct,mode:St}}case qe.TRANSMISSION:{let Ee=new ve((re=e.thickness)!=null?re:10),Xe=new ve((Ne=e.ior)!=null?Ne:1.5),He=new ve((ye=e.roughness)!=null?ye:.5),$e=new _r((Me=e.transmissionSamplerSize)!=null?Me:new Zi(2048,2048)),tt=(Fe=e.transmissionSamplerMap)!=null?Fe:new wi,at=(k=e.transmissionDepthMap)!=null?k:new wi,mt=new Fr(tt),gt=new Fr(at),ct=window.innerWidth,St=window.innerHeight,Rt=ct>=St?new _r(St/ct,1):new _r(1,ct/St),Ar=new ve((H=e.alpha)!=null?H:1),Ln=new Cu(Ee,Xe,He,$e,mt,gt,Rt,Ar),_n=new xt(Ln.calpha,"f"),zn=new Ye((_=e.mode)!=null?_:0);return{layer:new Bt(e.id,e.uuid,{type:t,thickness:Ee,ior:Xe,roughness:He,transmissionSamplerSize:$e,transmissionSamplerMap:mt,transmissionDepthMap:gt,aspectRatio:Rt,alpha:Ar,calpha:_n,mode:zn}),color:Ln,alpha:_n,mode:zn}}case qe.DEPTH:{let Ee=new Ye((J=e.gradientType)!=null?J:0),Xe=new bu((ee=e.smooth)!=null?ee:!1),He=new ve((oe=e.near)!=null?oe:50),$e=new ve((se=e.far)!=null?se:200),tt=new ve((ce=e.isVector)!=null?ce:1),at=new ve((ue=e.isWorldSpace)!=null?ue:0),mt=new Tr((K=e.origin)!=null?K:new Yi),gt=new Tr((ae=e.direction)!=null?ae:new Yi),ct=new Ye((ne=e.num)!=null?ne:0),St;e.colors?St=new Gs(ct.value+1,e.colors):(St=new Gs(ct.value+1,new Ou(0,0,0,1)),St.value[1]=new Ou(1,1,1,1));let Rt;e.steps?Rt=new js(e.steps.length,e.steps):(Rt=new js(10,1),Rt.value[0]=0);let Ar=new ve((Ce=e.alpha)!=null?Ce:1),Ln=new Ye((Y=e.mode)!=null?Y:0),_n=new Mu(Ee,Xe,He,$e,tt,at,mt,gt,St,Rt,ct,Ar),zn=new xt(_n.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,gradientType:Ee,smooth:Xe,near:He,far:$e,isVector:tt,isWorldSpace:at,origin:mt,direction:gt,colors:St,steps:Rt,num:ct,alpha:Ar,calpha:zn,mode:Ln}),color:_n,alpha:zn,mode:Ln}}case qe.NOISE:{let Ee=new ve((le=e.scale)!=null?le:1),Xe=new Tr((de=e.size)!=null?de:new Yi(100,100,100)),He=new ve((xe=e.move)!=null?xe:1),$e=new _r((_e=e.fA)!=null?_e:new Zi(1.7,9.2)),tt=new _r((pe=e.fB)!=null?pe:new Zi(8.3,2.8)),at=new _r((we=e.distortion)!=null?we:new Zi(1,1)),mt=new Xi(e.colorA),gt=new Xi(e.colorB),ct=new Xi(e.colorC),St=new Xi(e.colorD),Rt=new ve((Ve=e.alpha)!=null?Ve:1),Ar=new Ye((Ge=e.mode)!=null?Ge:0),Ln=new Ye((Qe=e.noiseType)!=null?Qe:0),_n=new Tu(Ee,Xe,He,$e,tt,at,mt,gt,ct,St,Rt,Ln),zn=new xt(_n.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,scale:Ee,size:Xe,move:He,fA:$e,fB:tt,distortion:at,colorA:mt,colorB:gt,colorC:ct,colorD:St,alpha:Rt,calpha:zn,mode:Ar,noiseType:Ln}),color:_n,alpha:zn,mode:Ar}}case qe.NORMAL:{let Ee=new Tr((bt=e.cnormal)!=null?bt:new Yi(1,1,1)),Xe=new ve((Lt=e.alpha)!=null?Lt:1),He=new Ye((At=e.mode)!=null?At:0),$e=new Lu(Ee,Xe),tt=new xt("alpha / clamp(alpha + accumAlpha, 0.00001, 1.0 )","f");return tt.keywords.alpha=Xe,{layer:new Bt(e.id,e.uuid,{type:t,cnormal:Ee,alpha:Xe,calpha:tt,mode:He}),color:$e,alpha:tt,mode:He}}case qe.GRADIENT:{let Ee=new Ye((sr=e.gradientType)!=null?sr:0),Xe=new bu((Ur=e.smooth)!=null?Ur:!1),He;e.colors?He=new Gs(e.colors.length,e.colors):(He=new Gs(10,new Ou(0,0,0,1)),He.value[1]=new Ou(1,1,1,1));let $e;e.steps?$e=new js(e.steps.length,e.steps):($e=new js(10,1),$e.value[0]=0);let tt=new _r((Ht=e.offset)!=null?Ht:new Zi(0,0)),at=new _r((kr=e.morph)!=null?kr:new Zi(0,0)),mt=new ve((Nn=e.angle)!=null?Nn:0),gt=new ve((Cn=e.alpha)!=null?Cn:1),ct=new Ye((pt=e.mode)!=null?pt:0),St=new _u(Ee,Xe,He,$e,tt,at,mt,gt),Rt=new xt(St.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,gradientType:Ee,smooth:Xe,colors:He,steps:$e,offset:tt,morph:at,angle:mt,alpha:gt,calpha:Rt,mode:ct}),color:St,alpha:Rt,mode:ct}}case qe.DISPLACE:{let Ee=new Ye((Wt=e.displacementType)!=null?Wt:0);if(Ee.value===0){let Xe=new Tr((ar=e.offset)!=null?ar:new Yi(0,0,0)),He=new ve((Do=e.scale)!=null?Do:10),$e=new ve((Bo=e.intensity)!=null?Bo:8),tt=new ve((Go=e.movement)!=null?Go:1),at=new ve((no=e.alpha)!=null?no:1),mt=new Ye((io=e.mode)!=null?io:0),gt=new Ye((jo=e.noiseType)!=null?jo:0),ct=new Ga(Ee,$e,tt,Xe,He,gt);return{layer:new Bt(e.id,e.uuid,{displacementType:Ee,type:t,offset:Xe,scale:He,intensity:$e,movement:tt,alpha:at,mode:mt,noiseType:gt}),position:ct}}else if(Ee.value===1){let Xe=(Mr=e.texture)!=null?Mr:new wi,He=Xe.matrix;e.mat&&He.copy(e.mat),Xe.needsUpdate=!0;let $e=new ve((oo=e.intensity)!=null?oo:8),tt=new Fr(Xe),at=new ve((Jt=e.crop)!=null?Jt:0),mt=new ve((ni=e.alpha)!=null?ni:1),gt=new Ye((Eo=e.mode)!=null?Eo:0),ct=new Ga(Ee,$e,tt,at);return{layer:new Bt(e.id,e.uuid,{displacementType:Ee,type:t,intensity:$e,texture:tt,crop:at,mat:ct.mat,alpha:mt,mode:gt}),position:ct}}return{}}}return{}}blendColors(){let e=this._layerNodes.findIndex(r=>r.type===Mt.COLOR),t=this._layerNodes.findIndex(r=>r.type===Mt.LIGHTING);if(e!==-1&&e<t){let r=this._layerNodes[e].color;for(let n=e+1;n<t;++n){let s=this._layerNodes[n];s.type===Mt.COLOR&&(r=new Iu(r,s.color,s.alpha,s.mode))}this._material.color=r}else this._material.color=void 0}blendAfterColors(){let e=new xt("outgoingLight","f"),t=this._layerNodes.findIndex(r=>r.type===Mt.LIGHTING);if(this._layerNodes.length>t+1){for(let r=t+1;r<this._layerNodes.length;++r){let n=this._layerNodes[r];n.type===Mt.COLOR&&(e=new Iu(e,n.color,n.alpha,n.mode))}"afterColor"in this._material&&(this._material.afterColor=e)}else"afterColor"in this._material&&(this._material.afterColor=void 0)}blendPositions(){let e=this._layerNodes.filter(t=>t.type===Mt.POSITION);if(e.length>0){let t=e[0].position;for(let r=1;r<e.length;++r)e[r]&&(t=new rn(t,e[r].position,rn.ADD),t=new rn(t,new ve(.5).setReadonly(!0),rn.MUL));this._material.position=t}else this._material.position=void 0}cleanupChangedLayer(e){switch(this._layerNodes=this._layerNodes.filter(t=>t.id!==e.id),e.type){case qe.DISPLACE:{this.blendPositions();break}default:{this.blendColors(),this.blendAfterColors();break}}}};var bn=class extends QD{constructor(e,t,r){super(r);this.isNodeMaterial=!0;this.type="NodeMaterial";this.wireframeLinecap="";this.wireframeLinejoin="";this.uniformsBackup={};this.userData={type:"",category:"",nodeType:""};this.fog=!0,this.vertex=e!=null?e:new vu(new xr(xr.PROJECTION)),this.fragment=t!=null?t:new vu(new vt(Yt)),this.updaters=[],this.isDetached=!0,this.dithering=!0,this.onBeforeCompile=this._onBeforeCompile}getDefines(){return this.defines}getUniforms(){return this.uniforms}getVertexShader(){return this.vertexShader}getFragmentShader(){return this.fragmentShader}_onBeforeCompile(e,t){this.build({renderer:t}),e.defines=this.defines,e.uniforms=this.uniforms,e.vertexShader=this.vertexShader,e.fragmentShader=this.fragmentShader,e.extensionDerivatives=this.extensions.derivatives===!0,e.extensionFragDepth=this.extensions.fragDepth===!0,e.extensionDrawBuffers=this.extensions.drawBuffers===!0,e.extensionShaderTextureLOD=this.extensions.shaderTextureLOD===!0}_getLayerStack(e){let t=new Ir(this);return e&&(async()=>{for(;e.image===void 0;)await new Promise(r=>requestAnimationFrame(r));t.addLayerAt(1,{type:qe.TEXTURE,texture:e}),this.dispose()})(),t}clampUniformsForPreview(e,t){let r=(n,s,l)=>Math.min(Math.max(n,s),l);if(this.userData.layers){for(let n of this.userData.layers.getLayers())if(n.type==qe.DISPLACE){this.uniformsBackup[`f${n.id}_intensity`]=n.uniforms[`f${n.id}_intensity`].value;let s=r(n.uniforms[`f${n.id}_intensity`].value,e,t);n.uniforms[`f${n.id}_intensity`].value=s}}}restoreClampedUniforms(){if(this.userData.layers)for(let e of this.userData.layers.getLayers())e.type==qe.DISPLACE&&(e.uniforms[`f${e.id}_intensity`].value=this.uniformsBackup[`f${e.id}_intensity`])}customProgramCacheKey(){return this.getHash()}updateFrame(e){for(let t=0;t<this.updaters.length;++t)e.updateNode(this.updaters[t])}build(e){var r;e=e!=null?e:{};let t=(r=e.builder)!=null?r:new hd;return t.setMaterial(this,e.renderer),t.build(this.vertex,this.fragment),this.vertexShader=t.getCode("vertex"),this.fragmentShader=t.getCode("fragment"),this.defines=t.defines,this.uniforms=t.uniforms,this.extensions=t.extensions,this.updaters=t.updaters,this.fog=t.requires.fog,this.lights=t.requires.lights,this.transparent=t.requires.transparent||this.blending>YD,this}getHash(){let e="{";return e+='"vertex":'+this.vertex.getHash()+",",e+='"fragment":'+this.fragment.getHash(),e+="}",e}copy(e){let t=this.uuid;for(let r in e)this[r]=e[r];return this.uuid=t,e.userData!==void 0&&(this.userData=JSON.parse(JSON.stringify(e.userData))),this}toJSON(e){let t=this.userData.layers;this.userData.layers=void 0;let r=super.toJSON(e);return r.type="ShaderMaterial",r.userData={type:this.userData.type,category:this.userData.category,nodeType:this.type,layers:t.toJSON(e)},r.vertex=this.vertex.toJSON(e).uuid,r.fragment=this.fragment.toJSON(e).uuid,delete r.vertexShader,delete r.fragmentShader,delete r.color,delete r.shininess,delete r.specular,delete r.roughness,delete r.metalness,delete r.uniforms,e&&!e.materials[this.uuid]&&(e.materials[this.uuid]=r),this.userData.layers=t,r}fromJSON(e,t){var r;this.defines=(r=e.defines)!=null?r:{},this.depthFunc=e.depthFunc,this.depthWrite=e.depthWrite,this.side=e.side!==void 0?e.side:e3,this.transparent=e.transparent,this.wireframeLinecap=e.wireframeLinecap,this.wireframeLinejoin=e.wireframeLinejoin,this.flatShading=e.flatShading,this.wireframe=e.wireframe,this.userData.layers.fromJSON(e.userData.layers,t,this)}};Object.defineProperties(bn.prototype,{properties:{get:function(){return this.fragment.properties}},needsUpdate:{set:function(i){i===!0&&this.version++,this.needsCompile=i},get:function(){return this.needsCompile}}});import{UniformsLib as t3,UniformsUtils as r3}from"three";var bd=class extends Pe{constructor(){super("basic");this.nodeType="Basic";this.color=new vt(Yt)}generate(e){let t;if(e.isShader("vertex")){let r=this.position?this.position.analyzeAndFlow(e,"v3",{cache:"position"}):void 0;e.mergeUniform(r3.merge([t3.fog])),e.addParsCode(["varying vec3 vViewPosition;","#include <fog_pars_vertex>","#include <normal_pars_vertex>"].join(`
|
|
728
|
+
`)}}();var Ir=class{constructor(e){this.id=2,this.layerCount=2,this.uuid=wi.generateUUID(),this.needsUpdate=!1,this._material=e,this._layerNodes=[];let t=this._createLayer({id:0,type:qe.COLOR});this._material.color=t.color,this._material.alpha===void 0&&(this._material.alpha=new ve(1));let r=new ve(1),n=new Ye(0);"shadingAlpha"in this._material&&"shadingBlend"in this._material&&(this._material.shadingAlpha=r,this._material.shadingBlend=n),this._layerNodes.push({id:0,type:Mt.COLOR,color:t.color,alpha:t.alpha,mode:t.mode}),this._layerNodes.push({id:1,type:Mt.LIGHTING,alpha:r,mode:n}),this.head=t.layer,this.head.next=new Bt(1,void 0,{type:qe.LIGHTING,alpha:r,mode:n}),this.attachLightNodes(this.getLightLayer())}get material(){return this._material}set material(e){var s;this._material=e;let t,r,n=this.head;for(;n!==void 0;){if(n.type===qe.LIGHTING){t=n.uniforms[`f${n.id}_alpha`],r=n.uniforms[`f${n.id}_mode`];break}n=n.next}"shadingAlpha"in this._material&&"shadingBlend"in this._material&&(this._material.shadingAlpha=t,this._material.shadingBlend=r),this.attachLightNodes((s=e.userData.layers)==null?void 0:s.getLightLayer()),this.blendColors(),this.blendAfterColors(),this.blendPositions()}getLayersOfType(e){let t=[],r=this.head;for(;r;)r.type===e&&t.push(r),r=r.next;return t}addLayer(e){var n;if(e.id=(n=e.id)!=null?n:++this.id,this.layerCount++,e.type===qe.LIGHTING){let s=this.createLightLayer(e);return this.uuid=wi.generateUUID(),this.blendColors(),this.blendAfterColors(),this.blendPositions(),s}let t=this._createLayer(e),r=t.layer;if(this.head===void 0)this.head=r;else{let s=this.head;for(;s.next!=null;)s=s.next;s.next=r}return t.color&&this._layerNodes.push({id:r.id,type:Mt.COLOR,color:t.color,alpha:t.alpha,mode:t.mode}),t.position&&this._layerNodes.push({id:r.id,type:Mt.POSITION,position:t.position}),this.uuid=wi.generateUUID(),this.blendColors(),this.blendAfterColors(),this.blendPositions(),r}addLayerBeforeAt(e,t){var c;let r=this.head;e.id=(c=e.id)!=null?c:++this.id,this.layerCount++;let n=this._createLayer(e),s=n.layer;s.next=t;let l=0;if(r===t)this.head=s,n.color&&this._layerNodes.splice(0,0,{id:s.id,type:Mt.COLOR,color:n.color,alpha:n.alpha,mode:n.mode}),n.position&&this._layerNodes.splice(0,0,{id:s.id,type:Mt.POSITION,position:n.position});else{for(l=1;(r==null?void 0:r.next)!==t;)r=r==null?void 0:r.next,l++;r.next=s,n.color&&this._layerNodes.splice(l,0,{id:s.id,type:Mt.COLOR,color:n.color,alpha:n.alpha,mode:n.mode}),n.position&&this._layerNodes.splice(l,0,{id:s.id,type:Mt.POSITION,position:n.position})}return this.uuid=wi.generateUUID(),this.blendColors(),this.blendAfterColors(),this.blendPositions(),s}addLayerAt(e,t){var s;t.id=(s=t.id)!=null?s:++this.id,this.layerCount++;let r=this._createLayer(t),n=r.layer;if(r.color&&this._layerNodes.splice(e,0,{id:n.id,type:Mt.COLOR,color:r.color,alpha:r.alpha,mode:r.mode}),r.position&&this._layerNodes.splice(e,0,{id:n.id,type:Mt.POSITION,position:r.position}),e==0)n.next=this.head,this.head=n;else{let l=this.head,c=this.head.next;for(let f=0;f<e-1;f++)l=c,c=c.next;n.next=c,l.next=n}return this.uuid=wi.generateUUID(),this.blendColors(),this.blendAfterColors(),this.blendPositions(),n}removeLayer(e){let t=this.head,r,n=0;if((t==null?void 0:t.id)==e)this.head=t.next;else for(n=1,r=t,t=t==null?void 0:t.next;t!=null;){if(t.id==e){r.next=t.next;break}n++,r=t,t=t.next}return this.cleanupChangedLayer(t),this.blendColors(),this.blendAfterColors(),this.blendPositions(),this.uuid=wi.generateUUID(),this.layerCount--,n}changeLayer(e,t){let r,n=this.head,s;if((n==null?void 0:n.id)==e){let l=this._createLayer(U({id:e,uuid:n.uuid},t));s=l.layer,s.next=n.next,this.head=s,l.color&&(this._layerNodes[0]={id:s.id,type:Mt.COLOR,color:l.color,alpha:l.alpha,mode:l.mode}),l.position&&(this._layerNodes[0]={id:s.id,type:Mt.POSITION,position:l.position}),s.uniforms[`f${e}_mode`].value=n.uniforms[`f${e}_mode`].value,s.uniforms[`f${e}_alpha`].value=n.uniforms[`f${e}_alpha`].value}else{r=n,n=n.next;let l=1;for(;n!=null;){if(n.id==e){let c=this._createLayer(U({id:e,uuid:n.uuid},t));s=c.layer,r.next=s,s.next=n.next,c.color&&(this._layerNodes[l]={id:e,type:Mt.COLOR,color:c.color,alpha:c.alpha,mode:c.mode}),c.position&&(this._layerNodes[l]={id:e,type:Mt.POSITION,position:c.position}),s.uniforms[`f${e}_mode`].value=n.uniforms[`f${e}_mode`].value,s.uniforms[`f${e}_alpha`].value=n.uniforms[`f${e}_alpha`].value;break}r=n,n=n.next,l++}}return this.uuid=wi.generateUUID(),this.blendColors(),this.blendAfterColors(),this.blendPositions(),s}getLayer(e){let t=this.head;for(;t!=null&&t.id!=e;)t=t.next;return t}getLayerByUuid(e){let t=this.head;for(;t!==void 0;){if(t.uuid===e)return t;t=t.next}}getLayers(){let e=[],t=this.head;for(;t!=null;)e.push(t),t=t.next;return e}getLayerPosition(e){let t=this.head,r=0;for(;t!==void 0&&t.id!=e;)r++,t=t.next;return r}getDefines(){}getBeforeProgram(){}getLightingProgram(){}getAfterProgram(){}getVarPrograms(){}getUniforms(){}moveLayer(e,t){let r,n=this.head,s;if(e==0)r=this.head,this.head=r.next;else{for(let c=0;c<e;c++)s=n,n=n.next;s.next=n.next,r=n}if(n=this.head,s=void 0,t==0)r.next=this.head,this.head=r;else{for(let c=0;c<t-1;c++)n=n.next;r.next=n==null?void 0:n.next,n.next=r}let l=this._layerNodes.splice(e,1)[0];this._layerNodes.splice(t,0,l),this.uuid=wi.generateUUID(),this.blendColors(),this.blendAfterColors()}updateLayerUniform(){this.uuid=wi.generateUUID(),this.blendColors(),this.blendAfterColors()}copy(e){this.needsUpdate=!1,this.layerCount=e.layerCount,this._layerNodes=[],this.layerCount=0,this.head=void 0,this.rebuildLayerNodes(this.head,e.head);let t=e.head,r=this.head;for(;t.next!=null;)this.rebuildLayerNodes(r,t.next),r=r.next,t=t.next;return this.id=e.id,this.uuid=e.uuid,this.blendColors(),this.blendAfterColors(),this.blendPositions(),this}createLightLayer(e){let t=new ve(e.alpha),r=new Ye(e.mode);this._material.shadingAlpha=t,this._material.shadingBlend=r,this._layerNodes.push({id:e.id,type:Mt.LIGHTING,alpha:t,mode:r});let n=new Bt(e.id,void 0,{type:qe.LIGHTING,alpha:t,mode:r});if(this.head===void 0)this.head=n;else{let s=this.head;for(;s.next!=null;)s=s.next;s.next=n}return this.attachLightNodes(this.getLightLayer()),n}rebuildLayerNodes(e,t,r=!1){if(t.type===qe.LIGHTING){let n=r?t.uniforms[`f${t.id}_alpha`]:new ve(t.uniforms[`f${t.id}_alpha`].value),s=r?t.uniforms[`f${t.id}_mode`]:new Ye(t.uniforms[`f${t.id}_mode`].value);this._material.shadingAlpha=n,this._material.shadingBlend=s,this._layerNodes.push({id:t.id,type:Mt.LIGHTING,alpha:n,mode:s}),this.head===void 0?this.head=new Bt(t.id,t.uuid,{type:qe.LIGHTING,alpha:n,mode:s}):e&&(e.next=new Bt(t.id,t.uuid,{type:qe.LIGHTING,alpha:n,mode:s})),this.attachLightNodes(t)}else{let n={type:t.type,id:t.id};for(let s in t.uniforms){let l=t.getName(s);if(!l)continue;let c=`f${t.id}_${l}`;if(Array.isArray(t.uniforms[c].value))n[l]=t.uniforms[c].value.map(f=>f.clone&&!r?f.clone():f);else{let f=t.uniforms[c].value;if(l==="transmissionDepthMap"){n[l]=f;continue}f!=null&&(n[l]=f.clone&&!r&&!f.isRenderTargetTexture?f.clone():f)}}this.addLayer(n)}}attachLightNodes(e){var n,s,l,c,f,h,d,x,g,w,S;let t={},r=this.getLightLayer();switch(this._material.userData.category){case"Lambert":t.emissive=new vt((s=(n=e==null?void 0:e.getValue("emissive"))==null?void 0:n.clone())!=null?s:0);break;case"Phong":t.shininess=new ve((l=e==null?void 0:e.getValue("shininess"))!=null?l:30),t.specular=new vt((f=(c=e==null?void 0:e.getValue("specular"))==null?void 0:c.clone())!=null?f:1118481);break;case"Toon":t.shininess=new ve((h=e==null?void 0:e.getValue("shininess"))!=null?h:30),t.specular=new vt((x=(d=e==null?void 0:e.getValue("specular"))==null?void 0:d.clone())!=null?x:1118481);break;case"Physical":t.roughness=new ve((g=e==null?void 0:e.getValue("roughness"))!=null?g:.3),t.metalness=new ve((w=e==null?void 0:e.getValue("metalness"))!=null?w:0),t.reflectivity=new ve((S=e==null?void 0:e.getValue("reflectivity"))!=null?S:.5);break;default:break}Object.keys(t).forEach(D=>{this._material[D]=t[D],r.uniforms[`f${r.id}_${D}`]=t[D]})}clone(e){return new Ir(e).copy(this)}toJSON(e){return{id:this.id,uuid:this.uuid,head:this.head.toJSON(e)}}fromJSON(e,t,r){let n=new Bt(e.head.id,void 0,{type:e.head.type}).fromJSON(e.head,t),s=e.head.next,l=n;for(;s!=null;)l.next=new Bt(s.id,void 0,{type:s.type}).fromJSON(s,t),s=s.next,l=l.next;this._layerNodes=[],this.head=void 0,this.rebuildLayerNodes(this.head,n,!0);let c=n;for(l=this.head;c.next!=null;)this.rebuildLayerNodes(l,c.next,!0),l=l.next,c=c.next;return this._material=r,this.id=e.id,this.uuid=e.uuid,this.blendColors(),this.blendAfterColors(),this.blendPositions(),this}getLightLayer(){var t;let e=this.head;for(;e!==void 0&&e.type!=="light";)e=(t=e.next)!=null?t:e;return e}dispose(){let e=this.head;for(this._layerNodes=[],this.layerCount=0;e!==void 0;)e.hasOwnProperty("dispose")===!0&&e.dispose(),e=e.next;this.head=void 0}_createLayer(e){var r,n,s,l,c,f,h,d,x,g,w,S,D,C,G,B,P,W,M,q,E,b,R,T,z,A,$,he,re,Ne,ye,Me,Fe,k,H,_,J,ee,oe,se,ce,ue,K,ae,ne,Ce,Y,le,pe,xe,_e,de,we,Ve,Ge,Qe,bt,Lt,At,sr,Ur,Ht,kr,wn,Nn,dt,Wt,ar,Ao,Oo,Po,ro,no,Do,Mr,io,Jt,ti,Bo;let t=e.type;switch(t){case qe.COLOR:{let Ee=new vt((r=e.color)!=null?r:Yt),Xe=new ve((n=e.alpha)!=null?n:1),He=new xt("alpha / clamp(alpha + accumAlpha, 0.00001, 1.0 )","f");He.keywords.alpha=Xe;let $e=new Ye((s=e.mode)!=null?s:0);return Ee.alpha=Xe,{layer:new Bt(e.id,e.uuid,{type:t,color:Ee,alpha:Xe,calpha:He,mode:$e}),color:Ee,alpha:He,mode:$e}}case qe.TEXTURE:{let Ee=(l=e.texture)!=null?l:new bi,Xe=Ee.matrix;e.mat&&Xe.copy(e.mat),Ee.needsUpdate=!0;let He=new ve((c=e.crop)!=null?c:0),$e=new Ye((f=e.projection)!=null?f:0),tt=new Ye((h=e.axis)!=null?h:0),at=new _r(e.size?new Ki(e.size[0],e.size[1]):new Ki(100,100)),mt=new ve((d=e.alpha)!=null?d:1),gt=new Ye((x=e.mode)!=null?x:0),ct=new Fr(Ee),St=new Tr((g=e.textureSize)!=null?g:new Xi(Ee.image?Ee.image.width:0,Ee.image?Ee.image.height:0)),Rt=new gu(ct,St,He,$e,tt,at,mt,gt),Ar=new xt(Rt.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,texture:ct,textureSize:St,crop:He,projection:$e,axis:tt,size:at,mat:Rt.mat,alpha:mt,calpha:Ar,mode:gt}),color:Rt,alpha:Ar,mode:gt}}case qe.MATCAP:{let Ee=(w=e.texture)!=null?w:new bi;Ee.needsUpdate=!0;let Xe=new ve((S=e.alpha)!=null?S:1),He=new Fr(Ee),$e=new Ye((D=e.mode)!=null?D:0),tt=new Lu(He,Xe,$e),at=new xt(tt.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,texture:He,alpha:Xe,calpha:at,mode:$e}),color:tt,alpha:at,mode:$e}}case qe.FRESNEL:{let Ee=new vt((C=e.color)!=null?C:16777215),Xe=new ve((G=e.bias)!=null?G:.1),He=new ve((B=e.scale)!=null?B:1),$e=new ve((P=e.intensity)!=null?P:2),tt=new ve((W=e.factor)!=null?W:1),at=new ve((M=e.alpha)!=null?M:1),mt=new Ye((q=e.mode)!=null?q:0),gt=new yu(Ee,Xe,He,$e,tt,at,mt),ct=new xt(gt.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,color:Ee,bias:Xe,scale:He,intensity:$e,factor:tt,alpha:at,calpha:ct,mode:mt}),color:gt,alpha:ct,mode:mt}}case qe.RAINBOW:{let Ee=new ve((E=e.filmThickness)!=null?E:30),Xe=new ve((b=e.movement)!=null?b:0),He=new Tr((R=e.wavelengths)!=null?R:new Xi(0,0,0)),$e=new ve((T=e.noiseStrength)!=null?T:0),tt=new ve((z=e.noiseScale)!=null?z:1),at=new Tr((A=e.offset)!=null?A:new Xi(0,0,0)),mt=new ve(($=e.alpha)!=null?$:1),gt=new xu(Ee,Xe,He,$e,tt,at,mt),ct=new xt(gt.calpha,"f"),St=new Ye((he=e.mode)!=null?he:0);return{layer:new Bt(e.id,e.uuid,{type:t,filmThickness:Ee,movement:Xe,wavelengths:He,noiseStrength:$e,noiseScale:tt,offset:at,alpha:mt,calpha:ct,mode:St}),color:gt,alpha:ct,mode:St}}case qe.TRANSMISSION:{let Ee=new ve((re=e.thickness)!=null?re:10),Xe=new ve((Ne=e.ior)!=null?Ne:1.5),He=new ve((ye=e.roughness)!=null?ye:.5),$e=new _r((Me=e.transmissionSamplerSize)!=null?Me:new Ki(2048,2048)),tt=(Fe=e.transmissionSamplerMap)!=null?Fe:new bi,at=(k=e.transmissionDepthMap)!=null?k:new bi,mt=new Fr(tt),gt=new Fr(at),ct=window.innerWidth,St=window.innerHeight,Rt=ct>=St?new _r(St/ct,1):new _r(1,ct/St),Ar=new ve((H=e.alpha)!=null?H:1),Cn=new vu(Ee,Xe,He,$e,mt,gt,Rt,Ar),Ln=new xt(Cn.calpha,"f"),Rn=new Ye((_=e.mode)!=null?_:0);return{layer:new Bt(e.id,e.uuid,{type:t,thickness:Ee,ior:Xe,roughness:He,transmissionSamplerSize:$e,transmissionSamplerMap:mt,transmissionDepthMap:gt,aspectRatio:Rt,alpha:Ar,calpha:Ln,mode:Rn}),color:Cn,alpha:Ln,mode:Rn}}case qe.DEPTH:{let Ee=new Ye((J=e.gradientType)!=null?J:0),Xe=new mu((ee=e.smooth)!=null?ee:!1),He=new ve((oe=e.near)!=null?oe:50),$e=new ve((se=e.far)!=null?se:200),tt=new ve((ce=e.isVector)!=null?ce:1),at=new ve((ue=e.isWorldSpace)!=null?ue:0),mt=new Tr((K=e.origin)!=null?K:new Xi),gt=new Tr((ae=e.direction)!=null?ae:new Xi),ct=new Ye((ne=e.num)!=null?ne:0),St;e.colors?St=new Os(ct.value+1,e.colors):(St=new Os(ct.value+1,new _u(0,0,0,1)),St.value[1]=new _u(1,1,1,1));let Rt;e.steps?Rt=new Ps(e.steps.length,e.steps):(Rt=new Ps(10,1),Rt.value[0]=0);let Ar=new ve((Ce=e.alpha)!=null?Ce:1),Cn=new Ye((Y=e.mode)!=null?Y:0),Ln=new Cu(Ee,Xe,He,$e,tt,at,mt,gt,St,Rt,ct,Ar),Rn=new xt(Ln.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,gradientType:Ee,smooth:Xe,near:He,far:$e,isVector:tt,isWorldSpace:at,origin:mt,direction:gt,colors:St,steps:Rt,num:ct,alpha:Ar,calpha:Rn,mode:Cn}),color:Ln,alpha:Rn,mode:Cn}}case qe.NOISE:{let Ee=new ve((le=e.scale)!=null?le:1),Xe=new Tr((pe=e.size)!=null?pe:new Xi(100,100,100)),He=new ve((xe=e.move)!=null?xe:1),$e=new _r((_e=e.fA)!=null?_e:new Ki(1.7,9.2)),tt=new _r((de=e.fB)!=null?de:new Ki(8.3,2.8)),at=new _r((we=e.distortion)!=null?we:new Ki(1,1)),mt=new Ji(e.colorA),gt=new Ji(e.colorB),ct=new Ji(e.colorC),St=new Ji(e.colorD),Rt=new ve((Ve=e.alpha)!=null?Ve:1),Ar=new Ye((Ge=e.mode)!=null?Ge:0),Cn=new Ye((Qe=e.noiseType)!=null?Qe:0),Ln=new wu(Ee,Xe,He,$e,tt,at,mt,gt,ct,St,Rt,Cn),Rn=new xt(Ln.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,scale:Ee,size:Xe,move:He,fA:$e,fB:tt,distortion:at,colorA:mt,colorB:gt,colorC:ct,colorD:St,alpha:Rt,calpha:Rn,mode:Ar,noiseType:Cn}),color:Ln,alpha:Rn,mode:Ar}}case qe.NORMAL:{let Ee=new Tr((bt=e.cnormal)!=null?bt:new Xi(1,1,1)),Xe=new ve((Lt=e.alpha)!=null?Lt:1),He=new Ye((At=e.mode)!=null?At:0),$e=new bu(Ee,Xe),tt=new xt("alpha / clamp(alpha + accumAlpha, 0.00001, 1.0 )","f");return tt.keywords.alpha=Xe,{layer:new Bt(e.id,e.uuid,{type:t,cnormal:Ee,alpha:Xe,calpha:tt,mode:He}),color:$e,alpha:tt,mode:He}}case qe.GRADIENT:{let Ee=new Ye((sr=e.gradientType)!=null?sr:0),Xe=new mu((Ur=e.smooth)!=null?Ur:!1),He;e.colors?He=new Os(e.colors.length,e.colors):(He=new Os(10,new _u(0,0,0,1)),He.value[1]=new _u(1,1,1,1));let $e;e.steps?$e=new Ps(e.steps.length,e.steps):($e=new Ps(10,1),$e.value[0]=0);let tt=new _r((Ht=e.offset)!=null?Ht:new Ki(0,0)),at=new _r((kr=e.morph)!=null?kr:new Ki(0,0)),mt=new ve((wn=e.angle)!=null?wn:0),gt=new ve((Nn=e.alpha)!=null?Nn:1),ct=new Ye((dt=e.mode)!=null?dt:0),St=new Su(Ee,Xe,He,$e,tt,at,mt,gt),Rt=new xt(St.calpha,"f");return{layer:new Bt(e.id,e.uuid,{type:t,gradientType:Ee,smooth:Xe,colors:He,steps:$e,offset:tt,morph:at,angle:mt,alpha:gt,calpha:Rt,mode:ct}),color:St,alpha:Rt,mode:ct}}case qe.DISPLACE:{let Ee=new Ye((Wt=e.displacementType)!=null?Wt:0);if(Ee.value===0){let Xe=new Tr((ar=e.offset)!=null?ar:new Xi(0,0,0)),He=new ve((Ao=e.scale)!=null?Ao:10),$e=new ve((Oo=e.intensity)!=null?Oo:8),tt=new ve((Po=e.movement)!=null?Po:1),at=new ve((ro=e.alpha)!=null?ro:1),mt=new Ye((no=e.mode)!=null?no:0),gt=new Ye((Do=e.noiseType)!=null?Do:0),ct=new Da(Ee,$e,tt,Xe,He,gt);return{layer:new Bt(e.id,e.uuid,{displacementType:Ee,type:t,offset:Xe,scale:He,intensity:$e,movement:tt,alpha:at,mode:mt,noiseType:gt}),position:ct}}else if(Ee.value===1){let Xe=(Mr=e.texture)!=null?Mr:new bi,He=Xe.matrix;e.mat&&He.copy(e.mat),Xe.needsUpdate=!0;let $e=new ve((io=e.intensity)!=null?io:8),tt=new Fr(Xe),at=new ve((Jt=e.crop)!=null?Jt:0),mt=new ve((ti=e.alpha)!=null?ti:1),gt=new Ye((Bo=e.mode)!=null?Bo:0),ct=new Da(Ee,$e,tt,at);return{layer:new Bt(e.id,e.uuid,{displacementType:Ee,type:t,intensity:$e,texture:tt,crop:at,mat:ct.mat,alpha:mt,mode:gt}),position:ct}}return{}}}return{}}blendColors(){let e=this._layerNodes.findIndex(r=>r.type===Mt.COLOR),t=this._layerNodes.findIndex(r=>r.type===Mt.LIGHTING);if(e!==-1&&e<t){let r=this._layerNodes[e].color;for(let n=e+1;n<t;++n){let s=this._layerNodes[n];s.type===Mt.COLOR&&(r=new Nu(r,s.color,s.alpha,s.mode))}this._material.color=r}else this._material.color=void 0}blendAfterColors(){let e=new xt("outgoingLight","f"),t=this._layerNodes.findIndex(r=>r.type===Mt.LIGHTING);if(this._layerNodes.length>t+1){for(let r=t+1;r<this._layerNodes.length;++r){let n=this._layerNodes[r];n.type===Mt.COLOR&&(e=new Nu(e,n.color,n.alpha,n.mode))}"afterColor"in this._material&&(this._material.afterColor=e)}else"afterColor"in this._material&&(this._material.afterColor=void 0)}blendPositions(){let e=this._layerNodes.filter(t=>t.type===Mt.POSITION);if(e.length>0){let t=e[0].position;for(let r=1;r<e.length;++r)e[r]&&(t=new rn(t,e[r].position,rn.ADD),t=new rn(t,new ve(.5).setReadonly(!0),rn.MUL));this._material.position=t}else this._material.position=void 0}cleanupChangedLayer(e){switch(this._layerNodes=this._layerNodes.filter(t=>t.id!==e.id),e.type){case qe.DISPLACE:{this.blendPositions();break}default:{this.blendColors(),this.blendAfterColors();break}}}};var vn=class extends LD{constructor(e,t,r){super(r);this.isNodeMaterial=!0;this.type="NodeMaterial";this.wireframeLinecap="";this.wireframeLinejoin="";this.uniformsBackup={};this.userData={type:"",category:"",nodeType:""};this.fog=!0,this.vertex=e!=null?e:new du(new xr(xr.PROJECTION)),this.fragment=t!=null?t:new du(new vt(Yt)),this.updaters=[],this.isDetached=!0,this.dithering=!0,this.onBeforeCompile=this._onBeforeCompile}getDefines(){return this.defines}getUniforms(){return this.uniforms}getVertexShader(){return this.vertexShader}getFragmentShader(){return this.fragmentShader}_onBeforeCompile(e,t){this.build({renderer:t}),e.defines=this.defines,e.uniforms=this.uniforms,e.vertexShader=this.vertexShader,e.fragmentShader=this.fragmentShader,e.extensionDerivatives=this.extensions.derivatives===!0,e.extensionFragDepth=this.extensions.fragDepth===!0,e.extensionDrawBuffers=this.extensions.drawBuffers===!0,e.extensionShaderTextureLOD=this.extensions.shaderTextureLOD===!0}_getLayerStack(e){let t=new Ir(this);return e&&(async()=>{for(;e.image===void 0;)await new Promise(r=>requestAnimationFrame(r));t.addLayerAt(1,{type:qe.TEXTURE,texture:e}),this.dispose()})(),t}clampUniformsForPreview(e,t){let r=(n,s,l)=>Math.min(Math.max(n,s),l);if(this.userData.layers){for(let n of this.userData.layers.getLayers())if(n.type==qe.DISPLACE){this.uniformsBackup[`f${n.id}_intensity`]=n.uniforms[`f${n.id}_intensity`].value;let s=r(n.uniforms[`f${n.id}_intensity`].value,e,t);n.uniforms[`f${n.id}_intensity`].value=s}}}restoreClampedUniforms(){if(this.userData.layers)for(let e of this.userData.layers.getLayers())e.type==qe.DISPLACE&&(e.uniforms[`f${e.id}_intensity`].value=this.uniformsBackup[`f${e.id}_intensity`])}customProgramCacheKey(){return this.getHash()}updateFrame(e){for(let t=0;t<this.updaters.length;++t)e.updateNode(this.updaters[t])}build(e){var r;e=e!=null?e:{};let t=(r=e.builder)!=null?r:new ip;return t.setMaterial(this,e.renderer),t.build(this.vertex,this.fragment),this.vertexShader=t.getCode("vertex"),this.fragmentShader=t.getCode("fragment"),this.defines=t.defines,this.uniforms=t.uniforms,this.extensions=t.extensions,this.updaters=t.updaters,this.fog=t.requires.fog,this.lights=t.requires.lights,this.transparent=t.requires.transparent||this.blending>CD,this}getHash(){let e="{";return e+='"vertex":'+this.vertex.getHash()+",",e+='"fragment":'+this.fragment.getHash(),e+="}",e}copy(e){let t=this.uuid;for(let r in e)this[r]=e[r];return this.uuid=t,e.userData!==void 0&&(this.userData=JSON.parse(JSON.stringify(e.userData))),this}toJSON(e){let t=this.userData.layers;this.userData.layers=void 0;let r=super.toJSON(e);return r.type="ShaderMaterial",r.userData={type:this.userData.type,category:this.userData.category,nodeType:this.type,layers:t.toJSON(e)},r.vertex=this.vertex.toJSON(e).uuid,r.fragment=this.fragment.toJSON(e).uuid,delete r.vertexShader,delete r.fragmentShader,delete r.color,delete r.shininess,delete r.specular,delete r.roughness,delete r.metalness,delete r.uniforms,e&&!e.materials[this.uuid]&&(e.materials[this.uuid]=r),this.userData.layers=t,r}fromJSON(e,t){var r;this.defines=(r=e.defines)!=null?r:{},this.depthFunc=e.depthFunc,this.depthWrite=e.depthWrite,this.side=e.side!==void 0?e.side:_D,this.transparent=e.transparent,this.wireframeLinecap=e.wireframeLinecap,this.wireframeLinejoin=e.wireframeLinejoin,this.flatShading=e.flatShading,this.wireframe=e.wireframe,this.userData.layers.fromJSON(e.userData.layers,t,this)}};Object.defineProperties(vn.prototype,{properties:{get:function(){return this.fragment.properties}},needsUpdate:{set:function(i){i===!0&&this.version++,this.needsCompile=i},get:function(){return this.needsCompile}}});import{UniformsLib as TD,UniformsUtils as ID}from"three";var hp=class extends Pe{constructor(){super("basic");this.nodeType="Basic";this.color=new vt(Yt)}generate(e){let t;if(e.isShader("vertex")){let r=this.position?this.position.analyzeAndFlow(e,"v3",{cache:"position"}):void 0;e.mergeUniform(ID.merge([TD.fog])),e.addParsCode(["varying vec3 vViewPosition;","#include <fog_pars_vertex>","#include <normal_pars_vertex>"].join(`
|
|
729
729
|
`));let n=["#include <beginnormal_vertex>",`
|
|
730
730
|
#if !defined( USE_LAYER_DISPLACE )
|
|
731
731
|
#include <defaultnormal_vertex>
|
|
@@ -745,7 +745,7 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
745
745
|
`];r&&n.push(r.code,r.result?"displaced_position = "+r.result+";":""),n.push("transformed = displaced_position;","transformedNormal = normalMatrix * displaced_normal;","#ifndef FLAT_SHADED"," vNormal = transformedNormal;","#endif"),n.push("#include <project_vertex>","#include <fog_vertex>","#include <clipping_planes_vertex>"," vViewPosition = - mvPosition.xyz;","#include <worldpos_vertex>"),t=n.join(`
|
|
746
746
|
`)}else{this.color===void 0&&(this.color=new vt(Yt)),this.color.analyze(e,{slot:"color"}),this.alpha&&this.alpha.analyze(e),this.afterColor&&this.afterColor.analyze(e,{slot:"afterColor"});let r=this.color.flow(e,"c",{slot:"color"}),n=this.alpha?this.alpha.flow(e,"f"):void 0,s=this.afterColor?this.afterColor.flow(e,"c",{slot:"afterColor"}):void 0;e.requires.transparent=n!==void 0,e.addParsCode(["#include <fog_pars_fragment>","#include <dithering_pars_fragment>","varying vec3 vViewPosition;","#include <normal_pars_fragment>"].join(`
|
|
747
747
|
`));let l=["#include <normal_fragment_begin>",r.code];n&&l.push(n.code,"#ifdef ALPHATEST"," if ( "+n.result+" <= ALPHATEST ) discard;","#endif"),s?l.push(s.code,`vec3 outgoingLight = ${r.result};`,`vec3 finalColor = spe_blend(outgoingLight, ${s.result}, 1.0, SPE_BLENDING_NORMAL);`):l.push(`vec3 finalColor = ${r.result};`),n?l.push(`gl_FragColor = vec4( finalColor, accumAlpha * ${n.result} );`):l.push("gl_FragColor = vec4("+r.result+", 1.0 );"),l.push("#include <fog_fragment>","#include <dithering_fragment>"),t=l.join(`
|
|
748
|
-
`)}return t}copy(e){return super.copy(e),e.color&&(this.color=e.color.clone()),e.position&&(this.position=e.position.clone()),e.alpha&&(this.alpha=e.alpha.clone()),e.afterColor&&(this.afterColor=e.afterColor.clone()),e.shadingAlpha&&(this.shadingAlpha=e.shadingAlpha.clone()),e.shadingBlend&&(this.shadingBlend=e.shadingBlend.clone()),this}};var
|
|
748
|
+
`)}return t}copy(e){return super.copy(e),e.color&&(this.color=e.color.clone()),e.position&&(this.position=e.position.clone()),e.alpha&&(this.alpha=e.alpha.clone()),e.afterColor&&(this.afterColor=e.afterColor.clone()),e.shadingAlpha&&(this.shadingAlpha=e.shadingAlpha.clone()),e.shadingBlend&&(this.shadingBlend=e.shadingBlend.clone()),this}};var pp=class extends vn{get color(){return this.fragment.color}set color(e){this.fragment.color=e}get afterColor(){return this.fragment.afterColor}set afterColor(e){this.fragment.afterColor=e}get alpha(){return this.fragment.alpha}set alpha(e){this.fragment.alpha=e}get shadingAlpha(){return this.fragment.shadingAlpha}set shadingAlpha(e){this.fragment.shadingAlpha=e}get shadingBlend(){return this.fragment.shadingBlend}set shadingBlend(e){this.fragment.shadingBlend=e}get position(){return this.fragment.position}set position(e){this.fragment.position=e}constructor(e=new hp,t){super(e,e,t);this.type="BasicNodeMaterial",this.fragment=e}};var vr=class extends pp{constructor(e,t,r){super(t,e);this.userData.type="BasicMaterial",this.userData.category="Basic",this.userData.layers=r!=null?r:this._getLayerStack(e==null?void 0:e.map)}get layersList(){return this.userData.layers}set layersList(e){this.userData.layers=e}equals(e){return this.userData.type===e.userData.type&&this.userData.layers.uuid==e.userData.layers.uuid}copy(e){if(e.userData.layers!==void 0&&e.userData.layers instanceof Ir){let t=e.userData.layers,r=e.fragment;super.copy(e);let n=r.clone();this.fragment=n,this.vertex=n;let s=t.clone(this);this.userData.layers=s}else super.copy(e);return this}static fromJSON(e,t,r){let n=r.getNode(t.vertex),s=new vr(void 0,n);return s.fromJSON(t,r),s}static fromMaterial(e){let t=new vr(e.map?{map:e.map}:{}),r=t.fragment;return r.color.value.copy(e.color),r.alpha.value=e.opacity,t}dispose(){super.dispose()}};import{UniformsLib as Lv,UniformsUtils as MD}from"three";var dp=class extends Pe{constructor(){super("phong");this.nodeType="Phong";this.color=new vt(Yt),this.specular=new vt(1118481),this.shininess=new ve(30),this.shadingAlpha=new ve(1),this.shadingBlend=new Ye(0)}build(e){let t;if(e.define("PHONG"),e.requires.lights=!0,e.extensions.derivatives=!0,e.isShader("vertex")){let r=this.position?this.position.analyzeAndFlow(e,"v3",{cache:"position"}):void 0;e.mergeUniform(MD.merge([Lv.fog,Lv.lights])),e.addParsCode(["varying vec3 vViewPosition;","#include <fog_pars_vertex>","#include <normal_pars_vertex>","#include <shadowmap_pars_vertex>","#include <clipping_planes_pars_vertex>"].join(`
|
|
749
749
|
`));let n=["#include <beginnormal_vertex>",`
|
|
750
750
|
#ifndef USE_LAYER_DISPLACE
|
|
751
751
|
#include <defaultnormal_vertex>
|
|
@@ -764,7 +764,7 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
764
764
|
#endif
|
|
765
765
|
`];r&&n.push(r.code,r.result?"displaced_position = "+r.result+";":""),n.push("transformed = displaced_position;","transformedNormal = normalMatrix * displaced_normal;","#ifndef FLAT_SHADED"," vNormal = transformedNormal;","#endif"),n.push(" #include <project_vertex>"," #include <clipping_planes_vertex>"," vViewPosition = - mvPosition.xyz;"," #include <worldpos_vertex>"," #include <shadowmap_vertex>"," #include <fog_vertex>"),t=n.join(`
|
|
766
766
|
`)}else{this.color===void 0&&(this.color=new vt(Yt)),this.color.analyze(e,{slot:"color"}),this.specular.analyze(e),this.shininess.analyze(e),this.shadingAlpha.analyze(e),this.shadingBlend.analyze(e),this.afterColor&&this.afterColor.analyze(e,{slot:"afterColor"}),this.alpha&&this.alpha.analyze(e);let r=this.color.flow(e,"c",{slot:"color"}),n=this.specular.flow(e,"c"),s=this.shininess.flow(e,"f"),l=this.shadingAlpha.flow(e,"f"),c=this.shadingBlend.flow(e,"i"),f=this.afterColor?this.afterColor.flow(e,"c",{slot:"afterColor"}):void 0,h=this.alpha?this.alpha.flow(e,"f"):void 0;e.requires.transparent=h!==void 0,e.addParsCode(["uniform vec3 emissive;","#include <normal_pars_fragment>","#include <fog_pars_fragment>","#include <bsdfs>","#include <lights_pars_begin>","#include <lights_phong_pars_fragment>","#include <shadowmap_pars_fragment>","#include <dithering_pars_fragment>"].join(`
|
|
767
|
-
`));let
|
|
767
|
+
`));let d=["#include <normal_fragment_begin>",`
|
|
768
768
|
// NOTE: gl_FrontFacing alternative using face normal estimation.
|
|
769
769
|
vec3 viewdx = dFdx(vViewPosition);
|
|
770
770
|
vec3 viewdy = dFdy(vViewPosition);
|
|
@@ -772,14 +772,14 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
772
772
|
if (dot(normal, faceNormal) < 0.0) {
|
|
773
773
|
normal *= -1.0;
|
|
774
774
|
}
|
|
775
|
-
`," BlinnPhongMaterial material;"];
|
|
775
|
+
`," BlinnPhongMaterial material;"];d.push(r.code," vec3 diffuseColor = "+r.result+";"," ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );"," vec3 totalEmissiveRadiance = emissive;",n.code," vec3 specular = "+n.result+";",s.code," float shininess = max( 0.0001, "+s.result+" );"," float specularStrength = 1.0;"),h&&d.push(h.code,"#ifdef ALPHATEST","if ( "+h.result+" <= ALPHATEST ) discard;","#endif"),d.push("material.diffuseColor = diffuseColor;"),d.push("material.specularColor = specular;","material.specularShininess = shininess;","material.specularStrength = specularStrength;","#include <lights_fragment_begin>","#include <lights_fragment_end>"),d.push("vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;"),d.push(`
|
|
776
776
|
if (outgoingLight != diffuseColor) {
|
|
777
777
|
float lightAccu = clamp( length( reflectedLight.directSpecular + reflectedLight.indirectSpecular ), 0.0, 1.0 );
|
|
778
778
|
accumAlpha += ( 1.0 - accumAlpha ) * ${l.result} * lightAccu;
|
|
779
779
|
outgoingLight = spe_blend( diffuseColor, outgoingLight, ${l.result}, ${c.result} );
|
|
780
780
|
}
|
|
781
|
-
`),f&&
|
|
782
|
-
`)}return t}copy(e){return super.copy(e),e.color&&(this.color=e.color.clone()),this.specular=e.specular.clone(),this.shininess=e.shininess.clone(),e.position&&(this.position=e.position.clone()),e.afterColor&&(this.afterColor=e.afterColor.clone()),e.alpha&&(this.alpha=e.alpha.clone()),e.shadingAlpha&&(this.shadingAlpha=e.shadingAlpha.clone()),e.shadingBlend&&(this.shadingBlend=e.shadingBlend.clone()),this}};var
|
|
781
|
+
`),f&&d.push(f.code,`outgoingLight = spe_blend(outgoingLight, ${f.result}, 1.0, SPE_BLENDING_NORMAL);`),h?d.push(`gl_FragColor = vec4( outgoingLight, accumAlpha * ${h.result} );`):d.push("gl_FragColor = vec4( outgoingLight, 1.0 );"),d.push("#include <encodings_fragment>","#include <fog_fragment>","#include <dithering_fragment>"),t=d.join(`
|
|
782
|
+
`)}return t}copy(e){return super.copy(e),e.color&&(this.color=e.color.clone()),this.specular=e.specular.clone(),this.shininess=e.shininess.clone(),e.position&&(this.position=e.position.clone()),e.afterColor&&(this.afterColor=e.afterColor.clone()),e.alpha&&(this.alpha=e.alpha.clone()),e.shadingAlpha&&(this.shadingAlpha=e.shadingAlpha.clone()),e.shadingBlend&&(this.shadingBlend=e.shadingBlend.clone()),this}};var mp=class extends vn{get color(){return this.fragment.color}set color(e){this.fragment.color=e}get afterColor(){return this.fragment.afterColor}set afterColor(e){this.fragment.afterColor=e}get alpha(){return this.fragment.alpha}set alpha(e){this.fragment.alpha=e}get shadingAlpha(){return this.fragment.shadingAlpha}set shadingAlpha(e){this.fragment.shadingAlpha=e}get shadingBlend(){return this.fragment.shadingBlend}set shadingBlend(e){this.fragment.shadingBlend=e}get position(){return this.fragment.position}set position(e){this.fragment.position=e}get specular(){return this.fragment.specular}set specular(e){this.fragment.specular=e}get shininess(){return this.fragment.shininess}set shininess(e){this.fragment.shininess=e}constructor(e=new dp,t){super(e,e,t);this.type="PhongNodeMaterial",this.fragment=e}};var bn=class extends mp{constructor(e,t,r){super(t,e);this.userData.type="PhongMaterial",this.userData.category="Phong",this.userData.layers=r!=null?r:this._getLayerStack(e==null?void 0:e.map)}get layersList(){return this.userData.layers}set layersList(e){this.userData.layers=e}equals(e){return this.userData.type===e.userData.type&&this.userData.layers.uuid==e.userData.layers.uuid}copy(e){if(e.userData.layers!==void 0&&e.userData.layers instanceof Ir){let t=e.userData.layers,r=e.fragment;super.copy(e);let n=r.clone();this.fragment=n,this.vertex=n;let s=t.clone(this);this.userData.layers=s,n.shadingAlpha.value=r.shadingAlpha.value,n.shadingBlend.value=r.shadingBlend.value}else super.copy(e);return this}static fromJSON(e,t,r){let n=r.getNode(t.vertex),s=new bn(void 0,n);return s.fromJSON(t,r),s}static fromMaterial(e){let t=new bn(e.map?{map:e.map}:{}),r=t.fragment;return r.color.value.copy(e.color),r.alpha.value=e.opacity,t}dispose(){super.dispose()}};import{UniformsLib as _v,UniformsUtils as AD}from"three";var gp=class extends Pe{constructor(){super("lambert");this.nodeType="Lambert";this.color=new vt(Yt),this.emissive=new vt(0),this.emissiveIntensity=new ve(1),this.shadingAlpha=new ve(1),this.shadingBlend=new Ye(0)}build(e){let t;if(e.define("LAMBERT"),e.requires.lights=!0,e.extensions.derivatives=!0,e.isShader("vertex")){let r=this.position?this.position.analyzeAndFlow(e,"v3",{cache:"position"}):void 0;e.mergeUniform(AD.merge([_v.fog,_v.lights])),e.addParsCode(["varying vec3 vViewPosition;","varying vec3 vLightFront;","varying vec3 vIndirectFront;","#ifndef DOUBLE_SIDED"," #define DOUBLE_SIDED","#endif","#ifdef DOUBLE_SIDED"," varying vec3 vLightBack;"," varying vec3 vIndirectBack;","#endif","#include <bsdfs>","#include <lights_pars_begin>","#include <color_pars_vertex>","#include <fog_pars_vertex>","#include <normal_pars_vertex>","#include <shadowmap_pars_vertex>","#include <clipping_planes_pars_vertex>"].join(`
|
|
783
783
|
`));let n=["#include <beginnormal_vertex>",`
|
|
784
784
|
#ifndef USE_LAYER_DISPLACE
|
|
785
785
|
#include <defaultnormal_vertex>
|
|
@@ -872,20 +872,20 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
872
872
|
#endif
|
|
873
873
|
`," #include <shadowmap_vertex>"," #include <fog_vertex>"),t=n.join(`
|
|
874
874
|
`)}else{this.color===void 0&&(this.color=new vt(Yt)),this.color.analyze(e,{slot:"color"}),this.shadingAlpha.analyze(e),this.shadingBlend.analyze(e),this.afterColor&&this.afterColor.analyze(e,{slot:"afterColor"}),this.alpha&&this.alpha.analyze(e);let r=this.color.flow(e,"c",{slot:"color"}),n=this.emissive.flow(e,"c",{slot:"emissive"}),s=this.emissiveIntensity.flow(e,"f",{slot:"emissive"}),l=this.shadingAlpha.flow(e,"f"),c=this.shadingBlend.flow(e,"i"),f=this.afterColor?this.afterColor.flow(e,"c",{slot:"afterColor"}):void 0,h=this.alpha?this.alpha.flow(e,"f"):void 0;e.requires.transparent=h!==void 0,e.addParsCode(["varying vec3 vViewPosition;","varying vec3 vLightFront;","varying vec3 vIndirectFront;","#ifndef DOUBLE_SIDED"," #define DOUBLE_SIDED","#endif","#include <normal_pars_fragment>","#ifdef DOUBLE_SIDED"," varying vec3 vLightBack;"," varying vec3 vIndirectBack;","#endif","#include <bsdfs>","#include <lights_pars_begin>","#include <fog_pars_fragment>","#include <shadowmap_pars_fragment>","#include <shadowmask_pars_fragment>","#include <clipping_planes_pars_fragment>","#include <dithering_pars_fragment>"].join(`
|
|
875
|
-
`));let
|
|
875
|
+
`));let d=["#include <normal_fragment_begin>",`
|
|
876
876
|
// NOTE: gl_FrontFacing alternative using face normal estimation.
|
|
877
877
|
vec3 viewdx = dFdx(vViewPosition);
|
|
878
878
|
vec3 viewdy = dFdy(vViewPosition);
|
|
879
879
|
vec3 faceNormal = normalize(cross(viewdx, viewdy));
|
|
880
880
|
bool isFrontFacing = (dot(normal, faceNormal) >= 0.0);
|
|
881
|
-
`,"#include <clipping_planes_fragment>"];
|
|
881
|
+
`,"#include <clipping_planes_fragment>"];d.push(r.code,"vec3 diffuseColor = "+r.result+";","ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );"),h&&d.push(h.code,"#ifdef ALPHATEST","if ( "+h.result+" <= ALPHATEST ) discard;","#endif"),d.push("#ifdef DOUBLE_SIDED"," reflectedLight.indirectDiffuse += ( isFrontFacing ) ? vIndirectFront : vIndirectBack;","#else"," reflectedLight.indirectDiffuse += vIndirectFront;","#endif","#include <lightmap_fragment>","reflectedLight.indirectDiffuse *= BRDF_Lambert( diffuseColor.rgb );","#ifdef DOUBLE_SIDED"," reflectedLight.directDiffuse = ( isFrontFacing ) ? vLightFront : vLightBack;","#else"," reflectedLight.directDiffuse = vLightFront;","#endif","reflectedLight.directDiffuse *= BRDF_Lambert( diffuseColor.rgb ) * getShadowMask();"),n&&d.push(n.code,"reflectedLight.directDiffuse += "+n.result+" * "+s.result+";"),d.push("vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse;"),d.push(`
|
|
882
882
|
if (outgoingLight != diffuseColor) {
|
|
883
883
|
float lightAccu = clamp( length( reflectedLight.directSpecular + reflectedLight.indirectSpecular ), 0.0, 1.0 );
|
|
884
884
|
accumAlpha += ( 1.0 - accumAlpha ) * ${l.result} * lightAccu;
|
|
885
885
|
outgoingLight = spe_blend( diffuseColor, outgoingLight, ${l.result}, ${c.result} );
|
|
886
886
|
}
|
|
887
|
-
`),f&&
|
|
888
|
-
`)}return t}copy(e){return super.copy(e),this.emissiveIntensity=e.emissiveIntensity.clone(),e.color&&(this.color=e.color.clone()),e.position&&(this.position=e.position.clone()),e.afterColor&&(this.afterColor=e.afterColor.clone()),e.alpha&&(this.alpha=e.alpha.clone()),e.shadingAlpha&&(this.shadingAlpha=e.shadingAlpha.clone()),e.shadingBlend&&(this.shadingBlend=e.shadingBlend.clone()),e.emissive&&(this.emissive=e.emissive.clone()),this}};var
|
|
887
|
+
`),f&&d.push(f.code,`outgoingLight = spe_blend(outgoingLight, ${f.result}, 1.0, SPE_BLENDING_NORMAL);`),h?d.push(`gl_FragColor = vec4( outgoingLight, accumAlpha * ${h.result} );`):d.push("gl_FragColor = vec4( outgoingLight, 1.0 );"),d.push("#include <encodings_fragment>","#include <fog_fragment>","#include <dithering_fragment>"),t=d.join(`
|
|
888
|
+
`)}return t}copy(e){return super.copy(e),this.emissiveIntensity=e.emissiveIntensity.clone(),e.color&&(this.color=e.color.clone()),e.position&&(this.position=e.position.clone()),e.afterColor&&(this.afterColor=e.afterColor.clone()),e.alpha&&(this.alpha=e.alpha.clone()),e.shadingAlpha&&(this.shadingAlpha=e.shadingAlpha.clone()),e.shadingBlend&&(this.shadingBlend=e.shadingBlend.clone()),e.emissive&&(this.emissive=e.emissive.clone()),this}};var yp=class extends vn{get color(){return this.fragment.color}set color(e){this.fragment.color=e}get afterColor(){return this.fragment.afterColor}set afterColor(e){this.fragment.afterColor=e}get alpha(){return this.fragment.alpha}set alpha(e){this.fragment.alpha=e}get shadingAlpha(){return this.fragment.shadingAlpha}set shadingAlpha(e){this.fragment.shadingAlpha=e}get shadingBlend(){return this.fragment.shadingBlend}set shadingBlend(e){this.fragment.shadingBlend=e}get position(){return this.fragment.position}set position(e){this.fragment.position=e}get emissive(){return this.fragment.emissive}set emissive(e){this.fragment.emissive=e}get emissiveIntensity(){return this.fragment.emissiveIntensity}set emissiveIntensity(e){this.fragment.emissiveIntensity=e}constructor(e=new gp,t){super(e,e,t);this.type="LambertNodeMaterial",this.fragment=e}};var Ba=class extends yp{constructor(e,t,r){super(t,e);this.userData.type="LambertMaterial",this.userData.category="Lambert",this.userData.layers=r!=null?r:this._getLayerStack(e==null?void 0:e.map)}get layersList(){return this.userData.layers}set layersList(e){this.userData.layers=e}equals(e){return this.userData.type===e.userData.type&&this.userData.layers.uuid==e.userData.layers.uuid}copy(e){if(e.userData.layers!==void 0&&e.userData.layers instanceof Ir){let t=e.userData.layers,r=e.fragment;super.copy(e);let n=r.clone();this.fragment=n,this.vertex=n;let s=t.clone(this);this.userData.layers=s,n.shadingAlpha.value=r.shadingAlpha.value,n.shadingBlend.value=r.shadingBlend.value}else super.copy(e);return this}static fromJSON(e,t,r){let n=r.getNode(t.vertex),s=new Ba(void 0,n);return s.fromJSON(t,r),s}dispose(){super.dispose()}};import{UniformsLib as Tv,UniformsUtils as OD}from"three";var xp=class extends Pe{constructor(){super("toon");this.nodeType="Toon";this.color=new vt(Yt),this.specular=new vt(1118481),this.shininess=new ve(30),this.shadingAlpha=new ve(1),this.shadingBlend=new Ye(0)}build(e){let t;if(e.define("TOON"),e.requires.lights=!0,e.extensions.derivatives=!0,e.isShader("vertex")){let r=this.position?this.position.analyzeAndFlow(e,"v3",{cache:"position"}):void 0;e.mergeUniform(OD.merge([Tv.fog,Tv.lights])),e.addParsCode(["varying vec3 vViewPosition;","#include <fog_pars_vertex>","#include <normal_pars_vertex>","#include <shadowmap_pars_vertex>","#include <clipping_planes_pars_vertex>"].join(`
|
|
889
889
|
`));let n=["#include <beginnormal_vertex>",`
|
|
890
890
|
#ifndef USE_LAYER_DISPLACE
|
|
891
891
|
#include <defaultnormal_vertex>
|
|
@@ -924,7 +924,7 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
924
924
|
#define RE_IndirectDiffuse RE_IndirectDiffuse_Toon
|
|
925
925
|
#define Material_LightProbeLOD( material ) (0)
|
|
926
926
|
`,"#include <shadowmap_pars_fragment>","#include <bumpmap_pars_fragment>","#include <normalmap_pars_fragment>"].join(`
|
|
927
|
-
`));let
|
|
927
|
+
`));let d=["#include <normal_fragment_begin>",`
|
|
928
928
|
// NOTE: gl_FrontFacing alternative using face normal estimation.
|
|
929
929
|
vec3 viewdx = dFdx(vViewPosition);
|
|
930
930
|
vec3 viewdy = dFdy(vViewPosition);
|
|
@@ -932,14 +932,14 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
932
932
|
if (dot(normal, faceNormal) < 0.0) {
|
|
933
933
|
normal *= -1.0;
|
|
934
934
|
}
|
|
935
|
-
`," ToonMaterial material;"];
|
|
935
|
+
`," ToonMaterial material;"];d.push(r.code," vec3 diffuseColor = "+r.result+";"," ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );",n.code," vec3 specular = "+n.result+";",s.code," float shininess = max( 0.0001, "+s.result+" );"," float specularStrength = 1.0;"),h&&d.push(h.code,"#ifdef ALPHATEST","if ( "+h.result+" <= ALPHATEST ) discard;","#endif"),d.push("material.diffuseColor = diffuseColor;"),d.push("material.specularColor = specular;","material.specularShininess = shininess;","material.specularStrength = specularStrength;","#include <lights_fragment_begin>","#include <lights_fragment_end>"),d.push("vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular;"),d.push(`
|
|
936
936
|
if (outgoingLight != diffuseColor) {
|
|
937
937
|
float lightAccu = clamp( length( reflectedLight.directSpecular + reflectedLight.indirectSpecular ), 0.0, 1.0 );
|
|
938
938
|
accumAlpha += ( 1.0 - accumAlpha ) * ${l.result} * lightAccu;
|
|
939
939
|
outgoingLight = spe_blend( diffuseColor, outgoingLight, ${l.result}, ${c.result} );
|
|
940
940
|
}
|
|
941
|
-
`),f&&
|
|
942
|
-
`)}return t}copy(e){return super.copy(e),e.color&&(this.color=e.color.clone()),this.specular=e.specular.clone(),this.shininess=e.shininess.clone(),e.position&&(this.position=e.position.clone()),e.afterColor&&(this.afterColor=e.afterColor.clone()),e.alpha&&(this.alpha=e.alpha.clone()),e.shadingAlpha&&(this.shadingAlpha=e.shadingAlpha.clone()),e.shadingBlend&&(this.shadingBlend=e.shadingBlend.clone()),this}};var
|
|
941
|
+
`),f&&d.push(f.code,`outgoingLight = spe_blend(outgoingLight, ${f.result}, 1.0, SPE_BLENDING_NORMAL);`),h?d.push(`gl_FragColor = vec4( outgoingLight, accumAlpha * ${h.result} );`):d.push("gl_FragColor = vec4( outgoingLight, 1.0 );"),d.push("#include <encodings_fragment>","#include <fog_fragment>","#include <dithering_fragment>"),t=d.join(`
|
|
942
|
+
`)}return t}copy(e){return super.copy(e),e.color&&(this.color=e.color.clone()),this.specular=e.specular.clone(),this.shininess=e.shininess.clone(),e.position&&(this.position=e.position.clone()),e.afterColor&&(this.afterColor=e.afterColor.clone()),e.alpha&&(this.alpha=e.alpha.clone()),e.shadingAlpha&&(this.shadingAlpha=e.shadingAlpha.clone()),e.shadingBlend&&(this.shadingBlend=e.shadingBlend.clone()),this}};var vp=class extends vn{get color(){return this.fragment.color}set color(e){this.fragment.color=e}get afterColor(){return this.fragment.afterColor}set afterColor(e){this.fragment.afterColor=e}get alpha(){return this.fragment.alpha}set alpha(e){this.fragment.alpha=e}get shadingAlpha(){return this.fragment.shadingAlpha}set shadingAlpha(e){this.fragment.shadingAlpha=e}get shadingBlend(){return this.fragment.shadingBlend}set shadingBlend(e){this.fragment.shadingBlend=e}get position(){return this.fragment.position}set position(e){this.fragment.position=e}get specular(){return this.fragment.specular}set specular(e){this.fragment.specular=e}get shininess(){return this.fragment.shininess}set shininess(e){this.fragment.shininess=e}constructor(e=new xp,t){super(e,e,t);this.type="ToonNodeMaterial",this.fragment=e}};var Ga=class extends vp{constructor(e,t,r){super(t,e);this.userData.type="ToonMaterial",this.userData.category="Toon",this.userData.layers=r!=null?r:this._getLayerStack(e==null?void 0:e.map)}get layersList(){return this.userData.layers}set layersList(e){this.userData.layers=e}equals(e){return this.userData.type===e.userData.type&&this.userData.layers.uuid==e.userData.layers.uuid}copy(e){if(e.userData.layers!==void 0&&e.userData.layers instanceof Ir){let t=e.userData.layers,r=e.fragment;super.copy(e);let n=r.clone();this.fragment=n,this.vertex=n;let s=t.clone(this);this.userData.layers=s,n.shadingAlpha.value=r.shadingAlpha.value,n.shadingBlend.value=r.shadingBlend.value}else super.copy(e);return this}static fromJSON(e,t,r){let n=r.getNode(t.vertex),s=new Ga(void 0,n);return s.fromJSON(t,r),s}dispose(){super.dispose()}};import{UniformsLib as bp,UniformsUtils as PD}from"three";var Sp=class extends Pe{constructor(){super("standard");this.nodeType="Standard";this.color=new vt(Yt),this.roughness=new ve(.3),this.metalness=new ve(0),this.reflectivity=new ve(.5),this.shadingAlpha=new ve(1),this.shadingBlend=new Ye(0)}build(e){let t;if(e.define("STANDARD"),e.requires.lights=!0,e.extensions.derivatives=!0,e.extensions.shaderTextureLOD=!0,e.isShader("vertex")){let r=this.position?this.position.analyzeAndFlow(e,"v3",{cache:"position"}):void 0;e.mergeUniform(PD.merge([bp.fog,bp.lights])),bp.LTC_1&&(e.uniforms.ltc_1={value:void 0},e.uniforms.ltc_2={value:void 0}),e.addParsCode(["varying vec3 vViewPosition;","#include <fog_pars_vertex>","#include <normal_pars_vertex>","#include <shadowmap_pars_vertex>","#include <clipping_planes_pars_vertex>"].join(`
|
|
943
943
|
`));let n=["#include <beginnormal_vertex>",`
|
|
944
944
|
#if !defined( USE_LAYER_DISPLACE )
|
|
945
945
|
#include <defaultnormal_vertex>
|
|
@@ -957,7 +957,7 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
957
957
|
#include <begin_vertex>
|
|
958
958
|
#endif /* !USE_LAYER_DISPLACE */
|
|
959
959
|
`];r&&n.push(r.code,r.result?"displaced_position = "+r.result+";":""),n.push("transformed = displaced_position;","transformedNormal = normalMatrix * displaced_normal;","#ifndef FLAT_SHADED"," vNormal = transformedNormal;","#endif"),n.push("#include <project_vertex>","#include <fog_vertex>","#include <clipping_planes_vertex>"," vViewPosition = - mvPosition.xyz;","#include <worldpos_vertex>","#include <shadowmap_vertex>"),t=n.join(`
|
|
960
|
-
`)}else{let r={gamma:!0};this.color===void 0&&(this.color=new vt(Yt)),this.color.analyze(e,{slot:"color",context:r}),this.roughness.analyze(e),this.metalness.analyze(e),this.shadingAlpha.analyze(e),this.shadingBlend.analyze(e),this.afterColor&&this.afterColor.analyze(e,{slot:"afterColor"}),this.alpha&&this.alpha.analyze(e),this.reflectivity&&this.reflectivity.analyze(e);let n=this.color.flow(e,"c",{slot:"color",context:r}),s=this.roughness.flow(e,"f"),l=this.metalness.flow(e,"f"),c=this.shadingAlpha.flow(e,"f"),f=this.shadingBlend.flow(e,"i"),h=this.afterColor?this.afterColor.flow(e,"c",{slot:"afterColor"}):void 0,
|
|
960
|
+
`)}else{let r={gamma:!0};this.color===void 0&&(this.color=new vt(Yt)),this.color.analyze(e,{slot:"color",context:r}),this.roughness.analyze(e),this.metalness.analyze(e),this.shadingAlpha.analyze(e),this.shadingBlend.analyze(e),this.afterColor&&this.afterColor.analyze(e,{slot:"afterColor"}),this.alpha&&this.alpha.analyze(e),this.reflectivity&&this.reflectivity.analyze(e);let n=this.color.flow(e,"c",{slot:"color",context:r}),s=this.roughness.flow(e,"f"),l=this.metalness.flow(e,"f"),c=this.shadingAlpha.flow(e,"f"),f=this.shadingBlend.flow(e,"i"),h=this.afterColor?this.afterColor.flow(e,"c",{slot:"afterColor"}):void 0,d=this.alpha?this.alpha.flow(e,"f"):void 0,x=this.reflectivity?this.reflectivity.flow(e,"f"):void 0;e.requires.transparent=d!==void 0,e.addParsCode(["varying vec3 vViewPosition;","#include <normal_pars_fragment>","#include <dithering_pars_fragment>","#include <fog_pars_fragment>","#include <bsdfs>","#include <lights_pars_begin>","#include <lights_physical_pars_fragment>","#include <shadowmap_pars_fragment>"].join(`
|
|
961
961
|
`));let g=["#include <clipping_planes_fragment>"," #include <normal_fragment_begin>",`
|
|
962
962
|
// NOTE: gl_FrontFacing alternative using face normal estimation.
|
|
963
963
|
vec3 viewdx = dFdx(vViewPosition);
|
|
@@ -966,12 +966,12 @@ vec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 position, mat
|
|
|
966
966
|
if (dot(normal, faceNormal) < 0.0) {
|
|
967
967
|
normal *= -1.0;
|
|
968
968
|
}
|
|
969
|
-
`," PhysicalMaterial material;"," material.diffuseColor = vec3( 1.0 );"];g.push(n.code," vec3 diffuseColor = "+n.result+";"," ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );",s.code," float roughnessFactor = "+s.result+";",l.code," float metalnessFactor = "+l.result+";"),
|
|
969
|
+
`," PhysicalMaterial material;"," material.diffuseColor = vec3( 1.0 );"];g.push(n.code," vec3 diffuseColor = "+n.result+";"," ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );",s.code," float roughnessFactor = "+s.result+";",l.code," float metalnessFactor = "+l.result+";"),d&&g.push(d.code,"#ifdef ALPHATEST"," if ( "+d.result+" <= ALPHATEST ) discard;","#endif"),g.push("vec3 dxy = max( abs( dFdx( geometryNormal ) ), abs( dFdy( geometryNormal ) ) );","float geometryRoughness = max( max( dxy.x, dxy.y ), dxy.z );"),g.push("material.diffuseColor = diffuseColor * ( 1.0 - metalnessFactor );","material.roughness = max( roughnessFactor, 0.0525 );","material.roughness += geometryRoughness;","material.roughness = min( material.roughness, 1.0 );","material.roughness = clamp( roughnessFactor, 0.04, 1.0 );"),x?g.push(x.code,"material.specularColor = mix( vec3( 0.16 * pow2( "+x.result+" ) ), diffuseColor, metalnessFactor );"):g.push("material.specularColor = mix( vec3( 0.04 ), diffuseColor, metalnessFactor );"),g.push("#include <lights_fragment_begin>"),g.push("#include <lights_fragment_end>"),g.push("vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular;"),g.push(`
|
|
970
970
|
if (outgoingLight != diffuseColor) {
|
|
971
971
|
float lightAccu = clamp( length( reflectedLight.directSpecular + reflectedLight.indirectSpecular ), 0.0, 1.0 );
|
|
972
972
|
accumAlpha += ( 1.0 - accumAlpha ) * ${c.result} * lightAccu;
|
|
973
973
|
outgoingLight = spe_blend( diffuseColor, outgoingLight, ${c.result}, ${f.result} );
|
|
974
974
|
}
|
|
975
|
-
`),h&&g.push(h.code,`outgoingLight = spe_blend(outgoingLight, ${h.result}, 1.0, SPE_BLENDING_NORMAL);`),
|
|
976
|
-
`)}return t}copy(e){return super.copy(e),e.color&&(this.color=e.color.clone()),this.roughness=e.roughness.clone(),this.metalness=e.metalness.clone(),e.position&&(this.position=e.position.clone()),e.afterColor&&(this.afterColor=e.afterColor.clone()),e.alpha&&(this.alpha=e.alpha.clone()),e.reflectivity&&(this.reflectivity=e.reflectivity.clone()),e.shadingAlpha&&(this.shadingAlpha=e.shadingAlpha.clone()),e.shadingBlend&&(this.shadingBlend=e.shadingBlend.clone()),this}};var Ad=class extends bn{get color(){return this.fragment.color}set color(e){this.fragment.color=e}get afterColor(){return this.fragment.afterColor}set afterColor(e){this.fragment.afterColor=e}get alpha(){return this.fragment.alpha}set alpha(e){this.fragment.alpha=e}get shadingAlpha(){return this.fragment.shadingAlpha}set shadingAlpha(e){this.fragment.shadingAlpha=e}get shadingBlend(){return this.fragment.shadingBlend}set shadingBlend(e){this.fragment.shadingBlend=e}get position(){return this.fragment.position}set position(e){this.fragment.position=e}get roughness(){return this.fragment.roughness}set roughness(e){this.fragment.roughness=e}get metalness(){return this.fragment.metalness}set metalness(e){this.fragment.metalness=e}get reflectivity(){return this.fragment.reflectivity}set reflectivity(e){this.fragment.reflectivity=e}constructor(e=new Md,t){super(e,e,t);this.type="StandardNodeMaterial",this.fragment=e}};var Ra=class extends Ad{constructor(e,t,r){super(t,e);this.userData.type="PhysicalMaterial",this.userData.category="Physical",this.userData.layers=r!=null?r:this._getLayerStack(e==null?void 0:e.map)}get layersList(){return this.userData.layers}set layersList(e){this.userData.layers=e}equals(e){return this.userData.type===e.userData.type&&this.userData.layers.uuid==e.userData.layers.uuid}copy(e){if(e.userData.layers!==void 0&&e.userData.layers instanceof Ir){let t=e.userData.layers,r=e.fragment;super.copy(e);let n=r.clone();this.fragment=n,this.vertex=n;let s=t.clone(this);this.userData.layers=s,n.shadingAlpha.value=r.shadingAlpha.value,n.shadingBlend.value=r.shadingBlend.value}else super.copy(e);return this}static fromJSON(e,t,r){let n=r.getNode(t.vertex),s=new Ra(void 0,n);return s.fromJSON(t,r),s}dispose(){super.dispose()}};import{Color as Pd}from"three";import{Matrix3 as kv,Texture as Od,Vector2 as za,Vector3 as Qi,Vector4 as Hv}from"three";function Wv(i,e){switch(i.data.type){case"light":return jn(i);case"fresnel":return l3(i,e);case"gradient":return c3(i);case"depth":return u3(i);case"normal":return f3(i);case"noise":return h3(i,e);case"texture":return d3(i,e);case"rainbow":return p3(i);case"transmission":return m3(i,e);case"matcap":return g3(i,e);case"displace":return y3(i);case"color":default:return a3(i,e)}}function qv(i){return{type:i.data.type}}function jn(i){let{alpha:e,mode:t}=i.data;return fe(U({},qv(i)),{alpha:e,mode:t})}function a3(i,e){return fe(U({},jn(i)),{color:kt(i.data.color,e)})}function l3(i,e){let{bias:t,scale:r,intensity:n,factor:s,color:l}=i.data;return fe(U({},jn(i)),{color:kt(l,e),bias:t,scale:r,intensity:n,factor:s})}function c3(i){let{gradientType:e,smooth:t,colors:r,steps:n,angle:s,offset:l,morph:c}=i.data;return fe(U({},jn(i)),{gradientType:e,smooth:t,colors:r.map(f=>new Hv(f[0],f[1],f[2],f[3])),num:r.length,steps:n,offset:new za(...l),morph:new za(...c),angle:s})}function u3(i){let{gradientType:e,near:t,far:r,isVector:n,isWorldSpace:s,origin:l,direction:c,colors:f,steps:h,smooth:p,num:y}=i.data;return fe(U({},jn(i)),{gradientType:e,near:t,far:r,isVector:n,isWorldSpace:s,origin:new Qi(...l),direction:c?new Qi(...c):new Qi(1,0,0),num:y,colors:f.map(g=>new Hv(g[0],g[1],g[2],g[3])),steps:h,smooth:p})}function f3(i){let{cnormal:e}=i.data;return fe(U({},jn(i)),{cnormal:new Qi(e[0],e[1],e[2])})}function h3(i,e){let{data:t}=i;return fe(U({},jn(i)),{scale:t.scale,move:t.move,fA:new za(...t.fA),fB:new za(...t.fB),size:new Qi(...t.size),distortion:new za(...t.distortion),colorA:kt(t.colorA,e),colorB:kt(t.colorB,e),colorC:kt(t.colorC,e),colorD:kt(t.colorD,e),noiseType:t.noiseType})}function d3(i,e){let{projection:t,axis:r,crop:n,size:s}=i.data,{image:l,wrapping:c,repeat:f,offset:h}=i.data.texture,p=new Od,y;if(typeof l=="string")y=e==null?void 0:e.getImage(l);else{let g=new Image;g.src=l.data,g.onload=()=>{(e==null?void 0:e.onImageLoad)&&(e==null||e.onImageLoad(l.data))},y=g}return p.image=y,p.repeat.set(f[0],f[1]),p.offset.set(h[0],h[1]),p.wrapS=p.wrapT=c,fe(U({},jn(i)),{texture:p,mat:new kv().setUvTransform(h[0],h[1],f[0],f[1],0,0,0),crop:n,projection:t,axis:["x","y","z"].indexOf(r),size:s})}function p3(i){let{data:e}=i;return fe(U({},jn(i)),{filmThickness:e.filmThickness,movement:e.movement,wavelengths:new Qi(...e.wavelengths),noiseStrength:e.noiseStrength,noiseScale:e.noiseScale,offset:new Qi(...e.offset)})}function m3(i,e){let{data:t}=i;return fe(U({},jn(i)),{thickness:t.thickness,ior:t.ior,roughness:t.roughness,transmissionSamplerMap:e.transmissionSamplerMap,transmissionDepthMap:e.transmissionDepthMap})}function g3(i,e){let t=new Od,{image:r}=i.data.texture,n;if(typeof r=="string")n=e==null?void 0:e.getImage(r);else{let l=new Image;l.src=r.data,l.onload=()=>{(e==null?void 0:e.onImageLoad)&&(e==null||e.onImageLoad(r.data))},n=l}t.image=n;let s=16777215;return fe(U({},jn(i)),{color:s,texture:t})}function y3(i){let{data:e}=i,t=fe(U({},qv(i)),{intensity:e.intensity});if(e.displacementType==="noise")return fe(U({},t),{offset:new Qi(...e.offset),scale:e.scale,movement:e.movement,noiseType:e.noiseType});{let r=new Od,n=new kv().setUvTransform(0,0,1,1,0,0,0);return fe(U({},t),{texture:r,mat:n,crop:e.crop})}}function $v(i,e,t){if(t.type==="displace"&&(i==="intensity"||i==="visible")){let r=e.uniforms[`f${e.id}_intensity`];return r?(r.value=t.intensity*(t.visible?1:0),r):void 0}if(t.type!=="displace"&&(i==="alpha"||i==="visible")){let r=e.uniforms[`f${e.id}_alpha`];return r?(r.value=t.alpha*(t.visible?1:0),r):void 0}}import{Color as Jv,Vector4 as x3}from"three";var Fs;(function(e){function i(t){return new Jv(t.x,t.y,t.z).getHex()}e.getHex=i})(Fs||(Fs={}));var Kv;(function(e){function i(t){return new x3(t.r,t.g,t.b,t.a)}e.getThreeVector4=i})(Kv||(Kv={}));var Xv;(function(t){function i(r,n){r.setRGB(n.r,n.g,n.b)}t.setThreeColor=i;function e(r){return new Jv(r.r,r.g,r.b).getHex()}t.getHex=e})(Xv||(Xv={}));function Fa(i,e){return typeof i=="string"?e.getMaterialOrDeletedPlaceholder(i):Dd(i,e)}function Zv(i,e){return i.map(t=>Fa(t,e))}function Dd(i,e){var l,c;let t=(l=i.layers)!=null?l:Cs.defaultTwoLayerData("phong").layers,r=v3(t),n;switch(r.category){case"basic":n=new vr;break;case"lambert":{n=new ja;break}case"toon":{n=new Ea;break}case"physical":n=new Ra;break;case"phong":default:{n=new Sn;break}}n.name=(c=i.name)!=null?c:"Untitled Material";let s=n.userData.layers;b3(s);for(let f=t.length-1;f>=0;f--)S3(s,t[f],e);switch(r.category){case"basic":break;case"lambert":{let p=n,g=kt(r.emissive,e);g instanceof Pd?p.emissive.value=g:p.emissive.value.setHex(Fs.getHex(g));break}case"toon":{let p=n,y=r;p.shininess.value=y.shininess;let g=kt(y.specular,e);g instanceof Pd?p.specular.value=g:p.specular.value.setHex(Fs.getHex(g));break}case"physical":let f=n,h=r;f.metalness.value=h.metalness,f.roughness.value=h.roughness,f.reflectivity.value=h.reflectivity;break;case"phong":default:{let p=n,y=r;p.shininess.value=y.shininess;let g=kt(y.specular,e);g instanceof Pd?p.specular.value=g:p.specular.value.setHex(Fs.getHex(g));break}}return s.blendColors(),s.blendAfterColors(),s.blendPositions(),n}function v3(i){for(let e of i)if(e.data.type==="light")return e.data;return{type:"light",category:"basic",visible:!0,alpha:1,mode:Zt.Normal}}function b3(i){for(let e of i.getLayers())i.removeLayer(e.id)}function S3(i,e,t){let r=Wv(e,t);r.type==="transmission"&&(r.transmissionSamplerMap=t==null?void 0:t.transmissionSamplerMap,r.transmissionDepthMap=t==null?void 0:t.transmissionDepthMap);let n=i.addLayer(r);n.uuid=e.id;for(let s in e.data)$v(s,n,e.data)}import{Vector2 as Yv}from"three";var Pu=new Yv,Ao=class{constructor(e,t,r){this.message=[];this.endLine=!0;this.yLinePos=e,this.lineHeight=t,this.maxCharSize=r,this.nextChar3DPos=new Yv(0,this.yLinePos+this.maxCharSize*this.lineHeight),this.align=Lr.Left}addChar3D(e,t,r=this.message.length){this.message.splice(r,0,e),e.fontSize>this.maxCharSize?(this.maxCharSize=e.fontSize,this.nextChar3DPos.y=this.yLinePos+this.maxCharSize*this.lineHeight,this.fullUpdate(t)):(e.updatePosition(this.nextChar3DPos,t),this.nextChar3DPos.x+=e.charSize)}deleteChar3D(e=this.message.length-1){let t=this.message[e];if(t)return this.message.splice(e,1),this.nextChar3DPos.x-=t.charSize,t}isEndLine(e){this.endLine=e}fullUpdate(e,t=0){this.nextChar3DPos.x=0;for(let r=t,n=this.message.length;r<n;r+=1)this.message[r].updatePosition(this.nextChar3DPos,e),this.nextChar3DPos.x+=this.message[r].charSize}checkOverFlow(e){let t,r=this.message.length-1;if(r<=0)return!1;for(;r>=0;){if(this.message[r].char!==" "){t=this.message[r];break}r-=1}return!!(r>=0&&t&&t.localPosition.x+t.charSize>e)}containSpaceOverFlow(e=this.message.length-1){for(let t=e;t>=0;t-=1)if(this.message[t].char===" ")return!0;return!1}containSpace(e=this.message.length-1){if(this.endLine)return!0;for(let t=e;t>=0;t-=1)if(this.message[t].char===" ")return!0;return!1}popWord(e=this.message.length-1){let t=[],r=!0,n;for(n=e;n>=0;n-=1)if(this.message[n].char===" "){r=!1,t.length===0&&(n-=1,t.splice(0,0,this.message[n]));break}else t.splice(0,0,this.message[n]);return r?t=[]:this.message.splice(n+1,t.length),t}getWord(e=0,t=1){let r=[],n=e;for(n=e;;n+=t){if(!this.message[n]||this.message[n].char===" "){r.length===0&&this.message[n]&&(r.push(this.message[n]),this.message.splice(n,1));break}t>0?(r.push(this.message[n]),this.message.splice(n,1),n-=t):(r.splice(0,0,this.message[n]),this.message.splice(n,1))}return r}getWordAtIndex(e){let t=[];for(let r=e;r<this.message.length&&this.message[r].char!==" ";r++)t.push(this.message[r]);for(let r=e-1;r>=0&&this.message[r].char!==" ";r--)t.splice(0,0,this.message[r]);return t}wordSize(e=0,t=-1){let r=0,n=e;for(;n>=0&&n<this.message.length;){if(this.message[n].char===" "){r===0&&(r=this.message[n].charSize);break}r+=this.message[n].charSize,n+=t}return(n<0||n>=this.message.length)&&!this.endLine?this.message[e]?this.message[e].charSize:999999999:r===0?999999999:r}spaceLeft(e){return e-this.nextChar3DPos.x}popChar(e=this.message.length-1){return this.nextChar3DPos.x-=this.message[e].charSize,this.message.splice(e,1)}isEmpty(){return!this.message.length}updateNextCharPosY(){this.nextChar3DPos.y=this.yLinePos+this.maxCharSize*this.lineHeight}updateYLinePos(e){this.yLinePos=e,this.updateNextCharPosY()}updatelineHeight(e){this.lineHeight=e,this.updateNextCharPosY()}updateFontSize(e,t=0,r=this.message.length-1){for(let n=t;n<=r;n+=1)this.message[n].updateFontSize(e);this.maxCharSize=e,this.nextChar3DPos.y=this.yLinePos+this.maxCharSize*this.lineHeight}countSpaces(){let e=0;for(let t=0;t<this.message.length;t++)this.message[t].char===" "&&(e+=1);return e}alignText(e,t,r,n,s){switch(r){case Lr.Left:this.leftAlign(e,s);break;case Lr.Center:this.centerAlign(this.spaceLeft(t),e,s);break;case Lr.Right:this.rightAlign(this.spaceLeft(t),e,s);break;case Lr.Justify:this.justifyAlign(this.spaceLeft(t),e,s);break}}offsetCharacters(e,t,r){Pu.set(t,r);let n=this.message.length;for(let s=0;s<n;s++)this.message[s].updatePosition(this.message[s].localPosition.add(Pu),e)}leftAlign(e,t){this.align=Lr.Left,this.offsetCharacters(e,0,t)}centerAlign(e,t,r){this.align=Lr.Center,this.offsetCharacters(t,e/2,r)}rightAlign(e,t,r){this.align=Lr.Right,this.offsetCharacters(t,e,r)}justifyAlign(e,t,r){if(this.align=Lr.Justify,this.endLine){this.offsetCharacters(t,0,r);return}let n=this.countSpaces();if(n===0){this.offsetCharacters(t,0,r);return}let s=e/n,l=0;for(let c=0;c<this.message.length;c++)this.message[c].char===" "&&(l+=s),Pu.set(l,r),this.message[c].updatePosition(this.message[c].localPosition.add(Pu),t)}clone(){let e=new Ao(this.yLinePos,this.lineHeight,this.maxCharSize);e.nextChar3DPos=this.nextChar3DPos.clone(),e.align=this.align,e.endLine=this.endLine;for(let t=0;t<this.message.length;t++)e.message.push(this.message[t].clone());return e}};import{DoubleSide as w3,EventDispatcher as N3,Matrix3 as C3,Vector3 as Bd}from"three";var L3=new Bd(0,0,1),Qv=new Bd,eb=new Bd,tb=new C3,Oo=class extends hr{constructor(e=ur.create({}),t=new vr({side:w3})){super(e,t);this.recursiveSelection=!1;this.objectType="VectorObject";this.eventDispatcher=new N3;this._onShapeUpdate=()=>{if(this.geometry instanceof Lo){if(this.geometry.updateFromShape()){let e=this.geometry.drawCount,t=this.geometry.userData;this.updateGeometry(Object.assign(this.geometry.userData,{parameters:Object.assign(t.parameters,{surfaceMaxCount:e+1e3})}))}}else this.updateGeometry({});this.geometry.computeBoundingSphere(),this.geometry.computeBoundingBox()};var r;this.castShadow=!0,this.receiveShadow=!0,this.forceComputeSize=!0,this.shape=e.userData.shape,(r=this.shape.eventDispatcher)==null||r.addEventListener("update",this._onShapeUpdate)}toJSON(e){let t=super.toJSON(e);return t.object.objectType="VectorObject",t}fromState(e){return super.fromState(e),this.shape.update(),this}setHelperVisibility(){}updateGeometry(e){if(super.updateGeometry(e),"userData"in this.geometry){let t=this.geometry.userData.parameters;this.eventDispatcher.dispatchEvent({type:"geometryUpdate",parameters:t})}}setShape(e){var t,r;this.shape&&((t=this.shape.eventDispatcher)==null||t.removeEventListener("update",this._onShapeUpdate)),this.shape=e,(r=this.shape.eventDispatcher)==null||r.addEventListener("update",this._onShapeUpdate)}updateWorldMatrix(e,t){super.updateWorldMatrix(e,t),tb.getNormalMatrix(this.matrixWorld),Qv.copy(L3).applyMatrix3(tb).normalize(),eb.setFromMatrixPosition(this.matrixWorld),this.shape.plane.setFromNormalAndCoplanarPoint(Qv,eb)}clone(e){let t=this.shape.clone(),r=this.material.clone(),n=this.geometry.userData,s=ur.create(Object.assign({},n,{shape:t})),l=new Oo(s,r).copy(this,e);return l.shape=t,t.update(),l}raycast(e,t){hr.prototype.raycast.call(this,e,t)}};import{Camera as F3,OrthographicCamera as V3,PerspectiveCamera as U3,Vector3 as nn,Object3D as ob,Quaternion as k3}from"three";import{BoxBufferGeometry as _3}from"three";var ei=i=>{var e;return e=class extends i{constructor(){super(...arguments);this.isObjectHelper=!0}},e.geometryHelper=new _3(30,30,30),e};import{Camera as A3,LineSegments as O3,BufferGeometry as P3,LineBasicMaterial as D3,Color as jd,Vector3 as B3,Float32BufferAttribute as nb}from"three";import{Ray as T3,Sphere as I3,Matrix4 as M3,Vector3 as Li}from"three";var Du=new T3,Gd=new I3,rb=new M3,ti=(i,e,t,r,n=!1)=>{let s=e,l=i.matrixWorld;if(s.boundingSphere===null&&s.computeBoundingSphere(),Gd.copy(s.boundingSphere),Gd.applyMatrix4(l),t.ray.intersectsSphere(Gd)===!1||(rb.copy(l).invert(),Du.copy(t.ray).applyMatrix4(rb),s.boundingBox!==null&&Du.intersectsBox(s.boundingBox)===!1))return;let c,f,h,p,y=s.index,g=s.attributes.position,w=s.drawRange,S,T;if(n===!1){let B=Math.max(0,w.start),G=Math.min(y.count,w.start+w.count);for(S=B,T=G;S<T;S+=3)if(f=y.getX(S),h=y.getX(S+1),p=y.getX(S+2),c=C(i,t,Du,g,f,h,p),c){c.faceIndex=Math.floor(S/3),r.push(c);return}}else{let G=s.attributes.position,D=new Li,W=new Li,A=new Li,q=new Li,E=2,R=1/((i.scale.x+i.scale.y+i.scale.z)/3),I=R*R,z=Math.max(0,w.start),O=Math.min(G.count,w.start+w.count);for(let $=z,he=O-1;$<he;$+=E){if(D.fromBufferAttribute(G,$),W.fromBufferAttribute(G,$+1),Du.distanceSqToSegment(D,W,q,A)>I)continue;q.applyMatrix4(i.matrixWorld);let Ne=t.ray.origin.distanceTo(q);Ne<t.near||Ne>t.far||r.push({distance:Ne,point:A.clone().applyMatrix4(i.matrixWorld),object:i})}}function C(B,G,D,W,A,q,E){let b=new Li,R=new Li,I=new Li,z=new Li,O=new Li;if(b.fromBufferAttribute(W,A),R.fromBufferAttribute(W,q),I.fromBufferAttribute(W,E),D.intersectTriangle(b,R,I,!1,z)===null)return null;O.copy(z),O.applyMatrix4(B.matrixWorld);let he=G.ray.origin.distanceTo(O);return he<G.near||he>G.far?null:{faceIndex:1,distance:he,point:O.clone(),object:B}}};var Bu=new B3,wn=new A3,ib=class extends O3{constructor(e){let t=new P3,r=new D3({color:16777215,vertexColors:!0,toneMapped:!1}),n=[],s=[],l={},c=new jd(Th),f=new jd(Th),h=new jd(d0);p("n1","n2",c),p("n2","n4",c),p("n4","n3",c),p("n3","n1",c),p("f1","f2",c),p("f2","f4",c),p("f4","f3",c),p("f3","f1",c),p("n1","f1",c),p("n2","f2",c),p("n3","f3",c),p("n4","f4",c),p("p","n1",f),p("p","n2",f),p("p","n3",f),p("p","n4",f),p("u1","u2",h),p("u2","u3",h),p("u3","u1",h);function p(g,w,S){y(g,S),y(w,S)}function y(g,w){n.push(0,0,0),s.push(w.r,w.g,w.b),l[g]===void 0&&(l[g]=[]),l[g].push(n.length/3-1)}t.setAttribute("position",new nb(n,3)),t.setAttribute("color",new nb(s,3));super(t,r);this.type="CameraHelper",this.camera=e,this.camera.updateProjectionMatrix&&this.camera.updateProjectionMatrix(),this.matrix=e.matrixWorld,this.matrixAutoUpdate=!1,this.pointMap=l,this.update()}update(){let e=this.geometry,t=this.pointMap,r=!0;wn.projectionMatrixInverse.elements=[.5112609807824982,-0,-0,-0,-0,.41421356237309503,-0,-0,-0,-0,-0,-.099999,-0,-0,-1.0000000000000002,.100001];let n=1,s=1,l=r?.8:1e-4;En("n1",t,e,wn,-n,-s,l),En("n2",t,e,wn,n,-s,l),En("n3",t,e,wn,-n,s,l),En("n4",t,e,wn,n,s,l);let c=l;En("f1",t,e,wn,-n,-s,c),En("f2",t,e,wn,n,-s,c),En("f3",t,e,wn,-n,s,c),En("f4",t,e,wn,n,s,c);let f=c,h=.5;En("u1",t,e,wn,n*.7*h,s*1.1,f),En("u2",t,e,wn,-n*.7*h,s*1.1,f),En("u3",t,e,wn,0,s*(1.1+.9*h),f),e.getAttribute("position").needsUpdate=!0}dispose(){this.geometry.dispose(),this.material.dispose()}};function En(i,e,t,r,n,s,l){Bu.set(n,s,l).unproject(r);let c=e[i];if(c!==void 0){let f=t.getAttribute("position");for(let h=0,p=c.length;h<p;h++)f.setXYZ(c[h],Bu.x,Bu.y,Bu.z)}}var Ed=class extends ei(ib){constructor(e){super(e);this.object=e;this.object=e,this.name=`CombinedCameraHelper: ${e.uuid}`}updateMatrixWorld(e){super.updateMatrixWorld(e),this.updateTarget()}updateTarget(){let e=this.object.getTarget();this.updateWorldMatrix(!0,!1),this.worldToLocal(e)}raycast(e,t){ti(this.object,this.geometry,e,t,!0)}};import{DirectionalLightHelper as G3}from"three";var Va=class extends ei(G3){constructor(e,t=15,r=10066329){super(e,t,r);this.object=e;this.name=`DirectionalLightHelper: ${e.uuid}`}raycast(e,t){ti(this.object,Va.geometryHelper,e,t)}};import{AxesHelper as j3}from"three";var Ua=class extends ei(j3){constructor(e,t=15){super(t);this.object=e;this.object.updateMatrixWorld(),this.name=`EmptyObjectHelper: ${e.uuid}`,this.matrix=e.matrixWorld,this.matrixAutoUpdate=!1}raycast(e,t){ti(this.object,Ua.geometryHelper,e,t)}update(){}};import{PointLightHelper as E3}from"three";var ka=class extends ei(E3){constructor(e,t=15,r=6710886){super(e,t,r);this.object=e;this.name=`PointLightHelper: ${e.uuid}`}raycast(e,t){ti(this.object,ka.geometryHelper,e,t)}};import{SpotLightHelper as R3,Vector3 as z3}from"three";var ju=class extends ei(R3){constructor(e,t=6710886){super(e,t);this.object=e;this.name=`SpotLightHelper: ${e.uuid}`}raycast(e,t){ti(this.object,ju.geometryHelper,e,t)}update(){if(this.object!==void 0){let e=ju._vector,t=this.object.distance?this.object.distance:1e3,r=t*Math.tan(this.object.angle);this.cone.scale.set(r,r,t),e.setFromMatrixPosition(this.object.target.matrixWorld),this.cone.lookAt(e);let n=this.color!==void 0?this.color:this.light.color;if(this.cone.material instanceof Array)for(let s=0,l=this.cone.material.length;s<l;s++)this.cone.material[s].color.set(n);else this.cone.material.color.set(n)}}},Gu=ju;Gu._vector=new z3;var ri=(i,e)=>class extends i{constructor(){super(...arguments);this.objectHelper=new e(this);this.enableHelper=!1}set visibility(r){this.visible=r,this.setHelperVisibility(r),this.setHelperChildrenVisibility(r)}get visibility(){return this.visible}get geometryHelper(){return e.geometryHelper}setHelperVisibility(r){this.objectHelper.visible=r}setHelperChildrenVisibility(r){for(let n of this.children)xn(n)&&n.traverseEntity(s=>{Si(s)&&s.visible&&(s.objectHelper.visible=r)})}raycast(r,n){this.objectHelper.raycast(r,n)}copy(r,n=!0){return super.copy(r,n),r.enableHelper!==void 0&&(this.enableHelper=r.enableHelper),r.objectHelper!==void 0&&(this.objectHelper.visible=r.objectHelper.visible),this}toJSON(r){let n=super.toJSON(r),s=n.object;return s.enableHelper=this.enableHelper,n}fromJSON(r){return super.fromJSON(r),r.enableHelper!==void 0&&(this.enableHelper=!0),this}fromLightState(r,n){if(this.objectType==="LightDirectional"||this.objectType==="LightPoint"||this.objectType==="LightSpot"){let s=this;r.color!==void 0&&(s.color=kt(r.color,n)),r.intensity!==void 0&&(s.intensity=r.intensity),r.depth!==void 0&&(s.shadow.camera.far=r.depth,s.shadow.needsUpdate=!0),r.shadows!==void 0&&(this.castShadow=r.shadows),r.helper!==void 0&&(this.enableHelper=r.helper,s.gizmos.shadowmap.visible=r.helper)}return this}};var Vs=new nn,Rd=new nn,eo=class extends ri(vn(F3),Ed){constructor(e=window.innerWidth,t=window.innerHeight,r=45,n,s=1e5){super();this.objectType="CombinedCamera";this._cameraType="OrthographicCamera";this.targetOffset=bo.DefaultTargetOffset;this.isUpVectorFlipped=!1;this.angleOffsetFromUp=0;this.width=e,this.height=t,this.orthoCamera=new V3(e*-.5,e*.5,t*.5,t*-.5,n!=null?n:-5e4,s),this.perspCamera=new U3(r,e/t,n!=null?n:50,s),this.left=this.orthoCamera.left,this.right=this.orthoCamera.right,this.top=this.orthoCamera.top,this.bottom=this.orthoCamera.bottom,this.far=this.orthoCamera.far,this.view=this.orthoCamera.view,this.aspect=this.perspCamera.aspect,this.fov=this.perspCamera.fov,this.focus=this.perspCamera.focus,this.filmGauge=this.perspCamera.filmGauge,this.filmOffset=this.perspCamera.filmOffset,this.toOrthographic(!0)}static createFromState(e,t){let r=new eo().fromState(t);return r.enableHelper=!0,r.objectHelper.update(),r.uuid=e,r}get isPerspectiveCamera(){return this.cameraType==="PerspectiveCamera"}get isOrthographicCamera(){return!this.isPerspectiveCamera}get cameraType(){return this._cameraType}setNear(e,t){e==="PerspectiveCamera"?this.perspCamera.near=t:this.orthoCamera.near=t}setZoom(e,t){t>=0&&(e==="PerspectiveCamera"?this.perspCamera.zoom=t:this.orthoCamera.zoom=t)}set cameraType(e){e==="PerspectiveCamera"?this.toPerspective():e==="OrthographicCamera"&&this.toOrthographic()}get near(){return this._cameraType==="PerspectiveCamera"?this.perspCamera.near:this.orthoCamera.near}set near(e){this._cameraType==="PerspectiveCamera"?this.perspCamera.near=e:this.orthoCamera.near=e}get zoom(){return this._cameraType==="PerspectiveCamera"?this.perspCamera.zoom:this.orthoCamera.zoom}set zoom(e){e>=0&&(this._cameraType==="PerspectiveCamera"?this.perspCamera.zoom=e:this.orthoCamera.zoom=e)}lookAt(e){super.lookAt(e),this.getWorldPosition(Vs),this.targetOffset=Vs.distanceTo(e)}getTarget(e=new nn){return this.getWorldDirection(Rd),this.getWorldPosition(Vs),Rd.multiplyScalar(this.targetOffset),e.copy(Vs).add(Rd),e}getDistanceToTarget(){let e=this.getTarget();return this.getWorldPosition(Vs),Vs.distanceTo(e)}updateUp(){let e=this.getWorldQuaternion(new k3),t=new nn(0,0,1).applyQuaternion(e),r=new nn().copy(ob.DefaultUp);this.isUpVectorFlipped&&r.negate(),r.applyQuaternion(e);let n=new nn().copy(ob.DefaultUp).projectOnPlane(t),s=new nn().crossVectors(n,r).dot(t)>=0?1:-1;this.angleOffsetFromUp=n.angleTo(r)*s}getViewFrontToObject(e){let t=e.getWorldPosition(new nn),n=e.getWorldDirection(new nn).multiplyScalar(this.targetOffset);return{position:t.clone().add(n),target:t}}getViewToObject(e){let t=e.getWorldPosition(new nn),n=this.getWorldDirection(new nn).multiplyScalar(this.targetOffset);return{position:t.clone().sub(n),target:t}}setViewplaneSize(e,t){this.left=-e*.5,this.right=e*.5,this.top=t*.5,this.bottom=-t*.5,this.aspect=e/t,this.updateProjectionMatrix()}toOrthographic(e){this.orthoCamera.left=this.left,this.orthoCamera.right=this.right,this.orthoCamera.top=this.top,this.orthoCamera.bottom=this.bottom,this.orthoCamera.view=this.view,this.orthoCamera.far=this.far,this.orthoCamera.updateProjectionMatrix(),this.projectionMatrix=this.orthoCamera.projectionMatrix,this.projectionMatrixInverse=this.orthoCamera.projectionMatrixInverse,this._cameraType="OrthographicCamera",(this.enableHelper===!0||e===!0)&&this.objectHelper.update()}toPerspective(e){this.perspCamera.aspect=this.aspect,this.perspCamera.fov=this.fov,this.perspCamera.view=this.view,this.perspCamera.far=this.far,this.perspCamera.updateProjectionMatrix(),this.projectionMatrix=this.perspCamera.projectionMatrix,this.projectionMatrixInverse=this.perspCamera.projectionMatrixInverse,this._cameraType="PerspectiveCamera",(this.enableHelper===!0||e===!0)&&this.objectHelper.update()}setFocalLength(e){this.perspCamera.setFocalLength(e),this.toPerspective()}getFocalLength(){return this.perspCamera.getFocalLength()}getEffectiveFOV(){return this.perspCamera.getEffectiveFOV()}getFilmWidth(){return this.perspCamera.getFilmWidth()}getFilmHeight(){return this.perspCamera.getFilmHeight()}setViewOffset(e,t,r,n,s,l){this._cameraType==="PerspectiveCamera"?this.perspCamera.setViewOffset(e,t,r,n,s,l):this.orthoCamera.setViewOffset(e,t,r,n,s,l)}clearViewOffset(){this._cameraType==="PerspectiveCamera"?(this.perspCamera.clearViewOffset(),this.toPerspective()):(this.orthoCamera.clearViewOffset(),this.toOrthographic())}updateProjectionMatrix(e){this._cameraType==="PerspectiveCamera"?this.toPerspective(e):this._cameraType==="OrthographicCamera"&&this.toOrthographic(e)}updateMatrixWorld(e){super.updateMatrixWorld(e),this.matrixWorldInverse.copy(this.matrixWorld).invert()}updateWorldMatrix(e,t){super.updateWorldMatrix(e,t),this.matrixWorldInverse.copy(this.matrixWorld).invert()}copy(e,t){return super.copy(e,t),this.orthoCamera.copy(e.orthoCamera),this.perspCamera.copy(e.perspCamera),this.left=e.left,this.right=e.right,this.top=e.top,this.bottom=e.bottom,this.far=e.far,this.view=e.view===null?null:Object.assign({},e.view),this._cameraType=e._cameraType,this.aspect=e.aspect,this.fov=e.fov,this.focus=e.focus,this.filmGauge=e.filmGauge,this.filmOffset=e.filmOffset,this.targetOffset=e.targetOffset,this.updateProjectionMatrix(),this}fromCameraRender(e){let t={near:this.orthoCamera.near,far:this.orthoCamera.far},r={near:this.perspCamera.near,far:this.perspCamera.far};return this.copy(e),this.name="",this.enableHelper=!0,this.objectHelper.visible=!0,this.orthoCamera.near=t.near,this.orthoCamera.far=t.far,this.perspCamera.near=r.near,this.perspCamera.far=r.far,this.updateProjectionMatrix(),this}toJSON(e){let t=super.toJSON(e),r=t.object;return r.objectType="CombinedCamera",r.cameraType=this.cameraType,r.targetOffset=this.targetOffset,r.isUpVectorFlipped=this.isUpVectorFlipped,r.angleOffsetFromUp=this.angleOffsetFromUp,r.left=this.left,r.right=this.right,r.top=this.top,r.bottom=this.bottom,this.view!==null&&(r.view=Object.assign({},this.view)),r.zoomOrtho=this.orthoCamera.zoom,r.nearOrtho=this.orthoCamera.near,r.far=this.far,r.aspect=this.aspect,r.fov=this.fov,r.focus=this.focus,r.filmGauge=this.filmGauge,r.filmOffset=this.filmOffset,r.zoomPersp=this.perspCamera.zoom,r.nearPersp=this.perspCamera.near,t}fromJSON(e){var t;if(super.fromJSON(e),this.cameraType=e.cameraType,e.targetOffset!==void 0&&(this.targetOffset=e.targetOffset),e.orbitControlsTarget!==void 0){let r=this.getWorldPosition(new nn),n=new nn().fromArray(e.orbitControlsTarget);this.targetOffset=n.distanceTo(r)}else e.targetOffset!==void 0&&(this.targetOffset=e.targetOffset);return this.isUpVectorFlipped=!1,this.angleOffsetFromUp=(t=e.angleOffsetFromUp)!=null?t:0,e.left!==void 0&&(this.left=e.left),e.right!==void 0&&(this.right=e.right),e.top!==void 0&&(this.top=e.top),e.bottom!==void 0&&(this.bottom=e.bottom),e.view!==void 0&&(this.view=Object.assign({},e.view)),e.zoomOrtho!==void 0&&(this.orthoCamera.zoom=e.zoomOrtho),e.nearOrtho!==void 0&&(this.orthoCamera.near=e.nearOrtho),e.far!==void 0&&(this.far=e.far),e.aspect!==void 0&&(this.aspect=e.aspect),e.fov!==void 0&&(this.fov=e.fov),e.focus!==void 0&&(this.focus=e.focus),e.filmGauge!==void 0&&(this.filmGauge=e.filmGauge),e.filmOffset!==void 0&&(this.filmOffset=e.filmOffset),e.zoomPersp!==void 0&&(this.perspCamera.zoom=e.zoomPersp),e.nearPersp!==void 0&&(this.perspCamera.near=e.nearPersp),this.updateProjectionMatrix(),this}toCameraState(e=[]){let t={type:this.cameraType,far:this.far,orthographic:{near:this.orthoCamera.near,zoom:this.orthoCamera.zoom},perspective:{near:this.perspCamera.near,fov:this.perspCamera.fov,zoom:this.perspCamera.zoom},up:this.up.toArray(),targetOffset:this.targetOffset,isUpVectorFlipped:this.isUpVectorFlipped};return ms(t,e)}fromCameraState(e){let{orthographic:t,perspective:r}=e;return e.type!==void 0&&(this.cameraType=e.type),e.far!==void 0&&(this.far=e.far),t!==void 0&&(t.near!==void 0&&(this.orthoCamera.near=t.near),t.zoom!==void 0&&(this.orthoCamera.zoom=t.zoom)),r!==void 0&&(r.near!==void 0&&(this.perspCamera.near=r.near),r.fov!==void 0&&(this.perspCamera.fov=r.fov),r.zoom!==void 0&&(this.perspCamera.zoom=r.zoom)),e.up!==void 0&&this.up.fromArray(e.up),e.targetOffset!==void 0&&(this.targetOffset=e.targetOffset),e.isUpVectorFlipped!==void 0&&(this.isUpVectorFlipped=e.isUpVectorFlipped),this.updateProjectionMatrix(),this}toState(e){return fe(U(U({},super.toState(e)),this.toCameraState(e)),{type:this.cameraType})}fromState(e){return super.fromState(e),this.fromCameraState(e),this}};import{Group as H3}from"three";var to=class extends ri(vn(H3),Ua){constructor(){super(...arguments);this.objectType="EmptyObject"}static createFromState(e,t){let r=new to().fromState(t);return r.uuid=e,r.enableHelper=!0,r.objectHelper.update(),r}toJSON(e){let t=super.toJSON(e);return t.object.objectType="EmptyObject",t}};import{DirectionalLight as W3,CameraHelper as Eu}from"three";var Ha=class extends ri(vn(W3),Va){constructor(...e){super(...e);this.objectType="LightDirectional";this._gizmos={};this.castShadow=!0,this.shadow.mapSize.width=1024,this.shadow.mapSize.height=1024;let r=this.shadow.camera;r.top=1250,r.bottom=-1250,r.right=1250,r.left=-1250,r.near=1,r.far=2500;let n=new Eu(this.shadow.camera);n.visible=!1,this._gizmos.shadowmap=n,this.update()}static createFromState(e,t,r){let n=new Ha().fromState(t,r);return n.uuid=e,n}get gizmos(){return this._gizmos}showGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Eu&&(t.visible=!0)}}hideGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Eu&&(t.visible=!1)}}update(){this.shadow.camera.updateProjectionMatrix();for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Eu&&t.update()}}updateMatrixWorld(e){super.updateMatrixWorld(e),this.enableHelper===!0&&this.objectHelper.visible===!0&&this.objectHelper.update()}copy(e,t=!0){return super.copy(e,t),this.color.copy(e.color),this.intensity=e.intensity,this.target=e.target.clone(),this.shadow=e.shadow.clone(),this}toJSON(e){let t=super.toJSON(e),r=t.object;return r.objectType="LightDirectional",r.color=this.color.getHex(),r.intensity=this.intensity,r.shadow=this.shadow.toJSON(),t}fromJSON(e){var n;super.fromJSON(e),this.color.set(e.color),this.intensity=e.intensity,this.shadow.normalBias=(n=e.shadow.normalBias)!=null?n:0,this.shadow.radius=e.shadow.radius,this.shadow.mapSize.fromArray(e.shadow.mapSize);let t=this.shadow.camera,r=e.shadow.camera;return t.near=r.near,t.far=r.far,t.zoom=r.zoom,t.left=r.left,t.right=r.right,t.top=r.top,t.bottom=r.bottom,r.view!==void 0&&(t.view=Object.assign({},r.view)),this}fromDirectionalLightState(e,t){let r=e.depth!==void 0&&e.depth!==this.shadow.camera.far||e.size!==void 0&&e.size/2!==this.shadow.camera.right;return super.fromLightState(e,t),e.size!==void 0&&yv(this,e.size),r&&this.update(),this}fromState(e,t){return super.fromState(e),this.fromDirectionalLightState(e,t),this}};import{PointLight as q3,Vector3 as Ru,Box3 as $3,Box3Helper as zu,Color as J3}from"three";var Wa=class extends ri(vn(q3),ka){constructor(...e){super(...e);this.objectType="LightPoint";this._gizmos={};this.castShadow=!0,this.shadow.mapSize.width=1024,this.shadow.mapSize.height=1024;let r=this.shadow.camera;r.fov=90,r.aspect=1,r.near=100,r.far=2500;let n=new Ru(-r.far+this.position.x,-r.far+this.position.y,-r.far+this.position.z),s=new Ru(r.far+this.position.x,r.far+this.position.y,r.far+this.position.z),l=new $3(n,s),c=new zu(l,new J3(16755200));c.visible=!1,this._gizmos.shadowmap=c,this.update()}static createFromState(e,t,r){let n=new Wa().fromState(t,r);return n.uuid=e,n}get gizmos(){return this._gizmos}showGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof zu&&(t.visible=!0)}}hideGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof zu&&(t.visible=!1)}}update(){if(this.shadow&&(this.shadow.camera.updateProjectionMatrix(),this._gizmos))for(let e in this._gizmos){let t=this._gizmos[e];if(t instanceof zu){let r=this.shadow.camera,n=new Ru(-r.far+this.position.x,-r.far+this.position.y,-r.far+this.position.z),s=new Ru(r.far+this.position.x,r.far+this.position.y,r.far+this.position.z);t.box.set(n,s),t.updateMatrixWorld(!0)}}}updateMatrixWorld(e){super.updateMatrixWorld(e),this.enableHelper===!0&&this.objectHelper.visible===!0&&this.objectHelper.update()}copy(e,t=!0){return super.copy(e,t),this.color.copy(e.color),this.intensity=e.intensity,this.distance=e.distance,this.decay=e.decay,this.shadow=e.shadow.clone(),this}toJSON(e){let t=super.toJSON(e),r=t.object;return r.objectType="LightPoint",r.color=this.color.getHex(),r.intensity=this.intensity,r.distance=this.distance,r.decay=this.decay,r.shadow=this.shadow.toJSON(),t}fromJSON(e){var n,s;super.fromJSON(e),this.color.set(e.color),this.intensity=e.intensity,this.distance=e.distance,this.decay=e.decay,this.shadow.normalBias=(n=e.shadow.normalBias)!=null?n:0,this.shadow.radius=e.shadow.radius,this.shadow.mapSize.fromArray((s=e.shadow.mapSize)!=null?s:[512,512]),this.shadow.map&&(this.shadow.map.dispose(),this.shadow.map=null);let t=this.shadow.camera,r=e.shadow.camera;return t.near=r.near,t.far=r.far,t.zoom=r.zoom,t.fov=r.fov,t.focus=r.focus,t.aspect=r.aspect,t.filmGauge=r.filmGauge,t.filmOffset=r.filmOffset,r.view!==void 0&&(t.view=Object.assign({},r.view)),this}fromPointLightState(e,t){return super.fromLightState(e,t),e.distance!==void 0&&(this.distance=e.distance),e.decay!==void 0&&(this.decay=e.decay),e.shadowRadius!==void 0&&(this.shadow.radius=e.shadowRadius),e.shadowResolution!==void 0&&(this.shadow.mapSize.set(e.shadowResolution,e.shadowResolution),this.shadow.map&&(this.shadow.map.dispose(),this.shadow.map=null)),this}fromState(e,t){return super.fromState(e),this.fromPointLightState(e,t),this}};import{SpotLight as K3,CameraHelper as Fu,MathUtils as X3,Vector3 as sb,Quaternion as Z3}from"three";var ab=new sb,lb=new sb,cb=new Z3,qa=class extends ri(vn(K3),Gu){constructor(...e){super(...e);this.objectType="LightSpot";this._gizmos={};this.castShadow=!0,this.shadow.mapSize.width=1024,this.shadow.mapSize.height=1024;let r=this.shadow.camera;r.fov=X3.RAD2DEG*2*this.angle,r.aspect=1,r.near=100,r.far=2500;let n=new Fu(this.shadow.camera);n.visible=!1,this._gizmos.shadowmap=n,this.update()}static createFromState(e,t,r){let n=new qa().fromState(t,r);return n.uuid=e,n}get gizmos(){return this._gizmos}showGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Fu&&(t.visible=!0)}}hideGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Fu&&(t.visible=!1)}}update(){this.shadow.camera.updateProjectionMatrix();for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Fu&&t.update()}}updateMatrixWorld(e){super.updateMatrixWorld(e),lb.setFromMatrixPosition(this.matrixWorld),cb.setFromRotationMatrix(this.matrixWorld),ab.copy(this.up).applyQuaternion(cb).negate().multiplyScalar(this.distance),this.target.position.copy(lb).add(ab),this.target.updateMatrixWorld(),this.enableHelper===!0&&this.objectHelper.visible===!0&&this.objectHelper.update()}copy(e,t=!0){return super.copy(e,t),this.color.copy(e.color),this.intensity=e.intensity,this.distance=e.distance,this.angle=e.angle,this.penumbra=e.penumbra,this.decay=e.decay,this.target=e.target.clone(),this.shadow=e.shadow.clone(),this}toJSON(e){let t=super.toJSON(e),r=t.object;return r.objectType="LightSpot",r.color=this.color.getHex(),r.intensity=this.intensity,r.distance=this.distance,r.angle=this.angle,r.decay=this.decay,r.penumbra=this.penumbra,r.shadow=this.shadow.toJSON(),t}fromJSON(e){var n;super.fromJSON(e),this.color.set(e.color),this.intensity=e.intensity,this.distance=e.distance,this.angle=e.angle,this.decay=e.decay,this.penumbra=e.penumbra,this.shadow.normalBias=(n=e.shadow.normalBias)!=null?n:0,this.shadow.radius=e.shadow.radius,this.shadow.mapSize.fromArray(e.shadow.mapSize);let t=this.shadow.camera,r=e.shadow.camera;return t.near=r.near,t.far=r.far,t.zoom=r.zoom,t.fov=r.fov,t.focus=r.focus,t.aspect=r.aspect,t.filmGauge=r.filmGauge,t.filmOffset=r.filmOffset,r.view!==void 0&&(t.view=Object.assign({},r.view)),this}fromSpotLightState(e,t){return super.fromLightState(e,t),e.distance!==void 0&&(this.distance=e.distance),e.decay!==void 0&&(this.decay=e.decay),e.angle!==void 0&&(this.angle=e.angle),e.penumbra!==void 0&&(this.penumbra=e.penumbra),this}fromState(e,t){return super.fromState(e),this.fromSpotLightState(e,t),this}};import{VideoTexture as Y3}from"three";var ub=i=>i.tagName==="VIDEO",Us=class{static resize(e,t,r){let n=e/t,s;if(!r.image)return;let l=r.image;ub(l)?s=l.videoWidth/l.videoHeight:s=l.width/l.height,n>s&&(r.imageType=="WEBCAM"?r.repeat.set(-1,1*s/n):r.repeat.set(1,1*s/n)),n<s&&(r.imageType=="WEBCAM"?r.repeat.set(1*n/s*-1,1):r.repeat.set(1*n/s,1)),n==s&&(r.imageType=="WEBCAM"?r.repeat.set(-1,1):r.repeat.set(1,1))}static resizeTextureLayer(e,t,r){let n=e/t,s=r.image!==void 0?r.image.width/r.image.height:1,l;n>s?l={x:1,y:s/n}:n<s?l={x:n/s,y:1}:l={x:1,y:1},r.repeat.set(l.x,l.y),r.updateMatrix()}static resizeTextureLayers(e,t,r){let n=r.userData.layers,s=n.getLayers();for(let l=0;l<s.length;l++){let c=s[l];Rv(c)&&(Us.resizeTextureLayer(e,t,c.uniforms[`f${c.id}_texture`].value),n.updateLayerUniform())}}static resizeComplex(e,t,r,n){let s=e/t,l,c=r.image;ub(c)?l=c.videoWidth/c.videoHeight:l=c.width/c.height,n.geometry.type.includes("Shape")?(s>l&&(r.imageType=="WEBCAM"?r.repeat.set(1/e*-1,1/t*l/s):r.repeat.set(1/e,1/t*l/s)),s<l&&(r.imageType=="WEBCAM"?r.repeat.set(1/e*s/l*-1,1/t):r.repeat.set(1/e*s/l,1/t)),s==l&&(r.imageType=="WEBCAM"?r.repeat.set(1/e*-1,1/t):r.repeat.set(1/e,1/t))):(s>l&&(r.imageType=="WEBCAM"?r.repeat.set(-1,1*l/s):r.repeat.set(1,1*l/s)),s<l&&(r.imageType=="WEBCAM"?r.repeat.set(1*s/l*-1,1):r.repeat.set(1*s/l,1)),s==l&&(r.imageType=="WEBCAM"?r.repeat.set(-1,1):r.repeat.set(1,1)))}};var $a=class extends hr{constructor(e,t=new vr){super(e,t);this.objectType="Mesh2D";this.castShadow=!0,this.receiveShadow=!0}updateGeometry(e){super.updateGeometry(e),this.material.userData.layers&&Us.resizeTextureLayers(this.geometry.userData.parameters.width,this.geometry.userData.parameters.height,this.material)}resizeGeometry(e,t){super.resizeGeometry(e,t,0),this.material.userData.layers&&Us.resizeTextureLayers(this.geometry.userData.parameters.width,this.geometry.userData.parameters.height,this.material)}toJSON(e){let t=super.toJSON(e);return t.object.objectType="Mesh2D",t}clone(){let e=super.clone();return e.updateGeometry({}),e}static fromTexture(e){let t,r;if(e instanceof Y3){let l=e.image;t=l.videoWidth*.5,r=l.videoHeight*.5}else{let l=e.image;t=l.width*.5,r=l.height*.5}let n=lu.create({parameters:{width:t,height:r}}),s=new vr;return s.layersList.changeLayer(0,{type:qe.TEXTURE,texture:e}),s.layersList.moveLayer(0,1),s.dispose(),new $a(n,s)}};var Ja=class extends hr{constructor(e,t=new Sn){super(e,t);this.objectType="Mesh3D";this.castShadow=!0,this.receiveShadow=!0}toJSON(e){let t=super.toJSON(e);return t.object.objectType="Mesh3D",t}};var Ka=class extends Ja{constructor(e,t=new Sn){super(e,t);this.objectType="NonParametric"}toJSON(e){let t=super.toJSON(e);return t.object.objectType="NonParametric",t}};var Xa;(function(t){t[t.TO_RIGHT=1]="TO_RIGHT",t[t.TO_LEFT=-1]="TO_LEFT"})(Xa||(Xa={}));var zd=class extends hr{constructor(e,t=new vr({transparent:!0,opacity:1,visible:!1,side:Vu})){super(e,t);this.objectType="TextFrame";this.charContainer=new Q3,this.add(this.charContainer),this.material.visible=!1,this._geometryUserData=e.userData,this.userData.textFrame={hexColor:null,opacity:1,visible:!0,text:"",fontSize:16,lineHeight:1.5,letterSpacing:1,fontFamily:"roboto_regular",textTransform:Wi.None,horizontalAlignment:1,verticalAlignment:xi.Top,LOD:16,maxLineSize:this._geometryUserData.parameters.width,textOrigin:new hb(this._geometryUserData.parameters.width*-.5,this._geometryUserData.parameters.height*.5,0),textLines:[]},this.createTextLine()}static createFromState(e,t,r){let n=cu.create({parameters:{width:t.width,height:t.height}}),s=new zd(n).fromState(t,r);return s.uuid=e,s}async updateText(e){this.clearText();let t=this.userData.textFrame,r=t.fontFamily;await Rr.loadFont(r),t.text=e;let n=t.textOrigin,s=new fb({visible:t.visible,transparent:!0,side:Vu}),l=e.split(`
|
|
977
|
-
`),c=0;this.userData.textFrame.textLines=l.map((f,h)=>{let p=new Ao(c,t.lineHeight,t.fontSize);return p.message=f.split("").map(y=>{let g={char:y,fontFamily:r,letterSpacing:t.letterSpacing,fontSize:t.fontSize,LOD:16},w=s.clone();w.color=t.hexColor,w.opacity=t.opacity;let S=new Rr(g,w);return p.addChar3D(S,n),this.charContainer.add(S),S}),c+=p.maxCharSize*p.lineHeight,p}),this.textFullUpdate(),this.checkOverFlow()}clearText(){let e=this.userData.textFrame.textLines;for(;this.charContainer.children.length;){let t=this.charContainer.children[0];this.charContainer.remove(t)}for(;e.length;)e.pop()}raycast(e,t){let r=[];if(super.raycast(e,r),r.length>0){t.push(r[0]);return}let n=[];for(let s=0,l=this.charContainer.children.length;s<l;++s)if(this.charContainer.children[s]instanceof Rr&&(e.intersectObject(this.charContainer.children[s],!1,n),n.length>0)){n[0].object=this,t.push(n[0]);return}}updateGeometry(e){var h,p,y,g;let t=this.userData,r=this.geometry.userData,n=r.parameters.width,s=r.parameters.height,l=(p=(h=e.parameters)==null?void 0:h.width)!=null?p:n,c=(g=(y=e.parameters)==null?void 0:y.height)!=null?g:s,f=t.textFrame;super.updateGeometry(e),f.maxLineSize=l,f.textOrigin.set(-.5*l,.5*c,0),c!==s?(this.checkOverFlow(),this.checkCapacity()):l!==n&&(n<l?this.checkCapacity():n>l&&this.checkOverFlow())}checkOverFlow(e=0){let t=this.userData,r=t.textFrame.textOrigin,n=t.textFrame.textLines;for(let s=e;s<n.length;s++){n[s].updateYLinePos(this.getNewLinePosition(s)),n[s].fullUpdate(r);let l=[];for(;n[s].checkOverFlow(t.textFrame.maxLineSize);)n[s].containSpaceOverFlow()?l.unshift(n[s].getWord(n[s].message.length-1,-1)):l.unshift(n[s].popChar());if(l.length>0){n[s+1]===void 0?(n[s].isEndLine(!1),this.createTextLine()):n[s].endLine&&(this.createTextLine(s+1),n[s].isEndLine(!1),n[s+1].isEndLine(!0));let c=0;for(let f=0;f<l.length;f+=1)for(let h=0;h<l[f].length;h+=1)n[s+1].addChar3D(l[f][h],r,c),c+=1;n[s+1].fullUpdate(r)}n[s].fullUpdate(r)}this.textFullUpdate(e)}checkCapacity(e=0){let t=this.userData,r=t.textFrame.textOrigin,n=t.textFrame.maxLineSize,s=t.textFrame.textLines;for(let l=e;l<s.length;l+=1)if(s[l].updateYLinePos(this.getNewLinePosition(l)),s[l].fullUpdate(r),!!s[l-1])for(;!s[l-1].endLine;){let c,f=s[l-1].spaceLeft(n);if(s[l].wordSize(0,1)<=f){s[l].containSpace()?c=s[l].getWord(0,1):c=s[l].popChar(0);for(let h=0;h<c.length;h+=1)c[h]&&s[l-1].addChar3D(c[h],r)}else{s[l].isEmpty()?(s[l].endLine&&s[l-1].isEndLine(!0),s.splice(l,1),l-=1):(s[l].updateYLinePos(this.getNewLinePosition(l)),s[l].fullUpdate(r));break}}this.textFullUpdate(e)}createTextLine(e=this.userData.textFrame.textLines.length){let r=this.userData.textFrame;r.textLines.splice(e,0,new Ao(this.getNewLinePosition(e),r.lineHeight,r.fontSize))}textFullUpdate(e=0){let r=this.userData.textFrame,n=r.textLines,s=this.getVerticalAlignmentOffSet();for(let l=e;l<n.length;l++)n[l].updateYLinePos(this.getNewLinePosition(l)),n[l].fullUpdate(r.textOrigin),n[l].alignText(r.textOrigin,r.maxLineSize,r.horizontalAlignment,r.verticalAlignment,s)}getVerticalAlignmentOffSet(){switch(this.userData.textFrame.verticalAlignment){case xi.Top:return 0;case xi.Center:return this.getRemainingVerticalSpace()/2;case xi.Bottom:return this.getRemainingVerticalSpace();default:return 0}}getRemainingVerticalSpace(){let t=this.userData.textFrame.textLines;return this.geometry.userData.parameters.height-this.getNewLinePosition(t.length)}getNewLinePosition(e){let r=this.userData.textFrame.textLines,n=0;for(let s=0;s<e;s+=1)n+=r[s].maxCharSize*r[s].lineHeight;return n}updateColor(e){var n;let t=this.userData;t.textFrame.hexColor=e;let r=t.textFrame.textLines;for(let s=0;s<r.length;s++){let l=r[s].message;for(let c=0;c<l.length;c++){let f=l[c].material;((n=f.color)==null?void 0:n.isColor)&&(f.color=e)}}}updateOpacity(e){let t=this.userData;t.textFrame.opacity=e;let r=t.textFrame.textLines;for(let n=0;n<r.length;n++){let s=r[n].message;for(let l=0;l<s.length;l++){let c=s[l].material;c.opacity=e}}}updateVisible(e){let t=this.userData;t.textFrame.visible=e;let r=t.textFrame.textLines;for(let n=0;n<r.length;n++){let s=r[n].message;for(let l=0;l<s.length;l++){let c=s[l].material;c.visible=e}}}async updateFontFamily(e){await Rr.loadFont(e);let r=this.userData.textFrame,n=r.textLines;r.fontFamily=e;for(let s=0;s<n.length;s++){let l=n[s].message;for(let c=0;c<l.length;c++)l[c].updateFontFamily(e)}this.textFullUpdate(),this.checkOverFlow(),this.checkCapacity()}updateFontSize(e){let r=this.userData.textFrame,n=r.textLines,s=r.fontSize;r.fontSize=e;for(let l=0;l<n.length;l++)n[l].updateFontSize(e);this.textFullUpdate(),e>s?this.checkOverFlow():e<s&&this.checkCapacity()}async updateTextTransform(e){let r=this.userData.textFrame;await Rr.loadFont(r.fontFamily);let n=r.textLines;switch(r.textTransform=e,e){case Wi.Upper:for(let s=0;s<n.length;s++){let l=n[s].message;for(let c=0;c<l.length;c++)n[s].message[c].updateChar(l[c].char.toUpperCase())}break;case Wi.Lower:for(let s=0;s<n.length;s++){let l=n[s].message;for(let c=0;c<l.length;c++)n[s].message[c].updateChar(l[c].char.toLowerCase())}break;default:for(let s=0;s<n.length;s++){let l=n[s].message;for(let c=0;c<l.length;c++)n[s].message[c].updateChar(l[c].originalChar)}}this.textFullUpdate(),this.checkOverFlow(),this.checkCapacity()}updateLetterSpacing(e){let t=this.userData,r=t.textFrame.textLines;t.textFrame.letterSpacing=e;for(let n=0;n<r.length;n++){let s=r[n].message;for(let l=0;l<s.length;l++)s[l].updateLetterSpacing(e)}this.textFullUpdate(),this.checkOverFlow(),this.checkCapacity()}updateLOD(e){let t=this.userData;t.textFrame.LOD=e;let r=t.textFrame.textLines;for(let n=0;n<r.length;n++);this.textFullUpdate(),this.checkOverFlow(),this.checkCapacity()}updateLineHeight(e){let t=this.userData,r=t.textFrame.textLines;t.textFrame.lineHeight=e;for(let n=0;n<r.length;n++)r[n].updatelineHeight(e);this.textFullUpdate()}updateVerticalAlignment(e){let t=this.userData;t.textFrame.verticalAlignment=e,this.textFullUpdate()}updateHorizontalAlignment(e){let t=this.userData;t.textFrame.horizontalAlignment=e,this.textFullUpdate()}toJSON(e){let t=super.toJSON(e),r=t.object;r.objectType="TextFrame";let s=this.userData.textFrame.textLines.map(l=>{let c=l.message.map(f=>({char:f.char,originalChar:f.originalChar,fontFamily:f.fontFamily,letterSpacing:f.letterSpacing,fontSize:f.fontSize,LOD:f.LOD}));return{align:l.align,endLine:l.endLine,lineHeight:l.lineHeight,maxCharSize:l.maxCharSize,yLinePos:l.yLinePos,message:c}});return r.userData.textFrame.textLinesData=s,t}async fromJSONasync(e){if(super.fromJSON(e),e.userData!==void 0){let t=e.userData.textFrame;await Rr.loadFont(t.fontFamily),t.textOrigin=new hb(t.textOrigin.x,t.textOrigin.y,t.textOrigin.z);let r=new fb({color:t.hexColor,opacity:t.opacity,visible:t.visible,transparent:!0,side:Vu});t.textLinesData&&(t.textLines=t.textLinesData.map((n,s)=>{let l=new Ao(Number(n.yLinePos),Number(n.lineHeight),Number(n.maxCharSize)),c=n.message.map((f,h)=>{if(f.char===void 0){let g=t.textLines[s].message[h];if("geometries"in g){let w=g.geometries[0].userData.parameters;Object.assign(f,{LOD:w.lod,char:w.char,fontFamily:w.fontFamily,fontSize:w.fontSize,letterSpacing:w.letterSpacing,originalChar:w.char})}}let p={char:f.char,fontFamily:f.fontFamily,letterSpacing:Number(f.letterSpacing),fontSize:Number(f.fontSize),LOD:f.LOD},y=new Rr(p,r.clone());return l.addChar3D(y,t.textOrigin),this.charContainer.add(y),y});return l.message=c,l}),this.userData.textFrame=t),this.textFullUpdate()}return this}fromTextFrameData(e,t){if(e.color!==void 0){let r=kt(e.color,t);this.updateColor(r),this.updateOpacity(r.a)}e.alpha!==void 0&&this.updateOpacity(e.alpha),e.font!==void 0&&this.updateFontFamily(e.font),e.horizontalAlign!==void 0&&this.updateHorizontalAlignment(e.horizontalAlign),e.verticalAlign!==void 0&&this.updateVerticalAlignment(e.verticalAlign),e.textTransform!==void 0&&this.updateTextTransform(e.textTransform),e.fontSize!==void 0&&this.updateFontSize(e.fontSize),e.lineHeight!==void 0&&this.updateLineHeight(e.lineHeight),e.letterSpacing!==void 0&&this.updateLetterSpacing(e.letterSpacing),e.text!==void 0&&e.text!==""&&this.updateText(e.text),(e.width!==void 0||e.height!==void 0)&&this.updateGeometry({parameters:{width:e.width,height:e.height}})}fromState(e,t){return super.fromState(e),this.fromTextFrameData(e,t),this}convertToVector(){let{fontFamily:e,hexColor:t}=this.userData.textFrame,r=new to;r.name="Text Shape";let n=Rr.fontCache[e];for(let s of this.charContainer.children)s instanceof Rr&&n.generateShapes(s.char,1).forEach(l=>{let c=new st().fromShape(l);c.applyScale(s.scale.x,s.scale.y);let f=ur.create({shape:c}),h=new vr({side:Vu});h.color=t;let p=new Oo(f,h);p.name=s.char,p.position.copy(s.position),p.rotation.copy(s.rotation),r.attach(p)});return r}},ks=zd;ks.VerticalAlign=xi,ks.HorizontalAlign=Lr,ks.TextTransform=Wi;import{HemisphereLight as pB,Scene as mB,Vector3 as gB,Color as _b,Fog as yB,Box3 as xB}from"three";import{BufferGeometryLoader as eB}from"three";function db(i,e){return tB(i)}function tB(i){let e={parameters:i,type:i.type};if(i.type==="VectorGeometry"){let r=st.createFromState(i.shape,i.width,i.height);e.shape=r}else i.type==="NonParametricGeometry"&&(i.data.groups&&i.data.groups.forEach(r=>{var n;return r.materialIndex=Math.max((n=r.materialIndex)!=null?n:0,0)}),e.geometry=new eB().parse(i));let t;try{t=Ia(e)}catch(r){console.error(r)}if(!t){let r=st.createFromState(Ls.defaultData(),100,100);e.shape=r,t=Ia(e)}return t}import{Box3 as rB,Matrix4 as Po,Sphere as gb,Vector3 as nB}from"three";var yb=rh(mb());var Fd;uu.then(i=>{Fd=i});var xb=new Po,iB=new Po,oB=new Po,Rn=new rB,ro=new nB,sB=new Po,aB=new Po,Za=class extends hr{constructor(e,t,r,n=new Sn){super(r!=null?r:t,n);this.subdivPointer=e;this.originalGeometry=t;this.subdividedGeometry=r;this.objectType="SubdivObject";this.hiddenMatrixOld=new Po;this.smoothShading=!0;this.matrixWorldRigid=new Po;this.castShadow=!0,this.receiveShadow=!0,this.forceComputeSize=!1}static createFromState(e,t,r){let{subdivPointer:n,originalGeometry:s,subdividedGeometry:l}=en.build(t.geometry,void 0,void 0,!t.flatShading),c=Fa(t.material,r),f=new Za(n,s,l||void 0,c);return f.calcBoundingBox(),f.freeSubdivPointer(),f.uuid=e,f.fromState(t),f}shallowClone(e){return new Ka(this.geometry,this.material).shallowCopy(this,e)}toJSON(e){let t=super.toJSON(e);return t.object.objectType="SubdivObject",t}buildFromStore(e){var s,l,c;let{originalGeometry:t,subdividedGeometry:r,subdivPointer:n}=en.build(e,this.subdivPointer,void 0,this.smoothShading,this.shearScale);if(this.subdivPointer=n,t!==void 0&&((s=this.originalGeometry)==null||s.dispose(),this.originalGeometry=t),r!==void 0&&((l=this.subdividedGeometry)==null||l.dispose(),this.subdividedGeometry=r!=null?r:void 0),this.geometry=(c=this.subdividedGeometry)!=null?c:this.originalGeometry,this.cloner)for(let f of this.cloner.children)f.geometry=this.geometry;e.width&&(this.geometry.userData.parameters={width:e.width,height:e.height,depth:e.depth})}updateMesh(e=!1){en.buildLevel(this.subdivPointer,!0,this.smoothShading,this.originalGeometry,e?this.shearScaleInv:void 0),this.subdividedGeometry&&en.buildLevel(this.subdivPointer,!1,this.smoothShading,this.subdividedGeometry,e?this.shearScaleInv:void 0)}updateTopology(){var e;this.originalGeometry.dispose(),this.originalGeometry=en.buildLevel(this.subdivPointer,!0,this.smoothShading),this.subdividedGeometry&&(this.subdividedGeometry.dispose(),this.subdividedGeometry=en.buildLevel(this.subdivPointer,!1,this.smoothShading)),this.geometry=(e=this.subdividedGeometry)!=null?e:this.originalGeometry}raycast(e,t){var r;this.geometry=this.originalGeometry,hr.prototype.raycast.call(this,e,t),this.geometry=(r=this.subdividedGeometry)!=null?r:this.originalGeometry}updateMatrixWorldSVD(){let e=this.matrixWorld.elements,t=[[e[0],e[4],e[8]],[e[1],e[5],e[9]],[e[2],e[6],e[10]]],{u:r,v:n,q:s}=(0,yb.SVD)(t),l=xb.set(r[0][0],r[0][1],r[0][2],0,r[1][0],r[1][1],r[1][2],0,r[2][0],r[2][1],r[2][2],0,0,0,0,1),c=iB.set(n[0][0],n[0][1],n[0][2],0,n[1][0],n[1][1],n[1][2],0,n[2][0],n[2][1],n[2][2],0,0,0,0,1),f=oB.copy(c).transpose();this.shearScale=sB.makeScale(s[0],s[1],s[2]).multiply(f).premultiply(c),this.shearScaleInv=aB.copy(this.shearScale).invert(),this.matrixWorldRigid.multiplyMatrices(l,f),s.every(h=>Math.abs(s[0]-h)<.01)&&(this.shearScale=void 0,this.shearScaleInv=void 0)}activateSVDCompensation(){this.shearScale!==void 0&&(this.matrixAutoUpdate=!1,this.matrix.copy(this.matrixWorldRigid).copyPosition(this.matrixWorld),this.hiddenMatrixOld.copy(this.hiddenMatrix),this.hiddenMatrix.copy(this.parent.matrixWorld).invert())}deactivateSVDCompensation(){this.shearScale!==void 0&&(this.shearScale=void 0,this.shearScaleInv=void 0,this.matrixAutoUpdate=!0,this.hiddenMatrix.copy(this.hiddenMatrixOld))}calcBoundingBox(){let e=this.originalGeometry;e.boundingSphere===null&&(e.boundingSphere=new gb);let t=e.attributes.position,r=e.boundingSphere.center;Rn.setFromBufferAttribute(t),Rn.getCenter(r),e.boundingSphere.radius=r.distanceTo(Rn.max),isNaN(e.boundingSphere.radius)&&console.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.',this),Rn.getSize(ro);let n={width:ro.x,height:ro.y,depth:ro.z};return this.geometry.userData.parameters=n,n}updateBoundingBox(e){let t=this.originalGeometry;Rn.min.set(e[0],e[2],e[4]),Rn.max.set(e[1],e[3],e[5]),this.shearScaleInv&&(Rn.min.applyMatrix4(this.shearScaleInv),Rn.max.applyMatrix4(this.shearScaleInv)),t.boundingSphere===null&&(t.boundingSphere=new gb);let r=t.boundingSphere.center;Rn.getCenter(r),t.boundingSphere.radius=r.distanceTo(Rn.max),isNaN(t.boundingSphere.radius)&&console.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.',this),Rn.getSize(ro);let n={width:ro.x,height:ro.y,depth:ro.z};return this.geometry.userData.parameters=n,n}freeSubdivPointer(){this.subdivPointer&&(Fd.free_bvh(this.subdivPointer),Fd.free_subdivision_surface(this.subdivPointer),this.subdivPointer=0)}updateGeometry(e){this.geometry.userData.scale||(this.geometry.userData.scale=Array(3)),this.geometry.userData.scale[0]=this.geometry.userData.parameters.width===0?1:e.parameters.width/this.geometry.userData.parameters.width,this.geometry.userData.scale[1]=this.geometry.userData.parameters.height===0?1:e.parameters.height/this.geometry.userData.parameters.height,this.geometry.userData.scale[2]=this.geometry.userData.parameters.depth===0?1:e.parameters.depth/this.geometry.userData.parameters.depth,vb(this.originalGeometry.attributes,...this.geometry.userData.scale),this.originalGeometry.attributes.position.needsUpdate=!0,this.originalGeometry.attributes.normal.needsUpdate=!0,this.subdividedGeometry&&(vb(this.subdividedGeometry.attributes,...this.subdividedGeometry.userData.scale),this.subdividedGeometry.attributes.position.needsUpdate=!0,this.subdividedGeometry.attributes.normal.needsUpdate=!0),this.geometry.userData.parameters=U({},e.parameters)}};function vb(i,e,t,r){let n=i.position.array,s=i.normal.array,l=xb.makeScale(e,t,r).invert().elements,c,f,h;for(var p=0,y=n.length;p<y;p+=3)n[p]*=e,n[p+1]*=t,n[p+2]*=r,c=s[p],f=s[p+1],h=s[p+2],s[p]=l[0]*c+l[4]*f+l[8]*h,s[p+1]=l[1]*c+l[5]*f+l[9]*h,s[p+2]=l[2]*c+l[6]*f+l[10]*h}import{BackSide as lB,DoubleSide as cB,FrontSide as uB}from"three";function bb(i,e){e.flatShading!==void 0&&(i.flatShading=e.flatShading,i.needsUpdate=!0),e.wireframe!==void 0&&(i.wireframe=e.wireframe),e.side!==void 0&&(e.side===Ss.Front?i.side=uB:e.side===Ss.Back?i.side=lB:i.side=cB)}function fB(i,e){if(Array.isArray(i.material))for(let t of i.material)bb(t,e);else{let t=i.material;bb(t,e)}i.objectType==="SubdivObject"&&e.flatShading!==void 0&&(i.material.flatShading=!1,i.smoothShading=!e.flatShading,i.updateMesh())}function Sb(i,e,t){let r;if(e.geometry.type==="SubdivGeometry")r=Za.createFromState(i,e,t);else{let n=db(e.geometry,t),s="materials"in e?Zv(e.materials,t):Fa(e.material,t);Uc.is2DParametricMesh(n.userData.type)?r=new $a(n,s):(n==null?void 0:n.userData.type)==="VectorGeometry"?r=new Oo(n,s):e.geometry.type==="NonParametricGeometry"?r=new Ka(n,s):r=new Ja(n,s),r.uuid=i,r.fromState(e)}return fB(r,e),r}function wb(i,e,t){return e.type==="Mesh"?Sb(i,e,t):e.type==="TextFrame"?ks.createFromState(i,e,t):e.type==="Empty"?to.createFromState(i,e):e.type==="PointLight"?Wa.createFromState(i,e,t):e.type==="SpotLight"?qa.createFromState(i,e,t):e.type==="DirectionalLight"?Ha.createFromState(i,e,t):gs.is(e.type)?eo.createFromState(i,e):(console.error(e),new to)}function hB(i,e){e.uniforms[`f${e.id}_transmissionSamplerMap`].value=i.texture,e.uniforms[`f${e.id}_transmissionDepthMap`].value=i.depthTexture}function Nb(i,e,t){if(!t.userData.layers)return!1;let r=!1,n=t.userData.layers.getLayersOfType(qe.TRANSMISSION);return n.length>0?(e.layers.set(3),r=!0,i!==void 0&&n.forEach(s=>hB(i,s))):e.layers.set(0),r}function Cb(i,e){let t=!1;return e.traverseEntity(r=>{if(r instanceof hr)if(Array.isArray(r.material))for(let n=0;n<r.material.length;n++)Nb(i,r,r.material[n])&&(t=!0);else Nb(i,r,r.material)&&(t=!0)}),t}function Lb(i,e){"material"in i&&dB(i.material,e),"geometry"in i&&i.geometry.dispose()}function dB(i,e){yg(i).forEach(t=>{e.isSharedMaterial(t)||t.dispose()})}var Tb=new gB,Vd=class extends mu(mB){constructor(e,t){super();this.objectType="Scene";this.alpha=1;this.backupFog=new yB(16777215,.1,2e3);this.fogUseBGColor=!1;this.wireframeState=!1;this.needsTransmissionDirty=!0;this._needsTransmission=!1;this._color=new _b(1,0,0);this.bgColor=new _b(1,1,1);this.entityByUuid={};this.ambientLight=new pB(13882323,8553090,.75),this.ambientLight.name="Default Ambient Light",this.personalCamera=this.createPersonalCamera(),this.activeCamera=this.personalCamera,this.sharedAssetManager=t,this.init(e,t)}needsTransmission(e){return this.needsTransmissionDirty&&(this._needsTransmission=Cb(e,this),e!==void 0&&(this.needsTransmissionDirty=!1)),this._needsTransmission}find(e){if(e===""||e===void 0)return;let t=this.entityByUuid[e];return t===void 0?this.getObjectByProperty("uuid",e):t}get color(){return this._color}set color(e){this.fogUseBGColor===!0&&this.backupFog.color.copy(e),this._color.copy(e)}get enableFog(){return this.fog!==null}set enableFog(e){this.fog=e===!0?this.backupFog:null}init(e,t){if(this.createChildrenObjects(e.objects,this,t),this.personalCamera.removeFromParent(),this.add(this.personalCamera),this.ambientLight.removeFromParent(),this.add(this.ambientLight),this.setBackgroundColor(kt(e.backgroundColor,t)),this.updateFog(e.fog,t),this.updateAmbientLight(e.environment.ambientLight,t),this.activeCamera=this.personalCamera,e.publish.playCamera!==null){let r=this.find(e.publish.playCamera);r instanceof eo&&this.switchActiveCamera(r)}}clearScene(e){this.traverseEntity(t=>{Lb(t,e)});for(let t of this.children)xn(t)&&t.removeFromParent()}resetAfterClear(e,t){this.init(e,t)}createPersonalCamera(){let e=eo.createFromState(Vd.PERSONAL_CAMERA_ID,fe(U({},Hc.defaultData),{name:"Personal Camera"}));return e.enableHelper=!1,e.objectHelper.visible=!1,delete e.isEntity,this.registerObjectCreatedInLegacy(e),e}raycast(e){let t=[],r=n=>{for(let s of n.children)xn(s)&&!s.raycastLock&&s.visible&&((Ms(s)||Si(s)&&s.enableHelper&&s.objectHelper.parent)&&e.intersectObject(s,!1,t),r(s))};return r(this),t}traverseEntity(e){for(let t of this.children)xn(t)&&t.traverseEntity(e)}updateFog(e,t){this.enableFog=e.enabled,this.fogUseBGColor=e.useBackgroundColor,e.useBackgroundColor?this.backupFog.color.set(this.bgColor):this.backupFog.color=kt(e.color,t),this.backupFog.near=e.near,this.backupFog.far=e.far}toJSON(e){return{}}fromJSON(e){return this}dispose(){this.clearScene(this.sharedAssetManager),this.sharedAssetManager.dispose()}updateAmbientLight(e,t){gv(this.ambientLight,e,t),e.groundColor!==void 0&&(this.ambientLight.groundColor=kt(e.groundColor,t)),e.enabled!==void 0&&(this.ambientLight.visible=e.enabled)}switchActiveCamera(e){this.activeCamera!==this.personalCamera&&(this.activeCamera.enableHelper=!0),this.activeCamera=e,e.enableHelper=!1}setBackgroundColor(e){this.bgColor=e,this.alpha=e.a}createChildrenObjects(e,t,r){for(let n of e)this.createChildObject(n.id,n.data,n.children,t,r)}registerObjectCreatedInLegacy(e){this.entityByUuid[e.uuid]=e}unregisterObject(e){delete this.entityByUuid[e.uuid];for(let t of e.children)this.unregisterObject(t)}createChildObject(e,t,r,n,s){let l=wb(e,t,s);return l&&(this.entityByUuid[e]=l,n.add(l),this.createChildrenObjects(r,l,s)),l}getCenter(e){let t=[];for(let n=0,s=e.length;n<s;++n){let{id:l,recursive:c}=e[n],f=this.find(l),h=c?f.recursiveBBox:f.singleBBox;t.push(...h.vertices)}let r=new xB;return r.setFromPoints(t),r.getCenter(Tb),Tb}copyMatrixWorld(e,t){if(e===null){t.identity();return}let r=this.find(e);r?t.copy(r.matrixWorld):t.identity()}copyParentMatrixWorld(e,t){var n;if(e===null){t.identity();return}let r=(n=this.find(e))==null?void 0:n.parent;r?t.copy(r.matrixWorld):t.identity()}traverseMaterial(e){this.traverseEntity(t=>{if(t instanceof hr)if(Array.isArray(t.material))for(let r=0;r<t.material.length;r++)e(t.material[r]);else e(t.material)})}updateCanvasSize(e,t){this.activeCamera.setViewplaneSize(e,t);let r,n;e>=t?(r=t/e,n=1):(r=1,n=e/t),this.traverseMaterial(s=>{s.layersList.getLayersOfType(qe.TRANSMISSION).forEach(c=>{c.uniforms[`f${c.id}_aspectRatio`].value.x=r,c.uniforms[`f${c.id}_aspectRatio`].value.y=n})})}},ku=Vd;ku.PERSONAL_CAMERA_ID="f23858d0-4a3b-4bd8-8173-66ed0af7f6fb-personalCamera";import{WebGLRenderTarget as vB,LinearMipmapLinearFilter as bB,LinearFilter as SB,ClampToEdgeWrapping as Ib,DepthTexture as wB}from"three";var Mb=new vr,Ud=class extends tn{},kd=class{constructor(e){this.materials={};this.images={};this.colors={};this.transmissionRenderTarget=new vB(2048,2048,{generateMipmaps:!0,minFilter:bB,magFilter:SB,wrapS:Ib,wrapT:Ib}),this.transmissionRenderTarget.depthTexture=new wB(2048,2048),this.reset(e)}reset(e){for(let[t,r]of Object.entries(e.images))this.addImage(t,r.data);for(let[t,r]of Object.entries(e.colors))this.addColor(t,r);for(let[t,r]of Object.entries(e.materials))this.addMaterial(t,Dd(r,this))}get transmissionSamplerMap(){return this.transmissionRenderTarget.texture}get transmissionDepthMap(){return this.transmissionRenderTarget.depthTexture}addMaterial(e,t){t.uuid=e,this.materials[e]=t}deleteMaterial(e){this.materials[e]&&(this.materials[e].dispose(),delete this.materials[e])}isSharedMaterial(e){return e.uuid in this.materials||e===Mb}getMaterial(e){let t=this.materials[e];return t}getMaterialOrDeletedPlaceholder(e){var t;return(t=this.materials[e])!=null?t:Mb}getMaterials(){return this.materials}addImage(e,t){if(this.images[e])return this.images[e].onload=()=>{this.onImageLoad&&this.onImageLoad(e)},this.images[e].src=t,!0;{let r=new Image;return r.src=t,r.onload=()=>{this.onImageLoad&&this.onImageLoad(e)},this.images[e]=r,!1}}deleteImage(e){this.images[e]&&delete this.images[e]}getDefaultImage(){return this.images.image_0}getImage(e){return this.images[e]}getImages(){return this.images}addColor(e,t){return this.colors[e]?("a"in t?this.colors[e].setRGBA(t.r,t.g,t.b,t.a):this.colors[e].setRGBA(t.r,t.g,t.b,1),!0):("a"in t?this.colors[e]=new Ud(t.r,t.g,t.b,t.a):this.colors[e]=new Ud(t.r,t.g,t.b,1),!1)}updateColor(e,t){var r,n,s,l;if(this.colors[e]){let c=this.colors[e];return this.colors[e].r=(r=t.r)!=null?r:c.r,this.colors[e].g=(n=t.g)!=null?n:c.g,this.colors[e].b=(s=t.b)!=null?s:c.b,this.colors[e].a=(l=t.a)!=null?l:c.a,!0}return!1}deleteColor(e){this.colors[e]&&delete this.colors[e]}getColor(e){return this.colors[e]}dispose(){Object.keys(this.materials).forEach(t=>this.deleteMaterial(t)),this.transmissionRenderTarget.depthTexture.dispose(),this.transmissionRenderTarget.dispose(),this.onImageLoad=void 0}};import{Color as Ob,ShaderLib as NB}from"three";var Pb=rh(Ab());function Db(i){let e=new Set;return i.traverse(t=>{if(Ms(t))if((0,Pb.isArray)(t.material))t.material.forEach(r=>{let n=r;e.has(n)||e.add(n)});else{let r=t.material;e.has(r)||e.add(r)}}),e.forEach(t=>{let r=t.onBeforeCompile.bind(t);CB(t)?(Object.assign(t,{isMeshStandardMaterial:!0,isMeshPhysicalMaterial:!0,transmission:1,attenuationColor:new Ob,specularColor:new Ob}),t.onBeforeCompile=(n,s)=>{r&&r(n,s),n.uniforms=Object.assign(NB.physical.uniforms,n.uniforms),t.userData.layers.getLayersOfType(qe.TRANSMISSION).forEach(l=>{n.uniforms.transmissionSamplerMap.value&&(l.uniforms["f"+l.id+"_transmissionSamplerMap"].value=n.uniforms.transmissionSamplerMap.value,l.uniforms["f"+l.id+"_transmissionSamplerSize"].value=n.uniforms.transmissionSamplerSize.value)})}):LB(t)||(t.onBeforeCompile=(n,s)=>{r&&r(n,s),t.transparent=!1})}),i}function CB(i){return i.userData.layers.getLayersOfType(qe.TRANSMISSION).length>0}function LB(i){let e=i.userData.layers.head,t=0;for(;e!==void 0;){if(e.type!==qe.LIGHTING&&e.type!==qe.FRESNEL){let r=e.uniforms["f"+e.id+"_alpha"];r&&(t+=(1-t)*r.value)}e=e.next}return t<1}function Bb(i){return i.traverse(e=>{if(e.type==="Camera"){let t=e;t.type=t.cameraType}}),i}var Gb=class extends TB{load(e,t,r,n=console.error){let s=new _B(this.manager);s.setPath(this.path),s.setResponseType("arraybuffer"),s.setRequestHeader(this.requestHeader),s.setWithCredentials(this.withCredentials),s.load(e,l=>{try{if(typeof l=="string")throw new Error("The .spline file is not binary!");t(this.parse(l))}catch(c){n(c)}},r,n)}parse(e){let t=Bc.deserialize(new Uint8Array(e)),r=new kd(t.shared),n=new ku(t.scene,r);return Bb(Db(n))}};export{Gb as default};
|
|
975
|
+
`),h&&g.push(h.code,`outgoingLight = spe_blend(outgoingLight, ${h.result}, 1.0, SPE_BLENDING_NORMAL);`),d?g.push(`gl_FragColor = vec4( outgoingLight, accumAlpha * ${d.result} );`):g.push("gl_FragColor = vec4( outgoingLight, 1.0 );"),g.push("#include <encodings_fragment>","#include <fog_fragment>","#include <dithering_fragment>"),t=g.join(`
|
|
976
|
+
`)}return t}copy(e){return super.copy(e),e.color&&(this.color=e.color.clone()),this.roughness=e.roughness.clone(),this.metalness=e.metalness.clone(),e.position&&(this.position=e.position.clone()),e.afterColor&&(this.afterColor=e.afterColor.clone()),e.alpha&&(this.alpha=e.alpha.clone()),e.reflectivity&&(this.reflectivity=e.reflectivity.clone()),e.shadingAlpha&&(this.shadingAlpha=e.shadingAlpha.clone()),e.shadingBlend&&(this.shadingBlend=e.shadingBlend.clone()),this}};var wp=class extends vn{get color(){return this.fragment.color}set color(e){this.fragment.color=e}get afterColor(){return this.fragment.afterColor}set afterColor(e){this.fragment.afterColor=e}get alpha(){return this.fragment.alpha}set alpha(e){this.fragment.alpha=e}get shadingAlpha(){return this.fragment.shadingAlpha}set shadingAlpha(e){this.fragment.shadingAlpha=e}get shadingBlend(){return this.fragment.shadingBlend}set shadingBlend(e){this.fragment.shadingBlend=e}get position(){return this.fragment.position}set position(e){this.fragment.position=e}get roughness(){return this.fragment.roughness}set roughness(e){this.fragment.roughness=e}get metalness(){return this.fragment.metalness}set metalness(e){this.fragment.metalness=e}get reflectivity(){return this.fragment.reflectivity}set reflectivity(e){this.fragment.reflectivity=e}constructor(e=new Sp,t){super(e,e,t);this.type="StandardNodeMaterial",this.fragment=e}};var ja=class extends wp{constructor(e,t,r){super(t,e);this.userData.type="PhysicalMaterial",this.userData.category="Physical",this.userData.layers=r!=null?r:this._getLayerStack(e==null?void 0:e.map)}get layersList(){return this.userData.layers}set layersList(e){this.userData.layers=e}equals(e){return this.userData.type===e.userData.type&&this.userData.layers.uuid==e.userData.layers.uuid}copy(e){if(e.userData.layers!==void 0&&e.userData.layers instanceof Ir){let t=e.userData.layers,r=e.fragment;super.copy(e);let n=r.clone();this.fragment=n,this.vertex=n;let s=t.clone(this);this.userData.layers=s,n.shadingAlpha.value=r.shadingAlpha.value,n.shadingBlend.value=r.shadingBlend.value}else super.copy(e);return this}static fromJSON(e,t,r){let n=r.getNode(t.vertex),s=new ja(void 0,n);return s.fromJSON(t,r),s}dispose(){super.dispose()}};import{Color as Cp}from"three";import{Matrix3 as Iv,Texture as Np,Vector2 as Ea,Vector3 as Zi,Vector4 as Mv}from"three";function Av(i,e){switch(i.data.type){case"light":return Gn(i);case"fresnel":return BD(i,e);case"gradient":return GD(i);case"depth":return jD(i);case"normal":return ED(i);case"noise":return RD(i,e);case"texture":return zD(i,e);case"rainbow":return FD(i);case"transmission":return VD(i,e);case"matcap":return UD(i,e);case"displace":return kD(i);case"color":default:return DD(i,e)}}function Ov(i){return{type:i.data.type}}function Gn(i){let{alpha:e,mode:t}=i.data;return fe(U({},Ov(i)),{alpha:e,mode:t})}function DD(i,e){return fe(U({},Gn(i)),{color:kt(i.data.color,e)})}function BD(i,e){let{bias:t,scale:r,intensity:n,factor:s,color:l}=i.data;return fe(U({},Gn(i)),{color:kt(l,e),bias:t,scale:r,intensity:n,factor:s})}function GD(i){let{gradientType:e,smooth:t,colors:r,steps:n,angle:s,offset:l,morph:c}=i.data;return fe(U({},Gn(i)),{gradientType:e,smooth:t,colors:r.map(f=>new Mv(f[0],f[1],f[2],f[3])),num:r.length,steps:n,offset:new Ea(...l),morph:new Ea(...c),angle:s})}function jD(i){let{gradientType:e,near:t,far:r,isVector:n,isWorldSpace:s,origin:l,direction:c,colors:f,steps:h,smooth:d,num:x}=i.data;return fe(U({},Gn(i)),{gradientType:e,near:t,far:r,isVector:n,isWorldSpace:s,origin:new Zi(...l),direction:c?new Zi(...c):new Zi(1,0,0),num:x,colors:f.map(g=>new Mv(g[0],g[1],g[2],g[3])),steps:h,smooth:d})}function ED(i){let{cnormal:e}=i.data;return fe(U({},Gn(i)),{cnormal:new Zi(e[0],e[1],e[2])})}function RD(i,e){let{data:t}=i;return fe(U({},Gn(i)),{scale:t.scale,move:t.move,fA:new Ea(...t.fA),fB:new Ea(...t.fB),size:new Zi(...t.size),distortion:new Ea(...t.distortion),colorA:kt(t.colorA,e),colorB:kt(t.colorB,e),colorC:kt(t.colorC,e),colorD:kt(t.colorD,e),noiseType:t.noiseType})}function zD(i,e){let{projection:t,axis:r,crop:n,size:s}=i.data,{image:l,wrapping:c,repeat:f,offset:h}=i.data.texture,d=new Np,x;if(typeof l=="string")x=e==null?void 0:e.getImage(l);else{let g=new Image;g.src=l.data,g.onload=()=>{(e==null?void 0:e.onImageLoad)&&(e==null||e.onImageLoad(l.data))},x=g}return d.image=x,d.repeat.set(f[0],f[1]),d.offset.set(h[0],h[1]),d.wrapS=d.wrapT=c,fe(U({},Gn(i)),{texture:d,mat:new Iv().setUvTransform(h[0],h[1],f[0],f[1],0,0,0),crop:n,projection:t,axis:["x","y","z"].indexOf(r),size:s})}function FD(i){let{data:e}=i;return fe(U({},Gn(i)),{filmThickness:e.filmThickness,movement:e.movement,wavelengths:new Zi(...e.wavelengths),noiseStrength:e.noiseStrength,noiseScale:e.noiseScale,offset:new Zi(...e.offset)})}function VD(i,e){let{data:t}=i;return fe(U({},Gn(i)),{thickness:t.thickness,ior:t.ior,roughness:t.roughness,transmissionSamplerMap:e.transmissionSamplerMap,transmissionDepthMap:e.transmissionDepthMap})}function UD(i,e){let t=new Np,{image:r}=i.data.texture,n;if(typeof r=="string")n=e==null?void 0:e.getImage(r);else{let l=new Image;l.src=r.data,l.onload=()=>{(e==null?void 0:e.onImageLoad)&&(e==null||e.onImageLoad(r.data))},n=l}t.image=n;let s=16777215;return fe(U({},Gn(i)),{color:s,texture:t})}function kD(i){let{data:e}=i,t=fe(U({},Ov(i)),{intensity:e.intensity});if(e.displacementType==="noise")return fe(U({},t),{offset:new Zi(...e.offset),scale:e.scale,movement:e.movement,noiseType:e.noiseType});{let r=new Np,n=new Iv().setUvTransform(0,0,1,1,0,0,0);return fe(U({},t),{texture:r,mat:n,crop:e.crop})}}function Pv(i,e,t){if(t.type==="displace"&&(i==="intensity"||i==="visible")){let r=e.uniforms[`f${e.id}_intensity`];return r?(r.value=t.intensity*(t.visible?1:0),r):void 0}if(t.type!=="displace"&&(i==="alpha"||i==="visible")){let r=e.uniforms[`f${e.id}_alpha`];return r?(r.value=t.alpha*(t.visible?1:0),r):void 0}}import{Color as Dv,Vector4 as HD}from"three";var js;(function(e){function i(t){return new Dv(t.x,t.y,t.z).getHex()}e.getHex=i})(js||(js={}));var Bv;(function(e){function i(t){return new HD(t.r,t.g,t.b,t.a)}e.getThreeVector4=i})(Bv||(Bv={}));var Gv;(function(t){function i(r,n){r.setRGB(n.r,n.g,n.b)}t.setThreeColor=i;function e(r){return new Dv(r.r,r.g,r.b).getHex()}t.getHex=e})(Gv||(Gv={}));function Ra(i,e){return typeof i=="string"?e.getMaterialOrDeletedPlaceholder(i):Lp(i,e)}function jv(i,e){return i.map(t=>Ra(t,e))}function Lp(i,e){var l,c;let t=(l=i.layers)!=null?l:Ss.defaultTwoLayerData("phong").layers,r=WD(t),n;switch(r.category){case"basic":n=new vr;break;case"lambert":{n=new Ba;break}case"toon":{n=new Ga;break}case"physical":n=new ja;break;case"phong":default:{n=new bn;break}}n.name=(c=i.name)!=null?c:"Untitled Material";let s=n.userData.layers;qD(s);for(let f=t.length-1;f>=0;f--)$D(s,t[f],e);switch(r.category){case"basic":break;case"lambert":{let d=n,g=kt(r.emissive,e);g instanceof Cp?d.emissive.value=g:d.emissive.value.setHex(js.getHex(g));break}case"toon":{let d=n,x=r;d.shininess.value=x.shininess;let g=kt(x.specular,e);g instanceof Cp?d.specular.value=g:d.specular.value.setHex(js.getHex(g));break}case"physical":let f=n,h=r;f.metalness.value=h.metalness,f.roughness.value=h.roughness,f.reflectivity.value=h.reflectivity;break;case"phong":default:{let d=n,x=r;d.shininess.value=x.shininess;let g=kt(x.specular,e);g instanceof Cp?d.specular.value=g:d.specular.value.setHex(js.getHex(g));break}}return s.blendColors(),s.blendAfterColors(),s.blendPositions(),n}function WD(i){for(let e of i)if(e.data.type==="light")return e.data;return{type:"light",category:"basic",visible:!0,alpha:1,mode:Zt.Normal}}function qD(i){for(let e of i.getLayers())i.removeLayer(e.id)}function $D(i,e,t){let r=Av(e,t);r.type==="transmission"&&(r.transmissionSamplerMap=t==null?void 0:t.transmissionSamplerMap,r.transmissionDepthMap=t==null?void 0:t.transmissionDepthMap);let n=i.addLayer(r);n.uuid=e.id;for(let s in e.data)Pv(s,n,e.data)}import{Vector2 as Ev}from"three";var Tu=new Ev,To=class{constructor(e,t,r){this.message=[];this.endLine=!0;this.yLinePos=e,this.lineHeight=t,this.maxCharSize=r,this.nextChar3DPos=new Ev(0,this.yLinePos+this.maxCharSize*this.lineHeight),this.align=Lr.Left}addChar3D(e,t,r=this.message.length){this.message.splice(r,0,e),e.fontSize>this.maxCharSize?(this.maxCharSize=e.fontSize,this.nextChar3DPos.y=this.yLinePos+this.maxCharSize*this.lineHeight,this.fullUpdate(t)):(e.updatePosition(this.nextChar3DPos,t),this.nextChar3DPos.x+=e.charSize)}deleteChar3D(e=this.message.length-1){let t=this.message[e];if(t)return this.message.splice(e,1),this.nextChar3DPos.x-=t.charSize,t}isEndLine(e){this.endLine=e}fullUpdate(e,t=0){this.nextChar3DPos.x=0;for(let r=t,n=this.message.length;r<n;r+=1)this.message[r].updatePosition(this.nextChar3DPos,e),this.nextChar3DPos.x+=this.message[r].charSize}checkOverFlow(e){let t,r=this.message.length-1;if(r<=0)return!1;for(;r>=0;){if(this.message[r].char!==" "){t=this.message[r];break}r-=1}return!!(r>=0&&t&&t.localPosition.x+t.charSize>e)}containSpaceOverFlow(e=this.message.length-1){for(let t=e;t>=0;t-=1)if(this.message[t].char===" ")return!0;return!1}containSpace(e=this.message.length-1){if(this.endLine)return!0;for(let t=e;t>=0;t-=1)if(this.message[t].char===" ")return!0;return!1}popWord(e=this.message.length-1){let t=[],r=!0,n;for(n=e;n>=0;n-=1)if(this.message[n].char===" "){r=!1,t.length===0&&(n-=1,t.splice(0,0,this.message[n]));break}else t.splice(0,0,this.message[n]);return r?t=[]:this.message.splice(n+1,t.length),t}getWord(e=0,t=1){let r=[],n=e;for(n=e;;n+=t){if(!this.message[n]||this.message[n].char===" "){r.length===0&&this.message[n]&&(r.push(this.message[n]),this.message.splice(n,1));break}t>0?(r.push(this.message[n]),this.message.splice(n,1),n-=t):(r.splice(0,0,this.message[n]),this.message.splice(n,1))}return r}getWordAtIndex(e){let t=[];for(let r=e;r<this.message.length&&this.message[r].char!==" ";r++)t.push(this.message[r]);for(let r=e-1;r>=0&&this.message[r].char!==" ";r--)t.splice(0,0,this.message[r]);return t}wordSize(e=0,t=-1){let r=0,n=e;for(;n>=0&&n<this.message.length;){if(this.message[n].char===" "){r===0&&(r=this.message[n].charSize);break}r+=this.message[n].charSize,n+=t}return(n<0||n>=this.message.length)&&!this.endLine?this.message[e]?this.message[e].charSize:999999999:r===0?999999999:r}spaceLeft(e){return e-this.nextChar3DPos.x}popChar(e=this.message.length-1){return this.nextChar3DPos.x-=this.message[e].charSize,this.message.splice(e,1)}isEmpty(){return!this.message.length}updateNextCharPosY(){this.nextChar3DPos.y=this.yLinePos+this.maxCharSize*this.lineHeight}updateYLinePos(e){this.yLinePos=e,this.updateNextCharPosY()}updatelineHeight(e){this.lineHeight=e,this.updateNextCharPosY()}updateFontSize(e,t=0,r=this.message.length-1){for(let n=t;n<=r;n+=1)this.message[n].updateFontSize(e);this.maxCharSize=e,this.nextChar3DPos.y=this.yLinePos+this.maxCharSize*this.lineHeight}countSpaces(){let e=0;for(let t=0;t<this.message.length;t++)this.message[t].char===" "&&(e+=1);return e}alignText(e,t,r,n,s){switch(r){case Lr.Left:this.leftAlign(e,s);break;case Lr.Center:this.centerAlign(this.spaceLeft(t),e,s);break;case Lr.Right:this.rightAlign(this.spaceLeft(t),e,s);break;case Lr.Justify:this.justifyAlign(this.spaceLeft(t),e,s);break}}offsetCharacters(e,t,r){Tu.set(t,r);let n=this.message.length;for(let s=0;s<n;s++)this.message[s].updatePosition(this.message[s].localPosition.add(Tu),e)}leftAlign(e,t){this.align=Lr.Left,this.offsetCharacters(e,0,t)}centerAlign(e,t,r){this.align=Lr.Center,this.offsetCharacters(t,e/2,r)}rightAlign(e,t,r){this.align=Lr.Right,this.offsetCharacters(t,e,r)}justifyAlign(e,t,r){if(this.align=Lr.Justify,this.endLine){this.offsetCharacters(t,0,r);return}let n=this.countSpaces();if(n===0){this.offsetCharacters(t,0,r);return}let s=e/n,l=0;for(let c=0;c<this.message.length;c++)this.message[c].char===" "&&(l+=s),Tu.set(l,r),this.message[c].updatePosition(this.message[c].localPosition.add(Tu),t)}clone(){let e=new To(this.yLinePos,this.lineHeight,this.maxCharSize);e.nextChar3DPos=this.nextChar3DPos.clone(),e.align=this.align,e.endLine=this.endLine;for(let t=0;t<this.message.length;t++)e.message.push(this.message[t].clone());return e}};import{DoubleSide as JD,EventDispatcher as KD,Matrix3 as XD,Vector3 as _p}from"three";var ZD=new _p(0,0,1),Rv=new _p,zv=new _p,Fv=new XD,Io=class extends hr{constructor(e=ur.create({}),t=new vr({side:JD})){super(e,t);this.recursiveSelection=!1;this.objectType="VectorObject";this.eventDispatcher=new KD;this._onShapeUpdate=()=>{if(this.geometry instanceof No){if(this.geometry.updateFromShape()){let e=this.geometry.drawCount,t=this.geometry.userData;this.updateGeometry(Object.assign(this.geometry.userData,{parameters:Object.assign(t.parameters,{surfaceMaxCount:e+1e3})}))}}else this.updateGeometry({});this.geometry.computeBoundingSphere(),this.geometry.computeBoundingBox()};var r;this.castShadow=!0,this.receiveShadow=!0,this.forceComputeSize=!0,this.shape=e.userData.shape,(r=this.shape.eventDispatcher)==null||r.addEventListener("update",this._onShapeUpdate)}toJSON(e){let t=super.toJSON(e);return t.object.objectType="VectorObject",t}fromState(e){return super.fromState(e),this.shape.update(),this}setHelperVisibility(){}updateGeometry(e){if(super.updateGeometry(e),"userData"in this.geometry){let t=this.geometry.userData.parameters;this.eventDispatcher.dispatchEvent({type:"geometryUpdate",parameters:t})}}setShape(e){var t,r;this.shape&&((t=this.shape.eventDispatcher)==null||t.removeEventListener("update",this._onShapeUpdate)),this.shape=e,(r=this.shape.eventDispatcher)==null||r.addEventListener("update",this._onShapeUpdate)}updateWorldMatrix(e,t){super.updateWorldMatrix(e,t),Fv.getNormalMatrix(this.matrixWorld),Rv.copy(ZD).applyMatrix3(Fv).normalize(),zv.setFromMatrixPosition(this.matrixWorld),this.shape.plane.setFromNormalAndCoplanarPoint(Rv,zv)}clone(e){let t=this.shape.clone(),r=this.material.clone(),n=this.geometry.userData,s=ur.create(Object.assign({},n,{shape:t})),l=new Io(s,r).copy(this,e);return l.shape=t,t.update(),l}raycast(e,t){hr.prototype.raycast.call(this,e,t)}};import{Camera as h3,OrthographicCamera as p3,PerspectiveCamera as d3,Vector3 as nn,Object3D as Hv,Quaternion as m3}from"three";import{BoxBufferGeometry as YD}from"three";var Yn=i=>{var e;return e=class extends i{constructor(){super(...arguments);this.isObjectHelper=!0}},e.geometryHelper=new YD(30,30,30),e};import{Camera as r3,LineSegments as n3,BufferGeometry as i3,LineBasicMaterial as o3,Color as Ip,Vector3 as s3,Float32BufferAttribute as Uv}from"three";import{Ray as QD,Sphere as e3,Matrix4 as t3,Vector3 as Ni}from"three";var Iu=new QD,Tp=new e3,Vv=new t3,Qn=(i,e,t,r,n=!1)=>{let s=e,l=i.matrixWorld;if(s.boundingSphere===null&&s.computeBoundingSphere(),Tp.copy(s.boundingSphere),Tp.applyMatrix4(l),t.ray.intersectsSphere(Tp)===!1||(Vv.copy(l).invert(),Iu.copy(t.ray).applyMatrix4(Vv),s.boundingBox!==null&&Iu.intersectsBox(s.boundingBox)===!1))return;let c,f,h,d,x=s.index,g=s.attributes.position,w=s.drawRange,S,D;if(n===!1){let G=Math.max(0,w.start),B=Math.min(x.count,w.start+w.count);for(S=G,D=B;S<D;S+=3)if(f=x.getX(S),h=x.getX(S+1),d=x.getX(S+2),c=C(i,t,Iu,g,f,h,d),c){c.faceIndex=Math.floor(S/3),r.push(c);return}}else{let B=s.attributes.position,P=new Ni,W=new Ni,M=new Ni,q=new Ni,E=2,R=1/((i.scale.x+i.scale.y+i.scale.z)/3),T=R*R,z=Math.max(0,w.start),A=Math.min(B.count,w.start+w.count);for(let $=z,he=A-1;$<he;$+=E){if(P.fromBufferAttribute(B,$),W.fromBufferAttribute(B,$+1),Iu.distanceSqToSegment(P,W,q,M)>T)continue;q.applyMatrix4(i.matrixWorld);let Ne=t.ray.origin.distanceTo(q);Ne<t.near||Ne>t.far||r.push({distance:Ne,point:M.clone().applyMatrix4(i.matrixWorld),object:i})}}function C(G,B,P,W,M,q,E){let b=new Ni,R=new Ni,T=new Ni,z=new Ni,A=new Ni;if(b.fromBufferAttribute(W,M),R.fromBufferAttribute(W,q),T.fromBufferAttribute(W,E),P.intersectTriangle(b,R,T,!1,z)===null)return null;A.copy(z),A.applyMatrix4(G.matrixWorld);let he=B.ray.origin.distanceTo(A);return he<B.near||he>B.far?null:{faceIndex:1,distance:he,point:A.clone(),object:G}}};var Mu=new s3,Sn=new r3,kv=class extends n3{constructor(e){let t=new i3,r=new o3({color:16777215,vertexColors:!0,toneMapped:!1}),n=[],s=[],l={},c=new Ip(wh),f=new Ip(wh),h=new Ip(a0);d("n1","n2",c),d("n2","n4",c),d("n4","n3",c),d("n3","n1",c),d("f1","f2",c),d("f2","f4",c),d("f4","f3",c),d("f3","f1",c),d("n1","f1",c),d("n2","f2",c),d("n3","f3",c),d("n4","f4",c),d("p","n1",f),d("p","n2",f),d("p","n3",f),d("p","n4",f),d("u1","u2",h),d("u2","u3",h),d("u3","u1",h);function d(g,w,S){x(g,S),x(w,S)}function x(g,w){n.push(0,0,0),s.push(w.r,w.g,w.b),l[g]===void 0&&(l[g]=[]),l[g].push(n.length/3-1)}t.setAttribute("position",new Uv(n,3)),t.setAttribute("color",new Uv(s,3));super(t,r);this.type="CameraHelper",this.camera=e,this.camera.updateProjectionMatrix&&this.camera.updateProjectionMatrix(),this.matrix=e.matrixWorld,this.matrixAutoUpdate=!1,this.pointMap=l,this.update()}update(){let e=this.geometry,t=this.pointMap,r=!0;Sn.projectionMatrixInverse.elements=[.5112609807824982,-0,-0,-0,-0,.41421356237309503,-0,-0,-0,-0,-0,-.099999,-0,-0,-1.0000000000000002,.100001];let n=1,s=1,l=r?.8:1e-4;jn("n1",t,e,Sn,-n,-s,l),jn("n2",t,e,Sn,n,-s,l),jn("n3",t,e,Sn,-n,s,l),jn("n4",t,e,Sn,n,s,l);let c=l;jn("f1",t,e,Sn,-n,-s,c),jn("f2",t,e,Sn,n,-s,c),jn("f3",t,e,Sn,-n,s,c),jn("f4",t,e,Sn,n,s,c);let f=c,h=.5;jn("u1",t,e,Sn,n*.7*h,s*1.1,f),jn("u2",t,e,Sn,-n*.7*h,s*1.1,f),jn("u3",t,e,Sn,0,s*(1.1+.9*h),f),e.getAttribute("position").needsUpdate=!0}dispose(){this.geometry.dispose(),this.material.dispose()}};function jn(i,e,t,r,n,s,l){Mu.set(n,s,l).unproject(r);let c=e[i];if(c!==void 0){let f=t.getAttribute("position");for(let h=0,d=c.length;h<d;h++)f.setXYZ(c[h],Mu.x,Mu.y,Mu.z)}}var Mp=class extends Yn(kv){constructor(e){super(e);this.object=e;this.object=e,this.name=`CombinedCameraHelper: ${e.uuid}`}updateMatrixWorld(e){super.updateMatrixWorld(e),this.updateTarget()}updateTarget(){let e=this.object.getTarget();this.updateWorldMatrix(!0,!1),this.worldToLocal(e)}raycast(e,t){Qn(this.object,this.geometry,e,t,!0)}};import{DirectionalLightHelper as a3}from"three";var za=class extends Yn(a3){constructor(e,t=15,r=10066329){super(e,t,r);this.object=e;this.name=`DirectionalLightHelper: ${e.uuid}`}raycast(e,t){Qn(this.object,za.geometryHelper,e,t)}};import{AxesHelper as l3}from"three";var Fa=class extends Yn(l3){constructor(e,t=15){super(t);this.object=e;this.object.updateMatrixWorld(),this.name=`EmptyObjectHelper: ${e.uuid}`,this.matrix=e.matrixWorld,this.matrixAutoUpdate=!1}raycast(e,t){Qn(this.object,Fa.geometryHelper,e,t)}update(){}};import{PointLightHelper as c3}from"three";var Va=class extends Yn(c3){constructor(e,t=15,r=6710886){super(e,t,r);this.object=e;this.name=`PointLightHelper: ${e.uuid}`}raycast(e,t){Qn(this.object,Va.geometryHelper,e,t)}};import{SpotLightHelper as u3,Vector3 as f3}from"three";var Ou=class extends Yn(u3){constructor(e,t=6710886){super(e,t);this.object=e;this.name=`SpotLightHelper: ${e.uuid}`}raycast(e,t){Qn(this.object,Ou.geometryHelper,e,t)}update(){if(this.object!==void 0){let e=Ou._vector,t=this.object.distance?this.object.distance:1e3,r=t*Math.tan(this.object.angle);this.cone.scale.set(r,r,t),e.setFromMatrixPosition(this.object.target.matrixWorld),this.cone.lookAt(e);let n=this.color!==void 0?this.color:this.light.color;if(this.cone.material instanceof Array)for(let s=0,l=this.cone.material.length;s<l;s++)this.cone.material[s].color.set(n);else this.cone.material.color.set(n)}}},Au=Ou;Au._vector=new f3;var ei=(i,e)=>class extends i{constructor(){super(...arguments);this.objectHelper=new e(this);this.enableHelper=!1}set visibility(r){this.visible=r,this.setHelperVisibility(r),this.setHelperChildrenVisibility(r)}get visibility(){return this.visible}get geometryHelper(){return e.geometryHelper}setHelperVisibility(r){this.objectHelper.visible=r}setHelperChildrenVisibility(r){for(let n of this.children)yn(n)&&n.traverseEntity(s=>{vi(s)&&s.visible&&(s.objectHelper.visible=r)})}raycast(r,n){this.objectHelper.raycast(r,n)}copy(r,n=!0){return super.copy(r,n),r.enableHelper!==void 0&&(this.enableHelper=r.enableHelper),r.objectHelper!==void 0&&(this.objectHelper.visible=r.objectHelper.visible),this}toJSON(r){let n=super.toJSON(r),s=n.object;return s.enableHelper=this.enableHelper,n}fromJSON(r){return super.fromJSON(r),r.enableHelper!==void 0&&(this.enableHelper=!0),this}fromLightState(r,n){if(this.objectType==="LightDirectional"||this.objectType==="LightPoint"||this.objectType==="LightSpot"){let s=this;r.color!==void 0&&(s.color=kt(r.color,n)),r.intensity!==void 0&&(s.intensity=r.intensity),r.depth!==void 0&&(s.shadow.camera.far=r.depth,s.shadow.needsUpdate=!0),r.shadows!==void 0&&(this.castShadow=r.shadows),r.helper!==void 0&&(this.enableHelper=r.helper,s.gizmos.shadowmap.visible=r.helper)}return this}};var Es=new nn,Ap=new nn,Yi=class extends ei(xn(h3),Mp){constructor(e=window.innerWidth,t=window.innerHeight,r=45,n,s=1e5){super();this.objectType="CombinedCamera";this._cameraType="OrthographicCamera";this.targetOffset=xo.DefaultTargetOffset;this.isUpVectorFlipped=!1;this.angleOffsetFromUp=0;this.width=e,this.height=t,this.orthoCamera=new p3(e*-.5,e*.5,t*.5,t*-.5,n!=null?n:-5e4,s),this.perspCamera=new d3(r,e/t,n!=null?n:50,s),this.left=this.orthoCamera.left,this.right=this.orthoCamera.right,this.top=this.orthoCamera.top,this.bottom=this.orthoCamera.bottom,this.far=this.orthoCamera.far,this.view=this.orthoCamera.view,this.aspect=this.perspCamera.aspect,this.fov=this.perspCamera.fov,this.focus=this.perspCamera.focus,this.filmGauge=this.perspCamera.filmGauge,this.filmOffset=this.perspCamera.filmOffset,this.toOrthographic(!0)}static createFromState(e,t){let r=new Yi().fromState(t);return r.enableHelper=!0,r.objectHelper.update(),r.uuid=e,r}get isPerspectiveCamera(){return this.cameraType==="PerspectiveCamera"}get isOrthographicCamera(){return!this.isPerspectiveCamera}get cameraType(){return this._cameraType}setNear(e,t){e==="PerspectiveCamera"?this.perspCamera.near=t:this.orthoCamera.near=t}setZoom(e,t){t>=0&&(e==="PerspectiveCamera"?this.perspCamera.zoom=t:this.orthoCamera.zoom=t)}set cameraType(e){e==="PerspectiveCamera"?this.toPerspective():e==="OrthographicCamera"&&this.toOrthographic()}get near(){return this._cameraType==="PerspectiveCamera"?this.perspCamera.near:this.orthoCamera.near}set near(e){this._cameraType==="PerspectiveCamera"?this.perspCamera.near=e:this.orthoCamera.near=e}get zoom(){return this._cameraType==="PerspectiveCamera"?this.perspCamera.zoom:this.orthoCamera.zoom}set zoom(e){e>=0&&(this._cameraType==="PerspectiveCamera"?this.perspCamera.zoom=e:this.orthoCamera.zoom=e)}lookAt(e){super.lookAt(e),this.getWorldPosition(Es),this.targetOffset=Es.distanceTo(e)}getTarget(e=new nn){return this.getWorldDirection(Ap),this.getWorldPosition(Es),Ap.multiplyScalar(this.targetOffset),e.copy(Es).add(Ap),e}getDistanceToTarget(){let e=this.getTarget();return this.getWorldPosition(Es),Es.distanceTo(e)}updateUp(){let e=this.getWorldQuaternion(new m3),t=new nn(0,0,1).applyQuaternion(e),r=new nn().copy(Hv.DefaultUp);this.isUpVectorFlipped&&r.negate(),r.applyQuaternion(e);let n=new nn().copy(Hv.DefaultUp).projectOnPlane(t),s=new nn().crossVectors(n,r).dot(t)>=0?1:-1;this.angleOffsetFromUp=n.angleTo(r)*s}getViewFrontToObject(e){let t=e.getWorldPosition(new nn),n=e.getWorldDirection(new nn).multiplyScalar(this.targetOffset);return{position:t.clone().add(n),target:t}}getViewToObject(e){let t=e.getWorldPosition(new nn),n=this.getWorldDirection(new nn).multiplyScalar(this.targetOffset);return{position:t.clone().sub(n),target:t}}setViewplaneSize(e,t){this.left=-e*.5,this.right=e*.5,this.top=t*.5,this.bottom=-t*.5,this.aspect=e/t,this.updateProjectionMatrix()}toOrthographic(e){this.orthoCamera.left=this.left,this.orthoCamera.right=this.right,this.orthoCamera.top=this.top,this.orthoCamera.bottom=this.bottom,this.orthoCamera.view=this.view,this.orthoCamera.far=this.far,this.orthoCamera.updateProjectionMatrix(),this.projectionMatrix=this.orthoCamera.projectionMatrix,this.projectionMatrixInverse=this.orthoCamera.projectionMatrixInverse,this._cameraType="OrthographicCamera",(this.enableHelper===!0||e===!0)&&this.objectHelper.update()}toPerspective(e){this.perspCamera.aspect=this.aspect,this.perspCamera.fov=this.fov,this.perspCamera.view=this.view,this.perspCamera.far=this.far,this.perspCamera.updateProjectionMatrix(),this.projectionMatrix=this.perspCamera.projectionMatrix,this.projectionMatrixInverse=this.perspCamera.projectionMatrixInverse,this._cameraType="PerspectiveCamera",(this.enableHelper===!0||e===!0)&&this.objectHelper.update()}setFocalLength(e){this.perspCamera.setFocalLength(e),this.toPerspective()}getFocalLength(){return this.perspCamera.getFocalLength()}getEffectiveFOV(){return this.perspCamera.getEffectiveFOV()}getFilmWidth(){return this.perspCamera.getFilmWidth()}getFilmHeight(){return this.perspCamera.getFilmHeight()}setViewOffset(e,t,r,n,s,l){this._cameraType==="PerspectiveCamera"?this.perspCamera.setViewOffset(e,t,r,n,s,l):this.orthoCamera.setViewOffset(e,t,r,n,s,l)}clearViewOffset(){this._cameraType==="PerspectiveCamera"?(this.perspCamera.clearViewOffset(),this.toPerspective()):(this.orthoCamera.clearViewOffset(),this.toOrthographic())}updateProjectionMatrix(e){this._cameraType==="PerspectiveCamera"?this.toPerspective(e):this._cameraType==="OrthographicCamera"&&this.toOrthographic(e)}updateMatrixWorld(e){super.updateMatrixWorld(e),this.matrixWorldInverse.copy(this.matrixWorld).invert()}updateWorldMatrix(e,t){super.updateWorldMatrix(e,t),this.matrixWorldInverse.copy(this.matrixWorld).invert()}copy(e,t){return super.copy(e,t),this.orthoCamera.copy(e.orthoCamera),this.perspCamera.copy(e.perspCamera),this.left=e.left,this.right=e.right,this.top=e.top,this.bottom=e.bottom,this.far=e.far,this.view=e.view===null?null:Object.assign({},e.view),this._cameraType=e._cameraType,this.aspect=e.aspect,this.fov=e.fov,this.focus=e.focus,this.filmGauge=e.filmGauge,this.filmOffset=e.filmOffset,this.targetOffset=e.targetOffset,this.updateProjectionMatrix(),this}fromCameraRender(e){let t={near:this.orthoCamera.near,far:this.orthoCamera.far},r={near:this.perspCamera.near,far:this.perspCamera.far};return this.copy(e),this.name="",this.enableHelper=!0,this.objectHelper.visible=!0,this.orthoCamera.near=t.near,this.orthoCamera.far=t.far,this.perspCamera.near=r.near,this.perspCamera.far=r.far,this.updateProjectionMatrix(),this}toJSON(e){let t=super.toJSON(e),r=t.object;return r.objectType="CombinedCamera",r.cameraType=this.cameraType,r.targetOffset=this.targetOffset,r.isUpVectorFlipped=this.isUpVectorFlipped,r.angleOffsetFromUp=this.angleOffsetFromUp,r.left=this.left,r.right=this.right,r.top=this.top,r.bottom=this.bottom,this.view!==null&&(r.view=Object.assign({},this.view)),r.zoomOrtho=this.orthoCamera.zoom,r.nearOrtho=this.orthoCamera.near,r.far=this.far,r.aspect=this.aspect,r.fov=this.fov,r.focus=this.focus,r.filmGauge=this.filmGauge,r.filmOffset=this.filmOffset,r.zoomPersp=this.perspCamera.zoom,r.nearPersp=this.perspCamera.near,t}fromJSON(e){var t;if(super.fromJSON(e),this.cameraType=e.cameraType,e.targetOffset!==void 0&&(this.targetOffset=e.targetOffset),e.orbitControlsTarget!==void 0){let r=this.getWorldPosition(new nn),n=new nn().fromArray(e.orbitControlsTarget);this.targetOffset=n.distanceTo(r)}else e.targetOffset!==void 0&&(this.targetOffset=e.targetOffset);return this.isUpVectorFlipped=!1,this.angleOffsetFromUp=(t=e.angleOffsetFromUp)!=null?t:0,e.left!==void 0&&(this.left=e.left),e.right!==void 0&&(this.right=e.right),e.top!==void 0&&(this.top=e.top),e.bottom!==void 0&&(this.bottom=e.bottom),e.view!==void 0&&(this.view=Object.assign({},e.view)),e.zoomOrtho!==void 0&&(this.orthoCamera.zoom=e.zoomOrtho),e.nearOrtho!==void 0&&(this.orthoCamera.near=e.nearOrtho),e.far!==void 0&&(this.far=e.far),e.aspect!==void 0&&(this.aspect=e.aspect),e.fov!==void 0&&(this.fov=e.fov),e.focus!==void 0&&(this.focus=e.focus),e.filmGauge!==void 0&&(this.filmGauge=e.filmGauge),e.filmOffset!==void 0&&(this.filmOffset=e.filmOffset),e.zoomPersp!==void 0&&(this.perspCamera.zoom=e.zoomPersp),e.nearPersp!==void 0&&(this.perspCamera.near=e.nearPersp),this.updateProjectionMatrix(),this}toCameraState(e=[]){let t={type:this.cameraType,far:this.far,orthographic:{near:this.orthoCamera.near,zoom:this.orthoCamera.zoom},perspective:{near:this.perspCamera.near,fov:this.perspCamera.fov,zoom:this.perspCamera.zoom},up:this.up.toArray(),targetOffset:this.targetOffset,isUpVectorFlipped:this.isUpVectorFlipped};return hs(t,e)}fromCameraState(e){let{orthographic:t,perspective:r}=e;return e.type!==void 0&&(this.cameraType=e.type),e.far!==void 0&&(this.far=e.far),t!==void 0&&(t.near!==void 0&&(this.orthoCamera.near=t.near),t.zoom!==void 0&&(this.orthoCamera.zoom=t.zoom)),r!==void 0&&(r.near!==void 0&&(this.perspCamera.near=r.near),r.fov!==void 0&&(this.perspCamera.fov=r.fov),r.zoom!==void 0&&(this.perspCamera.zoom=r.zoom)),e.up!==void 0&&this.up.fromArray(e.up),e.targetOffset!==void 0&&(this.targetOffset=e.targetOffset),e.isUpVectorFlipped!==void 0&&(this.isUpVectorFlipped=e.isUpVectorFlipped),this.updateProjectionMatrix(),this}toState(e){return fe(U(U({},super.toState(e)),this.toCameraState(e)),{type:this.cameraType})}fromState(e){return super.fromState(e),this.fromCameraState(e),this}};import{Group as g3}from"three";var Qi=class extends ei(xn(g3),Fa){constructor(){super(...arguments);this.objectType="EmptyObject"}static createFromState(e,t){let r=new Qi().fromState(t);return r.uuid=e,r.enableHelper=!0,r.objectHelper.update(),r}toJSON(e){let t=super.toJSON(e);return t.object.objectType="EmptyObject",t}};import{DirectionalLight as y3,CameraHelper as Pu}from"three";var Ua=class extends ei(xn(y3),za){constructor(...e){super(...e);this.objectType="LightDirectional";this._gizmos={};this.castShadow=!0,this.shadow.mapSize.width=1024,this.shadow.mapSize.height=1024;let r=this.shadow.camera;r.top=1250,r.bottom=-1250,r.right=1250,r.left=-1250,r.near=1,r.far=2500;let n=new Pu(this.shadow.camera);n.visible=!1,this._gizmos.shadowmap=n,this.update()}static createFromState(e,t,r){let n=new Ua().fromState(t,r);return n.uuid=e,n}get gizmos(){return this._gizmos}showGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Pu&&(t.visible=!0)}}hideGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Pu&&(t.visible=!1)}}update(){this.shadow.camera.updateProjectionMatrix();for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Pu&&t.update()}}updateMatrixWorld(e){super.updateMatrixWorld(e),this.enableHelper===!0&&this.objectHelper.visible===!0&&this.objectHelper.update()}copy(e,t=!0){return super.copy(e,t),this.color.copy(e.color),this.intensity=e.intensity,this.target=e.target.clone(),this.shadow=e.shadow.clone(),this}toJSON(e){let t=super.toJSON(e),r=t.object;return r.objectType="LightDirectional",r.color=this.color.getHex(),r.intensity=this.intensity,r.shadow=this.shadow.toJSON(),t}fromJSON(e){var n;super.fromJSON(e),this.color.set(e.color),this.intensity=e.intensity,this.shadow.normalBias=(n=e.shadow.normalBias)!=null?n:0,this.shadow.radius=e.shadow.radius,this.shadow.mapSize.fromArray(e.shadow.mapSize);let t=this.shadow.camera,r=e.shadow.camera;return t.near=r.near,t.far=r.far,t.zoom=r.zoom,t.left=r.left,t.right=r.right,t.top=r.top,t.bottom=r.bottom,r.view!==void 0&&(t.view=Object.assign({},r.view)),this}fromDirectionalLightState(e,t){let r=e.depth!==void 0&&e.depth!==this.shadow.camera.far||e.size!==void 0&&e.size/2!==this.shadow.camera.right;return super.fromLightState(e,t),e.size!==void 0&&hv(this,e.size),r&&this.update(),this}fromState(e,t){return super.fromState(e),this.fromDirectionalLightState(e,t),this}};import{PointLight as x3,Vector3 as Du,Box3 as v3,Box3Helper as Bu,Color as b3}from"three";var ka=class extends ei(xn(x3),Va){constructor(...e){super(...e);this.objectType="LightPoint";this._gizmos={};this.castShadow=!0,this.shadow.mapSize.width=1024,this.shadow.mapSize.height=1024;let r=this.shadow.camera;r.fov=90,r.aspect=1,r.near=100,r.far=2500;let n=new Du(-r.far+this.position.x,-r.far+this.position.y,-r.far+this.position.z),s=new Du(r.far+this.position.x,r.far+this.position.y,r.far+this.position.z),l=new v3(n,s),c=new Bu(l,new b3(16755200));c.visible=!1,this._gizmos.shadowmap=c,this.update()}static createFromState(e,t,r){let n=new ka().fromState(t,r);return n.uuid=e,n}get gizmos(){return this._gizmos}showGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Bu&&(t.visible=!0)}}hideGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Bu&&(t.visible=!1)}}update(){if(this.shadow&&(this.shadow.camera.updateProjectionMatrix(),this._gizmos))for(let e in this._gizmos){let t=this._gizmos[e];if(t instanceof Bu){let r=this.shadow.camera,n=new Du(-r.far+this.position.x,-r.far+this.position.y,-r.far+this.position.z),s=new Du(r.far+this.position.x,r.far+this.position.y,r.far+this.position.z);t.box.set(n,s),t.updateMatrixWorld(!0)}}}updateMatrixWorld(e){super.updateMatrixWorld(e),this.enableHelper===!0&&this.objectHelper.visible===!0&&this.objectHelper.update()}copy(e,t=!0){return super.copy(e,t),this.color.copy(e.color),this.intensity=e.intensity,this.distance=e.distance,this.decay=e.decay,this.shadow=e.shadow.clone(),this}toJSON(e){let t=super.toJSON(e),r=t.object;return r.objectType="LightPoint",r.color=this.color.getHex(),r.intensity=this.intensity,r.distance=this.distance,r.decay=this.decay,r.shadow=this.shadow.toJSON(),t}fromJSON(e){var n,s;super.fromJSON(e),this.color.set(e.color),this.intensity=e.intensity,this.distance=e.distance,this.decay=e.decay,this.shadow.normalBias=(n=e.shadow.normalBias)!=null?n:0,this.shadow.radius=e.shadow.radius,this.shadow.mapSize.fromArray((s=e.shadow.mapSize)!=null?s:[512,512]),this.shadow.map&&(this.shadow.map.dispose(),this.shadow.map=null);let t=this.shadow.camera,r=e.shadow.camera;return t.near=r.near,t.far=r.far,t.zoom=r.zoom,t.fov=r.fov,t.focus=r.focus,t.aspect=r.aspect,t.filmGauge=r.filmGauge,t.filmOffset=r.filmOffset,r.view!==void 0&&(t.view=Object.assign({},r.view)),this}fromPointLightState(e,t){return super.fromLightState(e,t),e.distance!==void 0&&(this.distance=e.distance),e.decay!==void 0&&(this.decay=e.decay),e.shadowRadius!==void 0&&(this.shadow.radius=e.shadowRadius),e.shadowResolution!==void 0&&(this.shadow.mapSize.set(e.shadowResolution,e.shadowResolution),this.shadow.map&&(this.shadow.map.dispose(),this.shadow.map=null)),this}fromState(e,t){return super.fromState(e),this.fromPointLightState(e,t),this}};import{SpotLight as S3,CameraHelper as Gu,MathUtils as w3,Vector3 as Wv,Quaternion as N3}from"three";var qv=new Wv,$v=new Wv,Jv=new N3,Ha=class extends ei(xn(S3),Au){constructor(...e){super(...e);this.objectType="LightSpot";this._gizmos={};this.castShadow=!0,this.shadow.mapSize.width=1024,this.shadow.mapSize.height=1024;let r=this.shadow.camera;r.fov=w3.RAD2DEG*2*this.angle,r.aspect=1,r.near=100,r.far=2500;let n=new Gu(this.shadow.camera);n.visible=!1,this._gizmos.shadowmap=n,this.update()}static createFromState(e,t,r){let n=new Ha().fromState(t,r);return n.uuid=e,n}get gizmos(){return this._gizmos}showGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Gu&&(t.visible=!0)}}hideGizmos(){for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Gu&&(t.visible=!1)}}update(){this.shadow.camera.updateProjectionMatrix();for(let e in this._gizmos){let t=this._gizmos[e];t instanceof Gu&&t.update()}}updateMatrixWorld(e){super.updateMatrixWorld(e),$v.setFromMatrixPosition(this.matrixWorld),Jv.setFromRotationMatrix(this.matrixWorld),qv.copy(this.up).applyQuaternion(Jv).negate().multiplyScalar(this.distance),this.target.position.copy($v).add(qv),this.target.updateMatrixWorld(),this.enableHelper===!0&&this.objectHelper.visible===!0&&this.objectHelper.update()}copy(e,t=!0){return super.copy(e,t),this.color.copy(e.color),this.intensity=e.intensity,this.distance=e.distance,this.angle=e.angle,this.penumbra=e.penumbra,this.decay=e.decay,this.target=e.target.clone(),this.shadow=e.shadow.clone(),this}toJSON(e){let t=super.toJSON(e),r=t.object;return r.objectType="LightSpot",r.color=this.color.getHex(),r.intensity=this.intensity,r.distance=this.distance,r.angle=this.angle,r.decay=this.decay,r.penumbra=this.penumbra,r.shadow=this.shadow.toJSON(),t}fromJSON(e){var n;super.fromJSON(e),this.color.set(e.color),this.intensity=e.intensity,this.distance=e.distance,this.angle=e.angle,this.decay=e.decay,this.penumbra=e.penumbra,this.shadow.normalBias=(n=e.shadow.normalBias)!=null?n:0,this.shadow.radius=e.shadow.radius,this.shadow.mapSize.fromArray(e.shadow.mapSize);let t=this.shadow.camera,r=e.shadow.camera;return t.near=r.near,t.far=r.far,t.zoom=r.zoom,t.fov=r.fov,t.focus=r.focus,t.aspect=r.aspect,t.filmGauge=r.filmGauge,t.filmOffset=r.filmOffset,r.view!==void 0&&(t.view=Object.assign({},r.view)),this}fromSpotLightState(e,t){return super.fromLightState(e,t),e.distance!==void 0&&(this.distance=e.distance),e.decay!==void 0&&(this.decay=e.decay),e.angle!==void 0&&(this.angle=e.angle),e.penumbra!==void 0&&(this.penumbra=e.penumbra),this}fromState(e,t){return super.fromState(e),this.fromSpotLightState(e,t),this}};import{VideoTexture as C3}from"three";var Kv=i=>i.tagName==="VIDEO",Rs=class{static resize(e,t,r){let n=e/t,s;if(!r.image)return;let l=r.image;Kv(l)?s=l.videoWidth/l.videoHeight:s=l.width/l.height,n>s&&(r.imageType=="WEBCAM"?r.repeat.set(-1,1*s/n):r.repeat.set(1,1*s/n)),n<s&&(r.imageType=="WEBCAM"?r.repeat.set(1*n/s*-1,1):r.repeat.set(1*n/s,1)),n==s&&(r.imageType=="WEBCAM"?r.repeat.set(-1,1):r.repeat.set(1,1))}static resizeTextureLayer(e,t,r){let n=e/t,s=r.image!==void 0?r.image.width/r.image.height:1,l;n>s?l={x:1,y:s/n}:n<s?l={x:n/s,y:1}:l={x:1,y:1},r.repeat.set(l.x,l.y),r.updateMatrix()}static resizeTextureLayers(e,t,r){let n=r.userData.layers,s=n.getLayers();for(let l=0;l<s.length;l++){let c=s[l];Nv(c)&&(Rs.resizeTextureLayer(e,t,c.uniforms[`f${c.id}_texture`].value),n.updateLayerUniform())}}static resizeComplex(e,t,r,n){let s=e/t,l,c=r.image;Kv(c)?l=c.videoWidth/c.videoHeight:l=c.width/c.height,n.geometry.type.includes("Shape")?(s>l&&(r.imageType=="WEBCAM"?r.repeat.set(1/e*-1,1/t*l/s):r.repeat.set(1/e,1/t*l/s)),s<l&&(r.imageType=="WEBCAM"?r.repeat.set(1/e*s/l*-1,1/t):r.repeat.set(1/e*s/l,1/t)),s==l&&(r.imageType=="WEBCAM"?r.repeat.set(1/e*-1,1/t):r.repeat.set(1/e,1/t))):(s>l&&(r.imageType=="WEBCAM"?r.repeat.set(-1,1*l/s):r.repeat.set(1,1*l/s)),s<l&&(r.imageType=="WEBCAM"?r.repeat.set(1*s/l*-1,1):r.repeat.set(1*s/l,1)),s==l&&(r.imageType=="WEBCAM"?r.repeat.set(-1,1):r.repeat.set(1,1)))}};var Wa=class extends hr{constructor(e,t=new vr){super(e,t);this.objectType="Mesh2D";this.castShadow=!0,this.receiveShadow=!0}updateGeometry(e){super.updateGeometry(e),this.material.userData.layers&&Rs.resizeTextureLayers(this.geometry.userData.parameters.width,this.geometry.userData.parameters.height,this.material)}resizeGeometry(e,t){super.resizeGeometry(e,t,0),this.material.userData.layers&&Rs.resizeTextureLayers(this.geometry.userData.parameters.width,this.geometry.userData.parameters.height,this.material)}toJSON(e){let t=super.toJSON(e);return t.object.objectType="Mesh2D",t}clone(){let e=super.clone();return e.updateGeometry({}),e}static fromTexture(e){let t,r;if(e instanceof C3){let l=e.image;t=l.videoWidth*.5,r=l.videoHeight*.5}else{let l=e.image;t=l.width*.5,r=l.height*.5}let n=ou.create({parameters:{width:t,height:r}}),s=new vr;return s.layersList.changeLayer(0,{type:qe.TEXTURE,texture:e}),s.layersList.moveLayer(0,1),s.dispose(),new Wa(n,s)}};var qa=class extends hr{constructor(e,t=new bn){super(e,t);this.objectType="Mesh3D";this.castShadow=!0,this.receiveShadow=!0}toJSON(e){let t=super.toJSON(e);return t.object.objectType="Mesh3D",t}};var $a=class extends qa{constructor(e,t=new bn){super(e,t);this.objectType="NonParametric"}toJSON(e){let t=super.toJSON(e);return t.object.objectType="NonParametric",t}};var Ja;(function(t){t[t.TO_RIGHT=1]="TO_RIGHT",t[t.TO_LEFT=-1]="TO_LEFT"})(Ja||(Ja={}));var Op=class extends hr{constructor(e,t=new vr({transparent:!0,opacity:1,visible:!1,side:ju})){super(e,t);this.objectType="TextFrame";this.charContainer=new L3,this.add(this.charContainer),this.material.visible=!1,this._geometryUserData=e.userData,this.userData.textFrame={hexColor:null,opacity:1,visible:!0,text:"",fontSize:16,lineHeight:1.5,letterSpacing:1,fontFamily:"roboto_regular",textTransform:ki.None,horizontalAlignment:1,verticalAlignment:gi.Top,LOD:16,maxLineSize:this._geometryUserData.parameters.width,textOrigin:new Zv(this._geometryUserData.parameters.width*-.5,this._geometryUserData.parameters.height*.5,0),textLines:[]},this.createTextLine()}static createFromState(e,t,r){let n=su.create({parameters:{width:t.width,height:t.height}}),s=new Op(n).fromState(t,r);return s.uuid=e,s}async updateText(e){this.clearText();let t=this.userData.textFrame,r=t.fontFamily;await Rr.loadFont(r),t.text=e;let n=t.textOrigin,s=new Xv({visible:t.visible,transparent:!0,side:ju}),l=e.split(`
|
|
977
|
+
`),c=0;this.userData.textFrame.textLines=l.map((f,h)=>{let d=new To(c,t.lineHeight,t.fontSize);return d.message=f.split("").map(x=>{let g={char:x,fontFamily:r,letterSpacing:t.letterSpacing,fontSize:t.fontSize,LOD:16},w=s.clone();w.color=t.hexColor,w.opacity=t.opacity;let S=new Rr(g,w);return d.addChar3D(S,n),this.charContainer.add(S),S}),c+=d.maxCharSize*d.lineHeight,d}),this.textFullUpdate(),this.checkOverFlow()}clearText(){let e=this.userData.textFrame.textLines;for(;this.charContainer.children.length;){let t=this.charContainer.children[0];this.charContainer.remove(t)}for(;e.length;)e.pop()}raycast(e,t){let r=[];if(super.raycast(e,r),r.length>0){t.push(r[0]);return}let n=[];for(let s=0,l=this.charContainer.children.length;s<l;++s)if(this.charContainer.children[s]instanceof Rr&&(e.intersectObject(this.charContainer.children[s],!1,n),n.length>0)){n[0].object=this,t.push(n[0]);return}}updateGeometry(e){var h,d,x,g;let t=this.userData,r=this.geometry.userData,n=r.parameters.width,s=r.parameters.height,l=(d=(h=e.parameters)==null?void 0:h.width)!=null?d:n,c=(g=(x=e.parameters)==null?void 0:x.height)!=null?g:s,f=t.textFrame;super.updateGeometry(e),f.maxLineSize=l,f.textOrigin.set(-.5*l,.5*c,0),c!==s?(this.checkOverFlow(),this.checkCapacity()):l!==n&&(n<l?this.checkCapacity():n>l&&this.checkOverFlow())}checkOverFlow(e=0){let t=this.userData,r=t.textFrame.textOrigin,n=t.textFrame.textLines;for(let s=e;s<n.length;s++){n[s].updateYLinePos(this.getNewLinePosition(s)),n[s].fullUpdate(r);let l=[];for(;n[s].checkOverFlow(t.textFrame.maxLineSize);)n[s].containSpaceOverFlow()?l.unshift(n[s].getWord(n[s].message.length-1,-1)):l.unshift(n[s].popChar());if(l.length>0){n[s+1]===void 0?(n[s].isEndLine(!1),this.createTextLine()):n[s].endLine&&(this.createTextLine(s+1),n[s].isEndLine(!1),n[s+1].isEndLine(!0));let c=0;for(let f=0;f<l.length;f+=1)for(let h=0;h<l[f].length;h+=1)n[s+1].addChar3D(l[f][h],r,c),c+=1;n[s+1].fullUpdate(r)}n[s].fullUpdate(r)}this.textFullUpdate(e)}checkCapacity(e=0){let t=this.userData,r=t.textFrame.textOrigin,n=t.textFrame.maxLineSize,s=t.textFrame.textLines;for(let l=e;l<s.length;l+=1)if(s[l].updateYLinePos(this.getNewLinePosition(l)),s[l].fullUpdate(r),!!s[l-1])for(;!s[l-1].endLine;){let c,f=s[l-1].spaceLeft(n);if(s[l].wordSize(0,1)<=f){s[l].containSpace()?c=s[l].getWord(0,1):c=s[l].popChar(0);for(let h=0;h<c.length;h+=1)c[h]&&s[l-1].addChar3D(c[h],r)}else{s[l].isEmpty()?(s[l].endLine&&s[l-1].isEndLine(!0),s.splice(l,1),l-=1):(s[l].updateYLinePos(this.getNewLinePosition(l)),s[l].fullUpdate(r));break}}this.textFullUpdate(e)}createTextLine(e=this.userData.textFrame.textLines.length){let r=this.userData.textFrame;r.textLines.splice(e,0,new To(this.getNewLinePosition(e),r.lineHeight,r.fontSize))}textFullUpdate(e=0){let r=this.userData.textFrame,n=r.textLines,s=this.getVerticalAlignmentOffSet();for(let l=e;l<n.length;l++)n[l].updateYLinePos(this.getNewLinePosition(l)),n[l].fullUpdate(r.textOrigin),n[l].alignText(r.textOrigin,r.maxLineSize,r.horizontalAlignment,r.verticalAlignment,s)}getVerticalAlignmentOffSet(){switch(this.userData.textFrame.verticalAlignment){case gi.Top:return 0;case gi.Center:return this.getRemainingVerticalSpace()/2;case gi.Bottom:return this.getRemainingVerticalSpace();default:return 0}}getRemainingVerticalSpace(){let t=this.userData.textFrame.textLines;return this.geometry.userData.parameters.height-this.getNewLinePosition(t.length)}getNewLinePosition(e){let r=this.userData.textFrame.textLines,n=0;for(let s=0;s<e;s+=1)n+=r[s].maxCharSize*r[s].lineHeight;return n}updateColor(e){var n;let t=this.userData;t.textFrame.hexColor=e;let r=t.textFrame.textLines;for(let s=0;s<r.length;s++){let l=r[s].message;for(let c=0;c<l.length;c++){let f=l[c].material;((n=f.color)==null?void 0:n.isColor)&&(f.color=e)}}}updateOpacity(e){let t=this.userData;t.textFrame.opacity=e;let r=t.textFrame.textLines;for(let n=0;n<r.length;n++){let s=r[n].message;for(let l=0;l<s.length;l++){let c=s[l].material;c.opacity=e}}}updateVisible(e){let t=this.userData;t.textFrame.visible=e;let r=t.textFrame.textLines;for(let n=0;n<r.length;n++){let s=r[n].message;for(let l=0;l<s.length;l++){let c=s[l].material;c.visible=e}}}async updateFontFamily(e){await Rr.loadFont(e);let r=this.userData.textFrame,n=r.textLines;r.fontFamily=e;for(let s=0;s<n.length;s++){let l=n[s].message;for(let c=0;c<l.length;c++)l[c].updateFontFamily(e)}this.textFullUpdate(),this.checkOverFlow(),this.checkCapacity()}updateFontSize(e){let r=this.userData.textFrame,n=r.textLines,s=r.fontSize;r.fontSize=e;for(let l=0;l<n.length;l++)n[l].updateFontSize(e);this.textFullUpdate(),e>s?this.checkOverFlow():e<s&&this.checkCapacity()}async updateTextTransform(e){let r=this.userData.textFrame;await Rr.loadFont(r.fontFamily);let n=r.textLines;switch(r.textTransform=e,e){case ki.Upper:for(let s=0;s<n.length;s++){let l=n[s].message;for(let c=0;c<l.length;c++)n[s].message[c].updateChar(l[c].char.toUpperCase())}break;case ki.Lower:for(let s=0;s<n.length;s++){let l=n[s].message;for(let c=0;c<l.length;c++)n[s].message[c].updateChar(l[c].char.toLowerCase())}break;default:for(let s=0;s<n.length;s++){let l=n[s].message;for(let c=0;c<l.length;c++)n[s].message[c].updateChar(l[c].originalChar)}}this.textFullUpdate(),this.checkOverFlow(),this.checkCapacity()}updateLetterSpacing(e){let t=this.userData,r=t.textFrame.textLines;t.textFrame.letterSpacing=e;for(let n=0;n<r.length;n++){let s=r[n].message;for(let l=0;l<s.length;l++)s[l].updateLetterSpacing(e)}this.textFullUpdate(),this.checkOverFlow(),this.checkCapacity()}updateLOD(e){let t=this.userData;t.textFrame.LOD=e;let r=t.textFrame.textLines;for(let n=0;n<r.length;n++);this.textFullUpdate(),this.checkOverFlow(),this.checkCapacity()}updateLineHeight(e){let t=this.userData,r=t.textFrame.textLines;t.textFrame.lineHeight=e;for(let n=0;n<r.length;n++)r[n].updatelineHeight(e);this.textFullUpdate()}updateVerticalAlignment(e){let t=this.userData;t.textFrame.verticalAlignment=e,this.textFullUpdate()}updateHorizontalAlignment(e){let t=this.userData;t.textFrame.horizontalAlignment=e,this.textFullUpdate()}toJSON(e){let t=super.toJSON(e),r=t.object;r.objectType="TextFrame";let s=this.userData.textFrame.textLines.map(l=>{let c=l.message.map(f=>({char:f.char,originalChar:f.originalChar,fontFamily:f.fontFamily,letterSpacing:f.letterSpacing,fontSize:f.fontSize,LOD:f.LOD}));return{align:l.align,endLine:l.endLine,lineHeight:l.lineHeight,maxCharSize:l.maxCharSize,yLinePos:l.yLinePos,message:c}});return r.userData.textFrame.textLinesData=s,t}async fromJSONasync(e){if(super.fromJSON(e),e.userData!==void 0){let t=e.userData.textFrame;await Rr.loadFont(t.fontFamily),t.textOrigin=new Zv(t.textOrigin.x,t.textOrigin.y,t.textOrigin.z);let r=new Xv({color:t.hexColor,opacity:t.opacity,visible:t.visible,transparent:!0,side:ju});t.textLinesData&&(t.textLines=t.textLinesData.map((n,s)=>{let l=new To(Number(n.yLinePos),Number(n.lineHeight),Number(n.maxCharSize)),c=n.message.map((f,h)=>{if(f.char===void 0){let g=t.textLines[s].message[h];if("geometries"in g){let w=g.geometries[0].userData.parameters;Object.assign(f,{LOD:w.lod,char:w.char,fontFamily:w.fontFamily,fontSize:w.fontSize,letterSpacing:w.letterSpacing,originalChar:w.char})}}let d={char:f.char,fontFamily:f.fontFamily,letterSpacing:Number(f.letterSpacing),fontSize:Number(f.fontSize),LOD:f.LOD},x=new Rr(d,r.clone());return l.addChar3D(x,t.textOrigin),this.charContainer.add(x),x});return l.message=c,l}),this.userData.textFrame=t),this.textFullUpdate()}return this}fromTextFrameData(e,t){if(e.color!==void 0){let r=kt(e.color,t);this.updateColor(r),this.updateOpacity(r.a)}e.alpha!==void 0&&this.updateOpacity(e.alpha),e.font!==void 0&&this.updateFontFamily(e.font),e.horizontalAlign!==void 0&&this.updateHorizontalAlignment(e.horizontalAlign),e.verticalAlign!==void 0&&this.updateVerticalAlignment(e.verticalAlign),e.textTransform!==void 0&&this.updateTextTransform(e.textTransform),e.fontSize!==void 0&&this.updateFontSize(e.fontSize),e.lineHeight!==void 0&&this.updateLineHeight(e.lineHeight),e.letterSpacing!==void 0&&this.updateLetterSpacing(e.letterSpacing),e.text!==void 0&&e.text!==""&&this.updateText(e.text),(e.width!==void 0||e.height!==void 0)&&this.updateGeometry({parameters:{width:e.width,height:e.height}})}fromState(e,t){return super.fromState(e),this.fromTextFrameData(e,t),this}convertToVector(){let{fontFamily:e,hexColor:t}=this.userData.textFrame,r=new Qi;r.name="Text Shape";let n=Rr.fontCache[e];for(let s of this.charContainer.children)s instanceof Rr&&n.generateShapes(s.char,1).forEach(l=>{let c=new st().fromShape(l);c.applyScale(s.scale.x,s.scale.y);let f=ur.create({shape:c}),h=new vr({side:ju});h.color=t;let d=new Io(f,h);d.name=s.char,d.position.copy(s.position),d.rotation.copy(s.rotation),r.attach(d)});return r}},zs=Op;zs.VerticalAlign=gi,zs.HorizontalAlign=Lr,zs.TextTransform=ki;import{HemisphereLight as F3,Scene as V3,Vector3 as U3,Color as fb,Fog as k3,Box3 as H3}from"three";import{BufferGeometryLoader as _3}from"three";function Yv(i,e){return T3(i)}function T3(i){let e={parameters:i,type:i.type};if(i.type==="VectorGeometry"){let r=st.createFromState(i.shape,i.width,i.height);e.shape=r}else i.type==="NonParametricGeometry"&&(i.data.groups&&i.data.groups.forEach(r=>{var n;return r.materialIndex=Math.max((n=r.materialIndex)!=null?n:0,0)}),e.geometry=new _3().parse(i));let t;try{t=La(e)}catch(r){console.error(r)}if(!t){let r=st.createFromState(ws.defaultData(),100,100);e.shape=r,t=La(e)}return t}import{Box3 as I3,Matrix4 as Mo,Sphere as tb,Vector3 as M3}from"three";var rb=ug(eb());var Pp;au.then(i=>{Pp=i});var nb=new Mo,A3=new Mo,O3=new Mo,En=new I3,eo=new M3,P3=new Mo,D3=new Mo,Ka=class extends hr{constructor(e,t,r,n=new bn){super(r!=null?r:t,n);this.subdivPointer=e;this.originalGeometry=t;this.subdividedGeometry=r;this.objectType="SubdivObject";this.hiddenMatrixOld=new Mo;this.smoothShading=!0;this.matrixWorldRigid=new Mo;this.castShadow=!0,this.receiveShadow=!0,this.forceComputeSize=!1}static createFromState(e,t,r){let{subdivPointer:n,originalGeometry:s,subdividedGeometry:l}=en.build(t.geometry,void 0,void 0,!t.flatShading),c=Ra(t.material,r),f=new Ka(n,s,l||void 0,c);return f.calcBoundingBox(),f.freeSubdivPointer(),f.uuid=e,f.fromState(t),f}shallowClone(e){return new $a(this.geometry,this.material).shallowCopy(this,e)}toJSON(e){let t=super.toJSON(e);return t.object.objectType="SubdivObject",t}buildFromStore(e){var s,l,c;let{originalGeometry:t,subdividedGeometry:r,subdivPointer:n}=en.build(e,this.subdivPointer,void 0,this.smoothShading,this.shearScale);if(this.subdivPointer=n,t!==void 0&&((s=this.originalGeometry)==null||s.dispose(),this.originalGeometry=t),r!==void 0&&((l=this.subdividedGeometry)==null||l.dispose(),this.subdividedGeometry=r!=null?r:void 0),this.geometry=(c=this.subdividedGeometry)!=null?c:this.originalGeometry,this.cloner)for(let f of this.cloner.children)f.geometry=this.geometry;e.width&&(this.geometry.userData.parameters={width:e.width,height:e.height,depth:e.depth})}updateMesh(e=!1){en.buildLevel(this.subdivPointer,!0,this.smoothShading,this.originalGeometry,e?this.shearScaleInv:void 0),this.subdividedGeometry&&en.buildLevel(this.subdivPointer,!1,this.smoothShading,this.subdividedGeometry,e?this.shearScaleInv:void 0)}updateTopology(){var e;this.originalGeometry.dispose(),this.originalGeometry=en.buildLevel(this.subdivPointer,!0,this.smoothShading),this.subdividedGeometry&&(this.subdividedGeometry.dispose(),this.subdividedGeometry=en.buildLevel(this.subdivPointer,!1,this.smoothShading)),this.geometry=(e=this.subdividedGeometry)!=null?e:this.originalGeometry}raycast(e,t){var r;this.geometry=this.originalGeometry,hr.prototype.raycast.call(this,e,t),this.geometry=(r=this.subdividedGeometry)!=null?r:this.originalGeometry}updateMatrixWorldSVD(){let e=this.matrixWorld.elements,t=[[e[0],e[4],e[8]],[e[1],e[5],e[9]],[e[2],e[6],e[10]]],{u:r,v:n,q:s}=(0,rb.SVD)(t),l=nb.set(r[0][0],r[0][1],r[0][2],0,r[1][0],r[1][1],r[1][2],0,r[2][0],r[2][1],r[2][2],0,0,0,0,1),c=A3.set(n[0][0],n[0][1],n[0][2],0,n[1][0],n[1][1],n[1][2],0,n[2][0],n[2][1],n[2][2],0,0,0,0,1),f=O3.copy(c).transpose();this.shearScale=P3.makeScale(s[0],s[1],s[2]).multiply(f).premultiply(c),this.shearScaleInv=D3.copy(this.shearScale).invert(),this.matrixWorldRigid.multiplyMatrices(l,f),s.every(h=>Math.abs(s[0]-h)<.01)&&(this.shearScale=void 0,this.shearScaleInv=void 0)}activateSVDCompensation(){this.shearScale!==void 0&&(this.matrixAutoUpdate=!1,this.matrix.copy(this.matrixWorldRigid).copyPosition(this.matrixWorld),this.hiddenMatrixOld.copy(this.hiddenMatrix),this.hiddenMatrix.copy(this.parent.matrixWorld).invert())}deactivateSVDCompensation(){this.shearScale!==void 0&&(this.shearScale=void 0,this.shearScaleInv=void 0,this.matrixAutoUpdate=!0,this.hiddenMatrix.copy(this.hiddenMatrixOld))}calcBoundingBox(){let e=this.originalGeometry;e.boundingSphere===null&&(e.boundingSphere=new tb);let t=e.attributes.position,r=e.boundingSphere.center;En.setFromBufferAttribute(t),En.getCenter(r),e.boundingSphere.radius=r.distanceTo(En.max),isNaN(e.boundingSphere.radius)&&console.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.',this),En.getSize(eo);let n={width:eo.x,height:eo.y,depth:eo.z};return this.geometry.userData.parameters=n,n}updateBoundingBox(e){let t=this.originalGeometry;En.min.set(e[0],e[2],e[4]),En.max.set(e[1],e[3],e[5]),this.shearScaleInv&&(En.min.applyMatrix4(this.shearScaleInv),En.max.applyMatrix4(this.shearScaleInv)),t.boundingSphere===null&&(t.boundingSphere=new tb);let r=t.boundingSphere.center;En.getCenter(r),t.boundingSphere.radius=r.distanceTo(En.max),isNaN(t.boundingSphere.radius)&&console.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.',this),En.getSize(eo);let n={width:eo.x,height:eo.y,depth:eo.z};return this.geometry.userData.parameters=n,n}freeSubdivPointer(){this.subdivPointer&&(Pp.free_bvh(this.subdivPointer),Pp.free_subdivision_surface(this.subdivPointer),this.subdivPointer=0)}updateGeometry(e){this.geometry.userData.scale||(this.geometry.userData.scale=Array(3)),this.geometry.userData.scale[0]=this.geometry.userData.parameters.width===0?1:e.parameters.width/this.geometry.userData.parameters.width,this.geometry.userData.scale[1]=this.geometry.userData.parameters.height===0?1:e.parameters.height/this.geometry.userData.parameters.height,this.geometry.userData.scale[2]=this.geometry.userData.parameters.depth===0?1:e.parameters.depth/this.geometry.userData.parameters.depth,ib(this.originalGeometry.attributes,...this.geometry.userData.scale),this.originalGeometry.attributes.position.needsUpdate=!0,this.originalGeometry.attributes.normal.needsUpdate=!0,this.subdividedGeometry&&(ib(this.subdividedGeometry.attributes,...this.subdividedGeometry.userData.scale),this.subdividedGeometry.attributes.position.needsUpdate=!0,this.subdividedGeometry.attributes.normal.needsUpdate=!0),this.geometry.userData.parameters=U({},e.parameters)}};function ib(i,e,t,r){let n=i.position.array,s=i.normal.array,l=nb.makeScale(e,t,r).invert().elements,c,f,h;for(var d=0,x=n.length;d<x;d+=3)n[d]*=e,n[d+1]*=t,n[d+2]*=r,c=s[d],f=s[d+1],h=s[d+2],s[d]=l[0]*c+l[4]*f+l[8]*h,s[d+1]=l[1]*c+l[5]*f+l[9]*h,s[d+2]=l[2]*c+l[6]*f+l[10]*h}import{BackSide as B3,DoubleSide as G3,FrontSide as j3}from"three";function ob(i,e){e.flatShading!==void 0&&(i.flatShading=e.flatShading,i.needsUpdate=!0),e.wireframe!==void 0&&(i.wireframe=e.wireframe),e.side!==void 0&&(e.side===xs.Front?i.side=j3:e.side===xs.Back?i.side=B3:i.side=G3)}function E3(i,e){if(Array.isArray(i.material))for(let t of i.material)ob(t,e);else{let t=i.material;ob(t,e)}i.objectType==="SubdivObject"&&e.flatShading!==void 0&&(i.material.flatShading=!1,i.smoothShading=!e.flatShading,i.updateMesh())}function sb(i,e,t){let r;if(e.geometry.type==="SubdivGeometry")r=Ka.createFromState(i,e,t);else{let n=Yv(e.geometry,t),s="materials"in e?jv(e.materials,t):Ra(e.material,t);Fc.is2DParametricMesh(n.userData.type)?r=new Wa(n,s):(n==null?void 0:n.userData.type)==="VectorGeometry"?r=new Io(n,s):e.geometry.type==="NonParametricGeometry"?r=new $a(n,s):r=new qa(n,s),r.uuid=i,r.fromState(e)}return E3(r,e),r}function ab(i,e,t){return e.type==="Mesh"?sb(i,e,t):e.type==="TextFrame"?zs.createFromState(i,e,t):e.type==="Empty"?Qi.createFromState(i,e):e.type==="PointLight"?ka.createFromState(i,e,t):e.type==="SpotLight"?Ha.createFromState(i,e,t):e.type==="DirectionalLight"?Ua.createFromState(i,e,t):ps.is(e.type)?Yi.createFromState(i,e):(console.error(e),new Qi)}function R3(i,e){e.uniforms[`f${e.id}_transmissionSamplerMap`].value=i.texture,e.uniforms[`f${e.id}_transmissionDepthMap`].value=i.depthTexture}function lb(i,e,t){if(!t.userData.layers)return!1;let r=!1,n=t.userData.layers.getLayersOfType(qe.TRANSMISSION);return n.length>0?(e.layers.set(3),r=!0,i!==void 0&&n.forEach(s=>R3(i,s))):e.layers.set(0),r}function cb(i,e){let t=!1;return e.traverseEntity(r=>{if(r instanceof hr)if(Array.isArray(r.material))for(let n=0;n<r.material.length;n++)lb(i,r,r.material[n])&&(t=!0);else lb(i,r,r.material)&&(t=!0)}),t}function ub(i,e){"material"in i&&z3(i.material,e),"geometry"in i&&i.geometry.dispose()}function z3(i,e){fg(i).forEach(t=>{e.isSharedMaterial(t)||t.dispose()})}var hb=new U3,Dp=class extends uu(V3){constructor(e,t){super();this.objectType="Scene";this.alpha=1;this.backupFog=new k3(16777215,.1,2e3);this.fogUseBGColor=!1;this.wireframeState=!1;this.needsTransmissionDirty=!0;this._needsTransmission=!1;this._color=new fb(1,0,0);this.bgColor=new fb(1,1,1);this.entityByUuid={};this.ambientLight=new F3(13882323,8553090,.75),this.ambientLight.name="Default Ambient Light",this.personalCamera=this.createPersonalCamera(),this.activeCamera=this.personalCamera,this.sharedAssetManager=t,this.init(e,t)}needsTransmission(e){return this.needsTransmissionDirty&&(this._needsTransmission=cb(e,this),e!==void 0&&(this.needsTransmissionDirty=!1)),this._needsTransmission}find(e){if(e===""||e===void 0)return;let t=this.entityByUuid[e];return t===void 0?this.getObjectByProperty("uuid",e):t}get color(){return this._color}set color(e){this.fogUseBGColor===!0&&this.backupFog.color.copy(e),this._color.copy(e)}get enableFog(){return this.fog!==null}set enableFog(e){this.fog=e===!0?this.backupFog:null}init(e,t){if(this.createChildrenObjects(e.objects,this,t),this.personalCamera.removeFromParent(),this.add(this.personalCamera),this.ambientLight.removeFromParent(),this.add(this.ambientLight),this.setBackgroundColor(kt(e.backgroundColor,t)),this.updateFog(e.fog,t),this.updateAmbientLight(e.environment.ambientLight,t),this.activeCamera=this.personalCamera,e.publish.playCamera!==null){let r=this.find(e.publish.playCamera);r instanceof Yi&&this.switchActiveCamera(r)}}clearScene(e){this.traverseEntity(t=>{ub(t,e)});for(let t of this.children)yn(t)&&t.removeFromParent()}resetAfterClear(e,t){this.init(e,t)}createPersonalCamera(){let e=Yi.createFromState(Dp.PERSONAL_CAMERA_ID,fe(U({},Uc.defaultData),{name:"Personal Camera"}));return e.enableHelper=!1,e.objectHelper.visible=!1,delete e.isEntity,this.registerObjectCreatedInLegacy(e),e}raycast(e){let t=[],r=n=>{for(let s of n.children)yn(s)&&!s.raycastLock&&s.visible&&((_s(s)||vi(s)&&s.enableHelper&&s.objectHelper.parent)&&e.intersectObject(s,!1,t),r(s))};return r(this),t}traverseEntity(e){for(let t of this.children)yn(t)&&t.traverseEntity(e)}updateFog(e,t){this.enableFog=e.enabled,this.fogUseBGColor=e.useBackgroundColor,e.useBackgroundColor?this.backupFog.color.set(this.bgColor):this.backupFog.color=kt(e.color,t),this.backupFog.near=e.near,this.backupFog.far=e.far}toJSON(e){return{}}fromJSON(e){return this}dispose(){this.clearScene(this.sharedAssetManager),this.sharedAssetManager.dispose()}updateAmbientLight(e,t){fv(this.ambientLight,e,t),e.groundColor!==void 0&&(this.ambientLight.groundColor=kt(e.groundColor,t)),e.enabled!==void 0&&(this.ambientLight.visible=e.enabled)}switchActiveCamera(e){this.activeCamera!==this.personalCamera&&(this.activeCamera.enableHelper=!0),this.activeCamera=e,e.enableHelper=!1}setBackgroundColor(e){this.bgColor=e,this.alpha=e.a}createChildrenObjects(e,t,r){for(let n of e)this.createChildObject(n.id,n.data,n.children,t,r)}registerObjectCreatedInLegacy(e){this.entityByUuid[e.uuid]=e}unregisterObject(e){delete this.entityByUuid[e.uuid];for(let t of e.children)this.unregisterObject(t)}createChildObject(e,t,r,n,s){let l=ab(e,t,s);return l&&(this.entityByUuid[e]=l,n.add(l),this.createChildrenObjects(r,l,s)),l}getCenter(e){let t=[];for(let n=0,s=e.length;n<s;++n){let{id:l,recursive:c}=e[n],f=this.find(l),h=c?f.recursiveBBox:f.singleBBox;t.push(...h.vertices)}let r=new H3;return r.setFromPoints(t),r.getCenter(hb),hb}copyMatrixWorld(e,t){if(e===null){t.identity();return}let r=this.find(e);r?t.copy(r.matrixWorld):t.identity()}copyParentMatrixWorld(e,t){var n;if(e===null){t.identity();return}let r=(n=this.find(e))==null?void 0:n.parent;r?t.copy(r.matrixWorld):t.identity()}traverseMaterial(e){this.traverseEntity(t=>{if(t instanceof hr)if(Array.isArray(t.material))for(let r=0;r<t.material.length;r++)e(t.material[r]);else e(t.material)})}updateCanvasSize(e,t){this.activeCamera.setViewplaneSize(e,t);let r,n;e>=t?(r=t/e,n=1):(r=1,n=e/t),this.traverseMaterial(s=>{s.layersList.getLayersOfType(qe.TRANSMISSION).forEach(c=>{c.uniforms[`f${c.id}_aspectRatio`].value.x=r,c.uniforms[`f${c.id}_aspectRatio`].value.y=n})})}},Ru=Dp;Ru.PERSONAL_CAMERA_ID="f23858d0-4a3b-4bd8-8173-66ed0af7f6fb-personalCamera";import{DRACOLoader as W3}from"three/examples/jsm/loaders/DRACOLoader.js";var to;function q3(){return to||(to=new W3,to.setDecoderPath("https://www.gstatic.com/draco/versioned/decoders/1.5.2/").preload()),to.decoderPending}async function $3(i){if(to){let e={attributeIDs:to.defaultAttributeIDs,attributeTypes:to.defaultAttributeTypes,useUniqueIDs:!1},t;try{t=await to.decodeGeometry(new Int8Array(i).buffer,e)}catch(r){console.error(r)}if(t)return{index:t.index?{array:t.index.array}:void 0,attributes:Object.entries(t.attributes).map(([r,n])=>({name:r,itemSize:n.itemSize,array:n.array}))}}return null}async function pb(i){let[e,t]=ih(Pc.deserialize(new Uint8Array(i))),r=[];e.scene.objects.traverse((n,s)=>{s.type==="Mesh"&&s.geometry.type==="NonParametricGeometry"&&s.geometry.data.draco!==void 0&&r.push(s)}),r.length&&await q3();for(let n of r){let s=await $3(sh(n.geometry.data.draco));if(s){s.index&&(n.geometry.data.index={array:s.index.array,itemSize:1,normalized:!1,type:"Uint32Array"});let l={};s.attributes.forEach(({name:c,array:f,itemSize:h})=>{l[c]={array:f,itemSize:h,type:"Float32Array",normalized:!1}}),n.geometry.data.attributes=l,n.geometry.data.draco=void 0}}return t.result().data}import{WebGLRenderTarget as J3,LinearMipmapLinearFilter as K3,LinearFilter as X3,ClampToEdgeWrapping as db,DepthTexture as Z3}from"three";var mb=new vr,Bp=class extends tn{},Gp=class{constructor(e){this.materials={};this.images={};this.colors={};this.transmissionRenderTarget=new J3(2048,2048,{generateMipmaps:!0,minFilter:K3,magFilter:X3,wrapS:db,wrapT:db}),this.transmissionRenderTarget.depthTexture=new Z3(2048,2048),this.reset(e)}reset(e){for(let[t,r]of Object.entries(e.images))this.addImage(t,r.data);for(let[t,r]of Object.entries(e.colors))this.addColor(t,r);for(let[t,r]of Object.entries(e.materials))this.addMaterial(t,Lp(r,this))}get transmissionSamplerMap(){return this.transmissionRenderTarget.texture}get transmissionDepthMap(){return this.transmissionRenderTarget.depthTexture}addMaterial(e,t){t.uuid=e,this.materials[e]=t}deleteMaterial(e){this.materials[e]&&(this.materials[e].dispose(),delete this.materials[e])}isSharedMaterial(e){return e.uuid in this.materials||e===mb}getMaterial(e){let t=this.materials[e];return t}getMaterialOrDeletedPlaceholder(e){var t;return(t=this.materials[e])!=null?t:mb}getMaterials(){return this.materials}addImage(e,t){if(this.images[e])return this.images[e].onload=()=>{this.onImageLoad&&this.onImageLoad(e)},this.images[e].src=t,!0;{let r=new Image;return r.src=t,r.onload=()=>{this.onImageLoad&&this.onImageLoad(e)},this.images[e]=r,!1}}deleteImage(e){this.images[e]&&delete this.images[e]}getDefaultImage(){return this.images.image_0}getImage(e){return this.images[e]}getImages(){return this.images}addColor(e,t){return this.colors[e]?("a"in t?this.colors[e].setRGBA(t.r,t.g,t.b,t.a):this.colors[e].setRGBA(t.r,t.g,t.b,1),!0):("a"in t?this.colors[e]=new Bp(t.r,t.g,t.b,t.a):this.colors[e]=new Bp(t.r,t.g,t.b,1),!1)}updateColor(e,t){var r,n,s,l;if(this.colors[e]){let c=this.colors[e];return this.colors[e].r=(r=t.r)!=null?r:c.r,this.colors[e].g=(n=t.g)!=null?n:c.g,this.colors[e].b=(s=t.b)!=null?s:c.b,this.colors[e].a=(l=t.a)!=null?l:c.a,!0}return!1}deleteColor(e){this.colors[e]&&delete this.colors[e]}getColor(e){return this.colors[e]}dispose(){Object.keys(this.materials).forEach(t=>this.deleteMaterial(t)),this.transmissionRenderTarget.depthTexture.dispose(),this.transmissionRenderTarget.dispose(),this.onImageLoad=void 0}};import{Color as yb,ShaderLib as Y3}from"three";var xb=ug(gb());function vb(i){let e=new Set;return i.traverse(t=>{if(_s(t))if((0,xb.isArray)(t.material))t.material.forEach(r=>{let n=r;e.has(n)||e.add(n)});else{let r=t.material;e.has(r)||e.add(r)}}),e.forEach(t=>{let r=t.onBeforeCompile.bind(t);Q3(t)?(Object.assign(t,{isMeshStandardMaterial:!0,isMeshPhysicalMaterial:!0,transmission:1,attenuationColor:new yb,specularColor:new yb}),t.onBeforeCompile=(n,s)=>{r&&r(n,s),n.uniforms=Object.assign(Y3.physical.uniforms,n.uniforms),t.userData.layers.getLayersOfType(qe.TRANSMISSION).forEach(l=>{n.uniforms.transmissionSamplerMap.value&&(l.uniforms["f"+l.id+"_transmissionSamplerMap"].value=n.uniforms.transmissionSamplerMap.value,l.uniforms["f"+l.id+"_transmissionSamplerSize"].value=n.uniforms.transmissionSamplerSize.value)})}):eB(t)||(t.onBeforeCompile=(n,s)=>{r&&r(n,s),t.transparent=!1})}),i}function Q3(i){return i.userData.layers.getLayersOfType(qe.TRANSMISSION).length>0}function eB(i){let e=i.userData.layers.head,t=0;for(;e!==void 0;){if(e.type!==qe.LIGHTING&&e.type!==qe.FRESNEL){let r=e.uniforms["f"+e.id+"_alpha"];r&&(t+=(1-t)*r.value)}e=e.next}return t<1}function bb(i){return i.traverse(e=>{if(e.type==="Camera"){let t=e;t.type=t.cameraType}}),i}var Sb=class extends rB{load(e,t,r,n=console.error){let s=new tB(this.manager);s.setPath(this.path),s.setResponseType("arraybuffer"),s.setRequestHeader(this.requestHeader),s.setWithCredentials(this.withCredentials),s.load(e,async l=>{try{if(typeof l=="string")throw new Error("The .spline file is not binary!");let c=await this.parse(l);t(c)}catch(c){n(c)}},r,n)}async parse(e){let t=await pb(e),r=new Gp(t.shared),n=new Ru(t.scene,r);return bb(vb(n))}};export{Sb as default};
|