@roomle/web-sdk 2.60.0 → 2.61.0-alpha.1
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/lib/{banana-for-scale-3a114a0c.nomodule.js → banana-for-scale-1b8f041a.nomodule.js} +2 -2
- package/lib/{banana-for-scale-3a114a0c.nomodule.js.map → banana-for-scale-1b8f041a.nomodule.js.map} +1 -1
- package/lib/{banana-for-scale-68a45a69.js → banana-for-scale-411e5a4a.js} +2 -2
- package/lib/{banana-for-scale-68a45a69.js.map → banana-for-scale-411e5a4a.js.map} +1 -1
- package/lib/{component-dimensioning-a8078114.nomodule.js → component-dimensioning-a747c60d.nomodule.js} +2 -2
- package/lib/component-dimensioning-a747c60d.nomodule.js.map +1 -0
- package/lib/{component-dimensioning-64dd804c.js → component-dimensioning-be39c0b1.js} +2 -2
- package/lib/component-dimensioning-be39c0b1.js.map +1 -0
- package/lib/{component-raycast-helper-4f91b663.js → component-raycast-helper-c3888e4b.js} +2 -2
- package/lib/component-raycast-helper-c3888e4b.js.map +1 -0
- package/lib/{component-raycast-helper-ac3b7072.nomodule.js → component-raycast-helper-f110f8df.nomodule.js} +2 -2
- package/lib/component-raycast-helper-f110f8df.nomodule.js.map +1 -0
- package/lib/{configurator-c62d84e8.js → configurator-8a45d794.js} +2 -2
- package/lib/configurator-8a45d794.js.map +1 -0
- package/lib/{configurator-a9c1fe12.nomodule.js → configurator-ba8f2705.nomodule.js} +2 -2
- package/lib/configurator-ba8f2705.nomodule.js.map +1 -0
- package/lib/configurator-main-6b1a9963.js +2 -0
- package/lib/configurator-main-6b1a9963.js.map +1 -0
- package/lib/configurator-main.nomodule.js +1 -1
- package/lib/{continuous-drawing-helper-3b11f9f9.js → continuous-drawing-helper-8234d7be.js} +2 -2
- package/lib/continuous-drawing-helper-8234d7be.js.map +1 -0
- package/lib/{continuous-drawing-helper-7a08e3cf.nomodule.js → continuous-drawing-helper-c5fe700e.nomodule.js} +2 -2
- package/lib/continuous-drawing-helper-c5fe700e.nomodule.js.map +1 -0
- package/lib/{default-light-setting-01a91d0f.nomodule.js → default-light-setting-942df376.nomodule.js} +2 -2
- package/lib/default-light-setting-942df376.nomodule.js.map +1 -0
- package/lib/{default-light-setting-f4f47231.js → default-light-setting-d50d49f0.js} +2 -2
- package/lib/default-light-setting-d50d49f0.js.map +1 -0
- package/lib/definitions/common-core/src/webgl/renderer/screen-space-shadow-map.d.ts +1 -0
- package/lib/{dimensioning-helper-b9457f63.js → dimensioning-helper-1b1e1ca3.js} +2 -2
- package/lib/{dimensioning-helper-b9457f63.js.map → dimensioning-helper-1b1e1ca3.js.map} +1 -1
- package/lib/{dimensioning-helper-3efe98dd.nomodule.js → dimensioning-helper-9ef056d6.nomodule.js} +2 -2
- package/lib/{dimensioning-helper-3efe98dd.nomodule.js.map → dimensioning-helper-9ef056d6.nomodule.js.map} +1 -1
- package/lib/{glb-viewer-1aee8147.js → glb-viewer-8648293c.js} +2 -2
- package/lib/{glb-viewer-1aee8147.js.map → glb-viewer-8648293c.js.map} +1 -1
- package/lib/{glb-viewer-c1c1106b.nomodule.js → glb-viewer-d6255582.nomodule.js} +2 -2
- package/lib/{glb-viewer-c1c1106b.nomodule.js.map → glb-viewer-d6255582.nomodule.js.map} +1 -1
- package/lib/glb-viewer-main-92221a71.js +2 -0
- package/lib/glb-viewer-main-92221a71.js.map +1 -0
- package/lib/glb-viewer-main.nomodule.js +1 -1
- package/lib/legacy/{banana-for-scale-8fde3b6e.legacy.js → banana-for-scale-eb990d71.legacy.js} +2 -2
- package/lib/legacy/{banana-for-scale-8fde3b6e.legacy.js.map → banana-for-scale-eb990d71.legacy.js.map} +1 -1
- package/lib/legacy/{component-dimensioning-0c4f6279.legacy.js → component-dimensioning-5ddf8d0a.legacy.js} +2 -2
- package/lib/legacy/component-dimensioning-5ddf8d0a.legacy.js.map +1 -0
- package/lib/legacy/{component-raycast-helper-e634d9cc.legacy.js → component-raycast-helper-a2d37ac8.legacy.js} +2 -2
- package/lib/legacy/component-raycast-helper-a2d37ac8.legacy.js.map +1 -0
- package/lib/legacy/{configurator-5d8e9e4c.legacy.js → configurator-3ba95484.legacy.js} +2 -2
- package/lib/legacy/configurator-3ba95484.legacy.js.map +1 -0
- package/lib/legacy/configurator-main.legacy.js +1 -1
- package/lib/legacy/{continuous-drawing-helper-d7691e20.legacy.js → continuous-drawing-helper-e7b0526f.legacy.js} +2 -2
- package/lib/legacy/continuous-drawing-helper-e7b0526f.legacy.js.map +1 -0
- package/lib/legacy/{default-light-setting-80b8957f.legacy.js → default-light-setting-95addd85.legacy.js} +2 -2
- package/lib/legacy/default-light-setting-95addd85.legacy.js.map +1 -0
- package/lib/legacy/{dimensioning-helper-8d78ba0a.legacy.js → dimensioning-helper-2dbdb17d.legacy.js} +2 -2
- package/lib/legacy/{dimensioning-helper-8d78ba0a.legacy.js.map → dimensioning-helper-2dbdb17d.legacy.js.map} +1 -1
- package/lib/legacy/{glb-viewer-20b26df0.legacy.js → glb-viewer-6dee4f24.legacy.js} +2 -2
- package/lib/legacy/{glb-viewer-20b26df0.legacy.js.map → glb-viewer-6dee4f24.legacy.js.map} +1 -1
- package/lib/legacy/glb-viewer-main.legacy.js +1 -1
- package/lib/legacy/{material-viewer-83aa0d82.legacy.js → material-viewer-b6d87d4d.legacy.js} +2 -2
- package/lib/legacy/material-viewer-b6d87d4d.legacy.js.map +1 -0
- package/lib/legacy/material-viewer-main.legacy.js +1 -1
- package/lib/legacy/{planner-a0ef7d31.legacy.js → planner-16fc7895.legacy.js} +2 -2
- package/lib/legacy/{planner-a0ef7d31.legacy.js.map → planner-16fc7895.legacy.js.map} +1 -1
- package/lib/legacy/planner-main.legacy.js +1 -1
- package/lib/legacy/{roomle-configurator-7dc323ca.legacy.js → roomle-configurator-658bd821.legacy.js} +2 -2
- package/lib/legacy/roomle-configurator-658bd821.legacy.js.map +1 -0
- package/lib/legacy/roomle-dependency-injection-fe83f5a8.legacy.js +9 -0
- package/lib/legacy/{roomle-dependency-injection-ab58de3d.legacy.js.map → roomle-dependency-injection-fe83f5a8.legacy.js.map} +1 -1
- package/lib/legacy/roomle-sdk.legacy.js +1 -1
- package/lib/legacy/{scene-manager-079c4752.legacy.js → scene-manager-136db902.legacy.js} +2 -2
- package/lib/legacy/{scene-manager-079c4752.legacy.js.map → scene-manager-136db902.legacy.js.map} +1 -1
- package/lib/legacy/{script-loader-35fe01aa.legacy.js → script-loader-bed3087a.legacy.js} +2 -2
- package/lib/legacy/script-loader-bed3087a.legacy.js.map +1 -0
- package/lib/legacy/{stats-helper-40eeaca2.legacy.js → stats-helper-ff57364c.legacy.js} +2 -2
- package/lib/legacy/stats-helper-ff57364c.legacy.js.map +1 -0
- package/lib/legacy/{tools-core-ae90b05b.legacy.js → tools-core-3e70a4f3.legacy.js} +2 -2
- package/lib/legacy/tools-core-3e70a4f3.legacy.js.map +1 -0
- package/lib/{material-viewer-e70173ae.js → material-viewer-90d8260f.js} +2 -2
- package/lib/material-viewer-90d8260f.js.map +1 -0
- package/lib/{material-viewer-4d884001.nomodule.js → material-viewer-b5729235.nomodule.js} +2 -2
- package/lib/material-viewer-b5729235.nomodule.js.map +1 -0
- package/lib/material-viewer-main-d161abcc.js +2 -0
- package/lib/material-viewer-main-d161abcc.js.map +1 -0
- package/lib/material-viewer-main.nomodule.js +1 -1
- package/lib/{planner-7ec2696d.nomodule.js → planner-89c28a23.nomodule.js} +2 -2
- package/lib/{planner-7ec2696d.nomodule.js.map → planner-89c28a23.nomodule.js.map} +1 -1
- package/lib/{planner-2d7a7b1b.js → planner-9ebfcb2b.js} +2 -2
- package/lib/{planner-2d7a7b1b.js.map → planner-9ebfcb2b.js.map} +1 -1
- package/lib/planner-main-cd087802.js +2 -0
- package/lib/planner-main-cd087802.js.map +1 -0
- package/lib/planner-main.nomodule.js +1 -1
- package/lib/{roomle-configurator-42d4fecc.js → roomle-configurator-521e927f.js} +2 -2
- package/lib/roomle-configurator-521e927f.js.map +1 -0
- package/lib/{roomle-configurator-b01d2885.nomodule.js → roomle-configurator-683f0ae0.nomodule.js} +2 -2
- package/lib/roomle-configurator-683f0ae0.nomodule.js.map +1 -0
- package/lib/roomle-dependency-injection-390d51f2.js +16 -0
- package/lib/{roomle-dependency-injection-bf64a07e.js.map → roomle-dependency-injection-390d51f2.js.map} +1 -1
- package/lib/roomle-dependency-injection-f0a6e177.nomodule.js +16 -0
- package/lib/{roomle-dependency-injection-2583f0dc.nomodule.js.map → roomle-dependency-injection-f0a6e177.nomodule.js.map} +1 -1
- package/lib/{roomle-sdk-1ed375ca.js → roomle-sdk-597c482f.js} +2 -2
- package/lib/roomle-sdk-597c482f.js.map +1 -0
- package/lib/roomle-sdk.nomodule.js +1 -1
- package/lib/{scene-manager-45fc4ce6.nomodule.js → scene-manager-9ba0a160.nomodule.js} +2 -2
- package/lib/{scene-manager-45fc4ce6.nomodule.js.map → scene-manager-9ba0a160.nomodule.js.map} +1 -1
- package/lib/{scene-manager-d25d6ad2.js → scene-manager-f66599cf.js} +2 -2
- package/lib/{scene-manager-d25d6ad2.js.map → scene-manager-f66599cf.js.map} +1 -1
- package/lib/{script-loader-92e1532b.nomodule.js → script-loader-2d5e7ddb.nomodule.js} +2 -2
- package/lib/script-loader-2d5e7ddb.nomodule.js.map +1 -0
- package/lib/{script-loader-9059c8a6.js → script-loader-b4f54de0.js} +2 -2
- package/lib/script-loader-b4f54de0.js.map +1 -0
- package/lib/{stats-helper-dd07b86c.nomodule.js → stats-helper-7835a1cb.nomodule.js} +2 -2
- package/lib/stats-helper-7835a1cb.nomodule.js.map +1 -0
- package/lib/{stats-helper-62ea900d.js → stats-helper-f207bbc5.js} +2 -2
- package/lib/stats-helper-f207bbc5.js.map +1 -0
- package/lib/{tools-core-02eb3a98.js → tools-core-1798c674.js} +2 -2
- package/lib/tools-core-1798c674.js.map +1 -0
- package/lib/{tools-core-f5491293.nomodule.js → tools-core-30418d31.nomodule.js} +2 -2
- package/lib/tools-core-30418d31.nomodule.js.map +1 -0
- package/package.json +2 -2
- package/lib/component-dimensioning-64dd804c.js.map +0 -1
- package/lib/component-dimensioning-a8078114.nomodule.js.map +0 -1
- package/lib/component-raycast-helper-4f91b663.js.map +0 -1
- package/lib/component-raycast-helper-ac3b7072.nomodule.js.map +0 -1
- package/lib/configurator-a9c1fe12.nomodule.js.map +0 -1
- package/lib/configurator-c62d84e8.js.map +0 -1
- package/lib/configurator-main-ba699dda.js +0 -2
- package/lib/configurator-main-ba699dda.js.map +0 -1
- package/lib/continuous-drawing-helper-3b11f9f9.js.map +0 -1
- package/lib/continuous-drawing-helper-7a08e3cf.nomodule.js.map +0 -1
- package/lib/default-light-setting-01a91d0f.nomodule.js.map +0 -1
- package/lib/default-light-setting-f4f47231.js.map +0 -1
- package/lib/glb-viewer-main-a9bf8d50.js +0 -2
- package/lib/glb-viewer-main-a9bf8d50.js.map +0 -1
- package/lib/legacy/component-dimensioning-0c4f6279.legacy.js.map +0 -1
- package/lib/legacy/component-raycast-helper-e634d9cc.legacy.js.map +0 -1
- package/lib/legacy/configurator-5d8e9e4c.legacy.js.map +0 -1
- package/lib/legacy/continuous-drawing-helper-d7691e20.legacy.js.map +0 -1
- package/lib/legacy/default-light-setting-80b8957f.legacy.js.map +0 -1
- package/lib/legacy/material-viewer-83aa0d82.legacy.js.map +0 -1
- package/lib/legacy/roomle-configurator-7dc323ca.legacy.js.map +0 -1
- package/lib/legacy/roomle-dependency-injection-ab58de3d.legacy.js +0 -9
- package/lib/legacy/script-loader-35fe01aa.legacy.js.map +0 -1
- package/lib/legacy/stats-helper-40eeaca2.legacy.js.map +0 -1
- package/lib/legacy/tools-core-ae90b05b.legacy.js.map +0 -1
- package/lib/material-viewer-4d884001.nomodule.js.map +0 -1
- package/lib/material-viewer-e70173ae.js.map +0 -1
- package/lib/material-viewer-main-7c8974fa.js +0 -2
- package/lib/material-viewer-main-7c8974fa.js.map +0 -1
- package/lib/planner-main-d56b0156.js +0 -2
- package/lib/planner-main-d56b0156.js.map +0 -1
- package/lib/roomle-configurator-42d4fecc.js.map +0 -1
- package/lib/roomle-configurator-b01d2885.nomodule.js.map +0 -1
- package/lib/roomle-dependency-injection-2583f0dc.nomodule.js +0 -16
- package/lib/roomle-dependency-injection-bf64a07e.js +0 -16
- package/lib/roomle-sdk-1ed375ca.js.map +0 -1
- package/lib/script-loader-9059c8a6.js.map +0 -1
- package/lib/script-loader-92e1532b.nomodule.js.map +0 -1
- package/lib/stats-helper-62ea900d.js.map +0 -1
- package/lib/stats-helper-dd07b86c.nomodule.js.map +0 -1
- package/lib/tools-core-02eb3a98.js.map +0 -1
- package/lib/tools-core-f5491293.nomodule.js.map +0 -1
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
System.register(["./main-thread-to-worker-50cdf3d3.legacy.js"],(function(e,t){var r,n,a,i,s,o,l,h,d,c,u,p,m,f,g,v,w,b,y,_,x,S,C,M,T,A,P,R,E,I,k,O,D,L,U,F,B,N,z,H,j,V,G,K,W,X,q,Q,Y,Z,J,$,ee,te,re,ne,ae,ie,se,oe,le,he,de,ce,ue,pe,me,fe,ge,ve,we,be,ye,_e,xe,Se,Ce,Me,Te,Ae,Pe,Re,Ee,Ie,ke,Oe,De,Le,Ue,Fe,Be,Ne,ze,He,je,Ve,Ge,Ke,We,Xe,qe,Qe,Ye,Ze,Je,$e,et,tt,rt,nt,at,it,st,ot,lt,ht,dt,ct,ut,pt,mt,ft,gt,vt,wt,bt,yt,_t,xt,St,Ct,Mt,Tt,At,Pt,Rt,Et,It,kt,Ot,Dt,Lt,Ut,Ft,Bt,Nt,zt,Ht,jt,Vt,Gt,Kt,Wt,Xt,qt,Qt,Yt,Zt,Jt,$t,er,tr;return{setters:[function(e){r=e.g,n=e.A,a=e.D,i=e.V,s=e.a,o=e.R,l=e.S,h=e.C,d=e.M,c=e.B,u=e.b,p=e.T,m=e.c,f=e.d,g=e._,v=e.e,w=e.f,b=e.h,y=e.L,_=e.F,x=e.i,S=e.P,C=e.j,M=e.k,T=e.l,A=e.m,P=e.n,R=e.Q,E=e.I,I=e.O,k=e.o,O=e.p,D=e.q,L=e.r,U=e.s,F=e.t,B=e.u,N=e.v,z=e.w,H=e.x,j=e.y,V=e.z,G=e.E,K=e.G,W=e.H,X=e.J,q=e.K,Q=e.N,Y=e.U,Z=e.W,J=e.X,$=e.Y,ee=e.Z,te=e.$,re=e.a0,ne=e.a1,ae=e.a2,ie=e.a3,se=e.a4,oe=e.a5,le=e.a6,he=e.a7,de=e.a8,ce=e.a9,ue=e.aa,pe=e.ab,me=e.ac,fe=e.ad,ge=e.ae,ve=e.af,we=e.ag,be=e.ah,ye=e.ai,_e=e.aj,xe=e.ak,Se=e.al,Ce=e.am,Me=e.an,Te=e.ao,Ae=e.ap,Pe=e.aq,Re=e.ar,Ee=e.as,Ie=e.at,ke=e.au,Oe=e.av,De=e.aw,Le=e.ax,Ue=e.ay,Fe=e.az,Be=e.aA,Ne=e.aB,ze=e.aC,He=e.aD,je=e.aE,Ve=e.aF,Ge=e.aG,Ke=e.aH,We=e.aI,Xe=e.aJ,qe=e.aK,Qe=e.aL,Ye=e.aM,Ze=e.aN,Je=e.aO,$e=e.aP,et=e.aQ,tt=e.aR,rt=e.aS,nt=e.aT,at=e.aU,it=e.aV,st=e.aW,ot=e.aX,lt=e.aY,ht=e.aZ,dt=e.a_,ct=e.a$,ut=e.b0,pt=e.b1,mt=e.b2,ft=e.b3,gt=e.b4,vt=e.b5,wt=e.b6,bt=e.b7,yt=e.b8,_t=e.b9,xt=e.ba,St=e.bb,Ct=e.bc,Mt=e.bd,Tt=e.be,At=e.bf,Pt=e.bg,Rt=e.bh,Et=e.bi,It=e.bj,kt=e.bk,Ot=e.bl,Dt=e.bm,Lt=e.bn,Ut=e.bo,Ft=e.bp,Bt=e.bq,Nt=e.br,zt=e.bs,Ht=e.bt,jt=e.bu,Vt=e.bv,Gt=e.bw,Kt=e.bx,Wt=e.by,Xt=e.bz,qt=e.bA,Qt=e.bB,Yt=e.bC,Zt=e.bD,Jt=e.bE,$t=e.bF,er=e.bG,tr=e.bH}],execute:function(){e({_:pr,i:fr,x:Is});class rr{constructor(){this._context=new Map,this._lookups=new Map,this._singletons=new Map}getContext(e){if(this._context.has(e)){const t=this._context.get(e);return this._context.set(e,t+1),e+t}return this._context.set(e,1),e+0}addDependencyInjectionAssignments(e){e.forEach(e=>{this._lookups.set(e.className,e)})}lookup(e,t){if(!this._lookups.has(e))return null;const r=this._lookups.get(e);if(1===r.type&&void 0===t){const t="Dependency "+e+" has definition context but no context was defined!";return console.trace(t),console.error(t),null}let n=t&&1===r.type?t:"global";if(n+="_"+e,2===r.type)return new r.classDefinition;if(this._singletons.has(n))return this._singletons.get(n);const a=new r.classDefinition(t);return this._singletons.set(n,a),a}cleanUp(e){if(e){let t=[];this._singletons.forEach((r,n)=>{n.startsWith(e)&&t.push(n)}),t.forEach(e=>{this._singletons.delete(e)})}else this._singletons.clear(),this._singletons=new Map}}class nr{constructor(e,t,r){this.className=e,this.classDefinition=t,this.type=void 0===r?0:r}}e("D",nr);const ar={JPG:".jpg",JPEG:".jpeg",PNG:".png",GIF:".gif"};class ir{_base64toBlob(e,t){t=t||"";const r=atob(e),n=r.length,a=Math.ceil(n/1024),i=new Array(a);for(let e=0;e<a;++e){let t=1024*e,a=Math.min(t+1024,n);const s=new Array(a-t);for(let e=t,n=0;e<a;++n,++e)s[n]=r[e].charCodeAt(0);i[e]=new Uint8Array(s)}return new Blob(i,{type:t})}_createFormData(e,t,r,n){const a=new FormData;-1!==e.indexOf(",")&&(e=e.substr(e.indexOf(",")+1));const i=-1===Object.keys(ar).map(e=>ar[e]).indexOf(r)?"application":"image",s=this._base64toBlob(e,i+"/"+r.substr(1));return a.append(n,s,t+r),a}create(e,t,r,n){return this._createFormData(e,t,r,n)}}const sr=e("q",{SOFA:"sofa",SHELF:"shelf",SHELF_FRONT:"shelf_front",BAKED:"baked",CAMERA:"camera",EQUAL:"equal"});class or{static createDynamicLightSettingSource(e,t){let n={};if(e)n.url=e;else if(t)switch(t){case sr.SHELF:n.url=r()+"static/shelf-2975dd3f2fa9c763.json";break;case sr.SHELF_FRONT:n.url=r()+"static/shelf_front-8c9566a4512f0de8.json";break;case sr.SOFA:n.url=r()+"static/sofa-997b116bc5f2e92e.json";break;case sr.BAKED:n.url=r()+"static/baked-6485a2b1daeb69e8.json";break;case sr.CAMERA:n.url=r()+"static/camera-05824b47cdb951e4.json";break;case sr.EQUAL:n.url=r()+"static/equal-319f6b83c827913f.json";break;default:n.url=r()+"static/camera-05824b47cdb951e4.json"}else n=null;return n}parse(e){let t=JSON.parse(e);return t.lights?this.load(t):[]}load(e){let t=[];return e.lights?(e.lights.forEach(e=>{let r;switch(e.type){case"ambient":r=this._parseAmbientLight(e);break;case"rectarea":r=this._parseRectAreaLight(e);break;case"spot":r=this._parseSpotLight(e);break;case"directional":r=this._parseDirectionalLight(e)}r&&t.push(r)}),t):[]}_parseAmbientLight(e){let t=new n;return this._parseCommon(t,e),t}_parseRectAreaLight(e){let{intensity:t,castShadow:r,target:n,width:l,height:h}=e,d=null;if(r&&or.rectAreaLightReplacement){const r=new a;this._parseCommon(r,e),d=r,r.castShadow=!0,r.shadow.camera.near=.1,r.shadow.camera.far=100,r.shadow.mapSize=new i(1024,1024),r.shadow.bias=-5e-5,r.shadow.normalBias=.01,r.intensity=t?t/100:1,r.lookAt(n?new s(n.x,n.y,n.z):new s(0,0,0))}else{const r=new o;this._parseCommon(r,e),d=r,r.width=l||.8,r.height=h||.8,r.castShadow=!1,r.matrixAutoUpdate=!0,r.intensity=(t||240)/((l||.8)*(h||.8)),r.lookAt(n?new s(n.x,n.y,n.z):new s(0,0,0)),or.rectAreaLightLoadingListener&&or.rectAreaLightLoadingListener(r)}return d}_parseSpotLight(e){let t=new l;this._parseCommon(t,e);let{angle:r,penumbra:n,target:a,castShadow:o}=e;return t.angle=(r||100)*Math.PI/180,t.penumbra=n||.5,t.lookAt(a?new s(a.x,a.y,a.z):new s(0,0,0)),t.shadow.camera.near=.1,t.shadow.camera.far=10,t.shadow.mapSize=new i(1024,1024),t.castShadow=o||!1,t}_parseDirectionalLight(e){let t=new a;this._parseCommon(t,e);let{target:r,castShadow:n}=e;return t.castShadow=n||!1,t.shadow.camera.near=.1,t.shadow.camera.far=100,t.shadow.mapSize=new i(1024,1024),t.shadow.bias=-5e-5,t.lookAt(r?new s(r.x,r.y,r.z):new s(0,0,0)),t}_parseCommon(e,t){let{name:r,intensity:n,color:a,position:i,movesWithCamera:o}=t;e.name=r||"",e.intensity=n||1,e.color=new h(a||"#ffffff"),e.position.copy(i?new s(i.x,i.y,i.z):new s(0,0,0)),e.visible=!0,e.layers.set(1),e.userData.movesWithCamera=o}}e("p",or),or.rectAreaLightReplacement=!0;const lr=["127.0.0.1","localhost","0.0.0.0"],hr=(e("H",(function(e){return!(!e||"string"!=typeof e||e.split(":").length>2)})),e("G",e=>{if(!e||"string"!=typeof e)return null;const t=e.split(":");return t.length<2?null:t[0]})),dr=({articleNr:e,componentId:t})=>e&&""!==e?t.split(":")[0]+":"+e:null,cr=(e,t)=>null!=e?"string"==typeof e?"true"===e:!0===e:("string"==typeof t&&(t=parseInt(t,10)),t>=200&&t<300);class ur{constructor(){this._queue=[],this._pendingRequests=0}_nextSlot(){if(this._pendingRequests-=1,!this._queue.length)return;const{request:e,resolve:t,reject:r}=this._queue.shift();this._fetch(e).then(t,r)}_fetch(e,t={},r={}){return this._pendingRequests+=1,new Promise((n,a)=>{self.fetch(e,t).then(async function(e){this._nextSlot();const t=!r.checkResponse||!1!==await r.checkResponse(e);if(cr(e.ok,e.status)&&t)n(...arguments);else{const t=(null==e?void 0:e.url)||"URL unknown";a(new Error(e.statusText||'Http error "'+(e&&e.status?e.status:"unknown")+'", for "'+t+'"'))}}.bind(this),e=>{this._nextSlot(),a(e)})})}fetch(e,t={},r={}){return this._pendingRequests>=40?new Promise((t,r)=>this._queue.push({request:e,resolve:t,reject:r})):this._fetch(e,t,r)}}function pr(e,t,r,n){var a,i=arguments.length,s=i<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,r):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,n);else for(var o=e.length-1;o>=0;o--)(a=e[o])&&(s=(i<3?a(s):i>3?a(t,r,s):a(t,r))||s);return i>3&&s&&Object.defineProperty(t,r,s),s}"function"==typeof SuppressedError&&SuppressedError;const mr=function(e){return e.startsWith("_")&&(e=e.substr(1)),e.replace(/[A-Z](?:(?=[^A-Z])|[A-Z]*(?=[A-Z][^A-Z]|$))/g,(function(e,t){return(t>0?"-":"")+e.toLowerCase()}))};function fr(e,t){const r=Symbol("property-cache");Object.defineProperty(e,t,{get(){if(!this[r]){const e=window.__RML__DI__.lookup(mr(t),this._creator_);e?this[r]=e:console.error("Dependency "+mr(t)+" not found! Add dependency to /utils/injectables.ts")}return this[r]}})}class gr{info(...e){console}log(...e){console}warn(...e){console.warn.apply(console,e)}error(...e){console.warn.apply(console,e)}}e("L",gr);class vr extends gr{constructor(e){super(),this._creator_=e}setMeta(e){this._meta=e}get meta(){return this._meta?this._meta:{}}throw(e){const t="[Kernel Exception]: "+e;this._globalCallback.onKernelMsg("exception",e,this.meta),this.error(t)}error(e){this._globalCallback.onKernelMsg("error",e,this.meta),super.error(e)}warn(e){this._globalCallback.onKernelMsg("warning",e,this.meta),super.warn(e)}}pr([fr],vr.prototype,"_globalCallback",void 0);const wr=new Map,br=new Map,yr=new Map,_r=new Map;class xr{constructor(e){this._bootCallbacks=[],this._isStarted=!1,this._isStarting=!1,this._alwaysUseCache=!1,this._creator_=e}start(e){return this._configuratorUiCallbacks.onSyncStarted(),this._startWorker().then(()=>this._handleCatalog(e)).then(()=>{const{typeChangeTag:e,floorMaterialsTag:t}=this._initData;Promise.all([this._syncFloorTag(t),this._syncTypeChangeTag(e)]).then(()=>{_r.set(e,!0),this._configuratorUiCallbacks.onSyncDone()})})}syncCatalog(e){return this._startWorker().then(()=>this._handleCatalog(e))}syncFloorTag(e){return this._startWorker().then(()=>this._syncFloorTag(e))}syncTypeChangeTag(e){return this._startWorker().then(()=>this._syncTypeChangeTag(e))}_syncFloorTag(e){const t=[];return e&&!yr.get(e)?(t.push(this._handleTags([e])),this._rapiAccess.getTag(e).then(e=>{t.push(this._handleMaterialsAndTextures(e))}),this._singlePromiseFactory.create(1,e,r=>{Promise.all(t).then(()=>{yr.set(e,!0),r()},e=>this._softReject(r,'_syncFloorTag error: "'+e+'"'))})):Promise.resolve()}_syncTypeChangeTag(e){const t=[];return e&&!_r.get(e)?(t.push(this._handleTags([e])),this._rapiAccess.getTag(e).then(e=>{this._rapiAccess.getItems(e.items).then(e=>{e.forEach(e=>{this.getIsCatalogSynced(e.catalog)&&t.push(this._handleCatalog(e.catalog))})})}),this._singlePromiseFactory.create(2,e,r=>{Promise.all(t).then(()=>{yr.set(e,!0),r()},e=>this._softReject(r,'_syncTypeChangeTag error: "'+e+'"'))})):Promise.resolve()}getIsCatalogSynced(e){return!!br.get(e)}_startWorker(){return new Promise((e,t)=>{if(this._isStarted)return e();this._bootCallbacks.push({resolve:e,reject:t}),this._isStarting||(this._worker=new Worker(r()+"static/asset-loader.worker-1735a5fb1e401244.js"),this._mainThreadToWorker=new d(this,this._worker),this._isStarting=!0,this._mainThreadToWorker.sendToWorker(1))})}onCommand(e,t,r){switch(e){case 4:this._isStarted=!0,this._bootCallbacks.forEach(({resolve:e})=>e());break;case 3:this._mainThreadToWorker.resolvePromises(t,r)}}_handleCatalog(e){return this._singlePromiseFactory.create(0,e,t=>this.getIsCatalogSynced(e)?t():this._rapiAccess.getCatalog(e).then(e=>Promise.all([this._handleContentWithAssets(this._rapiAccess.getComponentsOf(e),["perspectiveImage"]),this._handleItemsAndAdditionalContents(e),this._handleMaterialsAndTextures(e),this._handleExternalMeshes(e),this._handleTags(e.tags)])).then(()=>{br.set(e,!0),t()},e=>this._softReject(t,'Catalog sync error: "'+e+'"')))}_handleTags(e){return this._handleContentWithAssets(this._rapiAccess.getTags(e),["pngIcon","svgIcon"])}_handleExternalMeshes(e){return new Promise(t=>{this._rapiAccess.getMeshesOfCatalog(e.id).then(e=>{const r=[];e.forEach(e=>{r.push(this._handleContentWithAssets(Promise.all([this._rapiAccess.getMesh(e.id)]),["url"]))}),Promise.all(r).then(t,e=>this._softReject(t,'Sync crt files error: "'+e+'"'))},e=>this._softReject(t,'getMeshesOfCatalog error: "'+e+'"'))})}_handleItemsAndAdditionalContents(e){return new Promise(t=>{this._rapiAccess.getItemsOf(e).then(e=>{const r=[];r.push(this._handleContentWithAssets(Promise.resolve(e),["perspectiveImage"])),this._rapiAccess.getAdditionalContentsOfItems(e).then(e=>{const t=e.filter(e=>-1!==[5,6,4].indexOf(e.type));r.push(this._handleContentWithAssets(Promise.resolve(t),["content"]))},e=>this._softReject(t,'getAdditionalContentsOfItems error: "'+e+'"')),Promise.all(r).then(t,e=>this._softReject(t,'AdditionalContent image sync error:"'+e+'"'))})})}_handleMaterialsAndTextures(e){return new Promise(t=>{this._rapiAccess.getMaterialsOf(e).then(e=>{const r=[];r.push(this._handleContentWithAssets(Promise.resolve(e),["thumbnail"])),e.forEach(e=>{r.push(this._handleContentWithAssets(this._rapiAccess.getTexturesOf(e),["image"]))}),Promise.all(r).then(t,e=>this._softReject(t,'getTexturesOf error: "'+e+'"'))},e=>this._softReject(t,'getMaterialsOf error: "'+e+'"'))})}_handleContentWithAssets(e,t){return new Promise(r=>e.then(e=>this._fetchAssets(e,t).then(r,e=>this._softReject(r,'_handleContentWithAssets error: "'+e+'"')),e=>this._softReject(r,'_handleContentWithAssets promise error: "'+e+'"')))}_fetchAssets(e,t){const r=[];e||(e=[]);for(let n=0,a=e.length;n<a;n++){const a=e[n];t.forEach(e=>{const t=a[e];t&&r.push(this._preCacheAsset(t))})}return Promise.all(r)}_preCacheAsset(e){return new Promise(t=>{if(wr.get(e))return t();this._assetUrlToBase64(e).then(r=>{wr.set(e,r),t()},e=>this._softReject(t,'_preCacheAsset error: "'+e+'"'))})}_assetUrlToBase64(e){return new Promise(t=>{this._mainThreadToWorker.sendToWorker(5,e,t,e=>this._softReject(t,'_assetUrlToBase64 error: "'+e+'"'))})}_softReject(e,t){this._errorHandler.softReject(e,t,2)}requestAsset(e,t=!1){return navigator.onLine&&!this._alwaysUseCache?e:wr.get(e)||(t?e:null)}setAlwaysUseCache(e){this._alwaysUseCache=e}preFillAssetCache(e,t){wr.set(e,t)}}e("a",xr),pr([fr],xr.prototype,"_rapiAccess",void 0),pr([fr],xr.prototype,"_singlePromiseFactory",void 0),pr([fr],xr.prototype,"_errorHandler",void 0),pr([fr],xr.prototype,"_configuratorUiCallbacks",void 0),pr([fr],xr.prototype,"_initData",void 0);class Sr{constructor(e){this.info=e,this._init()}_init(){this._promise=new Promise((e,t)=>{this._resolve=e,this._reject=t})}resolve(e){e&&this._resolve(e),this._resolve()}reject(e){this._reject(e)}wait(){return this._promise}reset(){this._init()}}function Cr(e){for(var t,r,n,a=-1,i=0,s=0;s<e.length;++s){var o=e[s];if(o.isInterleavedBufferAttribute)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. InterleavedBufferAttributes are not supported."),null;if(void 0===t&&(t=o.array.constructor),t!==o.array.constructor)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.array must be of consistent array types across matching attributes."),null;if(void 0===r&&(r=o.itemSize),r!==o.itemSize)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.itemSize must be consistent across matching attributes."),null;if(void 0===n&&(n=o.normalized),n!==o.normalized)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.normalized must be consistent across matching attributes."),null;if(-1===a&&(a=o.gpuType),a!==o.gpuType)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.gpuType must be consistent across matching attributes."),null;i+=o.array.length}for(var l=new t(i),h=0,d=0;d<e.length;++d)l.set(e[d].array,h),h+=e[d].array.length;var c=new u(l,r,n);return void 0!==a&&(c.gpuType=a),c}function Mr(e,t){if(t===p)return console.warn("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Geometry already defined as triangles."),e;if(t===m||t===f){var r=e.getIndex();if(null===r){var n=[],a=e.getAttribute("position");if(void 0===a)return console.error("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Undefined position attribute. Processing not possible."),e;for(var i=0;i<a.count;i++)n.push(i);e.setIndex(n),r=e.getIndex()}var s=r.count-2,o=[];if(t===m)for(var l=1;l<=s;l++)o.push(r.getX(0)),o.push(r.getX(l)),o.push(r.getX(l+1));else for(var h=0;h<s;h++)h%2==0?(o.push(r.getX(h)),o.push(r.getX(h+1)),o.push(r.getX(h+2))):(o.push(r.getX(h+2)),o.push(r.getX(h+1)),o.push(r.getX(h)));o.length/3!==s&&console.error("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Unable to generate correct amount of triangles.");var d=e.clone();return d.setIndex(o),d.clearGroups(),d}return console.error("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Unknown draw mode:",t),e}e("ac",Sr);var Tr=function(e){g(r,e);var t=v(r);function r(e){var n;return w(this,r),(n=t.call(this,e)).dracoLoader=null,n.ktx2Loader=null,n.meshoptDecoder=null,n.pluginCallbacks=[],n.register((function(e){return new kr(e)})),n.register((function(e){return new zr(e)})),n.register((function(e){return new Hr(e)})),n.register((function(e){return new jr(e)})),n.register((function(e){return new Dr(e)})),n.register((function(e){return new Lr(e)})),n.register((function(e){return new Ur(e)})),n.register((function(e){return new Fr(e)})),n.register((function(e){return new Ir(e)})),n.register((function(e){return new Br(e)})),n.register((function(e){return new Or(e)})),n.register((function(e){return new Nr(e)})),n.register((function(e){return new Rr(e)})),n.register((function(e){return new Vr(e)})),n.register((function(e){return new Gr(e)})),n}return b(r,[{key:"load",value:function(e,t,r,n){var a,i=this;a=""!==this.resourcePath?this.resourcePath:""!==this.path?this.path:y.extractUrlBase(e),this.manager.itemStart(e);var s=function(t){n?n(t):console.error(t),i.manager.itemError(e),i.manager.itemEnd(e)},o=new _(this.manager);o.setPath(this.path),o.setResponseType("arraybuffer"),o.setRequestHeader(this.requestHeader),o.setWithCredentials(this.withCredentials),o.load(e,(function(r){try{i.parse(r,a,(function(r){t(r),i.manager.itemEnd(e)}),s)}catch(e){s(e)}}),r,s)}},{key:"setDRACOLoader",value:function(e){return this.dracoLoader=e,this}},{key:"setDDSLoader",value:function(){throw new Error('THREE.GLTFLoader: "MSFT_texture_dds" no longer supported. Please update to "KHR_texture_basisu".')}},{key:"setKTX2Loader",value:function(e){return this.ktx2Loader=e,this}},{key:"setMeshoptDecoder",value:function(e){return this.meshoptDecoder=e,this}},{key:"register",value:function(e){return-1===this.pluginCallbacks.indexOf(e)&&this.pluginCallbacks.push(e),this}},{key:"unregister",value:function(e){return-1!==this.pluginCallbacks.indexOf(e)&&this.pluginCallbacks.splice(this.pluginCallbacks.indexOf(e),1),this}},{key:"parse",value:function(e,t,r,n){var a,i={},s={},o=new TextDecoder;if("string"==typeof e)a=JSON.parse(e);else if(e instanceof ArrayBuffer)if(o.decode(new Uint8Array(e,0,4))===Kr){try{i[Pr.KHR_BINARY_GLTF]=new Wr(e)}catch(e){return void(n&&n(e))}a=JSON.parse(i[Pr.KHR_BINARY_GLTF].content)}else a=JSON.parse(o.decode(e));else a=e;if(void 0===a.asset||a.asset.version[0]<2)n&&n(new Error("THREE.GLTFLoader: Unsupported asset. glTF versions >=2.0 are supported."));else{var l=new fn(a,{path:t||this.resourcePath||"",crossOrigin:this.crossOrigin,requestHeader:this.requestHeader,manager:this.manager,ktx2Loader:this.ktx2Loader,meshoptDecoder:this.meshoptDecoder});l.fileLoader.setRequestHeader(this.requestHeader);for(var h=0;h<this.pluginCallbacks.length;h++){var d=this.pluginCallbacks[h](l);s[d.name]=d,i[d.name]=!0}if(a.extensionsUsed)for(var c=0;c<a.extensionsUsed.length;++c){var u=a.extensionsUsed[c],p=a.extensionsRequired||[];switch(u){case Pr.KHR_MATERIALS_UNLIT:i[u]=new Er;break;case Pr.KHR_DRACO_MESH_COMPRESSION:i[u]=new Xr(a,this.dracoLoader);break;case Pr.KHR_TEXTURE_TRANSFORM:i[u]=new qr;break;case Pr.KHR_MESH_QUANTIZATION:i[u]=new Qr;break;default:p.indexOf(u)>=0&&void 0===s[u]&&console.warn('THREE.GLTFLoader: Unknown extension "'+u+'".')}}l.setExtensions(i),l.setPlugins(s),l.parse(r,n)}}},{key:"parseAsync",value:function(e,t){var r=this;return new Promise((function(n,a){r.parse(e,t,n,a)}))}}]),r}(x);function Ar(){var e={};return{get:function(t){return e[t]},add:function(t,r){e[t]=r},remove:function(t){delete e[t]},removeAll:function(){e={}}}}var Pr={KHR_BINARY_GLTF:"KHR_binary_glTF",KHR_DRACO_MESH_COMPRESSION:"KHR_draco_mesh_compression",KHR_LIGHTS_PUNCTUAL:"KHR_lights_punctual",KHR_MATERIALS_CLEARCOAT:"KHR_materials_clearcoat",KHR_MATERIALS_IOR:"KHR_materials_ior",KHR_MATERIALS_SHEEN:"KHR_materials_sheen",KHR_MATERIALS_SPECULAR:"KHR_materials_specular",KHR_MATERIALS_TRANSMISSION:"KHR_materials_transmission",KHR_MATERIALS_IRIDESCENCE:"KHR_materials_iridescence",KHR_MATERIALS_ANISOTROPY:"KHR_materials_anisotropy",KHR_MATERIALS_UNLIT:"KHR_materials_unlit",KHR_MATERIALS_VOLUME:"KHR_materials_volume",KHR_TEXTURE_BASISU:"KHR_texture_basisu",KHR_TEXTURE_TRANSFORM:"KHR_texture_transform",KHR_MESH_QUANTIZATION:"KHR_mesh_quantization",KHR_MATERIALS_EMISSIVE_STRENGTH:"KHR_materials_emissive_strength",EXT_TEXTURE_WEBP:"EXT_texture_webp",EXT_TEXTURE_AVIF:"EXT_texture_avif",EXT_MESHOPT_COMPRESSION:"EXT_meshopt_compression",EXT_MESH_GPU_INSTANCING:"EXT_mesh_gpu_instancing"},Rr=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.KHR_LIGHTS_PUNCTUAL,this.cache={refs:{},uses:{}}}return b(e,[{key:"_markDefs",value:function(){for(var e=this.parser,t=this.parser.json.nodes||[],r=0,n=t.length;r<n;r++){var a=t[r];a.extensions&&a.extensions[this.name]&&void 0!==a.extensions[this.name].light&&e._addNodeRef(this.cache,a.extensions[this.name].light)}}},{key:"_loadLight",value:function(e){var t=this.parser,r="light:"+e,n=t.cache.get(r);if(n)return n;var i,s=t.json,o=((s.extensions&&s.extensions[this.name]||{}).lights||[])[e],d=new h(16777215);void 0!==o.color&&d.fromArray(o.color);var c=void 0!==o.range?o.range:0;switch(o.type){case"directional":(i=new a(d)).target.position.set(0,0,-1),i.add(i.target);break;case"point":(i=new S(d)).distance=c;break;case"spot":(i=new l(d)).distance=c,o.spot=o.spot||{},o.spot.innerConeAngle=void 0!==o.spot.innerConeAngle?o.spot.innerConeAngle:0,o.spot.outerConeAngle=void 0!==o.spot.outerConeAngle?o.spot.outerConeAngle:Math.PI/4,i.angle=o.spot.outerConeAngle,i.penumbra=1-o.spot.innerConeAngle/o.spot.outerConeAngle,i.target.position.set(0,0,-1),i.add(i.target);break;default:throw new Error("THREE.GLTFLoader: Unexpected light type: "+o.type)}return i.position.set(0,0,0),i.decay=2,hn(i,o),void 0!==o.intensity&&(i.intensity=o.intensity),i.name=t.createUniqueName(o.name||"light_"+e),n=Promise.resolve(i),t.cache.add(r,n),n}},{key:"getDependency",value:function(e,t){if("light"===e)return this._loadLight(t)}},{key:"createNodeAttachment",value:function(e){var t=this,r=this.parser,n=r.json.nodes[e],a=(n.extensions&&n.extensions[this.name]||{}).light;return void 0===a?null:this._loadLight(a).then((function(e){return r._getNodeRef(t.cache,a,e)}))}}]),e}(),Er=function(){function e(){w(this,e),this.name=Pr.KHR_MATERIALS_UNLIT}return b(e,[{key:"getMaterialType",value:function(){return C}},{key:"extendParams",value:function(e,t,r){var n=[];e.color=new h(1,1,1),e.opacity=1;var a=t.pbrMetallicRoughness;if(a){if(Array.isArray(a.baseColorFactor)){var i=a.baseColorFactor;e.color.fromArray(i),e.opacity=i[3]}void 0!==a.baseColorTexture&&n.push(r.assignTexture(e,"map",a.baseColorTexture,M))}return Promise.all(n)}}]),e}(),Ir=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.KHR_MATERIALS_EMISSIVE_STRENGTH}return b(e,[{key:"extendMaterialParams",value:function(e,t){var r=this.parser.json.materials[e];if(!r.extensions||!r.extensions[this.name])return Promise.resolve();var n=r.extensions[this.name].emissiveStrength;return void 0!==n&&(t.emissiveIntensity=n),Promise.resolve()}}]),e}(),kr=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.KHR_MATERIALS_CLEARCOAT}return b(e,[{key:"getMaterialType",value:function(e){var t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?T:null}},{key:"extendMaterialParams",value:function(e,t){var r=this.parser,n=r.json.materials[e];if(!n.extensions||!n.extensions[this.name])return Promise.resolve();var a=[],s=n.extensions[this.name];if(void 0!==s.clearcoatFactor&&(t.clearcoat=s.clearcoatFactor),void 0!==s.clearcoatTexture&&a.push(r.assignTexture(t,"clearcoatMap",s.clearcoatTexture)),void 0!==s.clearcoatRoughnessFactor&&(t.clearcoatRoughness=s.clearcoatRoughnessFactor),void 0!==s.clearcoatRoughnessTexture&&a.push(r.assignTexture(t,"clearcoatRoughnessMap",s.clearcoatRoughnessTexture)),void 0!==s.clearcoatNormalTexture&&(a.push(r.assignTexture(t,"clearcoatNormalMap",s.clearcoatNormalTexture)),void 0!==s.clearcoatNormalTexture.scale)){var o=s.clearcoatNormalTexture.scale;t.clearcoatNormalScale=new i(o,o)}return Promise.all(a)}}]),e}(),Or=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.KHR_MATERIALS_IRIDESCENCE}return b(e,[{key:"getMaterialType",value:function(e){var t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?T:null}},{key:"extendMaterialParams",value:function(e,t){var r=this.parser,n=r.json.materials[e];if(!n.extensions||!n.extensions[this.name])return Promise.resolve();var a=[],i=n.extensions[this.name];return void 0!==i.iridescenceFactor&&(t.iridescence=i.iridescenceFactor),void 0!==i.iridescenceTexture&&a.push(r.assignTexture(t,"iridescenceMap",i.iridescenceTexture)),void 0!==i.iridescenceIor&&(t.iridescenceIOR=i.iridescenceIor),void 0===t.iridescenceThicknessRange&&(t.iridescenceThicknessRange=[100,400]),void 0!==i.iridescenceThicknessMinimum&&(t.iridescenceThicknessRange[0]=i.iridescenceThicknessMinimum),void 0!==i.iridescenceThicknessMaximum&&(t.iridescenceThicknessRange[1]=i.iridescenceThicknessMaximum),void 0!==i.iridescenceThicknessTexture&&a.push(r.assignTexture(t,"iridescenceThicknessMap",i.iridescenceThicknessTexture)),Promise.all(a)}}]),e}(),Dr=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.KHR_MATERIALS_SHEEN}return b(e,[{key:"getMaterialType",value:function(e){var t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?T:null}},{key:"extendMaterialParams",value:function(e,t){var r=this.parser,n=r.json.materials[e];if(!n.extensions||!n.extensions[this.name])return Promise.resolve();var a=[];t.sheenColor=new h(0,0,0),t.sheenRoughness=0,t.sheen=1;var i=n.extensions[this.name];return void 0!==i.sheenColorFactor&&t.sheenColor.fromArray(i.sheenColorFactor),void 0!==i.sheenRoughnessFactor&&(t.sheenRoughness=i.sheenRoughnessFactor),void 0!==i.sheenColorTexture&&a.push(r.assignTexture(t,"sheenColorMap",i.sheenColorTexture,M)),void 0!==i.sheenRoughnessTexture&&a.push(r.assignTexture(t,"sheenRoughnessMap",i.sheenRoughnessTexture)),Promise.all(a)}}]),e}(),Lr=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.KHR_MATERIALS_TRANSMISSION}return b(e,[{key:"getMaterialType",value:function(e){var t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?T:null}},{key:"extendMaterialParams",value:function(e,t){var r=this.parser,n=r.json.materials[e];if(!n.extensions||!n.extensions[this.name])return Promise.resolve();var a=[],i=n.extensions[this.name];return void 0!==i.transmissionFactor&&(t.transmission=i.transmissionFactor),void 0!==i.transmissionTexture&&a.push(r.assignTexture(t,"transmissionMap",i.transmissionTexture)),Promise.all(a)}}]),e}(),Ur=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.KHR_MATERIALS_VOLUME}return b(e,[{key:"getMaterialType",value:function(e){var t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?T:null}},{key:"extendMaterialParams",value:function(e,t){var r=this.parser,n=r.json.materials[e];if(!n.extensions||!n.extensions[this.name])return Promise.resolve();var a=[],i=n.extensions[this.name];t.thickness=void 0!==i.thicknessFactor?i.thicknessFactor:0,void 0!==i.thicknessTexture&&a.push(r.assignTexture(t,"thicknessMap",i.thicknessTexture)),t.attenuationDistance=i.attenuationDistance||1/0;var s=i.attenuationColor||[1,1,1];return t.attenuationColor=new h(s[0],s[1],s[2]),Promise.all(a)}}]),e}(),Fr=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.KHR_MATERIALS_IOR}return b(e,[{key:"getMaterialType",value:function(e){var t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?T:null}},{key:"extendMaterialParams",value:function(e,t){var r=this.parser.json.materials[e];if(!r.extensions||!r.extensions[this.name])return Promise.resolve();var n=r.extensions[this.name];return t.ior=void 0!==n.ior?n.ior:1.5,Promise.resolve()}}]),e}(),Br=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.KHR_MATERIALS_SPECULAR}return b(e,[{key:"getMaterialType",value:function(e){var t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?T:null}},{key:"extendMaterialParams",value:function(e,t){var r=this.parser,n=r.json.materials[e];if(!n.extensions||!n.extensions[this.name])return Promise.resolve();var a=[],i=n.extensions[this.name];t.specularIntensity=void 0!==i.specularFactor?i.specularFactor:1,void 0!==i.specularTexture&&a.push(r.assignTexture(t,"specularIntensityMap",i.specularTexture));var s=i.specularColorFactor||[1,1,1];return t.specularColor=new h(s[0],s[1],s[2]),void 0!==i.specularColorTexture&&a.push(r.assignTexture(t,"specularColorMap",i.specularColorTexture,M)),Promise.all(a)}}]),e}(),Nr=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.KHR_MATERIALS_ANISOTROPY}return b(e,[{key:"getMaterialType",value:function(e){var t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?T:null}},{key:"extendMaterialParams",value:function(e,t){var r=this.parser,n=r.json.materials[e];if(!n.extensions||!n.extensions[this.name])return Promise.resolve();var a=[],i=n.extensions[this.name];return void 0!==i.anisotropyStrength&&(t.anisotropy=i.anisotropyStrength),void 0!==i.anisotropyRotation&&(t.anisotropyRotation=i.anisotropyRotation),void 0!==i.anisotropyTexture&&a.push(r.assignTexture(t,"anisotropyMap",i.anisotropyTexture)),Promise.all(a)}}]),e}(),zr=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.KHR_TEXTURE_BASISU}return b(e,[{key:"loadTexture",value:function(e){var t=this.parser,r=t.json,n=r.textures[e];if(!n.extensions||!n.extensions[this.name])return null;var a=n.extensions[this.name],i=t.options.ktx2Loader;if(!i){if(r.extensionsRequired&&r.extensionsRequired.indexOf(this.name)>=0)throw new Error("THREE.GLTFLoader: setKTX2Loader must be called before loading KTX2 textures");return null}return t.loadTextureImage(e,a.source,i)}}]),e}(),Hr=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.EXT_TEXTURE_WEBP,this.isSupported=null}return b(e,[{key:"loadTexture",value:function(e){var t=this.name,r=this.parser,n=r.json,a=n.textures[e];if(!a.extensions||!a.extensions[t])return null;var i=a.extensions[t],s=n.images[i.source],o=r.textureLoader;if(s.uri){var l=r.options.manager.getHandler(s.uri);null!==l&&(o=l)}return this.detectSupport().then((function(a){if(a)return r.loadTextureImage(e,i.source,o);if(n.extensionsRequired&&n.extensionsRequired.indexOf(t)>=0)throw new Error("THREE.GLTFLoader: WebP required by asset but unsupported.");return r.loadTexture(e)}))}},{key:"detectSupport",value:function(){return this.isSupported||(this.isSupported=new Promise((function(e){var t=new Image;t.src="data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA",t.onload=t.onerror=function(){e(1===t.height)}}))),this.isSupported}}]),e}(),jr=function(){function e(t){w(this,e),this.parser=t,this.name=Pr.EXT_TEXTURE_AVIF,this.isSupported=null}return b(e,[{key:"loadTexture",value:function(e){var t=this.name,r=this.parser,n=r.json,a=n.textures[e];if(!a.extensions||!a.extensions[t])return null;var i=a.extensions[t],s=n.images[i.source],o=r.textureLoader;if(s.uri){var l=r.options.manager.getHandler(s.uri);null!==l&&(o=l)}return this.detectSupport().then((function(a){if(a)return r.loadTextureImage(e,i.source,o);if(n.extensionsRequired&&n.extensionsRequired.indexOf(t)>=0)throw new Error("THREE.GLTFLoader: AVIF required by asset but unsupported.");return r.loadTexture(e)}))}},{key:"detectSupport",value:function(){return this.isSupported||(this.isSupported=new Promise((function(e){var t=new Image;t.src="data:image/avif;base64,AAAAIGZ0eXBhdmlmAAAAAGF2aWZtaWYxbWlhZk1BMUIAAADybWV0YQAAAAAAAAAoaGRscgAAAAAAAAAAcGljdAAAAAAAAAAAAAAAAGxpYmF2aWYAAAAADnBpdG0AAAAAAAEAAAAeaWxvYwAAAABEAAABAAEAAAABAAABGgAAABcAAAAoaWluZgAAAAAAAQAAABppbmZlAgAAAAABAABhdjAxQ29sb3IAAAAAamlwcnAAAABLaXBjbwAAABRpc3BlAAAAAAAAAAEAAAABAAAAEHBpeGkAAAAAAwgICAAAAAxhdjFDgQAMAAAAABNjb2xybmNseAACAAIABoAAAAAXaXBtYQAAAAAAAAABAAEEAQKDBAAAAB9tZGF0EgAKCBgABogQEDQgMgkQAAAAB8dSLfI=",t.onload=t.onerror=function(){e(1===t.height)}}))),this.isSupported}}]),e}(),Vr=function(){function e(t){w(this,e),this.name=Pr.EXT_MESHOPT_COMPRESSION,this.parser=t}return b(e,[{key:"loadBufferView",value:function(e){var t=this.parser.json,r=t.bufferViews[e];if(r.extensions&&r.extensions[this.name]){var n=r.extensions[this.name],a=this.parser.getDependency("buffer",n.buffer),i=this.parser.options.meshoptDecoder;if(!i||!i.supported){if(t.extensionsRequired&&t.extensionsRequired.indexOf(this.name)>=0)throw new Error("THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files");return null}return a.then((function(e){var t=n.byteOffset||0,r=n.byteLength||0,a=n.count,s=n.byteStride,o=new Uint8Array(e,t,r);return i.decodeGltfBufferAsync?i.decodeGltfBufferAsync(a,s,o,n.mode,n.filter).then((function(e){return e.buffer})):i.ready.then((function(){var e=new ArrayBuffer(a*s);return i.decodeGltfBuffer(new Uint8Array(e),a,s,o,n.mode,n.filter),e}))}))}return null}}]),e}(),Gr=function(){function e(t){w(this,e),this.name=Pr.EXT_MESH_GPU_INSTANCING,this.parser=t}return b(e,[{key:"createNodeMesh",value:function(e){var t=this,r=this.parser.json,n=r.nodes[e];if(!n.extensions||!n.extensions[this.name]||void 0===n.mesh)return null;var a,i=r.meshes[n.mesh],o=A(i.primitives);try{for(o.s();!(a=o.n()).done;){var l=a.value;if(l.mode!==$r.TRIANGLES&&l.mode!==$r.TRIANGLE_STRIP&&l.mode!==$r.TRIANGLE_FAN&&void 0!==l.mode)return null}}catch(e){o.e(e)}finally{o.f()}var h=n.extensions[this.name].attributes,d=[],c={},u=function(e){d.push(t.parser.getDependency("accessor",h[e]).then((function(t){return c[e]=t,c[e]})))};for(var p in h)u(p);return d.length<1?null:(d.push(this.parser.createNodeMesh(e)),Promise.all(d).then((function(e){var r,n=e.pop(),a=n.isGroup?n.children:[n],i=e[0].count,o=[],l=A(a);try{for(l.s();!(r=l.n()).done;){for(var h=r.value,d=new P,u=new s,p=new R,m=new s(1,1,1),f=new E(h.geometry,h.material,i),g=0;g<i;g++)c.TRANSLATION&&u.fromBufferAttribute(c.TRANSLATION,g),c.ROTATION&&p.fromBufferAttribute(c.ROTATION,g),c.SCALE&&m.fromBufferAttribute(c.SCALE,g),f.setMatrixAt(g,d.compose(u,p,m));for(var v in c)"TRANSLATION"!==v&&"ROTATION"!==v&&"SCALE"!==v&&h.geometry.setAttribute(v,c[v]);I.prototype.copy.call(f,h),t.parser.assignFinalMaterial(f),o.push(f)}}catch(e){l.e(e)}finally{l.f()}return n.isGroup?(n.clear(),n.add.apply(n,o),n):o[0]})))}}]),e}(),Kr="glTF",Wr=b((function e(t){w(this,e),this.name=Pr.KHR_BINARY_GLTF,this.content=null,this.body=null;var r=new DataView(t,0,12),n=new TextDecoder;if(this.header={magic:n.decode(new Uint8Array(t.slice(0,4))),version:r.getUint32(4,!0),length:r.getUint32(8,!0)},this.header.magic!==Kr)throw new Error("THREE.GLTFLoader: Unsupported glTF-Binary header.");if(this.header.version<2)throw new Error("THREE.GLTFLoader: Legacy binary file detected.");for(var a=this.header.length-12,i=new DataView(t,12),s=0;s<a;){var o=i.getUint32(s,!0);s+=4;var l=i.getUint32(s,!0);if(s+=4,1313821514===l){var h=new Uint8Array(t,12+s,o);this.content=n.decode(h)}else if(5130562===l){var d=12+s;this.body=t.slice(d,d+o)}s+=o}if(null===this.content)throw new Error("THREE.GLTFLoader: JSON content not found.")})),Xr=function(){function e(t,r){if(w(this,e),!r)throw new Error("THREE.GLTFLoader: No DRACOLoader instance provided.");this.name=Pr.KHR_DRACO_MESH_COMPRESSION,this.json=t,this.dracoLoader=r,this.dracoLoader.preload()}return b(e,[{key:"decodePrimitive",value:function(e,t){var r=this.json,n=this.dracoLoader,a=e.extensions[this.name].bufferView,i=e.extensions[this.name].attributes,s={},o={},l={};for(var h in i){var d=an[h]||h.toLowerCase();s[d]=i[h]}for(var c in e.attributes){var u=an[c]||c.toLowerCase();if(void 0!==i[c]){var p=r.accessors[e.attributes[c]],m=en[p.componentType];l[u]=m.name,o[u]=!0===p.normalized}}return t.getDependency("bufferView",a).then((function(e){return new Promise((function(t){n.decodeDracoFile(e,(function(e){for(var r in e.attributes){var n=e.attributes[r],a=o[r];void 0!==a&&(n.normalized=a)}t(e)}),s,l)}))}))}}]),e}(),qr=function(){function e(){w(this,e),this.name=Pr.KHR_TEXTURE_TRANSFORM}return b(e,[{key:"extendTexture",value:function(e,t){return void 0!==t.texCoord&&t.texCoord!==e.channel||void 0!==t.offset||void 0!==t.rotation||void 0!==t.scale?(e=e.clone(),void 0!==t.texCoord&&(e.channel=t.texCoord),void 0!==t.offset&&e.offset.fromArray(t.offset),void 0!==t.rotation&&(e.rotation=t.rotation),void 0!==t.scale&&e.repeat.fromArray(t.scale),e.needsUpdate=!0,e):e}}]),e}(),Qr=b((function e(){w(this,e),this.name=Pr.KHR_MESH_QUANTIZATION})),Yr=function(e){g(r,e);var t=v(r);function r(e,n,a,i){return w(this,r),t.call(this,e,n,a,i)}return b(r,[{key:"copySampleValue_",value:function(e){for(var t=this.resultBuffer,r=this.sampleValues,n=this.valueSize,a=e*n*3+n,i=0;i!==n;i++)t[i]=r[a+i];return t}},{key:"interpolate_",value:function(e,t,r,n){for(var a=this.resultBuffer,i=this.sampleValues,s=this.valueSize,o=2*s,l=3*s,h=n-t,d=(r-t)/h,c=d*d,u=c*d,p=e*l,m=p-l,f=-2*u+3*c,g=u-c,v=1-f,w=g-c+d,b=0;b!==s;b++){var y=i[m+b+s],_=i[m+b+o]*h,x=i[p+b+s],S=i[p+b]*h;a[b]=v*y+w*_+f*x+g*S}return a}}]),r}(_e),Zr=new R,Jr=function(e){g(r,e);var t=v(r);function r(){return w(this,r),t.apply(this,arguments)}return b(r,[{key:"interpolate_",value:function(e,t,n,a){var i=xe(Se(r.prototype),"interpolate_",this).call(this,e,t,n,a);return Zr.fromArray(i).normalize().toArray(i),i}}]),r}(Yr),$r={FLOAT:5126,FLOAT_MAT3:35675,FLOAT_MAT4:35676,FLOAT_VEC2:35664,FLOAT_VEC3:35665,FLOAT_VEC4:35666,LINEAR:9729,REPEAT:10497,SAMPLER_2D:35678,POINTS:0,LINES:1,LINE_LOOP:2,LINE_STRIP:3,TRIANGLES:4,TRIANGLE_STRIP:5,TRIANGLE_FAN:6,UNSIGNED_BYTE:5121,UNSIGNED_SHORT:5123},en={5120:Int8Array,5121:Uint8Array,5122:Int16Array,5123:Uint16Array,5125:Uint32Array,5126:Float32Array},tn={9728:ae,9729:L,9984:ie,9985:se,9986:oe,9987:U},rn={33071:le,33648:he,10497:F},nn={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16},an={POSITION:"position",NORMAL:"normal",TANGENT:"tangent",TEXCOORD_0:"uv",TEXCOORD_1:"uv1",TEXCOORD_2:"uv2",TEXCOORD_3:"uv3",COLOR_0:"color",WEIGHTS_0:"skinWeight",JOINTS_0:"skinIndex"},sn={scale:"scale",translation:"position",rotation:"quaternion",weights:"morphTargetInfluences"},on={CUBICSPLINE:void 0,LINEAR:ne,STEP:de};function ln(e,t,r){for(var n in r.extensions)void 0===e[n]&&(t.userData.gltfExtensions=t.userData.gltfExtensions||{},t.userData.gltfExtensions[n]=r.extensions[n])}function hn(e,t){void 0!==t.extras&&("object"===k(t.extras)?Object.assign(e.userData,t.extras):console.warn("THREE.GLTFLoader: Ignoring primitive type .extras, "+t.extras))}function dn(e,t){if(e.updateMorphTargets(),void 0!==t.weights)for(var r=0,n=t.weights.length;r<n;r++)e.morphTargetInfluences[r]=t.weights[r];if(t.extras&&Array.isArray(t.extras.targetNames)){var a=t.extras.targetNames;if(e.morphTargetInfluences.length===a.length){e.morphTargetDictionary={};for(var i=0,s=a.length;i<s;i++)e.morphTargetDictionary[a[i]]=i}else console.warn("THREE.GLTFLoader: Invalid extras.targetNames length. Ignoring names.")}}function cn(e){var t,r=e.extensions&&e.extensions[Pr.KHR_DRACO_MESH_COMPRESSION];if(t=r?"draco:"+r.bufferView+":"+r.indices+":"+un(r.attributes):e.indices+":"+un(e.attributes)+":"+e.mode,void 0!==e.targets)for(var n=0,a=e.targets.length;n<a;n++)t+=":"+un(e.targets[n]);return t}function un(e){for(var t="",r=Object.keys(e).sort(),n=0,a=r.length;n<a;n++)t+=r[n]+":"+e[r[n]]+";";return t}function pn(e){switch(e){case Int8Array:return 1/127;case Uint8Array:return 1/255;case Int16Array:return 1/32767;case Uint16Array:return 1/65535;default:throw new Error("THREE.GLTFLoader: Unsupported normalized accessor component type.")}}var mn=new P,fn=function(){function e(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};w(this,e),this.json=t,this.extensions={},this.plugins={},this.options=r,this.cache=new Ar,this.associations=new Map,this.primitiveCache={},this.nodeCache={},this.meshCache={refs:{},uses:{}},this.cameraCache={refs:{},uses:{}},this.lightCache={refs:{},uses:{}},this.sourceCache={},this.textureCache={},this.nodeNamesUsed={};var n=!1,a=!1,i=-1;"undefined"!=typeof navigator&&(n=!0===/^((?!chrome|android).)*safari/i.test(navigator.userAgent),i=(a=navigator.userAgent.indexOf("Firefox")>-1)?navigator.userAgent.match(/Firefox\/([0-9]+)\./)[1]:-1),"undefined"==typeof createImageBitmap||n||a&&i<98?this.textureLoader=new ue(this.options.manager):this.textureLoader=new pe(this.options.manager),this.textureLoader.setCrossOrigin(this.options.crossOrigin),this.textureLoader.setRequestHeader(this.options.requestHeader),this.fileLoader=new _(this.options.manager),this.fileLoader.setResponseType("arraybuffer"),"use-credentials"===this.options.crossOrigin&&this.fileLoader.setWithCredentials(!0)}return b(e,[{key:"setExtensions",value:function(e){this.extensions=e}},{key:"setPlugins",value:function(e){this.plugins=e}},{key:"parse",value:function(e,t){var r=this,n=this.json,a=this.extensions;this.cache.removeAll(),this.nodeCache={},this._invokeAll((function(e){return e._markDefs&&e._markDefs()})),Promise.all(this._invokeAll((function(e){return e.beforeRoot&&e.beforeRoot()}))).then((function(){return Promise.all([r.getDependencies("scene"),r.getDependencies("animation"),r.getDependencies("camera")])})).then((function(t){var i={scene:t[0][n.scene||0],scenes:t[0],animations:t[1],cameras:t[2],asset:n.asset,parser:r,userData:{}};ln(a,i,n),hn(i,n),Promise.all(r._invokeAll((function(e){return e.afterRoot&&e.afterRoot(i)}))).then((function(){e(i)}))})).catch(t)}},{key:"_markDefs",value:function(){for(var e=this.json.nodes||[],t=this.json.skins||[],r=this.json.meshes||[],n=0,a=t.length;n<a;n++)for(var i=t[n].joints,s=0,o=i.length;s<o;s++)e[i[s]].isBone=!0;for(var l=0,h=e.length;l<h;l++){var d=e[l];void 0!==d.mesh&&(this._addNodeRef(this.meshCache,d.mesh),void 0!==d.skin&&(r[d.mesh].isSkinnedMesh=!0)),void 0!==d.camera&&this._addNodeRef(this.cameraCache,d.camera)}}},{key:"_addNodeRef",value:function(e,t){void 0!==t&&(void 0===e.refs[t]&&(e.refs[t]=e.uses[t]=0),e.refs[t]++)}},{key:"_getNodeRef",value:function(e,t,r){var n=this;if(e.refs[t]<=1)return r;var a=r.clone();return function e(t,r){var a=n.associations.get(t);null!=a&&n.associations.set(r,a);var i,s=A(t.children.entries());try{for(s.s();!(i=s.n()).done;){var o=me(i.value,2),l=o[0];e(o[1],r.children[l])}}catch(e){s.e(e)}finally{s.f()}}(r,a),a.name+="_instance_"+e.uses[t]++,a}},{key:"_invokeOne",value:function(e){var t=Object.values(this.plugins);t.push(this);for(var r=0;r<t.length;r++){var n=e(t[r]);if(n)return n}return null}},{key:"_invokeAll",value:function(e){var t=Object.values(this.plugins);t.unshift(this);for(var r=[],n=0;n<t.length;n++){var a=e(t[n]);a&&r.push(a)}return r}},{key:"getDependency",value:function(e,t){var r=e+":"+t,n=this.cache.get(r);if(!n){switch(e){case"scene":n=this.loadScene(t);break;case"node":n=this._invokeOne((function(e){return e.loadNode&&e.loadNode(t)}));break;case"mesh":n=this._invokeOne((function(e){return e.loadMesh&&e.loadMesh(t)}));break;case"accessor":n=this.loadAccessor(t);break;case"bufferView":n=this._invokeOne((function(e){return e.loadBufferView&&e.loadBufferView(t)}));break;case"buffer":n=this.loadBuffer(t);break;case"material":n=this._invokeOne((function(e){return e.loadMaterial&&e.loadMaterial(t)}));break;case"texture":n=this._invokeOne((function(e){return e.loadTexture&&e.loadTexture(t)}));break;case"skin":n=this.loadSkin(t);break;case"animation":n=this._invokeOne((function(e){return e.loadAnimation&&e.loadAnimation(t)}));break;case"camera":n=this.loadCamera(t);break;default:if(!(n=this._invokeOne((function(r){return r!=this&&r.getDependency&&r.getDependency(e,t)}))))throw new Error("Unknown type: "+e)}this.cache.add(r,n)}return n}},{key:"getDependencies",value:function(e){var t=this.cache.get(e);if(!t){var r=this,n=this.json[e+("mesh"===e?"es":"s")]||[];t=Promise.all(n.map((function(t,n){return r.getDependency(e,n)}))),this.cache.add(e,t)}return t}},{key:"loadBuffer",value:function(e){var t=this.json.buffers[e],r=this.fileLoader;if(t.type&&"arraybuffer"!==t.type)throw new Error("THREE.GLTFLoader: "+t.type+" buffer type is not supported.");if(void 0===t.uri&&0===e)return Promise.resolve(this.extensions[Pr.KHR_BINARY_GLTF].body);var n=this.options;return new Promise((function(e,a){r.load(y.resolveURL(t.uri,n.path),e,void 0,(function(){a(new Error('THREE.GLTFLoader: Failed to load buffer "'+t.uri+'".'))}))}))}},{key:"loadBufferView",value:function(e){var t=this.json.bufferViews[e];return this.getDependency("buffer",t.buffer).then((function(e){var r=t.byteLength||0,n=t.byteOffset||0;return e.slice(n,n+r)}))}},{key:"loadAccessor",value:function(e){var t=this,r=this.json,n=this.json.accessors[e];if(void 0===n.bufferView&&void 0===n.sparse){var a=nn[n.type],i=en[n.componentType],s=!0===n.normalized,o=new i(n.count*a);return Promise.resolve(new u(o,a,s))}var l=[];return void 0!==n.bufferView?l.push(this.getDependency("bufferView",n.bufferView)):l.push(null),void 0!==n.sparse&&(l.push(this.getDependency("bufferView",n.sparse.indices.bufferView)),l.push(this.getDependency("bufferView",n.sparse.values.bufferView))),Promise.all(l).then((function(e){var a,i,s=e[0],o=nn[n.type],l=en[n.componentType],h=l.BYTES_PER_ELEMENT,d=h*o,c=n.byteOffset||0,p=void 0!==n.bufferView?r.bufferViews[n.bufferView].byteStride:void 0,m=!0===n.normalized;if(p&&p!==d){var f=Math.floor(c/p),g="InterleavedBuffer:"+n.bufferView+":"+n.componentType+":"+f+":"+n.count,v=t.cache.get(g);v||(a=new l(s,f*p,n.count*p/h),v=new O(a,p/h),t.cache.add(g,v)),i=new D(v,o,c%p/h,m)}else a=null===s?new l(n.count*o):new l(s,c,n.count*o),i=new u(a,o,m);if(void 0!==n.sparse){var w=nn.SCALAR,b=en[n.sparse.indices.componentType],y=n.sparse.indices.byteOffset||0,_=n.sparse.values.byteOffset||0,x=new b(e[1],y,n.sparse.count*w),S=new l(e[2],_,n.sparse.count*o);null!==s&&(i=new u(i.array.slice(),i.itemSize,i.normalized));for(var C=0,M=x.length;C<M;C++){var T=x[C];if(i.setX(T,S[C*o]),o>=2&&i.setY(T,S[C*o+1]),o>=3&&i.setZ(T,S[C*o+2]),o>=4&&i.setW(T,S[C*o+3]),o>=5)throw new Error("THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.")}}return i}))}},{key:"loadTexture",value:function(e){var t=this.json,r=this.options,n=t.textures[e].source,a=t.images[n],i=this.textureLoader;if(a.uri){var s=r.manager.getHandler(a.uri);null!==s&&(i=s)}return this.loadTextureImage(e,n,i)}},{key:"loadTextureImage",value:function(e,t,r){var n=this,a=this.json,i=a.textures[e],s=a.images[t],o=(s.uri||s.bufferView)+":"+i.sampler;if(this.textureCache[o])return this.textureCache[o];var l=this.loadImageSource(t,r).then((function(t){t.flipY=!1,t.name=i.name||s.name||"",""===t.name&&"string"==typeof s.uri&&!1===s.uri.startsWith("data:image/")&&(t.name=s.uri);var r=(a.samplers||{})[i.sampler]||{};return t.magFilter=tn[r.magFilter]||L,t.minFilter=tn[r.minFilter]||U,t.wrapS=rn[r.wrapS]||F,t.wrapT=rn[r.wrapT]||F,n.associations.set(t,{textures:e}),t})).catch((function(){return null}));return this.textureCache[o]=l,l}},{key:"loadImageSource",value:function(e,t){var r=this.json,n=this.options;if(void 0!==this.sourceCache[e])return this.sourceCache[e].then((function(e){return e.clone()}));var a=r.images[e],i=self.URL||self.webkitURL,s=a.uri||"",o=!1;if(void 0!==a.bufferView)s=this.getDependency("bufferView",a.bufferView).then((function(e){o=!0;var t=new Blob([e],{type:a.mimeType});return s=i.createObjectURL(t)}));else if(void 0===a.uri)throw new Error("THREE.GLTFLoader: Image "+e+" is missing URI and bufferView");var l=Promise.resolve(s).then((function(e){return new Promise((function(r,a){var i=r;!0===t.isImageBitmapLoader&&(i=function(e){var t=new fe(e);t.needsUpdate=!0,r(t)}),t.load(y.resolveURL(e,n.path),i,void 0,a)}))})).then((function(e){var t;return!0===o&&i.revokeObjectURL(s),e.userData.mimeType=a.mimeType||((t=a.uri).search(/\.jpe?g($|\?)/i)>0||0===t.search(/^data\:image\/jpeg/)?"image/jpeg":t.search(/\.webp($|\?)/i)>0||0===t.search(/^data\:image\/webp/)?"image/webp":"image/png"),e})).catch((function(e){throw console.error("THREE.GLTFLoader: Couldn't load texture",s),e}));return this.sourceCache[e]=l,l}},{key:"assignTexture",value:function(e,t,r,n){var a=this;return this.getDependency("texture",r.index).then((function(i){if(!i)return null;if(void 0!==r.texCoord&&r.texCoord>0&&((i=i.clone()).channel=r.texCoord),a.extensions[Pr.KHR_TEXTURE_TRANSFORM]){var s=void 0!==r.extensions?r.extensions[Pr.KHR_TEXTURE_TRANSFORM]:void 0;if(s){var o=a.associations.get(i);i=a.extensions[Pr.KHR_TEXTURE_TRANSFORM].extendTexture(i,s),a.associations.set(i,o)}}return void 0!==n&&(i.colorSpace=n),e[t]=i,i}))}},{key:"assignFinalMaterial",value:function(e){var t=e.geometry,r=e.material,n=void 0===t.attributes.tangent,a=void 0!==t.attributes.color,i=void 0===t.attributes.normal;if(e.isPoints){var s="PointsMaterial:"+r.uuid,o=this.cache.get(s);o||(o=new B,N.prototype.copy.call(o,r),o.color.copy(r.color),o.map=r.map,o.sizeAttenuation=!1,this.cache.add(s,o)),r=o}else if(e.isLine){var l="LineBasicMaterial:"+r.uuid,h=this.cache.get(l);h||(h=new z,N.prototype.copy.call(h,r),h.color.copy(r.color),h.map=r.map,this.cache.add(l,h)),r=h}if(n||a||i){var d="ClonedMaterial:"+r.uuid+":";n&&(d+="derivative-tangents:"),a&&(d+="vertex-colors:"),i&&(d+="flat-shading:");var c=this.cache.get(d);c||(c=r.clone(),a&&(c.vertexColors=!0),i&&(c.flatShading=!0),n&&(c.normalScale&&(c.normalScale.y*=-1),c.clearcoatNormalScale&&(c.clearcoatNormalScale.y*=-1)),this.cache.add(d,c),this.associations.set(c,this.associations.get(r))),r=c}e.material=r}},{key:"getMaterialType",value:function(){return H}},{key:"loadMaterial",value:function(e){var t,r=this,n=this.json,a=this.extensions,s=n.materials[e],o={},l=[];if((s.extensions||{})[Pr.KHR_MATERIALS_UNLIT]){var d=a[Pr.KHR_MATERIALS_UNLIT];t=d.getMaterialType(),l.push(d.extendParams(o,s,r))}else{var c=s.pbrMetallicRoughness||{};if(o.color=new h(1,1,1),o.opacity=1,Array.isArray(c.baseColorFactor)){var u=c.baseColorFactor;o.color.fromArray(u),o.opacity=u[3]}void 0!==c.baseColorTexture&&l.push(r.assignTexture(o,"map",c.baseColorTexture,M)),o.metalness=void 0!==c.metallicFactor?c.metallicFactor:1,o.roughness=void 0!==c.roughnessFactor?c.roughnessFactor:1,void 0!==c.metallicRoughnessTexture&&(l.push(r.assignTexture(o,"metalnessMap",c.metallicRoughnessTexture)),l.push(r.assignTexture(o,"roughnessMap",c.metallicRoughnessTexture))),t=this._invokeOne((function(t){return t.getMaterialType&&t.getMaterialType(e)})),l.push(Promise.all(this._invokeAll((function(t){return t.extendMaterialParams&&t.extendMaterialParams(e,o)}))))}!0===s.doubleSided&&(o.side=j);var p=s.alphaMode||"OPAQUE";if("BLEND"===p?(o.transparent=!0,o.depthWrite=!1):(o.transparent=!1,"MASK"===p&&(o.alphaTest=void 0!==s.alphaCutoff?s.alphaCutoff:.5)),void 0!==s.normalTexture&&t!==C&&(l.push(r.assignTexture(o,"normalMap",s.normalTexture)),o.normalScale=new i(1,1),void 0!==s.normalTexture.scale)){var m=s.normalTexture.scale;o.normalScale.set(m,m)}return void 0!==s.occlusionTexture&&t!==C&&(l.push(r.assignTexture(o,"aoMap",s.occlusionTexture)),void 0!==s.occlusionTexture.strength&&(o.aoMapIntensity=s.occlusionTexture.strength)),void 0!==s.emissiveFactor&&t!==C&&(o.emissive=(new h).fromArray(s.emissiveFactor)),void 0!==s.emissiveTexture&&t!==C&&l.push(r.assignTexture(o,"emissiveMap",s.emissiveTexture,M)),Promise.all(l).then((function(){var n=new t(o);return s.name&&(n.name=s.name),hn(n,s),r.associations.set(n,{materials:e}),s.extensions&&ln(a,n,s),n}))}},{key:"createUniqueName",value:function(e){var t=V.sanitizeNodeName(e||"");return t in this.nodeNamesUsed?t+"_"+ ++this.nodeNamesUsed[t]:(this.nodeNamesUsed[t]=0,t)}},{key:"loadGeometries",value:function(e){var t=this,r=this.extensions,n=this.primitiveCache;function a(e){return r[Pr.KHR_DRACO_MESH_COMPRESSION].decodePrimitive(e,t).then((function(r){return gn(r,e,t)}))}for(var i=[],s=0,o=e.length;s<o;s++){var l,h=e[s],d=cn(h),u=n[d];u?i.push(u.promise):(l=h.extensions&&h.extensions[Pr.KHR_DRACO_MESH_COMPRESSION]?a(h):gn(new c,h,t),n[d]={primitive:h,promise:l},i.push(l))}return Promise.all(i)}},{key:"loadMesh",value:function(e){for(var t,r=this,n=this.json,a=this.extensions,i=n.meshes[e],s=i.primitives,o=[],l=0,h=s.length;l<h;l++){var d=void 0===s[l].material?(void 0===(t=this.cache).DefaultMaterial&&(t.DefaultMaterial=new H({color:16777215,emissive:0,metalness:1,roughness:1,transparent:!1,depthTest:!0,side:ce})),t.DefaultMaterial):this.getDependency("material",s[l].material);o.push(d)}return o.push(r.loadGeometries(s)),Promise.all(o).then((function(t){for(var n=t.slice(0,t.length-1),o=t[t.length-1],l=[],h=0,d=o.length;h<d;h++){var c=o[h],u=s[h],p=void 0,g=n[h];if(u.mode===$r.TRIANGLES||u.mode===$r.TRIANGLE_STRIP||u.mode===$r.TRIANGLE_FAN||void 0===u.mode)!0===(p=!0===i.isSkinnedMesh?new G(c,g):new K(c,g)).isSkinnedMesh&&p.normalizeSkinWeights(),u.mode===$r.TRIANGLE_STRIP?p.geometry=Mr(p.geometry,f):u.mode===$r.TRIANGLE_FAN&&(p.geometry=Mr(p.geometry,m));else if(u.mode===$r.LINES)p=new W(c,g);else if(u.mode===$r.LINE_STRIP)p=new X(c,g);else if(u.mode===$r.LINE_LOOP)p=new q(c,g);else{if(u.mode!==$r.POINTS)throw new Error("THREE.GLTFLoader: Primitive mode unsupported: "+u.mode);p=new Q(c,g)}Object.keys(p.geometry.morphAttributes).length>0&&dn(p,i),p.name=r.createUniqueName(i.name||"mesh_"+e),hn(p,i),u.extensions&&ln(a,p,u),r.assignFinalMaterial(p),l.push(p)}for(var v=0,w=l.length;v<w;v++)r.associations.set(l[v],{meshes:e,primitives:v});if(1===l.length)return i.extensions&&ln(a,l[0],i),l[0];var b=new Y;i.extensions&&ln(a,b,i),r.associations.set(b,{meshes:e});for(var y=0,_=l.length;y<_;y++)b.add(l[y]);return b}))}},{key:"loadCamera",value:function(e){var t,r=this.json.cameras[e],n=r[r.type];if(n)return"perspective"===r.type?t=new Z(J.radToDeg(n.yfov),n.aspectRatio||1,n.znear||1,n.zfar||2e6):"orthographic"===r.type&&(t=new $(-n.xmag,n.xmag,n.ymag,-n.ymag,n.znear,n.zfar)),r.name&&(t.name=this.createUniqueName(r.name)),hn(t,r),Promise.resolve(t);console.warn("THREE.GLTFLoader: Missing camera parameters.")}},{key:"loadSkin",value:function(e){for(var t=this.json.skins[e],r=[],n=0,a=t.joints.length;n<a;n++)r.push(this._loadNodeShallow(t.joints[n]));return void 0!==t.inverseBindMatrices?r.push(this.getDependency("accessor",t.inverseBindMatrices)):r.push(null),Promise.all(r).then((function(e){for(var r=e.pop(),n=e,a=[],i=[],s=0,o=n.length;s<o;s++){var l=n[s];if(l){a.push(l);var h=new P;null!==r&&h.fromArray(r.array,16*s),i.push(h)}else console.warn('THREE.GLTFLoader: Joint "%s" could not be found.',t.joints[s])}return new ee(a,i)}))}},{key:"loadAnimation",value:function(e){for(var t=this.json,r=this,n=t.animations[e],a=n.name?n.name:"animation_"+e,i=[],s=[],o=[],l=[],h=[],d=0,c=n.channels.length;d<c;d++){var u=n.channels[d],p=n.samplers[u.sampler],m=u.target,f=m.node,g=void 0!==n.parameters?n.parameters[p.input]:p.input,v=void 0!==n.parameters?n.parameters[p.output]:p.output;void 0!==m.node&&(i.push(this.getDependency("node",f)),s.push(this.getDependency("accessor",g)),o.push(this.getDependency("accessor",v)),l.push(p),h.push(m))}return Promise.all([Promise.all(i),Promise.all(s),Promise.all(o),Promise.all(l),Promise.all(h)]).then((function(e){for(var t=e[0],n=e[1],i=e[2],s=e[3],o=e[4],l=[],h=0,d=t.length;h<d;h++){var c=t[h],u=n[h],p=i[h],m=s[h],f=o[h];if(void 0!==c){c.updateMatrix&&c.updateMatrix();var g=r._createAnimationTracks(c,u,p,m,f);if(g)for(var v=0;v<g.length;v++)l.push(g[v])}}return new te(a,void 0,l)}))}},{key:"createNodeMesh",value:function(e){var t=this.json,r=this,n=t.nodes[e];return void 0===n.mesh?null:r.getDependency("mesh",n.mesh).then((function(e){var t=r._getNodeRef(r.meshCache,n.mesh,e);return void 0!==n.weights&&t.traverse((function(e){if(e.isMesh)for(var t=0,r=n.weights.length;t<r;t++)e.morphTargetInfluences[t]=n.weights[t]})),t}))}},{key:"loadNode",value:function(e){for(var t=this.json.nodes[e],r=this._loadNodeShallow(e),n=[],a=t.children||[],i=0,s=a.length;i<s;i++)n.push(this.getDependency("node",a[i]));var o=void 0===t.skin?Promise.resolve(null):this.getDependency("skin",t.skin);return Promise.all([r,Promise.all(n),o]).then((function(e){var t=e[0],r=e[1],n=e[2];null!==n&&t.traverse((function(e){e.isSkinnedMesh&&e.bind(n,mn)}));for(var a=0,i=r.length;a<i;a++)t.add(r[a]);return t}))}},{key:"_loadNodeShallow",value:function(e){var t=this.json,r=this.extensions,n=this;if(void 0!==this.nodeCache[e])return this.nodeCache[e];var a=t.nodes[e],i=a.name?n.createUniqueName(a.name):"",s=[],o=n._invokeOne((function(t){return t.createNodeMesh&&t.createNodeMesh(e)}));return o&&s.push(o),void 0!==a.camera&&s.push(n.getDependency("camera",a.camera).then((function(e){return n._getNodeRef(n.cameraCache,a.camera,e)}))),n._invokeAll((function(t){return t.createNodeAttachment&&t.createNodeAttachment(e)})).forEach((function(e){s.push(e)})),this.nodeCache[e]=Promise.all(s).then((function(t){var s;if((s=!0===a.isBone?new re:t.length>1?new Y:1===t.length?t[0]:new I)!==t[0])for(var o=0,l=t.length;o<l;o++)s.add(t[o]);if(a.name&&(s.userData.name=a.name,s.name=i),hn(s,a),a.extensions&&ln(r,s,a),void 0!==a.matrix){var h=new P;h.fromArray(a.matrix),s.applyMatrix4(h)}else void 0!==a.translation&&s.position.fromArray(a.translation),void 0!==a.rotation&&s.quaternion.fromArray(a.rotation),void 0!==a.scale&&s.scale.fromArray(a.scale);return n.associations.has(s)||n.associations.set(s,{}),n.associations.get(s).nodes=e,s})),this.nodeCache[e]}},{key:"loadScene",value:function(e){var t=this.extensions,r=this.json.scenes[e],n=this,a=new Y;r.name&&(a.name=n.createUniqueName(r.name)),hn(a,r),r.extensions&&ln(t,a,r);for(var i=r.nodes||[],s=[],o=0,l=i.length;o<l;o++)s.push(n.getDependency("node",i[o]));return Promise.all(s).then((function(e){for(var t=0,r=e.length;t<r;t++)a.add(e[t]);return n.associations=function(e){var t,r=new Map,a=A(n.associations);try{for(a.s();!(t=a.n()).done;){var i=me(t.value,2),s=i[0],o=i[1];(s instanceof N||s instanceof fe)&&r.set(s,o)}}catch(e){a.e(e)}finally{a.f()}return e.traverse((function(e){var t=n.associations.get(e);null!=t&&r.set(e,t)})),r}(a),a}))}},{key:"_createAnimationTracks",value:function(e,t,r,n,a){var i,s=[],o=e.name?e.name:e.uuid,l=[];switch(sn[a.path]===sn.weights?e.traverse((function(e){e.morphTargetInfluences&&l.push(e.name?e.name:e.uuid)})):l.push(o),sn[a.path]){case sn.weights:i=ve;break;case sn.rotation:i=we;break;case sn.position:case sn.scale:i=ge;break;default:switch(r.itemSize){case 1:i=ve;break;case 2:case 3:default:i=ge}}for(var h=void 0!==n.interpolation?on[n.interpolation]:ne,d=this._getArrayFromAccessor(r),c=0,u=l.length;c<u;c++){var p=new i(l[c]+"."+sn[a.path],t.array,d,h);"CUBICSPLINE"===n.interpolation&&this._createCubicSplineTrackInterpolant(p),s.push(p)}return s}},{key:"_getArrayFromAccessor",value:function(e){var t=e.array;if(e.normalized){for(var r=pn(t.constructor),n=new Float32Array(t.length),a=0,i=t.length;a<i;a++)n[a]=t[a]*r;t=n}return t}},{key:"_createCubicSplineTrackInterpolant",value:function(e){e.createInterpolant=function(e){return new(this instanceof we?Jr:Yr)(this.times,this.values,this.getValueSize()/3,e)},e.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline=!0}}]),e}();function gn(e,t,r){var n=t.attributes,a=[];function i(t,n){return r.getDependency("accessor",t).then((function(t){e.setAttribute(n,t)}))}for(var o in n){var l=an[o]||o.toLowerCase();l in e.attributes||a.push(i(n[o],l))}if(void 0!==t.indices&&!e.index){var h=r.getDependency("accessor",t.indices).then((function(t){e.setIndex(t)}));a.push(h)}return hn(e,t),function(e,t,r){var n=t.attributes,a=new be;if(void 0!==n.POSITION){var i=r.json.accessors[n.POSITION],o=i.min,l=i.max;if(void 0!==o&&void 0!==l){if(a.set(new s(o[0],o[1],o[2]),new s(l[0],l[1],l[2])),i.normalized){var h=pn(en[i.componentType]);a.min.multiplyScalar(h),a.max.multiplyScalar(h)}var d=t.targets;if(void 0!==d){for(var c=new s,u=new s,p=0,m=d.length;p<m;p++){var f=d[p];if(void 0!==f.POSITION){var g=r.json.accessors[f.POSITION],v=g.min,w=g.max;if(void 0!==v&&void 0!==w){if(u.setX(Math.max(Math.abs(v[0]),Math.abs(w[0]))),u.setY(Math.max(Math.abs(v[1]),Math.abs(w[1]))),u.setZ(Math.max(Math.abs(v[2]),Math.abs(w[2]))),g.normalized){var b=pn(en[g.componentType]);u.multiplyScalar(b)}c.max(u)}else console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.")}}a.expandByVector(c)}e.boundingBox=a;var y=new ye;a.getCenter(y.center),y.radius=a.min.distanceTo(a.max)/2,e.boundingSphere=y}else console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.")}}(e,t,r),Promise.all(a).then((function(){return void 0!==t.targets?function(e,t,r){for(var n=!1,a=!1,i=!1,s=0,o=t.length;s<o;s++){var l=t[s];if(void 0!==l.POSITION&&(n=!0),void 0!==l.NORMAL&&(a=!0),void 0!==l.COLOR_0&&(i=!0),n&&a&&i)break}if(!n&&!a&&!i)return Promise.resolve(e);for(var h=[],d=[],c=[],u=0,p=t.length;u<p;u++){var m=t[u];if(n){var f=void 0!==m.POSITION?r.getDependency("accessor",m.POSITION):e.attributes.position;h.push(f)}if(a){var g=void 0!==m.NORMAL?r.getDependency("accessor",m.NORMAL):e.attributes.normal;d.push(g)}if(i){var v=void 0!==m.COLOR_0?r.getDependency("accessor",m.COLOR_0):e.attributes.color;c.push(v)}}return Promise.all([Promise.all(h),Promise.all(d),Promise.all(c)]).then((function(t){var r=t[0],s=t[1],o=t[2];return n&&(e.morphAttributes.position=r),a&&(e.morphAttributes.normal=s),i&&(e.morphAttributes.color=o),e.morphTargetsRelative=!0,e}))}(e,t.targets,r):e}))}var vn=new WeakMap,wn=function(e){g(r,e);var t=v(r);function r(e){var n;return w(this,r),(n=t.call(this,e)).decoderPath="",n.decoderConfig={},n.decoderBinary=null,n.decoderPending=null,n.workerLimit=4,n.workerPool=[],n.workerNextTaskID=1,n.workerSourceURL="",n.defaultAttributeIDs={position:"POSITION",normal:"NORMAL",color:"COLOR",uv:"TEX_COORD"},n.defaultAttributeTypes={position:"Float32Array",normal:"Float32Array",color:"Float32Array",uv:"Float32Array"},n}return b(r,[{key:"setDecoderPath",value:function(e){return this.decoderPath=e,this}},{key:"setDecoderConfig",value:function(e){return this.decoderConfig=e,this}},{key:"setWorkerLimit",value:function(e){return this.workerLimit=e,this}},{key:"load",value:function(e,t,r,n){var a=this,i=new _(this.manager);i.setPath(this.path),i.setResponseType("arraybuffer"),i.setRequestHeader(this.requestHeader),i.setWithCredentials(this.withCredentials),i.load(e,(function(e){a.parse(e,t,n)}),r,n)}},{key:"parse",value:function(e,t,r){this.decodeDracoFile(e,t,null,null,M).catch(r)}},{key:"decodeDracoFile",value:function(e,t,r,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:Ce,i={attributeIDs:r||this.defaultAttributeIDs,attributeTypes:n||this.defaultAttributeTypes,useUniqueIDs:!!r,vertexColorSpace:a};return this.decodeGeometry(e,i).then(t)}},{key:"decodeGeometry",value:function(e,t){var r,n=this,a=JSON.stringify(t);if(vn.has(e)){var i=vn.get(e);if(i.key===a)return i.promise;if(0===e.byteLength)throw new Error("THREE.DRACOLoader: Unable to re-decode a buffer with different settings. Buffer has already been transferred.")}var s=this.workerNextTaskID++,o=e.byteLength,l=this._getWorker(s,o).then((function(n){return r=n,new Promise((function(n,a){r._callbacks[s]={resolve:n,reject:a},r.postMessage({type:"decode",id:s,taskConfig:t,buffer:e},[e])}))})).then((function(e){return n._createGeometry(e.geometry)}));return l.catch((function(){return!0})).then((function(){r&&s&&n._releaseTask(r,s)})),vn.set(e,{key:a,promise:l}),l}},{key:"_createGeometry",value:function(e){var t=new c;e.index&&t.setIndex(new u(e.index.array,1));for(var r=0;r<e.attributes.length;r++){var n=e.attributes[r],a=n.name,i=n.array,s=n.itemSize,o=new u(i,s);"color"===a&&(this._assignVertexColorSpace(o,n.vertexColorSpace),o.normalized=i instanceof Float32Array==0),t.setAttribute(a,o)}return t}},{key:"_assignVertexColorSpace",value:function(e,t){if(t===M)for(var r=new h,n=0,a=e.count;n<a;n++)r.fromBufferAttribute(e,n).convertSRGBToLinear(),e.setXYZ(n,r.r,r.g,r.b)}},{key:"_loadLibrary",value:function(e,t){var r=new _(this.manager);return r.setPath(this.decoderPath),r.setResponseType(t),r.setWithCredentials(this.withCredentials),new Promise((function(t,n){r.load(e,t,void 0,n)}))}},{key:"preload",value:function(){return this._initDecoder(),this}},{key:"_initDecoder",value:function(){var e=this;if(this.decoderPending)return this.decoderPending;var t="object"!==("undefined"==typeof WebAssembly?"undefined":k(WebAssembly))||"js"===this.decoderConfig.type,r=[];return t?r.push(this._loadLibrary("draco_decoder.js","text")):(r.push(this._loadLibrary("draco_wasm_wrapper.js","text")),r.push(this._loadLibrary("draco_decoder.wasm","arraybuffer"))),this.decoderPending=Promise.all(r).then((function(r){var n=r[0];t||(e.decoderConfig.wasmBinary=r[1]);var a=bn.toString(),i=["/* draco decoder */",n,"","/* worker */",a.substring(a.indexOf("{")+1,a.lastIndexOf("}"))].join("\n");e.workerSourceURL=URL.createObjectURL(new Blob([i]))})),this.decoderPending}},{key:"_getWorker",value:function(e,t){var r=this;return this._initDecoder().then((function(){if(r.workerPool.length<r.workerLimit){var n=new Worker(r.workerSourceURL);n._callbacks={},n._taskCosts={},n._taskLoad=0,n.postMessage({type:"init",decoderConfig:r.decoderConfig}),n.onmessage=function(e){var t=e.data;switch(t.type){case"decode":n._callbacks[t.id].resolve(t);break;case"error":n._callbacks[t.id].reject(t);break;default:console.error('THREE.DRACOLoader: Unexpected message, "'+t.type+'"')}},r.workerPool.push(n)}else r.workerPool.sort((function(e,t){return e._taskLoad>t._taskLoad?-1:1}));var a=r.workerPool[r.workerPool.length-1];return a._taskCosts[e]=t,a._taskLoad+=t,a}))}},{key:"_releaseTask",value:function(e,t){e._taskLoad-=e._taskCosts[t],delete e._callbacks[t],delete e._taskCosts[t]}},{key:"debug",value:function(){this.workerPool.map((function(e){return e._taskLoad}))}},{key:"dispose",value:function(){for(var e=0;e<this.workerPool.length;++e)this.workerPool[e].terminate();return this.workerPool.length=0,""!==this.workerSourceURL&&URL.revokeObjectURL(this.workerSourceURL),this}}]),r}(x);function bn(){var e,t;function r(e,t,r,n,a,i){var s=i.num_components(),o=r.num_points()*s,l=o*a.BYTES_PER_ELEMENT,h=function(e,t){switch(t){case Float32Array:return e.DT_FLOAT32;case Int8Array:return e.DT_INT8;case Int16Array:return e.DT_INT16;case Int32Array:return e.DT_INT32;case Uint8Array:return e.DT_UINT8;case Uint16Array:return e.DT_UINT16;case Uint32Array:return e.DT_UINT32}}(e,a),d=e._malloc(l);t.GetAttributeDataArrayForAllPoints(r,i,h,l,d);var c=new a(e.HEAPF32.buffer,d,o).slice();return e._free(d),{name:n,array:c,itemSize:s}}onmessage=function(n){var a=n.data;switch(a.type){case"init":e=a.decoderConfig,t=new Promise((function(t){e.onModuleLoaded=function(e){t({draco:e})},DracoDecoderModule(e)}));break;case"decode":var i=a.buffer,s=a.taskConfig;t.then((function(e){var t=e.draco,n=new t.Decoder;try{var o=function(e,t,n,a){var i,s,o=a.attributeIDs,l=a.attributeTypes,h=t.GetEncodedGeometryType(n);if(h===e.TRIANGULAR_MESH)i=new e.Mesh,s=t.DecodeArrayToMesh(n,n.byteLength,i);else{if(h!==e.POINT_CLOUD)throw new Error("THREE.DRACOLoader: Unexpected geometry type.");i=new e.PointCloud,s=t.DecodeArrayToPointCloud(n,n.byteLength,i)}if(!s.ok()||0===i.ptr)throw new Error("THREE.DRACOLoader: Decoding failed: "+s.error_msg());var d={index:null,attributes:[]};for(var c in o){var u=self[l[c]],p=void 0,m=void 0;if(a.useUniqueIDs)m=o[c],p=t.GetAttributeByUniqueId(i,m);else{if(-1===(m=t.GetAttributeId(i,e[o[c]])))continue;p=t.GetAttribute(i,m)}var f=r(e,t,i,c,u,p);"color"===c&&(f.vertexColorSpace=a.vertexColorSpace),d.attributes.push(f)}return h===e.TRIANGULAR_MESH&&(d.index=function(e,t,r){var n=3*r.num_faces(),a=4*n,i=e._malloc(a);t.GetTrianglesUInt32Array(r,a,i);var s=new Uint32Array(e.HEAPF32.buffer,i,n).slice();return e._free(i),{array:s,itemSize:1}}(e,t,i)),e.destroy(i),d}(t,n,new Int8Array(i),s),l=o.attributes.map((function(e){return e.array.buffer}));o.index&&l.push(o.index.array.buffer),self.postMessage({type:"decode",id:a.id,geometry:o},l)}catch(e){console.error(e),self.postMessage({type:"error",id:a.id,error:e.message})}finally{t.destroy(n)}}))}}}const yn={"draco_wasm_wrapper.js":"static/draco_wasm_wrapper-6263f3a4b71cdf3b.js","draco_decoder.wasm":"static/draco_decoder-b048235474cbf09e.wasm","draco_decoder.js":"static/draco_decoder-dc7f397e2a2ebac4.js"};class _n{static setEnvMapIntensity(e){this._envMapIntensity=e}static createMeshPhysicalMaterial(e){return e.envMapIntensity=this._envMapIntensity,new T(e)}static createMeshStandardMaterial(e){return e.envMapIntensity=this._envMapIntensity,new H(e)}static getEnvMapIntensity(){return this._envMapIntensity}}e("V",_n),_n._envMapIntensity=1.5;class xn{constructor(e){this._context_=e}getStore(e="rml_default"){return this._localStorage.getItem(e)||{entries:[]}}saveStore(e,t){this._localStorage.setItem(e,t)}addItem(e,t,r="rml_default",n=5){const a=this.getStore(r),i=a.entries.find(t=>t.id===e);if(i?(i.payload=t,i.date=Date.now()):a.entries.push({id:e,date:Date.now(),payload:t}),a.entries.length>n)for(a.entries.sort((e,t)=>t.date-e.date);a.entries.length>n;)a.entries.pop();this.saveStore(r,a)}getItem(e,t="rml_default"){const r=this.getStore(t).entries.find(t=>t.id===e);return r?r.payload:null}}pr([fr],xn.prototype,"_localStorage",void 0);const Sn=e("t",(function(e){return e*(Math.PI/180)})),Cn=e("y",(function(e){return e*(180/Math.PI)})),Mn=(e("w",(function(e,t,r,n,a,i){e=Math.sqrt(e*e+r*r);const s=a/i,o=2*Math.atan(Math.tan(n*Math.PI/180/2)*s)*180/Math.PI,l=Sn(n),h=t/2/Math.tan(l/2),d=e/(2*Math.atan(Math.PI*o/360));return Math.max(h,d)})),function(e){return Math.round(1e3*e)/1e3}),Tn=(e("a0",(function(e,t){return Math.abs(e.y-t.y)+Math.abs(e.x-t.x)})),e("a9",e=>new s(e.x/1e3,e.z/1e3,e.y/-1e3))),An=e=>new s(e.x/1e3,e.z/1e3,e.y/1e3),Pn=e("h",e=>({x:Math.round(1e3*e.x),y:Math.round(-1e3*e.z),z:Math.round(1e3*e.y)})),Rn=e=>decodeURIComponent(encodeURIComponent(e)),En=e("O",e=>{if(!e){const t=typeof e;return"number"===t||"boolean"===t?e:null}if(!e.hasOwnProperty("size")&&e.size&&"function"==typeof e.size){let t=In(e);for(let e=0;e<t.length;e++)t[e]=En(t[e]);return"string"==typeof t?Rn(t):t}if("object"==typeof e)for(let t in e)e.hasOwnProperty(t)&&(e[t]=En(e[t]));return"string"==typeof e?Rn(e):e}),In=e=>{let t=[];if(e){let r=e.size();for(let n=0;n<r;n++)t.push(e.get(n))}return t},kn=e=>{let t=new P,r=En(e);return t.fromArray(r),t.transpose(),(e=>{let t=new P;t.set(1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1),t.scale(new s(.001,.001,.001));let r=new P;return r.set(1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1),r.scale(new s(1e3,1e3,1e3)),t.multiply(e).multiply(r)})(t)};function On(e,t){var r=e.__state.conversionName.toString(),n=Math.round(e.r),a=Math.round(e.g),i=Math.round(e.b),s=e.a,o=Math.round(e.h),l=e.s.toFixed(1),h=e.v.toFixed(1);if(t||"THREE_CHAR_HEX"===r||"SIX_CHAR_HEX"===r){for(var d=e.hex.toString(16);d.length<6;)d="0"+d;return"#"+d}return"CSS_RGB"===r?"rgb("+n+","+a+","+i+")":"CSS_RGBA"===r?"rgba("+n+","+a+","+i+","+s+")":"HEX"===r?"0x"+e.hex.toString(16):"RGB_ARRAY"===r?"["+n+","+a+","+i+"]":"RGBA_ARRAY"===r?"["+n+","+a+","+i+","+s+"]":"RGB_OBJ"===r?"{r:"+n+",g:"+a+",b:"+i+"}":"RGBA_OBJ"===r?"{r:"+n+",g:"+a+",b:"+i+",a:"+s+"}":"HSV_OBJ"===r?"{h:"+o+",s:"+l+",v:"+h+"}":"HSVA_OBJ"===r?"{h:"+o+",s:"+l+",v:"+h+",a:"+s+"}":"unknown format"}var Dn=Array.prototype.forEach,Ln=Array.prototype.slice,Un={BREAK:{},extend:function(e){return this.each(Ln.call(arguments,1),(function(t){(this.isObject(t)?Object.keys(t):[]).forEach(function(r){this.isUndefined(t[r])||(e[r]=t[r])}.bind(this))}),this),e},defaults:function(e){return this.each(Ln.call(arguments,1),(function(t){(this.isObject(t)?Object.keys(t):[]).forEach(function(r){this.isUndefined(e[r])&&(e[r]=t[r])}.bind(this))}),this),e},compose:function(){var e=Ln.call(arguments);return function(){for(var t=Ln.call(arguments),r=e.length-1;r>=0;r--)t=[e[r].apply(this,t)];return t[0]}},each:function(e,t,r){if(e)if(Dn&&e.forEach&&e.forEach===Dn)e.forEach(t,r);else if(e.length===e.length+0){var n,a=void 0;for(a=0,n=e.length;a<n;a++)if(a in e&&t.call(r,e[a],a)===this.BREAK)return}else for(var i in e)if(t.call(r,e[i],i)===this.BREAK)return},defer:function(e){setTimeout(e,0)},debounce:function(e,t,r){var n=void 0;return function(){var a=this,i=arguments;function s(){n=null,r||e.apply(a,i)}var o=r||!n;clearTimeout(n),n=setTimeout(s,t),o&&e.apply(a,i)}},toArray:function(e){return e.toArray?e.toArray():Ln.call(e)},isUndefined:function(e){return void 0===e},isNull:function(e){return null===e},isNaN:function(e){function t(t){return e.apply(this,arguments)}return t.toString=function(){return e.toString()},t}((function(e){return isNaN(e)})),isArray:Array.isArray||function(e){return e.constructor===Array},isObject:function(e){return e===Object(e)},isNumber:function(e){return e===e+0},isString:function(e){return e===e+""},isBoolean:function(e){return!1===e||!0===e},isFunction:function(e){return e instanceof Function}},Fn=[{litmus:Un.isString,conversions:{THREE_CHAR_HEX:{read:function(e){var t=e.match(/^#([A-F0-9])([A-F0-9])([A-F0-9])$/i);return null!==t&&{space:"HEX",hex:parseInt("0x"+t[1].toString()+t[1].toString()+t[2].toString()+t[2].toString()+t[3].toString()+t[3].toString(),0)}},write:On},SIX_CHAR_HEX:{read:function(e){var t=e.match(/^#([A-F0-9]{6})$/i);return null!==t&&{space:"HEX",hex:parseInt("0x"+t[1].toString(),0)}},write:On},CSS_RGB:{read:function(e){var t=e.match(/^rgb\(\s*(\S+)\s*,\s*(\S+)\s*,\s*(\S+)\s*\)/);return null!==t&&{space:"RGB",r:parseFloat(t[1]),g:parseFloat(t[2]),b:parseFloat(t[3])}},write:On},CSS_RGBA:{read:function(e){var t=e.match(/^rgba\(\s*(\S+)\s*,\s*(\S+)\s*,\s*(\S+)\s*,\s*(\S+)\s*\)/);return null!==t&&{space:"RGB",r:parseFloat(t[1]),g:parseFloat(t[2]),b:parseFloat(t[3]),a:parseFloat(t[4])}},write:On}}},{litmus:Un.isNumber,conversions:{HEX:{read:function(e){return{space:"HEX",hex:e,conversionName:"HEX"}},write:function(e){return e.hex}}}},{litmus:Un.isArray,conversions:{RGB_ARRAY:{read:function(e){return 3===e.length&&{space:"RGB",r:e[0],g:e[1],b:e[2]}},write:function(e){return[e.r,e.g,e.b]}},RGBA_ARRAY:{read:function(e){return 4===e.length&&{space:"RGB",r:e[0],g:e[1],b:e[2],a:e[3]}},write:function(e){return[e.r,e.g,e.b,e.a]}}}},{litmus:Un.isObject,conversions:{RGBA_OBJ:{read:function(e){return!!(Un.isNumber(e.r)&&Un.isNumber(e.g)&&Un.isNumber(e.b)&&Un.isNumber(e.a))&&{space:"RGB",r:e.r,g:e.g,b:e.b,a:e.a}},write:function(e){return{r:e.r,g:e.g,b:e.b,a:e.a}}},RGB_OBJ:{read:function(e){return!!(Un.isNumber(e.r)&&Un.isNumber(e.g)&&Un.isNumber(e.b))&&{space:"RGB",r:e.r,g:e.g,b:e.b}},write:function(e){return{r:e.r,g:e.g,b:e.b}}},HSVA_OBJ:{read:function(e){return!!(Un.isNumber(e.h)&&Un.isNumber(e.s)&&Un.isNumber(e.v)&&Un.isNumber(e.a))&&{space:"HSV",h:e.h,s:e.s,v:e.v,a:e.a}},write:function(e){return{h:e.h,s:e.s,v:e.v,a:e.a}}},HSV_OBJ:{read:function(e){return!!(Un.isNumber(e.h)&&Un.isNumber(e.s)&&Un.isNumber(e.v))&&{space:"HSV",h:e.h,s:e.s,v:e.v}},write:function(e){return{h:e.h,s:e.s,v:e.v}}}}}],Bn=void 0,Nn=void 0,zn=function(){Nn=!1;var e=arguments.length>1?Un.toArray(arguments):arguments[0];return Un.each(Fn,(function(t){if(t.litmus(e))return Un.each(t.conversions,(function(t,r){if(Bn=t.read(e),!1===Nn&&!1!==Bn)return Nn=Bn,Bn.conversionName=r,Bn.conversion=t,Un.BREAK})),Un.BREAK})),Nn},Hn=void 0,jn={hsv_to_rgb:function(e,t,r){var n=Math.floor(e/60)%6,a=e/60-Math.floor(e/60),i=r*(1-t),s=r*(1-a*t),o=r*(1-(1-a)*t),l=[[r,o,i],[s,r,i],[i,r,o],[i,s,r],[o,i,r],[r,i,s]][n];return{r:255*l[0],g:255*l[1],b:255*l[2]}},rgb_to_hsv:function(e,t,r){var n=Math.min(e,t,r),a=Math.max(e,t,r),i=a-n,s=void 0;return 0===a?{h:NaN,s:0,v:0}:(s=e===a?(t-r)/i:t===a?2+(r-e)/i:4+(e-t)/i,(s/=6)<0&&(s+=1),{h:360*s,s:i/a,v:a/255})},rgb_to_hex:function(e,t,r){var n=this.hex_with_component(0,2,e);return n=this.hex_with_component(n,1,t),this.hex_with_component(n,0,r)},component_from_hex:function(e,t){return e>>8*t&255},hex_with_component:function(e,t,r){return r<<(Hn=8*t)|e&~(255<<Hn)}},Vn="function"==typeof Symbol&&"symbol"===k(Symbol.iterator)?function(e){return k(e)}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":k(e)},Gn=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},Kn=function(){function e(e,t){for(var r=0;r<t.length;r++){var n=t[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(e,n.key,n)}}return function(t,r,n){return r&&e(t.prototype,r),n&&e(t,n),t}}(),Wn=function e(t,r,n){null===t&&(t=Function.prototype);var a=Object.getOwnPropertyDescriptor(t,r);if(void 0===a){var i=Object.getPrototypeOf(t);return null===i?void 0:e(i,r,n)}if("value"in a)return a.value;var s=a.get;return void 0!==s?s.call(n):void 0},Xn=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+k(t));e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)},qn=function(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!==k(t)&&"function"!=typeof t?e:t},Qn=function(){function e(){if(Gn(this,e),this.__state=zn.apply(this,arguments),!1===this.__state)throw new Error("Failed to interpret color arguments");this.__state.a=this.__state.a||1}return Kn(e,[{key:"toString",value:function(){return On(this)}},{key:"toHexString",value:function(){return On(this,!0)}},{key:"toOriginal",value:function(){return this.__state.conversion.write(this)}}]),e}();function Yn(e,t,r){Object.defineProperty(e,t,{get:function(){return"RGB"===this.__state.space||Qn.recalculateRGB(this,t,r),this.__state[t]},set:function(e){"RGB"!==this.__state.space&&(Qn.recalculateRGB(this,t,r),this.__state.space="RGB"),this.__state[t]=e}})}function Zn(e,t){Object.defineProperty(e,t,{get:function(){return"HSV"===this.__state.space||Qn.recalculateHSV(this),this.__state[t]},set:function(e){"HSV"!==this.__state.space&&(Qn.recalculateHSV(this),this.__state.space="HSV"),this.__state[t]=e}})}Qn.recalculateRGB=function(e,t,r){if("HEX"===e.__state.space)e.__state[t]=jn.component_from_hex(e.__state.hex,r);else{if("HSV"!==e.__state.space)throw new Error("Corrupted color state");Un.extend(e.__state,jn.hsv_to_rgb(e.__state.h,e.__state.s,e.__state.v))}},Qn.recalculateHSV=function(e){var t=jn.rgb_to_hsv(e.r,e.g,e.b);Un.extend(e.__state,{s:t.s,v:t.v}),Un.isNaN(t.h)?Un.isUndefined(e.__state.h)&&(e.__state.h=0):e.__state.h=t.h},Qn.COMPONENTS=["r","g","b","h","s","v","hex","a"],Yn(Qn.prototype,"r",2),Yn(Qn.prototype,"g",1),Yn(Qn.prototype,"b",0),Zn(Qn.prototype,"h"),Zn(Qn.prototype,"s"),Zn(Qn.prototype,"v"),Object.defineProperty(Qn.prototype,"a",{get:function(){return this.__state.a},set:function(e){this.__state.a=e}}),Object.defineProperty(Qn.prototype,"hex",{get:function(){return"HEX"!==this.__state.space&&(this.__state.hex=jn.rgb_to_hex(this.r,this.g,this.b),this.__state.space="HEX"),this.__state.hex},set:function(e){this.__state.space="HEX",this.__state.hex=e}});var Jn=function(){function e(t,r){Gn(this,e),this.initialValue=t[r],this.domElement=document.createElement("div"),this.object=t,this.property=r,this.__onChange=void 0,this.__onFinishChange=void 0}return Kn(e,[{key:"onChange",value:function(e){return this.__onChange=e,this}},{key:"onFinishChange",value:function(e){return this.__onFinishChange=e,this}},{key:"setValue",value:function(e){return this.object[this.property]=e,this.__onChange&&this.__onChange.call(this,e),this.updateDisplay(),this}},{key:"getValue",value:function(){return this.object[this.property]}},{key:"updateDisplay",value:function(){return this}},{key:"isModified",value:function(){return this.initialValue!==this.getValue()}}]),e}(),$n={};Un.each({HTMLEvents:["change"],MouseEvents:["click","mousemove","mousedown","mouseup","mouseover"],KeyboardEvents:["keydown"]},(function(e,t){Un.each(e,(function(e){$n[e]=t}))}));var ea=/(\d+(\.\d+)?)px/;function ta(e){if("0"===e||Un.isUndefined(e))return 0;var t=e.match(ea);return Un.isNull(t)?0:parseFloat(t[1])}var ra={makeSelectable:function(e,t){void 0!==e&&void 0!==e.style&&(e.onselectstart=t?function(){return!1}:function(){},e.style.MozUserSelect=t?"auto":"none",e.style.KhtmlUserSelect=t?"auto":"none",e.unselectable=t?"on":"off")},makeFullscreen:function(e,t,r){var n=r,a=t;Un.isUndefined(a)&&(a=!0),Un.isUndefined(n)&&(n=!0),e.style.position="absolute",a&&(e.style.left=0,e.style.right=0),n&&(e.style.top=0,e.style.bottom=0)},fakeEvent:function(e,t,r,n){var a=r||{},i=$n[t];if(!i)throw new Error("Event type "+t+" not supported.");var s=document.createEvent(i);switch(i){case"MouseEvents":var o=a.x||a.clientX||0,l=a.y||a.clientY||0;s.initMouseEvent(t,a.bubbles||!1,a.cancelable||!0,window,a.clickCount||1,0,0,o,l,!1,!1,!1,!1,0,null);break;case"KeyboardEvents":var h=s.initKeyboardEvent||s.initKeyEvent;Un.defaults(a,{cancelable:!0,ctrlKey:!1,altKey:!1,shiftKey:!1,metaKey:!1,keyCode:void 0,charCode:void 0}),h(t,a.bubbles||!1,a.cancelable,window,a.ctrlKey,a.altKey,a.shiftKey,a.metaKey,a.keyCode,a.charCode);break;default:s.initEvent(t,a.bubbles||!1,a.cancelable||!0)}Un.defaults(s,n),e.dispatchEvent(s)},bind:function(e,t,r,n){var a=n||!1;return e.addEventListener?e.addEventListener(t,r,a):e.attachEvent&&e.attachEvent("on"+t,r),ra},unbind:function(e,t,r,n){var a=n||!1;return e.removeEventListener?e.removeEventListener(t,r,a):e.detachEvent&&e.detachEvent("on"+t,r),ra},addClass:function(e,t){if(void 0===e.className)e.className=t;else if(e.className!==t){var r=e.className.split(/ +/);-1===r.indexOf(t)&&(r.push(t),e.className=r.join(" ").replace(/^\s+/,"").replace(/\s+$/,""))}return ra},removeClass:function(e,t){if(t)if(e.className===t)e.removeAttribute("class");else{var r=e.className.split(/ +/),n=r.indexOf(t);-1!==n&&(r.splice(n,1),e.className=r.join(" "))}else e.className=void 0;return ra},hasClass:function(e,t){return new RegExp("(?:^|\\s+)"+t+"(?:\\s+|$)").test(e.className)||!1},getWidth:function(e){var t=getComputedStyle(e);return ta(t["border-left-width"])+ta(t["border-right-width"])+ta(t["padding-left"])+ta(t["padding-right"])+ta(t.width)},getHeight:function(e){var t=getComputedStyle(e);return ta(t["border-top-width"])+ta(t["border-bottom-width"])+ta(t["padding-top"])+ta(t["padding-bottom"])+ta(t.height)},getOffset:function(e){var t=e,r={left:0,top:0};if(t.offsetParent)do{r.left+=t.offsetLeft,r.top+=t.offsetTop,t=t.offsetParent}while(t);return r},isActive:function(e){return e===document.activeElement&&(e.type||e.href)}},na=function(e){function t(e,r){Gn(this,t);var n=qn(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,r)),a=n;return n.__prev=n.getValue(),n.__checkbox=document.createElement("input"),n.__checkbox.setAttribute("type","checkbox"),ra.bind(n.__checkbox,"change",(function(){a.setValue(!a.__prev)}),!1),n.domElement.appendChild(n.__checkbox),n.updateDisplay(),n}return Xn(t,e),Kn(t,[{key:"setValue",value:function(e){var r=Wn(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"setValue",this).call(this,e);return this.__onFinishChange&&this.__onFinishChange.call(this,this.getValue()),this.__prev=this.getValue(),r}},{key:"updateDisplay",value:function(){return!0===this.getValue()?(this.__checkbox.setAttribute("checked","checked"),this.__checkbox.checked=!0,this.__prev=!0):(this.__checkbox.checked=!1,this.__prev=!1),Wn(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(Jn),aa=function(e){function t(e,r,n){Gn(this,t);var a=qn(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,r)),i=n,s=a;if(a.__select=document.createElement("select"),Un.isArray(i)){var o={};Un.each(i,(function(e){o[e]=e})),i=o}return Un.each(i,(function(e,t){var r=document.createElement("option");r.innerHTML=t,r.setAttribute("value",e),s.__select.appendChild(r)})),a.updateDisplay(),ra.bind(a.__select,"change",(function(){var e=this.options[this.selectedIndex].value;s.setValue(e)})),a.domElement.appendChild(a.__select),a}return Xn(t,e),Kn(t,[{key:"setValue",value:function(e){var r=Wn(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"setValue",this).call(this,e);return this.__onFinishChange&&this.__onFinishChange.call(this,this.getValue()),r}},{key:"updateDisplay",value:function(){return ra.isActive(this.__select)?this:(this.__select.value=this.getValue(),Wn(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this))}}]),t}(Jn),ia=function(e){function t(e,r){Gn(this,t);var n=qn(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,r)),a=n;function i(){a.setValue(a.__input.value)}return n.__input=document.createElement("input"),n.__input.setAttribute("type","text"),ra.bind(n.__input,"keyup",i),ra.bind(n.__input,"change",i),ra.bind(n.__input,"blur",(function(){a.__onFinishChange&&a.__onFinishChange.call(a,a.getValue())})),ra.bind(n.__input,"keydown",(function(e){13===e.keyCode&&this.blur()})),n.updateDisplay(),n.domElement.appendChild(n.__input),n}return Xn(t,e),Kn(t,[{key:"updateDisplay",value:function(){return ra.isActive(this.__input)||(this.__input.value=this.getValue()),Wn(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(Jn);function sa(e){var t=e.toString();return t.indexOf(".")>-1?t.length-t.indexOf(".")-1:0}var oa=function(e){function t(e,r,n){Gn(this,t);var a=qn(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,r)),i=n||{};return a.__min=i.min,a.__max=i.max,a.__step=i.step,Un.isUndefined(a.__step)?0===a.initialValue?a.__impliedStep=1:a.__impliedStep=Math.pow(10,Math.floor(Math.log(Math.abs(a.initialValue))/Math.LN10))/10:a.__impliedStep=a.__step,a.__precision=sa(a.__impliedStep),a}return Xn(t,e),Kn(t,[{key:"setValue",value:function(e){var r=e;return void 0!==this.__min&&r<this.__min?r=this.__min:void 0!==this.__max&&r>this.__max&&(r=this.__max),void 0!==this.__step&&r%this.__step!=0&&(r=Math.round(r/this.__step)*this.__step),Wn(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"setValue",this).call(this,r)}},{key:"min",value:function(e){return this.__min=e,this}},{key:"max",value:function(e){return this.__max=e,this}},{key:"step",value:function(e){return this.__step=e,this.__impliedStep=e,this.__precision=sa(e),this}}]),t}(Jn),la=function(e){function t(e,r,n){Gn(this,t);var a=qn(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,r,n));a.__truncationSuspended=!1;var i=a,s=void 0;function o(){i.__onFinishChange&&i.__onFinishChange.call(i,i.getValue())}function l(e){var t=s-e.clientY;i.setValue(i.getValue()+t*i.__impliedStep),s=e.clientY}function h(){ra.unbind(window,"mousemove",l),ra.unbind(window,"mouseup",h),o()}return a.__input=document.createElement("input"),a.__input.setAttribute("type","text"),ra.bind(a.__input,"change",(function(){var e=parseFloat(i.__input.value);Un.isNaN(e)||i.setValue(e)})),ra.bind(a.__input,"blur",(function(){o()})),ra.bind(a.__input,"mousedown",(function(e){ra.bind(window,"mousemove",l),ra.bind(window,"mouseup",h),s=e.clientY})),ra.bind(a.__input,"keydown",(function(e){13===e.keyCode&&(i.__truncationSuspended=!0,this.blur(),i.__truncationSuspended=!1,o())})),a.updateDisplay(),a.domElement.appendChild(a.__input),a}return Xn(t,e),Kn(t,[{key:"updateDisplay",value:function(){var e,r,n;return this.__input.value=this.__truncationSuspended?this.getValue():(e=this.getValue(),r=this.__precision,n=Math.pow(10,r),Math.round(e*n)/n),Wn(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(oa);function ha(e,t,r,n,a){return n+(e-t)/(r-t)*(a-n)}var da=function(e){function t(e,r,n,a,i){Gn(this,t);var s=qn(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,r,{min:n,max:a,step:i})),o=s;function l(e){e.preventDefault();var t=o.__background.getBoundingClientRect();return o.setValue(ha(e.clientX,t.left,t.right,o.__min,o.__max)),!1}function h(){ra.unbind(window,"mousemove",l),ra.unbind(window,"mouseup",h),o.__onFinishChange&&o.__onFinishChange.call(o,o.getValue())}function d(e){var t=e.touches[0].clientX,r=o.__background.getBoundingClientRect();o.setValue(ha(t,r.left,r.right,o.__min,o.__max))}function c(){ra.unbind(window,"touchmove",d),ra.unbind(window,"touchend",c),o.__onFinishChange&&o.__onFinishChange.call(o,o.getValue())}return s.__background=document.createElement("div"),s.__foreground=document.createElement("div"),ra.bind(s.__background,"mousedown",(function(e){document.activeElement.blur(),ra.bind(window,"mousemove",l),ra.bind(window,"mouseup",h),l(e)})),ra.bind(s.__background,"touchstart",(function(e){1===e.touches.length&&(ra.bind(window,"touchmove",d),ra.bind(window,"touchend",c),d(e))})),ra.addClass(s.__background,"slider"),ra.addClass(s.__foreground,"slider-fg"),s.updateDisplay(),s.__background.appendChild(s.__foreground),s.domElement.appendChild(s.__background),s}return Xn(t,e),Kn(t,[{key:"updateDisplay",value:function(){var e=(this.getValue()-this.__min)/(this.__max-this.__min);return this.__foreground.style.width=100*e+"%",Wn(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(oa),ca=function(e){function t(e,r,n){Gn(this,t);var a=qn(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,r)),i=a;return a.__button=document.createElement("div"),a.__button.innerHTML=void 0===n?"Fire":n,ra.bind(a.__button,"click",(function(e){return e.preventDefault(),i.fire(),!1})),ra.addClass(a.__button,"button"),a.domElement.appendChild(a.__button),a}return Xn(t,e),Kn(t,[{key:"fire",value:function(){this.__onChange&&this.__onChange.call(this),this.getValue().call(this.object),this.__onFinishChange&&this.__onFinishChange.call(this,this.getValue())}}]),t}(Jn),ua=function(e){function t(e,r){Gn(this,t);var n=qn(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,r));n.__color=new Qn(n.getValue()),n.__temp=new Qn(0);var a=n;n.domElement=document.createElement("div"),ra.makeSelectable(n.domElement,!1),n.__selector=document.createElement("div"),n.__selector.className="selector",n.__saturation_field=document.createElement("div"),n.__saturation_field.className="saturation-field",n.__field_knob=document.createElement("div"),n.__field_knob.className="field-knob",n.__field_knob_border="2px solid ",n.__hue_knob=document.createElement("div"),n.__hue_knob.className="hue-knob",n.__hue_field=document.createElement("div"),n.__hue_field.className="hue-field",n.__input=document.createElement("input"),n.__input.type="text",n.__input_textShadow="0 1px 1px ",ra.bind(n.__input,"keydown",(function(e){13===e.keyCode&&c.call(this)})),ra.bind(n.__input,"blur",c),ra.bind(n.__selector,"mousedown",(function(){ra.addClass(this,"drag").bind(window,"mouseup",(function(){ra.removeClass(a.__selector,"drag")}))})),ra.bind(n.__selector,"touchstart",(function(){ra.addClass(this,"drag").bind(window,"touchend",(function(){ra.removeClass(a.__selector,"drag")}))}));var i,s=document.createElement("div");function o(e){p(e),ra.bind(window,"mousemove",p),ra.bind(window,"touchmove",p),ra.bind(window,"mouseup",h),ra.bind(window,"touchend",h)}function l(e){m(e),ra.bind(window,"mousemove",m),ra.bind(window,"touchmove",m),ra.bind(window,"mouseup",d),ra.bind(window,"touchend",d)}function h(){ra.unbind(window,"mousemove",p),ra.unbind(window,"touchmove",p),ra.unbind(window,"mouseup",h),ra.unbind(window,"touchend",h),u()}function d(){ra.unbind(window,"mousemove",m),ra.unbind(window,"touchmove",m),ra.unbind(window,"mouseup",d),ra.unbind(window,"touchend",d),u()}function c(){var e=zn(this.value);!1!==e?(a.__color.__state=e,a.setValue(a.__color.toOriginal())):this.value=a.__color.toString()}function u(){a.__onFinishChange&&a.__onFinishChange.call(a,a.__color.toOriginal())}function p(e){-1===e.type.indexOf("touch")&&e.preventDefault();var t=a.__saturation_field.getBoundingClientRect(),r=e.touches&&e.touches[0]||e,n=r.clientX,i=r.clientY,s=(n-t.left)/(t.right-t.left),o=1-(i-t.top)/(t.bottom-t.top);return o>1?o=1:o<0&&(o=0),s>1?s=1:s<0&&(s=0),a.__color.v=o,a.__color.s=s,a.setValue(a.__color.toOriginal()),!1}function m(e){-1===e.type.indexOf("touch")&&e.preventDefault();var t=a.__hue_field.getBoundingClientRect(),r=1-((e.touches&&e.touches[0]||e).clientY-t.top)/(t.bottom-t.top);return r>1?r=1:r<0&&(r=0),a.__color.h=360*r,a.setValue(a.__color.toOriginal()),!1}return Un.extend(n.__selector.style,{width:"122px",height:"102px",padding:"3px",backgroundColor:"#222",boxShadow:"0px 1px 3px rgba(0,0,0,0.3)"}),Un.extend(n.__field_knob.style,{position:"absolute",width:"12px",height:"12px",border:n.__field_knob_border+(n.__color.v<.5?"#fff":"#000"),boxShadow:"0px 1px 3px rgba(0,0,0,0.5)",borderRadius:"12px",zIndex:1}),Un.extend(n.__hue_knob.style,{position:"absolute",width:"15px",height:"2px",borderRight:"4px solid #fff",zIndex:1}),Un.extend(n.__saturation_field.style,{width:"100px",height:"100px",border:"1px solid #555",marginRight:"3px",display:"inline-block",cursor:"pointer"}),Un.extend(s.style,{width:"100%",height:"100%",background:"none"}),ma(s,"top","rgba(0,0,0,0)","#000"),Un.extend(n.__hue_field.style,{width:"15px",height:"100px",border:"1px solid #555",cursor:"ns-resize",position:"absolute",top:"3px",right:"3px"}),(i=n.__hue_field).style.background="",i.style.cssText+="background: -moz-linear-gradient(top, #ff0000 0%, #ff00ff 17%, #0000ff 34%, #00ffff 50%, #00ff00 67%, #ffff00 84%, #ff0000 100%);",i.style.cssText+="background: -webkit-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",i.style.cssText+="background: -o-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",i.style.cssText+="background: -ms-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",i.style.cssText+="background: linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",Un.extend(n.__input.style,{outline:"none",textAlign:"center",color:"#fff",border:0,fontWeight:"bold",textShadow:n.__input_textShadow+"rgba(0,0,0,0.7)"}),ra.bind(n.__saturation_field,"mousedown",o),ra.bind(n.__saturation_field,"touchstart",o),ra.bind(n.__field_knob,"mousedown",o),ra.bind(n.__field_knob,"touchstart",o),ra.bind(n.__hue_field,"mousedown",l),ra.bind(n.__hue_field,"touchstart",l),n.__saturation_field.appendChild(s),n.__selector.appendChild(n.__field_knob),n.__selector.appendChild(n.__saturation_field),n.__selector.appendChild(n.__hue_field),n.__hue_field.appendChild(n.__hue_knob),n.domElement.appendChild(n.__input),n.domElement.appendChild(n.__selector),n.updateDisplay(),n}return Xn(t,e),Kn(t,[{key:"updateDisplay",value:function(){var e=zn(this.getValue());if(!1!==e){var t=!1;Un.each(Qn.COMPONENTS,(function(r){if(!Un.isUndefined(e[r])&&!Un.isUndefined(this.__color.__state[r])&&e[r]!==this.__color.__state[r])return t=!0,{}}),this),t&&Un.extend(this.__color.__state,e)}Un.extend(this.__temp.__state,this.__color.__state),this.__temp.a=1;var r=this.__color.v<.5||this.__color.s>.5?255:0,n=255-r;Un.extend(this.__field_knob.style,{marginLeft:100*this.__color.s-7+"px",marginTop:100*(1-this.__color.v)-7+"px",backgroundColor:this.__temp.toHexString(),border:this.__field_knob_border+"rgb("+r+","+r+","+r+")"}),this.__hue_knob.style.marginTop=100*(1-this.__color.h/360)+"px",this.__temp.s=1,this.__temp.v=1,ma(this.__saturation_field,"left","#fff",this.__temp.toHexString()),this.__input.value=this.__color.toString(),Un.extend(this.__input.style,{backgroundColor:this.__color.toHexString(),color:"rgb("+r+","+r+","+r+")",textShadow:this.__input_textShadow+"rgba("+n+","+n+","+n+",.7)"})}}]),t}(Jn),pa=["-moz-","-o-","-webkit-","-ms-",""];function ma(e,t,r,n){e.style.background="",Un.each(pa,(function(a){e.style.cssText+="background: "+a+"linear-gradient("+t+", "+r+" 0%, "+n+" 100%); "}))}var fa='<div id="dg-save" class="dg dialogue">\n\n Here\'s the new load parameter for your <code>GUI</code>\'s constructor:\n\n <textarea id="dg-new-constructor"></textarea>\n\n <div id="dg-save-locally">\n\n <input id="dg-local-storage" type="checkbox"/> Automatically save\n values to <code>localStorage</code> on exit.\n\n <div id="dg-local-explain">The values saved to <code>localStorage</code> will\n override those passed to <code>dat.GUI</code>\'s constructor. This makes it\n easier to work incrementally, but <code>localStorage</code> is fragile,\n and your friends may not see the same values you do.\n\n </div>\n\n </div>\n\n</div>',ga=function(e,t){var r=e[t];return Un.isArray(arguments[2])||Un.isObject(arguments[2])?new aa(e,t,arguments[2]):Un.isNumber(r)?Un.isNumber(arguments[2])&&Un.isNumber(arguments[3])?Un.isNumber(arguments[4])?new da(e,t,arguments[2],arguments[3],arguments[4]):new da(e,t,arguments[2],arguments[3]):Un.isNumber(arguments[4])?new la(e,t,{min:arguments[2],max:arguments[3],step:arguments[4]}):new la(e,t,{min:arguments[2],max:arguments[3]}):Un.isString(r)?new ia(e,t):Un.isFunction(r)?new ca(e,t,""):Un.isBoolean(r)?new na(e,t):null},va=window.requestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(e){setTimeout(e,1e3/60)},wa=function(){function e(){Gn(this,e),this.backgroundElement=document.createElement("div"),Un.extend(this.backgroundElement.style,{backgroundColor:"rgba(0,0,0,0.8)",top:0,left:0,display:"none",zIndex:"1000",opacity:0,WebkitTransition:"opacity 0.2s linear",transition:"opacity 0.2s linear"}),ra.makeFullscreen(this.backgroundElement),this.backgroundElement.style.position="fixed",this.domElement=document.createElement("div"),Un.extend(this.domElement.style,{position:"fixed",display:"none",zIndex:"1001",opacity:0,WebkitTransition:"-webkit-transform 0.2s ease-out, opacity 0.2s linear",transition:"transform 0.2s ease-out, opacity 0.2s linear"}),document.body.appendChild(this.backgroundElement),document.body.appendChild(this.domElement);var t=this;ra.bind(this.backgroundElement,"click",(function(){t.hide()}))}return Kn(e,[{key:"show",value:function(){var e=this;this.backgroundElement.style.display="block",this.domElement.style.display="block",this.domElement.style.opacity=0,this.domElement.style.webkitTransform="scale(1.1)",this.layout(),Un.defer((function(){e.backgroundElement.style.opacity=1,e.domElement.style.opacity=1,e.domElement.style.webkitTransform="scale(1)"}))}},{key:"hide",value:function(){var e=this,t=function t(){e.domElement.style.display="none",e.backgroundElement.style.display="none",ra.unbind(e.domElement,"webkitTransitionEnd",t),ra.unbind(e.domElement,"transitionend",t),ra.unbind(e.domElement,"oTransitionEnd",t)};ra.bind(this.domElement,"webkitTransitionEnd",t),ra.bind(this.domElement,"transitionend",t),ra.bind(this.domElement,"oTransitionEnd",t),this.backgroundElement.style.opacity=0,this.domElement.style.opacity=0,this.domElement.style.webkitTransform="scale(1.1)"}},{key:"layout",value:function(){this.domElement.style.left=window.innerWidth/2-ra.getWidth(this.domElement)/2+"px",this.domElement.style.top=window.innerHeight/2-ra.getHeight(this.domElement)/2+"px"}}]),e}();!function(e,t){var r=document,n=document.createElement("style");n.type="text/css",n.innerHTML=e;var a=r.getElementsByTagName("head")[0];try{a.appendChild(n)}catch(e){}}(function(e){if("undefined"!=typeof window){var t=document.createElement("style");return t.setAttribute("type","text/css"),t.innerHTML=e,document.head.appendChild(t),e}}(".dg ul{list-style:none;margin:0;padding:0;width:100%;clear:both}.dg.ac{position:fixed;top:0;left:0;right:0;height:0;z-index:0}.dg:not(.ac) .main{overflow:hidden}.dg.main{-webkit-transition:opacity .1s linear;-o-transition:opacity .1s linear;-moz-transition:opacity .1s linear;transition:opacity .1s linear}.dg.main.taller-than-window{overflow-y:auto}.dg.main.taller-than-window .close-button{opacity:1;margin-top:-1px;border-top:1px solid #2c2c2c}.dg.main ul.closed .close-button{opacity:1 !important}.dg.main:hover .close-button,.dg.main .close-button.drag{opacity:1}.dg.main .close-button{-webkit-transition:opacity .1s linear;-o-transition:opacity .1s linear;-moz-transition:opacity .1s linear;transition:opacity .1s linear;border:0;line-height:19px;height:20px;cursor:pointer;text-align:center;background-color:#000}.dg.main .close-button.close-top{position:relative}.dg.main .close-button.close-bottom{position:absolute}.dg.main .close-button:hover{background-color:#111}.dg.a{float:right;margin-right:15px;overflow-y:visible}.dg.a.has-save>ul.close-top{margin-top:0}.dg.a.has-save>ul.close-bottom{margin-top:27px}.dg.a.has-save>ul.closed{margin-top:0}.dg.a .save-row{top:0;z-index:1002}.dg.a .save-row.close-top{position:relative}.dg.a .save-row.close-bottom{position:fixed}.dg li{-webkit-transition:height .1s ease-out;-o-transition:height .1s ease-out;-moz-transition:height .1s ease-out;transition:height .1s ease-out;-webkit-transition:overflow .1s linear;-o-transition:overflow .1s linear;-moz-transition:overflow .1s linear;transition:overflow .1s linear}.dg li:not(.folder){cursor:auto;height:27px;line-height:27px;padding:0 4px 0 5px}.dg li.folder{padding:0;border-left:4px solid rgba(0,0,0,0)}.dg li.title{cursor:pointer;margin-left:-4px}.dg .closed li:not(.title),.dg .closed ul li,.dg .closed ul li>*{height:0;overflow:hidden;border:0}.dg .cr{clear:both;padding-left:3px;height:27px;overflow:hidden}.dg .property-name{cursor:default;float:left;clear:left;width:40%;overflow:hidden;text-overflow:ellipsis}.dg .cr.function .property-name{width:100%}.dg .c{float:left;width:60%;position:relative}.dg .c input[type=text]{border:0;margin-top:4px;padding:3px;width:100%;float:right}.dg .has-slider input[type=text]{width:30%;margin-left:0}.dg .slider{float:left;width:66%;margin-left:-5px;margin-right:0;height:19px;margin-top:4px}.dg .slider-fg{height:100%}.dg .c input[type=checkbox]{margin-top:7px}.dg .c select{margin-top:5px}.dg .cr.function,.dg .cr.function .property-name,.dg .cr.function *,.dg .cr.boolean,.dg .cr.boolean *{cursor:pointer}.dg .cr.color{overflow:visible}.dg .selector{display:none;position:absolute;margin-left:-9px;margin-top:23px;z-index:10}.dg .c:hover .selector,.dg .selector.drag{display:block}.dg li.save-row{padding:0}.dg li.save-row .button{display:inline-block;padding:0px 6px}.dg.dialogue{background-color:#222;width:460px;padding:15px;font-size:13px;line-height:15px}#dg-new-constructor{padding:10px;color:#222;font-family:Monaco, monospace;font-size:10px;border:0;resize:none;box-shadow:inset 1px 1px 1px #888;word-wrap:break-word;margin:12px 0;display:block;width:440px;overflow-y:scroll;height:100px;position:relative}#dg-local-explain{display:none;font-size:11px;line-height:17px;border-radius:3px;background-color:#333;padding:8px;margin-top:10px}#dg-local-explain code{font-size:10px}#dat-gui-save-locally{display:none}.dg{color:#eee;font:11px 'Lucida Grande', sans-serif;text-shadow:0 -1px 0 #111}.dg.main::-webkit-scrollbar{width:5px;background:#1a1a1a}.dg.main::-webkit-scrollbar-corner{height:0;display:none}.dg.main::-webkit-scrollbar-thumb{border-radius:5px;background:#676767}.dg li:not(.folder){background:#1a1a1a;border-bottom:1px solid #2c2c2c}.dg li.save-row{line-height:25px;background:#dad5cb;border:0}.dg li.save-row select{margin-left:5px;width:108px}.dg li.save-row .button{margin-left:5px;margin-top:1px;border-radius:2px;font-size:9px;line-height:7px;padding:4px 4px 5px 4px;background:#c5bdad;color:#fff;text-shadow:0 1px 0 #b0a58f;box-shadow:0 -1px 0 #b0a58f;cursor:pointer}.dg li.save-row .button.gears{background:#c5bdad url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAsAAAANCAYAAAB/9ZQ7AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAQJJREFUeNpiYKAU/P//PwGIC/ApCABiBSAW+I8AClAcgKxQ4T9hoMAEUrxx2QSGN6+egDX+/vWT4e7N82AMYoPAx/evwWoYoSYbACX2s7KxCxzcsezDh3evFoDEBYTEEqycggWAzA9AuUSQQgeYPa9fPv6/YWm/Acx5IPb7ty/fw+QZblw67vDs8R0YHyQhgObx+yAJkBqmG5dPPDh1aPOGR/eugW0G4vlIoTIfyFcA+QekhhHJhPdQxbiAIguMBTQZrPD7108M6roWYDFQiIAAv6Aow/1bFwXgis+f2LUAynwoIaNcz8XNx3Dl7MEJUDGQpx9gtQ8YCueB+D26OECAAQDadt7e46D42QAAAABJRU5ErkJggg==) 2px 1px no-repeat;height:7px;width:8px}.dg li.save-row .button:hover{background-color:#bab19e;box-shadow:0 -1px 0 #b0a58f}.dg li.folder{border-bottom:0}.dg li.title{padding-left:16px;background:#000 url(data:image/gif;base64,R0lGODlhBQAFAJEAAP////Pz8////////yH5BAEAAAIALAAAAAAFAAUAAAIIlI+hKgFxoCgAOw==) 6px 10px no-repeat;cursor:pointer;border-bottom:1px solid rgba(255,255,255,0.2)}.dg .closed li.title{background-image:url(data:image/gif;base64,R0lGODlhBQAFAJEAAP////Pz8////////yH5BAEAAAIALAAAAAAFAAUAAAIIlGIWqMCbWAEAOw==)}.dg .cr.boolean{border-left:3px solid #806787}.dg .cr.color{border-left:3px solid}.dg .cr.function{border-left:3px solid #e61d5f}.dg .cr.number{border-left:3px solid #2FA1D6}.dg .cr.number input[type=text]{color:#2FA1D6}.dg .cr.string{border-left:3px solid #1ed36f}.dg .cr.string input[type=text]{color:#1ed36f}.dg .cr.function:hover,.dg .cr.boolean:hover{background:#111}.dg .c input[type=text]{background:#303030;outline:none}.dg .c input[type=text]:hover{background:#3c3c3c}.dg .c input[type=text]:focus{background:#494949;color:#fff}.dg .c .slider{background:#303030;cursor:ew-resize}.dg .c .slider-fg{background:#2FA1D6;max-width:100%}.dg .c .slider:hover{background:#3c3c3c}.dg .c .slider:hover .slider-fg{background:#44abda}\n"));var ba=function(){try{return!!window.localStorage}catch(e){return!1}}(),ya=void 0,_a=!0,xa=void 0,Sa=!1,Ca=[],Ma=function e(t){var r=this,n=t||{};this.domElement=document.createElement("div"),this.__ul=document.createElement("ul"),this.domElement.appendChild(this.__ul),ra.addClass(this.domElement,"dg"),this.__folders={},this.__controllers=[],this.__rememberedObjects=[],this.__rememberedObjectIndecesToControllers=[],this.__listening=[],n=Un.defaults(n,{closeOnTop:!1,autoPlace:!0,width:e.DEFAULT_WIDTH}),n=Un.defaults(n,{resizable:n.autoPlace,hideable:n.autoPlace}),Un.isUndefined(n.load)?n.load={preset:"Default"}:n.preset&&(n.load.preset=n.preset),Un.isUndefined(n.parent)&&n.hideable&&Ca.push(this),n.resizable=Un.isUndefined(n.parent)&&n.resizable,n.autoPlace&&Un.isUndefined(n.scrollable)&&(n.scrollable=!0);var a,i=ba&&"true"===localStorage.getItem(Ia(0,"isLocal")),s=void 0,o=void 0;if(Object.defineProperties(this,{parent:{get:function(){return n.parent}},scrollable:{get:function(){return n.scrollable}},autoPlace:{get:function(){return n.autoPlace}},closeOnTop:{get:function(){return n.closeOnTop}},preset:{get:function(){return r.parent?r.getRoot().preset:n.load.preset},set:function(e){r.parent?r.getRoot().preset=e:n.load.preset=e,function(e){for(var t=0;t<e.__preset_select.length;t++)e.__preset_select[t].value===e.preset&&(e.__preset_select.selectedIndex=t)}(this),r.revert()}},width:{get:function(){return n.width},set:function(e){n.width=e,Ua(r,e)}},name:{get:function(){return n.name},set:function(e){n.name=e,o&&(o.innerHTML=n.name)}},closed:{get:function(){return n.closed},set:function(t){n.closed=t,n.closed?ra.addClass(r.__ul,e.CLASS_CLOSED):ra.removeClass(r.__ul,e.CLASS_CLOSED),this.onResize(),r.__closeButton&&(r.__closeButton.innerHTML=t?e.TEXT_OPEN:e.TEXT_CLOSED)}},load:{get:function(){return n.load}},useLocalStorage:{get:function(){return i},set:function(e){ba&&(i=e,e?ra.bind(window,"unload",s):ra.unbind(window,"unload",s),localStorage.setItem(Ia(0,"isLocal"),e))}}}),Un.isUndefined(n.parent)){if(this.closed=n.closed||!1,ra.addClass(this.domElement,e.CLASS_MAIN),ra.makeSelectable(this.domElement,!1),ba&&i){r.useLocalStorage=!0;var l=localStorage.getItem(Ia(0,"gui"));l&&(n.load=JSON.parse(l))}this.__closeButton=document.createElement("div"),this.__closeButton.innerHTML=e.TEXT_CLOSED,ra.addClass(this.__closeButton,e.CLASS_CLOSE_BUTTON),n.closeOnTop?(ra.addClass(this.__closeButton,e.CLASS_CLOSE_TOP),this.domElement.insertBefore(this.__closeButton,this.domElement.childNodes[0])):(ra.addClass(this.__closeButton,e.CLASS_CLOSE_BOTTOM),this.domElement.appendChild(this.__closeButton)),ra.bind(this.__closeButton,"click",(function(){r.closed=!r.closed}))}else{void 0===n.closed&&(n.closed=!0);var h=document.createTextNode(n.name);ra.addClass(h,"controller-name"),o=Ta(r,h),ra.addClass(this.__ul,e.CLASS_CLOSED),ra.addClass(o,"title"),ra.bind(o,"click",(function(e){return e.preventDefault(),r.closed=!r.closed,!1})),n.closed||(this.closed=!1)}n.autoPlace&&(Un.isUndefined(n.parent)&&(_a&&(xa=document.createElement("div"),ra.addClass(xa,"dg"),ra.addClass(xa,e.CLASS_AUTO_PLACE_CONTAINER),document.body.appendChild(xa),_a=!1),xa.appendChild(this.domElement),ra.addClass(this.domElement,e.CLASS_AUTO_PLACE)),this.parent||Ua(r,n.width)),this.__resizeHandler=function(){r.onResizeDebounced()},ra.bind(window,"resize",this.__resizeHandler),ra.bind(this.__ul,"webkitTransitionEnd",this.__resizeHandler),ra.bind(this.__ul,"transitionend",this.__resizeHandler),ra.bind(this.__ul,"oTransitionEnd",this.__resizeHandler),this.onResize(),n.resizable&&La(this),s=function(){ba&&"true"===localStorage.getItem(Ia(0,"isLocal"))&&localStorage.setItem(Ia(0,"gui"),JSON.stringify(r.getSaveObject()))},this.saveToLocalStorageIfPossible=s,n.parent||((a=r.getRoot()).width+=1,Un.defer((function(){a.width-=1})))};function Ta(e,t,r){var n=document.createElement("li");return t&&n.appendChild(t),r?e.__ul.insertBefore(n,r):e.__ul.appendChild(n),e.onResize(),n}function Aa(e){ra.unbind(window,"resize",e.__resizeHandler),e.saveToLocalStorageIfPossible&&ra.unbind(window,"unload",e.saveToLocalStorageIfPossible)}function Pa(e,t){var r=e.__preset_select[e.__preset_select.selectedIndex];r.innerHTML=t?r.value+"*":r.value}function Ra(e,t){var r=e.getRoot(),n=r.__rememberedObjects.indexOf(t.object);if(-1!==n){var a=r.__rememberedObjectIndecesToControllers[n];if(void 0===a&&(a={},r.__rememberedObjectIndecesToControllers[n]=a),a[t.property]=t,r.load&&r.load.remembered){var i=r.load.remembered,s=void 0;if(i[e.preset])s=i[e.preset];else{if(!i.Default)return;s=i.Default}if(s[n]&&void 0!==s[n][t.property]){var o=s[n][t.property];t.initialValue=o,t.setValue(o)}}}}function Ea(e,t,r,n){if(void 0===t[r])throw new Error('Object "'+t+'" has no property "'+r+'"');var a=void 0;if(n.color)a=new ua(t,r);else{var i=[t,r].concat(n.factoryArgs);a=ga.apply(e,i)}n.before instanceof Jn&&(n.before=n.before.__li),Ra(e,a),ra.addClass(a.domElement,"c");var s=document.createElement("span");ra.addClass(s,"property-name"),s.innerHTML=a.property;var o=document.createElement("div");o.appendChild(s),o.appendChild(a.domElement);var l=Ta(e,o,n.before);return ra.addClass(l,Ma.CLASS_CONTROLLER_ROW),a instanceof ua?ra.addClass(l,"color"):ra.addClass(l,Vn(a.getValue())),function(e,t,r){if(r.__li=t,r.__gui=e,Un.extend(r,{options:function(t){if(arguments.length>1){var n=r.__li.nextElementSibling;return r.remove(),Ea(e,r.object,r.property,{before:n,factoryArgs:[Un.toArray(arguments)]})}if(Un.isArray(t)||Un.isObject(t)){var a=r.__li.nextElementSibling;return r.remove(),Ea(e,r.object,r.property,{before:a,factoryArgs:[t]})}},name:function(e){return r.__li.firstElementChild.firstElementChild.innerHTML=e,r},listen:function(){return r.__gui.listen(r),r},remove:function(){return r.__gui.remove(r),r}}),r instanceof da){var n=new la(r.object,r.property,{min:r.__min,max:r.__max,step:r.__step});Un.each(["updateDisplay","onChange","onFinishChange","step","min","max"],(function(e){var t=r[e],a=n[e];r[e]=n[e]=function(){var e=Array.prototype.slice.call(arguments);return a.apply(n,e),t.apply(r,e)}})),ra.addClass(t,"has-slider"),r.domElement.insertBefore(n.domElement,r.domElement.firstElementChild)}else if(r instanceof la){var a=function(t){if(Un.isNumber(r.__min)&&Un.isNumber(r.__max)){var n=r.__li.firstElementChild.firstElementChild.innerHTML,a=r.__gui.__listening.indexOf(r)>-1;r.remove();var i=Ea(e,r.object,r.property,{before:r.__li.nextElementSibling,factoryArgs:[r.__min,r.__max,r.__step]});return i.name(n),a&&i.listen(),i}return t};r.min=Un.compose(a,r.min),r.max=Un.compose(a,r.max)}else r instanceof na?(ra.bind(t,"click",(function(){ra.fakeEvent(r.__checkbox,"click")})),ra.bind(r.__checkbox,"click",(function(e){e.stopPropagation()}))):r instanceof ca?(ra.bind(t,"click",(function(){ra.fakeEvent(r.__button,"click")})),ra.bind(t,"mouseover",(function(){ra.addClass(r.__button,"hover")})),ra.bind(t,"mouseout",(function(){ra.removeClass(r.__button,"hover")}))):r instanceof ua&&(ra.addClass(t,"color"),r.updateDisplay=Un.compose((function(e){return t.style.borderLeftColor=r.__color.toString(),e}),r.updateDisplay),r.updateDisplay());r.setValue=Un.compose((function(t){return e.getRoot().__preset_select&&r.isModified()&&Pa(e.getRoot(),!0),t}),r.setValue)}(e,l,a),e.__controllers.push(a),a}function Ia(e,t){return document.location.href+"."+t}function ka(e,t,r){var n=document.createElement("option");n.innerHTML=t,n.value=t,e.__preset_select.appendChild(n),r&&(e.__preset_select.selectedIndex=e.__preset_select.length-1)}function Oa(e,t){t.style.display=e.useLocalStorage?"block":"none"}function Da(e){var t=e.__save_row=document.createElement("li");ra.addClass(e.domElement,"has-save"),e.__ul.insertBefore(t,e.__ul.firstChild),ra.addClass(t,"save-row");var r=document.createElement("span");r.innerHTML=" ",ra.addClass(r,"button gears");var n=document.createElement("span");n.innerHTML="Save",ra.addClass(n,"button"),ra.addClass(n,"save");var a=document.createElement("span");a.innerHTML="New",ra.addClass(a,"button"),ra.addClass(a,"save-as");var i=document.createElement("span");i.innerHTML="Revert",ra.addClass(i,"button"),ra.addClass(i,"revert");var s=e.__preset_select=document.createElement("select");if(e.load&&e.load.remembered?Un.each(e.load.remembered,(function(t,r){ka(e,r,r===e.preset)})):ka(e,"Default",!1),ra.bind(s,"change",(function(){for(var t=0;t<e.__preset_select.length;t++)e.__preset_select[t].innerHTML=e.__preset_select[t].value;e.preset=this.value})),t.appendChild(s),t.appendChild(r),t.appendChild(n),t.appendChild(a),t.appendChild(i),ba){var o=document.getElementById("dg-local-explain"),l=document.getElementById("dg-local-storage");document.getElementById("dg-save-locally").style.display="block","true"===localStorage.getItem(Ia(0,"isLocal"))&&l.setAttribute("checked","checked"),Oa(e,o),ra.bind(l,"change",(function(){e.useLocalStorage=!e.useLocalStorage,Oa(e,o)}))}var h=document.getElementById("dg-new-constructor");ra.bind(h,"keydown",(function(e){!e.metaKey||67!==e.which&&67!==e.keyCode||ya.hide()})),ra.bind(r,"click",(function(){h.innerHTML=JSON.stringify(e.getSaveObject(),void 0,2),ya.show(),h.focus(),h.select()})),ra.bind(n,"click",(function(){e.save()})),ra.bind(a,"click",(function(){var t=prompt("Enter a new preset name.");t&&e.saveAs(t)})),ra.bind(i,"click",(function(){e.revert()}))}function La(e){var t=void 0;function r(r){return r.preventDefault(),e.width+=t-r.clientX,e.onResize(),t=r.clientX,!1}function n(){ra.removeClass(e.__closeButton,Ma.CLASS_DRAG),ra.unbind(window,"mousemove",r),ra.unbind(window,"mouseup",n)}function a(a){return a.preventDefault(),t=a.clientX,ra.addClass(e.__closeButton,Ma.CLASS_DRAG),ra.bind(window,"mousemove",r),ra.bind(window,"mouseup",n),!1}e.__resize_handle=document.createElement("div"),Un.extend(e.__resize_handle.style,{width:"6px",marginLeft:"-3px",height:"200px",cursor:"ew-resize",position:"absolute"}),ra.bind(e.__resize_handle,"mousedown",a),ra.bind(e.__closeButton,"mousedown",a),e.domElement.insertBefore(e.__resize_handle,e.domElement.firstElementChild)}function Ua(e,t){e.domElement.style.width=t+"px",e.__save_row&&e.autoPlace&&(e.__save_row.style.width=t+"px"),e.__closeButton&&(e.__closeButton.style.width=t+"px")}function Fa(e,t){var r={};return Un.each(e.__rememberedObjects,(function(n,a){var i={},s=e.__rememberedObjectIndecesToControllers[a];Un.each(s,(function(e,r){i[r]=t?e.initialValue:e.getValue()})),r[a]=i})),r}Ma.toggleHide=function(){Sa=!Sa,Un.each(Ca,(function(e){e.domElement.style.display=Sa?"none":""}))},Ma.CLASS_AUTO_PLACE="a",Ma.CLASS_AUTO_PLACE_CONTAINER="ac",Ma.CLASS_MAIN="main",Ma.CLASS_CONTROLLER_ROW="cr",Ma.CLASS_TOO_TALL="taller-than-window",Ma.CLASS_CLOSED="closed",Ma.CLASS_CLOSE_BUTTON="close-button",Ma.CLASS_CLOSE_TOP="close-top",Ma.CLASS_CLOSE_BOTTOM="close-bottom",Ma.CLASS_DRAG="drag",Ma.DEFAULT_WIDTH=245,Ma.TEXT_CLOSED="Close Controls",Ma.TEXT_OPEN="Open Controls",Ma._keydownHandler=function(e){"text"===document.activeElement.type||72!==e.which&&72!==e.keyCode||Ma.toggleHide()},ra.bind(window,"keydown",Ma._keydownHandler,!1),Un.extend(Ma.prototype,{add:function(e,t){return Ea(this,e,t,{factoryArgs:Array.prototype.slice.call(arguments,2)})},addColor:function(e,t){return Ea(this,e,t,{color:!0})},remove:function(e){this.__ul.removeChild(e.__li),this.__controllers.splice(this.__controllers.indexOf(e),1);var t=this;Un.defer((function(){t.onResize()}))},destroy:function(){if(this.parent)throw new Error("Only the root GUI should be removed with .destroy(). For subfolders, use gui.removeFolder(folder) instead.");this.autoPlace&&xa.removeChild(this.domElement);var e=this;Un.each(this.__folders,(function(t){e.removeFolder(t)})),ra.unbind(window,"keydown",Ma._keydownHandler,!1),Aa(this)},addFolder:function(e){if(void 0!==this.__folders[e])throw new Error('You already have a folder in this GUI by the name "'+e+'"');var t={name:e,parent:this};t.autoPlace=this.autoPlace,this.load&&this.load.folders&&this.load.folders[e]&&(t.closed=this.load.folders[e].closed,t.load=this.load.folders[e]);var r=new Ma(t);this.__folders[e]=r;var n=Ta(this,r.domElement);return ra.addClass(n,"folder"),r},removeFolder:function(e){this.__ul.removeChild(e.domElement.parentElement),delete this.__folders[e.name],this.load&&this.load.folders&&this.load.folders[e.name]&&delete this.load.folders[e.name],Aa(e);var t=this;Un.each(e.__folders,(function(t){e.removeFolder(t)})),Un.defer((function(){t.onResize()}))},open:function(){this.closed=!1},close:function(){this.closed=!0},hide:function(){this.domElement.style.display="none"},show:function(){this.domElement.style.display=""},onResize:function(){var e=this.getRoot();if(e.scrollable){var t=ra.getOffset(e.__ul).top,r=0;Un.each(e.__ul.childNodes,(function(t){e.autoPlace&&t===e.__save_row||(r+=ra.getHeight(t))})),window.innerHeight-t-20<r?(ra.addClass(e.domElement,Ma.CLASS_TOO_TALL),e.__ul.style.height=window.innerHeight-t-20+"px"):(ra.removeClass(e.domElement,Ma.CLASS_TOO_TALL),e.__ul.style.height="auto")}e.__resize_handle&&Un.defer((function(){e.__resize_handle.style.height=e.__ul.offsetHeight+"px"})),e.__closeButton&&(e.__closeButton.style.width=e.width+"px")},onResizeDebounced:Un.debounce((function(){this.onResize()}),50),remember:function(){if(Un.isUndefined(ya)&&((ya=new wa).domElement.innerHTML=fa),this.parent)throw new Error("You can only call remember on a top level GUI.");var e=this;Un.each(Array.prototype.slice.call(arguments),(function(t){0===e.__rememberedObjects.length&&Da(e),-1===e.__rememberedObjects.indexOf(t)&&e.__rememberedObjects.push(t)})),this.autoPlace&&Ua(this,this.width)},getRoot:function(){for(var e=this;e.parent;)e=e.parent;return e},getSaveObject:function(){var e=this.load;return e.closed=this.closed,this.__rememberedObjects.length>0&&(e.preset=this.preset,e.remembered||(e.remembered={}),e.remembered[this.preset]=Fa(this)),e.folders={},Un.each(this.__folders,(function(t,r){e.folders[r]=t.getSaveObject()})),e},save:function(){this.load.remembered||(this.load.remembered={}),this.load.remembered[this.preset]=Fa(this),Pa(this,!1),this.saveToLocalStorageIfPossible()},saveAs:function(e){this.load.remembered||(this.load.remembered={},this.load.remembered.Default=Fa(this,!0)),this.load.remembered[e]=Fa(this),this.preset=e,ka(this,e,!0),this.saveToLocalStorageIfPossible()},revert:function(e){Un.each(this.__controllers,(function(t){this.getRoot().load.remembered?Ra(e||this.getRoot(),t):t.setValue(t.initialValue),t.__onFinishChange&&t.__onFinishChange.call(t,t.getValue())}),this),Un.each(this.__folders,(function(e){e.revert(e)})),e||Pa(this.getRoot(),!1)},listen:function(e){var t=0===this.__listening.length;this.__listening.push(e),t&&function e(t){0!==t.length&&va.call(window,(function(){e(t)})),Un.each(t,(function(e){e.updateDisplay()}))}(this.__listening)},updateDisplay:function(){Un.each(this.__controllers,(function(e){e.updateDisplay()})),Un.each(this.__folders,(function(e){e.updateDisplay()}))}});var Ba=Ma;e("j",(e,t,r,n)=>{if(!e||!t||0===r||0===n)return new s;let a=e.clone(),i=r/2,o=n/2;return a.project(t),a.x=Math.floor(a.x*i+i),a.y=Math.floor(-a.y*o+o),a.z=e.distanceTo(t.position),a});const Na=e("k",(e,t)=>{t||(t=new s(0,0,0));let r=new s(e.size.x/1e3,e.size.z/1e3,e.size.y/1e3),n=new s(e.origin.x/1e3,e.origin.z/1e3,e.origin.y/-1e3),a=new s(0,0,-r.z).add(n).sub(t),i=new s(r.x,r.y,0).add(n).add(t);return new be(a,i)});e("Q",(e,t)=>{let r=Mn(e.x),n=Mn(e.y),a=Mn(e.z),i=Mn(t.x),s=Mn(t.y),o=Mn(t.z);return r===i&&n===s&&a===o}),e("$",(e,t)=>{let r=Mn(e.w),n=Mn(e.x),a=Mn(e.y),i=Mn(e.z),s=Mn(t.w),o=Mn(t.x),l=Mn(t.y),h=Mn(t.z);return r===s&&n===o&&a===l&&i===h}),e("T",(e,t)=>{let r=Mn(e.x),n=Mn(e.y),a=Mn(t.x),i=Mn(t.y);return r===a&&n===i});let za=null;const Ha=()=>{if(za)return za;const e=new Uint8Array(4);for(let t=0;t<1;t++){const r=4*t;e[r]=255,e[r+1]=255,e[r+2]=255,e[r+3]=255}const t=new Pe(e,1,1,Ae);return t.needsUpdate=!0,t},ja=(e,t,r,n)=>{const a=new Uint8Array(4),i=Math.floor(255*e),s=Math.floor(255*t),o=Math.floor(255*r),l=Math.floor(255*n);for(let e=0;e<4;e++){const t=4*e;a[t]=i,a[t+1]=s,a[t+2]=o,a[t+3]=l}const h=new Pe(a,1,1,Ae);return h.needsUpdate=!0,h},Va=e("X",(e,t)=>Ga(null,e,t)),Ga=e("ao",(e,t,r)=>{e||(e=Ka()),e.name=t.id?t.id.toString():"",void 0!==t.shading.metallic&&(e.metalness=1===t.shading.metallic?1:.5,e.reflectivity=Re(t.shading.metallic,.5));let n=!1;if(t.shading.transmission&&t.shading.transmission>0?(e.opacity=1-t.shading.transmission,e.transparent=!0,e.depthWrite=!1,e.metalness=0,n=!0):void 0!==t.shading.alpha&&t.shading.alpha<1&&(e.transparent=t.shading.alpha<1,e.opacity=t.shading.alpha,e.depthWrite=t.shading.alpha>=1,e.metalness=.5*Math.max(0,t.shading.alpha),n=!0),e.aoMapIntensity=Re(t.shading.occlusion,1),e.roughness=Re(t.shading.roughness,.5),e.alphaTest=Re(t.shading.alphaCutoff,0),void 0!==t.shading.basecolor){const r=new h(t.shading.basecolor.r,t.shading.basecolor.g,t.shading.basecolor.b);e.color.copy(r.convertSRGBToLinear())}return n||t.shading.doubleSided?e.side=j:e.side=ce,e.map||(za||(za=Ha()),e.map=za),e.envMapIntensity=r,e}),Ka=()=>_n.createMeshPhysicalMaterial({});e("ap",e=>{let t=e.color.clone().convertLinearToSRGB(),r={alpha:e.opacity,metallic:e.reflectivity,basecolor:{r:t.r,g:t.g,b:t.b},roughness:e.roughness,doubleSided:e.side===j,alphaCutoff:e.alphaTest,transmission:e.transmission};return 1===e.metalness?r.metallic=1:r.metallic=e.reflectivity,r});let Wa=null;const Xa=e("Y",(e,t,r,n,a,i,s=16)=>(Wa||(Wa=new ue,Wa.crossOrigin=""),new Promise((o,l)=>{if(!e)return console.warn("trying to add a texture without image",t),void o();Wa.load(e,e=>{qa(e,t,r,n,a,i,s),o()},l)}))),qa=e("aq",(e,t,r,n,a,i,s=16)=>{e.anisotropy=n,e.wrapS=F,e.wrapT=F,"ORM"===t.mapping&&s<=8?console.warn("ORM maps are not supported on devices with only "+s+" texture units"):(e.repeat.set(a,i),"XYZ"===t.mapping?(r.normalMap=e,r.map===Ha()&&(r.map=null)):"ORM"===t.mapping?(r.aoMap=e,r.roughnessMap=e,r.metalnessMap=e):(e.colorSpace=M,r.map=e),"RGBA"===t.mapping&&(r.transparent=!0,r.name.includes("glow")&&(r.emissiveIntensity=.5,r.emissive=new h(16777215),r.emissiveMap=r.map)),r.needsUpdate=!0)}),Qa=e("Z",(e=!0)=>(window.__RML_GUI__||(window.__RML_GUI__=new Ba({autoPlace:e})),window.__RML_GUI__)),Ya=(e("af",(e,t)=>{let r=!1;for(const n of t){const t=n.getKernelObject();let a;if(2===t.wallType.value&&(a=Tn(t.rightNormal)),1===t.wallType.value&&(a=Tn(t.leftNormal)),!a)continue;let i=Tn(n.getPlanElement().getCenter());i=i.applyMatrix4(e.matrixWorldInverse),a=a.transformDirection(e.matrixWorldInverse);const s=i.dot(a)>=0;s!==n.getContainer().visible&&(r=!0),s?n.show():n.isSelected||n.hide()}return r}),e("ai",(e,t,r=!0)=>{if(!e.userData.tween)if(t)if(e.transparent=!0,r){let t={opacity:1};e.userData.tween=!0,new TWEEN.Tween(t).to({opacity:.2},400).easing(TWEEN.Easing.Sinusoidal.In).onUpdate(()=>{e.opacity=t.opacity}).onComplete(()=>{e.userData.tween=!1}).start()}else e.opacity=.2;else if(r){let t={opacity:.2};e.userData.tween=!0,new TWEEN.Tween(t).to({opacity:1},400).easing(TWEEN.Easing.Sinusoidal.In).onUpdate(()=>{e.opacity=t.opacity}).onComplete(()=>{e.transparent=!1,e.userData.tween=!1}).start()}else e.opacity=1,e.transparent=!1}),e("a7",(e,t)=>{e.traverse(e=>{if(e instanceof K&&TWEEN){const r=e.material;e.userData.tween&&e.userData.tween.stop();const n={opacity:r.opacity};t.transparent&&(r.transparent=t.transparent),e.userData.tween=new TWEEN.Tween(n).to(t,250).easing(TWEEN.Easing.Linear.None).onUpdate(()=>{r.opacity=n.opacity}).onStop(()=>{t.transparent||(r.transparent=t.transparent),r.opacity=t.opacity,r.needsUpdate=!0,e.userData.tween=void 0}).onComplete(()=>{t.transparent||(r.transparent=t.transparent),r.needsUpdate=!0,e.userData.tween=void 0}).start()}})}),e("ag",e=>{e.traverse(e=>{if(e instanceof K&&TWEEN){let t=e.material;if(0===t.opacity)return;let r={opacity:0,transparent:!0},n={opacity:t.opacity,transparent:t.transparent};t.transparent=r.transparent,t.opacity=r.opacity,new TWEEN.Tween(r).to(n,500).easing(TWEEN.Easing.Linear.None).onUpdate(()=>{t.opacity=r.opacity}).onComplete(()=>{t.transparent=n.transparent}).start()}})})),Za=e("s",e=>{"Mesh"===e.type?$a(e):Ja(e)}),Ja=e=>{e&&e.children&&0!==e.children.length&&e.children.forEach(e=>{$a(e)})},$a=e("g",e=>{e&&(e.material&&ti(e.material),e.geometry&&ei(e.geometry),e.children&&e.children.length>0&&Ja(e))}),ei=e=>{e&&e.dispose()},ti=e=>{e&&(e.map&&e.map.dispose(),e.normalMap&&e.normalMap.dispose(),e.dispose())};let ri;e("v",e=>0===e.x&&0===e.y&&0===e.z);const ni=(e,t)=>{let r="";return e||""===e?(e.materialId&&""!==e.materialId?r=e.materialId:e.catalogItemId&&""!==e.catalogItemId?r=e.catalogItemId:e.rgbValue>0?r="rgb"+JSON.stringify(e.rgbValue):e.length>0?r=e:t&&1===t.value?r="default_wall_material_"+e.getSourceType().value:t&&7===t.value&&(r="default_ceiling_material_"+e.getSourceType().value),r):null},ai=(e("u",e=>{let t=e.getWorldDirection(new s).clone();t.y=0,t.lengthSq()<.01&&(t=new s(0,1,0),t.applyQuaternion(e.quaternion),t.y=0),t.normalize();let r=Math.asin(t.x);return t.z<0&&(r=Math.PI-r),r<0&&(r+=2*Math.PI),r}),e("U",(e,t)=>{if(!e||!t)return 0;const r=e.clone().expandByScalar(.001).containsBox(t),n=t.clone().expandByScalar(.001).containsBox(e);return n&&r||!n&&!r?0:!0===r?1:-1}),e("aj",(e,t,r,n=1)=>{const a=t>r,i=a?15:0,o=a?0:10,l=e.getSize(new s),h=e.getCenter(new s);let d=l.x>2*i?l.x/2:i,c=l.z>2*o?l.z/2:o;return d*=n,c*=n,new be(new s(h.x-d,h.y,h.z-c),new s(h.x+d,h.y,h.z+c))}),e("ab",e=>{const{x:t,y:r}=e;return{x:t,y:r}})),ii=e=>{const{x:t,y:r,z:n}=e;return{x:t,y:r,z:n}};e("ah",(e,t,r)=>(new s).setFromSphericalCoords(e,Math.PI*(1-r),2*Math.PI*(1-t)));const si=e("e",{CAMERA_2D:"2D",CAMERA_3D:"3D",CAMERA_FP:"FP"});e("a2",e=>{if(!e)return si.CAMERA_3D;let t=e.toUpperCase();return-1===Object.values(si).indexOf(t)&&(t=si.CAMERA_3D),t});var oi=e("a5","static/default_256-f1c66a2764f88cc0.exr");class li{constructor(e){this.autoQuality=!1,this.colors=Ee,this.unit=null,this.unitStringType=null,this.meshSelection=!0,this.stats=!1,this._measureTraffic=!1,this.disableDebugGUI=!1,this.disableEnvMap=!1,this.envMapUrl=oi,this.envMapIntensity=1.5,this.legacyLight=!1,this.restrictionLevel=0,this.dls=null,this.ls=null,this.cameraSpacing=0,this.transparentHighlighting=!0,this.featureFlags={pulsePreview:!1,reDock:!1},this.mode=si.CAMERA_3D,this.edit=!1,this.moc=!1,this.callbacksOnlyIfGeometryIsReady=!0,this._creator_=e}setOverrides(e){Ie(this,e)}}e("av",li);const hi=["language","browserLanguage","userLanguage","systemLanguage"];e("a8",/^((?!chrome|android).)*safari/i.test(navigator.userAgent));class di{constructor(e){this.locale=((e=null)=>{const t=window.navigator;if(e)return e.substr(0,2);if(Array.isArray(t.languages)&&t.languages.length>0)return t.languages[0].substr(0,2);for(let e=0,r=hi.length;e<r;e++){const r=t[hi[e]];if(r)return r.substr(0,2)}return"en"})()||"en",this.overrideCountry=null,this._creator_=e}setOverrides(e){Ie(this,e)}}e("au",di);class ci{_setMute(e){ke(this,"_isMute",!0),this._isMute=e,ke(this,"_isMute",!1)}mute(){this._setMute(!0)}unmute(){this._setMute(!1)}constructor(e){return this._isMute=!1,this.cameraStartsMoving=()=>{},this._creator_=e,Oe(this,"_isMute",{enumerable:!1,writable:!1}),Oe(ci.prototype,"_setMute",{enumerable:!1,writable:!1}),Oe(ci.prototype,"mute",{enumerable:!1,writable:!1}),Oe(ci.prototype,"unmute",{enumerable:!1,writable:!1}),new Proxy(this,this)}get(e,t){return this._isMute&&"function"==typeof this[t]&&"on"===t.substr(0,2)?()=>{}:this[t]}}e("ar",ci);class ui extends ci{constructor(){super(...arguments),this.onNetworkRequest=(e,t,r)=>{},this.onKernelMsg=(e,t,r={})=>{},this.onCheckExternalCache=async(e,t)=>Promise.resolve(null),this.onValidateNetworkResponse=(e,t)=>Promise.resolve(!0)}}e("at",ui),e("l",{HSC:"rml-configurator",HSP:"rml-hsp",GLB:"rml-glb",RMV:"rml-mv"});class pi{get element(){return this._container}constructor(e){this._creator_=e,this._lifeCycleManager.addEventListener(this)}setDomElement(e){if(!this._container){this._container=document.createElement("div"),this._container.classList.add("rml-threejs-canvas-container"),this._container.setAttribute("ondragover","return false"),this._container.style.position="relative",this._container.style.width="100%",this._container.style.height="100%";const t=document.createElement("style");t.innerText=".rml-threejs-canvas-container canvas{position:absolute;top:0;left:0;right:0;bottom:0;z-index:100; opacity:1;}",this._container.appendChild(t),e.appendChild(this._container)}this._element=e}getClientDimensions(){return new i(this._element.clientWidth,this._element.clientHeight)}_removeDomElement(e){if(!e)return;const t=e.parentElement;t&&t.removeChild(e)}reset(){this._element=null,this._removeDomElement(this._container),this._container=null}pause(){this.reset()}resume(){}destroy(){}}pr([fr],pi.prototype,"_lifeCycleManager",void 0),e("ax",class{constructor(e){this._creator_=e}setScene(e){}setUiScene(e){}updateBounds(e){}clearScene(e,t){}moveCameraEnd(e){}moveCameraStart(e){}needsUiScene(){return!1}});class mi{constructor(e){this._plugins=[],this._creator_=e}async init(e,r,n){this._scene=e,this._uiScene=r,this._cameraPosition=n;const{bananaForScale:a}=this._initData;a&&await t.import("./banana-for-scale-eb990d71.legacy.js").then(({default:e})=>this._plugins.push(new e(this._creator_))),this._plugins.forEach(e=>e.setScene(this._scene)),this._plugins.forEach(e=>e.setUiScene(this._uiScene)),this._plugins.forEach(e=>e.updateBounds(this._bounds)),this._plugins.forEach(e=>e.moveCameraEnd(this._cameraPosition))}addPlugin(e){this._plugins.push(e),e.setScene(this._scene),e.setUiScene(this._uiScene),e.updateBounds(this._bounds),e.moveCameraEnd(this._cameraPosition)}updateBounds(e){this._bounds=e,this._plugins.forEach(t=>t.updateBounds(e))}clearScene(e,t){this._plugins.forEach(r=>r.clearScene(e,t))}getActivePlugins(){return this._plugins}getPlugin(e){for(let t of this._plugins)if(t instanceof e)return t;return null}moveCameraEnd(e){this._cameraPosition=e,this._plugins.forEach(t=>t.moveCameraEnd(e))}moveCameraStart(e){this._cameraPosition=e,this._plugins.forEach(t=>t.moveCameraStart(e))}needsUiScene(){return this._plugins.map(e=>e.needsUiScene()).reduce((e,t)=>e||t,!1)}}pr([fr],mi.prototype,"_initData",void 0);class fi{constructor(e,t){this._waitingPromises=[],this._finishPromiseExecutor=[],this._errorCallback=()=>{},Promise.allSettled=Promise.allSettled||(e=>Promise.all(e.map(e=>e.then(e=>({status:"fulfilled",value:e})).catch(e=>({status:"rejected",reason:e}))))),e&&this.registerCallback(e),t&&(this._errorCallback=t)}push(e){this._waitingPromises.push(e),Promise.all(this._waitingPromises).then(e=>{e.length===this._waitingPromises.length&&(this._callback&&this._callback(e),this._waitingPromises=[])},this._errorCallback)}finished(e=!1){return new Promise((t,r)=>{this._finishPromiseExecutor.push({resolve:t,reject:r});const n=e?"allSettled":"all";Promise[n](this._waitingPromises).then(e=>{if("allSettled"===n){const t=[];e.forEach(({value:e,status:r})=>{"fulfilled"===r&&t.push(e)}),this._resolveAllExecutors(t)}else this._resolveAllExecutors(e)},e=>{this._rejectAllExecutors(e)})})}registerCallback(e){this._callback=e}unregisterCallback(){this._callback=null}_resolveAllExecutors(e){this._finishPromiseExecutor.forEach(({resolve:t})=>t(e)),this._finishPromiseExecutor=[]}_rejectAllExecutors(e){this._finishPromiseExecutor.forEach(({reject:t})=>t(e)),this._finishPromiseExecutor=[]}clear(){const e=this._waitingPromises.length>0;this._waitingPromises=[],e?this._rejectAllExecutors(new Error("Promise queue has been cleared")):this._resolveAllExecutors([])}get length(){return this._waitingPromises.length}}class gi{constructor(e){this.materialQueue=new fi,this._geometryComponentMaterialCache=new Map,this._maxAnisotropy=1,this._maxTextures=16,this._textureLoader=new ue,this._configuratorPreviewMaterial=_n.createMeshStandardMaterial({color:"#DDDDDD",transparent:!0,opacity:1,roughness:1,envMap:null}),this._creator_=e,this._previewMaterial=_n.createMeshStandardMaterial({color:"#DDDDDD",roughness:1,metalness:0})}getGeometry(e){return e&&this._cacheHolder.geometryCache.has(e)?this._cacheHolder.geometryCache.get(e):null}_generateGeometry(e,t,r,n,a){let i;return e&&this._cacheHolder.geometryCache.has(e)?i=this._cacheHolder.geometryCache.get(e):(i=new c,i.setIndex(new De(r,1)),i.setAttribute("position",new Le(t,3)),i.setAttribute("normal",new Le(a,3)),i.setAttribute("uv",new Le(n,2)),i.scale(.001,.001,.001),i.rotateX(-Math.PI/2),e&&this._cacheHolder.geometryCache.set(e,i)),i}changeMaterialOfMesh(e,t,r){e&&t?(e.material=t,e.material.transparent||0===e.material.opacity||e.material.transmission>0?(e.castShadow=!1,e.receiveShadow=!1):(e.castShadow=!0,e.receiveShadow=!0),e.material.needsUpdate=!0,this._materialLoaded&&this._materialLoaded(t),this._updateMaterialProperties(e,r)):console.warn("could not assign material to mesh",{mesh:e},{material:t})}_updateMaterialProperties(e,t){var r;if(t&&Object.keys(t).length>0&&e.material instanceof H){const n=e.material.clone();n.userData.materialAttributes=t,t.color&&(n.color=new h(t.color)),t.alpha&&(n.opacity=parseFloat(t.alpha)),t.roughness&&(n.roughness=parseFloat(t.roughness)),t.metallic&&(n.metalness=parseFloat(t.metallic)),n instanceof T&&t.transmission&&(n.transmission=parseFloat(t.transmission)),n.transparent=n.opacity<1;const a=e.material;e.material=n,(null===(r=a.userData)||void 0===r?void 0:r.materialAttributes)&&a.dispose()}}_createMaterial(e,t,r,n,a){if(this._cacheHolder.materialCache.has(e))t();else if(e.startsWith("benchmarkMaterial")){let i=Ue(e),s=Va(i,this._initData.envMapIntensity);this._loadBenchmarkTextures(i,s,n,a).then(t,r)}else this._rapiAccess.getMaterial(e).then(e=>{let i=Va(e,this._initData.envMapIntensity);this._loadTextures(e,i,n,a).then(t,r)},r)}_loadBenchmarkTextures(e,t,r=1,n=1){return new Promise((a,i)=>{const s=Fe(e.id);Xa(this._dataSyncer.requestAsset(s.image,!0),s,t,this._maxAnisotropy,r/(0===s.mmWidth?1:s.mmWidth),n/(0===s.mmHeight?1:s.mmHeight),this._maxTextures).then(()=>{this._cacheHolder.materialCache.set(e.id,t),a()},i)})}_loadTextures(e,t,r=1,n=1){return new Promise((a,i)=>{if(!e.textures||e.textures&&0===e.textures.length)return this._cacheHolder.materialCache.set(e.id,t),a();this._rapiAccess.getTexturesOf(e).then(s=>{let o=[];s.forEach(e=>{o.push(Xa(this._dataSyncer.requestAsset(e.image,!0),e,t,this._maxAnisotropy,r/(0===e.mmWidth?1:e.mmWidth),n/(0===e.mmHeight?1:e.mmHeight),this._maxTextures))}),Promise.all(o).then(()=>{this._cacheHolder.materialCache.set(e.id,t),a()},i)})})}_loadMaterial(e,t,r){return new Promise((n,a)=>{this._singlePromiseFactory.create(6,e,(n,a)=>this._createMaterial(e,n,a,t,r)).then(()=>{setTimeout(()=>n(this._cacheHolder.materialCache.get(e)),0)},a)})}_assignMaterial(e,t,r){return this._cacheHolder.materialCache.has(t)?(this.changeMaterialOfMesh(e,this._cacheHolder.materialCache.get(t),r),Promise.resolve()):new Promise((n,a)=>{this._loadMaterial(t).then(a=>{e.userData.materialId===t&&this.changeMaterialOfMesh(e,a,r),n()},a)})}get maxAnisotropy(){return this._maxAnisotropy}set maxAnisotropy(e){this._maxAnisotropy=e}get maxTextures(){return this._maxTextures}set maxTextures(e){this._maxTextures=e}clear(){this._cacheHolder.clear()}_assignRGB(e,t){return new Promise(r=>{let n,a="rgb"+JSON.stringify(t);this._cacheHolder.materialCache.has(a)?n=this._cacheHolder.materialCache.get(a):(n=_n.createMeshPhysicalMaterial({color:t}),this._cacheHolder.materialCache.set(a,n)),this.changeMaterialOfMesh(e,n),setTimeout(()=>r(),0)})}_assignItem(e,t){return new Promise((r,n)=>{if(this._cacheHolder.materialCache.has(t))return this.changeMaterialOfMesh(e,this._cacheHolder.materialCache.get(t)),void r();this._rapiAccess.getItem(t).then(a=>{if(a.topImage)this._textureLoader.load(a.topImage,n=>{n.anisotropy=this._maxAnisotropy,n.wrapS=F,n.wrapT=F;let s=new i(1,1);a.width>0&&(s.x=1/a.width),a.depth>0&&(s.y=1/a.depth),n.repeat.set(s.x,s.y);const o=_n.createMeshPhysicalMaterial({map:n,roughness:.5,metalness:.1});this._cacheHolder.materialCache.set(t,o),this.changeMaterialOfMesh(e,o),setTimeout(()=>r(),0)});else{const e="can not set material, catalog item top image is not set";console.warn(e),n(e)}},n)})}setMaterialLoadedListener(e){this._materialLoaded=e}removeMaterialLoadedListener(){this._materialLoaded=void 0}_createMesh(e,t,r){if(e&&t){const n=this._getComponentMeshId(e,t);if(this._geometryComponentMaterialCache.has(n)){const e=this._geometryComponentMaterialCache.get(n);if(this._cacheHolder.materialCache.has(e)){const t=this._cacheHolder.materialCache.get(e);return new K(r,t)}}}return new K(r,this._configuratorPreviewMaterial.clone())}_getComponentMeshId(e,t){return e+"_"+t}}pr([fr],gi.prototype,"_initData",void 0),pr([fr],gi.prototype,"_rapiAccess",void 0),pr([fr],gi.prototype,"_dataSyncer",void 0),pr([fr],gi.prototype,"_singlePromiseFactory",void 0),pr([fr],gi.prototype,"_cacheHolder",void 0),pr([fr],gi.prototype,"_plannerMeshGenerator",void 0);class vi extends gi{constructor(e){super(e)}generateMesh(e=0,t=null,r,n,a,i,s,o=!1,l){let h;h=o?this._generateGeometry(t,n,a,i,s).clone():this._generateGeometry(t,n,a,i,s);const d=this._createMesh(e,t,h);return d.userData.materialId=r,d.layers.set(4),r&&this.materialQueue.push(this._assignMaterial(d,r,l).then(()=>{e&&t&&this._geometryComponentMaterialCache.set(this._getComponentMeshId(e,t),r)})),d}setMaterial(e,t,r,n){return this._assignMaterial(e,t,n)}loadMaterial(e,t,r){return super._loadMaterial(e,t,r)}loadTextures(e,t,r,n){return super._loadTextures(e,t,r,n)}}e("as",vi);class wi{constructor(){this._listeners={},this._disabled=!1}_addEventListener(e,t,r){this._listeners[e]||(this._listeners[e]=[]),this._listeners[e].push({callback:t,scope:r})}addEventListener(e,t,r){this._addEventListener(e,t,r)}dispatchEvent(e,t){if(!this._listeners[e]||this._disabled)return;const r=this._listeners[e];let n=r.length;for(let e=0;e<n;e++){const n=r[e];t?n.callback.apply(n.scope,[t]):n.callback.call(n.scope)}}removeEventListener(e,t){const r=this._listeners[e];if(r)for(let e=0,n=r.length;e<n;e++)if(r[e].callback===t)return void r.splice(e,1)}enableEvents(){this._disabled=!1}disableEvents(){this._disabled=!0}}e("E",wi);const bi={SCROLL:"scroll",MOUSE_MOVE:"mousemove",MOUSE_DOWN:"mousedown",MOUSE_UP:"mouseup",MOUSE_LEAVE:"mouseleave",MOUSE_ENTER:"mouseenter",MOUSE_WHEEL:"wheel",TOUCH_MOVE:"touchmove",TOUCH_START:"touchstart",TOUCH_END:"touchend",CONTEXT_MENU:"contextmenu",DOUBLE_CLICK:"dblclick"};e("aa",{DRAG:50});class yi{constructor(e,t,r,n,a){this.position=e,this.positionRelative=t,this.type=r,this.rotation=n,this.event=a}}const _i=e("a1",5*window.devicePixelRatio),xi=3*window.devicePixelRatio;class Si extends wi{constructor(e){super(),this._elementHit=!1,this._delta=-1,this._state=0,this._pinchDistance=-1,this._rotationAngle=-1,this._lastMouseWheelEvent=null,this._lastTouchEvent=null,this._events=Object.keys(bi).map(e=>bi[e]),this._boundingClientRectInvalid=!0,this._creator_=e,this._downPosition={x:0,y:0},this._downPositionRelative={x:0,y:0},this._boundingClientRect=this._getBoundingClientRect()}enableDragIn(e){this._setState(1),this._dragEnabled=!0,e&&(this._dragMV=this._dragM.bind(this),this._dragEV=this._dragE.bind(this),this._dragTarget=e.currentTarget||e.target,this._delta=-1,this._dragMVName="drag",this._dragEVName="dragend",window.TouchEvent&&e instanceof TouchEvent?(this._dragMVName="touchmove",this._dragEVName="touchend"):e.dataTransfer&&e.dataTransfer.setData&&e.dataTransfer.setData("text/plain"," "),this._firefoxDragPosition={x:0,y:0},document.ondragover=e=>{e=e||window.event,this._firefoxDragPosition.x=e.pageX,this._firefoxDragPosition.y=e.pageY},this._dragTarget.addEventListener(this._dragMVName,this._dragMV,!1),this._dragTarget.addEventListener(this._dragEVName,this._dragEV,!1))}isMouseUp(){return 0===this._state}_dragM(e){let t=e,r=null,n=null;window.TouchEvent&&e instanceof TouchEvent?(r=this._getTouchPosition(t),n=this._getTouchPositionRelative(t)):(r=this._getMousePosition(t),n=this._getMousePositionRelative(t)),r.x>0&&r.y>0&&this._move(r,n)}_dragE(e){let t=e;document.ondragover=null,this._firefoxDragPosition=null,this._dragTarget.removeEventListener(this._dragMVName,this._dragMV),this._dragTarget.removeEventListener(this._dragEVName,this._dragEV),window.TouchEvent&&e instanceof TouchEvent?this._onUp(this._getTouchPosition(t),this._getTouchPositionRelative(t),2):this._onUp(this._getMousePosition(t),this._getMousePositionRelative(t),1)}addEvents(e){this._events.forEach(t=>e.addEventListener(t,this,!1)),null===window||void 0===window||window.addEventListener("scroll",this,!1)}removeEvents(e){this._events.forEach(t=>e.removeEventListener(t,this)),null===window||void 0===window||window.removeEventListener("scroll",this)}_move2(e){if(this._lastTouchEvent&&e.timeStamp-this._lastTouchEvent.timeStamp<16)return;const t=e.touches[0],r=e.touches[1],n=t.pageX-r.pageX,a=t.pageY-r.pageY,i=Math.abs(n)+Math.abs(a);this._pinchDistance>-1&&(i>this._pinchDistance+xi?(this._setState(3),this.dispatchEvent(7,new yi(this._getTouchPosition(e),this._getTouchPositionRelative(e)))):i<this._pinchDistance-xi?(this._setState(3),this.dispatchEvent(8,new yi(this._getTouchPosition(e),this._getTouchPositionRelative(e)))):i<=this._pinchDistance+xi&&i>=this._pinchDistance-xi&&(this._setState(5),this.dispatchEvent(11,new yi(this._getTouchPosition(e),this._getTouchPositionRelative(e))))),this._pinchDistance=i,this._lastTouchEvent=e}_setState(e){this._state=e}_move(e,t,r,n){void 0===r&&(r=0),void 0===this._dragEnabled&&(this._dragEnabled=!1),1===this._state&&this._canDrag(r)&&(this._delta=this._getDelta(e),(this._delta>_i||this._elementHit)&&(this._setState(2),this._longClickTimer&&clearTimeout(this._longClickTimer),this.dispatchEvent(0,new yi(this._downPosition,this._downPositionRelative)))),2===this._state&&this.dispatchEvent(1,new yi(e,t)),this.dispatchEvent(6,new yi(e,t,r,null,n))}_longClick(e){2!==e&&(this._setState(2),this._longClickTimer&&clearTimeout(this._longClickTimer),this.dispatchEvent(0,new yi(this._downPosition,this._downPositionRelative)),this.dispatchEvent(1,new yi(this._downPosition,this._downPositionRelative))),this.dispatchEvent(14,new yi(this._downPosition,this._downPositionRelative,2))}_onUp(e,t,r){this.dispatchEvent(4,new yi(e,t,r)),this._getDelta(e)<=_i&&this.dispatchEvent(5,new yi(e,t)),2===this._state&&this.dispatchEvent(2,new yi(e,t)),4===this._state&&(this.dispatchEvent(10,new yi(e,t)),this._rotationAngle=-1),3===this._state&&(this._pinchDistance=-1),this._lastTouchEvent=null,this._setState(0),this._dragTarget=null,this._elementHit=!1,this._longClickTimer&&clearTimeout(this._longClickTimer)}_getTouchPosition(e){if(e.touches.length){let{clientX:t,clientY:r}=e.touches[0];if(e.touches.length>1){const n=e.touches[1],a=n.clientX,i=n.clientY;t=(t+a)/2,r=(r+i)/2}return{x:t,y:r}}const t=e.changedTouches[0];return{x:t.clientX,y:t.clientY}}_getTouchPositionRelative(e){const t=this._getBoundingClientRect(),{clientWidth:r,clientHeight:n}=this._domHelper.element;if(e.touches.length){const{clientX:a,clientY:i}=e.touches[0];return{x:(a-t.left)/r*2-1,y:-(i-t.top)/n*2+1}}const a=e.changedTouches[0];return{x:(a.clientX-t.left)/r*2-1,y:-(a.clientY-t.top)/n*2+1}}_getMousePosition(e){if(0!==e.clientX&&0!==e.clientY)return{x:e.clientX,y:e.clientY};{let{x:t,y:r}=this._getFireFoxMousePosition(e);return{x:t,y:r}}}_getFireFoxMousePosition(e){let{x:t,y:r}=this._domHelper.getClientDimensions();return{x:t-(t+e.offsetX),y:r-(r+e.offsetY)}}_getMousePositionRelative(e){const t=this._getBoundingClientRect();return 0!==e.clientX&&0!==e.clientY?{x:(e.clientX-t.left)/this._domHelper.element.clientWidth*2-1,y:-(e.clientY-t.top)/this._domHelper.element.clientHeight*2+1}:this._firefoxDragPosition&&0!==this._firefoxDragPosition.x&&0!==this._firefoxDragPosition.y?{x:(this._firefoxDragPosition.x-t.left)/this._domHelper.element.clientWidth*2-1,y:-(this._firefoxDragPosition.y-t.top)/this._domHelper.element.clientHeight*2+1}:{x:0,y:0}}_getDelta(e){return Math.abs(this._downPosition.y-e.y)+Math.abs(this._downPosition.x-e.x)}setDragEnabled(e){this._dragEnabled=e}handleEvent(e){switch(e.type){case bi.SCROLL:this._boundingClientRectInvalid=!0;break;case bi.MOUSE_MOVE:this._onMouseMove(e);break;case bi.DOUBLE_CLICK:this._onDoubleClick(e);break;case bi.MOUSE_DOWN:this._onMouseDown(e);break;case bi.MOUSE_UP:this._onMouseUp(e);break;case bi.MOUSE_LEAVE:this._onMouseLeave(e);break;case bi.MOUSE_ENTER:this._onMouseEnter(e);break;case bi.MOUSE_WHEEL:this._onMouseWheel(e);break;case bi.TOUCH_MOVE:this._onTouchMove(e);break;case bi.TOUCH_START:this._onTouchStart(e);break;case bi.TOUCH_END:this._onTouchEnd(e);break;case bi.CONTEXT_MENU:this._onContextMenu(e)}}_onMouseDown(e){if(e.preventDefault(),2===e.detail)return;let{x:t,y:r}=this._getMousePosition(e);this._downPosition={x:t,y:r},this._downPositionRelative=this._getMousePositionRelative(e),this.dispatchEvent(3,new yi({x:t,y:r},this._downPositionRelative,1)),this._setState(1)}_onMouseUp(e){e.preventDefault(),2!==e.detail&&this._onUp(this._getMousePosition(e),this._getMousePositionRelative(e),1)}_onMouseMove(e){e.preventDefault(),this._move(this._getMousePosition(e),this._getMousePositionRelative(e),1,e)}_onDoubleClick(e){e.preventDefault(),this.dispatchEvent(12,new yi(this._getMousePosition(e),this._getMousePositionRelative(e),1))}_onMouseLeave(e){var t;this._delta=-1,(null===(t=e.relatedTarget)||void 0===t?void 0:t.closest('[data-rml-sdk="ignore-mouse-leave"]'))||this._onMouseUp(e)}_onMouseEnter(e){e.preventDefault()}_onMouseWheel(e){if(this._lastMouseWheelEvent&&e.timeStamp-this._lastMouseWheelEvent.timeStamp<40)return e.preventDefault(),void e.stopPropagation();e.deltaY<0?this.dispatchEvent(7,new yi(this._getMousePosition(e),this._getMousePositionRelative(e),1,0,e)):this.dispatchEvent(8,new yi(this._getMousePosition(e),this._getMousePositionRelative(e),1,0,e)),this._lastMouseWheelEvent=e}_onTouchMove(e){if(e.preventDefault(),!this._dragTarget)if(1===e.touches.length)this._move(this._getTouchPosition(e),this._getTouchPositionRelative(e),2);else if(2===e.touches.length)if(this._elementHit||4===this._state){const n=e.touches[0],a=e.touches[1],i=function(e){let t=Cn(e);return t<0&&(t=180+(180+t)),t}((t={x:n.pageX,y:n.pageY},r={x:a.pageX,y:a.pageY},Math.atan2(r.y-t.y,r.x-t.x)));this._rotationAngle<0&&(this._rotationAngle=i);const s=i-this._rotationAngle;this._rotationAngle=i,this.dispatchEvent(9,new yi(this._getTouchPosition(e),this._getTouchPositionRelative(e),2,Sn(s))),this._setState(4)}else this._move2(e);var t,r}_onTouchStart(e){if(e.preventDefault(),1===e.touches.length){let{x:t,y:r}=this._getTouchPosition(e);this._downPosition={x:t,y:r},this._downPositionRelative=this._getTouchPositionRelative(e),this.dispatchEvent(3,new yi({x:t,y:r},this._downPositionRelative,2)),this._setState(1),this._longClickTimer=window.setTimeout(this._longClick.bind(this,2),350)}else 2===e.touches.length&&(1!==this._state&&2!==this._state||this._onUp(this._getTouchPosition(e),this._getTouchPositionRelative(e),2),this._setState(3))}_onTouchEnd(e){e.preventDefault(),e.touches.length>1&&5===this._state||3===this._state||(this.dispatchEvent(13,new yi(this._getTouchPosition(e),this._getTouchPositionRelative(e),2)),this._onUp(this._getTouchPosition(e),this._getTouchPositionRelative(e),2))}_onContextMenu(e){e.preventDefault()}_canDrag(e){return this._dragEnabled}onElementHit(){this._elementHit=!0}_getBoundingClientRect(){return this._boundingClientRectInvalid&&(this._boundingClientRect=this._domHelper.element.getBoundingClientRect(),this._boundingClientRectInvalid=!1),this._boundingClientRect}updateSize(){this._boundingClientRectInvalid=!0}}e("am",Si),pr([fr],Si.prototype,"_domHelper",void 0);class Ci{constructor(e){const{component:t,resetCamera:r,consecutive:n}=e;this.component=t,this.resetCamera=void 0===r||r,this.consecutive=void 0===n||n}}var Mi=function(e){g(r,e);var t=v(r);function r(e){return w(this,r),t.call(this,e)}return b(r,[{key:"load",value:function(e,t,r,n){var a=this,i=new _(this.manager);i.setPath(this.path),i.setRequestHeader(this.requestHeader),i.setWithCredentials(this.withCredentials),i.load(e,(function(e){var r=a.parse(JSON.parse(e));t&&t(r)}),r,n)}},{key:"parse",value:function(e){return new Ti(e)}}]),r}(x),Ti=function(){function e(t){w(this,e),this.isFont=!0,this.type="Font",this.data=t}return b(e,[{key:"generateShapes",value:function(e){for(var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:100,r=[],n=Ai(e,t,this.data),a=0,i=n.length;a<i;a++)r.push.apply(r,Be(n[a].toShapes()));return r}}]),e}();function Ai(e,t,r){for(var n=Array.from(e),a=t/r.resolution,i=(r.boundingBox.yMax-r.boundingBox.yMin+r.underlineThickness)*a,s=[],o=0,l=0,h=0;h<n.length;h++){var d=n[h];if("\n"===d)o=0,l-=i;else{var c=Pi(d,a,o,l,r);o+=c.offsetX,s.push(c.path)}}return s}function Pi(e,t,r,n,a){var i=a.glyphs[e]||a.glyphs["?"];if(i){var s,o,l,h,d,c,u,p,m=new Ne;if(i.o)for(var f=i._cachedOutline||(i._cachedOutline=i.o.split(" ")),g=0,v=f.length;g<v;)switch(f[g++]){case"m":s=f[g++]*t+r,o=f[g++]*t+n,m.moveTo(s,o);break;case"l":s=f[g++]*t+r,o=f[g++]*t+n,m.lineTo(s,o);break;case"q":l=f[g++]*t+r,h=f[g++]*t+n,d=f[g++]*t+r,c=f[g++]*t+n,m.quadraticCurveTo(d,c,l,h);break;case"b":l=f[g++]*t+r,h=f[g++]*t+n,d=f[g++]*t+r,c=f[g++]*t+n,u=f[g++]*t+r,p=f[g++]*t+n,m.bezierCurveTo(d,c,u,p,l,h)}return{offsetX:i.ha*t,path:m}}console.error('THREE.Font: character "'+e+'" does not exists in font family '+a.familyName+".")}const Ri=new Map,Ei=new Map;class Ii{static loadFont(e){if(Ei.has(e))return new Promise(t=>{t(Ei.get(e))});if(Ri.has(e))return new Promise((t,r)=>{Ri.get(e).push({resolve:t,reject:r})});let t=new Mi;return new Promise((n,a)=>{Ri.set(e,[{resolve:n,reject:a}]),t.load(r()+e,t=>{Ei.set(e,t),Ii._resolveAll(e,t)})})}static _resolveAll(e,t){Ri.has(e)&&Ri.get(e).forEach(e=>e.resolve(t)),Ri.delete(e)}}e("aw",Ii);class ki{constructor(e){this._activeComponents=[],this._componentDimensioningsExist=new Map,this._creator_=e}setCamera(e){this._camera=e}add(e){if(this._componentDimensioningsExist.has(e.runtimeId)&&!this._componentDimensioningsExist.get(e.runtimeId))return!1;const r=this._plannerKernelAccess.kernelInstance.getComponent(e.runtimeId),n=r.dimensionings;if(this._componentDimensioningsExist.set(e.runtimeId,n.length>0),!n||0===n.length||this._camera.position.z<0)return!1;const a=Na(r.boxForMeasurement),i={x:this._camera.position.x,y:this._camera.position.z};return t.import("./component-dimensioning-5ddf8d0a.legacy.js").then(t=>{Ii.loadFont("static/rubik_regular-bc008a7de2daee79.json").then(r=>{n.forEach(n=>{var s;e.add(new t.default(((s=n).from=s.from/1e3,s.to=s.to/1e3,1===s.type.value?(s.type={value:2},s.from*=-1,s.to*=-1):2===s.type.value&&(s.type={value:1}),s),a,r,i))})})}),this._activeComponents.push(e),!0}remove(e,r=!0){return new Promise(n=>{t.import("./component-dimensioning-5ddf8d0a.legacy.js").then(t=>{let a=[];e.children.forEach(e=>{e instanceof t.default&&a.push(e)}),a.forEach(t=>{e.remove(t),Za(t)}),r&&ze(this._activeComponents,e),n()})})}hasComponentDimensions(){return this._activeComponents.length>0}async reset(){for(const e of this._activeComponents)await this.remove(e);this._activeComponents=[]}invalidateDimensioningsCache(e){e?this._componentDimensioningsExist.delete(e):this._componentDimensioningsExist.clear()}}pr([fr],ki.prototype,"_plannerKernelAccess",void 0);class Oi{constructor(){this._promiseExecutors=[]}create(){return new Promise((e,t)=>{this._promiseExecutors.push({resolve:e,reject:t})})}resolve(e){return new Promise(t=>{this._promiseExecutors.forEach(t=>t.resolve(e)),this._promiseExecutors=[],t(e)})}reject(e){return new Promise((t,r)=>{this._promiseExecutors.forEach(t=>t.reject(e)),this._promiseExecutors=[],r(e)})}}class Di extends class{constructor(e){this._coreReference=e.clone()}clearReference(){this._coreReference.delete(),this._coreReference=null}getKernelObject(){return this._coreReference}}{constructor(e){super(e),this._objectWaiter=new Oi,this._topView=!1;const t=Tn(e.getCenter());this._container=new I,this._container.position.copy(t),this._boundingBox=this._generateBoundingBox(),Ya(this._boundingBox),this._container.add(this._boundingBox),2!==this.getPlanElement().getType().value&&(this._object=new I,this._container.add(this._object))}getSize(){return this._object?(new be).setFromObject(this._object).getSize(new s):new s}update(){this._container.position.copy(Tn(this.getPlanElement().getMeshCenter())),this._boundingBox&&this._updateBoundingBox()}_updateBoundingBox(){const e=this.getSize();this._boundingBox.geometry=new He(e.x,e.y,e.z),this._boundingBox.position.y=e.y/2}getPosition(){return this._container.position}getRotation(){return this._container.rotation.y}getBounds(){let e;return this.getPlanElement().boxForMeasurement?(e=Na(this.getPlanElement().boxForMeasurement),e.applyMatrix4(this.getContainer().matrix)):(e=new be,e.setFromObject(this._container)),e}getBoundingBox(){return this._boundingBox}getPlanElement(){return this._coreReference}setObject(e){this._object=e,this._objectWaiter.resolve(e)}getObject(){return this._object}async getObjectAsync(){return this._object?Promise.resolve(this._object):this._objectWaiter.create()}addMesh(e){this._object.add(e),this.hidePreviewBox()}getMesh(e){if(!this._object||0===this._object.children.length)return null;const t=ni(e,this.getPlanElement().getType());return this._object.children.find(e=>e.userData.material===t)}getContainer(){return this._container}getId(){return this.getPlanElement().getId()}clear(){Za(this._container),this._selectionMesh&&Za(this._selectionMesh)}remove(){var e;null===(e=this._container.parent)||void 0===e||e.remove(this._container),this.clear()}hidePreviewBox(){this._container&&this._boundingBox&&(this._boundingBox.material=(ri||(ri=new C,ri.visible=!1),ri))}_generateBoundingBox(){const e=this.getSize(),t=new He(e.x,e.y,e.z);let r=new h("#DDDDDD");const n=this.getPlanElement().customColor;n>0&&(r=(e=>{let t=new h;return t.setRGB((e>>16)/255,(e>>8&255)/255,(e>>0&255)/255),t})(n));let a=_n.createMeshStandardMaterial({color:r,opacity:1,transparent:!0}),i=new K(t,a);return i.name="bounding box",i.position.y=e.y/2,i.castShadow=!1,i.receiveShadow=!1,i.layers.set(6),i}select(){this._isSelected=!0,this._selectionMesh&&this._container.add(this._selectionMesh)}deselect(){this._isSelected=!1,this._selectionMesh&&this._container.remove(this._selectionMesh)}hoverOn(){}hoverOff(){}setPrimaryColor(e){this._primaryColor=e}setTopView(e){this._topView=e}}class Li extends Di{constructor(e){super(e),this._initDone=!1,this._initFailed=null,this._initWaiter=new Oi,this._container.rotation.y=e.rotation}finishInit(){return this._initDone=!0,this._initFailed=null,this._initWaiter.resolve()}failInit(e){return this._initFailed=e,this._initDone=!1,this._initWaiter.reject(this._initFailed)}isInitDone(){return this._initDone?Promise.resolve():this._initFailed?Promise.reject(this._initFailed):this._initWaiter.create()}getPlanObject(){return this.getPlanElement()}getSize(){return An(this.getPlanObject().size)}update(){super.update(),this._container.rotation.y=this.getPlanObject().rotation}}class Ui extends Li{constructor(e){super(e),this._container.name="Configurable "+this._container.name}addRootComponent(e){this.setObject(e),this._rootComponentId=e.id,this._rootComponentRuntimeId=e.runtimeId,this._container.add(this.getObject())}getConfigurationRuntimeId(){return this.getPlanObject().getConfigurationRuntimeId()}getRootComponentId(){return this._rootComponentId}getRootComponentRuntimeId(){return this._rootComponentRuntimeId}finishConstruction(){return this.finishInit()}failConstruction(){return this.failInit(new Error("Construction of configuration failed"))}}e("c",Ui);let Fi=JSON.parse(JSON.stringify({isProduction:!0,isUnitTesting:!1,environment:"production",detailEnvironment:"development",features:{},APP:{RAPI:{server:"/api/v2",localReverseProxy:"https://www.roomle.com/api/v2",liveServer:"https://www.roomle.com/api/v2",testServer:"https://www.test.roomle.com/api/v2",headers:{apiKey:"roomle_portal_v2",currentTenant:9,locale:"en",language:"en",device:1,token:"anonymous",platform:"web"},itemHeaders:{assetRevision:"glb",assetFileFormat:"glb"}},SHORTENER_URL:"http://rml.co/"},environments:{PRODUCTION:"production",DEVELOPMENT:"development",TEST:"test",TEST_SERVER:"test_server",ALPHA:"alpha"}}));Fi.isUnitTesting=!1,void 0!==t&&t.exports||(window.IS_DEBUG=!0);const Bi={ENV_DEBUG:function(e=!1){if(e){let e=JSON.parse(JSON.stringify(Fi));const t={...e.APP,SHORTENER_URL:"http://localhost:4747/?isItem=false&id="},r={...e.features};return{...e,isProduction:!1,APP:t,features:r}}}(),ENV_PRODUCTION:JSON.parse(JSON.stringify(Fi))};var Ni=e("m",Bi.ENV_PRODUCTION);class zi extends Li{constructor(e){super(e),this._originalSize=new s,this._container.name="Static "+this._container.name}setRapiItem(e){return this._rapiItem?Promise.resolve():this._addStaticItem(e)}async _addStaticItem(e){this._rapiItem=e;let t=this.getPlanObject();if(this._glbUrl=je(e),!this._glbUrl)return Promise.reject("No glb url found");let r=e.scaleable?An(t.size):void 0,n=new s(1,1,1);t.flipX&&(n.x*=-1),t.flipY&&(n.z*=-1);try{const a=await this._staticItemLoader.loadGLB(this._glbUrl,void 0,void 0,r,n,t.customColor,e.colorable);this._originalSize.copy(a.boundingBox.getSize(new s)),a.scene.name=e.label,this.setObject(a.scene),((e,t)=>{let r=(new be).setFromObject(e),n=r.getSize(new s),a=Math.min(n.x,n.y,n.z),i=!0;a>5&&(console.warn("GLB seems to be too big ("+a+")",t),i=!1),r.min.y<-.01&&(console.warn("GLB seems to be under the floor ("+r.min.y+"): ",t),i=!1)})(a.scene,this._glbUrl),Ya(a.scene),this._container.add(this.getObject()),this.hidePreviewBox(),await this.finishInit()}catch(e){await this.failInit(e)}}getRapiItem(){return this._rapiItem}needsRapiItem(){return!this._glbUrl}getGLBUrl(){return this._glbUrl}update(){const e=An(this.getPlanElement().size),t=this.getObject();if(!t)return;if(e){const{x:r,y:n,z:a}=this._originalSize;let i=new s(e.x/r,e.y/n,e.z/a);t.scale.copy(i)}this.getPlanElement().flipX&&(t.scale.x*=-1),this.getPlanElement().flipY&&(t.scale.z*=-1);const r=this.getPlanElement().customColor;t.traverse(e=>{if(e instanceof K&&e.material instanceof H){const t=e.material;if(this._rapiItem.colorable&&r&&r>0){let e=new h(r);t.color=e.copySRGBToLinear(e)}t.envMapIntensity=_n.getEnvMapIntensity(),t.needsUpdate=!0}}),super.update()}}let Hi;e("S",zi),pr([fr],zi.prototype,"_staticItemLoader",void 0),e("ak",e=>{const{id:t,textRotation:r,length:n,lengthFormatted:a}=e;return{id:t,fromWithoutPadding:ii(e.fromWithoutPadding),toWithoutPadding:ii(e.toWithoutPadding),fromPosition3d:ii(e.fromPosition3d),toPosition3d:ii(e.toPosition3d),textPosition3d:ii(e.textPosition3d),fromPosition2d:ai(e.fromPosition2d),toPosition2d:ai(e.toPosition2d),textPosition2d:ai(e.textPosition2d),textDirection:ii(e.textDirection),textRotation:r,length:n,lengthFormatted:a}});const ji=()=>(Hi||(Hi=_n.createMeshPhysicalMaterial({color:0})),Hi);class Vi extends Di{constructor(e){super(e),this._container.name="Wall Plan Element"}get isSelected(){return this._isSelected}getWallDimension(e){const t=this.getPlanElement(),r=Tn(t.getCenter()),n=t.getPreferredSide();let a,i;0===n.value?(a=Tn(t.getCornerFromLeft()),i=Tn(t.getCornerToLeft())):1===n.value&&(a=Tn(t.getCornerFromRight()),i=Tn(t.getCornerToRight()));const o=a.clone().add(i).divideScalar(2),l=a.clone().sub(i),h=l.clone().cross(new s(0,1,0)).normalize();h.clone().dot(o.clone().sub(r))<0&&h.multiplyScalar(-1);const d={maxZoomedIn:Math.max(.7,e),maxZoomedOut:.01,minPadding:.05,maxPadding:.25},c=Ve(e,d.maxZoomedIn,d.maxZoomedOut,d.minPadding,d.maxPadding),u=h.clone().multiplyScalar(c/2),p=a.clone().add(u),m=i.clone().add(u),f=h.multiplyScalar(c),g=a.add(f),v=i.add(f),w=l.clone();l.dot(new s(1,0,0))<0&&w.multiplyScalar(-1);const b=Math.atan2(w.z,w.x),y=g.clone().add(v).divideScalar(2);return{id:t.getId(),fromPosition3d:g,toPosition3d:v,textPosition3d:y,textDirection:w,textRotation:b,length:t.getLength(n.value),fromWithoutPadding:p,toWithoutPadding:m}}addMesh(e){e.traverse(e=>{this._setMaterial(e)}),e.layers.set(9),super.addMesh(e);const t=(new be).setFromObject(this.getObject()).getSize(new s);this._boundingBox.geometry=new He(t.x,t.y,t.z),this._boundingBox.position.y=t.y/2}show(){var e,t;this.getContainer().visible=!0,null===(e=this.getObject())||void 0===e||e.traverse(e=>{e.layers.set(9)}),null===(t=this.getBoundingBox())||void 0===t||t.layers.set(6)}hide(){var e,t;this.getContainer().visible=!1,null===(e=this.getObject())||void 0===e||e.traverse(e=>{e.layers.disableAll()}),null===(t=this.getBoundingBox())||void 0===t||t.layers.disableAll()}_enableTopView(){this._container.traverse(e=>{this._setTopMaterial(e)})}_setTopMaterial(e){e instanceof K&&!e.userData.originalMaterial&&e.material&&e!==this._boundingBox&&(e.userData.originalMaterial=e.material,e.material=ji())}_disableTopView(){this._container.traverse(e=>{e instanceof K&&e.userData.originalMaterial&&(e.material=e.userData.originalMaterial,delete e.userData.originalMaterial)})}setTopView(e){super.setTopView(e),e?this._enableTopView():this._disableTopView()}getKernelObject(){return super.getKernelObject()}_setMaterial(e){e instanceof K&&e.material&&e!==this._boundingBox&&(e.userData.originalMaterial||(e.userData.originalMaterial=e.material),this._topView&&this._isSelected?e.material=new C({color:10526880,side:j}):this._topView&&!this._isSelected?e.material=ji():(e.material=e.userData.originalMaterial,delete e.userData.originalMaterial))}select(){super.select(),this._container.traverse(e=>{this._setMaterial(e)})}deselect(){super.deselect(),this._container.traverse(e=>{this._setMaterial(e)})}}e("W",Vi);class Gi extends Di{constructor(e){super(e),this._container.name="Floor Plan Element"}addMesh(e){this.getObject().clear(),super.addMesh(e),e.layers.set(9),e.castShadow=!1,e.position.y=-.001}}e("F",Gi);class Ki extends Di{constructor(e){super(e),this._container.name="Ceiling Plan Element"}addMesh(e){super.addMesh(e),e.castShadow=!1;const t=(new be).setFromObject(this.getObject()).getSize(new s);this._boundingBox.geometry=new He(t.x,.01,t.z)}}e("f",Ki);const Wi=new Map;class Xi{static start(e){if(!window.performance||!window.performance.getEntriesByName)return"";let t=window.performance.getEntriesByName(e).length++,r="";t<100&&(r="0"),t<10&&(r="0"+r);const n=t>0?e+"_"+r+t:e,a=n+"_start";return window.performance.mark(a),n}static addMeta(e,t){const r=Xi.getMeta(e);Wi.set(e,Object.assign(r,t))}static getMeta(e){return Wi.get(e)||{}}static end(e){}static getMeasure(e){return[]}static showBenchmarks(e){const t=window.performance.getEntriesByType("measure");t.sort((function(e,t){return e.startTime-t.startTime}));const r=[];for(let n=0,a=t.length;n<a;n++){const a=t[n];e&&-1===a.name.indexOf(e)||r.push({Start:parseFloat(a.startTime.toFixed(2)),Name:a.name,Duration:parseFloat(a.duration.toFixed(2))})}console.table(r)}}e("B",Xi);class qi{static init(e={}){const{kernelInstance:t,kernelContainer:r,planObjectId:n}=e;qi.kernelInstance=t,qi.kernelContainer=r,qi.planObjectId=n}static cleanUp(){qi.useHDGeometry=!1,qi.kernelInstance=null,qi.kernelContainer=null,qi.planObjectId=null}}e("A",qi),qi.useHDGeometry=!1,qi.kernelInstance=null,qi.kernelContainer=null,qi.planObjectId=null;const Qi=new Map,Yi=function(e,t,r){let n=Qi.get(e);if(n){const a=r?[r]:void 0;n.forEach(({resolve:e,reject:r})=>t?e.apply(e,a):r.apply(r,a)),Qi.delete(e)}};class Zi{static finishOperation(e,t){Yi(e,!0,t)}static failOperation(e,t){Yi(e,!1,t)}static waitFor(e,t){return new Promise((r,n)=>{let a=Qi.get(e);a||(Qi.set(e,[]),a=Qi.get(e)),a.push({resolve:r,reject:n}),"function"==typeof t&&t.apply(t)})}}e("J",Zi);const Ji=e("K",(function(e){return e.validRange&&"string"==typeof e.validRange.type})),$i=function(e){return e.validValues&&e.validValues.length>0},es=e("M",(function(e){return"Material"===e.type}));let ts,rs,ns,as,is;const ss={WASM:{CONFIGURATOR:{URL:"static/ConfiguratorKernel-b08c2b8a1d2b97d5.wasm",LOADER:"static/ConfiguratorKernel-4d9dfdcc5d9d38b8.js"},PLANNER:{URL:"static/RoomleCore-93a742872983693b.wasm",LOADER:"static/RoomleCore-4cab0c3c5040615b.js"}},ASM:{CONFIGURATOR:{MEM_URL:"static/ConfiguratorKernelJs-58bc6f0027b88d5b.mem",LOADER:"static/ConfiguratorKernelJs-87b3c4f3f586df91.js"},PLANNER:{MEM_URL:"static/RoomleCoreJs-d2ee0ac9ab433aa5.mem",LOADER:"static/RoomleCoreJs-8b85e0896df53cb0.js"}}},os=!!window.WebAssembly;class ls{_utilityToLongArray(e){const t=new this._kernelContainer.LongArray;return e.forEach(e=>t.push_back(e)),t}constructor(e){this._requestedItemIds=[],this._requestedMaterialIds=[],this._configuratorKernelCallbackListener=new Set,this._cachedGroupIds=[],this._waitingForGroups=!1,this._subComponentsWaiters=new Map,this._shouldWait=!0,this._creator_=e,window.KernelCallback={isReady:this.isReady.bind(this)},this._lifeCycleManager.addEventListener(this)}init(e){this._kernelType=e,this._setupKernelPaths(e),this._setupEmsModule(e),this._useWASM=os,this._kernelPath=os?ns:as}_initKernel(){const{restrictionLevel:e}=this._initData,t=!1!==this._initData.callbacksOnlyIfGeometryIsReady;this._kernelInstance.setUpdateCallbacksOnlyIfGeometryIsReady(t),this._kernelInstance.setLevel(e),this._unitFormatter.init(this._kernelContainer),this._kernelInstance.setEnvironmentVariable("unit",this._unitFormatter._actualUnitString||"cm"),this._kernelInstance.setEnvironmentVariable("unitString","short"),this._kernelInstance.useEnvironmentGeometry(1===this._kernelType);const{overrideCountry:r,locale:n}=this._globalInitData;r&&(this._kernelInstance.resetPriceListIds(),this._kernelInstance.addPriceList(r)),this._kernelInstance.setEnvironmentVariable("language",n)}get kernelContainer(){return this._kernelContainer}get kernelInstance(){return this._kernelInstance}get configurationExporter(){return this._configurationExporter||(this._configurationExporter=this._kernelContainer.newConfigurationExporter()),this._configurationExporter}_setupKernelPaths(e){const t=0===e?"PLANNER":"CONFIGURATOR";ts=ss.ASM[t].MEM_URL,rs=ss.WASM[t].URL,ns=ss.WASM[t].LOADER,as=ss.ASM[t].LOADER,is=!0}_setupEmsModule(e){const t=this;this._kernelContainer={locateFile(t){const n=0===e?/RoomleCoreJs[\-a-z0-9]*\.js\.mem/:/ConfiguratorKernelJs[\-a-z0-9]*\.js\.mem/;return t.match(n)?r()+ts:t},wasmBinaryFile:r()+rs,preRun:[],postRun:[],setStatus:null,print(e){t._kernelIo.log(e)},printErr(e){t._kernelIo.error(e)},quit(e){0!==e&&t._kernelIo.throw(e&&e.toString?e.toString():"Unknown error while C/C++ main executes")}},is&&os&&(this._kernelContainer.instantiateWasm=function(e,t){return((e,t,n)=>{const a="function"==typeof WebAssembly.instantiateStreaming;Xi.addMeta("kernel_is_ready",{cachedInIndexedDB:!1});let i=null;a?(Xi.start("kernel_stream_compile"),i=WebAssembly.instantiateStreaming(fetch(r()+e),t)):(Xi.start("kernel_legacy_compile"),i=fetch(r()+e).then(e=>e.arrayBuffer()).then(e=>WebAssembly.instantiate(e,t))),Xi.addMeta("kernel_is_ready",{instantiateStreaming:a}),i.then(e=>{n(e.instance)},e=>console.error(e))})(rs,e,t),{}})}_passSubComponentsToKernel(e,t){const r=e.id,n=t.get(r);if(n)for(let t=0,a=n.length;t<a;t++){const{parentId:a,partId:i}=n[t];this._kernelIo.setMeta({componentId:r}),this._kernelInstance.loadedSubComponent(a,i,r,e.configuration)}}_fetchSubComponents(e){let t=[...e.keys()];t.length&&this._rapiAccess.getComponents(t).then(t=>{for(let r=0,n=t.length;r<n;r++)this._passSubComponentsToKernel(t[r],e);this._flushSubComponentsWaiters()})}_flushSubComponentsWaiters(){this._fetchSubComponents(this._subComponentsWaiters),this._subComponentsWaiters=new Map,this._shouldWait=!1}isReady(){this._kernelContainer.setExternalHelpers(this._kernelIo,{convertCObject:En}),Ni.isProduction||Ni.isUnitTesting||this.addDebugInfo(),window.KernelCallback&&(window.KernelCallback=null,delete window.KernelCallback)}addDebugInfo(){const e=function(t,r=[]){const n=Object.getPrototypeOf(t),a=n?Object.getOwnPropertyNames(n):[],i=t?Object.getOwnPropertyNames(t):[];return n?e(n,[...r,...i,...a]):[...i,...a,...r]},t=e(this),r=["constructor","hasOwnProperty","isPrototypeOf","propertyIsEnumerable","toString","valueOf"];[...new Set(t)].forEach(e=>{if(!e.startsWith("_")&&"function"==typeof this[e]&&-1===r.indexOf(e))try{const t=this[e].bind(this);this[e]=function(...r){return this._kernelIo.log("[ KernelCommunication ]: "+e),t(...r)}}catch(e){}})}getConfigurationData(e){return new Promise(t=>{var r;const n=this.kernelInstance.getPlanObject(e),a=(new Date).toISOString(),i=this.kernelInstance.getComponentId(e),s=hr(i),o=(null===(r=n.boxForMeasurement)||void 0===r?void 0:r.size)||n.bounds;t({created:a,lastAccess:a,configuration:this.kernelInstance.getSerializedConfiguration(e),configurationHash:this.kernelInstance.getHashOfConfiguration(e),parts:JSON.stringify(this.kernelInstance.getPartList(e)),rootComponentId:i,width:o.x,height:o.z,depth:o.y,catalog:s,orderable:!1,requestable:!1})})}loadComponent(e,t,r){this._rapiAccess.getComponent(t.componentId).then(n=>{var a;let i=n.configuration;i||(i="error",null===(a=this._configuratorUiCallbacks)||void 0===a||a.onContentProblem({rapiPath:"components",ids:[t.componentId],message:t.componentId+" has no configuration"})),this._kernelIo.setMeta({componentId:t.componentId}),this._kernelInstance.loadComponent(e,i,t,r),this._flushSubComponentsWaiters()},n=>{var a;this._kernelInstance.loadComponent(e,"error",t,r),this.onLoadComponentError(n,t.componentId),null===(a=this._configuratorUiCallbacks)||void 0===a||a.onError(new Error(`Component with id "${t.componentId}" can not be loaded. "${n}"`)),this._flushSubComponentsWaiters()})}loadSubComponent(e,t,r){if(this._shouldWait){let n=this._subComponentsWaiters.get(r);n||this._subComponentsWaiters.set(r,[]),n=this._subComponentsWaiters.get(r),n.push({parentId:e,partId:t}),this._subComponentsWaiters.set(r,n)}else this._rapiAccess.getComponent(r).then(n=>{var a;let i=n.configuration;i||(i="error",null===(a=this._configuratorUiCallbacks)||void 0===a||a.onContentProblem({rapiPath:"components",ids:[r],message:"SubComponent "+r+" has no configuration"})),this._kernelIo.setMeta({componentId:r,parentId:e}),this._kernelInstance.loadedSubComponent(e,t,r,i)})}async loadItemConfigurations(e,t){let r=Array.isArray(t)?t:[t];if(this._requestedItemIds.push(...r),await Ge(0),!this._requestedItemIds.length)return;const n=[...this._requestedItemIds];this._requestedItemIds=[],(await this._rapiAccess.getItems(n)).forEach(t=>{this._kernelInstance.loadedItemConfiguration(e,t.id,t.configuration)})}requestDeleteComponent(e){var t,r;e&&((null===(r=null===(t=this._initData)||void 0===t?void 0:t.featureFlags)||void 0===r?void 0:r.reDock)?this._kernelInstance.deletePlanComponent(e):this._kernelInstance.deleteComponent(e))}dockComponentWithPosition(e,t,r,n,a){var i;this._kernelInstance.dockComponentWithPosition(r,n,e,t,a);const s=this._kernelInstance.getComponentId(r),o=this._kernelInstance.getComponentId(e);null===(i=this._configuratorUiCallbacks)||void 0===i||i.onUserInitiatedDockDone(s,n,o,t,a)}Editor3dAddBakedMesh(e,t,r,n,a,i,s,o){this._configuratorKernelCallbackListener.forEach(l=>l.Editor3dAddBakedMesh(e,t,r,n,a,i,s,o))}Editor3dAddNamedMesh(e,t,r,n,a,i,s,o,l,h,d,c){this._configuratorKernelCallbackListener.forEach(u=>u.Editor3dAddNamedMesh(e,t,r,n,a,i,s,o,l,h,d,c))}Editor3ChangedNamedMesh(e,t,r,n,a,i,s){this._configuratorKernelCallbackListener.forEach(o=>o.Editor3ChangedNamedMesh(e,t,r,n,a,i,s))}Editor3dRemoveNamedMesh(e,t){this._configuratorKernelCallbackListener.forEach(r=>r.Editor3dRemoveNamedMesh(e,t))}Editor3dBeginConstruction(e,t){this._configuratorKernelCallbackListener.forEach(r=>r.Editor3dBeginConstruction(e,t))}Editor3dEndConstruction(e){this._configuratorKernelCallbackListener.forEach(t=>t.Editor3dEndConstruction(e))}Editor3dComponentCreated(e,t,r,n){this._configuratorKernelCallbackListener.forEach(a=>a.Editor3dComponentCreated(e,t,r,n,!1))}Editor3dComponentDocked(e,t,r,n){this._configuratorKernelCallbackListener.forEach(a=>a.Editor3dComponentDocked(e,t,r,n))}Editor3dGeometryReady(e){this._configuratorKernelCallbackListener.forEach(t=>t.Editor3dGeometryReady(e)),this.requestPlanComponentConstruction(e),this._configuratorUiCallbacks.onGeometryReady(e)}Editor3dGeometryNotReady(e){this._configuratorKernelCallbackListener.forEach(t=>t.Editor3dGeometryNotReady(e)),this._configuratorUiCallbacks.onGeometryNotReady(e)}componentDeleted(e){this._configuratorKernelCallbackListener.forEach(t=>t.componentDeleted(e))}componentMetaUpdated(e){let t=this._kernelInstance.getComponent(e);this._configuratorKernelCallbackListener.forEach(e=>e.componentMetaUpdated(t))}sceneCleared(){this._configuratorKernelCallbackListener.forEach(e=>e.sceneCleared())}requestMaterialsInGroup(e){(Array.isArray(e)?e:[e]).forEach(e=>{-1===this._cachedGroupIds.indexOf(e)&&this._cachedGroupIds.push(e)}),this._waitingForGroups||(this._waitingForGroups=!0,Zi.waitFor(4).then(()=>{this._rapiAccess.getMaterialsByGroup(this._cachedGroupIds).then(e=>{let t=[];e.forEach(e=>{const r=[];e.materials.forEach(e=>r.push(e.id));const n=e.legacyId||e.id;e.legacyId||console.warn("Material group has no legacy id, please check content why this is the case"),t.push({group:n,materials:r})}),t.length&&this._kernelInstance.setMaterialsInGroup(t),this._cachedGroupIds=[]},e=>{var t;console.error(e),null===(t=this._configuratorUiCallbacks)||void 0===t||t.onError(new Error(`Material group with ids "${this._cachedGroupIds.join(",")}" can not be loaded. "${e}"`)),this._cachedGroupIds=[]})}))}requestPlanComponentConstruction(e,t=!0){t?this._kernelInstance.requestDeltaPlanComponentConstruction(e):this._kernelInstance.requestPlanComponentConstruction(e)}addConfiguratorListener(e){this._configuratorKernelCallbackListener.add(e)}removeConfiguratorListener(e){this._configuratorKernelCallbackListener.delete(e)}cleanUpCallbacks(){"function"==typeof this._kernelContainer.unregisterConfiguratorCallback&&this._kernelContainer.unregisterConfiguratorCallback(this)}async requestMaterialProperties(e){let t=Array.isArray(e)?e:[e];if(this._requestedMaterialIds.push(...t),await Ge(0),!this._requestedMaterialIds.length)return;const r=[...this._requestedMaterialIds];this._requestedMaterialIds=[];const n=await this._rapiAccess.getMaterials(r);let a=[];n.forEach(e=>{const t=new this._kernelContainer.StringStringMap,r=e.properties||{};for(let e in r)r.hasOwnProperty(e)&&t.set(e,r[e]);t.size()&&a.push({id:e.id,properties:t})}),a.length&&this._kernelInstance.setMaterialProperties(a)}registerCallbacks(){this._kernelContainer.registerConfiguratorCallback(this)}pause(){this.cleanUpCallbacks()}resume(){this.cleanUpCallbacks(),this.registerCallbacks()}destroy(){}_handleCortoMesh(e,t,r){var n;try{this._kernelInstance.addMeshCorto(t,r,new Uint8Array(e))}catch(e){console.error(e),null===(n=this._configuratorUiCallbacks)||void 0===n||n.onMemoryCorruption()}}_handleInvalidMesh(e){try{this._kernelInstance.setExternalMeshInvalid(e)}catch(e){console.error(e)}}calcPartsPriceSum(e){return this._calcPrice(e)}_calcPrice(e){const t=new Map;e||(e=this._kernelInstance.getFullPartList());const r=!!e&&!!e.fullList&&!!e.fullList.length;if(this._initData.useRoomlePrice&&r){const r=e.fullList[0].currencySymbol,n=e.fullList.reduce((e,t)=>e+(t.count?t.count:0)*(t.price?t.price:0),0),a=We(n,2);return this._configuratorUiCallbacks.onUpdatePrice(r,a),Promise.resolve({totalSum:a,partMap:t})}if(this._initData.usePriceService&&r){const r=e.fullList.reduce((e,r)=>{const n=dr(r);return n&&(t.set(n,r),e.push(n)),e},[]);return new Promise((n,a)=>{this._rapiAccess.getPrices(r).then(r=>{if(!r.length)return a(new Error("prices are empty"));let i=0;const s=Ke(r,"priceId");for(const t of e.fullList){const e=dr(t);if(!s.has(e)){console.warn("PriceId: "+e+" has no corresponding kernel-part");continue}const{price:r,currencySymbol:n}=s.get(e);t.price=r,t.currencySymbol=n,i+=r*t.count}return i=We(i,2),this._configuratorUiCallbacks.onUpdatePrice(r[0].currencySymbol,i),n({totalSum:i,partMap:t})},e=>{console.error(e),a(e)})})}return Promise.resolve({totalSum:0,partMap:t})}async addUiDataAndPriceToPartList(e,t){const{fullList:r,originPart:n}=e,a=e.perMainComponent;let i;this.addUiDataToPartList(r,t);try{const t=await this._calcPrice(e);i=t.partMap}catch(e){console.error(e),i=new Map}const s=this._initData.usePriceService||this._initData.useRoomlePrice,o=e=>{s||(e.price=null,e.currencySymbol=null);const t=dr(e);if(!t)return;if(!i.has(t))return;const{price:r,currencySymbol:n}=i.get(t);"number"==typeof r&&(e.price=r,e.currencySymbol=n)};return r.forEach(o),a.forEach(({fullList:e,perMainComponent:r})=>{r.length>0&&console.error("Not implemented! perMainComponent is deeper than one level"),this.addUiDataToPartList(e,t),e.forEach(o)}),{fullList:r,perMainComponent:a,originPart:n}}addUiDataToPartList(e,t){const r=[];return e.forEach(e=>{const t=this._rapiAccess.peekComponent(e.componentId);!t||e.labelIsCalculated&&e.label||(e.label=t.label),e.parameters.forEach(e=>{if(this._unitFormatter.formatPartListParameter(e),es(e)){const t=this._rapiAccess.peekMaterial(e.value);t?e.valueLabel=t.label||t.name||e.value:-1===r.indexOf(e.value)&&r.push(e.value)}})}),r.length&&this._rapiAccess.getMaterials(r).then(e=>{const r=this._lastPartListHash!==t;Array.isArray(e)&&e.length&&r&&(this._lastPartListHash=t,this.requestPartListAndUpdatePricesOfParts())}),e}async requestPartListAndUpdatePricesOfParts(e,t){let r=this._kernelInstance.getFullPartList();e||(e=this._kernelInstance.getHashOfConfiguration(this._configuratorContext.planObjectId));const n=await this.addUiDataAndPriceToPartList(r,e);this._configuratorUiCallbacks.onPartListUpdate(n,btoa(e))}}pr([fr],ls.prototype,"_rapiAccess",void 0),pr([fr],ls.prototype,"_scriptLoader",void 0),pr([fr],ls.prototype,"_kernelIo",void 0),pr([fr],ls.prototype,"_dataSyncer",void 0),pr([fr],ls.prototype,"_lifeCycleManager",void 0),pr([fr],ls.prototype,"_configuratorUiCallbacks",void 0),pr([fr],ls.prototype,"_globalCallback",void 0),pr([fr],ls.prototype,"_initData",void 0),pr([fr],ls.prototype,"_unitFormatter",void 0),pr([fr],ls.prototype,"_configuratorContext",void 0),pr([fr],ls.prototype,"_globalInitData",void 0);const{APP:hs}=Ni,{RAPI:ds}=hs,cs=ds.headers,us=ds.itemHeaders,ps=cs.token,ms=e("al",e=>e.startsWith("ps_")),fs=Xe();let gs=new Map,vs=new Map,ws=new Map,bs=new Map,ys=new Map,_s=new Map,xs=new Map,Ss=new Map,Cs=new Map;const Ms=e=>gs.get(e)||gs.get(fs+e),Ts=e=>e&&e.tags&&e.tags.length,As=e=>!Ts(e)&&e.group;class Ps{constructor(e){this._itemLoaded=!1,this._currentToken=null,this._creator_=e,window.addEventListener("online",this._flushOfflineQueue.bind(this))}getPreloadForItem(e){return this._getPreload(e,!0)}getPreloadForConfiguration(e){return this._getPreload(e,!1)}_getPreload(e,t){return new Promise((r,n)=>{if(!navigator.onLine)return r();if(this._dataSyncer.getIsCatalogSynced(hr(e)))return r();if(xs.get(e))return r();const a=t?"?itemId=":"?configurationId=";this._get("/preloads/components/"+a+e,"preloads/components").then(t=>{if(xs.get(e))return r();t.forEach(e=>{this._prepareData(e,"components")}),xs.set(e,!0),r()},n)})}changeUseOfHDGeometry(){const e=bs.get("components");xs.clear(),_s.clear(),e&&bs.delete("components")}getHSCPackage(e){return new Promise((t,r)=>{if(_s.get(e))return t();this._get("/catalogs/"+e+"/package","package").then(r=>{if(_s.get(e))return t(r);r.components.forEach(e=>{this._prepareData(e,"components")}),r.materials.forEach(e=>{this._prepareData(e,"materials"),this._prepareGroups(e)}),r.textures.forEach(e=>{this._prepareData(e,"textures")}),_s.set(e,!0),t(r)},r)})}getComponent(e){return this._getById(e,"components")}getConfiguration(e){return this._getById(e,"configurations")}getConfigurations(e){return this._getByIds(e,"configurations")}getItem(e){return this._getById(e,"items",{additionalHeaders:us})}getComponents(e){return this._getByIds(e,"components")}getItems(e){return this._getByIds(e,"items",{additionalHeaders:us})}getTag(e){return this._getById(e,"tags")}getTags(e){return this._getByIds(e,"tags")}getTexture(e){return this._getById(e,"textures")}getCatalog(e){return this._getById(e,"catalogs")}getMesh(e,t="crt",r=50){return this._getById(e,"meshes",{pathSuffix:"/data?format="+t+"&targetQuality="+r.toString()})}getMeshesOfCatalog(e){return new Promise((t,r)=>{const n=ys.get(e);n?t(n):this._get("/meshes?catalog="+e,"catalogMeshes").then(r=>{ys.set(e,r),t(r)},r)})}getTexturesOf(e){return this._getRelationData(e,{rapiPath:"textures"})}getItemsOf(e){return this._getRelationData(e,{rapiPath:"items"})}async getMaterialsOf(e){return(await this._getRelationData(e,{rapiPath:"materials"},{embed:["textures"]})).filter(e=>e.active)}getComponentsOf(e){return this._getRelationData(e,{rapiPath:"components"})}getAdditionalContentsOfItems(e){const t=[],r=[];return e.forEach(e=>{const n=vs.get(e.id.toString());n?r.push(...n):t.push(e.id.toString())}),new Promise((e,n)=>{0!==t.length?this._getByIdsPackets(t,"itemAdditionalContents",{filterKey:"itemIds"}).then(t=>{t.forEach(e=>{let t=vs.get(e.itemId);t||(t=[]);for(let r=0,n=t.length;r<n;r++)if(t[r].id===e.id)return;t.push(e),vs.set(e.itemId,t)}),e([...t,...r])},n):e(r)})}getMaterial(e){return this._getById(e,"materials",{embed:["textures"]})}peekMaterial(e){return this._peekData(e,"materials")}peekComponent(e){return this._peekData(e,"components")}peekItem(e){return this._peekData(e,"items")}peekConfiguration(e){return this._peekData(e,"configurations")}async getMaterials(e){return(await this._getByIds(e,"materials",{embed:["textures"]})).filter(e=>e.active)}getPlan(e){return this._getById(e,"plans")}getPlanSnapshot(e){return this._getById(e,"planSnapshots")}static clearCaches(){gs=new Map,ws=new Map,bs=new Map,_s=new Map,xs=new Map,Ss=new Map,vs=new Map}cleanUp(){Ps.clearCaches()}getMaterialsByGroup(e){const t=e.slice(),r=[];let n=t.length;for(let e=0;e<n;e++){const a=Ms(t[e]);if(a){const i=a.length;for(let e=0;e<i;e++){const t=this._getCache("materials").get(a[e]);r.push(t)}t.splice(e,1),n--,e--}}return new Promise((e,n)=>{0!==t.length&&navigator.onLine?this._getByIdsPackets(t,"materials",{filterKey:"groups",embed:["textures"]}).then(t=>{e(this.combineMaterialsToGroups([...t,...r]))},n):e(this.combineMaterialsToGroups(r))})}_flushOfflineQueue(){return new Promise((e,t)=>{const r=this._localStorage.getItem("hsc_configurations_offline_queue_v1"),n=[];for(let e in r)if(r.hasOwnProperty(e)){const t=r[e];n.push(new Promise((e,r)=>{this.saveConfiguration(t.data).then(n=>{const a=[];t.perspectiveImage&&!n.perspectiveImage&&a.push(this.savePerspectiveImage(n,t.perspectiveImage)),t.topImage&&!n.topImage&&a.push(this.savePerspectiveImage(n,t.topImage)),Promise.all(a).then(e,r)},r)}))}Promise.all(n).then(()=>{this._localStorage.setItem("hsc_configurations_offline_queue_v1",{}),e()},t)})}_setQueuedConfiguration(e,t={}){const r=e.configurationHash,{perspectiveImage:n,topImage:a}=t;let i=this._localStorage.getItem("hsc_configurations_offline_queue_v1")||{},s=i[r]||{};s.data=e,s.perspectiveImage=n,s.topImage=a,i[r]=s,this._localStorage.setItem("hsc_configurations_offline_queue_v1",i)}async saveConfiguration(e){return navigator.onLine?await this._save("/configurations",{configuration:e},"configurations",{accept:"application/json",contentType:"application/json; charset=UTF-8"}):(e.perspectiveImage=null,e.topImage=null,this._setQueuedConfiguration(e),this._markConfigurationAsLocally(e),Promise.resolve(e))}saveTopImage(e,t){return this._saveConfigurationImage(e,t,"topImage")}savePerspectiveImage(e,t){return this._saveConfigurationImage(e,t,"perspectiveImage")}savePlanSnapshotTopImage(e,t){return this._savePlanSnapshotImage(e,t,"topImage")}savePlanSnapshotPerspectiveImage(e,t){return this._savePlanSnapshotImage(e,t,"perspectiveImage")}getShortUrl(e,t){return new Promise((r,n)=>this._fetchJson("/shortIds","shortIds",{method:"POST",resolve:r,reject:n,data:JSON.stringify({shortId:{type:t,referencedId:e}}),accept:"application/json",contentType:"application/json; charset=UTF-8"}))}_peekData(e,t){const r=bs.get(t);return r&&r.get(e)||null}_saveConfigurationImage(e,t,r){if(!navigator.onLine){const n={};return n[r]=t,this._setQueuedConfiguration(e,n),this._markConfigurationAsLocally(e),e[r]=t.image,Promise.resolve(e)}const n=this._formDataUtil.create(t.image,e.configurationHash,ar.PNG,r);return this._save("/configurations/"+e.id+"/"+r,n,"configurations",{accept:"application/json"})}_savePlanSnapshotImage(e,t,r){const n=this._formDataUtil.create(t.image,e.id,ar.PNG,"file");return n.append("type",r),this._save("/planSnapshots/"+e.id,n,"planSnapshots",{accept:"application/json",method:"PUT"})}_markConfigurationAsLocally(e){e.isLocally=!0,e.id=e.configurationHash}_save(e,t,r,n={}){const a=t instanceof FormData?t:JSON.stringify(t);return new Promise((t,i)=>{const s={method:n.method||"POST",data:a,resolve:t,reject:i};n.contentType&&(s.contentType=n.contentType),n.accept&&(s.accept=n.accept),this._fetchJson(e,r,s)})}combineMaterialsToGroups(e){return new Promise((t,r)=>{const n=new Map,a={id:null,label:null,materials:[]},i=[];for(let t=0,r=e.length;t<r;t++){const r=e[t],s=r.tags&&r.tags.length?r.tags.map(e=>({isTag:!0,id:e})):[];r.group&&s.push({isTag:!1,id:fs+r.group,legacyId:r.group}),s.length||s.push({isTag:!1,id:null}),r.tags&&r.tags.length&&r.tags.forEach(e=>-1===i.indexOf(e)?i.push(e):null),s.forEach(({isTag:e,id:t,legacyId:i})=>{const s=r.id;let o=t?Ms(t):[];o||(gs.set(t,[]),o=Ms(t)),-1===o.indexOf(s.toString())&&o.push(s.toString());const l=Ts(r),h=l&&e,d=As(r);if(h||d&&!e||!l&&!d&&!t){let e=t?n.get(t):a;e||(n.set(t,{id:t,label:r.groupLabel,legacyId:i,materials:[]}),e=n.get(t)),e.materials.push(r)}})}const s=a.materials.length?[a]:[];this.getTags(i).then(e=>{const r=e.reduce((e,t)=>(e[t.id]=t,e),{});return n.forEach((e,t)=>{s.push({id:t,label:r[t]?r[t].label:e.label,materials:e.materials,legacyId:e.legacyId,sort:r[t]?r[t].sort:void 0})}),t(s)},r)})}_getByIds(e,t,r={}){const n=this._getCache(t),a=this._getErrorCache(t),i=[],s=[...new Set(e)];let o=s.length;if(n&&n.size){const e=(new Date).getTime();for(let t=0;t<o;t++){const r=s[t],l=n.get(r),h=a.get(r);let d=!1;null!=l?(i.push(l),d=!0):d=void 0!==h&&(e-h.timestamp<6e4||!1===navigator.onLine),d&&(s.splice(t,1),o--,t--)}}return new Promise((e,n)=>{0!==s.length&&navigator.onLine?this._getByIdsPackets(s,t,r).then(t=>{e([...t,...i])},n):e(i)})}_getByIdsPackets(e,t,r={}){const n=r.filterKey||"ids";let a,i="/"+t+"/",s="?",o=[];const l=e.length;if(!l)return new Promise(e=>e([]));let h=!0,d=[];for(a=0;a<l;a++){h=!1;const r=e[a],l=s+n+"[]="+r,c=l.length+i.length;d.push(r),s="&",c<=1500?i+=l:(c>1500&&(d.pop(),a--),o.push({url:i,ids:d}),h=!0,i="/"+t+"/",s="?",d=[])}h||o.push({url:i,ids:d});const c=[];return o.forEach(e=>c.push(this._getByIdsSingle(e.ids,e.url,t,r))),new Promise((e,t)=>{Promise.all(c).then(t=>{const r=[];t.length&&t.forEach(e=>r.push(...e)),e(r)},t)})}_getByIdsSingle(e,t,r,n={}){return new Promise((a,i)=>{this._get(t,r,n).then(t=>{for(let r=0,a=t.length;r<a;r++){const a=n&&n.cacheKey?t[r][n.cacheKey]:t[r].id,i=e.indexOf(a.toString());-1!==i&&e.splice(i,1)}const i=e.length;if(i){const t=this._getCache(r),n=this._getErrorCache(r),a=(new Date).getTime();for(let r=0;r<i;r++)n.set(e[r],{code:0,timestamp:a}),t.delete(e[r]);this._errorHandler.dispatch(2,[r,e.map(e=>'"'+e+'"').join(",")])}a(t)},i)})}_getById(e,t,r={}){if(!e||""===e||"string"!=typeof e)return console.error("no id passed to _getById"),Promise.reject(new Error("no id passed to _getById"));const n=this._getCache(t).get(e);if(n)return new Promise(e=>e(n));if(!navigator.onLine)return Promise.reject("Nothing cached but tried to fetch in offline mode");const a={...r,id:e},i=r.pathSuffix||"";return this._get("/"+t+"/"+e+i,t,a)}_get(e,t,r={}){const n=qi.useHDGeometry?"includeGeometryHD=true":"";let a=-1===e.indexOf("?")?"?":"&";return""!==n&&(e+=a+n),r.embed&&Array.isArray(r.embed)&&r.embed.forEach(t=>{e+=a+"embed"+(t[0].toUpperCase()+t.substr(1))+"=true",a="&"}),new Promise((n,a)=>{const i=Ss.get(e);Array.isArray(i)&&i.length>0?i.push({resolve:n,reject:a}):(Ss.set(e,[{resolve:n,reject:a}]),this._fetchJson(e,t,r))})}_fetchJson(e,t,r={}){this._fetch(e,r).then(qe.bind(this)).then(this._handleJson(e,t,r).bind(this)).catch(this._handleError(e,r).bind(this))}async _fetch(e,t){const r={method:t.method?t.method:"GET",headers:this._createHeaders(t),mode:"cors",cache:"default"};t.data&&(r.body=t.data);let n=ds.server;const a=this._globalInitData.overrideRapi;a&&(n="live"===a?ds.liveServer:ds.testServer),(this._globalInitData.customApiUrl||""===this._globalInitData.customApiUrl)&&(n=this._globalInitData.customApiUrl);const i=new Request(n+e,r);this._globalCallback.onNetworkRequest(e,r,t);const s=await this._globalCallback.onCheckExternalCache(e,r);return s?{headers:{get:()=>"application/json"},json:()=>Promise.resolve(s)}:this._networkLayer.fetch(i,{},{checkResponse:e=>this._globalCallback.onValidateNetworkResponse("rapi-access",e)})}_createHeaders(e={}){const t={...cs};this._globalInitData.overrideTenant&&(t.currentTenant=this._globalInitData.overrideTenant),this._globalInitData.overrideCountry&&(t.country=this._globalInitData.overrideCountry);const r=this._globalInitData.locale||"en";t.language=r,t.locale=r;const{contentType:n,accept:a,additionalHeaders:i,data:s}=e;if(n&&(t["content-type"]=e.contentType),a&&(t.accept=e.accept),i)for(let e in i)i.hasOwnProperty(e)&&(t[e]=i[e]);this._globalInitData.configuratorId&&(t.configurator=this._globalInitData.configuratorId);const o=this._currentToken||ps;t.token="03-"+window.btoa((new Date).toISOString()+";"+o+";"+cs.apiKey);const l=new Headers(t);return s instanceof FormData&&l.delete("content-type"),l}_handleJson(e,t,r={}){return n=>{let a=null,i=null;"number"==typeof n&&(a=n);for(let e in n)"meta"!==e&&n.hasOwnProperty(e)&&(a=n[e],i=e);if("error"===i)return this._handleError(e,r)(new Error(JSON.stringify(a)));if(!a)throw new TypeError("RAPI returned empty JSON");if(Array.isArray(a))for(let e=0,n=a.length;e<n;e++)this._prepareData(a[e],t,r),this._prepareEmbeddedData(a[e],t,r);else this._prepareData(a,t,r),this._prepareEmbeddedData(a,t,r);r.resolve?r.resolve(a):this._notifyWaiters(e,null,a)}}_prepareEmbeddedData(e,t,r={}){r.embed&&Array.isArray(r.embed)&&r.embed.forEach(n=>{const a=e[n.slice(0,-1)+"Objects"];if(Array.isArray(a)){for(let e=0,t=a.length;e<t;e++)this._prepareData(a[e],n,r);this._prepareRelationalData(t,n,e.id,a)}else a&&(this._prepareData(a,n,r),this._prepareRelationalData(t,n,e.id,[a]))})}_getCache(e){return this._getCacheFrom(e,bs)}_getErrorCache(e){return this._getCacheFrom(e,Cs)}_getCacheFrom(e,t){let r=t.get(e);return r||(t.set(e,new Map),r=t.get(e)),r}_setCache(e,t,r){r.set(e.toString(),t)}_prepareData(e,t,r=null){let n=this._getCache(t);const a=r&&r.cacheKey?e[r.cacheKey]:e.id;if(a||r&&r.id||"tenants/me"===t)if("tenants/me"!==t){{const t=a||r.id;this._setCache(t,e,n)}e.__rapi_path__=t}else this._setCache("0",e,n);else"shortIds"!==t&&console.error("Can not cache because there is no ID!")}_getRelationsCacheFor(e,t,r){let n=ws.get(t);if(!n){const a=new Map,i=new Map;i.set(r,void 0),a.set(e,i),ws.set(t,a),n=ws.get(t)}let a=n.get(e);if(!a){const t=new Map;t.set(r,void 0),n.set(e,t),a=n.get(e)}return a.get(r)}_prepareGroups(e){const t=e.group,r=e.id;let n=Ms(t);n||(gs.set(t,[]),n=Ms(t)),-1===n.indexOf(r.toString())&&n.push(r.toString())}_handleError(e,t={}){return r=>{navigator.onLine?(r.rmlErrorCode=1,r.message='Failed to load "'+e+'" because of "'+r.message+'"',this._errorHandler.dispatch(1,[r])):(r.rmlErrorCode=0,r.message='Failed to load "'+e+'" because of "'+r.message+'"',this._errorHandler.dispatch(0,[r])),t.reject?t.reject(r):this._notifyWaiters(e,r,null)}}_getRelationData(e,t,r={}){const n=e.id;if(!n)return Promise.resolve([]);const a=e.__rapi_path__,i=t.rapiPath;let s=this._getCache(i),o=this._getRelationsCacheFor(n.toString(),a,i),l=[];return o?(o.forEach(e=>l.push(s.get(e))),new Promise(e=>e(l))):navigator.onLine?new Promise((e,t)=>{this._get("/"+a+"/"+n+"/"+i,i,r).then(t=>{this._prepareRelationalData(a,i,n,t),e(t)},t)}):Promise.resolve([])}_prepareRelationalData(e,t,r,n){ws.has(e)||ws.set(e,new Map);let a=ws.get(e);const i=r.toString();a.has(i)||a.set(i,new Map);let s=a.get(i),o=this._getCache(t),l=[];for(let e=0,t=n.length;e<t;e++){const t=n[e],r=t.id.toString();l.push(r),o.set(r,t)}s.set(t,l)}_notifyWaiters(e,t,r){const n=Ss.get(e);if(n&&n.length){for(let e=0,a=n.length;e<a;e++)t?n[e].reject(t):n[e].resolve(r);Ss.delete(e)}}_tenantMe(){return new Promise((e,t)=>{const r=this._getCache("tenants/me"),n=this._globalInitData.overrideTenant?this._globalInitData.overrideTenant:r.get("0");if(n)return e(n);this._fetchJson("/tenants/me","tenants/me",{resolve:t=>e(t),reject:t})})}async getTenant(e){return e||(e=await this._tenantMe()),this._getById(e.toString(),"tenants")}getCurrentSkin(){return this._tenantMe().then(e=>this._getById(e.toString(),"tenants").then(e=>this._getById(e.skin.toString(),"skins")))}getPrices(e){return this._getByIds(e,"prices",{filterKey:"priceIds",cacheKey:"priceId"})}async getConfiguratorSettings(e){const t=await this._getById(e,"configurators");return t.allowedHosts||(t.allowedHosts=[]),t.allowedHosts&&!Array.isArray(t.allowedHosts)&&(t.allowedHosts=t.allowedHosts.split(" ")),t}sendUserAction(e){return this._save("/userActions",{userAction:e},"userActions",{accept:"application/json",contentType:"application/json; charset=UTF-8"})}_share(e,t,r,n){const a="/"+n+"/"+e+"/shares",i=new FormData;return i.append("email",t),i.append("type",r.toString()),new Promise((e,t)=>{const r={method:"POST",data:i,resolve:e,reject:t,accept:"application/json",contentType:"application/json; charset=UTF-8"};this._fetch(a,r).then(r.resolve,r.reject)})}shareConfiguration(e,t,r){return this._share(e,t,r,"configurations")}sharePlanSnapshot(e,t,r){return this._share(e,t,r,"planSnapshots")}export3D(e,t,r,n={}){const a="/"+(ms(e)?"planSnapshots":"configurations")+"/"+e+"/3d-exports",i={formats:[{file_format:r,pack_external_data:!0,...n}]},s=JSON.stringify(i),o=new FormData;return o.append("email",t),o.append("settings",s),new Promise((e,t)=>{const r={method:"POST",data:o,resolve:e,reject:t};this._fetch(a,r).then(r.resolve,r.reject)})}async trackView(e){if(this._itemLoaded||(t=(()=>{var e;const t=(()=>{if(window.__RML__ENV__&&window.__RML__ENV__.skipIframeCheck)return!1;try{return window.self!==window.top}catch(e){return!0}})();let r=null===(e=null===window||void 0===window?void 0:window.location)||void 0===e?void 0:e.href;if(!r)return null;if(t){if(!document.referrer)return null;r=document.referrer}const{hostname:n}=new URL(r);return n})())&&(lr.includes(t)||t.endsWith("gitlab.io")||t.endsWith("gitlab.com")||t.endsWith("codesandbox.io")||t.endsWith("stackblitz.com")||/^(admin.*.roomle.com)$/.test(t)))return;var t;const{configuratorId:r}=this._globalInitData,n={module:3,action:1,actionId:e,actionLabel:r};await this.sendUserAction(n),this._itemLoaded=!0}signinUser(e,t){return new Promise((r,n)=>{const a={method:"POST",accept:"application/json",contentType:"application/json; charset=UTF-8",data:JSON.stringify({identification:e,passwordMD5:t}),cacheKey:"token",resolve:r,reject:n};this._fetchJson("/auth/signin","auth",a)})}async signoutUser(e){const t=this._currentToken;t!==e&&this.setCurrentToken(e),await this._fetch("/auth/signout",{}),t&&t!==e?this.setCurrentToken(t):this.removeCurrentToken()}async savePlan(e){const t=e.id?"/plans/"+e.id:"/plans";return this._save(t,{plan:e},"plans",{method:e.id?"PUT":"POST",accept:"application/json",contentType:"application/json; charset=UTF-8"})}async savePlanSnapshot(e){return this._save("/planSnapshots",{planSnapshot:e},"planSnapshots",{accept:"application/json",contentType:"application/json; charset=UTF-8"})}setCurrentToken(e){this._currentToken=e}removeCurrentToken(){this._currentToken=null}createNewPlan(){return{name:"",description:"",changeDate:(new Date).toISOString(),created:(new Date).toISOString(),draftId:null,thumbnail:"data:image/png;base64,missing",planObjects:null,active:!0,open:0,planDirectory:0,changed:0,version:2,floorLevel:0,visibility:9,user:null,tenant:null,assets:[],parent:null,setting:null}}}e("R",Ps),pr([fr],Ps.prototype,"_formDataUtil",void 0),pr([fr],Ps.prototype,"_errorHandler",void 0),pr([fr],Ps.prototype,"_dataSyncer",void 0),pr([fr],Ps.prototype,"_networkLayer",void 0),pr([fr],Ps.prototype,"_localStorage",void 0),pr([fr],Ps.prototype,"_globalInitData",void 0),pr([fr],Ps.prototype,"_globalCallback",void 0);const Rs=e("o",1500),Es=e("n",5);function Is(){class e extends I{static _generateOutline(e,t){let r=new W(new Ye(e),new Ze({color:"#000000",dashSize:.03,gapSize:.01,linewidth:1}));return r.translateOnAxis(t,1),r.userData.ignoreComponentRaycast=!0,r}static cloneDockLine(e,t){let r=new W(e.geometry,e.material);return r.translateOnAxis(t.getCenter(new s),1),r.name="dockline",r.layers.set(5),r.userData.ignoreComponentRaycast=!0,r}_setValues(e,t,r,n){e&&(this.runtimeId=e,this.name=e.toString()),t&&(this.roomlePosition=Object.assign({},t)),r&&(this.roomleRotation=Object.assign({},r)),n&&(this.parentObjectId=n)}constructor(e,t,r,n){super(),this._selected=!1,this.geometryChanged=!0,this.meshes=[],this.castShadow=!1,this.receiveShadow=!0,this._setValues(e,t,r,n)}get loadingMesh(){return this._loadingMesh}get boundingBoxMesh(){return this._boundingBoxMesh}get boundingBox(){return this._boundingBox}set roomlePosition(e){this._roomlePosition=e,e&&this.position.set(e.x/1e3,e.z/1e3,e.y/-1e3)}get roomlePosition(){return this._roomlePosition}set roomleRotation(e){this._roomleRotation=e,e&&this.rotation.set(e.x,e.z,-e.y)}get roomleRotation(){return this._roomleRotation}replaceMeshes(e){this.removeAllMeshes(),e.forEach(e=>{this.addMesh(new K(e.geometry,e.material))})}addMesh(e,t){e.renderOrder=2,e.userData.meshType=0,t&&e.applyMatrix4(kn(t)),this.add(e),this.meshes.push(e)}getMeshById(e){return this.meshes.find(t=>t.userData.meshId===e)}removeMeshById(e){const t=this.getMeshById(e);t?this.removeMesh(t):console.warn("Could not remove mesh with id "+e,this.runtimeId,this.meshes)}removeMesh(e){const t=this.meshes.indexOf(e);this.remove(e),$a(e),t<0||this.meshes.splice(t,1)}removeAllMeshes(e=!0){this.meshes.forEach(t=>{this.remove(t),e&&$a(t)}),this.meshes=[],this._removeLoadingMesh(),this.remove(this._boundingBoxMesh),$a(this._boundingBoxMesh),this._boundingBoxMesh=null}_hideAllMeshes(){this.meshes.forEach(e=>e.visible=!1)}_showAllMeshes(){this.meshes.forEach(e=>e.visible=!0)}select(){this._selected=!0}loading(){if(!this._kernelBoundingBox)return void console.warn("Bounding box (box for measurements) for component "+this.runtimeId+" not set, can not show external mesh loading box!");this._removeLoadingMesh(),this._hideAllMeshes();const{x:e,y:t,z:r}=this._kernelBoundingBox.getSize(new s);let n=new He(e,t,r);this._loadingMesh=new K(n,_n.createMeshStandardMaterial({transparent:!0,opacity:1,color:new h("#DDDDDD")})),this._loadingMesh.name="loading mesh",this._loadingMesh.receiveShadow=!1,this._loadingMesh.castShadow=!1,this._loadingMesh.layers.set(5),this._loadingMesh.translateOnAxis(this._kernelBoundingBox.getCenter(new s),1),this._loadingMesh.renderOrder=3,this.add(this._loadingMesh)}_removeLoadingMesh(){this._loadingMesh&&(this.remove(this._loadingMesh),$a(this._loadingMesh),this._loadingMesh=null)}loadingFinished(){this._removeLoadingMesh(),this._showAllMeshes()}deselect(){this._selected=!1}hoverOn(){Qe("pointer")}hoverOff(){Qe("default")}removeFromParent(){return this.parent&&(this.parent.remove(this),this.removeAllMeshes()),this}computeBoundingBox(t,r=!1){if(this._boundingBoxMesh&&this.remove(this._boundingBoxMesh),!r&&t&&0===t.size.x&&0===t.size.y&&0===t.size.z)return;let n;if(!t||r){this._boundingBox=new be;let e=new s;this.meshes.forEach(t=>{if(t.geometry instanceof c){let r=t.geometry.attributes.position;if(void 0!==r)for(let n=0,a=r.count;n<a;n++)e.fromBufferAttribute(r,n).applyMatrix4(t.matrix),this._boundingBox.expandByPoint(e)}}),this._kernelBoundingBox=this._boundingBox.clone();let t=this._boundingBox.max.x-this._boundingBox.min.x,r=this._boundingBox.max.y-this._boundingBox.min.y,a=this._boundingBox.max.z-this._boundingBox.min.z;n=new He(t,r,a)}else{this._kernelBoundingBox=Na(t),this._boundingBox=this._kernelBoundingBox.clone();let{x:e,y:r,z:a}=this._boundingBox.getSize(new s);n=new He(e,r,a)}this._boundingBoxMesh=new K(n,_n.createMeshStandardMaterial({color:"#FFFFFF",transparent:!0,opacity:0,polygonOffset:!0,polygonOffsetFactor:-1,visible:!1})),this._boundingBoxMesh.name="bounding box mesh";let a=this._boundingBox.getCenter(new s);this._boundingBoxMesh.position.add(a),this._boundingBoxMesh.layers.set(5),this._boundingBoxMesh.renderOrder=3,this._boundingBoxMesh.castShadow=!1,this._boundingBoxMesh.receiveShadow=!1,this.add(this._boundingBoxMesh),this._dockline=e._generateOutline(n,a),this._dockline.name="bounding box outline",this._dockline.layers.set(5),this._selected&&this.add(this._dockline)}recursiveMeshes(){let t=this.meshes.slice();return this.children.forEach(r=>{r instanceof e&&t.push(...r.recursiveMeshes())}),t}isChild(t){let r=!1;return this.children.forEach(n=>{n instanceof e&&!r&&(r=n.runtimeId===t||n.isChild(t))}),r}getKernelPosition(e){let t=this.parent.localToWorld(this.position);return Pn(e.worldToLocal(t))}}class t extends e{constructor(e,t){super(e,null,null,null),this.glbUrl=t}}class r extends e{constructor(e,t,r,n,a){super(t,r,n,a),this._stringId=null,this.receivedPointAssociation=!1,this.castShadow=!1,this.receiveShadow=!1,this._creator_=e}get stringId(){return this._stringId?this._stringId:this.runtimeId.toString()}addMesh(e,t){super.addMesh(e,t),e.material instanceof H&&(e.material.opacity=.8,e.material.roughness=1,e.material.metalness=0,e.material.color=new h(this._initData.colors.PREVIEW_DOCKING_COLOR)),e.renderOrder=1,e.castShadow=!1,e.receiveShadow=!1}startPulsating(){var e,t;if(null===(t=null===(e=this._initData)||void 0===e?void 0:e.featureFlags)||void 0===t?void 0:t.pulsePreview)for(const e of this.meshes){const t={opacity:.8},r={opacity:.3};new TWEEN.Tween(t).to(r,Rs).easing(TWEEN.Easing.Sinusoidal.In).onUpdate(()=>{e.material.opacity=t.opacity}).yoyo(!0).repeat(Es).start()}}hoverOn(){this.remove(this._dockline),this.meshes.forEach(({material:e})=>{e.opacity=.9,e.roughness=1,e.metalness=0,e.color=new h(this._initData.colors.PREVIEW_DOCKING_COLOR)}),Qe("pointer")}hoverOff(){this.add(this._dockline),this.meshes.forEach(({material:e})=>{e.opacity=.8,e.roughness=1,e.metalness=0,e.color=new h(this._initData.colors.PREVIEW_DOCKING_COLOR)}),Qe("default")}clonePreview(t){const n=new r(this._creator_,this.runtimeId,this.roomlePosition,this.roomleRotation,this.parentObjectId);return n._stringId=this.runtimeId+"_"+t,this.children.forEach(e=>{e instanceof K&&0===e.userData.meshType&&n.meshes.push(e.clone(!0))}),n.meshes.forEach(e=>{e.material=e.material.clone(),e.geometry=e.geometry.clone(),n.add(e)}),this._dockline&&(n._dockline=e.cloneDockLine(this._dockline,this._boundingBox)),this._boundingBoxMesh&&(n._boundingBoxMesh=this._boundingBoxMesh.clone(!0)),this._boundingBox&&(n._boundingBox=this._boundingBox.clone()),n}preparePreview(){this.add(this._dockline),this.add(this._boundingBoxMesh)}}pr([fr],r.prototype,"_initData",void 0);class n extends r{constructor(e,t,r,n,a,i){super(e,t,r,n,a),i&&(this._stringId=this.runtimeId+"_has_additional_dock_point_copy")}set roomleLineFrom(e){this._roomleLineFrom=e,this.lineFrom=Tn(e)}get roomleLineFrom(){return this._roomleLineFrom}set roomleLineTo(e){this._roomleLineTo=e;let t=Tn(e);t.equals(this.lineFrom)&&(console.warn("lineFrom and lineTo are equal!"),t.add(new s(0,.01,0))),this.lineTo=t}get roomleLineTo(){return this._roomleLineTo}set roomlePositionFrom(e){this._roomlePositionFrom=e,this.positionFrom=Tn(e)}get roomlePositionFrom(){return this._roomlePositionFrom}set roomlePositionTo(e){this._roomlePositionTo=e;let t=Tn(e);t.equals(this.positionFrom)&&(console.warn("positionFrom and positionTo are equal!"),t.add(new s(0,.01,0))),this.positionTo=t}get roomlePositionTo(){return this._roomlePositionTo}addMesh(e,t){super.addMesh(e,t),e.visible=!1,e.renderOrder=3}hoverOn(){this._dockline.visible=!0,Qe("pointer")}hoverOff(){this._dockline.visible=!1,Qe("default")}preparePreview(){super.preparePreview(),this._dockline.visible=!1;let e=this.lineTo.clone(),t=this.lineFrom.clone();const r=(new s).subVectors(e,t);let n=r.length(),a=r.normalize(),i=new Je(a,t),o=new $e(.01,.01,n,16,1);this.lineMesh=new K(o,_n.createMeshStandardMaterial({color:"#DDDDDD",transparent:!0,opacity:.4})),this.lineMesh.name="line mesh";const l=(new R).setFromEuler(i.rotation);this.lineMesh.quaternion.multiply(l),this.lineMesh.renderOrder=1;let h=(new s).addVectors(e,t).multiplyScalar(.5);this.lineMesh.position.copy((new s).subVectors(h,this.position.clone())),this.add(this.lineMesh);let d=this._boundingBox.getCenter(new s).applyEuler(this.docklineRotation),c=null,u=0,p=Math.abs(a.x),m=Math.abs(a.y),f=Math.abs(a.z);p>=m&&p>=f?(c=new s(d.x,0,0),u=Math.sqrt(d.y*d.y+d.z*d.z)):m>=p&&m>=f?(c=new s(0,d.y,0),u=Math.sqrt(d.x*d.x+d.z*d.z)):f>=m&&f>=p&&(c=new s(0,0,d.z),u=Math.sqrt(d.y*d.y+d.x*d.x)),u=u>0?u:.01;let g=(new s).subVectors(this.positionTo.clone(),this.positionFrom.clone()).length()+c.length(),v=new $e(1.1*u,1.1*u,g,32,1);this.boundingLineMesh=new K(v,_n.createMeshStandardMaterial({color:"#ffffff",transparent:!0,opacity:0})),this.boundingLineMesh.name="bounding line mesh",this.boundingLineMesh.userData.ignoreComponentRaycast=!0,this.boundingLineMesh.layers.set(5);let w=this.positionTo.clone(),b=this.positionFrom.clone(),y=(new s).subVectors(w,b).normalize(),_=new Je(y,b);const x=(new R).setFromEuler(_.rotation);this.boundingLineMesh.quaternion.multiply(x),this.boundingLineMesh.renderOrder=3;let S=(new s).addVectors(this.positionTo.clone(),this.positionFrom.clone()).multiplyScalar(.5).add(d);this.boundingLineMesh.position.copy((new s).subVectors(S,this.position.clone())),this.add(this.boundingLineMesh)}clonePreviewLine(t){let r=new n(this._creator_,this.runtimeId,this.roomlePosition,this.roomleRotation,this.parentObjectId,this.receivedPointAssociation);return r._stringId=this.runtimeId+"_"+t,this.children.forEach(e=>{e instanceof K&&0===e.userData.meshType&&r.meshes.push(e.clone(!0))}),r.meshes.forEach(e=>{e.material=e.material.clone(),e.geometry=e.geometry.clone(),r.add(e)}),this._dockline&&(r._dockline=e.cloneDockLine(this._dockline,this._boundingBox)),this._boundingBoxMesh&&(r._boundingBoxMesh=this._boundingBoxMesh.clone(!0)),this._boundingBox&&(r._boundingBox=this._boundingBox.clone()),r}getPositionForIntersectionPoint(e){let t=this._boundingBox.getCenter(new s).applyEuler(this.docklineRotation),r=this.positionTo.clone().add(t),n=this.positionFrom.clone().add(t),a=new et(n,r).closestPointToPoint(e,!0,new s);return(isNaN(a.x)||isNaN(a.y)||isNaN(a.z))&&a.copy(e),a.sub(t)}updatePreviewPosition(e){let t=this.getPositionForIntersectionPoint(e),r=this.parent.localToWorld(t);this._newPosition=this.worldToLocal(r);let n=this._boundingBox.getCenter(new s).applyEuler(this.docklineRotation);this._dockline.position.copy((new s).addVectors(this._newPosition,n)),this._dockline.rotation.copy(this.docklineRotation)}hideSelectionLine(){this._dockline.visible=!1}getKernelPosition(e){if(this._newPosition){let t=this.localToWorld(this._newPosition);return Pn(e.worldToLocal(t))}return super.getKernelPosition(e)}}class a extends ${constructor(e,t,r,n,a,i,s){super(e,t,r,n,a,i),s||(s={left:0,top:1,right:1,bottom:0}),this.offset=s}set offset(e){this._offset=e,this.updateProjectionMatrix()}get offset(){return this._offset}resetOffset(){this._offset={left:0,top:1,right:1,bottom:0}}updateProjectionMatrix(){this._offset?(this.projectionMatrix=this._calculateProjectionMatrix(),this.projectionMatrixInverse.copy(this.projectionMatrix).invert()):super.updateProjectionMatrix()}_calculateProjectionMatrix(){const e=this._calculate2DPlanes();if(this._offset.left>=this._offset.right||this._offset.bottom>this._offset.top)return(new P).makeOrthographic(e.left,e.right,e.top,e.bottom,this.near,this.far);const t=this._scaleRange(e.left,e.right,this._offset.left,this._offset.right);let r=t.from,n=t.to;const a=this._scaleRange(e.bottom,e.top,this._offset.bottom,this._offset.top);let i=a.from,s=a.to;const o=(e.right-e.left)/(e.top-e.bottom),l=(n-r)/(s-i);if(l>o){const e=(i+s)/2,t=(s-i)*l/o;i=e-t/2,s=e+t/2}else{const e=(r+n)/2,t=(n-r)*o/l;r=e-t/2,n=e+t/2}return(new P).makeOrthographic(r,n,s,i,this.near,this.far)}_scaleRange(e,t,r,n){const a=(t-e)/(n-r);return{from:e-a*r,to:t+a*(1-n)}}_calculate2DPlanes(){const e=(this.right-this.left)/(2*this.zoom),t=(this.top-this.bottom)/(2*this.zoom),r=(this.right+this.left)/2,n=(this.top+this.bottom)/2;let a=r-e,i=r+e,s=n+t,o=n-t;if(null!==this.view&&this.view.enabled){const e=(this.right-this.left)/this.view.fullWidth/this.zoom,t=(this.top-this.bottom)/this.view.fullHeight/this.zoom;a+=e*this.view.offsetX,i=a+e*this.view.width,s-=t*this.view.offsetY,o=s-t*this.view.height}return{left:a,right:i,top:s,bottom:o}}}class o extends Z{constructor(e,t,r,n,a){super(e,t,r,n),a||(a={left:0,top:1,right:1,bottom:0}),this.offset=a}copy(e,t){return super.copy(e,t),this._offset=e._offset,this}set offset(e){this._offset=e,this.updateProjectionMatrix()}get offset(){return this._offset}resetOffset(){this._offset={left:0,top:1,right:1,bottom:0}}_calculateProjectionMatrix(){let e,t,r,n,a=this.fov*(2*Math.PI/360)/2;r=Math.tan(a),n=-r;let s=Math.atan(this.aspect*Math.tan(a));t=Math.tan(s),e=-t;let o=this._offset.left,l=this._offset.right,h=this._offset.top,d=this._offset.bottom,c=new i(l-o,h-d),u=new i(o+c.x/2,d+c.y/2);if(c.x<c.y){let a=(1-u.x)/(c.x/2),i=u.x/(c.x/2);t*=a,e*=i;let s=(a+i)/2;r*=s,n*=s}else{let a=(1-u.y)/(c.y/2),i=u.y/(c.y/2);r*=a,n*=i;let s=(i+a)/2;e*=s,t*=s}e*=this.near,t*=this.near,r*=this.near,n*=this.near;let p=this.near*Math.tan(Math.PI/180*.5*this.fov)/this.zoom*2,m=this.aspect*p;return this.view&&this.view.enabled&&(e+=this.view.offsetX*m/this.view.fullWidth,r-=this.view.offsetY*p/this.view.fullHeight,t+=this.view.offsetX*m/this.view.fullWidth,n-=this.view.offsetY*p/this.view.fullHeight),(new P).makePerspective(e,t,r,n,this.near,this.far)}clearViewOffset(){null!==this.view&&(this.view.enabled=!1),this.updateProjectionMatrix()}updateProjectionMatrix(){this._offset?(this.projectionMatrix=this._calculateProjectionMatrix(),this.projectionMatrixInverse.copy(this.projectionMatrix).invert()):super.updateProjectionMatrix()}}return{create:function(t,r,n,a){return new e(t,r,n,a)},createPreview:function(e,t,n){return new r(n,e,{x:0,y:0,z:0},{x:0,y:0,z:0},t)},createStatic:function(e,r){return new t(e,r)},createPreviewLine:function(e,t){let r=new n(t,e.id,e.roomlePosition,e.roomleRotation,e.parentObjectId,e.receivedPointAssociation);return e.meshes.forEach(e=>{let t=e.clone();t.material=e.material.clone(),t.geometry=e.geometry.clone(),r.addMesh(t)}),r.computeBoundingBox(),r},isPreview:function(e){return e instanceof r},isPreviewLine:function(e){return e instanceof n},createPerspectiveCamera:function(e,t,r,n,a){return new o(e,t,r,n,a)},createOrthographicCamera:function(e,t,r,n,i,s,o){return new a(e,t,r,n,i,s,o)}}}const ks=e("z",9);class Os{constructor(e){this._mergeThreshold=3,this._componentsToMerge=new Ds,this._mergeInProgress=!1,this._components=new Map,this._previews=new Map,this._componentNumberOfPossibleChildren=new Map,this._creator_=e,this._getKernelAccess().addConfiguratorListener(this),this._componentFactory=Is()}get materialQueue(){return this.getMeshGenerator().materialQueue}_getKernelAccess(){return _h.lookup("planner-kernel-access",this._creator_)}_applyMeshTransform(e,t,r,n,a){if(r){const n=e.userData.transform=kn(r);t&&(e.userData.transform=n),e.applyMatrix4(n)}this._applyMeshUVTransform(e,t,n,a)}_applyMeshUVTransform(e,t,r,n){if(6!==(null==r?void 0:r.length)||(e=>1===e[0]&&0===e[1]&&0===e[2]&&1===e[3]&&0===e[4]&&0===e[5])(r))t&&(t.uvTransform=void 0),n&&(e.geometry=n);else{const a=(e=>{const t=new P;return t.set(e[0],e[2],0,e[4],e[1],e[3],0,e[5],0,0,1,0,0,0,0,1),t})(r);t&&(t.uvTransform=a);const i=null!=n?n:e.geometry;if(i&&i.attributes.uv){const t=i.clone();t.attributes.uv.applyMatrix4(a),e.geometry=t}}}_addMeshToSubPart(e,t,r,n,a,i,s,o,l,h){const d=this._generateMesh(e,t,r,i,s,o,l,void 0,void 0,h);this._applyMeshTransform(d,null,n,a),this._subPartObject.add(d)}_addMeshToComponent(e,t,r,n,a,i,s,o,l,h,d,c){if(this._subPartGuard&&this._subPartGuard.info===e)return void this._addMeshToSubPart(e,null,n,null,null,s,o,l,h,c);const u=this.getComponent(e);if(!u)return;const p=this._componentFactory.isPreview(u),m=this._generateMesh(e,r,p?null:n,s,o,l,h,void 0,void 0,c);m.userData.meshId=t,m.userData.geometryId=r,m.userData.materialId=n,this._applyMeshTransform(m,m.userData,a,i),p&&m.layers.set(5),u&&u.addMesh(m),u.meshes.length>this._mergeThreshold&&this._componentsToMerge.set(e,u.meshes.length)}_changeMeshOfComponent(e,t,r,n,a,i,s){const o=this.getComponent(e);if(!o)return;const l=o.getMeshById(t);if(l){l.userData.geometryId!==r&&console.warn("Geometry of mesh has changed!"),l.userData.materialId=n,l.userData.materialAttributes=s;const e=l.material.clone();this._configuratorMeshGenerator.setMaterial(l,n,void 0,s),e.opacity!==l.material.opacity&&this._requestRenderCallback&&this._requestRenderCallback(),a&&(l.position.set(0,0,0),l.scale.set(1,1,1),l.rotation.set(0,0,0));const t=this._configuratorMeshGenerator.getGeometry(r);this._applyMeshTransform(l,l.userData,a,i,t)}}_removeMeshFromComponent(e,t){const r=this.getComponent(e);r&&r.removeMeshById(t)}getComponent(e){let t=this._components.get(e);return t||(t=this._previews.get(e.toString()),t)?t:(console.warn("component not found!",e),null)}getNumberOfPossibleChildrenForComponent(e){if(this._componentNumberOfPossibleChildren.has(e))return this._componentNumberOfPossibleChildren.get(e);const t=this._getKernelAccess().kernelInstance.getPlanComponentPossibleChildren(e).length;return this._componentNumberOfPossibleChildren.set(e,t),t}tryToMergeComponents(){this._initData.moc||this._mergeInProgress||(this._mergeInProgress=!0,this._componentsToMerge.size,this._requestMergeComponents())}_requestMergeComponents(){window.requestIdleCallback(this._mergeNextComponent.bind(this))}_mergeNextComponent(){if(this._componentsToMerge.size>0){const e=this._componentsToMerge.largestValue();this._componentsToMerge.delete(e),this._mergeComponent(e),this._requestMergeComponents()}else this._mergeInProgress=!1,this._geometriesMerged&&this._geometriesMerged(),this._components.forEach(e=>{e.loadingMesh&&console.warn("component still has loading mesh: ",e.hash)})}_mergeComponent(e){const t=this._components.get(e);if(t&&!(t.meshes.length<=this._mergeThreshold))if(this._cacheHolder.componentCache.has(t.hash)){const e=this._cacheHolder.componentCache.get(t.hash).meshes;t.replaceMeshes(e)}else{const e=new Map,r=[],n=[];t.meshes.forEach(t=>{const a=t.userData.materialId;if(!a)return void console.warn("mesh has no material id set");if(!e.has(a)){const n=new K(new c,t.material);n.userData.materialId=a,n.receiveShadow=!0,n.castShadow=!0,n.layers.set(3),this._setMaterial(n,a),r.push(n),e.set(a,n)}const i=e.get(a),s=i.geometry;t.userData.transform&&t.geometry.applyMatrix4(t.userData.transform),i.geometry=function(e){for(var t=arguments.length>1&&void 0!==arguments[1]&&arguments[1],r=null!==e[0].index,n=new Set(Object.keys(e[0].attributes)),a=new Set(Object.keys(e[0].morphAttributes)),i={},s={},o=e[0].morphTargetsRelative,l=new c,h=0,d=0;d<e.length;++d){var u=e[d],p=0;if(r!==(null!==u.index))return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+d+". All geometries must have compatible attributes; make sure index attribute exists among all geometries, or in none of them."),null;for(var m in u.attributes){if(!n.has(m))return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+d+'. All geometries must have compatible attributes; make sure "'+m+'" attribute exists among all geometries, or in none of them.'),null;void 0===i[m]&&(i[m]=[]),i[m].push(u.attributes[m]),p++}if(p!==n.size)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+d+". Make sure all geometries have the same number of attributes."),null;if(o!==u.morphTargetsRelative)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+d+". .morphTargetsRelative must be consistent throughout all geometries."),null;for(var f in u.morphAttributes){if(!a.has(f))return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+d+". .morphAttributes must be consistent throughout all geometries."),null;void 0===s[f]&&(s[f]=[]),s[f].push(u.morphAttributes[f])}if(t){var g=void 0;if(r)g=u.index.count;else{if(void 0===u.attributes.position)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+d+". The geometry must have either an index or a position attribute"),null;g=u.attributes.position.count}l.addGroup(h,g,d),h+=g}}if(r){for(var v=0,w=[],b=0;b<e.length;++b){for(var y=e[b].index,_=0;_<y.count;++_)w.push(y.getX(_)+v);v+=e[b].attributes.position.count}l.setIndex(w)}for(var x in i){var S=Cr(i[x]);if(!S)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed while trying to merge the "+x+" attribute."),null;l.setAttribute(x,S)}for(var C in s){var M=s[C][0].length;if(0===M)break;l.morphAttributes=l.morphAttributes||{},l.morphAttributes[C]=[];for(var T=0;T<M;++T){for(var A=[],P=0;P<s[C].length;++P)A.push(s[C][P][T]);var R=Cr(A);if(!R)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed while trying to merge the "+C+" morphAttribute."),null;l.morphAttributes[C].push(R)}}return l}([s,t.geometry]),n.push(t)}),r.forEach(e=>t.addMesh(e)),n.forEach(e=>t.removeMesh(e)),this._cacheHolder.componentCache.set(t.hash,t)}}_addRootComponent(e){this._listener&&this._listener.display(e)}removeDockingComponent(){this._getKernelAccess().requestDeleteComponent(this._configuratorContext.dockingRootComponentId),this._configuratorContext.dockingRootComponentId=null}dockComponent(e,t,r,n){let a=this._components.get(t),i=this._components.get(e);i&&(i.roomlePosition=r,i.roomleRotation=n,a&&a.add(i))}dockComponentWithPosition(e,t){let r,n=this._components.get(e.parentId);r=t?t.getKernelPosition(n):e.getKernelPosition(n),Xi.start("dock_component_with_position_"+e.childId),this._getKernelAccess().dockComponentWithPosition(e.parentId,e.parentDockId,e.childId,e.childDockId,r),this._configuratorContext.dockingRootComponentId=null}removePreviews(){this._previews.size>0&&(this._previews.forEach(e=>{e.removeFromParent(),e.removeAllMeshes()}),this._previews.clear())}_updatePlanObject(e){const t=this._components.get(e.rootPlanComponentId);let r=!0;t&&(r=t.geometryChanged),this._listener&&this._listener.planObjectUpdated(e,r)}Editor3dAddBakedMesh(e,t,r,n,a,i,s,o){this._addMeshToComponent(e,null,null,t,null,null,r,n,a,i,s,o)}Editor3dAddDockPreview(e,t){const r=this._componentFactory.createPreview(t,e,this._creator_);this._previews.set(t.toString(),r)}Editor3dAddNamedMesh(e,t,r,n,a,i,s,o,l,h,d,c){this._addMeshToComponent(e,t,r,n,a,d,i,s,o,l,h,c)}Editor3ChangedNamedMesh(e,t,r,n,a,i,s){this._changeMeshOfComponent(e,t,r,n,a,i,s)}Editor3dRemoveNamedMesh(e,t){this._removeMeshFromComponent(e,t)}Editor3dBeginConstruction(e,t){if(!t){const t=this._components.get(e);t&&t.removeAllMeshes()}this._subPartGuard&&e===this._subPartGuard.info&&(this._subPartObject=new I)}Editor3dComponentCreated(e,t,r,n,a){a&&(this._configuratorContext.rootComponentId=e);let i=null;this._components.has(e)?(i=this._components.get(e),i.removeAllMeshes()):(i=this._componentFactory.create(e,t,r,n),i.layers.set(3)),this._components.set(e,i),a&&this._addRootComponent(i)}Editor3dComponentDocked(e,t,r,n){this.dockComponent(e,t,r,n)}Editor3dEndConstruction(e){if(this._subPartGuard&&this._subPartGuard.info===e)return void this._subPartGuard.resolve(this._subPartObject);const t=this._getKernelAccess().kernelInstance.getComponent(e),r=this._components.get(e);r&&(r.computeBoundingBox(t.boxForMeasurement),r.boundingBoxMesh&&this._listener&&this._listener.addComponentHandlers(r));let n=this._previews.get(e.toString());n&&n.computeBoundingBox(t.boxForMeasurement,!0)}Editor3dGeometryReady(e){const t=this._components.get(e);t&&t.loadingFinished()}Editor3dGeometryNotReady(e){const t=this._components.get(e);t&&t.loading()}Editor3dPlanObjectConstructionDone(e){const t=this._getKernelAccess().kernelInstance.getPlanObject(e),r=[t,this._getKernelAccess().kernelInstance.getFullPartList(),this._getKernelAccess().kernelInstance.getHashOfConfiguration(e),this._getKernelAccess().kernelInstance.getComponentId(t.rootPlanComponentId)];Zi.finishOperation(2,r),this._updatePlanObject(t),this._listener&&this._listener.planObjectConstructionDone(t)}Editor3dPreviewConstructionDone(e,t){let r=!1;this._previews.forEach(e=>{null!==e.parent&&(this._listener&&(this._componentFactory.isPreviewLine(e)?this._listener.addPreviewLineHandlers(e):this._listener.addPreviewHandlers(e)),r=!0)}),this._listener&&this._listener.previewConstructionDone(this._components.get(e),r)}Editor3dSetPreviewLineAssociations(e,t){let r=this._previews.get(t.toString());if(r.clear(),!r)return;let n=this._componentFactory.createPreviewLine(r,this._creator_),a=this._components.get(this._configuratorContext.rootComponentId);for(let t=0;t<e.length;t++){let r;r=0===t?n:n.clonePreviewLine(t),r.name="Preview Line",r.parentDockId=e[t].parentDockId,r.parentId=e[t].parentId,r.childDockId=e[t].childDockId,r.childId=e[t].childId,r.docklineRotation=(i=e[t].rotation,new Me(i.x,i.z,-i.y)),r.roomlePosition=e[t].position,e[t].lineFrom.x>e[t].lineTo.x||e[t].lineFrom.y>e[t].lineTo.y||e[t].lineFrom.z>e[t].lineTo.z?(r.roomleLineFrom=e[t].lineTo,r.roomleLineTo=e[t].lineFrom):(r.roomleLineFrom=e[t].lineFrom,r.roomleLineTo=e[t].lineTo),e[t].positionFrom.x>e[t].positionTo.x||e[t].positionFrom.y>e[t].positionTo.y||e[t].positionFrom.z>e[t].positionTo.z?(r.roomlePositionFrom=e[t].positionTo,r.roomlePositionTo=e[t].positionFrom):(r.roomlePositionFrom=e[t].positionFrom,r.roomlePositionTo=e[t].positionTo),a.add(r),r.preparePreview(),this._previews.set(r.stringId,r)}var i}Editor3dSetPreviewPointAssociations(e,t){let r=this._previews.get(t.toString());if(!r)return;let n=this._components.get(this._configuratorContext.rootComponentId);for(let t=0;t<e.length;t++){let a;0===t?a=r:(a=r.clonePreview(t),this._previews.set(a.stringId,a)),a.name="Preview Point",a.parentDockId=e[t].parentDockId,a.parentId=e[t].parentId,a.childDockId=e[t].childDockId,a.childId=e[t].childId,a.preparePreview(),a.receivedPointAssociation=!0,a.userData.ignoreComponentRaycast=!0,n.add(a),a.roomlePosition=e[t].position,a.roomleRotation=e[t].rotation,a.startPulsating()}}componentDeleted(e){const t=this._components.get(e);t&&(this._listener&&this._listener.componentDeleted(t),t.removeFromParent(),t.removeAllMeshes(),this._components.delete(e))}componentMetaUpdated(e){const t=this._getRuntimeComponent(e.id);t&&(t.hash=e.hash,t.roomlePosition=e.position,t.roomleRotation=e.rotation,e.boxForMeasurement&&t.computeBoundingBox(e.boxForMeasurement),this._listener&&this._listener.componentUpdated(t,e))}componentConfigurationUpdated(e,t){const r=this._getRuntimeComponent(e);r&&(r.geometryChanged=t)}_getRuntimeComponent(e){let t=this._components.get(e);return t||(t=this._previews.get(e.toString()),t)?t:null}configurationLoaded(e,t,r,n,a){10===e&&(this._configuratorContext.dockingRootComponentId=r);let i=0===t;i?this._getKernelAccess().kernelInstance.requestPlanComponentConstructionRecursive(r):this._getKernelAccess().kernelInstance.requestPlanObjectConstruction(t);let s=this._getKernelAccess().kernelInstance.getComponent(r),o=this._components.get(r);o&&(o.computeBoundingBox(s.boxForMeasurement),o.hash=s.hash),this._listener&&this._listener.configurationLoaded(o,i&&void 0!==o.boundingBoxMesh)}finishParameterChange(e,t){this.materialQueue.registerCallback(e)}planObjectConfigurationUpdated(e,t,r){let n=this._getKernelAccess().kernelInstance.getPlanObject(e);this._updatePlanObject(n)}planObjectCreated(e,t){this._configuratorContext.planObjectId=t,this._listener&&this._listener.clearScene()}planObjectUpdated(e){this._updatePlanObject(e)}sceneCleared(){this._components.forEach((function(e){e.removeFromParent(),e.removeAllMeshes()})),this._components.clear(),this._componentNumberOfPossibleChildren.clear(),this._previews.forEach(e=>{e.removeFromParent(),e.removeAllMeshes()}),this._previews.clear()}setListener(e){this._listener=e}getBoundingBox(){if(this._configuratorContext.planObjectId){const e=this._getKernelAccess().kernelInstance.getPlanObject(this._configuratorContext.planObjectId);if(e&&e.boxForMeasurement)return Na(e.boxForMeasurement)}else if(this._configuratorContext.rootComponentId){const e=this._components.get(this._configuratorContext.rootComponentId);return(new be).setFromObject(e)}return null}getBoundingBoxWithPreviews(){const e=this._components.get(this._configuratorContext.rootComponentId);return e?(new be).setFromObject(e):null}hasPreviews(){return this._previews.size>0}clearRootComponent(){var e;null===(e=this._components.get(this._configuratorContext.rootComponentId))||void 0===e||e.hoverOff()}debugSceneGraph(e){e?this._components.has(e)?this._components.get(e):this._previews.has(e.toString())&&this._previews.get(e.toString()):this._configuratorContext}getComponentsForIds(e){let t=[];return e.forEach(e=>{const r=this._components.get(e);r&&t.push(r)}),t}getComponents(){return Array.from(this._components.values())}getPreviews(){return Array.from(this._previews.values())}hasPreviewLines(){for(const e of this._previews.values())if(this._componentFactory.isPreviewLine(e))return!0;return!1}isPreviewLine(e){return this._componentFactory.isPreviewLine(e)}isPreview(e){return this._componentFactory.isPreview(e)}setGeometriesMergedListener(e){this._geometriesMerged=e}removeGeometriesMergedListener(){this._geometriesMerged=void 0}setMergeThreshold(e){this._mergeThreshold=e}_generateMesh(e=0,t=null,r,n,a,i,s,o,l,h){return this._configuratorMeshGenerator.generateMesh(e,t,r,n,a,i,s,!1,h)}_setMaterial(e,t,r){this._configuratorMeshGenerator.setMaterial(e,t)}constructComponents(e){this._getKernelAccess().kernelInstance.requestPlanObjectConstruction(e)}requestSubPartConstruction(e){return this._subPartGuard=new Sr(e),this._getKernelAccess().requestPlanComponentConstruction(e,!1),this._subPartGuard.wait()}getMeshGenerator(){return this._configuratorMeshGenerator}setRequestRenderCallback(e){this._requestRenderCallback=e}}e("C",Os),pr([fr],Os.prototype,"_configuratorMeshGenerator",void 0),pr([fr],Os.prototype,"_configuratorContext",void 0),pr([fr],Os.prototype,"_cacheHolder",void 0),pr([fr],Os.prototype,"_initData",void 0);class Ds extends Map{largestValue(){let e=this.entries().next().value[0],t=0;return this.forEach((r,n)=>{r>t&&(e=n,t=r)}),e}}const Ls=["material"];class Us extends ls{constructor(e){super(e),this.externalMeshQueue=new fi,this.muteKernelCallbacks=!1,this.listOfVariants=(e,t)=>{}}init(e){super.init(e),Xi.addMeta("kernel_is_ready",{isWasm:this._useWASM}),qi.kernelInstance?(this._kernelContainer=qi.kernelContainer,setTimeout(()=>this._loadSuccess(),0)):this._scriptLoader.fetch(this._kernelPath,{id:"kernel"}).then(this._loadSuccess.bind(this),this._loadError.bind(this))}_loadSuccess(){Xi.start("kernel_is_ready"),window.ConfiguratorKernel&&(qi.kernelInstance?setTimeout(()=>this.isReady(),0):(window.ConfiguratorKernel(this._kernelContainer),window.ConfiguratorKernel=null))}_loadError(){this._configuratorKernelAccessCallback.loadError()}selectedComponent(e){this._updateComponentDependencies(e)}uiRequestConfiguration(e){const t=this._kernelInstance.getSerializedConfiguration(e);Zi.finishOperation(1,t)}_updateComponentParameters(e){let t=this._kernelInstance.getComponentParameters(e);const r=this._kernelInstance.getComponent(e);this._configuratorKernelAccessCallback.updateParameters(t,r.parameterGroups,e,1)}selectionChange(e,t){let r=!1,n=[];if(e){let t=this._kernelInstance.getComponent(e);t.componentId=this._kernelInstance.getComponentId(e),t&&t.childIds&&t.childIds.length>0&&(r=!0),n.push(t)}this._configuratorUiCallbacks.onSelectionChange("standard",t,r,n)}multiSelectionChange(e,t){this._updateCommonComponentDependencies(e);let r=!1,n=!1,a=[];e&&e.forEach(e=>{let i=this._kernelInstance.getComponent(e);i.componentId=this._kernelInstance.getComponentId(e),i&&i.childIds&&i.childIds.length>0&&(r=!0),i.id===t&&(n=!0),a.push(i)}),this._configuratorUiCallbacks.onSelectionChange("multiselect",n,r,a)}_updateCommonComponentDependencies(e){const{parameters:t,parameterGroups:r}=this._kernelInstance.getCommonPlanComponentParameters(this._utilityToLongArray(e));this._configuratorKernelAccessCallback.updateParameters(t,r,e,2)}_updateComponentChildren(e){const t=this._kernelInstance.getPlanComponentPossibleChildren(e);this._configuratorKernelAccessCallback.updatePossibleChildren(e,t,1)}_updateComponentDependencies(e){this._updateComponentParameters(e),this._updateComponentChildren(e)}_updatePlanObjectParameters(e){let t,r=this._kernelInstance.getPlanObjectParameters(e);if(0===r.length){let n=this._kernelInstance.getRootPlanComponentIdFromObjectId(e);r=this._kernelInstance.getComponentParameters(n),this._enableRootComponentParametersAsGlobal(),t=this._kernelInstance.getComponent(n)}else this._configuratorContext.rootComponentParametersAsGlobal=!1,t=this._kernelInstance.getPlanObject(e);this._configuratorKernelAccessCallback.updateParameters(r,t.parameterGroups,e,0)}_enableRootComponentParametersAsGlobal(){this._configuratorContext.selectedRuntimeComponentId||(this._configuratorContext.rootComponentParametersAsGlobal=!0)}_updatePlanObjectChildren(e){const t=this._kernelInstance.getPlanObjectPossibleChildren(e);this._configuratorKernelAccessCallback.updatePossibleChildren(e,t,0)}updatePlanObjectDependencies(e){this._updatePlanObjectParameters(e),this._updatePlanObjectChildren(e)}_updateConfigurationHasChildren(e,t=null){t||(t=this._kernelInstance.getComponent(this._kernelInstance.getRootPlanComponentIdFromObjectId(e)));const r=t.childIds.size?t.childIds.size():t.childIds.length;this._configuratorUiCallbacks.onConfigurationHasChildren(r>0)}dockComponent(e,t,r,n){const a=this._kernelInstance.getComponentId(r),i=this._kernelInstance.getComponentId(e);this._kernelInstance.dockComponent(r,n,e,t),this._configuratorUiCallbacks.onUserInitiatedDockDone(a,n,i,t,null)}changeUseOfHDGeometry(e,t){this._rapiAccess.changeUseOfHDGeometry();const r=e.planObjectId,n=e.lastLoadedRapiId?e.lastLoadedRapiId:this._kernelInstance.getComponentId(r),a=this._kernelInstance.getSerializedConfiguration(r);this._kernelInstance.clearAll(),this._kernelInstance.useHDGeometry(t),Zi.finishOperation(3,[a,n])}webGlPreviewDockings(e,t){Zi.waitFor(4).then(({componentId:r})=>{t&&this.requestPlanComponentConstruction(r),this._kernelInstance.requestPreviewGeometry(r,e.planObjectId)}),e.lastPossibleChild&&e.lastPossibleChild.isComponent&&(this._kernelIo.setMeta({componentId:e.lastPossibleChild.id}),this._kernelInstance.loadPlainComponent(10,e.lastPossibleChild.id,e.lastPossibleChild.configuration)),e.lastPossibleChild&&e.lastPossibleChild.isItem&&this._kernelInstance.loadFreeFlyingConfiguration(10,e.lastPossibleChild.configuration)}previewDockingsWithDrag(e,t){this._kernelInstance.requestPreviewGeometry(e,t)}loadConfiguration(e){this._initData.id?this._memoryManager.loadingConfiguration(this._initData.id):this._memoryManager.loadingConfigurationString(),this._memoryManager.shouldHardReset()?this._kernelInstance.clearAll():this._kernelInstance.clearScene(),this._kernelInstance.loadConfiguration(ks,e,{x:0,y:0,z:0})}changeCommonComponentParameter(e,t,r,n,a,i){"string"==typeof n?this._kernelInstance.setPlanComponentParameters(this._utilityToLongArray(e),t,n):console.warn("tried to set a parameter to a none string value!",n,t,r),this._finishParameterChange(r,a,i),this._updateCommonComponentDependencies(e)}changeComponentParameter(e,t,r,n,a,i){"string"==typeof n?this._kernelInstance.setComponentParameter(e,t,n):console.warn("tried to set a parameter to a none string value!",n,t,r),this._finishParameterChange(r,a,i),this._updateComponentDependencies(e)}changePlanObjectParameter(e,t,r,n,a,i){"string"==typeof n?this._kernelInstance.setPlanObjectParameter(e,t,n):console.warn("tried to set a parameter to a none string value!",n,t,r),this._finishParameterChange(r,a,i)}_finishParameterChange(e,t,r){-1===Ls.indexOf(e)?setTimeout(()=>t(),0):this._configuratorKernelCallbackListener.forEach(e=>e.finishParameterChange(t,r))}requestDeleteComponents(e){e&&this._kernelInstance.deletePlanComponents(this._utilityToLongArray(e))}requestDeletePlanComponent(e){var t,r;e&&(null===(r=null===(t=this._initData)||void 0===t?void 0:t.featureFlags)||void 0===r?void 0:r.reDock)&&this._kernelInstance.deletePlanComponent(e)}loadComponentIntoKernel(e,t){this._kernelIo.setMeta({componentId:t}),this._kernelInstance.loadComponentDefinition(10,e)}async requestPartListAndUpdatePricesOfParts(e,t){let r=this._kernelInstance.getFullPartList();e||(e=this._kernelInstance.getHashOfConfiguration(this._configuratorContext.planObjectId));const n=await this.addUiDataAndPriceToPartList(r,e);this._configuratorUiCallbacks.onPartListUpdate(n,btoa(e))}requestSync(e,t){this.planObjectCreated(e,t),this._kernelInstance.syncPlanObjectToView(e,t)}getGlobalParameters(e,t){return new Promise(r=>{let n=this._kernelInstance.getPlanObjectParameters,a=e;t&&(n=this._kernelInstance.getComponentParameters,a=this._kernelInstance.getRootPlanComponentIdFromObjectId(e)),r(n.apply(this._kernelInstance,[a]))})}getPartList(){return new Promise(e=>{e(this._kernelInstance.getFullPartList())})}getConfigurationHash(e){return new Promise(t=>t(this._kernelInstance.getHashOfConfiguration(e.planObjectId)))}requestPlanObjectConstruction(e){this._kernelInstance.requestPlanObjectConstruction(e)}isReady(){super.isReady(),this._setupKernel(),Ni.isProduction||(window.__RML__DEBUG__.Kernel=this._kernelInstance,window.__RML__DEBUG__.KernelContainer=this._kernelContainer,window.__RML__DEBUG__.Helper={convertCObject:En}),this._configuratorKernelAccessCallback.isReady(),this._configuratorUiCallbacks.onConfiguratorKernelIsReady(this._kernelContainer,this._kernelInstance),qi.planObjectId&&this.planObjectCreated(-1,qi.planObjectId)}_setupKernel(){1===this._kernelType&&(Xi.start("kernel_create_instance"),qi.kernelInstance?this._kernelInstance=qi.kernelInstance:this._kernelInstance=new this._kernelContainer.Kernel),this._initKernel()}onLoadComponentError(e,t){this._configuratorUiCallbacks.onComponentLoadError(e,t)}configurationLoaded(e,t,r,n,a,i){Zi.finishOperation(4,{conversationId:e,objectId:t,componentId:r,hash:n,errors:En(a)}),this._configuratorKernelCallbackListener.forEach(i=>i.configurationLoaded(e,t,r,n,a))}componentDefinitionLoaded(e,t){Zi.finishOperation(0,t)}componentDefinitionLoadingError(e,t){this._kernelIo.error(t),Zi.failOperation(0,new Error(t))}configurationLoadingError(e,t){let r="Configuration loading error";if(t){const e=En(t);Array.isArray(e)&&(r=e.join("\n"),e.forEach(e=>this._kernelIo.error(e)))}Zi.failOperation(4,new Error(r)),Zi.failOperation(2,new Error(r))}componentConfigurationUpdated(e,t){this._configuratorKernelCallbackListener.forEach(r=>r.componentConfigurationUpdated(e,t)),this._kernelInstance.requestDeltaPlanComponentConstruction(e)}setActiveGroupInView(e){this._kernelInstance.setActiveGroupInView(e)}setActiveGroupInViewForPlanObject(e,t){this._kernelInstance.setActiveGroupInViewForPlanObject(e,t||this._configuratorContext.planObjectId)}componentParameters(){}requestComponentDimensions(){}planObjectCreated(e,t){this._configuratorKernelCallbackListener.forEach(r=>r.planObjectCreated(e,t))}planObjectUpdated(e){const t=this._kernelInstance.getPlanObject(e);this._onBoundsUpdate(t),this._configuratorKernelCallbackListener.forEach(e=>e.planObjectUpdated(t))}planObjectConfigurationUpdated(e,t,r,n,a){this.updatePlanObjectDependencies(e);let i=this._kernelInstance.getComponent(this._kernelInstance.getRootPlanComponentIdFromObjectId(e));this._configuratorKernelCallbackListener.forEach(n=>n.planObjectConfigurationUpdated(e,t,r));const s=this._kernelInstance.getPlanObject(e);return this._onBoundsUpdate(s),this._configuratorHistory.push(t),this._updateConfigurationHasChildren(e,i),this.requestPartListAndUpdatePricesOfParts(r)}_onBoundsUpdate(e){if(!e.boxForMeasurement)return;const t={width:this._unitFormatter.formatMMValueToUnitString(e.boxForMeasurement.size.x),height:this._unitFormatter.formatMMValueToUnitString(e.boxForMeasurement.size.z),depth:this._unitFormatter.formatMMValueToUnitString(e.boxForMeasurement.size.y),kernelBounds:e.boxForMeasurement};this._configuratorUiCallbacks.onBoundsUpdate(t)}planObjectDeleted(){}requestPlanObjectDimensions(){}async requestExternalMesh(e,t){let r=()=>{};const n=new Promise((e,t)=>{r=e});let a;this.externalMeshQueue.push(n),this._configuratorUiCallbacks.onRequestExternalMesh(e,t);try{a=await this._rapiAccess.getMesh(e,"crt",t)}catch(t){return this._handleInvalidMesh(e),this._configuratorUiCallbacks.onError(new Error(`Mesh with id "${e}" can not be loaded. "${t}"`)),void console.error(t)}try{const n=await fetch(new Request(this._dataSyncer.requestAsset(a.url,!0))),i=await n.arrayBuffer();this._handleCortoMesh(i,e,t),r()}catch(t){return this._handleInvalidMesh(e),this._configuratorUiCallbacks.onError(new Error(`Mesh with id "${e}" breaks. "${t}"`)),void console.error(t)}}Editor3dComponentCreated(e,t,r,n){this._configuratorKernelCallbackListener.forEach(a=>a.Editor3dComponentCreated(e,t,r,n,!1)),n&&n>0&&this._configuratorKernelCallbackListener.forEach(a=>a.Editor3dComponentDocked(e,n,t,r))}Editor3dRootComponentCreated(e,t,r,n){this._configuratorKernelCallbackListener.forEach(a=>a.Editor3dComponentCreated(e,t,r,n,!0))}Editor3dPlanObjectConstructionDone(e){this._configuratorKernelCallbackListener.forEach(t=>t.Editor3dPlanObjectConstructionDone(e)),this.updatePlanObjectDependencies(e),this._updateConfigurationHasChildren(e),this._initData.moc||this._calcPrice()}Editor3dBeginGroup(){}Editor3dEndGroup(){}Editor3dSetMaterial(){}Editor3dLoadMaterial(){}Editor3dAddDockPreview(e,t){this._configuratorKernelCallbackListener.forEach(r=>r.Editor3dAddDockPreview(e,t))}Editor3dSetPreviewPointAssociations(e,t){this._configuratorKernelCallbackListener.forEach(r=>r.Editor3dSetPreviewPointAssociations(e,t))}Editor3dSetPreviewLineAssociations(e,t){this._configuratorKernelCallbackListener.forEach(r=>r.Editor3dSetPreviewLineAssociations(e,t))}Editor3dPreviewConstructionDone(e,t){this._configuratorKernelCallbackListener.forEach(r=>r.Editor3dPreviewConstructionDone(e,t))}Editor3dTranslateBy(){}Editor3dRotateBy(){}Editor3dRotateAround(){}Editor3dAddCube(){}Editor3dAddCubeUVMod(){}Editor3dAddSphere(){}Editor3dAddSphereUVMod(){}Editor3dAddRectangle(){}Editor3dAddRectangleUVMod(){}Editor3dAddMesh(){}Editor3dAddMeshUVMod(){}Editor3dAddMeshUVCoord(){}Editor3dAddCylinder(){}Editor3dAddCylinderUVMod(){}Editor3dAddPrism(){}Editor3dAddPrismUVMod(){}Editor3dAddFittingPoint(){}Editor3dAddFittingLine(){}Editor3dSelectObject(){}Editor3dCopy(){}Editor3dUpdatePlanObjectPosition(){}Editor3dUpdatePlanObjectRotation(){}Editor3dUpdatePlanObjectTransform(){}Editor3dUpdatePlanComponentPosition(){}Editor3dUpdatePlanComponentRotation(){}Editor3dUpdatePlanComponentTransform(){}getRuntimeComponentIdOfRootComponent(e){return this._kernelInstance?this._kernelInstance.getRootPlanComponentIdFromObjectId(e):(console.warn("this._kernelInstance not ready now"),0)}getRuntimeComponentId(e){return this._kernelInstance.getComponentId(e)}getParameterGroups(){if(!this._configuratorContext.planObjectId)return[];const e=this._kernelInstance.getRootPlanComponentIdFromObjectId(this._configuratorContext.planObjectId);return this._kernelInstance.getComponent(e).parameterGroups}resume(){this.muteKernelCallbacks||super.resume()}getSerializedConfiguration(e){return this._kernelInstance.getSerializedConfiguration(e)}createNewSerializedConfiguration(e){return this._kernelInstance.createNewSerializedConfiguration(e)}getCurrentConfigurationHash(e){return this._kernelInstance.getHashOfConfiguration(e)}listOfVariantsError(e,t){this._kernelIo.setMeta({rapiId:e}),this._kernelIo.error(t)}}pr([fr],Us.prototype,"_memoryManager",void 0),pr([fr],Us.prototype,"_configuratorKernelAccessCallback",void 0),pr([fr],Us.prototype,"_initData",void 0),pr([fr],Us.prototype,"_configuratorHistory",void 0);class Fs extends Di{constructor(e){super(e);const t=this.getPlanElement().getMaxWallHeight();this._container.position.y=(t<0?2800:t)/1e3+.01,this._container.name="Node Plan Element",this.addMesh(this._nodeUiMesh)}update(){super.update(),this._container.position.y=this.getPlanElement().getMaxWallHeight()/1e3+.01}_initNodeMesh(){if(this._nodeUiMesh)return;const e=new tt(.05,32),t=new C({color:16777215});this._sphere=new K(e,t);const r=new rt(.05,.07,32),n=new C({color:0,side:j});this._innerRingMesh=new K(r,n),this._innerRingMesh.rotation.set(Math.PI/2,0,0);const a=new rt(.07,.08,32),i=new C({color:16777215,side:j});this._outerRingMesh=new K(a,i),this._outerRingMesh.rotation.set(Math.PI/2,0,0),this._nodeUiMesh=new K,this._nodeUiMesh.add(this._sphere),this._nodeUiMesh.add(this._innerRingMesh),this._nodeUiMesh.add(this._outerRingMesh)}setTopView(e){super.setTopView(e),e||(this._nodeUiMesh.visible=!1)}getSize(){return this._initNodeMesh(),(new be).setFromObject(this._nodeUiMesh).getSize(new s)}show(){this._nodeUiMesh.visible=this._topView}hide(){this._nodeUiMesh.visible=!1}select(){this._innerRingMesh.material=new C({color:10526880,side:j}),super.select()}deselect(){this._innerRingMesh.material=new C({color:0,side:j}),super.deselect()}hoverOn(){this._sphere.geometry=new tt(.07,32),this._innerRingMesh.geometry=new rt(.07,.07+.02,32),this._outerRingMesh.geometry=new rt(.07+.02,.1,32),super.hoverOn()}hoverOff(){this._sphere.geometry=new tt(.05,32),this._innerRingMesh.geometry=new rt(.05,.07,32),this._outerRingMesh.geometry=new rt(.07,.08,32),super.hoverOff()}_generateBoundingBox(){const e=super._generateBoundingBox();return e.layers.set(9),e}addMesh(e){super.addMesh(e)}}e("N",Fs);class Bs extends zi{constructor(e){super(e),this._container.name="Construction "+this._container.name}setTopView(e){super.setTopView(e),e?this._enableTopView():this._disableTopView(),this._updateBoundingBox()}_enableTopView(){if(!this._topViewContainer){this._topViewContainer=new Y;const e=this.getPlanElement(),{x:t,z:r}=An(e.size),n=new He(t,.01,r);if(this._topGreyMesh=new K(n,_n.createMeshStandardMaterial({transparent:!0,opacity:1,color:11645361})),this._topViewContainer.add(this._topGreyMesh),"window"===e.getObjectType()){const e=new He(t,.02,.05);this._topBlackMesh=new K(e,_n.createMeshStandardMaterial({transparent:!0,opacity:1,color:0})),this._topViewContainer.add(this._topBlackMesh)}this._topViewContainer.position.y=5,this._container.add(this._topViewContainer)}this._topViewContainer.visible=!0}_disableTopView(){this._topViewContainer&&(this._topViewContainer.visible=!1)}getPlanElement(){return super.getPlanElement()}_generateBoundingBox(){const e=super._generateBoundingBox(),t=this.getSize();return e.geometry=new He(t.x,this._topView?5:t.y,t.z),e}_updateBoundingBox(){super._updateBoundingBox();const e=this.getSize();this._boundingBox.geometry=new He(e.x,this._topView?5:e.y,e.z)}getTopViewContainer(){return this._topViewContainer}update(){if(super.update(),!this._topGreyMesh)return;const{x:e,z:t}=An(this.getPlanElement().size);this._topGreyMesh.geometry=new He(e,.01,t),this._topBlackMesh&&(this._topBlackMesh.geometry=new He(e,.02,.05))}}e("d",Bs);class Ns extends Us{get kernelContainer(){return this._kernelContainer}constructor(e){super(e),this._plannerKernelCallbackListener=new Set}_loadSuccess(){super._loadSuccess(),window.RoomleCore&&window.RoomleCore(this._kernelContainer)}_loadError(){super._loadError(),console.error("kernel load error")}_createPlanInteractionHandler(){this._planInteractionHandler=new this._kernelContainer.PlanInteractionHandler,this._planInteractionHandler.init(this._planInteractionHandler,1,50,!!this._initData.snappingEnabled,!0,this._kernelContainer.DrawingType.CLICK_PER_CLICK),this._roomlePlannerUiCallback.onPlanInteractionHandlerCreated(this._planInteractionHandler)}addPlannerListener(e){this._plannerKernelCallbackListener.add(e)}removePlannerListener(e){this._plannerKernelCallbackListener.delete(e)}isReady(){super.isReady(),this.registerCallbacks(),this._roomlePlannerUiCallback.onPlannerKernelIsReady(this._kernelContainer),this._roomlePlannerUiCallback.onConfiguratorKernelIsReady(this._kernelContainer,this._kernelInstance),Ni.isProduction||(window.__RML__DEBUG__.ConfiguratorKernel=this._kernelInstance,window.__RML__DEBUG__.PlannerKernelContainer=this._kernelContainer),this._kernelAccessCallback.isReady()}_setupKernel(){0===this._kernelType&&(this._createPlanInteractionHandler(),qi.kernelInstance?this._kernelInstance=qi.kernelInstance:this._kernelInstance=this._planInteractionHandler.getConfiguratorKernel()),super._setupKernel()}get callbacks(){return this._roomlePlannerUiCallback}get planInteractionHandler(){return this._planInteractionHandler}get planModelViewHelper(){return this._kernelContainer.PlanModelViewHelper}catalogItemLoaded(e){const t=this._rapiItemToKernelItem(e);this._kernelContainer.catalogItemLoaded(t)}async insertItems(e){this.planInteractionHandler.startInteraction();let t=new this._kernelContainer.CatalogItemPtrList;e.forEach(e=>{let r=e.count||1;for(let n=0;n<r;n++)e.count||(e.count=0),t.push_back(this._rapiItemToKernelItem(e))});const r=this.planInteractionHandler.getPlan().extRef.jsObject,n=r.getPlanObjectViewModelsFromRapiId().reduce((e,t)=>(e[t.getId()]=!0,e),{});this.planInteractionHandler.addPlanObjects(t,!0),await Promise.allSettled([Promise.allSettled(r.getStaticPlanObjectViewModels().map(async e=>{if(e.needsRapiItem()){const t=await this._rapiAccess.getItem(e.getPlanObject().getCatalogItemId());e.setRapiItem(t)}})),Promise.allSettled(r.getConfigurablePlanObjectViewModels().map(e=>e.isInitDone()))]);const a=r.getPlanObjectViewModelsFromRapiId().map(e=>e.getId()).filter(e=>!n[e]);return this.planInteractionHandler.endInteraction(),a}duplicateItems(e){const t=new this.kernelContainer.PlanObjectPtrList;return e.forEach(e=>{t.push_back(e)}),this.planInteractionHandler.duplicatePlanObjects(t,1,!0)}_rapiItemToKernelItem(e){let t=new this._kernelContainer.CatalogItem(e.id),r=t.size;return r.x=e.width||0,r.y=e.depth||0,r.z=e.height||0,t.size=r,t.flipable=e.flipable,e.layer&&(t.layer=e.layer),t.orderable=e.orderable,t.scaleable=e.scaleable,t.type=e.type||"other",t.detailType=e.detailType||t.type||"other",t.configuration=e.configuration||"",t}planObjectDeleted(){}requestPlanObjectDimensions(){}cleanUpCallbacks(){var e;super.cleanUpCallbacks(),(null===(e=this._kernelContainer)||void 0===e?void 0:e.unregisterPlannerCallback)&&this._kernelContainer.unregisterPlannerCallback(this)}registerCallbacks(){var e;super.registerCallbacks(),(null===(e=this._kernelContainer)||void 0===e?void 0:e.registerPlannerCallback)&&this._kernelContainer.registerPlannerCallback(this)}planElementRemoved(e){this._plannerKernelCallbackListener.forEach(t=>t.planElementRemoved(e)),this._plannerKernelCallbackListener.forEach(t=>t.removePlanObjectFromScene(e.extRef.jsObject)),this._decoupleReferences(e)}handlerSwitchedPlans(e,t){this._decoupleReferences(e),t&&this._plannerKernelCallbackListener.forEach(r=>r.handlerSwitchedPlans(e,t))}planBoundsChanged(){this._plannerKernelCallbackListener.forEach(e=>e.planBoundsChanged())}planCleared(){this._plannerKernelCallbackListener.forEach(e=>e.planCleared())}planCompletelyLoaded(e){this._plannerKernelCallbackListener.forEach(t=>t.planCompletelyLoaded(e))}planElement3dMeshChanged(e,t){if(t.extRef){const e=t.extRef.jsObject;for(let t=e.getObject().children.length-1;t>=0;t--)e.getObject().remove(e.getObject().children[t])}this.planModelViewHelper.requestMesh3d(t)}async _onStaticItemAdded(e,t){let r;r=this.isConstructionPlanElement(t)?new Bs(t):new zi(t),this.coupleReferences(r,t),e.extRef.jsObject.addPlanElementViewModel(r);const n=t.getCatalogItemId();if(n){const e=await this._rapiAccess.getItem(n);r.setRapiItem(e),this._plannerKernelCallbackListener.forEach(e=>e.addPlanObjectToScene(r))}}_onConfigurableItemAdded(e,t){const r=new Ui(t);this.coupleReferences(r,t),e.extRef.jsObject.addPlanElementViewModel(r),this._plannerKernelCallbackListener.forEach(e=>e.addPlanObjectToScene(r))}async planElementAdded(e,t){if(e&&e.extRef)if(t.getType()===this._kernelContainer.PlanElementType.OBJECT)t.hasConfiguration()?this._onConfigurableItemAdded(e,t):await this._onStaticItemAdded(e,t);else{const r=t;let n;if(t.getType()===this._kernelContainer.PlanElementType.WALL?n=new Vi(r):t.getType()===this._kernelContainer.PlanElementType.FLOOR?n=new Gi(r):t.getType()===this._kernelContainer.PlanElementType.CEILING?n=new Ki(r):t.getType()===this._kernelContainer.PlanElementType.NODE&&(n=new Fs(r)),!n)return;this.coupleReferences(n,r),e.extRef.jsObject.addPlanElementViewModel(n),n.setPrimaryColor(this._initData.colors.PRIMARY),this.planModelViewHelper.requestMesh3d(t),this._plannerKernelCallbackListener.forEach(e=>e.addPlanObjectToScene(null))}}planElementChanged(e,t){if(t.extRef){let r=t.extRef.jsObject;r.update(),this._plannerKernelCallbackListener.forEach(t=>t.planElementChanged(e,r))}}planHistoryStateChanged(){this.planInteractionHandler&&(this._plannerKernelCallbackListener.forEach(e=>e.planHistoryStateChanged()),this._roomlePlannerUiCallback.onHistoryChange(this.planInteractionHandler.isUndoPossible(),this.planInteractionHandler.isRedoPossible()))}planObjectConfigurationCreated(e,t){}planObjectConfigurationLoaded(e,t,r){e&&e.extRef&&t&&t.extRef&&t.extRef.jsObject.getPlanObject().getConfigurationRuntimeId()>0&&this._plannerKernelCallbackListener.forEach(n=>n.planObjectConfigurationLoaded(e,t,r))}requestCatalogItem(e){}startedDrawing(){this._plannerKernelCallbackListener.forEach(e=>e.startedDrawing())}stoppedDrawing(){this._plannerKernelCallbackListener.forEach(e=>e.stoppedDrawing())}updateMesh2d(){}beginConstruction(){}addMesh(e,t,r,n,a,i){this._plannerKernelCallbackListener.forEach(s=>s.addMesh(e,t,r,n,a,i))}endConstruction(){}beginPlanConstruction(e){this._plannerKernelCallbackListener.forEach(t=>t.beginPlanConstruction(e))}addPlanMesh(e,t,r,n,a,i,s){this._plannerKernelCallbackListener.forEach(o=>o.addPlanMesh(e,t,r,n,a,i,s))}endPlanConstruction(e){this._plannerKernelCallbackListener.forEach(t=>t.endPlanConstruction(e))}async addPlanObjectFromItem(e,t,r){if(!t&&!r){const t=await this.insertItems([e]);if(1!==t.length)throw new Error("It was expected that 1 element is added but"+t.length+"were added");return t[0]}r=r||0===r?r:0,t=t||{x:0,y:0,z:0};const n=this._planInteractionHandler.addPlanObjectFromItem(this._rapiItemToKernelItem(e),t,r,!1),a=this._planInteractionHandler.getPlan().extRef.jsObject;let i;return n.hasConfiguration()?(i=a.getConfigurablePlanObjectForId(n.getId()),i||console.warn("Could not find configuration")):(i=a.getStaticPlanObjectViewModelForId(n.getId()),i?await i.setRapiItem(e):console.warn("Could not find static item")),await i.isInitDone(),i.getId()}coupleReferences(e,t){let r=new this._kernelContainer.EMSReference;r.jsObject=e,t.extRef=r}_decoupleReferences(e){e&&e.extRef&&(e.extRef.jsObject.clearReference(),e.extRef.jsObject=null,e.extRef.delete(),e.extRef=null)}isConstructionPlanElement(e){return e instanceof this.kernelContainer.ConstructionObject}}e("P",Ns),pr([fr],Ns.prototype,"_kernelAccessCallback",void 0),pr([fr],Ns.prototype,"_roomlePlannerUiCallback",void 0);class zs extends gi{constructor(e){super(e),this._wallMeshes=[],this._defaultMaterial=_n.createMeshPhysicalMaterial({color:"#ffffff",side:j})}generateGeometry(e=null,t,r,n,a,i=!1){let s;return s=i?this._generateGeometry(e,t,r,n,a).clone():this._generateGeometry(e,t,r,n,a),s}generateMesh(e=0,t=null,r,n,a,i,s,o,l=!1,h){let d;d=l?this._generateGeometry(t,n,a,i,s).clone():this._generateGeometry(t,n,a,i,s);const c=this._createMesh(e,t,d);return c.userData.materialId=r,c.layers.set(4),r&&this.setMaterial(c,r,o,h).then(()=>{e&&t&&r&&this._geometryComponentMaterialCache.set(this._getComponentMeshId(e,t),r);const n=o&&3===o.value,a=o&&1===o.value;c.castShadow=!n&&!a,c.userData.isFloor=n}),this._checkWallMaterial(c,o),c}async setMaterial(e,t,r,n){if(e.userData.materialId=ni(t,r),nt(t))t?await this._assignMaterial(e,t,n):(console.warn("Used default material because material is empty"),this.changeMaterialOfMesh(e,this._getDefaultMaterial(r)));else{if(!t)return void this.changeMaterialOfMesh(e,this._configuratorPreviewMaterial);2===(t=t).getSourceType().value?await this._assignMaterial(e,t.materialId,n):1===t.getSourceType().value?await this._assignItem(e,t.catalogItemId):3===t.getSourceType().value?await this._assignRGB(e,t.rgbValue):0===t.getSourceType().value?this.changeMaterialOfMesh(e,this._getDefaultMaterial(r)):(this.changeMaterialOfMesh(e,this._getDefaultMaterial(r)),1!==r.value&&7!==r.value&&3!==r.value&&console.warn("Used default material because material is not supported",t))}}_getDefaultMaterial(e){return 3===(null==e?void 0:e.value)?this._defaultMaterialFloor:this._defaultMaterial}set maxAnisotropy(e){this._maxAnisotropy=e}_checkWallMaterial(e,t){t&&1===t.value&&(e.renderOrder=5,this._wallMeshes.push(e))}clear(){super.clear(),this.clearWallMeshes()}clearWallMeshes(){this._wallMeshes.forEach(e=>{$a(e)}),this._wallMeshes=[]}get wallMeshes(){return this._wallMeshes}}e("an",zs);let Hs={InchFeet:null,Feet:null,MM:null,CM:null,Inch:null},js={NoUnitString:null,LongUnitString:null,ShortUnitString:null};const Vs=["mm","cm","feet"],Gs=["inch","inchfeet"];class Ks{constructor(e){this._formatter=null,this._precision=0,this._creator_=e}init(e){const t=new e.UnitMeasureFormatter;Hs=e.Unit,js=e.UnitStringType,this._initActualUnit(),this._initMeasurementSystemType(),this._initActualUnitStringType();const{precisionCm:r,precisionInch:n}=this._initData;this._actualUnit===Hs.InchFeet?this._precision=void 0!==n?parseInt(n,10):2:this._actualUnit===Hs.CM&&(this._precision=void 0!==r?parseInt(r,10):1),t.init("mm","cm","'","ft",'"',"inch","m²","sqft",!0,this._precision,!0),this._formatter=t}_initMeasurementSystemType(){let{measurementSystem:e,unit:t}=this._initData;if(this._actualMeasurementString=e,e||!t){if("metric"===e){t||(t="cm");const e=Vs.find(e=>e===t);e?(this._actualUnit=this._getKernelUnitEnum(t),this._actualUnitString=e):(console.warn("Unit is not a metric unit, using CM"),this._actualUnit=Hs.CM,this._actualUnitString="cm")}if("imperial"===e){t||(t="inch");const e=Gs.find(e=>e===t);e?(this._actualUnit=this._getKernelUnitEnum(t),this._actualUnitString=e):(console.warn("Unit is not an imperial unit, using Inches"),this._actualUnit=Hs.Inch,this._actualUnitString="inch")}}else{this._actualUnitString=t;const e=Vs.find(e=>e===t);this._actualMeasurementString=e?"metric":"imperial"}}_initActualUnit(){const{unit:e}=this._initData;this._actualUnit=this._getKernelUnitEnum(e)}_getKernelUnitEnum(e){switch(e){case"cm":return Hs.CM;case"mm":return Hs.MM;case"inchfeet":return Hs.InchFeet;case"feet":return Hs.Feet;case"inch":return Hs.Inch;default:return Hs.CM}}_initActualUnitStringType(){const{unitStringType:e}=this._initData;e&&"short"!==e&&console.warn("Only short unit strings is supported at the moment"),this._actualUnitStringType=js.ShortUnitString}_isFormatterReady(){return!!this._formatter||(console.warn("Formatter is not ready..."),!1)}formatAngleValueToUnitString(e,t){const r="Integer"===t.type?0:2;return e.toFixed(r)+"°"}parseAngleValueFromUnitString(e){return e.replace("°","").replace(/\s/g,"")}parseValue(e,t){return null===t.unitType||"unknown"===t.unitType||"count"===t.unitType?e:"length"===t.unitType?this.parseMMValueFromUnitString(e,t.unitType):"angle"===t.unitType||"area"===t.unitType?this.parseAngleValueFromUnitString(e):e}formatValueToUnitString(e,t){return null===t.unitType||"unknown"===t.unitType||"count"===t.unitType?"Integer"===t.type?e.toString():parseFloat(e.toString()).toFixed(2):"length"===t.unitType?this.formatMMValueToUnitString(e,t.unitType):"angle"===t.unitType?this.formatAngleValueToUnitString(e,t):"area"===t.unitType?this.formatSquareMMValueToUnitString(e):e}isParseableNumber(e){return this._isFormatterReady()?this._formatter.isParseableNumber(e):null}isParseableUnitString(e,t){return this._isFormatterReady()?"angle"===t.unitType?this._formatter.isParseableUnitString(this.parseAngleValueFromUnitString(e),this._actualUnit):this._formatter.isParseableUnitString(e,this._actualUnit):null}parseMMValueFromUnitString(e,t){return this._isFormatterReady()?"count"===t?parseFloat(e):this._formatter.parseMMValueFromUnitString(e,this._actualUnit):null}parseNumber(e){return this._isFormatterReady()?this._formatter.parseNumber(e):null}formatNumber(e,t=0){return this._isFormatterReady()?this._formatter.formatNumber(e,t):null}formatSquareMMValueToUnitString(e){return this._isFormatterReady()?this._formatter.formatSquareMMValueToUnitString(e,this._actualUnit):null}formatMMValueToUnitString(e,t){return this._isFormatterReady()?"count"===t?e.toString():this._formatter.formatMMValueToUnitString(e,this._actualUnit,this._actualUnitStringType):null}formatMMValueWithReqMaxLength(e,t){return this._isFormatterReady()?this._formatter.formatMMValueWithReqMaxLength(e,this._actualUnit,t):null}_formatParameterValue(e,t){return"length"===t?this.formatMMValueToUnitString(parseFloat(e)):"area"===t?this.formatSquareMMValueToUnitString(parseFloat(e)):e}formatPartListParameter(e){(function(e){return"length"===e.unitType||"area"===e.unitType})(e)&&(e.valueLabel=this._formatParameterValue(e.value,e.unitType))}formatParameter(e){if(e.valueLabel=this._formatParameterValue(e.value,e.unitType),es(e))e.uiType="Material";else if(function(e){return"Boolean"===e.type}(e))e.uiType="Boolean";else if(Ji(e)){e.uiType="Range";const t=null!==e.validRange.valueFrom?e.validRange.valueFrom:Number.MIN_SAFE_INTEGER,r=null!==e.validRange.valueTo?e.validRange.valueTo:Number.MAX_SAFE_INTEGER;e.validRangeLabels={valueFrom:this._formatParameterValue(t.toString(),e.unitType),valueTo:this._formatParameterValue(r.toString(),e.unitType),type:e.validRange.type}}else $i(e)?(e.uiType="Options",function(e){return!!$i(e)&&Array.isArray(e.validValues)&&e.validValues.length>0&&"string"==typeof e.validValues[0].thumbnail}(e)&&(e.uiType="Thumbnails")):(console.error("Could not detect uiType of param"),e.uiType=null)}isInch(){return this._actualUnit===Hs.InchFeet}getActualUnitString(){return this._actualUnitString}getActualMeasurementString(){return this._actualMeasurementString}getUnitStringType(){return this._initData.unitStringType}getPrecision(){return this._precision}getAllowedDelta(){const e=1/Math.pow(10,this._precision);return this.isInch()?25.4*e:e}setUnitInitData(e,t=""){this._initData.unit=e,this._initData.measurementSystem=t,this._initActualUnit(),this._initMeasurementSystemType(),this._initActualUnitStringType(),this._plannerKernelAccess.kernelInstance.setEnvironmentVariable("unit",this._actualUnitString)}}pr([fr],Ks.prototype,"_initData",void 0),pr([fr],Ks.prototype,"_plannerKernelAccess",void 0);class Ws{constructor(e){this._history=[],this._index=0,this._creator_=e}undo(){if(!this.canUndo())return null;this._index++;const[e]=this._history.slice(this._index);return this._index===this._history.length-1?this._configuratorUiCallbacks.onHistoryChange(!1,!0):this._configuratorUiCallbacks.onHistoryChange(!0,!0),e}redo(){if(!this.canRedo())return null;this._index--;const[e]=this._history.slice(this._index);return 0===this._index?this._configuratorUiCallbacks.onHistoryChange(!0,!1):this._configuratorUiCallbacks.onHistoryChange(!0,!0),e}push(e){const[t]=this._history.slice(this._index);t!==e&&(this._history=this._history.slice(this._index),this._history.unshift(e),this._index=0,1===this._history.length?this._configuratorUiCallbacks.onHistoryChange(!1,!1):this._configuratorUiCallbacks.onHistoryChange(!0,!1))}canUndo(){return this._index!==this._history.length-1}canRedo(){return 0!==this._index}getHistory(){return this._history}clearHistory(){this._history=[],this._index=0}}pr([fr],Ws.prototype,"_configuratorUiCallbacks",void 0),e("ae",{ADDED:"added",CHANGED:"changed",REMOVED:"removed"});class Xs{constructor(e){this._kernelCallbacks={isReady:()=>{},throw:e=>console.error("Kernel exception",e),log:e=>{},error:(e,t,r,n)=>{},message:e=>{this._analyzeComponentCallback&&this._analyzeComponentCallback(e)}},this._creator_=e}async init(){if(this._toolsCoreInstance)return Promise.resolve();const e=this,t={locateFile:e=>"RoomleToolsCore.wasm"===e?r()+"static/RoomleToolsCore-e914e875d1df9396.wasm":e,wasmBinaryFile:r()+"static/RoomleToolsCore-e914e875d1df9396.wasm",preRun:[],postRun:[],setStatus:null,print(t){e._kernelIo.log(t)},printErr(t){e._kernelIo.error(t)},quit(t){0!==t&&e._kernelIo.throw(t&&t.toString?t.toString():"Unknown error while C/C++ main executes")}};await this._scriptLoader.fetch("static/RoomleToolsCore-dccc86952ee877cc.js",{id:"core-tool"});const n=await window.RoomleToolsCore(t);n.setContext(this._kernelCallbacks),this._toolsCoreInstance=new n.ToolsCore}analyzeComponent(e,t){const r=[];return this._analyzeComponentCallback=e=>{r.push(e)},this._toolsCoreInstance.analyzeComponent(e,t),this._analyzeComponentCallback=null,Promise.resolve(r)}}pr([fr],Xs.prototype,"_scriptLoader",void 0),pr([fr],Xs.prototype,"_kernelIo",void 0);
|
|
2
|
+
/*!
|
|
3
|
+
fflate - fast JavaScript compression/decompression
|
|
4
|
+
<https://101arrowz.github.io/fflate>
|
|
5
|
+
Licensed under MIT. https://github.com/101arrowz/fflate/blob/master/LICENSE
|
|
6
|
+
version 0.6.9
|
|
7
|
+
*/
|
|
8
|
+
var qs=function(e){return URL.createObjectURL(new Blob([e],{type:"text/javascript"}))};try{URL.revokeObjectURL(qs(""))}catch(e){qs=function(e){return"data:application/javascript;charset=UTF-8,"+encodeURI(e)}}var Qs=Uint8Array,Ys=Uint16Array,Zs=Uint32Array,Js=new Qs([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0,0]),$s=new Qs([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13,0,0]),eo=new Qs([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),to=function(e,t){for(var r=new Ys(31),n=0;n<31;++n)r[n]=t+=1<<e[n-1];var a=new Zs(r[30]);for(n=1;n<30;++n)for(var i=r[n];i<r[n+1];++i)a[i]=i-r[n]<<5|n;return[r,a]},ro=to(Js,2),no=ro[0],ao=ro[1];no[28]=258,ao[258]=28;for(var io=to($s,0)[0],so=new Ys(32768),oo=0;oo<32768;++oo){var lo=(43690&oo)>>>1|(21845&oo)<<1;lo=(61680&(lo=(52428&lo)>>>2|(13107&lo)<<2))>>>4|(3855&lo)<<4,so[oo]=((65280&lo)>>>8|(255&lo)<<8)>>>1}var ho=function(e,t,r){for(var n=e.length,a=0,i=new Ys(t);a<n;++a)++i[e[a]-1];var s,o=new Ys(t);for(a=0;a<t;++a)o[a]=o[a-1]+i[a-1]<<1;if(r){s=new Ys(1<<t);var l=15-t;for(a=0;a<n;++a)if(e[a])for(var h=a<<4|e[a],d=t-e[a],c=o[e[a]-1]++<<d,u=c|(1<<d)-1;c<=u;++c)s[so[c]>>>l]=h}else for(s=new Ys(n),a=0;a<n;++a)e[a]&&(s[a]=so[o[e[a]-1]++]>>>15-e[a]);return s},co=new Qs(288);for(oo=0;oo<144;++oo)co[oo]=8;for(oo=144;oo<256;++oo)co[oo]=9;for(oo=256;oo<280;++oo)co[oo]=7;for(oo=280;oo<288;++oo)co[oo]=8;var uo=new Qs(32);for(oo=0;oo<32;++oo)uo[oo]=5;var po=ho(co,9,1),mo=ho(uo,5,1),fo=function(e){for(var t=e[0],r=1;r<e.length;++r)e[r]>t&&(t=e[r]);return t},go=function(e,t,r){var n=t/8|0;return(e[n]|e[n+1]<<8)>>(7&t)&r},vo=function(e,t){var r=t/8|0;return(e[r]|e[r+1]<<8|e[r+2]<<16)>>(7&t)},wo=new Qs(0);function bo(e,t){return function(e,t,r){var n=e.length;if(!n||r&&!r.l&&n<5)return t||new Qs(0);var a=!t||r,i=!r||r.i;r||(r={}),t||(t=new Qs(3*n));var s,o=function(e){var r=t.length;if(e>r){var n=new Qs(Math.max(2*r,e));n.set(t),t=n}},l=r.f||0,h=r.p||0,d=r.b||0,c=r.l,u=r.d,p=r.m,m=r.n,f=8*n;do{if(!c){r.f=l=go(e,h,1);var g=go(e,h+1,3);if(h+=3,!g){var v=e[(P=((s=h)/8|0)+(7&s&&1)+4)-4]|e[P-3]<<8,w=P+v;if(w>n){if(i)throw"unexpected EOF";break}a&&o(d+v),t.set(e.subarray(P,w),d),r.b=d+=v,r.p=h=8*w;continue}if(1==g)c=po,u=mo,p=9,m=5;else{if(2!=g)throw"invalid block type";var b=go(e,h,31)+257,y=go(e,h+10,15)+4,_=b+go(e,h+5,31)+1;h+=14;for(var x=new Qs(_),S=new Qs(19),C=0;C<y;++C)S[eo[C]]=go(e,h+3*C,7);h+=3*y;var M=fo(S),T=(1<<M)-1,A=ho(S,M,1);for(C=0;C<_;){var P,R=A[go(e,h,T)];if(h+=15&R,(P=R>>>4)<16)x[C++]=P;else{var E=0,I=0;for(16==P?(I=3+go(e,h,3),h+=2,E=x[C-1]):17==P?(I=3+go(e,h,7),h+=3):18==P&&(I=11+go(e,h,127),h+=7);I--;)x[C++]=E}}var k=x.subarray(0,b),O=x.subarray(b);p=fo(k),m=fo(O),c=ho(k,p,1),u=ho(O,m,1)}if(h>f){if(i)throw"unexpected EOF";break}}a&&o(d+131072);for(var D=(1<<p)-1,L=(1<<m)-1,U=h;;U=h){var F=(E=c[vo(e,h)&D])>>>4;if((h+=15&E)>f){if(i)throw"unexpected EOF";break}if(!E)throw"invalid length/literal";if(F<256)t[d++]=F;else{if(256==F){U=h,c=null;break}var B=F-254;if(F>264){var N=Js[C=F-257];B=go(e,h,(1<<N)-1)+no[C],h+=N}var z=u[vo(e,h)&L],H=z>>>4;if(!z)throw"invalid distance";if(h+=15&z,O=io[H],H>3&&(N=$s[H],O+=vo(e,h)&(1<<N)-1,h+=N),h>f){if(i)throw"unexpected EOF";break}a&&o(d+131072);for(var j=d+B;d<j;d+=4)t[d]=t[d-O],t[d+1]=t[d+1-O],t[d+2]=t[d+2-O],t[d+3]=t[d+3-O];d=j}}r.l=c,r.p=U,r.b=d,c&&(l=1,r.m=p,r.d=u,r.n=m)}while(!l);return d==t.length?t:function(e,t,r){(null==t||t<0)&&(t=0),(null==r||r>e.length)&&(r=e.length);var n=new(e instanceof Ys?Ys:e instanceof Zs?Zs:Qs)(r-t);return n.set(e.subarray(t,r)),n}(t,0,d)}((function(e){if(8!=(15&e[0])||e[0]>>>4>7||(e[0]<<8|e[1])%31)throw"invalid zlib data";if(32&e[1])throw"invalid zlib data: preset dictionaries not supported"}(e),e.subarray(2,-4)),t)}var yo="undefined"!=typeof TextDecoder&&new TextDecoder;try{yo.decode(wo,{stream:!0})}catch(e){}var _o=function(e){g(r,e);var t=v(r);function r(e){var n;return w(this,r),(n=t.call(this,e)).type=at,n}return b(r,[{key:"parse",value:function(e){var t=Math.pow(2.7182818,2.2),r={l:0,c:0,lc:0};function n(e,t,n,a,i){for(;n<e;)t=t<<8|L(a,i),n+=8;n-=e,r.l=t>>n&(1<<e)-1,r.c=t,r.lc=n}var a=new Array(59);function i(e){return 63&e}function s(e){return e>>6}var o={c:0,lc:0};function l(e,t,r,n){e=e<<8|L(r,n),t+=8,o.c=e,o.lc=t}var h={c:0,lc:0};function d(e,t,r,n,a,i,s,d,c){if(e==t){n<8&&(l(r,n,a,i),r=o.c,n=o.lc);var u=r>>(n-=8);if(u=new Uint8Array([u])[0],d.value+u>c)return!1;for(var p=s[d.value-1];u-- >0;)s[d.value++]=p}else{if(!(d.value<c))return!1;s[d.value++]=e}h.c=r,h.lc=n}function c(e){return 65535&e}function u(e){var t=c(e);return t>32767?t-65536:t}var p={a:0,b:0};function m(e,t){var r=u(e),n=u(t),a=r+(1&n)+(n>>1),i=a,s=a-n;p.a=i,p.b=s}function f(e,t){var r=c(e),n=c(t),a=r-(n>>1)&65535,i=n+a-32768&65535;p.a=i,p.b=a}function g(e,t,r,n,a,i,s){for(var o,l,h=s<16384,d=r>a?a:r,c=1;c<=d;)c<<=1;for(o=c>>=1,c>>=1;c>=1;){for(var u=(l=0)+i*(a-o),g=i*c,v=i*o,w=n*c,b=n*o,y=void 0,_=void 0,x=void 0,S=void 0;l<=u;l+=v){for(var C=l,M=l+n*(r-o);C<=M;C+=b){var T=C+w,A=C+g,P=A+w;h?(m(e[C+t],e[A+t]),y=p.a,x=p.b,m(e[T+t],e[P+t]),_=p.a,S=p.b,m(y,_),e[C+t]=p.a,e[T+t]=p.b,m(x,S),e[A+t]=p.a,e[P+t]=p.b):(f(e[C+t],e[A+t]),y=p.a,x=p.b,f(e[T+t],e[P+t]),_=p.a,S=p.b,f(y,_),e[C+t]=p.a,e[T+t]=p.b,f(x,S),e[A+t]=p.a,e[P+t]=p.b)}if(r&c){var R=C+g;h?m(e[C+t],e[R+t]):f(e[C+t],e[R+t]),y=p.a,e[R+t]=p.b,e[C+t]=y}}if(a&c)for(var E=l,I=l+n*(r-o);E<=I;E+=b){var k=E+w;h?m(e[E+t],e[k+t]):f(e[E+t],e[k+t]),y=p.a,e[k+t]=p.b,e[E+t]=y}o=c,c>>=1}return l}function v(e,t,c,u,p,m){var f=c.value,g=D(t,c),v=D(t,c);c.value+=4;var w=D(t,c);if(c.value+=4,g<0||g>=65537||v<0||v>=65537)throw new Error("Something wrong with HUF_ENCSIZE");var b=new Array(65537),y=new Array(16384);if(function(e){for(var t=0;t<16384;t++)e[t]={},e[t].len=0,e[t].lit=0,e[t].p=null}(y),function(e,t,i,s,o,l){for(var h=t,d=0,c=0;s<=o;s++){if(h.value-t.value>i)return!1;n(6,d,c,e,h);var u=r.l;if(d=r.c,c=r.lc,l[s]=u,63==u){if(h.value-t.value>i)throw new Error("Something wrong with hufUnpackEncTable");n(8,d,c,e,h);var p=r.l+6;if(d=r.c,c=r.lc,s+p>o+1)throw new Error("Something wrong with hufUnpackEncTable");for(;p--;)l[s++]=0;s--}else if(u>=59){var m=u-59+2;if(s+m>o+1)throw new Error("Something wrong with hufUnpackEncTable");for(;m--;)l[s++]=0;s--}}!function(e){for(var t=0;t<=58;++t)a[t]=0;for(var r=0;r<65537;++r)a[e[r]]+=1;for(var n=0,i=58;i>0;--i){var s=n+a[i]>>1;a[i]=n,n=s}for(var o=0;o<65537;++o){var l=e[o];l>0&&(e[o]=l|a[l]++<<6)}}(l)}(e,c,u-(c.value-f),g,v,b),w>8*(u-(c.value-f)))throw new Error("Something wrong with hufUncompress");!function(e,t,r,n){for(;t<=r;t++){var a=s(e[t]),o=i(e[t]);if(a>>o)throw new Error("Invalid table entry");if(o>14){var l=n[a>>o-14];if(l.len)throw new Error("Invalid table entry");if(l.lit++,l.p){var h=l.p;l.p=new Array(l.lit);for(var d=0;d<l.lit-1;++d)l.p[d]=h[d]}else l.p=new Array(1);l.p[l.lit-1]=t}else if(o)for(var c=0,u=1<<14-o;u>0;u--){var p=n[(a<<14-o)+c];if(p.len||p.p)throw new Error("Invalid table entry");p.len=o,p.lit=t,c++}}}(b,g,v,y),function(e,t,r,n,a,c,u,p,m){for(var f=0,g=0,v=u,w=Math.trunc(n.value+(a+7)/8);n.value<w;)for(l(f,g,r,n),f=o.c,g=o.lc;g>=14;){var b=t[f>>g-14&16383];if(b.len)g-=b.len,d(b.lit,c,f,g,r,n,p,m,v),f=h.c,g=h.lc;else{if(!b.p)throw new Error("hufDecode issues");var y=void 0;for(y=0;y<b.lit;y++){for(var _=i(e[b.p[y]]);g<_&&n.value<w;)l(f,g,r,n),f=o.c,g=o.lc;if(g>=_&&s(e[b.p[y]])==(f>>g-_&(1<<_)-1)){g-=_,d(b.p[y],c,f,g,r,n,p,m,v),f=h.c,g=h.lc;break}}if(y==b.lit)throw new Error("hufDecode issues")}}var x=8-a&7;for(f>>=x,g-=x;g>0;){var S=t[f<<14-g&16383];if(!S.len)throw new Error("hufDecode issues");g-=S.len,d(S.lit,c,f,g,r,n,p,m,v),f=h.c,g=h.lc}}(b,y,e,c,w,v,m,p,{value:0})}function w(e){for(var t=1;t<e.length;t++){var r=e[t-1]+e[t]-128;e[t]=r}}function b(e,t){for(var r=0,n=Math.floor((e.length+1)/2),a=0,i=e.length-1;!(a>i||(t[a++]=e[r++],a>i));)t[a++]=e[n++]}function y(e){for(var t=e.byteLength,r=new Array,n=0,a=new DataView(e);t>0;){var i=a.getInt8(n++);if(i<0){var s=-i;t-=s+1;for(var o=0;o<s;o++)r.push(a.getUint8(n++))}else{var l=i;t-=2;for(var h=a.getUint8(n++),d=0;d<l+1;d++)r.push(h)}}return r}function _(e,t,r){for(var n,a=1;a<64;)65280==(n=t[e.value])?a=64:n>>8==255?a+=255&n:(r[a]=n,a++),e.value++}function x(e,t){t[0]=z(e[0]),t[1]=z(e[1]),t[2]=z(e[5]),t[3]=z(e[6]),t[4]=z(e[14]),t[5]=z(e[15]),t[6]=z(e[27]),t[7]=z(e[28]),t[8]=z(e[2]),t[9]=z(e[4]),t[10]=z(e[7]),t[11]=z(e[13]),t[12]=z(e[16]),t[13]=z(e[26]),t[14]=z(e[29]),t[15]=z(e[42]),t[16]=z(e[3]),t[17]=z(e[8]),t[18]=z(e[12]),t[19]=z(e[17]),t[20]=z(e[25]),t[21]=z(e[30]),t[22]=z(e[41]),t[23]=z(e[43]),t[24]=z(e[9]),t[25]=z(e[11]),t[26]=z(e[18]),t[27]=z(e[24]),t[28]=z(e[31]),t[29]=z(e[40]),t[30]=z(e[44]),t[31]=z(e[53]),t[32]=z(e[10]),t[33]=z(e[19]),t[34]=z(e[23]),t[35]=z(e[32]),t[36]=z(e[39]),t[37]=z(e[45]),t[38]=z(e[52]),t[39]=z(e[54]),t[40]=z(e[20]),t[41]=z(e[22]),t[42]=z(e[33]),t[43]=z(e[38]),t[44]=z(e[46]),t[45]=z(e[51]),t[46]=z(e[55]),t[47]=z(e[60]),t[48]=z(e[21]),t[49]=z(e[34]),t[50]=z(e[37]),t[51]=z(e[47]),t[52]=z(e[50]),t[53]=z(e[56]),t[54]=z(e[59]),t[55]=z(e[61]),t[56]=z(e[35]),t[57]=z(e[36]),t[58]=z(e[48]),t[59]=z(e[49]),t[60]=z(e[57]),t[61]=z(e[58]),t[62]=z(e[62]),t[63]=z(e[63])}function S(e){for(var t=.5*Math.cos(.7853975),r=.5*Math.cos(3.14159/16),n=.5*Math.cos(3.14159/8),a=.5*Math.cos(3*3.14159/16),i=.5*Math.cos(.981746875),s=.5*Math.cos(3*3.14159/8),o=.5*Math.cos(1.374445625),l=new Array(4),h=new Array(4),d=new Array(4),c=new Array(4),u=0;u<8;++u){var p=8*u;l[0]=n*e[p+2],l[1]=s*e[p+2],l[2]=n*e[p+6],l[3]=s*e[p+6],h[0]=r*e[p+1]+a*e[p+3]+i*e[p+5]+o*e[p+7],h[1]=a*e[p+1]-o*e[p+3]-r*e[p+5]-i*e[p+7],h[2]=i*e[p+1]-r*e[p+3]+o*e[p+5]+a*e[p+7],h[3]=o*e[p+1]-i*e[p+3]+a*e[p+5]-r*e[p+7],d[0]=t*(e[p+0]+e[p+4]),d[3]=t*(e[p+0]-e[p+4]),d[1]=l[0]+l[3],d[2]=l[1]-l[2],c[0]=d[0]+d[1],c[1]=d[3]+d[2],c[2]=d[3]-d[2],c[3]=d[0]-d[1],e[p+0]=c[0]+h[0],e[p+1]=c[1]+h[1],e[p+2]=c[2]+h[2],e[p+3]=c[3]+h[3],e[p+4]=c[3]-h[3],e[p+5]=c[2]-h[2],e[p+6]=c[1]-h[1],e[p+7]=c[0]-h[0]}for(var m=0;m<8;++m)l[0]=n*e[16+m],l[1]=s*e[16+m],l[2]=n*e[48+m],l[3]=s*e[48+m],h[0]=r*e[8+m]+a*e[24+m]+i*e[40+m]+o*e[56+m],h[1]=a*e[8+m]-o*e[24+m]-r*e[40+m]-i*e[56+m],h[2]=i*e[8+m]-r*e[24+m]+o*e[40+m]+a*e[56+m],h[3]=o*e[8+m]-i*e[24+m]+a*e[40+m]-r*e[56+m],d[0]=t*(e[m]+e[32+m]),d[3]=t*(e[m]-e[32+m]),d[1]=l[0]+l[3],d[2]=l[1]-l[2],c[0]=d[0]+d[1],c[1]=d[3]+d[2],c[2]=d[3]-d[2],c[3]=d[0]-d[1],e[0+m]=c[0]+h[0],e[8+m]=c[1]+h[1],e[16+m]=c[2]+h[2],e[24+m]=c[3]+h[3],e[32+m]=c[3]-h[3],e[40+m]=c[2]-h[2],e[48+m]=c[1]-h[1],e[56+m]=c[0]-h[0]}function C(e){for(var t=0;t<64;++t){var r=e[0][t],n=e[1][t],a=e[2][t];e[0][t]=r+1.5747*a,e[1][t]=r-.1873*n-.4682*a,e[2][t]=r+1.8556*n}}function M(e,r,n){for(var a=0;a<64;++a)r[n+a]=ht.toHalfFloat((i=e[a])<=1?Math.sign(i)*Math.pow(Math.abs(i),2.2):Math.sign(i)*Math.pow(t,Math.abs(i)-1));var i}function T(e){return new DataView(e.array.buffer,e.offset.value,e.size)}function A(e){var t=e.viewer.buffer.slice(e.offset.value,e.offset.value+e.size),r=new Uint8Array(y(t)),n=new Uint8Array(r.length);return w(r),b(r,n),new DataView(n.buffer)}function P(e){var t=bo(e.array.slice(e.offset.value,e.offset.value+e.size)),r=new Uint8Array(t.length);return w(t),b(t,r),new DataView(r.buffer)}function R(e){for(var t=e.viewer,r={value:e.offset.value},n=new Uint16Array(e.width*e.scanlineBlockSize*(e.channels*e.type)),a=new Uint8Array(8192),i=0,s=new Array(e.channels),o=0;o<e.channels;o++)s[o]={},s[o].start=i,s[o].end=s[o].start,s[o].nx=e.width,s[o].ny=e.lines,s[o].size=e.type,i+=s[o].nx*s[o].ny*s[o].size;var l=H(t,r),h=H(t,r);if(h>=8192)throw new Error("Something is wrong with PIZ_COMPRESSION BITMAP_SIZE");if(l<=h)for(var d=0;d<h-l+1;d++)a[d+l]=U(t,r);var c=new Uint16Array(65536),u=function(e,t){for(var r=0,n=0;n<65536;++n)(0==n||e[n>>3]&1<<(7&n))&&(t[r++]=n);for(var a=r-1;r<65536;)t[r++]=0;return a}(a,c),p=D(t,r);v(e.array,t,r,p,n,i);for(var m=0;m<e.channels;++m)for(var f=s[m],w=0;w<s[m].size;++w)g(n,f.start+w,f.nx,f.size,f.ny,f.nx*f.size,u);!function(e,t,r){for(var n=0;n<r;++n)t[n]=e[t[n]]}(c,n,i);for(var b=0,y=new Uint8Array(n.buffer.byteLength),_=0;_<e.lines;_++)for(var x=0;x<e.channels;x++){var S=s[x],C=S.nx*S.size,M=new Uint8Array(n.buffer,2*S.end,2*C);y.set(M,b),b+=2*C,S.end+=C}return new DataView(y.buffer)}function E(e){for(var t=bo(e.array.slice(e.offset.value,e.offset.value+e.size)),r=e.lines*e.channels*e.width,n=1==e.type?new Uint16Array(r):new Uint32Array(r),a=0,i=0,s=new Array(4),o=0;o<e.lines;o++)for(var l=0;l<e.channels;l++){var h=0;switch(e.type){case 1:s[0]=a,s[1]=s[0]+e.width,a=s[1]+e.width;for(var d=0;d<e.width;++d)h+=t[s[0]++]<<8|t[s[1]++],n[i]=h,i++;break;case 2:s[0]=a,s[1]=s[0]+e.width,s[2]=s[1]+e.width,a=s[2]+e.width;for(var c=0;c<e.width;++c)h+=t[s[0]++]<<24|t[s[1]++]<<16|t[s[2]++]<<8,n[i]=h,i++}}return new DataView(n.buffer)}function I(e){var t=e.viewer,r={value:e.offset.value},n=new Uint8Array(e.width*e.lines*(e.channels*e.type*2)),a={version:F(t,r),unknownUncompressedSize:F(t,r),unknownCompressedSize:F(t,r),acCompressedSize:F(t,r),dcCompressedSize:F(t,r),rleCompressedSize:F(t,r),rleUncompressedSize:F(t,r),rleRawSize:F(t,r),totalAcUncompressedCount:F(t,r),totalDcUncompressedCount:F(t,r),acCompression:F(t,r)};if(a.version<2)throw new Error("EXRLoader.parse: "+X.compression+" version "+a.version+" is unsupported");for(var i=new Array,s=H(t,r)-2;s>0;){var o=k(t.buffer,r),l=U(t,r),h=l>>2&3,d=new Int8Array([(l>>4)-1])[0],c=U(t,r);i.push({name:o,index:d,type:c,compression:h}),s-=o.length+3}for(var u=X.channels,p=new Array(e.channels),m=0;m<e.channels;++m){var f=p[m]={},g=u[m];f.name=g.name,f.compression=0,f.decoded=!1,f.type=g.pixelType,f.pLinear=g.pLinear,f.width=e.width,f.height=e.lines}for(var w,b,T,A={idx:new Array(3)},R=0;R<e.channels;++R)for(var E=p[R],I=0;I<i.length;++I){var O=i[I];E.name==O.name&&(E.compression=O.compression,O.index>=0&&(A.idx[O.index]=R),E.offset=R)}if(a.acCompressedSize>0)switch(a.acCompression){case 0:w=new Uint16Array(a.totalAcUncompressedCount),v(e.array,t,r,a.acCompressedSize,w,a.totalAcUncompressedCount);break;case 1:var D=bo(e.array.slice(r.value,r.value+a.totalAcUncompressedCount));w=new Uint16Array(D.buffer),r.value+=a.totalAcUncompressedCount}if(a.dcCompressedSize>0){var L={array:e.array,offset:r,size:a.dcCompressedSize};b=new Uint16Array(P(L).buffer),r.value+=a.dcCompressedSize}a.rleRawSize>0&&(T=y(bo(e.array.slice(r.value,r.value+a.rleCompressedSize)).buffer),r.value+=a.rleCompressedSize);for(var B=0,N=new Array(p.length),j=0;j<N.length;++j)N[j]=new Array;for(var V=0;V<e.lines;++V)for(var G=0;G<p.length;++G)N[G].push(B),B+=p[G].width*e.type*2;!function(e,t,r,n,a,i){for(var s=new DataView(i.buffer),o=r[e.idx[0]].width,l=r[e.idx[0]].height,h=Math.floor(o/8),d=Math.ceil(o/8),c=Math.ceil(l/8),u=o-8*(d-1),p=l-8*(c-1),m={value:0},f=new Array(3),g=new Array(3),v=new Array(3),w=new Array(3),b=new Array(3),y=0;y<3;++y)b[y]=t[e.idx[y]],f[y]=y<1?0:f[y-1]+d*c,g[y]=new Float32Array(64),v[y]=new Uint16Array(64),w[y]=new Uint16Array(64*d);for(var T=0;T<c;++T){var A=8;T==c-1&&(A=p);for(var P=8,R=0;R<d;++R){R==d-1&&(P=u);for(var E=0;E<3;++E)v[E].fill(0),v[E][0]=a[f[E]++],_(m,n,v[E]),x(v[E],g[E]),S(g[E]);C(g);for(var I=0;I<3;++I)M(g[I],w[I],64*R)}for(var k=0,O=0;O<3;++O){for(var D=r[e.idx[O]].type,L=8*T;L<8*T+A;++L){k=b[O][L];for(var U=0;U<h;++U){var F=64*U+8*(7&L);s.setUint16(k+0*D,w[O][F+0],!0),s.setUint16(k+2*D,w[O][F+1],!0),s.setUint16(k+4*D,w[O][F+2],!0),s.setUint16(k+6*D,w[O][F+3],!0),s.setUint16(k+8*D,w[O][F+4],!0),s.setUint16(k+10*D,w[O][F+5],!0),s.setUint16(k+12*D,w[O][F+6],!0),s.setUint16(k+14*D,w[O][F+7],!0),k+=16*D}}if(h!=d)for(var B=8*T;B<8*T+A;++B)for(var N=b[O][B]+8*h*2*D,H=64*h+8*(7&B),j=0;j<P;++j)s.setUint16(N+2*j*D,w[O][H+j],!0)}}var V=new Uint16Array(o);s=new DataView(i.buffer);for(var G=0;G<3;++G){r[e.idx[G]].decoded=!0;var K=r[e.idx[G]].type;if(2==r[G].type)for(var W=0;W<l;++W){for(var X=b[G][W],q=0;q<o;++q)V[q]=s.getUint16(X+2*q*K,!0);for(var Q=0;Q<o;++Q)s.setFloat32(X+2*Q*K,z(V[Q]),!0)}}}(A,N,p,w,b,n);for(var K=0;K<p.length;++K){var W=p[K];if(!W.decoded)switch(W.compression){case 2:for(var q=0,Q=0,Y=0;Y<e.lines;++Y){for(var Z=N[K][q],J=0;J<W.width;++J){for(var $=0;$<2*W.type;++$)n[Z++]=T[Q+$*W.width*W.height];Q++}q++}break;case 1:default:throw new Error("EXRLoader.parse: unsupported channel compression")}}return new DataView(n.buffer)}function k(e,t){for(var r=new Uint8Array(e),n=0;0!=r[t.value+n];)n+=1;var a=(new TextDecoder).decode(r.slice(t.value,t.value+n));return t.value=t.value+n+1,a}function O(e,t){var r=e.getInt32(t.value,!0);return t.value=t.value+4,r}function D(e,t){var r=e.getUint32(t.value,!0);return t.value=t.value+4,r}function L(e,t){var r=e[t.value];return t.value=t.value+1,r}function U(e,t){var r=e.getUint8(t.value);return t.value=t.value+1,r}var F=function(e,t){var r;return r="getBigInt64"in DataView.prototype?Number(e.getBigInt64(t.value,!0)):e.getUint32(t.value+4,!0)+Number(e.getUint32(t.value,!0)<<32),t.value+=8,r};function B(e,t){var r=e.getFloat32(t.value,!0);return t.value+=4,r}function N(e,t){return ht.toHalfFloat(B(e,t))}function z(e){var t=(31744&e)>>10,r=1023&e;return(e>>15?-1:1)*(t?31===t?r?NaN:1/0:Math.pow(2,t-15)*(1+r/1024):r/1024*6103515625e-14)}function H(e,t){var r=e.getUint16(t.value,!0);return t.value+=2,r}function j(e,t){return z(H(e,t))}function V(e,t,r,n,a){return"string"===n||"stringvector"===n||"iccProfile"===n?function(e,t,r){var n=(new TextDecoder).decode(new Uint8Array(e).slice(t.value,t.value+r));return t.value=t.value+r,n}(t,r,a):"chlist"===n?function(e,t,r,n){for(var a=r.value,i=[];r.value<a+n-1;){var s=k(t,r),o=O(e,r),l=U(e,r);r.value+=3;var h=O(e,r),d=O(e,r);i.push({name:s,pixelType:o,pLinear:l,xSampling:h,ySampling:d})}return r.value+=1,i}(e,t,r,a):"chromaticities"===n?function(e,t){return{redX:B(e,t),redY:B(e,t),greenX:B(e,t),greenY:B(e,t),blueX:B(e,t),blueY:B(e,t),whiteX:B(e,t),whiteY:B(e,t)}}(e,r):"compression"===n?function(e,t){return["NO_COMPRESSION","RLE_COMPRESSION","ZIPS_COMPRESSION","ZIP_COMPRESSION","PIZ_COMPRESSION","PXR24_COMPRESSION","B44_COMPRESSION","B44A_COMPRESSION","DWAA_COMPRESSION","DWAB_COMPRESSION"][U(e,t)]}(e,r):"box2i"===n?function(e,t){return{xMin:D(e,t),yMin:D(e,t),xMax:D(e,t),yMax:D(e,t)}}(e,r):"lineOrder"===n?function(e,t){return["INCREASING_Y"][U(e,t)]}(e,r):"float"===n?B(e,r):"v2f"===n?function(e,t){return[B(e,t),B(e,t)]}(e,r):"v3f"===n?function(e,t){return[B(e,t),B(e,t),B(e,t)]}(e,r):"int"===n?O(e,r):"rational"===n?function(e,t){return[O(e,t),D(e,t)]}(e,r):"timecode"===n?function(e,t){return[D(e,t),D(e,t)]}(e,r):"preview"===n?(r.value+=a,"skipped"):void(r.value+=a)}for(var G=new DataView(e),K=new Uint8Array(e),W={value:0},X=function(e,t,r){var n={};if(20000630!=e.getUint32(0,!0))throw new Error("THREE.EXRLoader: provided file doesn't appear to be in OpenEXR format.");n.version=e.getUint8(4);var a=e.getUint8(5);n.spec={singleTile:!!(2&a),longName:!!(4&a),deepFormat:!!(8&a),multiPart:!!(16&a)},r.value=8;for(var i=!0;i;){var s=k(t,r);if(0==s)i=!1;else{var o=k(t,r),l=V(e,t,r,o,D(e,r));void 0===l?console.warn("EXRLoader.parse: skipped unknown header attribute type '".concat(o,"'.")):n[s]=l}}if(0!=(-5&a))throw console.error("EXRHeader:",n),new Error("THREE.EXRLoader: provided file is currently unsupported.");return n}(G,e,W),q=function(e,t,r,n,a){var i={size:0,viewer:t,array:r,offset:n,width:e.dataWindow.xMax-e.dataWindow.xMin+1,height:e.dataWindow.yMax-e.dataWindow.yMin+1,channels:e.channels.length,bytesPerLine:null,lines:null,inputSize:null,type:e.channels[0].pixelType,uncompress:null,getter:null,format:null,colorSpace:Ce};switch(e.compression){case"NO_COMPRESSION":i.lines=1,i.uncompress=T;break;case"RLE_COMPRESSION":i.lines=1,i.uncompress=A;break;case"ZIPS_COMPRESSION":i.lines=1,i.uncompress=P;break;case"ZIP_COMPRESSION":i.lines=16,i.uncompress=P;break;case"PIZ_COMPRESSION":i.lines=32,i.uncompress=R;break;case"PXR24_COMPRESSION":i.lines=16,i.uncompress=E;break;case"DWAA_COMPRESSION":i.lines=32,i.uncompress=I;break;case"DWAB_COMPRESSION":i.lines=256,i.uncompress=I;break;default:throw new Error("EXRLoader.parse: "+e.compression+" is unsupported")}if(i.scanlineBlockSize=i.lines,1==i.type)switch(a){case st:i.getter=j,i.inputSize=2;break;case at:i.getter=H,i.inputSize=2}else{if(2!=i.type)throw new Error("EXRLoader.parse: unsupported pixelType "+i.type+" for "+e.compression+".");switch(a){case st:i.getter=B,i.inputSize=4;break;case at:i.getter=N,i.inputSize=4}}i.blockCount=(e.dataWindow.yMax+1)/i.scanlineBlockSize;for(var s=0;s<i.blockCount;s++)F(t,n);i.outputChannels=3==i.channels?4:i.channels;var o=i.width*i.height*i.outputChannels;switch(a){case st:i.byteArray=new Float32Array(o),i.channels<i.outputChannels&&i.byteArray.fill(1,0,o);break;case at:i.byteArray=new Uint16Array(o),i.channels<i.outputChannels&&i.byteArray.fill(15360,0,o);break;default:console.error("THREE.EXRLoader: unsupported type: ",a)}return i.bytesPerLine=i.width*i.inputSize*i.channels,4==i.outputChannels?(i.format=Ae,i.colorSpace=Ce):(i.format=ot,i.colorSpace=lt),i}(X,G,K,W,this.type),Q={value:0},Y={R:0,G:1,B:2,A:3,Y:0},Z=0;Z<q.height/q.scanlineBlockSize;Z++){var J=D(G,W);q.size=D(G,W),q.lines=J+q.scanlineBlockSize>q.height?q.height-J:q.scanlineBlockSize;var $=q.size<q.lines*q.bytesPerLine?q.uncompress(q):T(q);W.value+=q.size;for(var ee=0;ee<q.scanlineBlockSize;ee++){var te=ee+Z*q.scanlineBlockSize;if(te>=q.height)break;for(var re=0;re<q.channels;re++)for(var ne=Y[X.channels[re].name],ae=0;ae<q.width;ae++){Q.value=(ee*(q.channels*q.width)+re*q.width+ae)*q.inputSize;var ie=(q.height-1-te)*(q.width*q.outputChannels)+ae*q.outputChannels+ne;q.byteArray[ie]=q.getter($,Q)}}}return{header:X,width:q.width,height:q.height,data:q.byteArray,format:q.format,colorSpace:q.colorSpace,type:this.type}}},{key:"setDataType",value:function(e){return this.type=e,this}},{key:"load",value:function(e,t,n,a){return xe(Se(r.prototype),"load",this).call(this,e,(function(e,r){e.colorSpace=r.colorSpace,e.minFilter=L,e.magFilter=L,e.generateMipmaps=!1,e.flipY=!1,t&&t(e,r)}),n,a)}}]),r}(it),xo=function(e){g(r,e);var t=v(r);function r(e){var n;return w(this,r),(n=t.call(this,e)).type=at,n}return b(r,[{key:"parse",value:function(e){var t=function(e,t){switch(e){case 1:console.error("THREE.RGBELoader Read Error: "+(t||""));break;case 2:console.error("THREE.RGBELoader Write Error: "+(t||""));break;case 3:console.error("THREE.RGBELoader Bad File Format: "+(t||""));break;default:case 4:console.error("THREE.RGBELoader: Error: "+(t||""))}return-1},r=function(e,t,r){t=t||1024;for(var n=e.pos,a=-1,i=0,s="",o=String.fromCharCode.apply(null,new Uint16Array(e.subarray(n,n+128)));0>(a=o.indexOf("\n"))&&i<t&&n<e.byteLength;)s+=o,i+=o.length,n+=128,o+=String.fromCharCode.apply(null,new Uint16Array(e.subarray(n,n+128)));return-1<a&&(!1!==r&&(e.pos+=i+a+1),s+o.slice(0,a))},n=function(e,t,r,n){var a=e[t+3],i=Math.pow(2,a-128)/255;r[n+0]=ht.toHalfFloat(Math.min(e[t+0]*i,65504)),r[n+1]=ht.toHalfFloat(Math.min(e[t+1]*i,65504)),r[n+2]=ht.toHalfFloat(Math.min(e[t+2]*i,65504)),r[n+3]=ht.toHalfFloat(1)},a=new Uint8Array(e);a.pos=0;var i,s,o,l,h,d,c=function(e){var n,a,i=/^\s*GAMMA\s*=\s*(\d+(\.\d+)?)\s*$/,s=/^\s*EXPOSURE\s*=\s*(\d+(\.\d+)?)\s*$/,o=/^\s*FORMAT=(\S+)\s*$/,l=/^\s*\-Y\s+(\d+)\s+\+X\s+(\d+)\s*$/,h={valid:0,string:"",comments:"",programtype:"RGBE",format:"",gamma:1,exposure:1,width:0,height:0};if(e.pos>=e.byteLength||!(n=r(e)))return t(1,"no header found");if(!(a=n.match(/^#\?(\S+)/)))return t(3,"bad initial token");for(h.valid|=1,h.programtype=a[1],h.string+=n+"\n";!1!==(n=r(e));)if(h.string+=n+"\n","#"!==n.charAt(0)){if((a=n.match(i))&&(h.gamma=parseFloat(a[1])),(a=n.match(s))&&(h.exposure=parseFloat(a[1])),(a=n.match(o))&&(h.valid|=2,h.format=a[1]),(a=n.match(l))&&(h.valid|=4,h.height=parseInt(a[1],10),h.width=parseInt(a[2],10)),2&h.valid&&4&h.valid)break}else h.comments+=n+"\n";return 2&h.valid?4&h.valid?h:t(3,"missing image size specifier"):t(3,"missing format specifier")}(a);if(-1!==c){var u=c.width,p=c.height,m=function(e,r,n){var a=r;if(a<8||a>32767||2!==e[0]||2!==e[1]||128&e[2])return new Uint8Array(e);if(a!==(e[2]<<8|e[3]))return t(3,"wrong scanline width");var i=new Uint8Array(4*r*n);if(!i.length)return t(4,"unable to allocate buffer space");for(var s=0,o=0,l=4*a,h=new Uint8Array(4),d=new Uint8Array(l),c=n;c>0&&o<e.byteLength;){if(o+4>e.byteLength)return t(1);if(h[0]=e[o++],h[1]=e[o++],h[2]=e[o++],h[3]=e[o++],2!=h[0]||2!=h[1]||(h[2]<<8|h[3])!=a)return t(3,"bad rgbe scanline format");for(var u=0,p=void 0;u<l&&o<e.byteLength;){var m=(p=e[o++])>128;if(m&&(p-=128),0===p||u+p>l)return t(3,"bad scanline data");if(m)for(var f=e[o++],g=0;g<p;g++)d[u++]=f;else d.set(e.subarray(o,o+p),u),u+=p,o+=p}for(var v=a,w=0;w<v;w++){var b=0;i[s]=d[w+b],b+=a,i[s+1]=d[w+b],b+=a,i[s+2]=d[w+b],b+=a,i[s+3]=d[w+b],s+=4}c--}return i}(a.subarray(a.pos),u,p);if(-1!==m){var f,g,v;switch(this.type){case st:v=m.length/4;for(var w=new Float32Array(4*v),b=0;b<v;b++)o=w,l=4*b,h=(i=m)[3+(s=4*b)],d=Math.pow(2,h-128)/255,o[l+0]=i[s+0]*d,o[l+1]=i[s+1]*d,o[l+2]=i[s+2]*d,o[l+3]=1;f=w,g=st;break;case at:v=m.length/4;for(var y=new Uint16Array(4*v),_=0;_<v;_++)n(m,4*_,y,4*_);f=y,g=at;break;default:console.error("THREE.RGBELoader: unsupported type: ",this.type)}return{width:u,height:p,data:f,header:c.string,gamma:c.gamma,exposure:c.exposure,type:g}}}return null}},{key:"setDataType",value:function(e){return this.type=e,this}},{key:"load",value:function(e,t,n,a){return xe(Se(r.prototype),"load",this).call(this,e,(function(e,r){switch(e.type){case st:case at:e.colorSpace=Ce,e.minFilter=L,e.magFilter=L,e.generateMipmaps=!1,e.flipY=!0}t&&t(e,r)}),n,a)}}]),r}(it);const So={uniforms:{tDiffuse:{value:null},colorTransform:{value:new P},colorBase:{value:new ct(0,0,0,0)},multiplyChannels:{value:0},uvTransform:{value:new ut}},vertexShader:"\n varying vec2 vUv;\n uniform mat3 uvTransform;\n \n void main() {\n vUv = (uvTransform * vec3(uv, 1.0)).xy;\n gl_Position = (projectionMatrix * modelViewMatrix * vec4(position, 1.0)).xyww;\n }",fragmentShader:"\n uniform sampler2D tDiffuse;\n uniform mat4 colorTransform;\n uniform vec4 colorBase;\n uniform float multiplyChannels;\n varying vec2 vUv;\n \n void main() {\n vec4 color = colorTransform * texture2D(tDiffuse, vUv) + colorBase;\n color.rgb = mix(color.rgb, vec3(color.r * color.g * color.b), multiplyChannels);\n gl_FragColor = color;\n }"},Co=new P,Mo=(new P).set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,0),To=(new P).set(0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0),Ao=(new P).set(1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1),Po=(new P).set(1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1),Ro=new ct(0,0,0,0),Eo=new ct(0,0,0,1),Io=new ut,ko=(new ut).set(1,0,0,0,-1,1,0,0,1);var Oo;!function(e){e[e.DEFAULT=0]="DEFAULT",e[e.ADDITIVE=1]="ADDITIVE"}(Oo||(Oo={}));class Do extends pt{constructor(e,t=Oo.ADDITIVE){const r=t===Oo.ADDITIVE?{blendSrc:gt,blendDst:vt,blendEquation:wt,blendSrcAlpha:bt,blendDstAlpha:vt,blendEquationAlpha:wt}:{};super({uniforms:mt.clone(So.uniforms),vertexShader:So.vertexShader,fragmentShader:So.fragmentShader,transparent:!0,depthTest:!1,depthWrite:!1,...r}),this.update(e)}update(e){return void 0!==(null==e?void 0:e.texture)&&(this.uniforms.tDiffuse.value=null==e?void 0:e.texture),void 0!==(null==e?void 0:e.colorTransform)&&(this.uniforms.colorTransform.value=null==e?void 0:e.colorTransform),void 0!==(null==e?void 0:e.colorBase)&&(this.uniforms.colorBase.value=null==e?void 0:e.colorBase),void 0!==(null==e?void 0:e.multiplyChannels)&&(this.uniforms.multiplyChannels.value=null==e?void 0:e.multiplyChannels),void 0!==(null==e?void 0:e.uvTransform)&&(this.uniforms.uvTransform.value=null==e?void 0:e.uvTransform),void 0!==(null==e?void 0:e.blending)&&(this.blending=null==e?void 0:e.blending),void 0!==(null==e?void 0:e.blendSrc)&&(this.blendSrc=null==e?void 0:e.blendSrc),void 0!==(null==e?void 0:e.blendDst)&&(this.blendDst=null==e?void 0:e.blendDst),void 0!==(null==e?void 0:e.blendEquation)&&(this.blendEquation=null==e?void 0:e.blendEquation),void 0!==(null==e?void 0:e.blendSrcAlpha)&&(this.blendSrcAlpha=null==e?void 0:e.blendSrcAlpha),void 0!==(null==e?void 0:e.blendDstAlpha)&&(this.blendDstAlpha=null==e?void 0:e.blendDstAlpha),void 0!==(null==e?void 0:e.blendEquationAlpha)&&(this.blendEquationAlpha=null==e?void 0:e.blendEquationAlpha),this}}const Lo={uniforms:{tDiffuse:{value:null},rangeMin:{value:new i(1/512,1/512)},rangeMax:{value:new i(1/512,1/512)}},vertexShader:"\n varying vec2 vUv;\n void main() {\n vUv = uv;\n gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\n }",fragmentShader:"\n uniform sampler2D tDiffuse;\n uniform vec2 rangeMin;\n uniform vec2 rangeMax;\n varying vec2 vUv;\n \n void main() {\n vec4 baseColor = texture2D(tDiffuse, vUv);\n vec2 blur = mix(rangeMax, rangeMin, baseColor.a);\n vec4 sum = vec4( 0.0 );\n sum += texture2D(tDiffuse, vUv - 1.0 * blur) * 0.051;\n sum += texture2D(tDiffuse, vUv - 0.75 * blur) * 0.0918;\n sum += texture2D(tDiffuse, vUv - 0.5 * blur) * 0.12245;\n sum += texture2D(tDiffuse, vUv - 0.25 * blur) * 0.1531;\n sum += baseColor * 0.1633;\n sum += texture2D(tDiffuse, vUv + 0.25 * blur) * 0.1531;\n sum += texture2D(tDiffuse, vUv + 0.5 * blur) * 0.12245;\n sum += texture2D(tDiffuse, vUv + 0.75 * blur) * 0.0918;\n sum += texture2D(tDiffuse, vUv + 1.0 * blur) * 0.051;\n gl_FragColor = sum;\n }"};new i(.1,.9),new i(.1,.9);class Uo extends pt{constructor(e){super({defines:Object.assign({},Uo.linearDepthShader.defines),uniforms:mt.clone(Uo.linearDepthShader.uniforms),vertexShader:Uo.linearDepthShader.vertexShader,fragmentShader:Uo.linearDepthShader.fragmentShader,blending:ft}),this.update(e)}update(e){if(void 0!==(null==e?void 0:e.depthTexture)&&(this.uniforms.tDepth.value=null==e?void 0:e.depthTexture),void 0!==(null==e?void 0:e.camera)){const t=(null==e?void 0:e.camera)||(null==e?void 0:e.camera);this.uniforms.cameraNear.value=t.near,this.uniforms.cameraFar.value=t.far}return void 0!==(null==e?void 0:e.depthFilter)&&(this.uniforms.depthFilter.value=null==e?void 0:e.depthFilter),this}}Uo.linearDepthShader={uniforms:{tDepth:{value:null},depthFilter:{value:new ct(1,0,0,0)},cameraNear:{value:.1},cameraFar:{value:1}},defines:{PERSPECTIVE_CAMERA:1,ALPHA_DEPTH:0},vertexShader:"varying vec2 vUv;\n void main() {\n vUv = uv;\n gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n }",fragmentShader:"uniform sampler2D tDepth;\n uniform vec4 depthFilter;\n uniform float cameraNear;\n uniform float cameraFar;\n varying vec2 vUv;\n \n #include <packing>\n \n float getLinearDepth(const in vec2 screenPosition) {\n float fragCoordZ = dot(texture2D(tDepth, screenPosition), depthFilter);\n #if PERSPECTIVE_CAMERA == 1\n float viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\n return viewZToOrthographicDepth(viewZ, cameraNear, cameraFar);\n #else\n return fragCoordZ;\n #endif\n }\n \n void main() {\n float depth = getLinearDepth(vUv);\n gl_FragColor = vec4(vec3(1.0 - depth), 1.0);\n }"};class Fo extends pt{constructor(e){var t;super({defines:Object.assign({...Fo.normalAndDepthShader.defines,FLOAT_BUFFER:(null==e?void 0:e.floatBufferType)?1:0,LINEAR_DEPTH:(null==e?void 0:e.linearDepth)?1:0}),uniforms:mt.clone(Fo.normalAndDepthShader.uniforms),vertexShader:Fo.normalAndDepthShader.vertexShader,fragmentShader:Fo.normalAndDepthShader.fragmentShader,blending:null!==(t=null==e?void 0:e.blending)&&void 0!==t?t:ft}),this.update(e)}update(e){if(void 0!==(null==e?void 0:e.camera)){const t=(null==e?void 0:e.camera)||(null==e?void 0:e.camera);this.uniforms.cameraNear.value=t.near,this.uniforms.cameraFar.value=t.far}return this}}Fo.normalAndDepthShader={uniforms:{cameraNear:{value:.1},cameraFar:{value:1}},defines:{FLOAT_BUFFER:0,LINEAR_DEPTH:0},vertexShader:"varying vec3 vNormal;\n#if LINEAR_DEPTH == 1\n varying float vZ; \n#endif\n\n void main() {\n vNormal = normalMatrix * normal;\n vec4 viewPosition = modelViewMatrix * vec4(position, 1.0);\n #if LINEAR_DEPTH == 1\n vZ = viewPosition.z; \n #endif\n gl_Position = projectionMatrix * viewPosition;\n }",fragmentShader:"varying vec3 vNormal;\n#if LINEAR_DEPTH == 1\n varying float vZ; \n uniform float cameraNear;\n uniform float cameraFar;\n#endif\n\n void main() {\n #if FLOAT_BUFFER == 1\n vec3 normal = normalize(vNormal);\n #else\n vec3 normal = normalize(vNormal) * 0.5 + 0.5;\n #endif\n #if LINEAR_DEPTH == 1\n float depth = (-vZ - cameraNear) / (cameraFar - cameraNear);\n #else\n float depth = gl_FragCoord.z;\n #endif\n gl_FragColor = vec4(normal, depth);\n }"};var Bo=function(){function e(){w(this,e),this.isPass=!0,this.enabled=!0,this.needsSwap=!0,this.clear=!1,this.renderToScreen=!1}return b(e,[{key:"setSize",value:function(){}},{key:"render",value:function(){console.error("THREE.Pass: .render() must be implemented in derived pass.")}},{key:"dispose",value:function(){}}]),e}(),No=new $(-1,1,1,-1,0,1),zo=new c;zo.setAttribute("position",new Le([-1,3,0,-1,-1,0,3,-1,0],3)),zo.setAttribute("uv",new Le([0,2,0,0,2,0],2));var Ho=function(){function e(t){w(this,e),this._mesh=new K(zo,t)}return b(e,[{key:"dispose",value:function(){this._mesh.geometry.dispose()}},{key:"render",value:function(e){e.render(this._mesh,No)}},{key:"material",get:function(){return this._mesh.material},set:function(e){this._mesh.material=e}}]),e}();new ue;class jo{constructor(){this.bounds=new be(new s(-1,-1,-1),new s(1,1,1)),this.size=new s(2,2,2),this.center=new s(0,0,0),this.maxSceneDistanceFromCenter=Math.sqrt(3),this.maxSceneDistanceFrom0=Math.sqrt(3)}copyFrom(e){this.bounds.copy(e.bounds),this.size.copy(e.size),this.center.copy(e.center),this.maxSceneDistanceFromCenter=e.maxSceneDistanceFromCenter,this.maxSceneDistanceFrom0=e.maxSceneDistanceFrom0}updateFromObject(e){e.updateMatrixWorld(),this.bounds.setFromObject(e),this.updateFromBox(this.bounds)}updateFromBox(e){this.bounds!==e&&this.bounds.copy(e),this.bounds.getSize(this.size),this.bounds.getCenter(this.center),this.maxSceneDistanceFromCenter=this.size.length()/2,this.maxSceneDistanceFrom0=new s(Math.max(Math.abs(this.bounds.min.x),Math.abs(this.bounds.max.x)),Math.max(Math.abs(this.bounds.min.y),Math.abs(this.bounds.max.y)),Math.max(Math.abs(this.bounds.min.z),Math.abs(this.bounds.max.z))).length()}updateCameraViewVolumeFromBounds(e){e.updateMatrixWorld();const t=this.bounds.clone().applyMatrix4(e.matrixWorldInverse);e instanceof $?((e,t)=>{e.left=t.min.x,e.right=t.max.x,e.bottom=t.min.y,e.top=t.max.y,e.near=Math.min(-t.min.z,-t.max.z),e.far=Math.max(-t.min.z,-t.max.z),e.updateProjectionMatrix()})(e,t):e instanceof Z&&((e,t)=>{const r=Math.min(-t.min.z,-t.max.z),n=Math.max(-t.min.z,-t.max.z);if(r<.001)return;const a=Math.max(Math.abs(t.min.x),Math.abs(t.max.x)),i=Math.max(Math.abs(t.min.y),Math.abs(t.max.y));e.aspect=a/i,e.fov=J.radToDeg(2*Math.atan2(i,r)),e.near=r,e.far=n,e.updateProjectionMatrix()})(e,t)}getNearAndFarForPerspectiveCamera(e,t=1){const r=e.clone().sub(this.center).length();return[Math.max(.01,r-this.maxSceneDistanceFromCenter-.01),r+this.maxSceneDistanceFromCenter*t+.01]}}class Vo{changed(e){var t,r;const n=!(null===(t=this.lastCameraProjection)||void 0===t?void 0:t.equals(e.projectionMatrix))||!(null===(r=this.lastCameraWorld)||void 0===r?void 0:r.equals(e.matrixWorld));return this.lastCameraProjection=e.projectionMatrix.clone(),this.lastCameraWorld=e.matrixWorld.clone(),n}}class Go{constructor(e,t,r){this._visibilityCache=new Map,this.background=r,this.hideLinesAndPoints=null!=e&&e,this.onIsObjectInvisible=t}updateVisibilityCache(e){this._visibilityCache.clear(),e&&(this.hideLinesAndPoints||this.onIsObjectInvisible)&&e.traverse(e=>{(this.hideLinesAndPoints&&(e.isPoints||e.isLine)||this.onIsObjectInvisible&&this.onIsObjectInvisible(e))&&this._visibilityCache.set(e,e.visible)})}render(e,t){this.updateVisibilityCache(e);const r=e.background;void 0!==this.background&&(e.background=this.background),this._visibilityCache.forEach((e,t)=>{t.visible=!1}),t(),this._visibilityCache.forEach((e,t)=>{t.visible=e}),void 0!==this.background&&(e.background=r)}}class Ko{constructor(){this.originalClearColor=new h,this.originalClearAlpha=0,this.originalAutoClear=!1,this.originalRenderTarget=null,this.screenSpaceQuad=new Ho(void 0)}renderWithOverrideMaterial(e,t,r,n,a,i,s){this.backup(e),this.prepareRenderer(e,a,i,s);const o=t.overrideMaterial;t.overrideMaterial=n,e.render(t,r),t.overrideMaterial=o,this.restore(e)}render(e,t,r,n,a,i){this.backup(e),this.prepareRenderer(e,n,a,i),e.render(t,r),this.restore(e)}renderScreenSpace(e,t,r,n,a){this.backup(e),this.prepareRenderer(e,r,n,a),this.screenSpaceQuad.material=t,this.screenSpaceQuad.render(e),this.restore(e)}prepareRenderer(e,t,r,n){e.setRenderTarget(t),e.autoClear=!1,null!=r&&(e.setClearColor(r),e.setClearAlpha(n||0),e.clear())}backup(e){e.getClearColor(this.originalClearColor),this.originalClearAlpha=e.getClearAlpha(),this.originalAutoClear=e.autoClear,this.originalRenderTarget=e.getRenderTarget()}restore(e){e.setClearColor(this.originalClearColor),e.setClearAlpha(this.originalClearAlpha),e.setRenderTarget(this.originalRenderTarget),e.autoClear=this.originalAutoClear}}class Wo{constructor(e,t){var r;this.renderPass=null!==(r=null==t?void 0:t.renderPass)&&void 0!==r?r:new Ko,this.blurMaterial=new pt(null!=e?e:Lo),this.blurMaterial.depthTest=!1}dispose(){this.blurMaterial.dispose()}render(e,t,r,n){this.blurMaterial.uniforms.tDiffuse.value=t[0].texture,this.blurMaterial.uniforms.rangeMin.value.x=r[0],this.blurMaterial.uniforms.rangeMin.value.y=0,this.blurMaterial.uniforms.rangeMax.value.x=n[0],this.blurMaterial.uniforms.rangeMax.value.y=0,this.renderPass.renderScreenSpace(e,this.blurMaterial,t[1]),this.blurMaterial.uniforms.tDiffuse.value=t[1].texture,this.blurMaterial.uniforms.rangeMin.value.x=0,this.blurMaterial.uniforms.rangeMin.value.y=r[1],this.blurMaterial.uniforms.rangeMax.value.x=0,this.blurMaterial.uniforms.rangeMax.value.y=n[1],this.renderPass.renderScreenSpace(e,this.blurMaterial,t[2])}}e("a6",(e,t)=>{e.traverse(e=>{if(e instanceof K){const r=e.material;r&&(r.envMapIntensity=t)}})});class Xo{get isFloatGBufferWithRgbNormalAlphaDepth(){return this.floatGBufferRgbNormalAlphaDepth}get gBufferTexture(){return this.depthNormalRenderTarget.texture}get depthBufferTexture(){return this.copyToSeparateDepthBuffer&&this.floatGBufferRgbNormalAlphaDepth?this.separateDeptRenderTarget.texture:this.depthNormalRenderTarget.depthTexture}get textureWithDepthValue(){return this.floatGBufferRgbNormalAlphaDepth?this.depthNormalRenderTarget.texture:this.depthNormalRenderTarget.depthTexture}get normalRenderMaterial(){var e;return this._normalRenderMaterial=null!==(e=this._normalRenderMaterial)&&void 0!==e?e:this.floatGBufferRgbNormalAlphaDepth?new Fo({blending:ft,floatBufferType:!0,linearDepth:!1}):new yt({blending:ft}),this._normalRenderMaterial}get depthNormalRenderTarget(){if(!this._depthNormalRenderTarget)if(this.floatGBufferRgbNormalAlphaDepth)this._depthNormalRenderTarget=new _t(this.width*this.parameters.depthNormalScale,this.height*this.parameters.depthNormalScale,{minFilter:this.targetMinificationTextureFilter,magFilter:this.targetMagnificationTextureFilter,type:st,samples:this.samples});else{const e=new xt(this.width*this.parameters.depthNormalScale,this.height*this.parameters.depthNormalScale);e.format=St,e.type=Ct,this._depthNormalRenderTarget=new _t(this.width*this.parameters.depthNormalScale,this.height*this.parameters.depthNormalScale,{minFilter:this.targetMinificationTextureFilter,magFilter:this.targetMagnificationTextureFilter,depthTexture:e})}return this._depthNormalRenderTarget}get separateDeptRenderTarget(){return this._separateDeptRenderTarget||(this._separateDeptRenderTarget=new _t(this.width*this.parameters.depthNormalScale,this.height*this.parameters.depthNormalScale,{minFilter:this.targetMinificationTextureFilter,magFilter:this.targetMagnificationTextureFilter,type:st,samples:0})),this._separateDeptRenderTarget}constructor(e){var t,r,n,a,i,s,o,l,h,d,c;this.floatGBufferRgbNormalAlphaDepth=!1,this.copyToSeparateDepthBuffer=!1,this.needsUpdate=!0,this.floatGBufferRgbNormalAlphaDepth=null!==(r=null===(t=null==e?void 0:e.capabilities)||void 0===t?void 0:t.isWebGL2)&&void 0!==r&&r,this.parameters={depthNormalScale:null!==(n=null==e?void 0:e.depthNormalScale)&&void 0!==n?n:1},this.targetMinificationTextureFilter=null!==(a=null==e?void 0:e.textureMinificationFilter)&&void 0!==a?a:ae,this.targetMagnificationTextureFilter=null!==(i=null==e?void 0:e.textureMagnificationFilter)&&void 0!==i?i:ae,this.width=null!==(s=null==e?void 0:e.width)&&void 0!==s?s:1024,this.height=null!==(o=null==e?void 0:e.height)&&void 0!==o?o:1024,this.samples=null!==(l=null==e?void 0:e.samples)&&void 0!==l?l:0,this.shared=null!==(h=null==e?void 0:e.shared)&&void 0!==h&&h,this.renderPass=null!==(d=null==e?void 0:e.renderPass)&&void 0!==d?d:new Ko,this.renderOverrideVisibility=null!==(c=null==e?void 0:e.renderOverrideVisibility)&&void 0!==c?c:new Go(!0,e=>{if(e.isMesh&&e.material){if(e.material.transparent&&e.material.opacity<.7||e.material.alphaTest>0)return!0;if(e.material instanceof T)return e.material.transmission>0}return!1})}dispose(){var e,t;null===(e=this._normalRenderMaterial)||void 0===e||e.dispose(),null===(t=this._depthNormalRenderTarget)||void 0===t||t.dispose()}setSize(e,t){var r;this.width=e,this.height=t,null===(r=this._depthNormalRenderTarget)||void 0===r||r.setSize(this.width*this.parameters.depthNormalScale,this.height*this.parameters.depthNormalScale)}render(e,t,r){if(this.shared&&!this.needsUpdate)return;this.needsUpdate=!1;const n=this.normalRenderMaterial;n instanceof Fo&&n.update({camera:r}),this.renderOverrideVisibility.render(t,()=>{this.renderPass.renderWithOverrideMaterial(e,t,r,n,this.depthNormalRenderTarget,7829503,1)}),this.floatGBufferRgbNormalAlphaDepth&&this.copyToSeparateDepthBuffer&&this.copyDepthToSeparateDepthTexture(e,this.depthNormalRenderTarget)}getCopyMaterial(e){var t;return null!==(t=this.copyMaterial)&&void 0!==t||(this.copyMaterial=new Do),this.copyMaterial.update(e)}copyDepthToSeparateDepthTexture(e,t){this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:t.texture,blending:ft,colorTransform:To,colorBase:Eo,multiplyChannels:0,uvTransform:Io}),this.separateDeptRenderTarget)}}class qo{constructor(e,t,r){var n;this.needsUpdate=!0,this.noNeedOfUpdateCount=0,this.blurScale=1,this.shadowScale=1,this.renderOverrideVisibility=new Go(!0,e=>e.isMesh&&!(e=>{var t;if(!e.isMesh)return!1;if(!e.castShadow&&!(null===(t=e.userData)||void 0===t?void 0:t.meshId))return!1;const r=e.material;return!r.transparent||r.opacity>.5})(e)||void 0!==e.name&&["Ground","Floor"].includes(e.name)),this.groundGroup=t,this.shadowMapSize=null!==(n=r.shadowMapSize)&&void 0!==n?n:1024,this.parameters=this.getDefaultParameters(r),this.groundShadowFar=this.parameters.cameraFar,this.renderer=e,this.renderTarget=new _t(this.shadowMapSize,this.shadowMapSize),this.renderTarget.texture.generateMipmaps=!1,this.renderTargetBlur=new _t(this.shadowMapSize,this.shadowMapSize),this.renderTargetBlur.texture.generateMipmaps=!1,this.shadowGroundPlane=new Qo(this.renderTarget.texture,this.parameters),this.groundGroup.add(this.shadowGroundPlane),this.groundContactCamera=new Yo,this.groundGroup.add(this.groundContactCamera),this.depthMaterial=new Tt,this.depthMaterial.userData.fadeoutBias={value:this.parameters.fadeoutBias},this.depthMaterial.userData.fadeoutFalloff={value:this.parameters.fadeoutFalloff},this.depthMaterial.onBeforeCompile=e=>{e.uniforms.fadeoutBias=this.depthMaterial.userData.fadeoutBias,e.uniforms.fadeoutFalloff=this.depthMaterial.userData.fadeoutFalloff,e.fragmentShader=`\n uniform float fadeoutBias;\n uniform float fadeoutFalloff;\n ${e.fragmentShader.replace("gl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );",Qo.alphaMap?"gl_FragColor = vec4(clamp(pow(1.0 + fadeoutBias - fragCoordZ, 1.0/(1.0-fadeoutFalloff)), 0.0, 1.0));":"gl_FragColor = vec4(vec3(0.0), clamp(pow(1.0 + fadeoutBias - fragCoordZ, 1.0/(1.0-fadeoutFalloff)), 0.0, 1.0));")}\n `},this.depthMaterial.side=j,this.depthMaterial.depthTest=!0,this.depthMaterial.depthWrite=!0,this.blurPass=new Wo(Lo,r),this.updatePlaneAndShadowCamera()}getDefaultParameters(e){return{enabled:!0,cameraHelper:!1,alwaysUpdate:!1,fadeIn:!1,blurMin:.001,blurMax:.1,fadeoutFalloff:.9,fadeoutBias:.03,opacity:.5,planeSize:10,cameraFar:3,hardLayers:null,softLayers:null,polygonOffset:2,excludeGroundObjects:!0,...e}}dispose(){this.renderTarget.dispose(),this.renderTargetBlur.dispose(),this.blurPass.dispose(),this.depthMaterial.dispose()}updateParameters(e){for(let t in e)this.parameters.hasOwnProperty(t)&&(this.parameters[t]=e[t]);void 0!==e.cameraFar&&(this.groundShadowFar=this.parameters.cameraFar)}applyParameters(){this.shadowGroundPlane.updateMaterial(this.parameters),this.groundContactCamera.updateCameraHelper(this.parameters.cameraHelper),this.groundContactCamera.far!==this.parameters.cameraFar&&this.updatePlaneAndShadowCamera();const e=this.parameters.fadeoutFalloff;this.depthMaterial.userData.fadeoutFalloff.value!==e&&(this.depthMaterial.userData.fadeoutFalloff.value=this.parameters.fadeoutFalloff);const t=this.parameters.fadeoutBias/this.groundContactCamera.far;this.depthMaterial.userData.fadeoutBias.value!==t&&(this.depthMaterial.userData.fadeoutBias.value=t),this.needsUpdate=!0}setScale(e,t){this.blurScale=e,this.shadowScale=null!=t?t:e,this.needsUpdate=!0}updateBounds(e,t){var r;this.groundShadowFar=this.parameters.cameraFar,this.groundShadowFar<e.size.z&&(this.groundShadowFar=1.01*e.size.z),this.groundGroup.position.set(e.center.x,null!=t?t:0,e.center.z),this.groundGroup.updateMatrixWorld();const n=Math.max(e.size.x,e.size.z);this.parameters.planeSize=n+2*Math.max(this.blurScale,null!==(r=this.shadowScale)&&void 0!==r?r:1,1),this.updatePlaneAndShadowCamera()}updatePlaneAndShadowCamera(){const e=this.parameters.planeSize;this.shadowGroundPlane.scale.x=e,this.shadowGroundPlane.scale.y=e,this.groundContactCamera.updateCameraFormPlaneSize(e,this.groundShadowFar),this.needsUpdate=!0}setGroundVisibility(e,t){this.shadowGroundPlane.updateVisibility(e)}render(e){if(this.groundContactCamera.updateCameraHelper(this.parameters.cameraHelper,e),this.shadowGroundPlane.visible=this.parameters.enabled,this.parameters.alwaysUpdate||this.needsUpdate)this.noNeedOfUpdateCount=0;else if(this.noNeedOfUpdateCount++,this.noNeedOfUpdateCount>=10)return;this.needsUpdate=!1,this.shadowGroundPlane.material.opacity=this.parameters.alwaysUpdate||!this.parameters.fadeIn?this.parameters.opacity:this.parameters.opacity*(this.noNeedOfUpdateCount+2)/12;const t=e.background;e.background=null,e.overrideMaterial=this.depthMaterial;const r=this.renderer.getClearAlpha();this.renderer.setClearAlpha(0),this.groundGroup.visible=!1,this.shadowGroundPlane.visible=!1,this.groundContactCamera.setCameraHelperVisibility(!1),0===this.noNeedOfUpdateCount?(this.renderGroundContact(e),this.renderBlur(e)):1===this.noNeedOfUpdateCount&&this.renderBlur(e),this.renderReduceBandingBlur(e),this.renderer.setRenderTarget(null),this.renderer.setClearAlpha(r),e.background=t,this.groundGroup.visible=!0,this.shadowGroundPlane.visible=this.parameters.enabled,this.groundContactCamera.setCameraHelperVisibility(this.parameters.cameraHelper)}renderGroundContact(e){this.renderer.setRenderTarget(this.renderTarget),this.renderer.clear();const t=this.renderer.autoClear;this.renderer.autoClear=!1,this.parameters.hardLayers&&(this.groundContactCamera.layers.mask=this.parameters.hardLayers.mask,this.groundContactCamera.updateCameraFarPlane(10),this.depthMaterial.userData.fadeoutBias.value=.99,this.renderer.render(e,this.groundContactCamera),this.groundContactCamera.updateCameraFarPlane(this.groundShadowFar),this.depthMaterial.userData.fadeoutBias.value=this.parameters.fadeoutBias/this.groundShadowFar),this.groundContactCamera.layers.enableAll(),this.parameters.softLayers&&(this.groundContactCamera.layers.mask=this.parameters.softLayers.mask),this.parameters.excludeGroundObjects?this.renderOverrideVisibility.render(e,()=>{this.renderer.render(e,this.groundContactCamera)}):this.renderer.render(e,this.groundContactCamera),this.renderer.autoClear=t}renderBlur(e){e.overrideMaterial=null,this.renderBlurPass(this.blurScale*this.parameters.blurMin/this.parameters.planeSize,this.blurScale*this.parameters.blurMax/this.parameters.planeSize)}renderReduceBandingBlur(e){e.overrideMaterial=null;const t=.01*this.blurScale/this.parameters.planeSize;this.renderBlurPass(t,t)}renderBlurPass(e,t){this.blurPass.render(this.renderer,[this.renderTarget,this.renderTargetBlur,this.renderTarget],[e,e],[t,t])}}qo.addTestMesh=!1;class Qo extends K{constructor(e,t){const r=new C({transparent:!0,depthWrite:!1});Qo.alphaMap&&r.color.set(0),r.polygonOffset=!0,super(new Mt(1,1,10,10),r),this.name="GroundContactShadowPlane",this.userData.isFloor=!0,this.renderOrder=1,this.receiveShadow=!1,this.layers.disableAll(),t&&this.updateMaterial(t),this.setShadowMap(e)}setVisibility(e){this.visible=e,this.visible?this.layers.enableAll():this.layers.disableAll()}setDepthWrite(e){const t=this.material;t.depthWrite=e,t.transparent=!e,t.needsUpdate=!0,this.setVisibility(e)}setReceiveShadow(e){this.receiveShadow=e,this.setVisibility(e)}setShadowMap(e){const t=this.material;t.map=e,Qo.alphaMap&&(t.alphaMap=e),t.needsUpdate=!0}updateMaterial(e){const t=this.material;t.opacity!==e.opacity&&(t.opacity=e.opacity),t.polygonOffsetFactor!==e.polygonOffset&&(t.polygonOffset=!0,t.polygonOffsetFactor=e.polygonOffset,t.polygonOffsetUnits=e.polygonOffset)}updateVisibility(e){e?this.layers.enableAll():this.layers.disableAll()}}Qo.alphaMap=!1;class Yo extends ${constructor(){super(-1,1,-1,1,-1,1),this.rotation.x=Math.PI}updateCameraFormPlaneSize(e,t){var r;this.left=-e/2,this.right=e/2,this.top=-e/2,this.bottom=e/2,this.near=0,this.far=t,this.updateProjectionMatrix(),null===(r=this.cameraHelper)||void 0===r||r.update()}updateCameraFarPlane(e){var t;this.far=e,this.updateProjectionMatrix(),null===(t=this.cameraHelper)||void 0===t||t.update()}updateCameraHelper(e,t){var r,n,a;e?(this.cameraHelper=null!==(r=this.cameraHelper)&&void 0!==r?r:new At(this),this.cameraHelper.visible=!0,null==t||t.add(this.cameraHelper)):(null===(n=this.cameraHelper)||void 0===n?void 0:n.parent)&&(null===(a=this.cameraHelper)||void 0===a||a.removeFromParent())}setCameraHelperVisibility(e){this.cameraHelper&&(this.cameraHelper.visible=e)}}var Zo={name:"CopyShader",uniforms:{tDiffuse:{value:null},opacity:{value:1}},vertexShader:"\n\n\t\tvarying vec2 vUv;\n\n\t\tvoid main() {\n\n\t\t\tvUv = uv;\n\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\n\t\t}",fragmentShader:"\n\n\t\tuniform float opacity;\n\n\t\tuniform sampler2D tDiffuse;\n\n\t\tvarying vec2 vUv;\n\n\t\tvoid main() {\n\n\t\t\tvec4 texel = texture2D( tDiffuse, vUv );\n\t\t\tgl_FragColor = opacity * texel;\n\n\n\t\t}"},Jo={uniforms:{tDiffuse:{value:null},resolution:{value:new i(1/1024,1/512)}},vertexShader:"\n\n\t\tvarying vec2 vUv;\n\n\t\tvoid main() {\n\n\t\t\tvUv = uv;\n\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\n\t\t}",fragmentShader:"\n\tprecision highp float;\n\n\tuniform sampler2D tDiffuse;\n\n\tuniform vec2 resolution;\n\n\tvarying vec2 vUv;\n\n\t// FXAA 3.11 implementation by NVIDIA, ported to WebGL by Agost Biro (biro@archilogic.com)\n\n\t//----------------------------------------------------------------------------------\n\t// File: es3-keplerFXAAassetsshaders/FXAA_DefaultES.frag\n\t// SDK Version: v3.00\n\t// Email: gameworks@nvidia.com\n\t// Site: http://developer.nvidia.com/\n\t//\n\t// Copyright (c) 2014-2015, NVIDIA CORPORATION. All rights reserved.\n\t//\n\t// Redistribution and use in source and binary forms, with or without\n\t// modification, are permitted provided that the following conditions\n\t// are met:\n\t// * Redistributions of source code must retain the above copyright\n\t// notice, this list of conditions and the following disclaimer.\n\t// * Redistributions in binary form must reproduce the above copyright\n\t// notice, this list of conditions and the following disclaimer in the\n\t// documentation and/or other materials provided with the distribution.\n\t// * Neither the name of NVIDIA CORPORATION nor the names of its\n\t// contributors may be used to endorse or promote products derived\n\t// from this software without specific prior written permission.\n\t//\n\t// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ''AS IS'' AND ANY\n\t// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n\t// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR\n\t// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR\n\t// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,\n\t// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,\n\t// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\n\t// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY\n\t// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n\t// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n\t// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n\t//\n\t//----------------------------------------------------------------------------------\n\n\t#ifndef FXAA_DISCARD\n\t\t\t//\n\t\t\t// Only valid for PC OpenGL currently.\n\t\t\t// Probably will not work when FXAA_GREEN_AS_LUMA = 1.\n\t\t\t//\n\t\t\t// 1 = Use discard on pixels which don't need AA.\n\t\t\t// For APIs which enable concurrent TEX+ROP from same surface.\n\t\t\t// 0 = Return unchanged color on pixels which don't need AA.\n\t\t\t//\n\t\t\t#define FXAA_DISCARD 0\n\t#endif\n\n\t/*--------------------------------------------------------------------------*/\n\t#define FxaaTexTop(t, p) texture2D(t, p, -100.0)\n\t#define FxaaTexOff(t, p, o, r) texture2D(t, p + (o * r), -100.0)\n\t/*--------------------------------------------------------------------------*/\n\n\t#define NUM_SAMPLES 5\n\n\t// assumes colors have premultipliedAlpha, so that the calculated color contrast is scaled by alpha\n\tfloat contrast( vec4 a, vec4 b ) {\n\t\t\tvec4 diff = abs( a - b );\n\t\t\treturn max( max( max( diff.r, diff.g ), diff.b ), diff.a );\n\t}\n\n\t/*============================================================================\n\n\t\t\t\t\t\t\t\t\tFXAA3 QUALITY - PC\n\n\t============================================================================*/\n\n\t/*--------------------------------------------------------------------------*/\n\tvec4 FxaaPixelShader(\n\t\t\tvec2 posM,\n\t\t\tsampler2D tex,\n\t\t\tvec2 fxaaQualityRcpFrame,\n\t\t\tfloat fxaaQualityEdgeThreshold,\n\t\t\tfloat fxaaQualityinvEdgeThreshold\n\t) {\n\t\t\tvec4 rgbaM = FxaaTexTop(tex, posM);\n\t\t\tvec4 rgbaS = FxaaTexOff(tex, posM, vec2( 0.0, 1.0), fxaaQualityRcpFrame.xy);\n\t\t\tvec4 rgbaE = FxaaTexOff(tex, posM, vec2( 1.0, 0.0), fxaaQualityRcpFrame.xy);\n\t\t\tvec4 rgbaN = FxaaTexOff(tex, posM, vec2( 0.0,-1.0), fxaaQualityRcpFrame.xy);\n\t\t\tvec4 rgbaW = FxaaTexOff(tex, posM, vec2(-1.0, 0.0), fxaaQualityRcpFrame.xy);\n\t\t\t// . S .\n\t\t\t// W M E\n\t\t\t// . N .\n\n\t\t\tbool earlyExit = max( max( max(\n\t\t\t\t\tcontrast( rgbaM, rgbaN ),\n\t\t\t\t\tcontrast( rgbaM, rgbaS ) ),\n\t\t\t\t\tcontrast( rgbaM, rgbaE ) ),\n\t\t\t\t\tcontrast( rgbaM, rgbaW ) )\n\t\t\t\t\t< fxaaQualityEdgeThreshold;\n\t\t\t// . 0 .\n\t\t\t// 0 0 0\n\t\t\t// . 0 .\n\n\t\t\t#if (FXAA_DISCARD == 1)\n\t\t\t\t\tif(earlyExit) FxaaDiscard;\n\t\t\t#else\n\t\t\t\t\tif(earlyExit) return rgbaM;\n\t\t\t#endif\n\n\t\t\tfloat contrastN = contrast( rgbaM, rgbaN );\n\t\t\tfloat contrastS = contrast( rgbaM, rgbaS );\n\t\t\tfloat contrastE = contrast( rgbaM, rgbaE );\n\t\t\tfloat contrastW = contrast( rgbaM, rgbaW );\n\n\t\t\tfloat relativeVContrast = ( contrastN + contrastS ) - ( contrastE + contrastW );\n\t\t\trelativeVContrast *= fxaaQualityinvEdgeThreshold;\n\n\t\t\tbool horzSpan = relativeVContrast > 0.;\n\t\t\t// . 1 .\n\t\t\t// 0 0 0\n\t\t\t// . 1 .\n\n\t\t\t// 45 deg edge detection and corners of objects, aka V/H contrast is too similar\n\t\t\tif( abs( relativeVContrast ) < .3 ) {\n\t\t\t\t\t// locate the edge\n\t\t\t\t\tvec2 dirToEdge;\n\t\t\t\t\tdirToEdge.x = contrastE > contrastW ? 1. : -1.;\n\t\t\t\t\tdirToEdge.y = contrastS > contrastN ? 1. : -1.;\n\t\t\t\t\t// . 2 . . 1 .\n\t\t\t\t\t// 1 0 2 ~= 0 0 1\n\t\t\t\t\t// . 1 . . 0 .\n\n\t\t\t\t\t// tap 2 pixels and see which ones are \"outside\" the edge, to\n\t\t\t\t\t// determine if the edge is vertical or horizontal\n\n\t\t\t\t\tvec4 rgbaAlongH = FxaaTexOff(tex, posM, vec2( dirToEdge.x, -dirToEdge.y ), fxaaQualityRcpFrame.xy);\n\t\t\t\t\tfloat matchAlongH = contrast( rgbaM, rgbaAlongH );\n\t\t\t\t\t// . 1 .\n\t\t\t\t\t// 0 0 1\n\t\t\t\t\t// . 0 H\n\n\t\t\t\t\tvec4 rgbaAlongV = FxaaTexOff(tex, posM, vec2( -dirToEdge.x, dirToEdge.y ), fxaaQualityRcpFrame.xy);\n\t\t\t\t\tfloat matchAlongV = contrast( rgbaM, rgbaAlongV );\n\t\t\t\t\t// V 1 .\n\t\t\t\t\t// 0 0 1\n\t\t\t\t\t// . 0 .\n\n\t\t\t\t\trelativeVContrast = matchAlongV - matchAlongH;\n\t\t\t\t\trelativeVContrast *= fxaaQualityinvEdgeThreshold;\n\n\t\t\t\t\tif( abs( relativeVContrast ) < .3 ) { // 45 deg edge\n\t\t\t\t\t\t\t// 1 1 .\n\t\t\t\t\t\t\t// 0 0 1\n\t\t\t\t\t\t\t// . 0 1\n\n\t\t\t\t\t\t\t// do a simple blur\n\t\t\t\t\t\t\treturn mix(\n\t\t\t\t\t\t\t\t\trgbaM,\n\t\t\t\t\t\t\t\t\t(rgbaN + rgbaS + rgbaE + rgbaW) * .25,\n\t\t\t\t\t\t\t\t\t.4\n\t\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\thorzSpan = relativeVContrast > 0.;\n\t\t\t}\n\n\t\t\tif(!horzSpan) rgbaN = rgbaW;\n\t\t\tif(!horzSpan) rgbaS = rgbaE;\n\t\t\t// . 0 . 1\n\t\t\t// 1 0 1 -> 0\n\t\t\t// . 0 . 1\n\n\t\t\tbool pairN = contrast( rgbaM, rgbaN ) > contrast( rgbaM, rgbaS );\n\t\t\tif(!pairN) rgbaN = rgbaS;\n\n\t\t\tvec2 offNP;\n\t\t\toffNP.x = (!horzSpan) ? 0.0 : fxaaQualityRcpFrame.x;\n\t\t\toffNP.y = ( horzSpan) ? 0.0 : fxaaQualityRcpFrame.y;\n\n\t\t\tbool doneN = false;\n\t\t\tbool doneP = false;\n\n\t\t\tfloat nDist = 0.;\n\t\t\tfloat pDist = 0.;\n\n\t\t\tvec2 posN = posM;\n\t\t\tvec2 posP = posM;\n\n\t\t\tint iterationsUsed = 0;\n\t\t\tint iterationsUsedN = 0;\n\t\t\tint iterationsUsedP = 0;\n\t\t\tfor( int i = 0; i < NUM_SAMPLES; i++ ) {\n\t\t\t\t\titerationsUsed = i;\n\n\t\t\t\t\tfloat increment = float(i + 1);\n\n\t\t\t\t\tif(!doneN) {\n\t\t\t\t\t\t\tnDist += increment;\n\t\t\t\t\t\t\tposN = posM + offNP * nDist;\n\t\t\t\t\t\t\tvec4 rgbaEndN = FxaaTexTop(tex, posN.xy);\n\t\t\t\t\t\t\tdoneN = contrast( rgbaEndN, rgbaM ) > contrast( rgbaEndN, rgbaN );\n\t\t\t\t\t\t\titerationsUsedN = i;\n\t\t\t\t\t}\n\n\t\t\t\t\tif(!doneP) {\n\t\t\t\t\t\t\tpDist += increment;\n\t\t\t\t\t\t\tposP = posM - offNP * pDist;\n\t\t\t\t\t\t\tvec4 rgbaEndP = FxaaTexTop(tex, posP.xy);\n\t\t\t\t\t\t\tdoneP = contrast( rgbaEndP, rgbaM ) > contrast( rgbaEndP, rgbaN );\n\t\t\t\t\t\t\titerationsUsedP = i;\n\t\t\t\t\t}\n\n\t\t\t\t\tif(doneN || doneP) break;\n\t\t\t}\n\n\n\t\t\tif ( !doneP && !doneN ) return rgbaM; // failed to find end of edge\n\n\t\t\tfloat dist = min(\n\t\t\t\t\tdoneN ? float( iterationsUsedN ) / float( NUM_SAMPLES - 1 ) : 1.,\n\t\t\t\t\tdoneP ? float( iterationsUsedP ) / float( NUM_SAMPLES - 1 ) : 1.\n\t\t\t);\n\n\t\t\t// hacky way of reduces blurriness of mostly diagonal edges\n\t\t\t// but reduces AA quality\n\t\t\tdist = pow(dist, .5);\n\n\t\t\tdist = 1. - dist;\n\n\t\t\treturn mix(\n\t\t\t\t\trgbaM,\n\t\t\t\t\trgbaN,\n\t\t\t\t\tdist * .5\n\t\t\t);\n\t}\n\n\tvoid main() {\n\t\t\tconst float edgeDetectionQuality = .2;\n\t\t\tconst float invEdgeDetectionQuality = 1. / edgeDetectionQuality;\n\n\t\t\tgl_FragColor = FxaaPixelShader(\n\t\t\t\t\tvUv,\n\t\t\t\t\ttDiffuse,\n\t\t\t\t\tresolution,\n\t\t\t\t\tedgeDetectionQuality, // [0,1] contrast needed, otherwise early discard\n\t\t\t\t\tinvEdgeDetectionQuality\n\t\t\t);\n\n\t}\n\t"};class $o extends Bo{constructor(e,t,r,n,a){var s;super(),this.patternTexture=null,this.gBufferRenderTarget=null==a?void 0:a.gBufferRenderTarget,this.renderScene=t,this.renderCamera=r,this.selectedObjects=void 0!==n?n:[],this.visibleEdgeColor=new h(1,1,1),this.hiddenEdgeColor=new h(.1,.04,.02),this.edgeGlow=0,this.usePatternTexture=!1,this.edgeThickness=1,this.edgeStrength=3,this.downSampleRatio=(null==a?void 0:a.downSampleRatio)||2,this.pulsePeriod=0,this.edgeDetectionFxaa=(null==a?void 0:a.edgeDetectionFxaa)||!1,this._visibilityCache=new Map,this.resolution=void 0!==e?new i(e.x,e.y):new i(256,256);const o=Math.round(this.resolution.x/this.downSampleRatio),l=Math.round(this.resolution.y/this.downSampleRatio);this.renderTargetMaskBuffer=new _t(this.resolution.x,this.resolution.y),this.renderTargetMaskBuffer.texture.name="OutlinePass.mask",this.renderTargetMaskBuffer.texture.generateMipmaps=!1,this.gBufferRenderTarget||(this.depthMaterial=new Tt,this.depthMaterial.side=j,this.depthMaterial.depthPacking=Pt,this.depthMaterial.blending=ft),this.prepareMaskMaterial=this.getPrepareMaskMaterial(null===(s=this.gBufferRenderTarget)||void 0===s?void 0:s.isFloatGBufferWithRgbNormalAlphaDepth),this.prepareMaskMaterial.side=j,this.prepareMaskMaterial.fragmentShader=function(e,t){const r=t.isPerspectiveCamera?"perspective":"orthographic";return e.replace(/DEPTH_TO_VIEW_Z/g,r+"DepthToViewZ")}(this.prepareMaskMaterial.fragmentShader,this.renderCamera),this.gBufferRenderTarget||(this.renderTargetDepthBuffer=new _t(this.resolution.x,this.resolution.y),this.renderTargetDepthBuffer.texture.name="OutlinePass.depth",this.renderTargetDepthBuffer.texture.generateMipmaps=!1),this.edgeDetectionFxaa&&(this.fxaaRenderMaterial=new pt(Jo),this.fxaaRenderMaterial.uniforms.tDiffuse.value=this.renderTargetMaskBuffer.texture,this.fxaaRenderMaterial.uniforms.resolution.value.set(1/this.resolution.x,1/this.resolution.y),this.renderTargetFxaaBuffer=new _t(this.resolution.x,this.resolution.y),this.renderTargetFxaaBuffer.texture.name="OutlinePass.fxaa",this.renderTargetFxaaBuffer.texture.generateMipmaps=!1),this.renderTargetMaskDownSampleBuffer=new _t(o,l),this.renderTargetMaskDownSampleBuffer.texture.name="OutlinePass.depthDownSample",this.renderTargetMaskDownSampleBuffer.texture.generateMipmaps=!1,this.renderTargetBlurBuffer1=new _t(o,l),this.renderTargetBlurBuffer1.texture.name="OutlinePass.blur1",this.renderTargetBlurBuffer1.texture.generateMipmaps=!1,this.renderTargetBlurBuffer2=new _t(Math.round(o/2),Math.round(l/2)),this.renderTargetBlurBuffer2.texture.name="OutlinePass.blur2",this.renderTargetBlurBuffer2.texture.generateMipmaps=!1,this.edgeDetectionMaterial=this.getEdgeDetectionMaterial(),this.renderTargetEdgeBuffer1=new _t(o,l),this.renderTargetEdgeBuffer1.texture.name="OutlinePass.edge1",this.renderTargetEdgeBuffer1.texture.generateMipmaps=!1,this.renderTargetEdgeBuffer2=new _t(Math.round(o/2),Math.round(l/2)),this.renderTargetEdgeBuffer2.texture.name="OutlinePass.edge2",this.renderTargetEdgeBuffer2.texture.generateMipmaps=!1,this.separableBlurMaterial1=this.getSeperableBlurMaterial(4),this.separableBlurMaterial1.uniforms.texSize.value.set(o,l),this.separableBlurMaterial1.uniforms.kernelRadius.value=1,this.separableBlurMaterial2=this.getSeperableBlurMaterial(4),this.separableBlurMaterial2.uniforms.texSize.value.set(Math.round(o/2),Math.round(l/2)),this.separableBlurMaterial2.uniforms.kernelRadius.value=4,this.overlayMaterial=this.getOverlayMaterial();const d=Zo;this.copyUniforms=mt.clone(d.uniforms),this.copyUniforms.opacity.value=1,this.materialCopy=new pt({uniforms:this.copyUniforms,vertexShader:d.vertexShader,fragmentShader:d.fragmentShader,blending:ft,depthTest:!1,depthWrite:!1,transparent:!0}),this.enabled=!0,this.needsSwap=!1,this._oldClearColor=new h,this.oldClearAlpha=1,this.fsQuad=new Ho(void 0),this.tempPulseColor1=new h,this.tempPulseColor2=new h,this.textureMatrix=new P}dispose(){var e,t,r,n;this.renderTargetMaskBuffer.dispose(),null===(e=this.renderTargetFxaaBuffer)||void 0===e||e.dispose(),null===(t=this.renderTargetDepthBuffer)||void 0===t||t.dispose(),this.renderTargetMaskDownSampleBuffer.dispose(),this.renderTargetBlurBuffer1.dispose(),this.renderTargetBlurBuffer2.dispose(),this.renderTargetEdgeBuffer1.dispose(),this.renderTargetEdgeBuffer2.dispose(),null===(r=this.depthMaterial)||void 0===r||r.dispose(),this.prepareMaskMaterial.dispose(),null===(n=this.fxaaRenderMaterial)||void 0===n||n.dispose(),this.edgeDetectionMaterial.dispose(),this.separableBlurMaterial1.dispose(),this.separableBlurMaterial2.dispose(),this.overlayMaterial.dispose(),this.materialCopy.dispose(),this.fsQuad.dispose()}setSize(e,t){var r,n,a;this.renderTargetMaskBuffer.setSize(e,t),null===(r=this.renderTargetDepthBuffer)||void 0===r||r.setSize(e,t);let i=Math.round(e/this.downSampleRatio),s=Math.round(t/this.downSampleRatio);this.renderTargetMaskDownSampleBuffer.setSize(i,s),this.renderTargetBlurBuffer1.setSize(i,s),this.renderTargetEdgeBuffer1.setSize(i,s),this.separableBlurMaterial1.uniforms.texSize.value.set(i,s),i=Math.round(i/2),s=Math.round(s/2),this.renderTargetBlurBuffer2.setSize(i,s),this.renderTargetEdgeBuffer2.setSize(i,s),this.separableBlurMaterial2.uniforms.texSize.value.set(i,s),null===(n=this.fxaaRenderMaterial)||void 0===n||n.uniforms.resolution.value.set(1/this.resolution.x,1/this.resolution.y),null===(a=this.renderTargetFxaaBuffer)||void 0===a||a.setSize(e,t)}changeVisibilityOfSelectedObjects(e){const t=this._visibilityCache;function r(r){r.isMesh&&(!0===e?r.visible=t.get(r):(t.set(r,r.visible),r.visible=e))}this.selectedObjects.forEach(e=>e.traverse(r))}changeVisibilityOfNonSelectedObjects(e){const t=this._visibilityCache,r=[];function n(e){e.isMesh&&r.push(e)}this.selectedObjects.forEach(e=>e.traverse(n)),this.renderScene.traverse((function(n){if(n.isMesh||n.isSprite){if(!1===r.some(e=>e.id===n.id)){const r=n.visible;!1!==e&&!0!==t.get(n)||(n.visible=e),t.set(n,r)}}else(n.isPoints||n.isLine)&&(!0===e?n.visible=t.get(n):(t.set(n,n.visible),n.visible=e))}))}updateTextureMatrix(){this.textureMatrix.set(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1),this.textureMatrix.multiply(this.renderCamera.projectionMatrix),this.textureMatrix.multiply(this.renderCamera.matrixWorldInverse)}render(e,t,r,n,a){var i,s;if(this.selectedObjects.length>0){null===(i=this.gBufferRenderTarget)||void 0===i||i.render(e,this.renderScene,this.renderCamera),e.getClearColor(this._oldClearColor),this.oldClearAlpha=e.getClearAlpha();const t=e.autoClear;e.autoClear=!1,a&&e.state.buffers.stencil.setTest(!1),e.setClearColor(16777215,1),this.changeVisibilityOfSelectedObjects(!1);const n=this.renderScene.background;this.renderScene.background=null,this.renderTargetDepthBuffer&&this.depthMaterial&&(this.renderScene.overrideMaterial=this.depthMaterial,e.setRenderTarget(this.renderTargetDepthBuffer),e.clear(),e.render(this.renderScene,this.renderCamera)),this.changeVisibilityOfSelectedObjects(!0),this._visibilityCache.clear(),this.updateTextureMatrix(),this.changeVisibilityOfNonSelectedObjects(!1),this.renderScene.overrideMaterial=this.prepareMaskMaterial,this.prepareMaskMaterial.uniforms.cameraNearFar.value.set(this.renderCamera.near,this.renderCamera.far),this.gBufferRenderTarget?this.prepareMaskMaterial.uniforms.depthTexture.value=this.gBufferRenderTarget.textureWithDepthValue:this.prepareMaskMaterial.uniforms.depthTexture.value=null===(s=this.renderTargetDepthBuffer)||void 0===s?void 0:s.texture,this.prepareMaskMaterial.uniforms.textureMatrix.value=this.textureMatrix,e.setRenderTarget(this.renderTargetMaskBuffer),e.clear(),e.render(this.renderScene,this.renderCamera),this.renderScene.overrideMaterial=null,this.changeVisibilityOfNonSelectedObjects(!0),this._visibilityCache.clear(),this.renderScene.background=n;let o=this.renderTargetMaskBuffer;if(this.edgeDetectionFxaa&&this.fxaaRenderMaterial&&this.renderTargetFxaaBuffer&&(this.fxaaRenderMaterial.uniforms.tDiffuse.value=this.renderTargetMaskBuffer.texture,this.fsQuad.material=this.fxaaRenderMaterial,e.setRenderTarget(this.renderTargetFxaaBuffer),e.clear(),this.fsQuad.render(e),o=this.renderTargetFxaaBuffer),this.fsQuad.material=this.materialCopy,this.copyUniforms.tDiffuse.value=o.texture,e.setRenderTarget(this.renderTargetMaskDownSampleBuffer),e.clear(),this.fsQuad.render(e),this.tempPulseColor1.copy(this.visibleEdgeColor),this.tempPulseColor2.copy(this.hiddenEdgeColor),this.pulsePeriod>0){const e=.625+.75*Math.cos(.01*performance.now()/this.pulsePeriod)/2;this.tempPulseColor1.multiplyScalar(e),this.tempPulseColor2.multiplyScalar(e)}this.fsQuad.material=this.edgeDetectionMaterial,this.edgeDetectionMaterial.uniforms.maskTexture.value=this.renderTargetMaskDownSampleBuffer.texture,this.edgeDetectionMaterial.uniforms.texSize.value.set(this.renderTargetMaskDownSampleBuffer.width,this.renderTargetMaskDownSampleBuffer.height),this.edgeDetectionMaterial.uniforms.visibleEdgeColor.value=this.tempPulseColor1,this.edgeDetectionMaterial.uniforms.hiddenEdgeColor.value=this.tempPulseColor2,e.setRenderTarget(this.renderTargetEdgeBuffer1),e.clear(),this.fsQuad.render(e),this.fsQuad.material=this.separableBlurMaterial1,this.separableBlurMaterial1.uniforms.colorTexture.value=this.renderTargetEdgeBuffer1.texture,this.separableBlurMaterial1.uniforms.direction.value=$o.BlurDirectionX,this.separableBlurMaterial1.uniforms.kernelRadius.value=this.edgeThickness,e.setRenderTarget(this.renderTargetBlurBuffer1),e.clear(),this.fsQuad.render(e),this.separableBlurMaterial1.uniforms.colorTexture.value=this.renderTargetBlurBuffer1.texture,this.separableBlurMaterial1.uniforms.direction.value=$o.BlurDirectionY,e.setRenderTarget(this.renderTargetEdgeBuffer1),e.clear(),this.fsQuad.render(e),this.fsQuad.material=this.separableBlurMaterial2,this.separableBlurMaterial2.uniforms.colorTexture.value=this.renderTargetEdgeBuffer1.texture,this.separableBlurMaterial2.uniforms.direction.value=$o.BlurDirectionX,e.setRenderTarget(this.renderTargetBlurBuffer2),e.clear(),this.fsQuad.render(e),this.separableBlurMaterial2.uniforms.colorTexture.value=this.renderTargetBlurBuffer2.texture,this.separableBlurMaterial2.uniforms.direction.value=$o.BlurDirectionY,e.setRenderTarget(this.renderTargetEdgeBuffer2),e.clear(),this.fsQuad.render(e),this.fsQuad.material=this.overlayMaterial,this.overlayMaterial.uniforms.maskTexture.value=o.texture,this.overlayMaterial.uniforms.edgeTexture1.value=this.renderTargetEdgeBuffer1.texture,this.overlayMaterial.uniforms.edgeTexture2.value=this.renderTargetEdgeBuffer2.texture,this.overlayMaterial.uniforms.patternTexture.value=this.patternTexture,this.overlayMaterial.uniforms.edgeStrength.value=this.edgeStrength,this.overlayMaterial.uniforms.edgeGlow.value=this.edgeGlow,this.overlayMaterial.uniforms.usePatternTexture.value=this.usePatternTexture,a&&e.state.buffers.stencil.setTest(!0),e.setRenderTarget(r),this.fsQuad.render(e),e.setClearColor(this._oldClearColor,this.oldClearAlpha),e.autoClear=t}this.renderToScreen&&r&&(this.fsQuad.material=this.materialCopy,this.copyUniforms.tDiffuse.value=r.texture,e.setRenderTarget(null),this.fsQuad.render(e))}getPrepareMaskMaterial(e){return new pt({uniforms:{depthTexture:{value:null},cameraNearFar:{value:new i(.5,.5)},textureMatrix:{value:null}},defines:{FLOAT_ALPHA_DEPTH:e?1:0},vertexShader:"#include <morphtarget_pars_vertex>\n\t\t\t\t#include <skinning_pars_vertex>\n\n\t\t\t\tvarying vec4 projTexCoord;\n\t\t\t\tvarying vec4 vPosition;\n\t\t\t\tuniform mat4 textureMatrix;\n\n\t\t\t\tvoid main() {\n\n\t\t\t\t\t#include <skinbase_vertex>\n\t\t\t\t\t#include <begin_vertex>\n\t\t\t\t\t#include <morphtarget_vertex>\n\t\t\t\t\t#include <skinning_vertex>\n\t\t\t\t\t#include <project_vertex>\n\n\t\t\t\t\tvPosition = mvPosition;\n\n\t\t\t\t\tvec4 worldPosition = vec4( transformed, 1.0 );\n\n\t\t\t\t\t#ifdef USE_INSTANCING\n\n\t\t\t\t\t\tworldPosition = instanceMatrix * worldPosition;\n\n\t\t\t\t\t#endif\n\t\t\t\t\t\n\t\t\t\t\tworldPosition = modelMatrix * worldPosition;\n\n\t\t\t\t\tprojTexCoord = textureMatrix * worldPosition;\n\n\t\t\t\t}",fragmentShader:"#include <packing>\n\t\t\t\tvarying vec4 vPosition;\n\t\t\t\tvarying vec4 projTexCoord;\n\t\t\t\tuniform sampler2D depthTexture;\n\t\t\t\tuniform vec2 cameraNearFar;\n\n\t\t\t\tvoid main() {\n\n #if FLOAT_ALPHA_DEPTH == 1\n\t\t\t\t\t float depth = texture2DProj( depthTexture, projTexCoord ).w;\n #else\n float depth = unpackRGBAToDepth(texture2DProj( depthTexture, projTexCoord ));\n #endif\n\t\t\t\t\tfloat viewZ = - DEPTH_TO_VIEW_Z( depth, cameraNearFar.x, cameraNearFar.y );\n\t\t\t\t\tfloat depthTest = (-vPosition.z > viewZ) ? 1.0 : 0.0;\n\t\t\t\t\tgl_FragColor = vec4(0.0, depthTest, 1.0, 1.0);\n\n\t\t\t\t}"})}getEdgeDetectionMaterial(){return new pt({uniforms:{maskTexture:{value:null},texSize:{value:new i(.5,.5)},visibleEdgeColor:{value:new s(1,1,1)},hiddenEdgeColor:{value:new s(1,1,1)}},vertexShader:"varying vec2 vUv;\n\n\t\t\t\tvoid main() {\n\t\t\t\t\tvUv = uv;\n\t\t\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\t\t\t\t}",fragmentShader:"varying vec2 vUv;\n\n\t\t\t\tuniform sampler2D maskTexture;\n\t\t\t\tuniform vec2 texSize;\n\t\t\t\tuniform vec3 visibleEdgeColor;\n\t\t\t\tuniform vec3 hiddenEdgeColor;\n\n\t\t\t\tvoid main() {\n\t\t\t\t\tvec2 invSize = 1.0 / texSize;\n\t\t\t\t\tvec4 uvOffset = vec4(1.0, 0.0, 0.0, 1.0) * vec4(invSize, invSize);\n\t\t\t\t\tvec4 c1 = texture2D( maskTexture, vUv + uvOffset.xy);\n\t\t\t\t\tvec4 c2 = texture2D( maskTexture, vUv - uvOffset.xy);\n\t\t\t\t\tvec4 c3 = texture2D( maskTexture, vUv + uvOffset.yw);\n\t\t\t\t\tvec4 c4 = texture2D( maskTexture, vUv - uvOffset.yw);\n\t\t\t\t\tfloat diff1 = (c1.r - c2.r)*0.5;\n\t\t\t\t\tfloat diff2 = (c3.r - c4.r)*0.5;\n\t\t\t\t\tfloat d = length( vec2(diff1, diff2) );\n\t\t\t\t\tfloat a1 = min(c1.g, c2.g);\n\t\t\t\t\tfloat a2 = min(c3.g, c4.g);\n\t\t\t\t\tfloat visibilityFactor = min(a1, a2);\n\t\t\t\t\tvec3 edgeColor = 1.0 - visibilityFactor > 0.001 ? visibleEdgeColor : hiddenEdgeColor;\n\t\t\t\t\tgl_FragColor = vec4(edgeColor, 1.0) * vec4(d);\n\t\t\t\t}"})}getSeperableBlurMaterial(e){return new pt({defines:{MAX_RADIUS:e},uniforms:{colorTexture:{value:null},texSize:{value:new i(.5,.5)},direction:{value:new i(.5,.5)},kernelRadius:{value:1}},vertexShader:"varying vec2 vUv;\n\n\t\t\t\tvoid main() {\n\t\t\t\t\tvUv = uv;\n\t\t\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\t\t\t\t}",fragmentShader:"#include <common>\n\t\t\t\tvarying vec2 vUv;\n\t\t\t\tuniform sampler2D colorTexture;\n\t\t\t\tuniform vec2 texSize;\n\t\t\t\tuniform vec2 direction;\n\t\t\t\tuniform float kernelRadius;\n\n\t\t\t\tfloat gaussianPdf(in float x, in float sigma) {\n\t\t\t\t\treturn 0.39894 * exp( -0.5 * x * x/( sigma * sigma))/sigma;\n\t\t\t\t}\n\n\t\t\t\tvoid main() {\n\t\t\t\t\tvec2 invSize = 1.0 / texSize;\n\t\t\t\t\tfloat sigma = kernelRadius/2.0;\n\t\t\t\t\tfloat weightSum = gaussianPdf(0.0, sigma);\n\t\t\t\t\tvec4 diffuseSum = texture2D( colorTexture, vUv) * weightSum;\n\t\t\t\t\tvec2 delta = direction * invSize * kernelRadius/float(MAX_RADIUS);\n\t\t\t\t\tvec2 uvOffset = delta;\n\t\t\t\t\tfor( int i = 1; i <= MAX_RADIUS; i ++ ) {\n\t\t\t\t\t\tfloat x = kernelRadius * float(i) / float(MAX_RADIUS);\n\t\t\t\t\t\tfloat w = gaussianPdf(x, sigma);\n\t\t\t\t\t\tvec4 sample1 = texture2D( colorTexture, vUv + uvOffset);\n\t\t\t\t\t\tvec4 sample2 = texture2D( colorTexture, vUv - uvOffset);\n\t\t\t\t\t\tdiffuseSum += ((sample1 + sample2) * w);\n\t\t\t\t\t\tweightSum += (2.0 * w);\n\t\t\t\t\t\tuvOffset += delta;\n\t\t\t\t\t}\n\t\t\t\t\tgl_FragColor = diffuseSum/weightSum;\n\t\t\t\t}"})}getOverlayMaterial(){return new pt({uniforms:{maskTexture:{value:null},edgeTexture1:{value:null},edgeTexture2:{value:null},patternTexture:{value:null},edgeStrength:{value:1},edgeGlow:{value:1},usePatternTexture:{value:0}},vertexShader:"varying vec2 vUv;\n\n\t\t\t\tvoid main() {\n\t\t\t\t\tvUv = uv;\n\t\t\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\t\t\t\t}",fragmentShader:"varying vec2 vUv;\n\n\t\t\t\tuniform sampler2D maskTexture;\n\t\t\t\tuniform sampler2D edgeTexture1;\n\t\t\t\tuniform sampler2D edgeTexture2;\n\t\t\t\tuniform sampler2D patternTexture;\n\t\t\t\tuniform float edgeStrength;\n\t\t\t\tuniform float edgeGlow;\n\t\t\t\tuniform bool usePatternTexture;\n\n\t\t\t\tvoid main() {\n\t\t\t\t\tvec4 edgeValue1 = texture2D(edgeTexture1, vUv);\n\t\t\t\t\tvec4 edgeValue2 = texture2D(edgeTexture2, vUv);\n\t\t\t\t\tvec4 maskColor = texture2D(maskTexture, vUv);\n\t\t\t\t\tvec4 patternColor = texture2D(patternTexture, 6.0 * vUv);\n\t\t\t\t\tfloat visibilityFactor = 1.0 - maskColor.g > 0.0 ? 1.0 : 0.5;\n\t\t\t\t\tvec4 edgeValue = edgeValue1 + edgeValue2 * edgeGlow;\n\t\t\t\t\tvec4 finalColor = edgeStrength * maskColor.r * edgeValue;\n\t\t\t\t\tif(usePatternTexture)\n\t\t\t\t\t\tfinalColor += + visibilityFactor * (1.0 - maskColor.r) * (1.0 - patternColor.r);\n\t\t\t\t\tgl_FragColor = finalColor;\n }",blending:Rt,depthTest:!1,depthWrite:!1,transparent:!0})}}$o.BlurDirectionX=new i(1,0),$o.BlurDirectionY=new i(0,1);class el{get isOutlinePassActivated(){return this.outlinePassActivated}constructor(e,t,r,n){this.width=0,this.height=0,this.effectComposer=null,this.outlinePass=null,this.outlinePassActivated=!1,this.effectComposer=e,this.gBufferRenderTarget=null==n?void 0:n.gBufferRenderTarget,this.width=t,this.height=r,this.parameters={enabled:!0,edgeStrength:2,edgeGlow:1,edgeThickness:2,pulsePeriod:0,usePatternTexture:!1,visibleEdgeColor:16777215,hiddenEdgeColor:16777215,...n}}dispose(){var e;null===(e=this.outlinePass)||void 0===e||e.dispose()}setSize(e,t){var r;this.width=e,this.height=t,null===(r=this.outlinePass)||void 0===r||r.setSize(e,t)}updateParameters(e){for(let t in e)this.parameters.hasOwnProperty(t)&&(this.parameters[t]=e[t])}applyParameters(){this.outlinePass&&(this.outlinePass.edgeStrength=this.parameters.edgeStrength,this.outlinePass.edgeGlow=this.parameters.edgeGlow,this.outlinePass.edgeThickness=this.parameters.edgeThickness,this.outlinePass.pulsePeriod=this.parameters.pulsePeriod,this.outlinePass.usePatternTexture=this.parameters.usePatternTexture,this.outlinePass.visibleEdgeColor.set(this.parameters.visibleEdgeColor),this.outlinePass.hiddenEdgeColor.set(this.parameters.hiddenEdgeColor))}activateOutline(e,t){var r;if(!this.parameters.enabled)return void this.deactivateOutline();const n=(null===(r=this.outlinePass)||void 0===r?void 0:r.renderCamera)&&t.isPerspectiveCamera!==this.outlinePass.renderCamera.isPerspectiveCamera;this.outlinePass&&(this.outlinePass.renderScene=e,this.outlinePass.renderCamera=t),!n&&this.outlinePassActivated||(!n&&this.outlinePass||(this.outlinePass=new $o(new i(this.width,this.height),e,t,[],{downSampleRatio:2,edgeDetectionFxaa:!0,gBufferRenderTarget:this.gBufferRenderTarget})),this.applyParameters(),this.effectComposer&&this.effectComposer.addPass(this.outlinePass),this.outlinePassActivated=!0)}deactivateOutline(){this.outlinePassActivated&&(this.outlinePass&&this.effectComposer&&this.effectComposer.removePass(this.outlinePass),this.outlinePassActivated=!1)}updateOutline(e,t,r){r.length>0?(this.activateOutline(e,t),this.outlinePass&&(this.outlinePass.selectedObjects=r)):this.deactivateOutline()}}var tl,rl=function(e){g(r,e);var t=v(r);function r(e,n){var a;w(this,r);var i=new c;i.setAttribute("position",new Le([1,1,0,-1,1,0,-1,-1,0,1,-1,0,1,1,0],3)),i.computeBoundingSphere();var s=new z({fog:!1});(a=t.call(this,i,s)).light=e,a.color=n,a.type="RectAreaLightHelper";var o=new c;return o.setAttribute("position",new Le([1,1,0,-1,1,0,-1,-1,0,1,1,0,-1,-1,0,1,-1,0],3)),o.computeBoundingSphere(),a.add(new K(o,new C({side:Et,fog:!1}))),a}return b(r,[{key:"updateMatrixWorld",value:function(){if(this.scale.set(.5*this.light.width,.5*this.light.height,1),void 0!==this.color)this.material.color.set(this.color),this.children[0].material.color.set(this.color);else{this.material.color.copy(this.light.color).multiplyScalar(this.light.intensity);var e=this.material.color,t=Math.max(e.r,e.g,e.b);t>1&&e.multiplyScalar(1/t),this.children[0].material.color.copy(this.material.color)}this.matrixWorld.extractRotation(this.light.matrixWorld).scale(this.scale).copyPosition(this.light.matrixWorld),this.children[0].matrixWorld.copy(this.matrixWorld)}},{key:"dispose",value:function(){this.geometry.dispose(),this.material.dispose(),this.children[0].geometry.dispose(),this.children[0].material.dispose()}}]),r}(X);!function(e){e[e.DirectionalLightShadow=0]="DirectionalLightShadow",e[e.SpotLightShadow=1]="SpotLightShadow"}(tl||(tl={}));const nl={alwaysUpdate:!1,enableShadowMap:!0,layers:null,shadowLightSourceType:tl.DirectionalLightShadow,maximumNumberOfLightSources:-1,fadeOutDistance:.3,fadeOutBlur:60},al="\n#ifdef DYNAMIC_SHADOW_RADIUS\nfloat shadowBase = 0.0;\nfloat shadowScale = 1.0;\nif (shadowFadeOut.x > 0.0) {\n float shadowDepth = unpackRGBAToDepth(texture2D(shadowMap, shadowCoord.xy));\n float delta = shadowDepth - shadowCoord.z;\n //if (delta < 0.0) {\n vec3 worldPos = (viewToWorldMatrix * vec4(-vViewPosition, 1.0)).xyz;\n vec3 boxDistanceVec = max(boxMin - worldPos, worldPos - boxMax);\n float boxDistance = length(max(vec3(0.0), boxDistanceVec));\n shadowBase = max(smoothstep(0.0, shadowFadeOut.x, boxDistance), smoothstep(max(shadowDepth, 0.5), shadowFadeOut.x * 0.5 + 0.5, shadowCoord.z));\n shadowBase = clamp(shadowBase, 0.0, 1.0);\n shadowScale = 1.0 - shadowBase;\n shadowRadius += shadowFadeOut.y * shadowBase;\n //}\n}\n#endif\n",il="\n#ifdef DYNAMIC_SHADOW_RADIUS\n shadow = shadowBase + shadowScale * (\n#else\n shadow = (\n#endif\n";class sl{get shadowTexture(){return this.shadowRenderTarget.texture}constructor(e,t){var r,n;this.needsUpdate=!1,this.shadowTypeNeedsUpdate=!0,this.shadowConfiguration=new hl,this.shadowLightSources=[],this.shadowScale=1,this.cameraUpdate=new Vo,this.viewportSize=new i(e.x,e.y),this.samples=null!==(r=null==t?void 0:t.samples)&&void 0!==r?r:0,this.shadowMapSize=null!==(n=null==t?void 0:t.shadowMapSize)&&void 0!==n?n:1024,this.parameters=this.getScreenSpaceShadowMapParameters(t),this.castShadow=this.parameters.enableShadowMap,this.shadowMapPassOverrideMaterials=new ll(this.parameters);const a=this.samples;this.shadowRenderTarget=new _t(this.viewportSize.x,this.viewportSize.y,{samples:a,format:ot})}getScreenSpaceShadowMapParameters(e){return{...nl,...e}}dispose(){this.shadowLightSources.forEach(e=>e.dispose()),this.shadowMapPassOverrideMaterials.dispose(),this.shadowRenderTarget.dispose()}updateParameters(e){for(let t in e)this.parameters.hasOwnProperty(t)&&(this.parameters[t]=e[t])}updateBounds(e,t){const r=this.shadowScale;this.shadowScale=t,Math.abs(r-this.shadowScale)>1e-5&&(this.shadowTypeNeedsUpdate=!0),this.shadowLightSources.forEach(t=>t.updateBounds(e)),this.shadowMapPassOverrideMaterials.setBoundingBox(e.bounds)}getShadowLightSources(){return this.shadowLightSources.map(e=>e.getShadowLight())}findShadowLightSource(e){var t;return null===(t=this.shadowLightSources.find(t=>t.getOriginalLight()===e))||void 0===t?void 0:t.getShadowLight()}addRectAreaLight(e,t){const r=new cl(e,{shadowMapSize:this.shadowMapSize,shadowLightSourceType:this.parameters.shadowLightSourceType});this.shadowLightSources.push(r),r.addTo(t),r.updatePositionAndTarget(),this.needsUpdate=!0}updateRectAreaLights(e,t){this.shadowLightSources=this.shadowLightSources.filter(r=>{if(r instanceof cl){const t=r.getRectAreaLight();if(e.includes(t))return r.updatePositionAndTarget(),!0}return r.removeFrom(t),r.dispose(),!1}),e.forEach(e=>{this.shadowLightSources.find(t=>t instanceof cl&&t.getRectAreaLight()===e)||this.addRectAreaLight(e,t)}),this.needsUpdate=!0,this.shadowTypeNeedsUpdate=!0}createShadowFromLightSources(e,t){this.shadowLightSources=this.shadowLightSources.filter(t=>{t.removeFrom(e),t.dispose()});const r=1/(t.length>0?Math.max(...t.map(e=>e.maxIntensity)):1);this.addShadowFromLightSources(t,r),this.shadowLightSources.forEach(t=>{t.addTo(e),t.updatePositionAndTarget()}),this.needsUpdate=!0,this.shadowTypeNeedsUpdate=!0}addShadowFromLightSources(e,t){e.forEach(e=>{const r=e.maxIntensity*t;if(r>=.1&&e.position.z>=0){const t=new s(e.position.x,e.position.z,e.position.y).multiplyScalar(7),n=new ul(t,r,{shadowMapSize:this.shadowMapSize,shadowLightSourceType:this.parameters.shadowLightSourceType});this.shadowLightSources.push(n)}})}setSize(e,t){this.viewportSize=new i(e,t),this.shadowRenderTarget.setSize(this.viewportSize.x,this.viewportSize.y)}updatePositionAndTarget(){this.shadowLightSources.forEach(e=>e.updatePositionAndTarget())}renderShadowMap(e,t,r){if(!(this.needsUpdate||this.parameters.alwaysUpdate||this.cameraUpdate.changed(r)))return;this.needsUpdate=!1,this.shadowTypeNeedsUpdate&&(this.shadowTypeNeedsUpdate=!1,this.needsUpdate=!0,this.updateShadowType(e));const n=t.background,a=t.environment,i=r.layers.mask;t.environment=null,t.background=null,this.parameters.layers&&(r.layers.mask=this.parameters.layers.mask),this.renderSimpleShadowMapFromShadowLightSources(e,t,r),r.layers.mask=i,t.environment=a,t.background=n}renderSimpleShadowMapFromShadowLightSources(e,t,r){this.shadowMapPassOverrideMaterials.setShadowFadeOut(this.parameters.fadeOutDistance*this.shadowScale,this.parameters.fadeOutBlur);const n=this.getSortedShadowLightSources();this.setShadowLightSourcesIntensity(n),this.shadowMapPassOverrideMaterials.render(e,t,r,this.shadowRenderTarget),this.shadowLightSources.forEach(e=>e.finishRenderShadow())}getSortedShadowLightSources(){let e=[];return this.shadowLightSources.forEach(t=>e.push(...t.prepareRenderShadow())),e.sort((e,t)=>e.light.castShadow&&!t.light.castShadow?-1:!e.light.castShadow&&t.light.castShadow?1:t.intensity-e.intensity),e}setShadowLightSourcesIntensity(e){var t;let r=0;for(let t=0;t<e.length;t++){const n=e[t];(this.parameters.maximumNumberOfLightSources<0||t<this.parameters.maximumNumberOfLightSources)&&(r+=n.intensity)}for(let n=0;n<e.length;n++){const a=e[n];this.parameters.maximumNumberOfLightSources<0||n<this.parameters.maximumNumberOfLightSources?(a.light.visible=!0,a.light.intensity=a.intensity/r,(t=a.light).castShadow&&(t.castShadow=this.castShadow)):(a.light.visible=!1,a.light.intensity=0,a.light.castShadow=!1)}}updateShadowType(e){e.shadowMap.type=this.shadowConfiguration.currentConfiguration.type;const t=this.parameters.enableShadowMap&&this.shadowConfiguration.currentConfiguration.castShadow;e.shadowMap.enabled=t,e.shadowMap.needsUpdate=!0,this.castShadow=t&&this.shadowConfiguration.currentConfiguration.castShadow,this.shadowLightSources.forEach(e=>e.updateShadowType(this.shadowConfiguration.currentConfiguration,this.shadowScale))}switchType(e){return!!this.shadowConfiguration.switchType(e)&&(this.needsUpdate=!0,this.shadowTypeNeedsUpdate=!0,!0)}}var ol;!function(e){e[e.Default=0]="Default",e[e.Unlit=1]="Unlit",e[e.Emissive=2]="Emissive",e[e.Shadow=3]="Shadow"}(ol||(ol={}));class ll{constructor(e){var t,r;this.boxMin=new s(1,1,1),this.boxMax=new s(-1,-1,-1),this.viewToWorldMatrix=new P,this.shadowFadeOut=new i(null!==(t=null==e?void 0:e.fadeOutTo)&&void 0!==t?t:.5,null!==(r=null==e?void 0:e.fadeOutBlur)&&void 0!==r?r:60),this.renderPass=new Ko,this.shadowObjectMaterial=this.createShadowMaterial(ol.Default),this.unlitMaterial=this.createShadowMaterial(ol.Unlit),this.emissiveMaterial=this.createShadowMaterial(ol.Emissive),this.receiveShadowMaterial=this.createShadowMaterial(ol.Shadow)}dispose(){this.shadowObjectMaterial.dispose(),this.unlitMaterial.dispose(),this.emissiveMaterial.dispose(),this.receiveShadowMaterial.dispose()}setShadowFadeOut(e,t){this.shadowFadeOut.set(e,t)}setBoundingBox(e){this.boxMin.copy(e.min),this.boxMax.copy(e.max)}createShadowMaterial(e){let t;return t=e===ol.Emissive||e===ol.Unlit?new C({color:16777215,side:j}):e===ol.Shadow?new It({side:j}):ll.useModifiedMaterial?this.createCustomerShadowMaterial():new kt({color:16777215,shininess:0,polygonOffsetFactor:0,polygonOffsetUnits:0,side:j}),t}createCustomerShadowMaterial(){if(!ll.shaderChunkChanged){ll.shaderChunkChanged=!0;let e=Bt.shadowmap_pars_fragment;e=e.replace("float getShadow(","\n#ifdef DYNAMIC_SHADOW_RADIUS\n uniform vec2 shadowFadeOut;\n uniform vec3 boxMin;\n uniform vec3 boxMax;\n uniform mat4 viewToWorldMatrix;\n#endif\nfloat getShadow("),e=e.replace("if ( frustumTest ) {","if ( frustumTest ) { "+al),e=e.replace("if(frustumTest){","if(frustumTest){ "+al),e=e.replace("shadow = (",il),e=e.replace("shadow=(",il),Bt.shadowmap_pars_fragment=e}const e=new Ot({side:j});return e.onBeforeCompile=e=>{e.defines=Object.assign({...e.defines,DYNAMIC_SHADOW_RADIUS:""});const t=e.uniforms;t&&(t.shadowFadeOut={value:this.shadowFadeOut},t.boxMin={value:this.boxMin},t.boxMax={value:this.boxMax},t.viewToWorldMatrix={value:this.viewToWorldMatrix}),e.fragmentShader=e.fragmentShader.replace("#include <lights_lambert_pars_fragment>","\nvarying vec3 vViewPosition;\n\nstruct LambertMaterial {\n\n\tvec3 diffuseColor;\n\tfloat specularStrength;\n\n};\n\nvoid RE_Direct_Lambert( const in IncidentLight directLight, const in GeometricContext geometry, const in LambertMaterial material, inout ReflectedLight reflectedLight ) {\n\n\tfloat dotNL = dot(geometry.normal, directLight.direction);\n // TODO: set with uniform\n float nonLinearDotNL = saturate(min(dotNL * 10.0 + 0.9, 1.0));\n\tvec3 irradiance = nonLinearDotNL * directLight.color;\n\treflectedLight.directDiffuse += irradiance;\n}\n\nvoid RE_IndirectDiffuse_Lambert( const in vec3 irradiance, const in GeometricContext geometry, const in LambertMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\n}\n\n#define RE_Direct\t\t\t\tRE_Direct_Lambert\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_Lambert\n")},e}render(e,t,r,n){this.viewToWorldMatrix.copy(r.matrixWorld);const a=new Map;t.traverse(e=>{e.isMesh&&e.visible?(a.set(e,{visible:e.visible,castShadow:e.castShadow,material:e.material}),this.setMeshMaterialAndVisibility(e)):(e.isLine||e.isLight&&!e.userData.shadowLightSource)&&(a.set(e,{visible:e.visible,castShadow:e.castShadow,material:e.material}),e.visible=!1)}),this.renderPass.render(e,t,r,n,16777215,1),a.forEach((e,t)=>{t.visible=e.visible,t.castShadow=e.castShadow,e.material&&(t.material=e.material)})}setMeshMaterialAndVisibility(e){!e.material||!e.receiveShadow||Array.isArray(e.material)||!0===e.material.transparent&&e.material.opacity<.9?e.userData.isFloor?e.material=this.shadowObjectMaterial:e.receiveShadow?(e.material=this.receiveShadowMaterial,e.castShadow=!1):e.material instanceof H&&e.material.emissiveIntensity>0?this.setMeshShadowStandardMaterial(e,e.material):e.visible=!1:this.setMeshShadowOpaqueMaterial(e)}setMeshShadowOpaqueMaterial(e){const t=e.material;t instanceof z||t instanceof C?e.material=this.unlitMaterial:t instanceof H?this.setMeshShadowStandardMaterial(e,t):e.material=e.receiveShadow?this.shadowObjectMaterial:this.unlitMaterial}setMeshShadowStandardMaterial(e,t){const r=t.emissiveIntensity>0&&(t.emissive.r>0||t.emissive.g>0||t.emissive.b>0);e.material=r?this.emissiveMaterial:e.receiveShadow?this.shadowObjectMaterial:this.unlitMaterial,r&&(e.castShadow=!1)}}ll.shaderChunkChanged=!1,ll.useModifiedMaterial=!0;class hl{constructor(){var e;this.types=new Map([["off",hl.noShadow],["BasicShadowMap",hl.basicShadow],["PCFShadowMap",hl.pcfShadow],["PCFSoftShadowMap",hl.pcfSoftShadow],["VSMShadowMap",hl.vcmShadow]]),this.shadowType="PCFShadowMap",this.currentConfiguration=null!==(e=this.types.get(this.shadowType))&&void 0!==e?e:hl.defaultType}switchType(e){var t;return!!this.types.has(e)&&(this.currentConfiguration=null!==(t=this.types.get(e))&&void 0!==t?t:hl.defaultType,!0)}}hl.noShadow={castShadow:!1,type:Dt,bias:0,normalBias:0,radius:0},hl.basicShadow={castShadow:!0,type:Lt,bias:-5e-5,normalBias:.005,radius:0},hl.pcfShadow={castShadow:!0,type:Dt,bias:-5e-5,normalBias:.01,radius:4},hl.pcfSoftShadow={castShadow:!0,type:Ut,bias:-5e-5,normalBias:.01,radius:1},hl.vcmShadow={castShadow:!0,type:Ft,bias:1e-4,normalBias:0,radius:15},hl.defaultType=hl.pcfShadow;class dl{constructor(e,t){var r,n;this.isVisibleBackup=!0,this.castShadowBackup=!0,this.shadowMapSize=null!==(r=null==t?void 0:t.shadowMapSize)&&void 0!==r?r:1024,this.blurSamples=null!==(n=null==t?void 0:t.blurSamples)&&void 0!==n?n:8,this._shadowLightSource=e,this._shadowLightSource.visible=!1,this._shadowLightSource.castShadow=!0,this._shadowLightSource.shadow&&(this._shadowLightSource.shadow.mapSize=new i(this.shadowMapSize,this.shadowMapSize),this._shadowLightSource.shadow.blurSamples=this.blurSamples),this._shadowLightSource.userData.shadowLightSource=this}getPosition(){return this._shadowLightSource.position}getShadowLight(){return this._shadowLightSource}getOriginalLight(){return null}dispose(){this._shadowLightSource.dispose()}addTo(e){e.add(this._shadowLightSource)}removeFrom(e){e.remove(this._shadowLightSource)}updatePositionAndTarget(){this.updateShadowPositionAndTarget(this.getPosition(),new s(0,0,0))}updateBounds(e){if(this._shadowLightSource instanceof l){const t=this._shadowLightSource.shadow.camera,r=e.bounds.clone().applyMatrix4(t.matrixWorldInverse),n=Math.max(.001,Math.min(-r.min.z,-r.max.z)),a=Math.max(-r.min.z,-r.max.z),i=Math.max(Math.abs(r.min.x),Math.abs(r.max.x)),s=Math.max(Math.abs(r.min.y),Math.abs(r.max.y)),o=Math.atan2(1.05*Math.hypot(s,i),n);t.aspect=1,t.near=n,t.far=a,this._shadowLightSource.angle=o}else if(this._shadowLightSource.shadow){const t=this._shadowLightSource.shadow.camera;e.updateCameraViewVolumeFromBounds(t);const r=t;r.far+=r.far-r.near,r.updateProjectionMatrix()}this._shadowLightSource.shadow&&(this._shadowLightSource.shadow.needsUpdate=!0)}updateShadowPositionAndTarget(e,t){var r,n,a;if(this._shadowLightSource instanceof l){const r=t.clone().sub(e),n=r.length();r.normalize();const a=t.clone().sub(r.clone().multiplyScalar(4*n));this._shadowLightSource.shadow.camera.position.copy(a),this._shadowLightSource.shadow.camera.position.copy(a),this._shadowLightSource.shadow.camera.lookAt(t),this._shadowLightSource.position.copy(a),this._shadowLightSource.lookAt(t)}else this._shadowLightSource.position.copy(e),this._shadowLightSource.lookAt(t),null===(r=this._shadowLightSource.shadow)||void 0===r||r.camera.position.copy(e),null===(n=this._shadowLightSource.shadow)||void 0===n||n.camera.lookAt(t);null===(a=this._shadowLightSource.shadow)||void 0===a||a.camera.updateMatrixWorld(),this._shadowLightSource.updateMatrixWorld()}updateShadowType(e,t){const r=this._shadowLightSource.shadow;r&&(r.bias=e.bias,r.normalBias=e.normalBias*t,r.radius=e.radius,r.needsUpdate=!0)}prepareRenderShadow(){return[]}finishRenderShadow(){}}class cl extends dl{constructor(e,t){let r;switch(null==t?void 0:t.shadowLightSourceType){default:case tl.DirectionalLightShadow:r=new a(16777215,1);break;case tl.SpotLightShadow:r=new l(16777215,1,0,Math.PI/4,0)}r.position.copy(e.position),r.lookAt(0,0,0),super(r,t),this._rectAreaLight=e,this._rectAreaLight.userData.shadowLightSource=this,(null==t?void 0:t.addHelper)&&(this._rectLightHelper=new rl(this._rectAreaLight),this._rectLightHelper.material.depthWrite=!1,this._rectAreaLight.add(this._rectLightHelper))}getPosition(){return this._rectAreaLight.position}getRectAreaLight(){return this._rectAreaLight}getOriginalLight(){return this._rectAreaLight}prepareRenderShadow(){return this.isVisibleBackup=this._rectAreaLight.visible,this.castShadowBackup=this._shadowLightSource.castShadow,this._shadowLightSource.visible=this._rectAreaLight.visible,this._rectAreaLight.visible=!1,this._shadowLightSource.visible?[{light:this._shadowLightSource,intensity:this._rectAreaLight.intensity}]:[]}finishRenderShadow(){this._shadowLightSource.visible=!1,this._shadowLightSource.castShadow=this.castShadowBackup,this._rectAreaLight.visible=this.isVisibleBackup}}class ul extends dl{constructor(e,t,r){const n=new a(16777215,t);n.position.copy(e),n.lookAt(0,0,0),n.updateMatrix(),n.castShadow=!0,super(n,r),this.position=e.clone(),this.intensity=t}getPosition(){return this.position}prepareRenderShadow(){return this.castShadowBackup=this._shadowLightSource.castShadow,this._shadowLightSource.visible=!0,[{light:this._shadowLightSource,intensity:this.intensity}]}finishRenderShadow(){this._shadowLightSource.castShadow=this.castShadowBackup,this._shadowLightSource.visible=!1}}var pl,ml,fl=new zt,gl=null,vl=function(){function e(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"Pass",r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:new Nt,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:fl;w(this,e),this.name=t,this.renderer=null,this.scene=r,this.camera=n,this.screen=null,this.rtt=!0,this.needsSwap=!0,this.needsDepthTexture=!1,this.enabled=!0}return b(e,[{key:"renderToScreen",get:function(){return!this.rtt},set:function(e){if(this.rtt===e){var t=this.fullscreenMaterial;null!==t&&(t.needsUpdate=!0),this.rtt=!e}}},{key:"mainScene",set:function(e){}},{key:"mainCamera",set:function(e){}},{key:"setRenderer",value:function(e){this.renderer=e}},{key:"isEnabled",value:function(){return this.enabled}},{key:"setEnabled",value:function(e){this.enabled=e}},{key:"fullscreenMaterial",get:function(){return null!==this.screen?this.screen.material:null},set:function(e){var t=this.screen;null!==t?t.material=e:((t=new K(function(){if(null===gl){var e=new Float32Array([-1,-1,0,3,-1,0,-1,3,0]),t=new Float32Array([0,0,2,0,0,2]);void 0!==(gl=new c).setAttribute?(gl.setAttribute("position",new u(e,3)),gl.setAttribute("uv",new u(t,2))):(gl.addAttribute("position",new u(e,3)),gl.addAttribute("uv",new u(t,2)))}return gl}(),e)).frustumCulled=!1,null===this.scene&&(this.scene=new Nt),this.scene.add(t),this.screen=t)}},{key:"getFullscreenMaterial",value:function(){return this.fullscreenMaterial}},{key:"setFullscreenMaterial",value:function(e){this.fullscreenMaterial=e}},{key:"getDepthTexture",value:function(){return null}},{key:"setDepthTexture",value:function(e){}},{key:"render",value:function(e,t,r,n,a){throw new Error("Render method not implemented!")}},{key:"setSize",value:function(e,t){}},{key:"initialize",value:function(e,t,r){}},{key:"dispose",value:function(){for(var t=0,r=Object.keys(this);t<r.length;t++){var n=r[t],a=this[n];(a instanceof _t||a instanceof N||a instanceof fe||a instanceof e)&&this[n].dispose()}}}]),e}(),wl="data:image/png;base64,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",bl="#define GLSLIFY 1\nvarying vec2 vUv;void main(){vUv=position.xy*0.5+0.5;gl_Position=vec4(position.xy,1.0,1.0);}",yl="#define GLSLIFY 1\nconst float g=1.6180339887498948482;const float a1=1.0/g;float r1(float n){return fract(1.1127756842787055+a1*n);}const vec4 hn=vec4(0.618033988749895,0.3247179572447458,0.2207440846057596,0.1673039782614187);vec4 sampleBlueNoise(sampler2D texture,int seed,vec2 repeat,vec2 texSize){vec2 size=vUv*texSize;vec2 blueNoiseSize=texSize/repeat;float blueNoiseIndex=floor(floor(size.y/blueNoiseSize.y)*repeat.x)+floor(size.x/blueNoiseSize.x);vec2 blueNoiseUv=vUv*repeat;vec4 blueNoise=textureLod(texture,blueNoiseUv,0.);if(seed!=0){blueNoise=fract(blueNoise+hn*float(seed));blueNoise.r=(blueNoise.r>0.5 ? 1.0-blueNoise.r : blueNoise.r)*2.0;blueNoise.g=(blueNoise.g>0.5 ? 1.0-blueNoise.g : blueNoise.g)*2.0;blueNoise.b=(blueNoise.b>0.5 ? 1.0-blueNoise.b : blueNoise.b)*2.0;blueNoise.a=(blueNoise.a>0.5 ? 1.0-blueNoise.a : blueNoise.a)*2.0;}return blueNoise;}",_l=function(e){g(r,e);var t=v(r);function r(e,n,a){var s;w(this,r),(s=t.call(this))._camera=e,s._scene=n,s.renderTarget=new _t(1,1,{type:at,depthBuffer:!1});var o=a.replace("#include <sampleBlueNoise>",yl);return s.fullscreenMaterial=new pt({fragmentShader:o,vertexShader:bl,uniforms:{depthTexture:{value:null},normalTexture:{value:null},cameraNear:{value:0},cameraFar:{value:0},viewMatrix:{value:s._camera.matrixWorldInverse},projectionViewMatrix:{value:new P},projectionMatrixInverse:{value:s._camera.projectionMatrixInverse},cameraMatrixWorld:{value:s._camera.matrixWorld},texSize:{value:new i},blueNoiseTexture:{value:null},blueNoiseRepeat:{value:new i},aoDistance:{value:0},distancePower:{value:0},bias:{value:0},thickness:{value:0},power:{value:0},frame:{value:0}},blending:ft,depthWrite:!1,depthTest:!1,toneMapped:!1}),(new ue).load(wl,(function(e){e.minFilter=ae,e.magFilter=ae,e.wrapS=F,e.wrapT=F,e.colorSpace=lt,s.fullscreenMaterial.uniforms.blueNoiseTexture.value=e})),s}return b(r,[{key:"texture",get:function(){return this.renderTarget.texture}},{key:"setSize",value:function(e,t){this.renderTarget.setSize(e,t),this.fullscreenMaterial.uniforms.texSize.value.set(this.renderTarget.width,this.renderTarget.height)}},{key:"render",value:function(e){var t=+this.fullscreenMaterial.defines.spp;this.fullscreenMaterial.uniforms.frame.value=(this.fullscreenMaterial.uniforms.frame.value+t)%65536,this.fullscreenMaterial.uniforms.cameraNear.value=this._camera.near,this.fullscreenMaterial.uniforms.cameraFar.value=this._camera.far,this.fullscreenMaterial.uniforms.projectionViewMatrix.value.multiplyMatrices(this._camera.projectionMatrix,this._camera.matrixWorldInverse);var r=this.fullscreenMaterial.uniforms.blueNoiseTexture.value;if(r){var n=r.source.data,a=n.width,i=n.height;this.fullscreenMaterial.uniforms.blueNoiseRepeat.value.set(this.renderTarget.width/a,this.renderTarget.height/i)}e.setRenderTarget(this.renderTarget),e.render(this.scene,this.camera)}}]),r}(vl),xl=function(e){g(r,e);var t=v(r);function r(e,n){return w(this,r),t.call(this,e,n,"#define GLSLIFY 1\nvarying vec2 vUv;uniform sampler2D depthTexture;uniform sampler2D normalTexture;uniform mat4 projectionViewMatrix;uniform mat4 cameraMatrixWorld;uniform sampler2D blueNoiseTexture;uniform vec2 blueNoiseRepeat;uniform vec2 texSize;uniform mat4 projectionMatrixInverse;uniform float aoDistance;uniform float distancePower;uniform float cameraNear;uniform float cameraFar;uniform int frame;uniform vec3[spp]samples;uniform float[spp]samplesR;\n#include <common>\n#include <packing>\n#include <sampleBlueNoise>\nvec3 getWorldPos(const float depth,const vec2 coord){float z=depth*2.0-1.0;vec4 clipSpacePosition=vec4(coord*2.0-1.0,z,1.0);vec4 viewSpacePosition=projectionMatrixInverse*clipSpacePosition;vec4 worldSpacePosition=cameraMatrixWorld*viewSpacePosition;worldSpacePosition.xyz/=worldSpacePosition.w;return worldSpacePosition.xyz;}vec3 computeNormal(vec3 worldPos,vec2 vUv){vec2 size=vec2(textureSize(depthTexture,0));ivec2 p=ivec2(vUv*size);float c0=texelFetch(depthTexture,p,0).x;float l2=texelFetch(depthTexture,p-ivec2(2,0),0).x;float l1=texelFetch(depthTexture,p-ivec2(1,0),0).x;float r1=texelFetch(depthTexture,p+ivec2(1,0),0).x;float r2=texelFetch(depthTexture,p+ivec2(2,0),0).x;float b2=texelFetch(depthTexture,p-ivec2(0,2),0).x;float b1=texelFetch(depthTexture,p-ivec2(0,1),0).x;float t1=texelFetch(depthTexture,p+ivec2(0,1),0).x;float t2=texelFetch(depthTexture,p+ivec2(0,2),0).x;float dl=abs((2.0*l1-l2)-c0);float dr=abs((2.0*r1-r2)-c0);float db=abs((2.0*b1-b2)-c0);float dt=abs((2.0*t1-t2)-c0);vec3 ce=getWorldPos(c0,vUv).xyz;vec3 dpdx=(dl<dr)? ce-getWorldPos(l1,(vUv-vec2(1.0/size.x,0.0))).xyz:-ce+getWorldPos(r1,(vUv+vec2(1.0/size.x,0.0))).xyz;vec3 dpdy=(db<dt)? ce-getWorldPos(b1,(vUv-vec2(0.0,1.0/size.y))).xyz:-ce+getWorldPos(t1,(vUv+vec2(0.0,1.0/size.y))).xyz;return normalize(cross(dpdx,dpdy));}highp float linearize_depth(highp float d,highp float zNear,highp float zFar){highp float z_n=2.0*d-1.0;return 2.0*zNear*zFar/(zFar+zNear-z_n*(zFar-zNear));}void main(){float depth=textureLod(depthTexture,vUv,0.).x;if(depth==1.0){discard;return;}vec3 worldPos=getWorldPos(depth,vUv);vec3 normal=computeNormal(worldPos,vUv);\n#ifdef animatedNoise\nint seed=frame;\n#else\nint seed=0;\n#endif\nvec4 noise=sampleBlueNoise(blueNoiseTexture,seed,blueNoiseRepeat,texSize);vec3 randomVec=normalize(noise.rgb*2.0-1.0);vec3 tangent=normalize(randomVec-normal*dot(randomVec,normal));vec3 bitangent=cross(normal,tangent);mat3 tbn=mat3(tangent,bitangent,normal);float occluded=0.0;float totalWeight=0.0;vec3 samplePos;float sppF=float(spp);for(float i=0.0;i<sppF;i++){vec3 sampleDirection=tbn*samples[int(i)];if(dot(sampleDirection,normal)<0.0)sampleDirection*=-1.0;float moveAmt=samplesR[int(mod(i+noise.a*sppF,sppF))];samplePos=worldPos+aoDistance*moveAmt*sampleDirection;vec4 offset=projectionViewMatrix*vec4(samplePos,1.0);offset.xyz/=offset.w;offset.xyz=offset.xyz*0.5+0.5;float sampleDepth=textureLod(depthTexture,offset.xy,0.0).x;float distSample=linearize_depth(sampleDepth,cameraNear,cameraFar);float distWorld=linearize_depth(offset.z,cameraNear,cameraFar);float rangeCheck=smoothstep(0.0,1.0,aoDistance/(aoDistance*abs(distSample-distWorld)));rangeCheck=pow(rangeCheck,distancePower);float weight=dot(sampleDirection,normal);occluded+=rangeCheck*weight*(distSample<distWorld ? 1.0 : 0.0);totalWeight+=weight;}float occ=clamp(1.0-occluded/totalWeight,0.0,1.0);gl_FragColor=vec4(normal,occ);}")}return b(r)}(_l),Sl="#define GLSLIFY 1\nvarying vec2 vUv;uniform sampler2D depthTexture;uniform mat4 projectionViewMatrix;uniform int frame;uniform sampler2D blueNoiseTexture;uniform vec2 blueNoiseRepeat;uniform vec2 texSize;uniform float aoDistance;uniform float distancePower;uniform float bias;uniform float thickness;\n#include <packing>\n#include <hbao_utils>\nfloat getOcclusion(const vec3 cameraPosition,const vec3 worldPos,const vec3 worldNormal,const float depth,const int seed,inout float totalWeight){vec4 blueNoise=sampleBlueNoise(blueNoiseTexture,seed,blueNoiseRepeat,texSize);vec3 sampleWorldDir=cosineSampleHemisphere(worldNormal,blueNoise.rg);vec3 sampleWorldPos=worldPos+aoDistance*pow(blueNoise.b,distancePower+1.0)*sampleWorldDir;vec4 sampleUv=projectionViewMatrix*vec4(sampleWorldPos,1.);sampleUv.xy/=sampleUv.w;sampleUv.xy=sampleUv.xy*0.5+0.5;float sampleDepth=textureLod(depthTexture,sampleUv.xy,0.0).r;float deltaDepth=depth-sampleDepth;float d=distance(sampleWorldPos,cameraPosition);deltaDepth*=0.001*d*d;float th=thickness*0.01;float theta=dot(worldNormal,sampleWorldDir);totalWeight+=theta;if(deltaDepth<th){float horizon=sampleDepth+deltaDepth*bias*1000.;float occlusion=max(0.0,horizon-depth)*theta;float m=max(0.,1.-deltaDepth/th);occlusion=10.*occlusion*m/d;occlusion=sqrt(occlusion);return occlusion;}return 0.;}void main(){float depth=textureLod(depthTexture,vUv,0.0).r;if(depth==1.0){discard;return;}vec4 cameraPosition=cameraMatrixWorld*vec4(0.0,0.0,0.0,1.0);vec3 worldPos=getWorldPos(depth,vUv);vec3 worldNormal=getWorldNormal(vUv);float ao=0.0,totalWeight=0.0;for(int i=0;i<spp;i++){int seed=i;\n#ifdef animatedNoise\nseed+=frame;\n#endif\nfloat occlusion=getOcclusion(cameraPosition.xyz,worldPos,worldNormal,depth,seed,totalWeight);ao+=occlusion;}if(totalWeight>0.)ao/=totalWeight;ao=clamp(1.-ao,0.,1.);gl_FragColor=vec4(worldNormal,ao);}".replace("#include <hbao_utils>","#define GLSLIFY 1\n#include <sampleBlueNoise>\nuniform sampler2D normalTexture;uniform float cameraNear;uniform float cameraFar;uniform mat4 projectionMatrixInverse;uniform mat4 cameraMatrixWorld;float getViewZ(const float depth){\n#ifdef PERSPECTIVE_CAMERA\nreturn perspectiveDepthToViewZ(depth,cameraNear,cameraFar);\n#else\nreturn orthographicDepthToViewZ(depth,cameraNear,cameraFar);\n#endif\n}vec3 getWorldPos(const float depth,const vec2 coord){float z=depth*2.0-1.0;vec4 clipSpacePosition=vec4(coord*2.0-1.0,z,1.0);vec4 viewSpacePosition=projectionMatrixInverse*clipSpacePosition;vec4 worldSpacePosition=cameraMatrixWorld*viewSpacePosition;worldSpacePosition.xyz/=worldSpacePosition.w;return worldSpacePosition.xyz;}vec3 slerp(const vec3 a,const vec3 b,const float t){float cosAngle=dot(a,b);float angle=acos(cosAngle);if(abs(angle)<0.001){return mix(a,b,t);}float sinAngle=sin(angle);float t1=sin((1.0-t)*angle)/sinAngle;float t2=sin(t*angle)/sinAngle;return(a*t1)+(b*t2);}vec3 computeWorldNormal(){vec2 size=vec2(textureSize(depthTexture,0));ivec2 p=ivec2(vUv*size);float c0=texelFetch(depthTexture,p,0).x;float l2=texelFetch(depthTexture,p-ivec2(2,0),0).x;float l1=texelFetch(depthTexture,p-ivec2(1,0),0).x;float r1=texelFetch(depthTexture,p+ivec2(1,0),0).x;float r2=texelFetch(depthTexture,p+ivec2(2,0),0).x;float b2=texelFetch(depthTexture,p-ivec2(0,2),0).x;float b1=texelFetch(depthTexture,p-ivec2(0,1),0).x;float t1=texelFetch(depthTexture,p+ivec2(0,1),0).x;float t2=texelFetch(depthTexture,p+ivec2(0,2),0).x;float dl=abs((2.0*l1-l2)-c0);float dr=abs((2.0*r1-r2)-c0);float db=abs((2.0*b1-b2)-c0);float dt=abs((2.0*t1-t2)-c0);vec3 ce=getWorldPos(c0,vUv).xyz;vec3 dpdx=(dl<dr)? ce-getWorldPos(l1,(vUv-vec2(1.0/size.x,0.0))).xyz:-ce+getWorldPos(r1,(vUv+vec2(1.0/size.x,0.0))).xyz;vec3 dpdy=(db<dt)? ce-getWorldPos(b1,(vUv-vec2(0.0,1.0/size.y))).xyz:-ce+getWorldPos(t1,(vUv+vec2(0.0,1.0/size.y))).xyz;return normalize(cross(dpdx,dpdy));}vec3 getWorldNormal(const vec2 uv){\n#ifdef useNormalTexture\nvec3 worldNormal=unpackRGBToNormal(textureLod(normalTexture,uv,0.).rgb);worldNormal=(vec4(worldNormal,1.)*viewMatrix).xyz;return normalize(worldNormal);\n#else\nreturn computeWorldNormal();\n#endif\n}\n#define PI 3.14159265358979323846264338327950288\nvec3 cosineSampleHemisphere(const vec3 n,const vec2 u){float r=sqrt(u.x);float theta=2.0*PI*u.y;vec3 b=normalize(cross(n,vec3(0.0,1.0,1.0)));vec3 t=cross(b,n);return normalize(r*sin(theta)*b+sqrt(1.0-u.x)*n+r*cos(theta)*t);}"),Cl=function(e){g(r,e);var t=v(r);function r(e,n){return w(this,r),t.call(this,e,n,Sl)}return b(r)}(_l),Ml="#define GLSLIFY 1\nvarying vec2 vUv;uniform sampler2D inputTexture;uniform sampler2D depthTexture;uniform sampler2D normalTexture;uniform mat4 projectionMatrixInverse;uniform mat4 cameraMatrixWorld;uniform float lumaPhi;uniform float depthPhi;uniform float normalPhi;uniform sampler2D blueNoiseTexture;uniform vec2 blueNoiseRepeat;uniform int index;uniform vec2 resolution;\n#include <common>\n#include <sampleBlueNoise>\nvec3 getWorldPos(float depth,vec2 coord){float z=depth*2.0-1.0;vec4 clipSpacePosition=vec4(coord*2.0-1.0,z,1.0);vec4 viewSpacePosition=projectionMatrixInverse*clipSpacePosition;vec4 worldSpacePosition=cameraMatrixWorld*viewSpacePosition;worldSpacePosition.xyz/=worldSpacePosition.w;return worldSpacePosition.xyz;}\n#define luminance(a) dot(vec3(0.2125, 0.7154, 0.0721), a)\nvec3 getNormal(vec2 uv,vec4 texel){\n#ifdef NORMAL_IN_RGB\nreturn texel.rgb;\n#else\nreturn normalize(textureLod(normalTexture,uv,0.).xyz*2.0-1.0);\n#endif\n}float distToPlane(const vec3 worldPos,const vec3 neighborWorldPos,const vec3 worldNormal){vec3 toCurrent=worldPos-neighborWorldPos;float distToPlane=abs(dot(toCurrent,worldNormal));return distToPlane;}void main(){vec4 depthTexel=textureLod(depthTexture,vUv,0.);if(depthTexel.r==1.0||dot(depthTexel.rgb,depthTexel.rgb)==0.){discard;return;}vec4 texel=textureLod(inputTexture,vUv,0.0);vec3 normal=getNormal(vUv,texel);\n#ifdef NORMAL_IN_RGB\nfloat denoised=texel.a;float center=texel.a;\n#else\nvec3 denoised=texel.rgb;vec3 center=texel.rgb;\n#endif\nfloat depth=depthTexel.x;vec3 worldPos=getWorldPos(depth,vUv);float totalWeight=1.0;vec4 blueNoise=sampleBlueNoise(blueNoiseTexture,0,blueNoiseRepeat,resolution);float angle=blueNoise[index];float s=sin(angle),c=cos(angle);mat2 rotationMatrix=mat2(c,-s,s,c);for(int i=0;i<samples;i++){vec2 offset=rotationMatrix*poissonDisk[i];vec2 neighborUv=vUv+offset;vec4 neighborTexel=textureLod(inputTexture,neighborUv,0.0);vec3 neighborNormal=getNormal(neighborUv,neighborTexel);\n#ifdef NORMAL_IN_RGB\nfloat neighborColor=neighborTexel.a;\n#else\nvec3 neighborColor=neighborTexel.rgb;\n#endif\nfloat sampleDepth=textureLod(depthTexture,neighborUv,0.0).x;vec3 worldPosSample=getWorldPos(sampleDepth,neighborUv);float tangentPlaneDist=abs(dot(worldPos-worldPosSample,normal));float normalDiff=dot(normal,neighborNormal);float normalSimilarity=pow(max(normalDiff,0.),normalPhi);\n#ifdef NORMAL_IN_RGB\nfloat lumaDiff=abs(neighborColor-center);\n#else\nfloat lumaDiff=abs(luminance(neighborColor)-luminance(center));\n#endif\nfloat lumaSimilarity=max(1.0-lumaDiff/lumaPhi,0.0);float depthDiff=1.-distToPlane(worldPos,worldPosSample,normal);float depthSimilarity=max(depthDiff/depthPhi,0.);float w=lumaSimilarity*depthSimilarity*normalSimilarity;denoised+=w*neighborColor;totalWeight+=w;}if(totalWeight>0.)denoised/=totalWeight;\n#ifdef NORMAL_IN_RGB\ngl_FragColor=vec4(normal,denoised);\n#else\ngl_FragColor=vec4(denoised,1.);\n#endif\n}".replace("#include <sampleBlueNoise>",yl),Tl={iterations:1,radius:8,rings:5.625,lumaPhi:10,depthPhi:2,normalPhi:3.25,samples:16,normalTexture:null},Al=function(e){g(r,e);var t=v(r);function r(e,n,a){var s,o=arguments.length>3&&void 0!==arguments[3]?arguments[3]:Tl;w(this,r),s=t.call(this,"PoissionBlurPass"),Ht(jt(s),"iterations",Tl.iterations),Ht(jt(s),"index",0),o=Vt(Vt({},Tl),o),s.inputTexture=n,s.fullscreenMaterial=new pt({fragmentShader:Ml,vertexShader:bl,uniforms:{depthTexture:{value:null},inputTexture:{value:null},projectionMatrixInverse:{value:new P},cameraMatrixWorld:{value:new P},lumaPhi:{value:5},depthPhi:{value:5},normalPhi:{value:5},resolution:{value:new i},blueNoiseTexture:{value:null},index:{value:0},blueNoiseRepeat:{value:new i}}});var l={type:at,depthBuffer:!1};s.renderTargetA=new _t(1,1,l),s.renderTargetB=new _t(1,1,l);var h=s.fullscreenMaterial.uniforms;h.inputTexture.value=s.inputTexture,h.depthTexture.value=a,h.projectionMatrixInverse.value=e.projectionMatrixInverse,h.cameraMatrixWorld.value=e.matrixWorld,h.depthPhi.value=o.depthPhi,h.normalPhi.value=o.normalPhi,o.normalTexture?h.normalTexture={value:o.normalTexture}:s.fullscreenMaterial.defines.NORMAL_IN_RGB="";for(var d=function(){var e=u[c];Object.defineProperty(jt(s),e,{get:function(){return o[e]},set:function(t){o[e]=t,s.setSize(s.renderTargetA.width,s.renderTargetA.height)}})},c=0,u=["radius","rings","samples"];c<u.length;c++)d();return(new ue).load(wl,(function(e){e.minFilter=ae,e.magFilter=ae,e.wrapS=F,e.wrapT=F,e.colorSpace=lt,s.fullscreenMaterial.uniforms.blueNoiseTexture.value=e})),s}return b(r,[{key:"setSize",value:function(e,t){this.renderTargetA.setSize(e,t),this.renderTargetB.setSize(e,t),this.fullscreenMaterial.uniforms.resolution.value.set(e,t);var r=function(e,t,r,n){for(var a=2*Math.PI*t/e,s=1/e,o=s,l=[],h=s,d=0,c=0;c<e;c++){var u=new i(Math.cos(d),Math.sin(d)).multiplyScalar(Math.pow(h,.75)).multiply(n).multiplyScalar(r);l.push(u),h+=o,d+=a}return l}(this.samples,this.rings,this.radius,new i(1/e,1/t)),n="const int samples = ".concat(this.samples,";\n"),a=function(e){for(var t=e.length,r="const vec2 poissonDisk[samples] = vec2[samples](\n",n=0;n<t;n++){var a=e[n];r+=" vec2(".concat(a.x,", ").concat(a.y,")"),n<t-1&&(r+=","),r+="\n"}return r+");"}(r);this.fullscreenMaterial.fragmentShader=n+a+"\n"+Ml,this.fullscreenMaterial.needsUpdate=!0}},{key:"texture",get:function(){return this.renderTargetB.texture}},{key:"render",value:function(e){this.fullscreenMaterial.uniforms.index.value=0;var t=this.fullscreenMaterial.uniforms.blueNoiseTexture.value;if(t){var r=t.source.data,n=r.width,a=r.height;this.fullscreenMaterial.uniforms.blueNoiseRepeat.value.set(this.renderTargetA.width/n,this.renderTargetA.height/a)}for(var i=0;i<2*this.iterations;i++){var s=i%2==0,o=s?this.renderTargetB:this.renderTargetA;this.fullscreenMaterial.uniforms.inputTexture.value=0===i?this.inputTexture:o.texture;var l=s?this.renderTargetA:this.renderTargetB;e.setRenderTarget(l),e.render(this.scene,this.camera),this.fullscreenMaterial.uniforms.index.value=(this.fullscreenMaterial.uniforms.index.value+1)%4}}}]),r}(vl);Al.DefaultOptions=Tl,function(e){e[e.INPUT_RGB_NORMAL=0]="INPUT_RGB_NORMAL",e[e.FLOAT_BUFFER_NORMAL=1]="FLOAT_BUFFER_NORMAL",e[e.CONSTANT_Z=2]="CONSTANT_Z"}(pl||(pl={})),function(e){e[e.SEPARATE_BUFFER=0]="SEPARATE_BUFFER",e[e.NORMAL_VECTOR_ALPHA=1]="NORMAL_VECTOR_ALPHA"}(ml||(ml={}));const Pl={resolutionScale:1,spp:16,distance:.25,distancePower:.25,power:2,bias:40,thickness:.075},Rl={resolutionScale:1,spp:16,distance:.25,distancePower:1,power:2,bias:20,thickness:.05},El={iterations:1,radius:10,rings:5.625,lumaPhi:10,depthPhi:12,normalPhi:3.25,samples:16};class Il{get texture(){return this.ssaoPass?this.ssaoPass.texture:null}constructor(e,t,r){this.needsUpdate=!0,this.parameters={...Pl},this.width=0,this.height=0,this.loaded=!1,this.normalVectorSourceType=pl.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=ml.NORMAL_VECTOR_ALPHA,this.modulateRedChannel=!1,this.depthTexture=null,this.normalTexture=null,this.width=e,this.height=t,this.normalVectorSourceType=(null==r?void 0:r.normalVectorSourceType)||pl.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=(null==r?void 0:r.depthValueSourceType)||ml.NORMAL_VECTOR_ALPHA,this.modulateRedChannel=(null==r?void 0:r.modulateRedChannel)||!1,(null==r?void 0:r.ssaoParameters)&&(this.parameters=r.ssaoParameters),r&&this.updateParameters(r)}getPass(e,t){if(!this.ssaoPass){this.ssaoPass=new xl(e,t);const r=this.ssaoPass.fullscreenMaterial;r.defines.useNormalTexture="",this.modulateRedChannel&&(r.blending=Gt,r.blendEquation=Kt,r.blendEquationAlpha=null,r.blendSrc=Wt,r.blendSrcAlpha=null,r.blendDst=Wt,r.blendDstAlpha=null),r.onBeforeCompile=e=>{this.normalVectorSourceType===pl.FLOAT_BUFFER_NORMAL&&(e.fragmentShader=e.fragmentShader.replace("computeNormal(worldPos, vUv)","normalize(textureLod(normalTexture, vUv, 0.).rgb)")),this.depthValueSourceType===ml.NORMAL_VECTOR_ALPHA&&(e.fragmentShader=e.fragmentShader.replace("textureLod(depthTexture, vUv, 0.).x","textureLod(normalTexture, vUv, 0.).a"),e.fragmentShader=e.fragmentShader.replace("textureLod(depthTexture,vUv,0.).x","textureLod(normalTexture, vUv, 0.).a"),e.fragmentShader=e.fragmentShader.replace("textureLod(depthTexture, offset.xy, 0.0).x","textureLod(normalTexture, offset.xy, 0.0).a"),e.fragmentShader=e.fragmentShader.replace("textureLod(depthTexture,offset.xy,0.0).x","textureLod(normalTexture, offset.xy, 0.0).a")),this.modulateRedChannel&&(e.fragmentShader=e.fragmentShader.replace("gl_FragColor = vec4(normal, occ);","gl_FragColor = vec4(occ, 1.0, 1.0, 1.0);"),e.fragmentShader=e.fragmentShader.replace("gl_FragColor=vec4(normal,occ);","gl_FragColor=vec4(occ,1.0,1.0,1.0);"))},this.needsUpdate=!0}return this.ssaoPass}dispose(){var e;null===(e=this.ssaoPass)||void 0===e||e.dispose()}setSize(e,t){var r;this.width=e,this.height=t,null===(r=this.ssaoPass)||void 0===r||r.setSize(e,t),this.needsUpdate=!0}updateParameters(e){for(let t in e)this.parameters.hasOwnProperty(t)&&(this.parameters[t]=e[t],this.needsUpdate=!0);e.depthTexture&&(this.depthTexture=e.depthTexture,this.needsUpdate=!0),e.normalTexture&&(this.normalTexture=e.normalTexture,this.needsUpdate=!0)}render(e,t,r,n){var a;this.loaded||null===(null===(a=this.ssaoPass)||void 0===a?void 0:a.fullscreenMaterial.uniforms.blueNoiseTexture.value)||(this.loaded=!0,this.needsUpdate=!0);const i=!this.ssaoPass,o=this.getPass(t,r);if(this.needsUpdate||i){if(this.needsUpdate=!1,o.fullscreenMaterial.uniforms.aoDistance.value=this.parameters.distance,o.fullscreenMaterial.uniforms.distancePower.value=this.parameters.distancePower,o.fullscreenMaterial.uniforms.bias.value=this.parameters.bias,o.fullscreenMaterial.uniforms.thickness.value=this.parameters.thickness,o.fullscreenMaterial.uniforms.power.value=this.parameters.power,o.fullscreenMaterial.uniforms.depthTexture.value=this.depthValueSourceType===ml.NORMAL_VECTOR_ALPHA?this.normalTexture:this.depthTexture,o.fullscreenMaterial.uniforms.normalTexture.value=this.normalTexture,o.fullscreenMaterial.needsUpdate=!0,i){const e=Math.round(this.parameters.spp);o.fullscreenMaterial.defines.spp=e;const t=function(e){for(var t=[],r=Math.PI*(3-Math.sqrt(5)),n=2/e,a=0;a<e;a++){var i=a*n-1+n/2,o=Math.sqrt(1-i*i),l=a*r;t.push(new s(Math.cos(l)*o,i,Math.sin(l)*o))}return t}(e),r=[];for(let t=0;t<e;t++)r.push((t+1)/e);o.fullscreenMaterial.uniforms.samples={value:t},o.fullscreenMaterial.uniforms.samplesR={value:r}}o.setSize(this.width,this.height),o.renderToScreen=!1}o._camera=t,o.fullscreenMaterial.uniforms.viewMatrix.value=t.matrixWorldInverse,o.fullscreenMaterial.uniforms.projectionMatrixInverse.value=t.projectionMatrixInverse,o.fullscreenMaterial.uniforms.cameraMatrixWorld.value=t.matrixWorld;const l=e.getRenderTarget();n&&(o.renderTarget=n),o.render(e),e.setRenderTarget(l)}}class kl{get texture(){return this.hbaoPass.texture}constructor(e,t,r){this.needsUpdate=!0,this.parameters={...Rl},this.width=0,this.height=0,this.loaded=!1,this.normalVectorSourceType=pl.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=ml.NORMAL_VECTOR_ALPHA,this.modulateRedChannel=!1,this.depthTexture=null,this.normalTexture=null,this.width=e,this.height=t,this.normalVectorSourceType=(null==r?void 0:r.normalVectorSourceType)||pl.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=(null==r?void 0:r.depthValueSourceType)||ml.NORMAL_VECTOR_ALPHA,this.modulateRedChannel=(null==r?void 0:r.modulateRedChannel)||!1,(null==r?void 0:r.hbaoParameters)&&(this.parameters=r.hbaoParameters),r&&this.updateParameters(r)}getPass(e,t){if(!this.hbaoPass){this.hbaoPass=new Cl(e,t);const r=this.hbaoPass.fullscreenMaterial;r.defines.useNormalTexture="",this.modulateRedChannel&&(r.blending=Gt,r.blendEquation=Kt,r.blendEquationAlpha=null,r.blendSrc=Wt,r.blendSrcAlpha=null,r.blendDst=Wt,r.blendDstAlpha=null),r.onBeforeCompile=e=>{this.normalVectorSourceType===pl.FLOAT_BUFFER_NORMAL&&(e.fragmentShader=e.fragmentShader.replace("vec3 worldNormal = unpackRGBToNormal(textureLod(normalTexture, uv, 0.).rgb);","vec3 worldNormal = normalize(textureLod(normalTexture, uv, 0.).rgb);"),e.fragmentShader=e.fragmentShader.replace("vec3 worldNormal=unpackRGBToNormal(textureLod(normalTexture,uv,0.).rgb);","vec3 worldNormal=normalize(textureLod(normalTexture,uv,0.).rgb);")),this.depthValueSourceType===ml.NORMAL_VECTOR_ALPHA&&(e.fragmentShader=e.fragmentShader.replace("textureLod(depthTexture, sampleUv.xy, 0.0).r","textureLod(normalTexture, sampleUv.xy, 0.0).a"),e.fragmentShader=e.fragmentShader.replace("textureLod(depthTexture,sampleUv.xy,0.0).r","textureLod(normalTexture, sampleUv.xy, 0.0).a"),e.fragmentShader=e.fragmentShader.replace("textureLod(depthTexture, vUv, 0.0).r","textureLod(normalTexture, vUv, 0.0).a"),e.fragmentShader=e.fragmentShader.replace("textureLod(depthTexture,vUv,0.0).r","textureLod(normalTexture, vUv, 0.0).a")),this.modulateRedChannel&&(e.fragmentShader=e.fragmentShader.replace("gl_FragColor = vec4(worldNormal, ao);","gl_FragColor = vec4(ao, 1.0, 1.0, 1.0);"),e.fragmentShader=e.fragmentShader.replace("gl_FragColor=vec4(worldNormal,ao);","gl_FragColor=vec4(ao,1.0,1.0,1.0);"))},this.needsUpdate=!0}return this.hbaoPass}dispose(){var e;null===(e=this.hbaoPass)||void 0===e||e.dispose()}setSize(e,t){var r;this.width=e,this.height=t,null===(r=this.hbaoPass)||void 0===r||r.setSize(e,t),this.needsUpdate=!0}updateParameters(e){for(let t in e)this.parameters.hasOwnProperty(t)&&(this.parameters[t]=e[t],this.needsUpdate=!0);e.depthTexture&&(this.depthTexture=e.depthTexture,this.needsUpdate=!0),e.normalTexture&&(this.normalTexture=e.normalTexture,this.needsUpdate=!0)}render(e,t,r,n){var a;this.loaded||null===(null===(a=this.hbaoPass)||void 0===a?void 0:a.fullscreenMaterial.uniforms.blueNoiseTexture.value)||(this.loaded=!0,this.needsUpdate=!0);const i=this.getPass(t,r);if(this.needsUpdate){this.needsUpdate=!1;const e=Math.round(this.parameters.spp);i.fullscreenMaterial.defines.spp=e,i.fullscreenMaterial.uniforms.aoDistance.value=this.parameters.distance,i.fullscreenMaterial.uniforms.distancePower.value=this.parameters.distancePower,i.fullscreenMaterial.uniforms.bias.value=this.parameters.bias,i.fullscreenMaterial.uniforms.thickness.value=this.parameters.thickness,i.fullscreenMaterial.uniforms.power.value=this.parameters.power,i.fullscreenMaterial.uniforms.depthTexture.value=this.depthValueSourceType===ml.NORMAL_VECTOR_ALPHA?this.normalTexture:this.depthTexture,i.fullscreenMaterial.uniforms.normalTexture.value=this.normalTexture,i.fullscreenMaterial.needsUpdate=!0,i.setSize(this.width,this.height),i.renderToScreen=!1}i._camera=t,i.fullscreenMaterial.uniforms.viewMatrix.value=t.matrixWorldInverse,i.fullscreenMaterial.uniforms.projectionMatrixInverse.value=t.projectionMatrixInverse,i.fullscreenMaterial.uniforms.cameraMatrixWorld.value=t.matrixWorld;const s=e.getRenderTarget();n&&(i.renderTarget=n),i.render(e),e.setRenderTarget(s)}}class Ol{get texture(){return this.denoisePass?this.denoisePass.texture:null}set inputTexture(e){this._inputTexture=e}constructor(e,t,r){this.needsUpdate=!0,this.parameters={...El},this.width=0,this.height=0,this.normalVectorSourceType=pl.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=ml.NORMAL_VECTOR_ALPHA,this.rgInputTexture=!0,this._inputTexture=null,this.depthTexture=null,this.normalTexture=null,this.width=e,this.height=t,this.normalVectorSourceType=(null==r?void 0:r.normalVectorSourceType)||pl.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=(null==r?void 0:r.depthValueSourceType)||ml.NORMAL_VECTOR_ALPHA,this.rgInputTexture=(null==r?void 0:r.rgInputTexture)||!0,this._inputTexture=(null==r?void 0:r.inputTexture)||null,this.depthTexture=(null==r?void 0:r.depthTexture)||null,this.normalTexture=(null==r?void 0:r.normalTexture)||null,r.poisonDenoiseParameters?this.parameters=r.poisonDenoiseParameters:r&&this.updateParameters(r)}getPass(e){return this.denoisePass||(this.normalTexture?(this.denoisePass=new Al(e,this._inputTexture,this.depthTexture,{normalTexture:this.normalTexture}),this.denoisePass.fullscreenMaterial.onBeforeCompile=e=>{switch(this.normalVectorSourceType){default:break;case pl.FLOAT_BUFFER_NORMAL:e.fragmentShader=e.fragmentShader.replace("return normalize(textureLod(normalTexture, uv, 0.).xyz * 2.0 - 1.0);","return normalize(textureLod(normalTexture, uv, 0.).xyz);"),e.fragmentShader=e.fragmentShader.replace("return normalize(textureLod(normalTexture,uv,0.).xyz*2.0-1.0);","return normalize(textureLod(normalTexture,uv,0.).xyz);");break;case pl.CONSTANT_Z:e.fragmentShader=e.fragmentShader.replace("return normalize(textureLod(normalTexture, uv, 0.).xyz * 2.0 - 1.0);","return vec3(0.0, 0.0, 1.0);"),e.fragmentShader=e.fragmentShader.replace("return normalize(textureLod(normalTexture,uv,0.).xyz*2.0-1.0);","return vec3(0.0, 0.0, 1.0);")}this.depthValueSourceType===ml.NORMAL_VECTOR_ALPHA&&(e.fragmentShader=e.fragmentShader.replace("vec4 depthTexel = textureLod(depthTexture, vUv, 0.);","vec4 depthTexel = textureLod(normalTexture, vUv, 0.).argb;"),e.fragmentShader=e.fragmentShader.replace("vec4 depthTexel=textureLod(depthTexture,vUv,0.);","vec4 depthTexel = textureLod(normalTexture, vUv, 0.).argb;"),e.fragmentShader=e.fragmentShader.replace("textureLod(depthTexture, neighborUv, 0.0).x","textureLod(normalTexture, neighborUv, 0.0).a"),e.fragmentShader=e.fragmentShader.replace("textureLod(depthTexture,neighborUv,0.0).x","textureLod(normalTexture, neighborUv, 0.0).a")),this.rgInputTexture&&(e.fragmentShader=e.fragmentShader.replace("#define luminance(a) dot(vec3(0.2125,0.7154,0.0721),a)","#define luminance(a) (a.r*a.g)"))}):this.denoisePass=new Al(e,this._inputTexture,this.depthTexture),this.needsUpdate=!0),this.denoisePass}dispose(){var e;null===(e=this.denoisePass)||void 0===e||e.dispose()}setSize(e,t){var r;this.width=e,this.height=t,null===(r=this.denoisePass)||void 0===r||r.setSize(e,t),this.needsUpdate=!0}updateParameters(e){for(let t in e)this.parameters.hasOwnProperty(t)&&(this.parameters[t]=e[t],this.needsUpdate=!0);e.inputTexture&&(this._inputTexture=e.inputTexture,this.needsUpdate=!0),e.depthTexture&&(this.depthTexture=e.depthTexture,this.needsUpdate=!0),e.normalTexture&&(this.normalTexture=e.normalTexture,this.needsUpdate=!0)}render(e,t){const r=this.getPass(t);this.needsUpdate&&(this.needsUpdate=!1,r.iterations=this.parameters.iterations,r.samples=this.parameters.samples,r.rings=this.parameters.rings,r.radius=this.parameters.radius,r.fullscreenMaterial.uniforms.lumaPhi.value=this.parameters.lumaPhi,r.fullscreenMaterial.uniforms.depthPhi.value=this.parameters.depthPhi,r.fullscreenMaterial.uniforms.normalPhi.value=this.parameters.normalPhi,r.fullscreenMaterial.needsUpdate=!0,r.setSize(this.width,this.height),r.renderToScreen=!1,this.normalTexture?(r.fullscreenMaterial.uniforms.depthTexture.value=this.depthValueSourceType===ml.NORMAL_VECTOR_ALPHA?this.normalTexture:this.depthTexture,r.fullscreenMaterial.uniforms.normalTexture.value=this.normalTexture):r.fullscreenMaterial.uniforms.depthTexture.value=this.depthTexture),r.inputTexture=this._inputTexture,r.fullscreenMaterial.uniforms.projectionMatrixInverse.value=t.projectionMatrixInverse,r.fullscreenMaterial.uniforms.cameraMatrixWorld.value=t.matrixWorld;const n=new h;e.getClearColor(n);const a=e.getClearAlpha(),i=e.autoClear,s=e.getRenderTarget();e.autoClear=!0,e.setClearColor(16777215,1),e.setRenderTarget(this.denoisePass.renderTargetA),e.setRenderTarget(this.denoisePass.renderTargetB),e.clear(!0,!1,!1),r.render(e),e.setClearColor(n),e.setClearAlpha(a),e.setRenderTarget(s),e.autoClear=i}}var Dl,Ll;!function(e){e[e.OFF=0]="OFF",e[e.HARD=1]="HARD",e[e.POISSON=2]="POISSON",e[e.FULL=3]="FULL"}(Dl||(Dl={})),function(e){e[e.NONE=0]="NONE",e[e.SSAO=1]="SSAO",e[e.EffectsSSAO=2]="EffectsSSAO",e[e.EffectsHBAO=3]="EffectsHBAO"}(Ll||(Ll={}));const Ul={aoKernelRadius:.25,aoDepthBias:1e-4,aoMaxDistance:.5,aoMaxDepth:.99,aoFadeout:.5,shadowRadius:.1},Fl={enabled:!0,aoType:Ll.SSAO,aoIntensity:.5,shadowIntensity:.3,aoOnGround:!0,shadowOnGround:!1,alwaysUpdate:!1};class Bl{get gBufferRenderTarget(){var e;return this._sharedGBufferRenderTarget?this._sharedGBufferRenderTarget:(this._gBufferRenderTarget=null!==(e=this._gBufferRenderTarget)&&void 0!==e?e:new Xo({width:this.width,height:this.height,samples:this.samples,renderPass:this.renderPass,renderOverrideVisibility:this._renderOverrideVisibility,textureFilter:ae}),this._gBufferRenderTarget)}get SSAOEffect(){return this._ssaoEffect||(this._ssaoEffect=new Il(this.width,this.height,{normalVectorSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?pl.FLOAT_BUFFER_NORMAL:pl.INPUT_RGB_NORMAL,depthValueSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?ml.NORMAL_VECTOR_ALPHA:ml.SEPARATE_BUFFER,modulateRedChannel:!0,ssaoParameters:this.parameters.ssao})),this._ssaoEffect}get HBAOEffect(){return this._hbaoEffect||(this._hbaoEffect=new kl(this.width,this.height,{normalVectorSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?pl.FLOAT_BUFFER_NORMAL:pl.INPUT_RGB_NORMAL,depthValueSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?ml.NORMAL_VECTOR_ALPHA:ml.SEPARATE_BUFFER,modulateRedChannel:!0,hbaoParameters:this.parameters.hbao})),this._hbaoEffect}get fadeRenderTarget(){var e;return this._fadeRenderTarget=null!==(e=this._fadeRenderTarget)&&void 0!==e?e:new _t(this.width,this.height,{format:Xt,magFilter:L,minFilter:L}),this._fadeRenderTarget}get denoisePass(){return this.poissonDenoiseEffect||(this.poissonDenoiseEffect=new Ol(this.width,this.height,{inputTexture:this.shadowAndAoRenderTargets.passRenderTarget.texture,depthTexture:this.gBufferRenderTarget.depthBufferTexture,normalTexture:this.gBufferRenderTarget.gBufferTexture,normalVectorSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?pl.FLOAT_BUFFER_NORMAL:pl.INPUT_RGB_NORMAL,depthValueSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?ml.NORMAL_VECTOR_ALPHA:ml.SEPARATE_BUFFER,rgInputTexture:!0,poisonDenoiseParameters:this.parameters.poissonDenoise})),this.poissonDenoiseEffect}get denoiseRenderTargetTexture(){return this.denoisePass?this.denoisePass.texture:null}constructor(e,t,r,n){var a,i,s,o,l,h,d;this.needsUpdate=!0,this.renderPass=new Ko,this._renderOverrideVisibility=new Go(!0),this.cameraUpdate=new Vo,(null==n?void 0:n.gBufferRenderTarget)&&(this._sharedGBufferRenderTarget=null==n?void 0:n.gBufferRenderTarget),this.width=e,this.height=t,this.samples=r,this.shadowAndAoRenderTargets=new Nl(this.gBufferRenderTarget,{...n,width:e,height:t,samples:r,renderPass:this.renderPass}),this.parameters={enabled:null!==(a=null==n?void 0:n.enabled)&&void 0!==a?a:Fl.enabled,aoType:null!==(i=null==n?void 0:n.aoType)&&void 0!==i?i:Fl.aoType,aoIntensity:null!==(s=null==n?void 0:n.aoIntensity)&&void 0!==s?s:Fl.aoIntensity,shadowIntensity:null!==(o=null==n?void 0:n.shadowIntensity)&&void 0!==o?o:Fl.shadowIntensity,aoOnGround:null!==(l=null==n?void 0:n.aoOnGround)&&void 0!==l?l:Fl.aoOnGround,shadowOnGround:null!==(h=null==n?void 0:n.shadowOnGround)&&void 0!==h?h:Fl.shadowOnGround,alwaysUpdate:null!==(d=null==n?void 0:n.alwaysUpdate)&&void 0!==d?d:Fl.alwaysUpdate,shAndAo:this.shadowAndAoRenderTargets.shadowAndAoParameters,ssao:{...Pl},hbao:{...Rl},poissonDenoise:{...El}},this._copyMaterial=new Do,this._blendMaterial=new Do({},Oo.DEFAULT)}dispose(){var e,t,r,n,a,i,s;null===(e=this.gBufferRenderTarget)||void 0===e||e.dispose(),this.shadowAndAoRenderTargets.dispose(),null===(t=this._ssaoEffect)||void 0===t||t.dispose(),null===(r=this._hbaoEffect)||void 0===r||r.dispose(),null===(n=this._fadeRenderTarget)||void 0===n||n.dispose(),null===(a=this.poissonDenoiseEffect)||void 0===a||a.dispose(),null===(i=this._copyMaterial)||void 0===i||i.dispose(),null===(s=this._blendMaterial)||void 0===s||s.dispose()}setSize(e,t){var r,n,a,i,s;this.width=e,this.height=t,null===(r=this._gBufferRenderTarget)||void 0===r||r.setSize(e,t),this.shadowAndAoRenderTargets.setSize(e,t),null===(n=this._ssaoEffect)||void 0===n||n.setSize(e,t),null===(a=this._hbaoEffect)||void 0===a||a.setSize(e,t),null===(i=this._fadeRenderTarget)||void 0===i||i.setSize(e,t),null===(s=this.poissonDenoiseEffect)||void 0===s||s.setSize(this.width,this.height),this._renderOverrideVisibility=new Go,this.needsUpdate=!0}updateParameters(e){void 0!==e.enabled&&(this.parameters.enabled=e.enabled),void 0!==e.aoType&&(this.parameters.aoType=e.aoType),void 0!==e.aoIntensity&&(this.parameters.aoIntensity=e.aoIntensity),void 0!==e.shadowIntensity&&(this.parameters.shadowIntensity=e.shadowIntensity),void 0!==e.aoOnGround&&(this.parameters.aoOnGround=e.aoOnGround),void 0!==e.shadowOnGround&&(this.parameters.shadowOnGround=e.shadowOnGround),void 0!==e.alwaysUpdate&&(this.parameters.alwaysUpdate=e.alwaysUpdate),this.updatePassParameters(e)}updatePassParameters(e){var t,r,n;if(null==e?void 0:e.shAndAo)for(let t in e.shAndAo)this.parameters.shAndAo.hasOwnProperty(t)&&(this.parameters.shAndAo[t]=e.shAndAo[t],this.shadowAndAoRenderTargets.parametersNeedsUpdate=!0);(null==e?void 0:e.ssao)&&(null===(t=this._hbaoEffect)||void 0===t||t.updateParameters(null==e?void 0:e.hbao)),(null==e?void 0:e.hbao)&&(null===(r=this._ssaoEffect)||void 0===r||r.updateParameters(null==e?void 0:e.hbao)),(null==e?void 0:e.poissonDenoise)&&(null===(n=this.poissonDenoiseEffect)||void 0===n||n.updateParameters(null==e?void 0:e.poissonDenoise))}updateBounds(e,t){this.shadowAndAoRenderTargets.updateBounds(e,t)}render(e,t,r,n,a=Dl.FULL,i=Dl.FULL,s=0){if(!this.setRenderState())return;let o=!1;const l=i===Dl.POISSON&&s>.001,h=i===Dl.HARD&&s>.001&&s<.999,d=i===Dl.HARD&&!h;!d&&a===Dl.FULL&&this.evaluateIfUpdateIsNeeded(r)&&(this.renderShadowAndAo(e,t,r,n),o=!0);let c=d?n:this.denoiseRenderTargetTexture;l&&(c=this.renderDynamicShadow(e,this.shadowAndAoRenderTargets.passRenderTarget.texture,n,s),o=!0),o&&(c=this.renderDenoise(e,r,l)),h&&(c=this.renderDynamicShadow(e,this.denoiseRenderTargetTexture,n,s)),this.renderToTarget(e,c,d)}setRenderState(){return this.shadowAndAoRenderTargets.aoEnabled=this.parameters.aoType===Ll.SSAO,this.shadowAndAoRenderTargets.shadowEnabled=this.parameters.shadowIntensity>.01,!(!this.parameters.enabled||this.parameters.aoType===Ll.NONE&&!this.shadowAndAoRenderTargets.shadowEnabled||(this.needsUpdate&&(this._ssaoEffect&&(this._ssaoEffect.needsUpdate=!0),this._hbaoEffect&&(this._hbaoEffect.needsUpdate=!0),this.poissonDenoiseEffect&&(this.poissonDenoiseEffect.needsUpdate=!0)),0))}evaluateIfUpdateIsNeeded(e){e.updateProjectionMatrix();const t=this.parameters.alwaysUpdate||this.needsUpdate||null!=e&&this.cameraUpdate.changed(e);return this.needsUpdate=!1,t}renderShadowAndAo(e,t,r,n){this.shadowAndAoRenderTargets.updateShadowTexture(n),this.gBufferRenderTarget.render(e,t,r),this.shadowAndAoRenderTargets.render(e,r),this.renderAoEffect(e,t,r)}renderAoEffect(e,t,r){if(this.parameters.aoType!==Ll.EffectsSSAO&&this.parameters.aoType!==Ll.EffectsHBAO)return;const n=this.gBufferRenderTarget.depthBufferTexture,a=this.gBufferRenderTarget.gBufferTexture,i=this.shadowAndAoRenderTargets.passRenderTarget,s=e.autoClear;switch(e.autoClear=!1,this.parameters.aoType){default:break;case Ll.EffectsSSAO:{const s=this.SSAOEffect;s.depthTexture=n,s.normalTexture=a,s.render(e,r,t,i)}break;case Ll.EffectsHBAO:{const s=this.HBAOEffect;s.depthTexture=n,s.normalTexture=a,s.render(e,r,t,i)}}e.autoClear=s}renderDynamicShadow(e,t,r,n=1){const a=n<.999;return a&&(this._copyMaterial.update({texture:t,blending:ft,colorTransform:Co,multiplyChannels:0}),this.renderPass.renderScreenSpace(e,this._copyMaterial,this.fadeRenderTarget)),n>.001&&(this._blendMaterial.update({texture:r,blending:a?Gt:ft,colorTransform:(new P).set(0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,a?n:1),multiplyChannels:0}),this.renderPass.renderScreenSpace(e,this._blendMaterial,this.fadeRenderTarget)),this.fadeRenderTarget.texture}renderDenoise(e,t,r){return this.denoisePass.inputTexture=r?this.fadeRenderTarget.texture:this.shadowAndAoRenderTargets.passRenderTarget.texture,this.denoisePass.render(e,t),this.denoisePass.texture}renderToTarget(e,t,r){const n=r?this.parameters.shadowIntensity:this.parameters.aoIntensity,a=r?0:this.parameters.shadowIntensity;var i,s;this.renderPass.renderScreenSpace(e,this._copyMaterial.update({texture:t,blending:Gt,colorTransform:(i=n,s=a,(new P).set(i,0,0,1-i,0,s,0,1-s,0,0,0,1,0,0,0,1)),multiplyChannels:1}),e.getRenderTarget())}}Bl.shadowTransform=(new P).set(0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,1);class Nl{get passRenderTarget(){var e;return this._passRenderTarget=null!==(e=this._passRenderTarget)&&void 0!==e?e:new _t(this.width,this.height,{samples:this.aoTargetSamples,format:Xt,magFilter:L,minFilter:L}),this._passRenderTarget}get passRenderMaterial(){var e;return this._passRenderMaterial=null!==(e=this._passRenderMaterial)&&void 0!==e?e:new zl({normalTexture:this.depthAndNormalTextures.gBufferTexture,depthTexture:this.depthAndNormalTextures.depthBufferTexture,noiseTexture:this.noiseTexture,sampleKernel:this.sampleKernel,floatGBufferRgbNormalAlphaDepth:this.depthAndNormalTextures.isFloatGBufferWithRgbNormalAlphaDepth}),this._passRenderMaterial}get noiseTexture(){var e;return this._noiseTexture=null!==(e=this._noiseTexture)&&void 0!==e?e:(()=>{const e=new Uint8Array(64);for(let t=0;t<16;++t){const r=Math.floor(t/2)+t%2*8,n=2*Math.PI*r/16,a=new s(Math.cos(n),Math.sin(n),0).normalize();e[4*t]=255*(.5*a.x+.5),e[4*t+1]=255*(.5*a.y+.5),e[4*t+2]=127,e[4*t+3]=0}const t=new Pe(e,4,4);return t.wrapS=F,t.wrapT=F,t.needsUpdate=!0,t})(),this._noiseTexture}get sampleKernel(){return this._sampleKernel.length||(this._sampleKernel=(e=>{const t=[];for(let r=0;r<e;r++){const n=r*Math.PI*(3-Math.sqrt(5)),a=.99-r/(e-1)*.8,i=Math.sqrt(1-a*a),o=Math.cos(n)*i,l=Math.sin(n)*i,h=8,d=Math.floor(e/h);let c=1-(Math.floor(r/h)+r%h*d)/e;c=J.lerp(.1,1,c*c),t.push(new s(o*c,l*c,a*c))}return t})(zl.kernelSize)),this._sampleKernel}constructor(e,t){var r,n,a,i;this.parametersNeedsUpdate=!0,this.aoEnabled=!0,this.shadowEnabled=!0,this.shadowAndAoScale=1,this.aoTargetSamples=0,this._sampleKernel=[],this.shadowAndAoParameters=this.getShadowAndAoParameters(t),this.width=null!==(r=null==t?void 0:t.width)&&void 0!==r?r:1024,this.height=null!==(n=null==t?void 0:t.height)&&void 0!==n?n:1024,this.samples=null!==(a=null==t?void 0:t.samples)&&void 0!==a?a:0,this.depthAndNormalTextures=e,this.renderPass=null!==(i=null==t?void 0:t.renderPass)&&void 0!==i?i:new Ko}getShadowAndAoParameters(e){return{...Ul,...e}}dispose(){var e,t,r;null===(e=this._noiseTexture)||void 0===e||e.dispose(),null===(t=this._passRenderMaterial)||void 0===t||t.dispose(),null===(r=this._passRenderTarget)||void 0===r||r.dispose()}setSize(e,t){var r;this.width=e,this.height=t,null===(r=this._passRenderMaterial)||void 0===r||r.update({width:this.width,height:this.height})}updateBounds(e,t){this.shadowAndAoScale=t,this.parametersNeedsUpdate=!0}render(e,t){this.renderPass.renderScreenSpace(e,this.updateSSAOMaterial(t),this.passRenderTarget),this.parametersNeedsUpdate=!1}updateSSAOMaterial(e){const t=this.passRenderMaterial;return t.updateDependencies({width:this.width,height:this.height,camera:e}),this.parametersNeedsUpdate&&t.updateSettings({...this.shadowAndAoParameters,aoKernelRadius:this.shadowAndAoParameters.aoKernelRadius*this.shadowAndAoScale,aoMaxDistance:this.shadowAndAoParameters.aoMaxDistance*this.shadowAndAoScale,shadowRadius:this.shadowAndAoParameters.shadowRadius*this.shadowAndAoScale,aoIntensity:this.aoEnabled?1:0,shadowIntensity:this.shadowEnabled?1:0}),t}updateShadowTexture(e){this._passRenderMaterial&&(this._passRenderMaterial.uniforms.tShadow.value=e)}}class zl extends pt{constructor(e){var t,r;super({defines:Object.assign({...zl.shader.defines,KERNEL_SIZE:null!==(r=null===(t=null==e?void 0:e.sampleKernel)||void 0===t?void 0:t.length)&&void 0!==r?r:zl.kernelSize,FLOAT_GBUFFER_RGB_NORMAL_ALPHA_DEPTH:(null==e?void 0:e.floatGBufferRgbNormalAlphaDepth)?1:0}),uniforms:mt.clone(zl.shader.uniforms),vertexShader:zl.shader.vertexShader,fragmentShader:zl.shader.fragmentShader,blending:ft}),this.update(e)}update(e){return this.updateDependencies(e),this.updateSettings(e),this}updateDependencies(e){var t,r;if(void 0!==(null==e?void 0:e.shadowTexture)&&(this.uniforms.tShadow.value=null==e?void 0:e.shadowTexture),void 0!==(null==e?void 0:e.normalTexture)&&(this.uniforms.tNormal.value=null==e?void 0:e.normalTexture),void 0!==(null==e?void 0:e.depthTexture)&&(this.uniforms.tDepth.value=null==e?void 0:e.depthTexture),void 0!==(null==e?void 0:e.noiseTexture)&&(this.uniforms.tNoise.value=null==e?void 0:e.noiseTexture),(null==e?void 0:e.width)||(null==e?void 0:e.height)){const n=null!==(t=null==e?void 0:e.width)&&void 0!==t?t:this.uniforms.resolution.value.x,a=null!==(r=null==e?void 0:e.width)&&void 0!==r?r:this.uniforms.resolution.value.y;this.uniforms.resolution.value.set(n,a)}if(void 0!==(null==e?void 0:e.camera)){const t=(null==e?void 0:e.camera)||(null==e?void 0:e.camera);this.uniforms.cameraNear.value=t.near,this.uniforms.cameraFar.value=t.far,this.uniforms.cameraProjectionMatrix.value.copy(t.projectionMatrix),this.uniforms.cameraInverseProjectionMatrix.value.copy(t.projectionMatrixInverse)}void 0!==(null==e?void 0:e.sampleKernel)&&(this.uniforms.sampleKernel.value=null==e?void 0:e.sampleKernel)}updateSettings(e){void 0!==(null==e?void 0:e.aoKernelRadius)&&(this.uniforms.aoKernelRadius.value=null==e?void 0:e.aoKernelRadius),void 0!==(null==e?void 0:e.aoDepthBias)&&(this.uniforms.aoDepthBias.value=null==e?void 0:e.aoDepthBias),void 0!==(null==e?void 0:e.aoMaxDistance)&&(this.uniforms.aoMaxDistance.value=null==e?void 0:e.aoMaxDistance),void 0!==(null==e?void 0:e.aoMaxDepth)&&(this.uniforms.aoMaxDepth.value=null==e?void 0:e.aoMaxDepth),void 0!==(null==e?void 0:e.aoIntensity)&&(this.uniforms.aoIntensity.value=null==e?void 0:e.aoIntensity),void 0!==(null==e?void 0:e.aoFadeout)&&(this.uniforms.aoFadeout.value=null==e?void 0:e.aoFadeout),void 0!==(null==e?void 0:e.shadowRadius)&&(this.uniforms.shKernelRadius.value=null==e?void 0:e.shadowRadius),void 0!==(null==e?void 0:e.shadowIntensity)&&(this.uniforms.shIntensity.value=null==e?void 0:e.shadowIntensity)}}zl.kernelSize=32,zl.shader={uniforms:{tShadow:{value:null},tNormal:{value:null},tDepth:{value:null},tNoise:{value:null},sampleKernel:{value:null},cameraNear:{value:.1},cameraFar:{value:1},resolution:{value:new i},cameraProjectionMatrix:{value:new P},cameraInverseProjectionMatrix:{value:new P},aoKernelRadius:{value:.1},aoDepthBias:{value:.001},aoMaxDistance:{value:.05},aoMaxDepth:{value:.99},aoIntensity:{value:1},aoFadeout:{value:0},shKernelRadius:{value:.15},shIntensity:{value:1}},defines:{PERSPECTIVE_CAMERA:1,KERNEL_SIZE:zl.kernelSize,FLOAT_GBUFFER_RGB_NORMAL_ALPHA_DEPTH:0},vertexShader:"varying vec2 vUv;\n void main() {\n vUv = uv;\n gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n }",fragmentShader:"uniform sampler2D tShadow;\n uniform sampler2D tNormal;\n#if FLOAT_GBUFFER_RGB_NORMAL_ALPHA_DEPTH != 1 \n uniform sampler2D tDepth;\n#endif \n uniform sampler2D tNoise;\n uniform vec3 sampleKernel[KERNEL_SIZE];\n uniform vec2 resolution;\n uniform float cameraNear;\n uniform float cameraFar;\n uniform mat4 cameraProjectionMatrix;\n uniform mat4 cameraInverseProjectionMatrix;\n uniform float aoKernelRadius;\n uniform float aoDepthBias; // avoid artifacts caused by neighbour fragments with minimal depth difference\n uniform float aoMaxDistance; // avoid the influence of fragments which are too far away\n uniform float aoMaxDepth;\n uniform float aoIntensity;\n uniform float aoFadeout;\n uniform float shKernelRadius;\n uniform float shIntensity;\n \n varying vec2 vUv;\n \n #include <packing>\n \n float getDepth(const in vec2 screenPosition) {\n #if FLOAT_GBUFFER_RGB_NORMAL_ALPHA_DEPTH == 1\n return texture2D(tNormal, screenPosition).w;\n #else \n return texture2D(tDepth, screenPosition).x;\n #endif\n }\n \n float getViewZ(const in float depth) {\n #if PERSPECTIVE_CAMERA == 1\n return perspectiveDepthToViewZ(depth, cameraNear, cameraFar);\n #else\n return orthographicDepthToViewZ(depth, cameraNear, cameraFar);\n #endif\n }\n \n vec3 getViewPosition(const in vec2 screenPosition, const in float depth, const in float viewZ) {\n float clipW = cameraProjectionMatrix[2][3] * viewZ + cameraProjectionMatrix[3][3];\n vec4 clipPosition = vec4( ( vec3( screenPosition, depth ) - 0.5 ) * 2.0, 1.0 );\n clipPosition *= clipW; // unprojection.\n return ( cameraInverseProjectionMatrix * clipPosition ).xyz;\n }\n \n vec3 getViewNormal(const in vec2 screenPosition) {\n #if FLOAT_GBUFFER_RGB_NORMAL_ALPHA_DEPTH == 1\n return texture2D(tNormal, screenPosition).xyz;\n #else\n return unpackRGBToNormal(texture2D(tNormal, screenPosition).xyz);\n #endif\n }\n \n void main() {\n \n float depth = getDepth(vUv);\n float viewZ = getViewZ(depth);\n \n vec3 viewPosition = getViewPosition(vUv, depth, viewZ);\n vec3 viewNormal = getViewNormal(vUv);\n \n vec2 noiseScale = resolution.xy / 4.0;\n vec3 random = texture2D(tNoise, vUv * noiseScale).xyz * 2.0 - 1.0;\n \n // compute matrix used to reorient a kernel vector\n vec3 tangent = normalize(random - viewNormal * dot(random, viewNormal));\n vec3 bitangent = cross(viewNormal, tangent);\n mat3 kernelMatrix = mat3(tangent, bitangent, viewNormal);\n \n float aoOcclusion = 0.0;\n float shOcclusion = texture2D(tShadow, vUv).r;\n float shSamples = 0.0;\n for (int i = 0; i < KERNEL_SIZE; i ++) {\n if (aoIntensity >= 0.01 && length(viewNormal) > 0.01) {\n vec3 aoSampleVector = kernelMatrix * sampleKernel[i]; \n vec3 aoSamplePoint = viewPosition + aoSampleVector * aoKernelRadius; \n vec4 aoSamplePointNDC = cameraProjectionMatrix * vec4(aoSamplePoint, 1.0); \n aoSamplePointNDC /= aoSamplePointNDC.w;\n vec2 aoSamplePointUv = aoSamplePointNDC.xy * 0.5 + 0.5;\n float aoRealSampleDepth = getDepth(aoSamplePointUv);\n float aoSampleDeltaZ = getViewZ(aoRealSampleDepth) - aoSamplePoint.z;\n float aoRealDeltaZ = viewZ - aoSamplePoint.z;\n float w_long = clamp((aoMaxDistance - max(aoRealDeltaZ, aoSampleDeltaZ)) / aoMaxDistance, 0.0, 1.0);\n float w_lat = clamp(1.0 - length(aoSampleVector.xy), 0.0, 1.0);\n aoOcclusion += \n step(aoRealSampleDepth, aoMaxDepth) * \n step(aoDepthBias, aoSampleDeltaZ / (cameraFar - cameraNear)) * \n step(aoSampleDeltaZ, aoMaxDistance) * mix(1.0, w_long * w_lat, aoFadeout);\n }\n if (shIntensity >= 0.01 && length(viewNormal) > 0.01) {\n vec3 shSampleVector = kernelMatrix * sampleKernel[i]; // reorient sample vector in view space\n vec3 shSamplePoint = viewPosition + shSampleVector * shKernelRadius; // calculate sample point\n vec4 shSamplePointNDC = cameraProjectionMatrix * vec4(shSamplePoint, 1.0); // project point and calculate NDC\n shSamplePointNDC /= shSamplePointNDC.w;\n vec2 shSamplePointUv = shSamplePointNDC.xy * 0.5 + 0.5; // compute uv coordinates\n vec3 shSampleNormal = getViewNormal(shSamplePointUv);\n float shDeltaZ = getViewZ(getDepth(shSamplePointUv)) - shSamplePoint.z;\n float w = step(abs(shDeltaZ), shKernelRadius) * max(0.0, dot(shSampleNormal, viewNormal));\n shSamples += w;\n shOcclusion += texture2D(tShadow, shSamplePointUv).r * w;\n }\n }\n \n aoOcclusion = clamp(aoOcclusion / float(KERNEL_SIZE) * (1.0 + aoFadeout), 0.0, 1.0);\n shOcclusion = clamp(shOcclusion / (shSamples + 1.0), 0.0, 1.0);\n gl_FragColor = vec4(clamp(1.0 - aoOcclusion, 0.0, 1.0), shOcclusion, 0.0, 1.0);\n }"};class Hl{get reflectionRenderTarget(){var e;return this._reflectionRenderTarget=null!==(e=this._reflectionRenderTarget)&&void 0!==e?e:this.newRenderTarget(!0),this._reflectionRenderTarget}get intensityRenderTarget(){var e;return this._intensityRenderTarget=null!==(e=this._intensityRenderTarget)&&void 0!==e?e:this.newRenderTarget(!1),this._intensityRenderTarget}get blurRenderTarget(){var e;return this._blurRenderTarget=null!==(e=this._blurRenderTarget)&&void 0!==e?e:this.newRenderTarget(!1),this._blurRenderTarget}constructor(e,t,r){var n;this.width=e,this.height=t,this.parameters={enabled:!1,intensity:.25,fadeOutDistance:1,fadeOutExponent:4,brightness:1,blurHorizontal:3,blurVertical:6,blurAscent:0,groundLevel:0,groundReflectionScale:1,renderTargetDownScale:4,...r},this._copyMaterial=new Do({}),this.updateCopyMaterial(null),this.reflectionIntensityMaterial=new jl,this.blurPass=new Wo(Lo,r),this.renderPass=null!==(n=null==r?void 0:r.renderPass)&&void 0!==n?n:new Ko}newRenderTarget(e){const t=this.width/this.parameters.renderTargetDownScale,r=this.height/this.parameters.renderTargetDownScale;let n={};if(e){const e=new xt(t,r);e.format=St,e.type=Ct,n.minFilter=ae,n.magFilter=ae,n.depthTexture=e}else n.samples=1;return new _t(t,r,{format:Ae,...n})}dispose(){var e,t,r;null===(e=this._reflectionRenderTarget)||void 0===e||e.dispose(),null===(t=this._intensityRenderTarget)||void 0===t||t.dispose(),null===(r=this._blurRenderTarget)||void 0===r||r.dispose(),this._copyMaterial.dispose()}setSize(e,t){var r,n,a;this.width=e,this.height=t,null===(r=this._reflectionRenderTarget)||void 0===r||r.setSize(this.width/this.parameters.renderTargetDownScale,this.height/this.parameters.renderTargetDownScale),null===(n=this._intensityRenderTarget)||void 0===n||n.setSize(this.width/this.parameters.renderTargetDownScale,this.height/this.parameters.renderTargetDownScale),null===(a=this._blurRenderTarget)||void 0===a||a.setSize(this.width/this.parameters.renderTargetDownScale,this.height/this.parameters.renderTargetDownScale)}updateParameters(e){for(let t in e)this.parameters.hasOwnProperty(t)&&(this.parameters[t]=e[t])}updateBounds(e,t){this.parameters.groundLevel=e,this.parameters.groundReflectionScale=t}updateCopyMaterial(e,t=1){var r;const n=this.parameters.intensity*t,a=this.parameters.brightness;this._copyMaterial.update({texture:null!==(r=null==e?void 0:e.texture)&&void 0!==r?r:void 0,colorTransform:(new P).set(a,0,0,0,0,a,0,0,0,0,a,0,0,0,0,n),multiplyChannels:0,uvTransform:ko}),this._copyMaterial.depthTest=!0,this._copyMaterial.depthWrite=!1}render(e,t,r,n=1){if(!(this.parameters.enabled&&r instanceof Z))return;const a=this.createGroundReflectionCamera(r);this.renderGroundReflection(e,t,a,this.reflectionRenderTarget),this.renderGroundReflectionIntensity(e,a,this.intensityRenderTarget),(this.parameters.blurHorizontal>0||this.parameters.blurVertical>0)&&this.blurReflection(e,r,[this.intensityRenderTarget,this.blurRenderTarget,this.intensityRenderTarget]),this.updateCopyMaterial(this.intensityRenderTarget,n),this.renderPass.renderScreenSpace(e,this._copyMaterial,e.getRenderTarget())}renderGroundReflection(e,t,r,n){const a=e.getRenderTarget();n&&e.setRenderTarget(n),e.render(t,r),n&&e.setRenderTarget(a)}renderGroundReflectionIntensity(e,t,r){const n=e.getRenderTarget();e.setRenderTarget(r),this.renderPass.renderScreenSpace(e,this.reflectionIntensityMaterial.update({texture:this.reflectionRenderTarget.texture,depthTexture:this.reflectionRenderTarget.depthTexture,camera:t,groundLevel:this.parameters.groundLevel,fadeOutDistance:this.parameters.fadeOutDistance*this.parameters.groundReflectionScale,fadeOutExponent:this.parameters.fadeOutExponent}),e.getRenderTarget()),e.setRenderTarget(n)}blurReflection(e,t,r){const n=new s(t.matrixWorld.elements[4],t.matrixWorld.elements[5],t.matrixWorld.elements[6]),a=this.parameters.blurHorizontal/this.width,i=this.parameters.blurVertical/this.height*Math.abs(n.dot(new s(0,0,1)));this.blurPass.render(e,r,[4*a,4*i],[4*a*(1+this.parameters.blurAscent),4*i*(1+this.parameters.blurAscent)])}createGroundReflectionCamera(e){const t=e.clone(),r=t;return r._offset&&(r._offset={left:r._offset.left,top:1-r._offset.bottom,right:r._offset.right,bottom:1-r._offset.top}),t.position.set(e.position.x,-e.position.y+2*this.parameters.groundLevel,e.position.z),t.rotation.set(-e.rotation.x,e.rotation.y,-e.rotation.z),t.updateMatrixWorld(),t.updateProjectionMatrix(),t}}class jl extends pt{constructor(e){super({defines:Object.assign({},jl.shader.defines),uniforms:mt.clone(jl.shader.uniforms),vertexShader:jl.shader.vertexShader,fragmentShader:jl.shader.fragmentShader,blending:ft}),this.update(e)}update(e){if(void 0!==(null==e?void 0:e.texture)&&(this.uniforms.tDiffuse.value=null==e?void 0:e.texture),void 0!==(null==e?void 0:e.depthTexture)&&(this.uniforms.tDepth.value=null==e?void 0:e.depthTexture),void 0!==(null==e?void 0:e.camera)){const t=(null==e?void 0:e.camera)||(null==e?void 0:e.camera);this.uniforms.cameraNear.value=t.near,this.uniforms.cameraFar.value=t.far,this.uniforms.cameraProjectionMatrix.value.copy(t.projectionMatrix),this.uniforms.cameraInverseProjectionMatrix.value.copy(t.projectionMatrixInverse),this.uniforms.inverseViewMatrix.value.copy(t.matrixWorld)}return void 0!==(null==e?void 0:e.groundLevel)&&(this.uniforms.groundLevel.value=null==e?void 0:e.groundLevel),void 0!==(null==e?void 0:e.fadeOutDistance)&&(this.uniforms.fadeOutDistance.value=null==e?void 0:e.fadeOutDistance),void 0!==(null==e?void 0:e.fadeOutExponent)&&(this.uniforms.fadeOutExponent.value=null==e?void 0:e.fadeOutExponent),this}}jl.shader={uniforms:{tDiffuse:{value:null},tDepth:{value:null},resolution:{value:new i},cameraNear:{value:.1},cameraFar:{value:1},cameraProjectionMatrix:{value:new P},cameraInverseProjectionMatrix:{value:new P},inverseViewMatrix:{value:new P},groundLevel:{value:0},fadeOutDistance:{value:1},fadeOutExponent:{value:1}},defines:{PERSPECTIVE_CAMERA:1,LINEAR_TO_SRGB:1},vertexShader:"\n varying vec2 vUv;\n void main() {\n vUv = uv;\n gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\n }",fragmentShader:"\n uniform sampler2D tDiffuse;\n uniform sampler2D tDepth;\n uniform vec2 resolution;\n uniform float cameraNear;\n uniform float cameraFar;\n uniform mat4 cameraProjectionMatrix;\n uniform mat4 cameraInverseProjectionMatrix;\n uniform mat4 inverseViewMatrix;\n uniform float groundLevel;\n uniform float fadeOutDistance;\n uniform float fadeOutExponent;\n varying vec2 vUv;\n\n #include <packing>\n\n float getDepth(const in vec2 screenPosition) {\n return texture2D(tDepth, screenPosition).x;\n }\n\n float getLinearDepth(const in vec2 screenPosition) {\n #if PERSPECTIVE_CAMERA == 1\n float fragCoordZ = texture2D(tDepth, screenPosition).x;\n float viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\n return viewZToOrthographicDepth(viewZ, cameraNear, cameraFar);\n #else\n return texture2D(tDepth, screenPosition).x;\n #endif\n }\n\n float getViewZ(const in float depth) {\n #if PERSPECTIVE_CAMERA == 1\n return perspectiveDepthToViewZ(depth, cameraNear, cameraFar);\n #else\n return 0.0;//orthographicDepthToViewZ(depth, cameraNear, cameraFar);\n #endif\n }\n\n vec3 getViewPosition(const in vec2 screenPosition, const in float depth, const in float viewZ ) {\n float clipW = cameraProjectionMatrix[2][3] * viewZ + cameraProjectionMatrix[3][3];\n vec4 clipPosition = vec4((vec3(screenPosition, depth) - 0.5) * 2.0, 1.0);\n clipPosition *= clipW;\n return (cameraInverseProjectionMatrix * clipPosition).xyz;\n }\n\n void main() {\n float depth = getDepth(vUv);\n float viewZ = getViewZ(depth);\n vec4 worldPosition = inverseViewMatrix * vec4(getViewPosition(vUv, depth, viewZ), 1.0);\n float distance = worldPosition.y - groundLevel;\n vec4 fragColor = texture2D(tDiffuse, vUv).rgba;\n #if LINEAR_TO_SRGB == 1\n fragColor.rgb = mix(fragColor.rgb * 12.92, 1.055 * pow(fragColor.rgb, vec3(0.41666)) - 0.055, step(0.0031308, fragColor.rgb));\n #endif\n float fadeOutAlpha = pow(clamp(1.0 - distance / fadeOutDistance, 0.0, 1.0), fadeOutExponent);\n fragColor.a *= fadeOutAlpha;\n gl_FragColor = (depth < 0.9999) ? fragColor : vec4(0.0);\n }"};const Vl=e=>{const t=Math.atan2(e.y,e.x)/(2*Math.PI)+.5,r=Math.asin(e.z)/Math.PI+.5;return new i(t,r)};class Gl{get colorRenderTarget(){var e;return this._colorRenderTarget=null!==(e=this._colorRenderTarget)&&void 0!==e?e:new _t,this._colorRenderTarget}get grayscaleRenderTarget(){var e;return this._grayscaleRenderTarget=null!==(e=this._grayscaleRenderTarget)&&void 0!==e?e:new _t,this._grayscaleRenderTarget}get grayscaleShaderMaterial(){var e;return this._grayscaleShaderMaterial=null!==(e=this._grayscaleShaderMaterial)&&void 0!==e?e:new Wl,this._grayscaleShaderMaterial}get camera(){var e;return this._camera=null!==(e=this._camera)&&void 0!==e?e:new $(-1,1,1,-1,-1,1),this._camera}scaleTexture(e,t,r,n){var a;this.colorRenderTarget.setSize(r,n),this.planeMesh=null!==(a=this.planeMesh)&&void 0!==a?a:new K(new Mt(2,2),new C({map:t}));const i=e.getRenderTarget();e.setRenderTarget(this.colorRenderTarget),e.render(this.planeMesh,this.camera),e.setRenderTarget(i);const s=this.grayscaleRenderTarget.texture,o=new Uint8Array(r*n*4);return e.readRenderTargetPixels(this.colorRenderTarget,0,0,r,n,o),{texture:s,pixels:o}}newGrayscaleTexture(e,t,r,n){var a;this.grayscaleRenderTarget.setSize(r,n),this.grayscaleShaderMaterial.setSourceTexture(t),this.planeMesh=null!==(a=this.planeMesh)&&void 0!==a?a:new K(new Mt(2,2),this.grayscaleShaderMaterial);const i=e.getRenderTarget();e.setRenderTarget(this.grayscaleRenderTarget),e.render(this.planeMesh,this.camera),e.setRenderTarget(i);const s=this.grayscaleRenderTarget.texture,o=new Uint8Array(r*n*4);return e.readRenderTargetPixels(this.grayscaleRenderTarget,0,0,r,n,o),{texture:s,pixels:o}}}const Kl={tDiffuse:{value:null}};class Wl extends pt{constructor(){super({uniforms:mt.clone(Kl),vertexShader:"\n varying vec2 vUv;\n void main() {\n vUv = uv;\n gl_Position = (projectionMatrix * modelViewMatrix * vec4(position, 1.0)).xyww;\n }",fragmentShader:"\n uniform sampler2D tDiffuse;\n varying vec2 vUv;\n void main() {\n vec4 color = texture2D(tDiffuse, vUv);\n float grayscale = dot(color.rgb, vec3(0.2126, 0.7152, 0.0722));\n //float grayscale = dot(color.rgb, vec3(1.0/3.0));\n gl_FragColor = vec4(vec3(grayscale), 1.0);\n }"})}setSourceTexture(e){this.uniforms.tDiffuse.value=e}}class Xl{constructor(e){var t,r,n,a;this.samplePoints=[],this.sampleUVs=[],this.grayscaleTexture={texture:new fe,pixels:new Uint8Array(0)},this.detectorTexture=new fe,this.detectorArray=new Float32Array(0),this.lightSamples=[],this.lightGraph=new Ql(0),this.lightSources=[],this.createEquirectangularSamplePoints=e=>{const t=[];for(let r=0;r<e;r++){const n=r*Math.PI*(3-Math.sqrt(5)),a=1-r/(e-1)*2,i=Math.sqrt(1-a*a),o=Math.cos(n)*i,l=Math.sin(n)*i;t.push(new s(o,l,a))}return t},this.numberOfSamples=null!==(t=null==e?void 0:e.numberOfSamples)&&void 0!==t?t:1e3,this.width=null!==(r=null==e?void 0:e.width)&&void 0!==r?r:1024,this.height=null!==(n=null==e?void 0:e.height)&&void 0!==n?n:512,this.sampleThreshold=null!==(a=null==e?void 0:e.sampleThreshold)&&void 0!==a?a:.707,this.pointDistance=Math.sqrt(4*Math.PI)/Math.sqrt(this.numberOfSamples),this.pixelDistance=Math.sqrt(2)*Math.PI*2/this.width,this.samplePoints=this.createEquirectangularSamplePoints(this.numberOfSamples),this.sampleUVs=this.samplePoints.map(e=>Vl(e))}detectLightSources(e,t,r){var n;this.textureData=r,this.textureConverter=null!==(n=this.textureConverter)&&void 0!==n?n:new Gl,this.grayscaleTexture=this.textureConverter.newGrayscaleTexture(e,t,this.width,this.height),this.detectorArray=this.redFromRgbaToNormalizedFloatArray(this.grayscaleTexture.pixels),this.detectorTexture=this.grayscaleTextureFromFloatArray(this.detectorArray,this.width,this.height),this.lightSamples=this.filterLightSamples(this.sampleThreshold),this.lightGraph=this.findClusterSegments(this.lightSamples,this.sampleThreshold),this.lightGraph.findConnectedComponents(),this.lightSources=this.createLightSourcesFromLightGraph(this.lightSamples,this.lightGraph),this.lightSources.sort((e,t)=>t.maxIntensity-e.maxIntensity)}redFromRgbaToNormalizedFloatArray(e,t){const r=new Float32Array(e.length/4);let n=1,a=0;for(let t=0;t<e.length/4;++t){const i=e[4*t]/255;n=Math.min(n,i),a=Math.max(a,i),r[t]=i}if(t)for(let e=0;e<r.length;++e){const i=(r[e]-n)/(a-n);r[e]=Math.pow(i,t)}else for(let e=0;e<r.length;++e)r[e]=(r[e]-n)/(a-n);return r}grayscaleTextureFromFloatArray(e,t,r){const n=t*r,a=new Uint8Array(4*n);for(let t=0;t<n;t++){const r=255*e[t];a[4*t+0]=r,a[4*t+1]=r,a[4*t+2]=r,a[4*t+3]=255}const i=new Pe(a,t,r);return i.needsUpdate=!0,i}filterLightSamples(e){const t=[];for(let r=0;r<this.sampleUVs.length;r++){const n=this.sampleUVs[r];this.detectorTextureLuminanceValueFromUV(n)>e&&t.push(new ql(this.samplePoints[r],n))}return t}detectorTextureLuminanceValueFromUV(e){const t=Math.floor(e.x*this.width),r=Math.floor(e.y*this.height)*this.width+t;return this.detectorArray[r]}originalLuminanceValueFromUV(e){if(!(this.textureData&&this.textureData.data&&this.textureData.width&&this.textureData.height))return 256*this.detectorTextureLuminanceValueFromUV(e);const t=Math.floor(e.x*this.textureData.width),r=Math.floor(e.y*this.textureData.height);let n=0;for(let e=Math.max(0,t-2);e<Math.max(0,t+2);++e)for(let t=Math.max(0,r-2);t<Math.max(0,r+2);++t){const r=t*this.textureData.width+e,a=(this.textureData.data[4*r]+this.textureData.data[4*r+1]+this.textureData.data[4*r+2])/3;n=Math.max(n,a)}return n}findClusterSegments(e,t){const r=2*this.pixelDistance,n=1.5*this.pointDistance,a=new Ql(e.length);for(let i=0;i<e.length;i++)for(let s=i+1;s<e.length;s++)if(e[i].position.angleTo(e[s].position)<n){const n=e[s].position.clone().sub(e[i].position),o=Math.floor(n.length()/r);let l=!0,h=0;for(let r=1;r<o;r++){const a=n.clone().multiplyScalar(r/o),s=Vl(e[i].position.clone().add(a).normalize());if(this.detectorTextureLuminanceValueFromUV(s)<t){if(h++,h>1){l=!1;break}}else h=0}l&&(a.adjacent[i].push(s),a.adjacent[s].push(i),a.edges.push([i,s]))}return a}createLightSourcesFromLightGraph(e,t){const r=t.components.filter(e=>e.length>1).map(t=>new Yl(t.map(t=>e[t])));return r.forEach(e=>e.calculateLightSourceProperties(e=>this.originalLuminanceValueFromUV(e))),r}}class ql{constructor(e,t){this.position=e,this.uv=t}}class Ql{constructor(e){this.edges=[],this.adjacent=[],this.components=[],this.noOfNodes=e;for(let t=0;t<e;t++)this.adjacent.push([])}findConnectedComponents(){const e=new Array(this.noOfNodes).fill(!1);this.components=[];for(let t=0;t<this.noOfNodes;t++)if(!e[t]){const r=[];this.dfs(t,e,r),this.components.push(r)}this.components.sort((e,t)=>t.length-e.length)}dfs(e,t,r){t[e]=!0,r.push(e);for(const n of this.adjacent[e])t[n]||this.dfs(n,t,r)}}class Yl{constructor(e){this.position=new s,this.uv=new i,this.averageIntensity=0,this.maxIntensity=0,this.size=0,this.lightSamples=e}calculateLightSourceProperties(e){this.position=new s,this.averageIntensity=0,this.maxIntensity=0;for(const t of this.lightSamples){this.position.add(t.position);const r=e(t.uv);this.averageIntensity+=r,this.maxIntensity=Math.max(this.maxIntensity,r)}this.averageIntensity/=this.lightSamples.length,this.position.normalize(),this.uv=Vl(this.position);let t=0;for(const e of this.lightSamples)t+=e.position.distanceTo(this.position);t/=this.lightSamples.length,this.size=t/Math.PI}}class Zl{constructor(e){this.grayMaterial=_n.createMeshStandardMaterial({color:12632256,side:j,envMapIntensity:.4}),this.renderPass=new Ko,this._sceneRenderer=e}get gBufferRenderTarget(){return this._sceneRenderer.gBufferRenderTarget}get screenSpaceShadow(){return this._sceneRenderer.screenSpaceShadow}get shadowAndAoPass(){return this._sceneRenderer.shadowAndAoPass}get groundReflectionPass(){return this._sceneRenderer.groundReflectionPass}get bakedGroundContactShadow(){return this._sceneRenderer.bakedGroundContactShadow}dispose(){var e,t;null===(e=this.depthRenderMaterial)||void 0===e||e.dispose(),null===(t=this.copyMaterial)||void 0===t||t.dispose(),this.grayMaterial.dispose()}getCopyMaterial(e){var t;return this.copyMaterial=null!==(t=this.copyMaterial)&&void 0!==t?t:new Do,this.copyMaterial.update(e)}getDepthRenderMaterial(e){var t;return this.depthRenderMaterial=null!==(t=this.depthRenderMaterial)&&void 0!==t?t:new Uo({depthTexture:this.gBufferRenderTarget.textureWithDepthValue,depthFilter:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?new ct(0,0,0,1):new ct(1,0,0,0)}),this.depthRenderMaterial.update({camera:e})}render(e,t,r){var n,a,i,s;switch(r){default:break;case"lineardepth":this.renderPass.renderScreenSpace(e,this.getDepthRenderMaterial(t),null);break;case"g-normal":this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:null===(n=this.gBufferRenderTarget)||void 0===n?void 0:n.gBufferTexture,blending:ft,colorTransform:(new P).set(.5,0,0,0,0,.5,0,0,0,0,.5,0,0,0,0,0),colorBase:new ct(.5,.5,.5,1),multiplyChannels:0,uvTransform:Io}),null):this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:null===(a=this.gBufferRenderTarget)||void 0===a?void 0:a.gBufferTexture,blending:ft,colorTransform:Mo,colorBase:Eo,multiplyChannels:0,uvTransform:Io}),null);break;case"g-depth":this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:null===(i=this.gBufferRenderTarget)||void 0===i?void 0:i.gBufferTexture,blending:ft,colorTransform:To,colorBase:Eo,multiplyChannels:0,uvTransform:Io}),null):this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:null===(s=this.gBufferRenderTarget)||void 0===s?void 0:s.depthBufferTexture,blending:ft,colorTransform:Ao,colorBase:Eo,multiplyChannels:0,uvTransform:Io}),null);break;case"ssao":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.shadowAndAoPass.shadowAndAoRenderTargets.passRenderTarget.texture,blending:ft,colorTransform:Po,colorBase:Ro,multiplyChannels:0,uvTransform:Io}),null);break;case"ssaodenoise":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.shadowAndAoPass.denoiseRenderTargetTexture,blending:ft,colorTransform:Po,colorBase:Ro,multiplyChannels:0,uvTransform:Io}),null);break;case"shadowmap":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.screenSpaceShadow.shadowTexture,blending:ft,colorTransform:Po,colorBase:Ro,multiplyChannels:0,uvTransform:Io}),null);break;case"shadow":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.shadowAndAoPass.shadowAndAoRenderTargets.passRenderTarget.texture,blending:ft,colorTransform:Bl.shadowTransform,colorBase:Ro,multiplyChannels:0,uvTransform:Io}),null);break;case"shadowblur":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.shadowAndAoPass.denoiseRenderTargetTexture,blending:ft,colorTransform:Bl.shadowTransform,colorBase:Ro,multiplyChannels:0,uvTransform:Io}),null);break;case"shadowfadein":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.shadowAndAoPass.fadeRenderTarget.texture,blending:ft,colorTransform:Bl.shadowTransform,colorBase:Ro,multiplyChannels:0,uvTransform:Io}),null);break;case"groundreflection":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.groundReflectionPass.reflectionRenderTarget.texture,blending:ft,colorTransform:Co,colorBase:Ro,multiplyChannels:0,uvTransform:ko}),null);break;case"bakedgroundshadow":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.bakedGroundContactShadow.renderTarget.texture,blending:ft,colorTransform:Co,colorBase:Ro,multiplyChannels:0,uvTransform:Io}),null)}}}var Jl;!function(e){e[e.HIGHEST=0]="HIGHEST",e[e.HIGH=1]="HIGH",e[e.MEDIUM=2]="MEDIUM",e[e.LOW=3]="LOW"}(Jl||(Jl={}));class $l{constructor(e,t,r){this.debugOutput="off",this.prevDebugOutput="off",this.outputColorSpace="",this.toneMapping="",this.environmentLights=!1,this.movingCamera=!1,this.groundLevel=0,this.uiInteractionMode=!1,this.noUpdateNeededCount=0,this.cameraUpdate=new Vo,this.width=0,this.height=0,this.maxSamples=1,this.cameraChanged=!0,this.boundingVolume=new jo,this.boundingVolumeSet=!1,this.debugRenderOverrideVisibility=new Go(!0),this.invisibleGroundOverrideVisibility=new Go(!0,e=>e===this.groundGroup),this.renderPass=new Ko,this.selectedObjects=[],this.groundGroup=new Y,this.qualityLevel=Jl.HIGHEST,this.qualityMap=new Map,this.width=t,this.height=r,this.maxSamples=e.capabilities.maxSamples,this.renderer=e,this.gBufferRenderTarget=new Xo({shared:!0,capabilities:e.capabilities,width:this.width,height:this.height,samples:1,renderPass:this.renderPass,textureFilter:ae}),this.shadowAndAoPass=new Bl(this.width,this.height,1,{gBufferRenderTarget:this.gBufferRenderTarget}),this.screenSpaceShadow=new sl(new i(this.width,this.height),{samples:this.maxSamples,alwaysUpdate:!1}),this.groundReflectionPass=new Hl(this.width,this.height,{renderPass:this.renderPass}),this.bakedGroundContactShadow=new qo(this.renderer,this.groundGroup,{renderPass:this.renderPass}),this.groundGroup.rotateX(-Math.PI/2),this.outlineRenderer=new el(null,this.width,this.height,{gBufferRenderTarget:this.gBufferRenderTarget}),this.parameters={gBufferRenderTargetParameters:this.gBufferRenderTarget.parameters,bakedGroundContactShadowParameters:this.bakedGroundContactShadow.parameters,screenSpaceShadowMapParameters:this.screenSpaceShadow.parameters,shAndAoPassParameters:this.shadowAndAoPass.parameters,groundReflectionParameters:this.groundReflectionPass.parameters,outlineParameters:this.outlineRenderer.parameters,effectSuspendFrames:0,effectFadeInFrames:0,suspendGroundReflection:!1,shadowOnCameraChange:Dl.OFF},this.addEventListeners(this.renderer)}addEventListeners(e){e.domElement.addEventListener("webglcontextlost",()=>{}),e.domElement.addEventListener("webglcontextrestored",()=>{this.forceEnvironmentMapUpdate(this.renderer)})}dispose(){var e,t;null===(e=this.debugPass)||void 0===e||e.dispose(),null===(t=this.copyMaterial)||void 0===t||t.dispose(),this.gBufferRenderTarget.dispose(),this.screenSpaceShadow.dispose(),this.shadowAndAoPass.dispose(),this.outlineRenderer.dispose(),this.renderer.dispose()}setSize(e,t){this.width=e,this.height=t,this.gBufferRenderTarget.setSize(e,t),this.screenSpaceShadow.setSize(e,t),this.shadowAndAoPass.setSize(e,t),this.outlineRenderer.setSize(e,t),this.groundReflectionPass.setSize(e,t),this.renderer.setSize(e,t)}getQualityLevel(){return this.qualityLevel}setQualityLevel(e){this.qualityLevel!==e&&(this.qualityMap.has(this.qualityLevel)&&(this.qualityLevel=e),this.applyCurrentParameters())}setQualityMap(e){this.qualityMap=e,this.applyCurrentParameters()}applyCurrentParameters(){this.qualityMap.has(this.qualityLevel)&&(this.updateParameters(this.qualityMap.get(this.qualityLevel)),this.bakedGroundContactShadow.applyParameters()),this.uiInteractionMode&&this.updateParameters({groundReflectionParameters:{enabled:!1}})}forceShadowUpdates(e){this.gBufferRenderTarget.needsUpdate=!0,this.shadowAndAoPass.needsUpdate=!0,this.screenSpaceShadow.needsUpdate=!0,e&&(this.bakedGroundContactShadow.needsUpdate=!0)}updateParameters(e){void 0!==e.shAndAoPassParameters&&this.shadowAndAoPass.updateParameters(e.shAndAoPassParameters),void 0!==e.effectParameters&&this.shadowAndAoPass.updateParameters({effectParameters:e.effectParameters}),void 0!==e.bakedGroundContactShadowParameters&&this.bakedGroundContactShadow.updateParameters(e.bakedGroundContactShadowParameters),void 0!==e.screenSpaceShadowMapParameters&&this.screenSpaceShadow.updateParameters(e.screenSpaceShadowMapParameters),void 0!==e.groundReflectionParameters&&this.groundReflectionPass.updateParameters(e.groundReflectionParameters),void 0!==e.outlineParameters&&this.outlineRenderer.updateParameters(e.outlineParameters),void 0!==e.effectSuspendFrames&&(this.parameters.effectSuspendFrames=e.effectSuspendFrames),void 0!==e.effectFadeInFrames&&(this.parameters.effectFadeInFrames=e.effectFadeInFrames),void 0!==e.suspendGroundReflection&&(this.parameters.suspendGroundReflection=e.suspendGroundReflection),void 0!==e.shadowOnCameraChange&&(this.parameters.shadowOnCameraChange=e.shadowOnCameraChange)}getCopyMaterial(e){var t;return this.copyMaterial=null!==(t=this.copyMaterial)&&void 0!==t?t:new Do,this.copyMaterial.update(e)}addRectAreaLight(e,t){this.environmentLights=!1,this.screenSpaceShadow.addRectAreaLight(e,t),this.shadowAndAoPass.needsUpdate=!0}updateRectAreaLights(e,t){e.length>0&&(this.environmentLights=!1),this.screenSpaceShadow.updateRectAreaLights(e,t),this.shadowAndAoPass.needsUpdate=!0}createShadowFromEnvironmentMap(e,t,r){const n=new Xl;n.detectLightSources(this.renderer,t,r),this.createShadowFromLightSources(e,n.lightSources)}createShadowFromLightSources(e,t){this.environmentLights=!0,this.screenSpaceShadow.createShadowFromLightSources(e,t),this.shadowAndAoPass.needsUpdate=!0}selectObjects(e){this.selectedObjects=e}updateBounds(e,t){this.boundingVolumeSet=!0,this.boundingVolume.updateFromBox(e);const r=this.boundingVolume.size,n=(r.x+r.y+r.z)/3,a=Math.min(r.x,r.y,r.z),i=Math.max(r.x,r.y,r.z),s=a<.5?a/.5:r.z>5?r.z/5:1;this.bakedGroundContactShadow.setScale(t?n:s,n),this.groundReflectionPass.updateBounds(this.groundLevel,Math.min(1,i)),this.screenSpaceShadow.updateBounds(this.boundingVolume,n),this.shadowAndAoPass.updateBounds(this.boundingVolume,t?n:Math.min(1,2*i))}updateNearAndFarPlaneOfPerspectiveCamera(e,t){const r=this.boundingVolume.getNearAndFarForPerspectiveCamera(e.position,3);e.near=Math.max(1e-5,.9*r[0]),e.far=Math.max(null!=t?t:e.near,r[1]),e.updateProjectionMatrix()}setRenderState(e,t){var r;const n=this.debugOutput!==this.prevDebugOutput;this.prevDebugOutput=this.debugOutput,this.screenSpaceShadow.parameters.alwaysUpdate=this.shadowAndAoPass.parameters.alwaysUpdate,this.cameraChanged=this.cameraUpdate.changed(t),(r=this.gBufferRenderTarget).needsUpdate||(r.needsUpdate=this.cameraChanged||n)}forceEnvironmentMapUpdate(e){const t=e.userData;if(null==t?void 0:t.environmentTexture){const e=t.environmentTexture;t.environmentTexture=void 0,e.dispose()}}updateEnvironment(e,t){var r;if(!(null===(r=t.userData)||void 0===r?void 0:r.equirectangularEnvironmentMap))return;e.userData||(e.userData={});const n=e.userData;if(n&&(!n.environmentTexture||n.equirectangularEnvironmentMap!==t.userData.equirectangularEnvironmentMap)){n.equirectangularEnvironmentMap=t.userData.equirectangularEnvironmentMap;const r=new qt(e).fromEquirectangular(n.equirectangularEnvironmentMap);n.environmentTexture=r.texture}t.environment=null==n?void 0:n.environmentTexture}render(e,t){e.add(this.groundGroup),this.setRenderState(e,t),this.updateEnvironment(this.renderer,e),this.outlineRenderer.updateOutline(e,t,this.movingCamera?[]:this.selectedObjects),this.renderer.setRenderTarget(null),this.renderGroundContactShadow(e),"color"!==this.debugOutput?(this.renderScene(this.renderer,e,t),this.renderOutline(),this.renderDebug(t),e.remove(this.groundGroup)):this.renderer.render(e,t)}renderGroundContactShadow(e){this.bakedGroundContactShadow.needsUpdate&&this.bakedGroundContactShadow.updateBounds(this.boundingVolume,this.groundLevel),this.bakedGroundContactShadow.render(e)}renderDebug(e){var t;this.debugOutput&&""!==this.debugOutput&&"off"!==this.debugOutput&&(this.debugPass=null!==(t=this.debugPass)&&void 0!==t?t:new Zl(this),this.debugPass.render(this.renderer,e,this.debugOutput))}renderScene(e,t,r){var n;const a=new Set;t.traverse(e=>{var t;(null===(t=e.userData)||void 0===t?void 0:t.isFloor)&&e instanceof K&&e.material instanceof H&&e.material.depthWrite&&(a.add(e.material),e.material.depthWrite=!1)}),"grayscale"===this.debugOutput?(this.debugPass=null!==(n=this.debugPass)&&void 0!==n?n:new Zl(this),this.debugRenderOverrideVisibility.render(t,()=>{var n;this.renderPass.renderWithOverrideMaterial(e,t,r,null===(n=this.debugPass)||void 0===n?void 0:n.grayMaterial,null,0,1)})):(this.bakedGroundContactShadow.setGroundVisibility(!0,r),e.render(t,r),this.bakedGroundContactShadow.setGroundVisibility(!1,r)),a.forEach(e=>e.depthWrite=!0),this.renderShadowAndAo(e,t,r)}renderShadowAndAo(e,t,r){const n=this.evaluateIfShadowAndAoUpdateIsNeeded(r);if(n.needsUpdate||n.shadowOnCameraChange!==Dl.OFF){if(!this.parameters.suspendGroundReflection||n.needsUpdate){const a=this.parameters.suspendGroundReflection?n.intensityScale:1;this.renderGroundReflection(e,t,r,a)}this.gBufferRenderTarget.needsUpdate=n.needsUpdate||n.shadowOnCameraChange===Dl.POISSON,this.renderEffectsWithGround(e,t,r),this.renderEffectsWithoutGround(e,t,r),this.shadowAndAoPass.render(e,t,r,this.screenSpaceShadow.shadowTexture,n.needsUpdate?Dl.FULL:n.shadowOnCameraChange,n.shadowOnCameraChange,1-n.intensityScale)}}evaluateIfShadowAndAoUpdateIsNeeded(e){const t=this.shadowAndAoPass.parameters.alwaysUpdate||this.screenSpaceShadow.needsUpdate||this.screenSpaceShadow.shadowTypeNeedsUpdate;let r=(this.shadowAndAoPass.parameters.enabled||this.groundReflectionPass.parameters.enabled)&&(0===this.parameters.effectSuspendFrames||this.cameraChanged);r&&(this.noUpdateNeededCount=0);let n=1;return!t&&this.parameters.effectSuspendFrames>0&&(this.noUpdateNeededCount++,r=this.noUpdateNeededCount>=this.parameters.effectSuspendFrames,n=Math.max(0,Math.min(1,(this.noUpdateNeededCount-this.parameters.effectSuspendFrames)/this.parameters.effectFadeInFrames))),r=t||r,{needsUpdate:r,shadowOnCameraChange:!r||n<.99?this.parameters.shadowOnCameraChange:Dl.OFF,intensityScale:n}}renderGroundReflection(e,t,r,n=1){this.groundReflectionPass.parameters.enabled&&this.invisibleGroundOverrideVisibility.render(t,()=>{this.groundReflectionPass.render(e,t,r,n)})}renderEffectsWithGround(e,t,r){const n=this.boundingVolumeSet&&this.shadowAndAoPass.parameters.aoOnGround,a=this.shadowAndAoPass.parameters.shadowIntensity>0&&this.boundingVolumeSet&&this.shadowAndAoPass.parameters.shadowOnGround,i=this.bakedGroundContactShadow.shadowGroundPlane;if(n){const n=null===this.bakedGroundContactShadow.parameters.hardLayers;n&&i.setDepthWrite(!0),this.gBufferRenderTarget.render(e,t,r),n&&i.setDepthWrite(!1)}a&&(i.setReceiveShadow(!0),this.screenSpaceShadow.renderShadowMap(e,t,r),i.setReceiveShadow(!1))}renderEffectsWithoutGround(e,t,r){const n=!this.boundingVolumeSet||!this.shadowAndAoPass.parameters.aoOnGround,a=this.shadowAndAoPass.parameters.shadowIntensity>0&&(!this.boundingVolumeSet||!this.shadowAndAoPass.parameters.shadowOnGround);(n||a)&&this.invisibleGroundOverrideVisibility.render(t,()=>{n&&this.gBufferRenderTarget.render(e,t,r),a&&this.screenSpaceShadow.renderShadowMap(e,t,r)})}renderOutline(){if(this.outlineRenderer.outlinePassActivated&&this.outlineRenderer.outlinePass){const e=this.renderer.getClearColor(new h),t=this.renderer.getClearAlpha();"outline"===this.debugOutput&&(this.renderer.setClearColor(0,255),this.renderer.clear(!0,!1,!1)),this.outlineRenderer.outlinePass.renderToScreen=!1,this.outlineRenderer.outlinePass.render(this.renderer,null,null,0,!1),"outline"===this.debugOutput&&this.renderer.setClearColor(e,t)}}}class eh{constructor(e){this.qualityLevel="",this.ambientOcclusionType="",this.sceneRenderer=e}addGUI(e,t){this.addRepresentationalGUI(e,t),this.addDebugGUI(e,t);const r=e.addFolder("Shadow type");this.addShadowTypeGUI(r,t);const n=e.addFolder("Shadow and Ambient Occlusion");this.addShadowAndAoGUI(n,t);const a=e.addFolder("Ground Reflection");this.addGroundReflectionGUI(a,t);const i=e.addFolder("Baked Ground Contact Shadow");this.addBakedGroundContactShadowGUI(i,t);const s=e.addFolder("Outline");this.addOutlineGUI(s,t)}addRepresentationalGUI(e,t){const r=new Map([["LinearSRGBColorSpace",Ce],["SRGBColorSpace",M]]),n=[];r.forEach((e,t)=>{n.push(t),this.sceneRenderer.renderer.outputColorSpace===e&&(this.sceneRenderer.outputColorSpace=t)}),e.add(this.sceneRenderer,"outputColorSpace",n).onChange(e=>{var n;r.has(e)&&(this.sceneRenderer.renderer.outputColorSpace=null!==(n=r.get(e))&&void 0!==n?n:M,t())});const a=new Map([["NoToneMapping",Qt],["LinearToneMapping",Yt],["ReinhardToneMapping",Zt],["CineonToneMapping",Jt],["ACESFilmicToneMapping",$t]]),i=[];a.forEach((e,t)=>{i.push(t),this.sceneRenderer.renderer.toneMapping===e&&(this.sceneRenderer.toneMapping=t)}),e.add(this.sceneRenderer,"toneMapping",i).onChange(e=>{var r;a.has(e)&&(this.sceneRenderer.renderer.toneMapping=null!==(r=a.get(e))&&void 0!==r?r:Qt,t())})}addDebugGUI(e,t){const r=new Map([["HIGHEST",Jl.HIGHEST],["HIGH",Jl.HIGH],["MEDIUM",Jl.MEDIUM],["LOW",Jl.LOW]]),n=[];r.forEach((e,t)=>n.push(t)),e.add(this,"qualityLevel",n).onChange(e=>{var t;r.has(e)&&this.sceneRenderer.setQualityLevel(null!==(t=r.get(e))&&void 0!==t?t:Jl.HIGHEST)}),e.add(this.sceneRenderer,"debugOutput",{"off ":"off","grayscale (no textures)":"grayscale","color buffer":"color","linear depth":"lineardepth","g-buffer normal vector":"g-normal","g-buffer depth":"g-depth","AO pure":"ssao","AO denoised":"ssaodenoise","shadow map":"shadowmap","shadow Monte Carlo":"shadow","shadow blur":"shadowblur","shadow fade in":"shadowfadein","ground reflection":"groundreflection","baked ground shadow":"bakedgroundshadow","selection outline":"outline"}).onChange(()=>t())}addShadowTypeGUI(e,t){const r=this.sceneRenderer.screenSpaceShadow.shadowConfiguration,n=[];r.types.forEach((e,t)=>{n.push(t)});const a=()=>{this.sceneRenderer.screenSpaceShadow.needsUpdate=!0,this.sceneRenderer.screenSpaceShadow.shadowTypeNeedsUpdate=!0,this.sceneRenderer.shadowAndAoPass.needsUpdate=!0,t()};e.add(r,"shadowType",n).onChange(e=>{this.sceneRenderer.screenSpaceShadow.switchType(e)&&(i.object=r.currentConfiguration,s.object=r.currentConfiguration,o.object=r.currentConfiguration,i.updateDisplay(),s.updateDisplay(),o.updateDisplay(),a())});const i=e.add(r.currentConfiguration,"bias",-.001,.001,1e-5).onChange(()=>a()),s=e.add(r.currentConfiguration,"normalBias",-.05,.05).onChange(()=>a()),o=e.add(r.currentConfiguration,"radius",0,100).onChange(()=>a())}addShadowAndAoGUI(e,t){const r=()=>{this.sceneRenderer.gBufferRenderTarget.needsUpdate=!0,this.sceneRenderer.screenSpaceShadow.needsUpdate=!0,this.sceneRenderer.shadowAndAoPass.needsUpdate=!0,this.sceneRenderer.shadowAndAoPass.shadowAndAoRenderTargets.parametersNeedsUpdate=!0,t()},n=this.sceneRenderer.shadowAndAoPass.parameters,a=n.shAndAo,i=this.sceneRenderer.screenSpaceShadow.parameters,s=n.ssao,o=n.hbao,l=n.poissonDenoise;e.add(n,"enabled").onChange(()=>r());const h=new Map([["none",Ll.NONE],["SSAO",Ll.SSAO],["effects SSAO",Ll.EffectsSSAO],["effects HBAO",Ll.EffectsHBAO]]),d=Array.from(h.keys());h.forEach((e,t)=>{e===n.aoType&&(this.ambientOcclusionType=t)}),e.add(this,"ambientOcclusionType",d).onChange(e=>{var t;h.has(e)&&(n.aoType=null!==(t=h.get(e))&&void 0!==t?t:Ll.SSAO,r())}),e.add(n,"aoIntensity",0,1).onChange(()=>{r()}),e.add(n,"aoOnGround").onChange(()=>{r()}),e.add(n,"shadowOnGround").onChange(()=>{r()}),e.add(n,"shadowIntensity",0,1).onChange(()=>r()),e.add(n,"alwaysUpdate").onChange(()=>r());const c=e.addFolder("Shadow and Monte Carlo integration");c.add(i,"maximumNumberOfLightSources").onChange(()=>r()),c.add(i,"fadeOutDistance",0,1).onChange(()=>r()),c.add(i,"fadeOutBlur",0,100).onChange(()=>r()),c.add(a,"shadowRadius",.001,.5).onChange(()=>r());const u=e.addFolder("Roomle SSAO");u.add(a,"aoFadeout",0,1).onChange(()=>r()),u.add(a,"aoKernelRadius",.001,1).onChange(()=>r()),u.add(a,"aoDepthBias",1e-4,.01).onChange(()=>r()),u.add(a,"aoMaxDistance",.01,1).onChange(()=>r()),u.add(a,"aoMaxDepth",.9,1).onChange(()=>r());const p=e.addFolder("effects SSAO");p.add(s,"resolutionScale",.25,1,.25).onChange(()=>r()),p.add(s,"spp",1,64,1).onChange(()=>r()),p.add(s,"distance",.1,10,.1).onChange(()=>r()),p.add(s,"distancePower",0,2,.125).onChange(()=>r()),p.add(s,"bias",0,500,1).onChange(()=>r()),p.add(s,"power",.5,32,.5).onChange(()=>r()),p.add(s,"thickness",0,.1,.001).onChange(()=>r());const m=e.addFolder("effects HBAO");m.add(o,"resolutionScale",.25,1,.2).onChange(()=>r()),m.add(o,"spp",1,64,1).onChange(()=>r()),m.add(o,"distance",.1,10,.01).onChange(()=>r()),m.add(o,"distancePower",.1,10,.1).onChange(()=>r()),m.add(o,"bias",0,100,1).onChange(()=>r()),m.add(o,"power",.5,8,.5).onChange(()=>r()),m.add(o,"thickness",0,.1,.001).onChange(()=>r());const f=e.addFolder("Possion Denoise");f.add(l,"iterations",0,3,1).onChange(()=>r()),f.add(l,"radius",0,32,1).onChange(()=>r()),f.add(l,"rings",0,16,.125).onChange(()=>r()),f.add(l,"samples",0,32,1).onChange(()=>r()),f.add(l,"lumaPhi",0,20,.001).onChange(()=>r()),f.add(l,"depthPhi",0,20,.001).onChange(()=>r()),f.add(l,"normalPhi",0,20,.001).onChange(()=>r())}addGroundReflectionGUI(e,t){const r=this.sceneRenderer.parameters.groundReflectionParameters;e.add(r,"enabled"),e.add(r,"intensity",0,1).onChange(()=>t()),e.add(r,"fadeOutDistance",0,4).onChange(()=>t()),e.add(r,"fadeOutExponent",.1,10).onChange(()=>t()),e.add(r,"brightness",0,2).onChange(()=>t()),e.add(r,"blurHorizontal",0,10).onChange(()=>t()),e.add(r,"blurVertical",0,10).onChange(()=>t())}addBakedGroundContactShadowGUI(e,t){const r=()=>{this.sceneRenderer.bakedGroundContactShadow.applyParameters(),t()},n=this.sceneRenderer.parameters.bakedGroundContactShadowParameters;e.add(n,"enabled"),e.add(n,"cameraHelper").onChange(()=>r()),e.add(n,"alwaysUpdate"),e.add(n,"fadeIn"),e.add(n,"blurMin",0,.2,.001).onChange(()=>r()),e.add(n,"blurMax",0,.5,.01).onChange(()=>r()),e.add(n,"fadeoutFalloff",0,1,.01).onChange(()=>r()),e.add(n,"fadeoutBias",0,.5).onChange(()=>r()),e.add(n,"opacity",0,1,.01).onChange(()=>r()),e.add(n,"cameraFar",.1,10,.1).onChange(()=>r())}addOutlineGUI(e,t){const r=()=>{this.sceneRenderer.outlineRenderer.applyParameters(),t()},n=this.sceneRenderer.outlineRenderer.parameters;e.add(n,"enabled"),e.add(n,"edgeStrength",.5,20).onChange(()=>r()),e.add(n,"edgeGlow",0,20).onChange(()=>r()),e.add(n,"edgeThickness",.5,20).onChange(()=>r()),e.add(n,"pulsePeriod",0,5).onChange(()=>r()),e.addColor(n,"visibleEdgeColor").onChange(()=>r()),e.addColor(n,"hiddenEdgeColor").onChange(()=>r())}}const th={effectSuspendFrames:0,effectFadeInFrames:0,suspendGroundReflection:!1,shadowOnCameraChange:Dl.FULL},rh={effectSuspendFrames:5,effectFadeInFrames:5,suspendGroundReflection:!1,shadowOnCameraChange:Dl.POISSON},nh={effectSuspendFrames:5,effectFadeInFrames:5,suspendGroundReflection:!0,shadowOnCameraChange:Dl.HARD},ah=e("a4",new Map([[Jl.HIGHEST,{...th,shAndAoPassParameters:{enabled:!0,aoOnGround:!0,shadowOnGround:!0},groundReflectionParameters:{enabled:!0},bakedGroundContactShadowParameters:{enabled:!1}}],[Jl.HIGH,{...rh,shAndAoPassParameters:{enabled:!0,aoOnGround:!0,shadowOnGround:!0},groundReflectionParameters:{enabled:!0},bakedGroundContactShadowParameters:{enabled:!1}}],[Jl.MEDIUM,{...nh,shAndAoPassParameters:{enabled:!0,aoOnGround:!0,shadowOnGround:!0},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:{enabled:!1}}],[Jl.LOW,{shAndAoPassParameters:{enabled:!1,aoOnGround:!1,shadowOnGround:!1},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:{enabled:!0}}]])),ih=new er;ih.enable(3);const sh=new er;sh.disableAll(),sh.enable(9);const oh={enabled:!0,aoType:Ll.SSAO,aoIntensity:.5,shadowIntensity:0,aoOnGround:!0,shadowOnGround:!1},lh={enabled:!0,aoType:Ll.EffectsHBAO,aoIntensity:.5,shadowIntensity:0,aoOnGround:!0,shadowOnGround:!1},hh=lh,dh={enabled:!0,fadeoutFalloff:.9,blurMax:.1,opacity:.5,hardLayers:null,softLayers:null,polygonOffset:2},ch={enabled:!0,fadeoutFalloff:.8,blurMax:.15,opacity:.5,hardLayers:sh,softLayers:null,polygonOffset:-1},uh={enabled:!1},ph=new Map([[Jl.HIGHEST,{...th,shAndAoPassParameters:oh,screenSpaceShadowMapParameters:{layers:ih},groundReflectionParameters:{enabled:!0},bakedGroundContactShadowParameters:dh}],[Jl.HIGH,{...rh,shAndAoPassParameters:oh,screenSpaceShadowMapParameters:{layers:ih},groundReflectionParameters:{enabled:!0},bakedGroundContactShadowParameters:dh}],[Jl.MEDIUM,{...nh,shAndAoPassParameters:oh,screenSpaceShadowMapParameters:{layers:ih},groundReflectionParameters:{enabled:!0},bakedGroundContactShadowParameters:dh}],[Jl.LOW,{shAndAoPassParameters:{enabled:!1,aoOnGround:!1,shadowOnGround:!1},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:dh}]]),mh=new Map([[Jl.HIGHEST,{...th,shAndAoPassParameters:lh,screenSpaceShadowMapParameters:{layers:ih},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:ch}],[Jl.HIGH,{...rh,shAndAoPassParameters:lh,screenSpaceShadowMapParameters:{layers:ih},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:ch}],[Jl.MEDIUM,{...nh,shAndAoPassParameters:lh,screenSpaceShadowMapParameters:{layers:ih},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:ch}],[Jl.LOW,{shAndAoPassParameters:{enabled:!1,aoOnGround:!1,shadowOnGround:!1},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:ch}]]),fh=new Map([[Jl.HIGHEST,{...th,shAndAoPassParameters:hh,screenSpaceShadowMapParameters:{layers:ih},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:uh}],[Jl.HIGH,{...rh,shAndAoPassParameters:hh,screenSpaceShadowMapParameters:{layers:ih},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:uh}],[Jl.MEDIUM,{...nh,shAndAoPassParameters:hh,screenSpaceShadowMapParameters:{layers:ih},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:uh}],[Jl.LOW,{shAndAoPassParameters:{enabled:!1,aoOnGround:!1,shadowOnGround:!1},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:uh}]]);class gh{constructor(){this._index=0,this._prevTime=0,this._frames=0,this._fps=-1,this._fpsList=Array(2).fill(0),this._prevTime=(performance||Date).now(),this.reset()}update(){this._frames++;const e=(performance||Date).now();e>=this._prevTime+1e3&&(this._fpsList[this._index%2]=1e3*this._frames/(e-this._prevTime),this._index>=2&&(this._fps=this._fpsList.reduce((e,t)=>e+t)/this._fpsList.length),this._prevTime=e,this._frames=0,this._index++)}start(){this._prevTime=(performance||Date).now(),this._frames=0}reset(){this._fps=-1,this._fpsList=Array(2).fill(0),this._index=0}getFps(){return this._fps}}var vh;e("ad",vh),function(e){e[e.Mode3D=0]="Mode3D",e[e.Mode2D=1]="Mode2D"}(vh||e("ad",vh={}));class wh{get renderer(){return this._renderer}get shadowAndAoPassParameters(){return this.sceneRenderer.shadowAndAoPass.parameters}get bakedGroundContactShadowParameters(){return this.sceneRenderer.bakedGroundContactShadow.parameters}get groundReflectionParameters(){return this.sceneRenderer.groundReflectionPass.parameters}get outlineParameters(){return this.sceneRenderer.outlineRenderer.parameters}constructor(e,t,r){this.configuratorMode=!0,this.uiInteractionMode=!0,this._renderer=e,this.sceneRenderer=new $l(this._renderer,t,r),this.outlineParameters.enabled=!0,this.outlineParameters.edgeStrength=2,this.outlineParameters.edgeGlow=1,this.outlineParameters.edgeThickness=2,this.outlineParameters.pulsePeriod=0,this.outlineParameters.usePatternTexture=!1,this.outlineParameters.visibleEdgeColor=16777215,this.outlineParameters.hiddenEdgeColor=16777215,wh.enableRectAreaLightShadow&&(or.rectAreaLightReplacement=!1,or.rectAreaLightLoadingListener=this.loadRectAreLight),this.sceneRenderer.setQualityLevel(Jl.HIGHEST),this.SceneRendererGUI=new eh(this.sceneRenderer)}dispose(){this.sceneRenderer.dispose()}setSize(e,t){this.sceneRenderer.setSize(e,t)}setAutoQuality(e){!this._fpsCounter&&e?this._fpsCounter=new gh:this._fpsCounter&&!e&&(this._fpsCounter=null)}setQualityLevel(e){this.sceneRenderer.setQualityLevel(e)}setQualityMap(e){this.sceneRenderer.setQualityMap(e)}enableUiInteractionMode(){this.sceneRenderer.uiInteractionMode=!0,this.sceneRenderer.applyCurrentParameters()}disableUiInteractionMode(){this.sceneRenderer.uiInteractionMode=!1,this.sceneRenderer.applyCurrentParameters()}loadRectAreLight(e){wh.rectAreaLightsNeedsUpdate=!0}updateRectAreaLight(e){let t=[];e.traverse(e=>{e instanceof o&&t.push(e)}),this.sceneRenderer.updateRectAreaLights(t,e),wh.rectAreaLightsNeedsUpdate=!1}forceShadowUpdates(e){this.sceneRenderer.forceShadowUpdates(e)}switchToConfigurator(){this.configuratorMode=!0,this.sceneRenderer.setQualityMap(ph)}switchToPlanner(e){vh.Mode3D,this.configuratorMode=!1,e===vh.Mode3D?this.sceneRenderer.setQualityMap(mh):this.sceneRenderer.setQualityMap(fh)}updateBounds(e){this.sceneRenderer.updateBounds(e,!1)}updateEnvironment(e,t=!1){e&&this.updateBounds(e)}movingCameraStarts(){var e;this.sceneRenderer.movingCamera=!0,null===(e=this._fpsCounter)||void 0===e||e.start()}movingCameraStops(){this.sceneRenderer.movingCamera=!1}highlightObjects(e){this.sceneRenderer.selectObjects(e)}render(e,t){var r;wh.rectAreaLightsNeedsUpdate&&this.updateRectAreaLight(e),t.updateMatrixWorld(),(t instanceof Z||t instanceof $)&&t.updateProjectionMatrix();const n=wh.updateNearAndFarPlaneOfPerspectiveCamera?this.createRenderCamera(t):t;if(this.sceneRenderer.render(e,n),this.sceneRenderer.movingCamera&&this._fpsCounter){null===(r=this._fpsCounter)||void 0===r||r.update();const e=this.sceneRenderer.getQualityLevel(),t=this._fpsCounter.getFps();t>0&&t<30&&e<3&&(this.sceneRenderer.setQualityLevel(e+1),this._fpsCounter.reset())}}createRenderCamera(e){const t=e.clone();return this.configuratorMode&&t instanceof Z&&(this.sceneRenderer.updateNearAndFarPlaneOfPerspectiveCamera(t,120),t.updateProjectionMatrix()),t}showGUI(e){const t=Qa();this.SceneRendererGUI.addGUI(t,e)}createShadowFromEnvironmentMap(e,t,r){this.sceneRenderer.createShadowFromEnvironmentMap(e,t,r)}}e("a3",wh),wh.enableRectAreaLightShadow=!0,wh.rectAreaLightsNeedsUpdate=!1,wh.updateNearAndFarPlaneOfPerspectiveCamera=!1;class bh{_getRoomleRenderer(){if(!this._roomleRenderer){const e=new tr({antialias:!0,alpha:!0});e.outputColorSpace=M,e.autoClear=!0,e.setSize(1024,1024),e.outputColorSpace=M,e.autoClear=!1,e.shadowMap.enabled=!0,e.shadowMap.type=Ut,this._roomleRenderer=new wh(e,1024,1024),this._roomleRenderer.setQualityMap(ah),this._roomleRenderer.setSize(1024,1024)}return this._roomleRenderer}setEnvMap(e,t){this._getRoomleRenderer().createShadowFromEnvironmentMap(e,t)}switchToPlannerSettings(){this._getRoomleRenderer().switchToPlanner(vh.Mode3D)}switchToConfiguratorSettings(){this._getRoomleRenderer().switchToConfigurator()}static getCameraTargetForBBox(e,t=0){if(!e){const e=new s;return{center:e,bounds:e,diagonal:0}}const r=e.getSize(new s);return r.addScalar(t),{center:e.getCenter(new s),bounds:r,diagonal:Math.sqrt(Math.pow(r.x,2)+Math.pow(r.y,2)+Math.pow(r.z,2))}}preparePerspectiveImage(e,t,r,n,a={},i=0){return new Promise(s=>{const{size:o=1024,showDimensions:l}=a,h=this._getRoomleRenderer();h.setSize(o,o);const d=e.fog?e.fog.clone():null,c=e.background?e.background.clone():null;e.background=null,e.fog=null,r.layers.disable(2),r.layers.disable(6),r.layers.disable(5),l?r.layers.enable(8):r.layers.disable(8);const u=-30+Cn(i);bh.placeCameraForPerspectiveImage(r,n,-20,u);const p=this._render(h,e,t,r);r.layers.enable(2),r.layers.enable(6),r.layers.enable(5),e.background=c,e.fog=d,s({image:p,width:o,height:o,blob:null})})}renderPerspectiveImage(e,t,r,n){return new Promise(a=>{n||(n=1024);const i=this._getRoomleRenderer();i.setSize(n,n);const s=e.fog?e.fog.clone():null,o=e.background?e.background.clone():null;e.background=null,e.fog=null,t.layers.disable(2),t.layers.disable(6),t.layers.disable(5),r?bh.placeCameraForPerspectiveImage(t,r,-20,-30):(t.aspect=1,t.updateProjectionMatrix());const l=this._render(i,e,null,t);t.layers.enable(2),t.layers.enable(6),t.layers.enable(5),e.background=o,e.fog=s,a({image:l,width:n,height:n,blob:null})})}static placeCameraForPerspectiveImage(e,t,r,n){e.far=1e3,e.fov=15,e.aspect=1,e.position.copy(t.center),e.rotation.set(0,0,0),e.rotateY(Sn(n)),e.rotateX(Sn(r)),e.translateZ(3.8*t.diagonal),e.updateProjectionMatrix()}prepareTopImage(e,t,r,n={}){const{showDimensions:a=!1}=n;return new Promise(n=>{const i=this._getRoomleRenderer();let s=new $(-r.bounds.x/2,r.bounds.x/2,r.bounds.z/2,-r.bounds.z/2,.5);s.position.copy(r.center),s.rotateX(Sn(-90)),s.translateZ(r.bounds.y+1),s.far=s.position.y+.5,s.layers.mask=65535;let o=200*r.bounds.x,l=200*r.bounds.z;if(o>4096||l>4096){let e=0;o>4096?e=o/4096:l>4096&&(e=l/4096),o/=e,l/=e}i.setSize(o,l);let h=e.fog?e.fog.clone():null,d=e.background?e.background.clone():null;e.background=null,e.fog=null,s.layers.disable(2),s.layers.disable(6),s.layers.disable(5),a?s.layers.enable(8):s.layers.disable(8);const c=this._render(i,e,t,s);s.layers.enable(2),s.layers.enable(6),s.layers.enable(5),e.background=d,e.fog=h,n({image:c,width:o,height:l,blob:null})})}_render(e,t,r,n){return e.forceShadowUpdates(!0),e.render(t,n),e.render(t,n),r&&(e.renderer.autoClear=!1,e.renderer.clearDepth(),e.renderer.render(r,n),e.renderer.autoClear=!0),e.renderer.domElement.toDataURL()}}e("r",bh);const yh=e("I",[new nr("error-handler",class{constructor(){this._listeners={}}_subscribe(e,t){this._listeners[e]||(this._listeners[e]=[]),this._listeners[e].push(t)}subscribe(e,t){this._subscribe(e,t)}dispatch(e,t){if(!this._listeners[e])return;const r=this._listeners[e];let n=r.length;for(let e=0;e<n;e++){const n=r[e];n.apply(n,t)}}unsubscribe(e,t){if(!this._listeners[e])return;const r=this._listeners[e];let n=r.length;for(let e=0;e<n;e++)if(r[e]===t)return r.splice(e,1),n--,void e--}softReject(e,t,r){return this.dispatch(r,[t]),e()}}),new nr("form-data-util",ir),new nr("hdr-environment-loader",class{constructor(e){this._creator_=e;const t=new h("#DDDDDD");this._environmentMap=((e,t,r,n)=>{const a=new Te;a.format=Ae,a.generateMipmaps=!1;for(let n=0;n<6;++n){const i=ja(e,t,r,1);i.format=a.format,i.type=a.type,i.minFilter=a.minFilter,i.magFilter=a.magFilter,i.generateMipmaps=a.generateMipmaps,i.needsUpdate=!0,a.images[n]=i}return a.needsUpdate=!0,a})(t.r,t.g,t.b)}async loadUrl(e,t){const r=t.toLowerCase();this._environmentMap=r.endsWith(".exr")?await this._loadExr(t):await this._loadRgbe(t),this._environmentMap.mapping=dt;const n={url:t,environmentMap:this._environmentMap};return this._envChangedCallback(n),n}_loadExr(e){var t;return this._exrLoader=null!==(t=this._exrLoader)&&void 0!==t?t:new _o,this._exrLoader.setPath(e.startsWith("http")?"":r()),this._exrLoader.loadAsync(e)}_loadRgbe(e){var t;return this._rgbeLoader=null!==(t=this._rgbeLoader)&&void 0!==t?t:new xo,this._rgbeLoader.setPath(e.startsWith("http")?"":r()),this._rgbeLoader.loadAsync(e)}registerEnvironmentChangedCallback(e){this._envChangedCallback=e}}),new nr("static-item-loader",class{constructor(e){this._gltfLoaderGuard=new Sr,this._creator_=e,this._initLoaders()}_initLoaders(){this._gltfLoader=new Tr;const e=new wn,t=e._loadLibrary.bind(e._loadLibrary);e._loadLibrary=(e,n)=>{const a=yn[e];if(!a)throw new Error('Can not load draco dependency "'+e+'" did three.js update DracoLoader lib? Available files'+JSON.stringify(yn));return t(r()+a,n)},e.setDecoderConfig({type:"wasm"}),this._gltfLoader.setDRACOLoader(e),this._gltfLoaderGuard.resolve(this._gltfLoader)}async loadGLB(e,t,r,n,a,i,s,o){return await this._gltfLoaderGuard.wait(),new Promise((l,h)=>{this._gltfLoader.load(e,e=>{l(this._handleGLTFScene("GLB",e,t,r,n,a,i,s))},e=>{o&&o(e.loaded/e.total)},e=>{h(e)})})}async loadGLTF(e,t,r,n,a,i,s,o){return await this._gltfLoaderGuard.wait(),new Promise((l,h)=>{this._gltfLoader.parse(e,null,e=>{l(this._handleGLTFScene("GLTF",e,t,r,n,a,i,s))},e=>{o&&o(e.loaded/e.total)},e=>{h(e)})})}_handleGLTFScene(e,t,r,n,a,i,o,l){if(!t||!t.scene||!t.scene.children||0===t.scene.children.length)return null;r&&t.scene.position.copy(r),n&&(t.scene.rotation.y=n);const d=new be;if(d.setFromObject(t.scene),a){const{x:e,y:r,z:n}=d.getSize(new s);let i=new s(a.x/e,a.y/r,a.z/n);t.scene.scale.copy(i)}return i&&t.scene.scale.multiply(i),t.scene.type=e,t.scene.traverse(e=>{if(e instanceof K){if(e.layers.set(3),e.material instanceof H){const t=e.material;if(l&&o&&o>0){let e=new h(o);t.color=e.copySRGBToLinear(e),t.roughness=.5,t.metalness=.1}t.needsUpdate=!0,t.envMapIntensity=_n.getEnvMapIntensity()}e.castShadow=!0,e.receiveShadow=!0}}),{boundingBox:d,scene:t.scene}}},0),new nr("form-data-util",ir),new nr("single-promise-factory",class{constructor(e){this._promises=new Map,this._creator_=e}create(e,t,r){return new Promise((n,a)=>{let i=this._promises.get(e),s=!0;if(!i){const t=new Map;this._promises.set(e,t),i=this._promises.get(e),s=!1}i.get(t)||(i.set(t,[]),s=!1);const o=i.get(t);o.push({resolve:n,reject:a}),i.set(t,o);const l=()=>{i.delete(t),0===i.size&&this._promises.delete(e)};s||new Promise(r).then(e=>{i.get(t).forEach(({resolve:t})=>t(e)),l()},e=>{i.get(t).forEach(({reject:t})=>t(e)),l()})})}},1),new nr("dynamic-light-setting-loader",or),new nr("network-layer",ur),new nr("local-storage",class{constructor(e){this._context_=e}get _localStorage(){let e=null;try{e=window.localStorage}catch(e){console.error(e)}return e}getItem(e){if(!this._localStorage)return null;const t=this._localStorage.getItem(e);try{return JSON.parse(t)}catch(e){return t}}setItem(e,t){if(this._localStorage)try{const r=JSON.stringify(t);this._localStorage.setItem(e,r)}catch(e){console.error(e)}}}),new nr("network-layer",ur),new nr("kernel-io",vr,0),new nr("data-syncer",xr),new nr("memory-manager",class{constructor(){this._configurationStringSet=new Set,this._singleLoadCounter=0}loadingConfigurationString(){this._singleLoadCounter+=1}loadingConfiguration(e){this._configurationStringSet.add(e),this._singleLoadCounter+=1}shouldHardReset(){return this._configurationStringSet.size>=15||this._singleLoadCounter>=30}executedHardReset(){this._configurationStringSet.clear(),this._singleLoadCounter=0}}),new nr("life-cycle-manager",class{constructor(){this._listeners=[]}addEventListener(e){this._listeners.push(e)}removeEventListener(e){const t=this._listeners;let r=t.length;if(r)for(let n=0;n<r;n++)t[n]===e&&(t.splice(n,1),n--,r--)}pause(){this._listeners.forEach(e=>e.pause())}resume(){this._listeners.forEach(e=>e.resume())}destroy(){this._listeners.forEach(e=>e.destroy())}},1),new nr("local-storage-helper",xn),new nr("cache-holder",class{constructor(){this._componentCache=new Map,this._geometryCache=new Map,this._materialCache=new Map}get componentCache(){return this._componentCache}get geometryCache(){return this._geometryCache}get materialCache(){return this._materialCache}clear(){for(const e of this._componentCache.values())Ja(e);for(const e of this._materialCache.values())ti(e);for(const e of this._geometryCache.values())ei(e);this._componentCache.clear(),this._geometryCache.clear(),this._materialCache.clear()}},0),new nr("kernel-access-callback",class{constructor(e){this._callbackListener=new Set,this._creator_=e}addListener(e){this._callbackListener.add(e)}removeListener(e){this._callbackListener.delete(e)}isReady(){this._callbackListener.forEach(e=>e.isReady())}loadError(e){this._callbackListener.forEach(t=>t.loadError(e))}},1),new nr("configurator-kernel-access-callback",class{constructor(e){this._callbackListener=new Set,this._creator_=e}addListener(e){this._callbackListener.add(e)}removeListener(e){this._callbackListener.delete(e)}isReady(){this._callbackListener.forEach(e=>e.isReady())}updatePossibleChildren(e,t,r){this._callbackListener.forEach(n=>n.updatePossibleChildren(e,t,r))}updateParameters(e,t,r,n){this._callbackListener.forEach(a=>a.updateParameters(e,t,r,n))}loadError(e){this._callbackListener.forEach(t=>t.loadError(e))}},1),new nr("configurator-context",class{constructor(){this.planObjectId=0,this.planElementId=0,this.rootComponentId=0,this.dockingRootComponentId=0,this.baseContext=null,this.rootComponentParametersAsGlobal=!1,this.lastLoadedRapiId=null,this.selectedRuntimeComponentIds=[],this.selectionMode="standard"}get selectedRuntimeComponentId(){return this.selectedRuntimeComponentIds.length>0?this.selectedRuntimeComponentIds[0]:null}},1),new nr("init-data",li,1),new nr("global-init-data",di,0),new nr("global-callback",ui,0),new nr("dom-helper",pi,1),new nr("unit-formatter",Ks,0),new nr("plugin-system",mi,1),new nr("configurator-mesh-generator",vi),new nr("configurator-input-manager",class extends Si{},1),new nr("selection-handler",class extends wi{constructor(){super(...arguments),this._selectionMode="standard",this._selectedComponents=new Map}check(e){"standard"===this._selectionMode&&this._checkStandard(e),"multiselect"===this._selectionMode&&this._checkMulti(e)}cancelSelection(){0!==this._selectedComponents.size&&this._selectedComponents.forEach((e,t)=>{e.deselect(),this._selectedComponents.delete(t),this.dispatchEvent(1,new Ci({component:e}))})}_checkStandard(e){this._selectedComponents.has(e.runtimeId)?this.dispatchEvent(0,new Ci({component:e,consecutive:!0})):(this._selectedComponents.size>0&&this._selectedComponents.forEach((e,t)=>{this._selectedComponents.delete(t),this.dispatchEvent(1,new Ci({component:e,resetCamera:!1}))}),this._selectedComponents.set(e.runtimeId,e),this.dispatchEvent(0,new Ci({component:e,consecutive:!1})))}_checkMulti(e){if(this._selectedComponents.has(e.runtimeId))return this._selectedComponents.delete(e.runtimeId),void this.dispatchEvent(1,new Ci({component:e,resetCamera:0===this._selectedComponents.size}));this._selectedComponents.set(e.runtimeId,e),this.dispatchEvent(0,new Ci({component:e}))}setSelectionMode(e){this._selectionMode=e}getSelectionMode(){return this._selectionMode}hasSelection(){return this._selectedComponents.size>0}getSelectedRuntimeComponentIds(){let e=[];return this._selectedComponents.forEach(t=>e.push(t.runtimeId)),e}isSelected(e){return this._selectedComponents.has(e.runtimeId)}},1),new nr("component-dimensioning-helper",ki,1),new nr("component-dimensioning-helper",ki,1),new nr("planner-kernel-access",Ns),new nr("planner-mesh-generator",zs,1),new nr("unit-formatter",Ks),new nr("configurator-history",Ws,1),new nr("roomle-planner-ui-callback",class extends ci{constructor(e){super(e),this.onItemsLoaded=()=>{},this.onCameraChanged=e=>{},this.onCameraIdle=()=>{},this.onTotalFloorAreaChanged=e=>{},this.onPlanInteractionHandlerCreated=e=>{},this.onPlannerKernelIsReady=e=>{},this.onConfiguratorKernelIsReady=(e,t)=>{},this.onSelectionChange=(e,t,r,n,a)=>{},this.onSelectionCancel=e=>{},this.onPlanChanged=()=>{},this.onPlanElementChanged=(e,t)=>{},this.onCompletelyLoaded=()=>{},this.onRotationCancel=()=>{},this.onHistoryChange=(e,t)=>{},this.onUpdateWallDimensions=e=>{},this.disableWallDimensions=()=>{},this.onUpdatePlanObjectPositions=e=>{},this.onDrawCancel=()=>{},this.onHandlerSwitchedPlans=()=>{},this.onDragElementStart=()=>{},this.onDragElementEnd=()=>{},this.onClickElement=e=>{},this.onMultiSelectionChange=e=>{}}}),new nr("configurator-ui-callbacks",class extends ci{constructor(e){super(e),this.onKernelIsReady=null,this.onComponentPositionsUpdated=null,this.onUpdateParameters=e=>{},this.onUpdatePossibleChildren=(e,t)=>{},this.onUpdatePrice=(e,t)=>{},this.onSelectionChange=(e,t,r,n)=>{},this.onSelectionCancel=()=>{},this.onPartListUpdate=(e,t)=>{},this.onBoundsUpdate=e=>{},this.onLoadConfiguration=()=>{},this.onConfigurationReady=(e,t,r)=>{},this.onOpenTag=e=>{},this.onOpenAddOns=()=>{},this.onClickOutside=()=>{},this.onNoDockingsAvailable=()=>{},this.onUiIntersectionChange=e=>{},this.onZoomChange=(e,t)=>{},this.onZoomToComponent=()=>{},this.onDimensionsVisibilityChange=e=>{},this.onErrorDueToOffline=e=>{},this.onError=e=>{},this.onDockingsPreviewRemoved=()=>{},this.onConfigurationHasChildren=e=>{},this.onTrackTiming=(e,t,r,n)=>{},this.onUserInitiatedDockDone=(e,t,r,n,a)=>{},this.onAddonPlusHover=()=>{},this.onAddonPlusHoverOff=()=>{},this.onAddonPlusShown=()=>{},this.onAddonPlusHidden=()=>{},this.onContentProblem=e=>{},this.onSyncStarted=()=>{},this.onSyncDone=()=>{},this.onOpenFloorMaterials=()=>{},this.onOpenPartList=()=>{},this.onComponentLoadError=(e,t)=>{},this.onConfigurationLoadError=()=>{},this.onChangeTypeChangeTag=e=>{},this.onRemoveTypeChangeTag=e=>{},this.onConfigurationLabelChange=(e,t,r)=>{},this.onMemoryCorruption=()=>{},this.onConfiguratorKernelIsReady=(e,t)=>{},this.onConfigurationSaved=e=>{},this.onCameraPositionChanges=()=>{},this.onHistoryChange=(e,t)=>{},this.onClickComponent=e=>{},this.onRequestExternalMesh=(e,t)=>{},this.onGeometryReady=e=>{},this.onGeometryNotReady=e=>{}}},1),new nr("roomle-tools-core",Xs,0),new nr("image-renderer",bh,0)]);class _h{static _ensureContainer(){window.__RML__DI__||(window.__RML__DI__=new rr,window.__RML__DI__.addDependencyInjectionAssignments(yh))}static setup(e){_h.addToContainer(e)}static lookup(e,t){return window.__RML__DI__?window.__RML__DI__.lookup(e,t):null}static getContext(e){return _h._ensureContainer(),window.__RML__DI__.getContext(e)}static cleanUp(e){return window.__RML__DI__?window.__RML__DI__.cleanUp(e):null}static addToContainer(e){_h._ensureContainer(),window.__RML__DI__.addDependencyInjectionAssignments(e)}}e("b",_h)}}}));
|
|
9
|
+
//# sourceMappingURL=roomle-dependency-injection-fe83f5a8.legacy.js.map
|