@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,16 @@
|
|
|
1
|
+
System.register(["./main-thread-to-worker-5609c757.nomodule.js"],(function(e,t){var n,r,i,s,a,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,ne,re,ie,se,ae,oe,le,he,de,ce,ue,pe,me,fe,ge,ve,we,be,_e,ye,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,nt,rt,it,st,at,ot,lt,ht,dt,ct,ut,pt,mt,ft,gt,vt,wt,bt,_t,yt,xt,St,Ct,Mt,Tt,At,Pt,Rt,Et,It,kt,Ot,Dt,Lt,Ut,Ft,Bt,Nt,zt,Ht,jt,Vt;return{setters:[function(e){n=e.g,r=e.A,i=e.D,s=e.V,a=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.L,v=e.e,w=e.F,b=e.P,_=e.f,y=e.h,x=e.i,S=e.j,C=e.Q,M=e.I,T=e.O,A=e.k,P=e.l,R=e.m,E=e.n,I=e.o,k=e.p,O=e.q,D=e.r,L=e.s,U=e.t,F=e.u,B=e.v,N=e.w,z=e.x,H=e.y,j=e.z,V=e.E,G=e.G,K=e.H,W=e.J,X=e.K,q=e.N,Q=e.U,Y=e.W,Z=e.X,J=e.Y,$=e.Z,ee=e._,te=e.$,ne=e.a0,re=e.a1,ie=e.a2,se=e.a3,ae=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,_e=e.ai,ye=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,nt=e.aS,rt=e.aT,it=e.aU,st=e.aV,at=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,_t=e.b8,yt=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}],execute:function(){e({_:tn,i:rn,x:wa});class Gt{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 n=this._lookups.get(e);if(1===n.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 r=t&&1===n.type?t:"global";if(r+="_"+e,2===n.type)return new n.classDefinition;if(this._singletons.has(r))return this._singletons.get(r);const i=new n.classDefinition(t);return this._singletons.set(r,i),i}cleanUp(e){if(e){let t=[];this._singletons.forEach((n,r)=>{r.startsWith(e)&&t.push(r)}),t.forEach(e=>{this._singletons.delete(e)})}else this._singletons.clear(),this._singletons=new Map}}class Kt{constructor(e,t,n){this.className=e,this.classDefinition=t,this.type=void 0===n?0:n}}e("D",Kt);const Wt={JPG:".jpg",JPEG:".jpeg",PNG:".png",GIF:".gif"};class Xt{_base64toBlob(e,t){t=t||"";const n=atob(e),r=n.length,i=Math.ceil(r/1024),s=new Array(i);for(let e=0;e<i;++e){let t=1024*e,i=Math.min(t+1024,r);const a=new Array(i-t);for(let e=t,r=0;e<i;++r,++e)a[r]=n[e].charCodeAt(0);s[e]=new Uint8Array(a)}return new Blob(s,{type:t})}_createFormData(e,t,n,r){const i=new FormData;-1!==e.indexOf(",")&&(e=e.substr(e.indexOf(",")+1));const s=-1===Object.keys(Wt).map(e=>Wt[e]).indexOf(n)?"application":"image",a=this._base64toBlob(e,s+"/"+n.substr(1));return i.append(r,a,t+n),i}create(e,t,n,r){return this._createFormData(e,t,n,r)}}const qt=e("q",{SOFA:"sofa",SHELF:"shelf",SHELF_FRONT:"shelf_front",BAKED:"baked",CAMERA:"camera",EQUAL:"equal"});class Qt{static createDynamicLightSettingSource(e,t){let r={};if(e)r.url=e;else if(t)switch(t){case qt.SHELF:r.url=n()+"static/shelf-2975dd3f2fa9c763.json";break;case qt.SHELF_FRONT:r.url=n()+"static/shelf_front-8c9566a4512f0de8.json";break;case qt.SOFA:r.url=n()+"static/sofa-997b116bc5f2e92e.json";break;case qt.BAKED:r.url=n()+"static/baked-6485a2b1daeb69e8.json";break;case qt.CAMERA:r.url=n()+"static/camera-05824b47cdb951e4.json";break;case qt.EQUAL:r.url=n()+"static/equal-319f6b83c827913f.json";break;default:r.url=n()+"static/camera-05824b47cdb951e4.json"}else r=null;return r}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 n;switch(e.type){case"ambient":n=this._parseAmbientLight(e);break;case"rectarea":n=this._parseRectAreaLight(e);break;case"spot":n=this._parseSpotLight(e);break;case"directional":n=this._parseDirectionalLight(e)}n&&t.push(n)}),t):[]}_parseAmbientLight(e){let t=new r;return this._parseCommon(t,e),t}_parseRectAreaLight(e){let{intensity:t,castShadow:n,target:r,width:l,height:h}=e,d=null;if(n&&Qt.rectAreaLightReplacement){const n=new i;this._parseCommon(n,e),d=n,n.castShadow=!0,n.shadow.camera.near=.1,n.shadow.camera.far=100,n.shadow.mapSize=new s(1024,1024),n.shadow.bias=-5e-5,n.shadow.normalBias=.01,n.intensity=t?t/100:1,n.lookAt(r?new a(r.x,r.y,r.z):new a(0,0,0))}else{const n=new o;this._parseCommon(n,e),d=n,n.width=l||.8,n.height=h||.8,n.castShadow=!1,n.matrixAutoUpdate=!0,n.intensity=(t||240)/((l||.8)*(h||.8)),n.lookAt(r?new a(r.x,r.y,r.z):new a(0,0,0)),Qt.rectAreaLightLoadingListener&&Qt.rectAreaLightLoadingListener(n)}return d}_parseSpotLight(e){let t=new l;this._parseCommon(t,e);let{angle:n,penumbra:r,target:i,castShadow:o}=e;return t.angle=(n||100)*Math.PI/180,t.penumbra=r||.5,t.lookAt(i?new a(i.x,i.y,i.z):new a(0,0,0)),t.shadow.camera.near=.1,t.shadow.camera.far=10,t.shadow.mapSize=new s(1024,1024),t.castShadow=o||!1,t}_parseDirectionalLight(e){let t=new i;this._parseCommon(t,e);let{target:n,castShadow:r}=e;return t.castShadow=r||!1,t.shadow.camera.near=.1,t.shadow.camera.far=100,t.shadow.mapSize=new s(1024,1024),t.shadow.bias=-5e-5,t.lookAt(n?new a(n.x,n.y,n.z):new a(0,0,0)),t}_parseCommon(e,t){let{name:n,intensity:r,color:i,position:s,movesWithCamera:o}=t;e.name=n||"",e.intensity=r||1,e.color=new h(i||"#ffffff"),e.position.copy(s?new a(s.x,s.y,s.z):new a(0,0,0)),e.visible=!0,e.layers.set(1),e.userData.movesWithCamera=o}}e("p",Qt),Qt.rectAreaLightReplacement=!0;const Yt=["127.0.0.1","localhost","0.0.0.0"],Zt=(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]})),Jt=({articleNr:e,componentId:t})=>e&&""!==e?t.split(":")[0]+":"+e:null,$t=(e,t)=>null!=e?"string"==typeof e?"true"===e:!0===e:("string"==typeof t&&(t=parseInt(t,10)),t>=200&&t<300);class en{constructor(){this._queue=[],this._pendingRequests=0}_nextSlot(){if(this._pendingRequests-=1,!this._queue.length)return;const{request:e,resolve:t,reject:n}=this._queue.shift();this._fetch(e).then(t,n)}_fetch(e,t={},n={}){return this._pendingRequests+=1,new Promise((r,i)=>{self.fetch(e,t).then(async function(e){this._nextSlot();const t=!n.checkResponse||!1!==await n.checkResponse(e);if($t(e.ok,e.status)&&t)r(...arguments);else{const t=(null==e?void 0:e.url)||"URL unknown";i(new Error(e.statusText||'Http error "'+(e&&e.status?e.status:"unknown")+'", for "'+t+'"'))}}.bind(this),e=>{this._nextSlot(),i(e)})})}fetch(e,t={},n={}){return this._pendingRequests>=40?new Promise((t,n)=>this._queue.push({request:e,resolve:t,reject:n})):this._fetch(e,t,n)}}function tn(e,t,n,r){var i,s=arguments.length,a=s<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,n,r);else for(var o=e.length-1;o>=0;o--)(i=e[o])&&(a=(s<3?i(a):s>3?i(t,n,a):i(t,n))||a);return s>3&&a&&Object.defineProperty(t,n,a),a}"function"==typeof SuppressedError&&SuppressedError;const nn=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 rn(e,t){const n=Symbol("property-cache");Object.defineProperty(e,t,{get(){if(!this[n]){const e=window.__RML__DI__.lookup(nn(t),this._creator_);e?this[n]=e:console.error("Dependency "+nn(t)+" not found! Add dependency to /utils/injectables.ts")}return this[n]}})}class sn{info(...e){console}log(...e){console}warn(...e){console.warn.apply(console,e)}error(...e){console.warn.apply(console,e)}}e("L",sn);class an extends sn{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)}}tn([rn],an.prototype,"_globalCallback",void 0);const on=new Map,ln=new Map,hn=new Map,dn=new Map;class cn{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(()=>{dn.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&&!hn.get(e)?(t.push(this._handleTags([e])),this._rapiAccess.getTag(e).then(e=>{t.push(this._handleMaterialsAndTextures(e))}),this._singlePromiseFactory.create(1,e,n=>{Promise.all(t).then(()=>{hn.set(e,!0),n()},e=>this._softReject(n,'_syncFloorTag error: "'+e+'"'))})):Promise.resolve()}_syncTypeChangeTag(e){const t=[];return e&&!dn.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,n=>{Promise.all(t).then(()=>{hn.set(e,!0),n()},e=>this._softReject(n,'_syncTypeChangeTag error: "'+e+'"'))})):Promise.resolve()}getIsCatalogSynced(e){return!!ln.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(n()+"static/asset-loader.worker-1735a5fb1e401244.js"),this._mainThreadToWorker=new d(this,this._worker),this._isStarting=!0,this._mainThreadToWorker.sendToWorker(1))})}onCommand(e,t,n){switch(e){case 4:this._isStarted=!0,this._bootCallbacks.forEach(({resolve:e})=>e());break;case 3:this._mainThreadToWorker.resolvePromises(t,n)}}_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(()=>{ln.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 n=[];e.forEach(e=>{n.push(this._handleContentWithAssets(Promise.all([this._rapiAccess.getMesh(e.id)]),["url"]))}),Promise.all(n).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 n=[];n.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));n.push(this._handleContentWithAssets(Promise.resolve(t),["content"]))},e=>this._softReject(t,'getAdditionalContentsOfItems error: "'+e+'"')),Promise.all(n).then(t,e=>this._softReject(t,'AdditionalContent image sync error:"'+e+'"'))})})}_handleMaterialsAndTextures(e){return new Promise(t=>{this._rapiAccess.getMaterialsOf(e).then(e=>{const n=[];n.push(this._handleContentWithAssets(Promise.resolve(e),["thumbnail"])),e.forEach(e=>{n.push(this._handleContentWithAssets(this._rapiAccess.getTexturesOf(e),["image"]))}),Promise.all(n).then(t,e=>this._softReject(t,'getTexturesOf error: "'+e+'"'))},e=>this._softReject(t,'getMaterialsOf error: "'+e+'"'))})}_handleContentWithAssets(e,t){return new Promise(n=>e.then(e=>this._fetchAssets(e,t).then(n,e=>this._softReject(n,'_handleContentWithAssets error: "'+e+'"')),e=>this._softReject(n,'_handleContentWithAssets promise error: "'+e+'"')))}_fetchAssets(e,t){const n=[];e||(e=[]);for(let r=0,i=e.length;r<i;r++){const i=e[r];t.forEach(e=>{const t=i[e];t&&n.push(this._preCacheAsset(t))})}return Promise.all(n)}_preCacheAsset(e){return new Promise(t=>{if(on.get(e))return t();this._assetUrlToBase64(e).then(n=>{on.set(e,n),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:on.get(e)||(t?e:null)}setAlwaysUseCache(e){this._alwaysUseCache=e}preFillAssetCache(e,t){on.set(e,t)}}e("a",cn),tn([rn],cn.prototype,"_rapiAccess",void 0),tn([rn],cn.prototype,"_singlePromiseFactory",void 0),tn([rn],cn.prototype,"_errorHandler",void 0),tn([rn],cn.prototype,"_configuratorUiCallbacks",void 0),tn([rn],cn.prototype,"_initData",void 0);class un{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 pn(e){let t,n,r,i=-1,s=0;for(let a=0;a<e.length;++a){const o=e[a];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===n&&(n=o.itemSize),n!==o.itemSize)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.itemSize must be consistent across matching attributes."),null;if(void 0===r&&(r=o.normalized),r!==o.normalized)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.normalized must be consistent across matching attributes."),null;if(-1===i&&(i=o.gpuType),i!==o.gpuType)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.gpuType must be consistent across matching attributes."),null;s+=o.array.length}const a=new t(s);let o=0;for(let t=0;t<e.length;++t)a.set(e[t].array,o),o+=e[t].array.length;const l=new u(a,n,r);return void 0!==i&&(l.gpuType=i),l}function mn(e,t){if(t===p)return console.warn("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Geometry already defined as triangles."),e;if(t===m||t===f){let n=e.getIndex();if(null===n){const t=[],r=e.getAttribute("position");if(void 0===r)return console.error("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Undefined position attribute. Processing not possible."),e;for(let e=0;e<r.count;e++)t.push(e);e.setIndex(t),n=e.getIndex()}const r=n.count-2,i=[];if(t===m)for(let e=1;e<=r;e++)i.push(n.getX(0)),i.push(n.getX(e)),i.push(n.getX(e+1));else for(let e=0;e<r;e++)e%2==0?(i.push(n.getX(e)),i.push(n.getX(e+1)),i.push(n.getX(e+2))):(i.push(n.getX(e+2)),i.push(n.getX(e+1)),i.push(n.getX(e)));i.length/3!==r&&console.error("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Unable to generate correct amount of triangles.");const s=e.clone();return s.setIndex(i),s.clearGroups(),s}return console.error("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Unknown draw mode:",t),e}e("ac",un);class fn extends g{constructor(e){super(e),this.dracoLoader=null,this.ktx2Loader=null,this.meshoptDecoder=null,this.pluginCallbacks=[],this.register((function(e){return new yn(e)})),this.register((function(e){return new Rn(e)})),this.register((function(e){return new En(e)})),this.register((function(e){return new In(e)})),this.register((function(e){return new Sn(e)})),this.register((function(e){return new Cn(e)})),this.register((function(e){return new Mn(e)})),this.register((function(e){return new Tn(e)})),this.register((function(e){return new _n(e)})),this.register((function(e){return new An(e)})),this.register((function(e){return new xn(e)})),this.register((function(e){return new Pn(e)})),this.register((function(e){return new wn(e)})),this.register((function(e){return new kn(e)})),this.register((function(e){return new On(e)}))}load(e,t,n,r){const i=this;let s;s=""!==this.resourcePath?this.resourcePath:""!==this.path?this.path:v.extractUrlBase(e),this.manager.itemStart(e);const a=function(t){r?r(t):console.error(t),i.manager.itemError(e),i.manager.itemEnd(e)},o=new w(this.manager);o.setPath(this.path),o.setResponseType("arraybuffer"),o.setRequestHeader(this.requestHeader),o.setWithCredentials(this.withCredentials),o.load(e,(function(n){try{i.parse(n,s,(function(n){t(n),i.manager.itemEnd(e)}),a)}catch(e){a(e)}}),n,a)}setDRACOLoader(e){return this.dracoLoader=e,this}setDDSLoader(){throw new Error('THREE.GLTFLoader: "MSFT_texture_dds" no longer supported. Please update to "KHR_texture_basisu".')}setKTX2Loader(e){return this.ktx2Loader=e,this}setMeshoptDecoder(e){return this.meshoptDecoder=e,this}register(e){return-1===this.pluginCallbacks.indexOf(e)&&this.pluginCallbacks.push(e),this}unregister(e){return-1!==this.pluginCallbacks.indexOf(e)&&this.pluginCallbacks.splice(this.pluginCallbacks.indexOf(e),1),this}parse(e,t,n,r){let i;const s={},a={},o=new TextDecoder;if("string"==typeof e)i=JSON.parse(e);else if(e instanceof ArrayBuffer)if(o.decode(new Uint8Array(e,0,4))===Dn){try{s[vn.KHR_BINARY_GLTF]=new Ln(e)}catch(e){return void(r&&r(e))}i=JSON.parse(s[vn.KHR_BINARY_GLTF].content)}else i=JSON.parse(o.decode(e));else i=e;if(void 0===i.asset||i.asset.version[0]<2)return void(r&&r(new Error("THREE.GLTFLoader: Unsupported asset. glTF versions >=2.0 are supported.")));const l=new rr(i,{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(let e=0;e<this.pluginCallbacks.length;e++){const t=this.pluginCallbacks[e](l);a[t.name]=t,s[t.name]=!0}if(i.extensionsUsed)for(let e=0;e<i.extensionsUsed.length;++e){const t=i.extensionsUsed[e],n=i.extensionsRequired||[];switch(t){case vn.KHR_MATERIALS_UNLIT:s[t]=new bn;break;case vn.KHR_DRACO_MESH_COMPRESSION:s[t]=new Un(i,this.dracoLoader);break;case vn.KHR_TEXTURE_TRANSFORM:s[t]=new Fn;break;case vn.KHR_MESH_QUANTIZATION:s[t]=new Bn;break;default:n.indexOf(t)>=0&&void 0===a[t]&&console.warn('THREE.GLTFLoader: Unknown extension "'+t+'".')}}l.setExtensions(s),l.setPlugins(a),l.parse(n,r)}parseAsync(e,t){const n=this;return new Promise((function(r,i){n.parse(e,t,r,i)}))}}function gn(){let e={};return{get:function(t){return e[t]},add:function(t,n){e[t]=n},remove:function(t){delete e[t]},removeAll:function(){e={}}}}const vn={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"};class wn{constructor(e){this.parser=e,this.name=vn.KHR_LIGHTS_PUNCTUAL,this.cache={refs:{},uses:{}}}_markDefs(){const e=this.parser,t=this.parser.json.nodes||[];for(let n=0,r=t.length;n<r;n++){const r=t[n];r.extensions&&r.extensions[this.name]&&void 0!==r.extensions[this.name].light&&e._addNodeRef(this.cache,r.extensions[this.name].light)}}_loadLight(e){const t=this.parser,n="light:"+e;let r=t.cache.get(n);if(r)return r;const s=t.json,a=((s.extensions&&s.extensions[this.name]||{}).lights||[])[e];let o;const d=new h(16777215);void 0!==a.color&&d.fromArray(a.color);const c=void 0!==a.range?a.range:0;switch(a.type){case"directional":o=new i(d),o.target.position.set(0,0,-1),o.add(o.target);break;case"point":o=new b(d),o.distance=c;break;case"spot":o=new l(d),o.distance=c,a.spot=a.spot||{},a.spot.innerConeAngle=void 0!==a.spot.innerConeAngle?a.spot.innerConeAngle:0,a.spot.outerConeAngle=void 0!==a.spot.outerConeAngle?a.spot.outerConeAngle:Math.PI/4,o.angle=a.spot.outerConeAngle,o.penumbra=1-a.spot.innerConeAngle/a.spot.outerConeAngle,o.target.position.set(0,0,-1),o.add(o.target);break;default:throw new Error("THREE.GLTFLoader: Unexpected light type: "+a.type)}return o.position.set(0,0,0),o.decay=2,Zn(o,a),void 0!==a.intensity&&(o.intensity=a.intensity),o.name=t.createUniqueName(a.name||"light_"+e),r=Promise.resolve(o),t.cache.add(n,r),r}getDependency(e,t){if("light"===e)return this._loadLight(t)}createNodeAttachment(e){const t=this,n=this.parser,r=n.json.nodes[e],i=(r.extensions&&r.extensions[this.name]||{}).light;return void 0===i?null:this._loadLight(i).then((function(e){return n._getNodeRef(t.cache,i,e)}))}}class bn{constructor(){this.name=vn.KHR_MATERIALS_UNLIT}getMaterialType(){return _}extendParams(e,t,n){const r=[];e.color=new h(1,1,1),e.opacity=1;const i=t.pbrMetallicRoughness;if(i){if(Array.isArray(i.baseColorFactor)){const t=i.baseColorFactor;e.color.fromArray(t),e.opacity=t[3]}void 0!==i.baseColorTexture&&r.push(n.assignTexture(e,"map",i.baseColorTexture,y))}return Promise.all(r)}}class _n{constructor(e){this.parser=e,this.name=vn.KHR_MATERIALS_EMISSIVE_STRENGTH}extendMaterialParams(e,t){const n=this.parser.json.materials[e];if(!n.extensions||!n.extensions[this.name])return Promise.resolve();const r=n.extensions[this.name].emissiveStrength;return void 0!==r&&(t.emissiveIntensity=r),Promise.resolve()}}class yn{constructor(e){this.parser=e,this.name=vn.KHR_MATERIALS_CLEARCOAT}getMaterialType(e){const t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?x:null}extendMaterialParams(e,t){const n=this.parser,r=n.json.materials[e];if(!r.extensions||!r.extensions[this.name])return Promise.resolve();const i=[],a=r.extensions[this.name];if(void 0!==a.clearcoatFactor&&(t.clearcoat=a.clearcoatFactor),void 0!==a.clearcoatTexture&&i.push(n.assignTexture(t,"clearcoatMap",a.clearcoatTexture)),void 0!==a.clearcoatRoughnessFactor&&(t.clearcoatRoughness=a.clearcoatRoughnessFactor),void 0!==a.clearcoatRoughnessTexture&&i.push(n.assignTexture(t,"clearcoatRoughnessMap",a.clearcoatRoughnessTexture)),void 0!==a.clearcoatNormalTexture&&(i.push(n.assignTexture(t,"clearcoatNormalMap",a.clearcoatNormalTexture)),void 0!==a.clearcoatNormalTexture.scale)){const e=a.clearcoatNormalTexture.scale;t.clearcoatNormalScale=new s(e,e)}return Promise.all(i)}}class xn{constructor(e){this.parser=e,this.name=vn.KHR_MATERIALS_IRIDESCENCE}getMaterialType(e){const t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?x:null}extendMaterialParams(e,t){const n=this.parser,r=n.json.materials[e];if(!r.extensions||!r.extensions[this.name])return Promise.resolve();const i=[],s=r.extensions[this.name];return void 0!==s.iridescenceFactor&&(t.iridescence=s.iridescenceFactor),void 0!==s.iridescenceTexture&&i.push(n.assignTexture(t,"iridescenceMap",s.iridescenceTexture)),void 0!==s.iridescenceIor&&(t.iridescenceIOR=s.iridescenceIor),void 0===t.iridescenceThicknessRange&&(t.iridescenceThicknessRange=[100,400]),void 0!==s.iridescenceThicknessMinimum&&(t.iridescenceThicknessRange[0]=s.iridescenceThicknessMinimum),void 0!==s.iridescenceThicknessMaximum&&(t.iridescenceThicknessRange[1]=s.iridescenceThicknessMaximum),void 0!==s.iridescenceThicknessTexture&&i.push(n.assignTexture(t,"iridescenceThicknessMap",s.iridescenceThicknessTexture)),Promise.all(i)}}class Sn{constructor(e){this.parser=e,this.name=vn.KHR_MATERIALS_SHEEN}getMaterialType(e){const t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?x:null}extendMaterialParams(e,t){const n=this.parser,r=n.json.materials[e];if(!r.extensions||!r.extensions[this.name])return Promise.resolve();const i=[];t.sheenColor=new h(0,0,0),t.sheenRoughness=0,t.sheen=1;const s=r.extensions[this.name];return void 0!==s.sheenColorFactor&&t.sheenColor.fromArray(s.sheenColorFactor),void 0!==s.sheenRoughnessFactor&&(t.sheenRoughness=s.sheenRoughnessFactor),void 0!==s.sheenColorTexture&&i.push(n.assignTexture(t,"sheenColorMap",s.sheenColorTexture,y)),void 0!==s.sheenRoughnessTexture&&i.push(n.assignTexture(t,"sheenRoughnessMap",s.sheenRoughnessTexture)),Promise.all(i)}}class Cn{constructor(e){this.parser=e,this.name=vn.KHR_MATERIALS_TRANSMISSION}getMaterialType(e){const t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?x:null}extendMaterialParams(e,t){const n=this.parser,r=n.json.materials[e];if(!r.extensions||!r.extensions[this.name])return Promise.resolve();const i=[],s=r.extensions[this.name];return void 0!==s.transmissionFactor&&(t.transmission=s.transmissionFactor),void 0!==s.transmissionTexture&&i.push(n.assignTexture(t,"transmissionMap",s.transmissionTexture)),Promise.all(i)}}class Mn{constructor(e){this.parser=e,this.name=vn.KHR_MATERIALS_VOLUME}getMaterialType(e){const t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?x:null}extendMaterialParams(e,t){const n=this.parser,r=n.json.materials[e];if(!r.extensions||!r.extensions[this.name])return Promise.resolve();const i=[],s=r.extensions[this.name];t.thickness=void 0!==s.thicknessFactor?s.thicknessFactor:0,void 0!==s.thicknessTexture&&i.push(n.assignTexture(t,"thicknessMap",s.thicknessTexture)),t.attenuationDistance=s.attenuationDistance||1/0;const a=s.attenuationColor||[1,1,1];return t.attenuationColor=new h(a[0],a[1],a[2]),Promise.all(i)}}class Tn{constructor(e){this.parser=e,this.name=vn.KHR_MATERIALS_IOR}getMaterialType(e){const t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?x:null}extendMaterialParams(e,t){const n=this.parser.json.materials[e];if(!n.extensions||!n.extensions[this.name])return Promise.resolve();const r=n.extensions[this.name];return t.ior=void 0!==r.ior?r.ior:1.5,Promise.resolve()}}class An{constructor(e){this.parser=e,this.name=vn.KHR_MATERIALS_SPECULAR}getMaterialType(e){const t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?x:null}extendMaterialParams(e,t){const n=this.parser,r=n.json.materials[e];if(!r.extensions||!r.extensions[this.name])return Promise.resolve();const i=[],s=r.extensions[this.name];t.specularIntensity=void 0!==s.specularFactor?s.specularFactor:1,void 0!==s.specularTexture&&i.push(n.assignTexture(t,"specularIntensityMap",s.specularTexture));const a=s.specularColorFactor||[1,1,1];return t.specularColor=new h(a[0],a[1],a[2]),void 0!==s.specularColorTexture&&i.push(n.assignTexture(t,"specularColorMap",s.specularColorTexture,y)),Promise.all(i)}}class Pn{constructor(e){this.parser=e,this.name=vn.KHR_MATERIALS_ANISOTROPY}getMaterialType(e){const t=this.parser.json.materials[e];return t.extensions&&t.extensions[this.name]?x:null}extendMaterialParams(e,t){const n=this.parser,r=n.json.materials[e];if(!r.extensions||!r.extensions[this.name])return Promise.resolve();const i=[],s=r.extensions[this.name];return void 0!==s.anisotropyStrength&&(t.anisotropy=s.anisotropyStrength),void 0!==s.anisotropyRotation&&(t.anisotropyRotation=s.anisotropyRotation),void 0!==s.anisotropyTexture&&i.push(n.assignTexture(t,"anisotropyMap",s.anisotropyTexture)),Promise.all(i)}}class Rn{constructor(e){this.parser=e,this.name=vn.KHR_TEXTURE_BASISU}loadTexture(e){const t=this.parser,n=t.json,r=n.textures[e];if(!r.extensions||!r.extensions[this.name])return null;const i=r.extensions[this.name],s=t.options.ktx2Loader;if(!s){if(n.extensionsRequired&&n.extensionsRequired.indexOf(this.name)>=0)throw new Error("THREE.GLTFLoader: setKTX2Loader must be called before loading KTX2 textures");return null}return t.loadTextureImage(e,i.source,s)}}class En{constructor(e){this.parser=e,this.name=vn.EXT_TEXTURE_WEBP,this.isSupported=null}loadTexture(e){const t=this.name,n=this.parser,r=n.json,i=r.textures[e];if(!i.extensions||!i.extensions[t])return null;const s=i.extensions[t],a=r.images[s.source];let o=n.textureLoader;if(a.uri){const e=n.options.manager.getHandler(a.uri);null!==e&&(o=e)}return this.detectSupport().then((function(i){if(i)return n.loadTextureImage(e,s.source,o);if(r.extensionsRequired&&r.extensionsRequired.indexOf(t)>=0)throw new Error("THREE.GLTFLoader: WebP required by asset but unsupported.");return n.loadTexture(e)}))}detectSupport(){return this.isSupported||(this.isSupported=new Promise((function(e){const t=new Image;t.src="data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA",t.onload=t.onerror=function(){e(1===t.height)}}))),this.isSupported}}class In{constructor(e){this.parser=e,this.name=vn.EXT_TEXTURE_AVIF,this.isSupported=null}loadTexture(e){const t=this.name,n=this.parser,r=n.json,i=r.textures[e];if(!i.extensions||!i.extensions[t])return null;const s=i.extensions[t],a=r.images[s.source];let o=n.textureLoader;if(a.uri){const e=n.options.manager.getHandler(a.uri);null!==e&&(o=e)}return this.detectSupport().then((function(i){if(i)return n.loadTextureImage(e,s.source,o);if(r.extensionsRequired&&r.extensionsRequired.indexOf(t)>=0)throw new Error("THREE.GLTFLoader: AVIF required by asset but unsupported.");return n.loadTexture(e)}))}detectSupport(){return this.isSupported||(this.isSupported=new Promise((function(e){const t=new Image;t.src="data:image/avif;base64,AAAAIGZ0eXBhdmlmAAAAAGF2aWZtaWYxbWlhZk1BMUIAAADybWV0YQAAAAAAAAAoaGRscgAAAAAAAAAAcGljdAAAAAAAAAAAAAAAAGxpYmF2aWYAAAAADnBpdG0AAAAAAAEAAAAeaWxvYwAAAABEAAABAAEAAAABAAABGgAAABcAAAAoaWluZgAAAAAAAQAAABppbmZlAgAAAAABAABhdjAxQ29sb3IAAAAAamlwcnAAAABLaXBjbwAAABRpc3BlAAAAAAAAAAEAAAABAAAAEHBpeGkAAAAAAwgICAAAAAxhdjFDgQAMAAAAABNjb2xybmNseAACAAIABoAAAAAXaXBtYQAAAAAAAAABAAEEAQKDBAAAAB9tZGF0EgAKCBgABogQEDQgMgkQAAAAB8dSLfI=",t.onload=t.onerror=function(){e(1===t.height)}}))),this.isSupported}}class kn{constructor(e){this.name=vn.EXT_MESHOPT_COMPRESSION,this.parser=e}loadBufferView(e){const t=this.parser.json,n=t.bufferViews[e];if(n.extensions&&n.extensions[this.name]){const e=n.extensions[this.name],r=this.parser.getDependency("buffer",e.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 r.then((function(t){const n=e.byteOffset||0,r=e.byteLength||0,s=e.count,a=e.byteStride,o=new Uint8Array(t,n,r);return i.decodeGltfBufferAsync?i.decodeGltfBufferAsync(s,a,o,e.mode,e.filter).then((function(e){return e.buffer})):i.ready.then((function(){const t=new ArrayBuffer(s*a);return i.decodeGltfBuffer(new Uint8Array(t),s,a,o,e.mode,e.filter),t}))}))}return null}}class On{constructor(e){this.name=vn.EXT_MESH_GPU_INSTANCING,this.parser=e}createNodeMesh(e){const t=this.parser.json,n=t.nodes[e];if(!n.extensions||!n.extensions[this.name]||void 0===n.mesh)return null;const r=t.meshes[n.mesh];for(const e of r.primitives)if(e.mode!==jn.TRIANGLES&&e.mode!==jn.TRIANGLE_STRIP&&e.mode!==jn.TRIANGLE_FAN&&void 0!==e.mode)return null;const i=n.extensions[this.name].attributes,s=[],o={};for(const e in i)s.push(this.parser.getDependency("accessor",i[e]).then(t=>(o[e]=t,o[e])));return s.length<1?null:(s.push(this.parser.createNodeMesh(e)),Promise.all(s).then(e=>{const t=e.pop(),n=t.isGroup?t.children:[t],r=e[0].count,i=[];for(const e of n){const t=new S,n=new a,s=new C,l=new a(1,1,1),h=new M(e.geometry,e.material,r);for(let e=0;e<r;e++)o.TRANSLATION&&n.fromBufferAttribute(o.TRANSLATION,e),o.ROTATION&&s.fromBufferAttribute(o.ROTATION,e),o.SCALE&&l.fromBufferAttribute(o.SCALE,e),h.setMatrixAt(e,t.compose(n,s,l));for(const t in o)"TRANSLATION"!==t&&"ROTATION"!==t&&"SCALE"!==t&&e.geometry.setAttribute(t,o[t]);T.prototype.copy.call(h,e),this.parser.assignFinalMaterial(h),i.push(h)}return t.isGroup?(t.clear(),t.add(...i),t):i[0]}))}}const Dn="glTF";class Ln{constructor(e){this.name=vn.KHR_BINARY_GLTF,this.content=null,this.body=null;const t=new DataView(e,0,12),n=new TextDecoder;if(this.header={magic:n.decode(new Uint8Array(e.slice(0,4))),version:t.getUint32(4,!0),length:t.getUint32(8,!0)},this.header.magic!==Dn)throw new Error("THREE.GLTFLoader: Unsupported glTF-Binary header.");if(this.header.version<2)throw new Error("THREE.GLTFLoader: Legacy binary file detected.");const r=this.header.length-12,i=new DataView(e,12);let s=0;for(;s<r;){const t=i.getUint32(s,!0);s+=4;const r=i.getUint32(s,!0);if(s+=4,1313821514===r){const r=new Uint8Array(e,12+s,t);this.content=n.decode(r)}else if(5130562===r){const n=12+s;this.body=e.slice(n,n+t)}s+=t}if(null===this.content)throw new Error("THREE.GLTFLoader: JSON content not found.")}}class Un{constructor(e,t){if(!t)throw new Error("THREE.GLTFLoader: No DRACOLoader instance provided.");this.name=vn.KHR_DRACO_MESH_COMPRESSION,this.json=e,this.dracoLoader=t,this.dracoLoader.preload()}decodePrimitive(e,t){const n=this.json,r=this.dracoLoader,i=e.extensions[this.name].bufferView,s=e.extensions[this.name].attributes,a={},o={},l={};for(const e in s){const t=Xn[e]||e.toLowerCase();a[t]=s[e]}for(const t in e.attributes){const r=Xn[t]||t.toLowerCase();if(void 0!==s[t]){const i=n.accessors[e.attributes[t]],s=Vn[i.componentType];l[r]=s.name,o[r]=!0===i.normalized}}return t.getDependency("bufferView",i).then((function(e){return new Promise((function(t){r.decodeDracoFile(e,(function(e){for(const t in e.attributes){const n=e.attributes[t],r=o[t];void 0!==r&&(n.normalized=r)}t(e)}),a,l)}))}))}}class Fn{constructor(){this.name=vn.KHR_TEXTURE_TRANSFORM}extendTexture(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}}class Bn{constructor(){this.name=vn.KHR_MESH_QUANTIZATION}}class Nn extends me{constructor(e,t,n,r){super(e,t,n,r)}copySampleValue_(e){const t=this.resultBuffer,n=this.sampleValues,r=this.valueSize,i=e*r*3+r;for(let e=0;e!==r;e++)t[e]=n[i+e];return t}interpolate_(e,t,n,r){const i=this.resultBuffer,s=this.sampleValues,a=this.valueSize,o=2*a,l=3*a,h=r-t,d=(n-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;for(let e=0;e!==a;e++){const t=s[m+e+a],n=s[m+e+o]*h,r=s[p+e+a],l=s[p+e]*h;i[e]=v*t+w*n+f*r+g*l}return i}}const zn=new C;class Hn extends Nn{interpolate_(e,t,n,r){const i=super.interpolate_(e,t,n,r);return zn.fromArray(i).normalize().toArray(i),i}}const jn={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},Vn={5120:Int8Array,5121:Uint8Array,5122:Int16Array,5123:Uint16Array,5125:Uint32Array,5126:Float32Array},Gn={9728:$,9729:E,9984:ee,9985:te,9986:ne,9987:I},Kn={33071:re,33648:ie,10497:k},Wn={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16},Xn={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"},qn={scale:"scale",translation:"position",rotation:"quaternion",weights:"morphTargetInfluences"},Qn={CUBICSPLINE:void 0,LINEAR:J,STEP:se};function Yn(e,t,n){for(const r in n.extensions)void 0===e[r]&&(t.userData.gltfExtensions=t.userData.gltfExtensions||{},t.userData.gltfExtensions[r]=n.extensions[r])}function Zn(e,t){void 0!==t.extras&&("object"==typeof t.extras?Object.assign(e.userData,t.extras):console.warn("THREE.GLTFLoader: Ignoring primitive type .extras, "+t.extras))}function Jn(e,t){if(e.updateMorphTargets(),void 0!==t.weights)for(let n=0,r=t.weights.length;n<r;n++)e.morphTargetInfluences[n]=t.weights[n];if(t.extras&&Array.isArray(t.extras.targetNames)){const n=t.extras.targetNames;if(e.morphTargetInfluences.length===n.length){e.morphTargetDictionary={};for(let t=0,r=n.length;t<r;t++)e.morphTargetDictionary[n[t]]=t}else console.warn("THREE.GLTFLoader: Invalid extras.targetNames length. Ignoring names.")}}function $n(e){let t;const n=e.extensions&&e.extensions[vn.KHR_DRACO_MESH_COMPRESSION];if(t=n?"draco:"+n.bufferView+":"+n.indices+":"+er(n.attributes):e.indices+":"+er(e.attributes)+":"+e.mode,void 0!==e.targets)for(let n=0,r=e.targets.length;n<r;n++)t+=":"+er(e.targets[n]);return t}function er(e){let t="";const n=Object.keys(e).sort();for(let r=0,i=n.length;r<i;r++)t+=n[r]+":"+e[n[r]]+";";return t}function tr(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.")}}const nr=new S;class rr{constructor(e={},t={}){this.json=e,this.extensions={},this.plugins={},this.options=t,this.cache=new gn,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={};let n=!1,r=!1,i=-1;"undefined"!=typeof navigator&&(n=!0===/^((?!chrome|android).)*safari/i.test(navigator.userAgent),r=navigator.userAgent.indexOf("Firefox")>-1,i=r?navigator.userAgent.match(/Firefox\/([0-9]+)\./)[1]:-1),"undefined"==typeof createImageBitmap||n||r&&i<98?this.textureLoader=new A(this.options.manager):this.textureLoader=new P(this.options.manager),this.textureLoader.setCrossOrigin(this.options.crossOrigin),this.textureLoader.setRequestHeader(this.options.requestHeader),this.fileLoader=new w(this.options.manager),this.fileLoader.setResponseType("arraybuffer"),"use-credentials"===this.options.crossOrigin&&this.fileLoader.setWithCredentials(!0)}setExtensions(e){this.extensions=e}setPlugins(e){this.plugins=e}parse(e,t){const n=this,r=this.json,i=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([n.getDependencies("scene"),n.getDependencies("animation"),n.getDependencies("camera")])})).then((function(t){const s={scene:t[0][r.scene||0],scenes:t[0],animations:t[1],cameras:t[2],asset:r.asset,parser:n,userData:{}};Yn(i,s,r),Zn(s,r),Promise.all(n._invokeAll((function(e){return e.afterRoot&&e.afterRoot(s)}))).then((function(){e(s)}))})).catch(t)}_markDefs(){const e=this.json.nodes||[],t=this.json.skins||[],n=this.json.meshes||[];for(let n=0,r=t.length;n<r;n++){const r=t[n].joints;for(let t=0,n=r.length;t<n;t++)e[r[t]].isBone=!0}for(let t=0,r=e.length;t<r;t++){const r=e[t];void 0!==r.mesh&&(this._addNodeRef(this.meshCache,r.mesh),void 0!==r.skin&&(n[r.mesh].isSkinnedMesh=!0)),void 0!==r.camera&&this._addNodeRef(this.cameraCache,r.camera)}}_addNodeRef(e,t){void 0!==t&&(void 0===e.refs[t]&&(e.refs[t]=e.uses[t]=0),e.refs[t]++)}_getNodeRef(e,t,n){if(e.refs[t]<=1)return n;const r=n.clone(),i=(e,t)=>{const n=this.associations.get(e);null!=n&&this.associations.set(t,n);for(const[n,r]of e.children.entries())i(r,t.children[n])};return i(n,r),r.name+="_instance_"+e.uses[t]++,r}_invokeOne(e){const t=Object.values(this.plugins);t.push(this);for(let n=0;n<t.length;n++){const r=e(t[n]);if(r)return r}return null}_invokeAll(e){const t=Object.values(this.plugins);t.unshift(this);const n=[];for(let r=0;r<t.length;r++){const i=e(t[r]);i&&n.push(i)}return n}getDependency(e,t){const n=e+":"+t;let r=this.cache.get(n);if(!r){switch(e){case"scene":r=this.loadScene(t);break;case"node":r=this._invokeOne((function(e){return e.loadNode&&e.loadNode(t)}));break;case"mesh":r=this._invokeOne((function(e){return e.loadMesh&&e.loadMesh(t)}));break;case"accessor":r=this.loadAccessor(t);break;case"bufferView":r=this._invokeOne((function(e){return e.loadBufferView&&e.loadBufferView(t)}));break;case"buffer":r=this.loadBuffer(t);break;case"material":r=this._invokeOne((function(e){return e.loadMaterial&&e.loadMaterial(t)}));break;case"texture":r=this._invokeOne((function(e){return e.loadTexture&&e.loadTexture(t)}));break;case"skin":r=this.loadSkin(t);break;case"animation":r=this._invokeOne((function(e){return e.loadAnimation&&e.loadAnimation(t)}));break;case"camera":r=this.loadCamera(t);break;default:if(r=this._invokeOne((function(n){return n!=this&&n.getDependency&&n.getDependency(e,t)})),!r)throw new Error("Unknown type: "+e)}this.cache.add(n,r)}return r}getDependencies(e){let t=this.cache.get(e);if(!t){const n=this,r=this.json[e+("mesh"===e?"es":"s")]||[];t=Promise.all(r.map((function(t,r){return n.getDependency(e,r)}))),this.cache.add(e,t)}return t}loadBuffer(e){const t=this.json.buffers[e],n=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[vn.KHR_BINARY_GLTF].body);const r=this.options;return new Promise((function(e,i){n.load(v.resolveURL(t.uri,r.path),e,void 0,(function(){i(new Error('THREE.GLTFLoader: Failed to load buffer "'+t.uri+'".'))}))}))}loadBufferView(e){const t=this.json.bufferViews[e];return this.getDependency("buffer",t.buffer).then((function(e){const n=t.byteLength||0,r=t.byteOffset||0;return e.slice(r,r+n)}))}loadAccessor(e){const t=this,n=this.json,r=this.json.accessors[e];if(void 0===r.bufferView&&void 0===r.sparse){const e=Wn[r.type],t=Vn[r.componentType],n=!0===r.normalized,i=new t(r.count*e);return Promise.resolve(new u(i,e,n))}const i=[];return void 0!==r.bufferView?i.push(this.getDependency("bufferView",r.bufferView)):i.push(null),void 0!==r.sparse&&(i.push(this.getDependency("bufferView",r.sparse.indices.bufferView)),i.push(this.getDependency("bufferView",r.sparse.values.bufferView))),Promise.all(i).then((function(e){const i=e[0],s=Wn[r.type],a=Vn[r.componentType],o=a.BYTES_PER_ELEMENT,l=o*s,h=r.byteOffset||0,d=void 0!==r.bufferView?n.bufferViews[r.bufferView].byteStride:void 0,c=!0===r.normalized;let p,m;if(d&&d!==l){const e=Math.floor(h/d),n="InterleavedBuffer:"+r.bufferView+":"+r.componentType+":"+e+":"+r.count;let l=t.cache.get(n);l||(p=new a(i,e*d,r.count*d/o),l=new R(p,d/o),t.cache.add(n,l)),m=new oe(l,s,h%d/o,c)}else p=null===i?new a(r.count*s):new a(i,h,r.count*s),m=new u(p,s,c);if(void 0!==r.sparse){const t=Wn.SCALAR,n=Vn[r.sparse.indices.componentType],o=r.sparse.indices.byteOffset||0,l=r.sparse.values.byteOffset||0,h=new n(e[1],o,r.sparse.count*t),d=new a(e[2],l,r.sparse.count*s);null!==i&&(m=new u(m.array.slice(),m.itemSize,m.normalized));for(let e=0,t=h.length;e<t;e++){const t=h[e];if(m.setX(t,d[e*s]),s>=2&&m.setY(t,d[e*s+1]),s>=3&&m.setZ(t,d[e*s+2]),s>=4&&m.setW(t,d[e*s+3]),s>=5)throw new Error("THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.")}}return m}))}loadTexture(e){const t=this.json,n=this.options,r=t.textures[e].source,i=t.images[r];let s=this.textureLoader;if(i.uri){const e=n.manager.getHandler(i.uri);null!==e&&(s=e)}return this.loadTextureImage(e,r,s)}loadTextureImage(e,t,n){const r=this,i=this.json,s=i.textures[e],a=i.images[t],o=(a.uri||a.bufferView)+":"+s.sampler;if(this.textureCache[o])return this.textureCache[o];const l=this.loadImageSource(t,n).then((function(t){t.flipY=!1,t.name=s.name||a.name||"",""===t.name&&"string"==typeof a.uri&&!1===a.uri.startsWith("data:image/")&&(t.name=a.uri);const n=(i.samplers||{})[s.sampler]||{};return t.magFilter=Gn[n.magFilter]||E,t.minFilter=Gn[n.minFilter]||I,t.wrapS=Kn[n.wrapS]||k,t.wrapT=Kn[n.wrapT]||k,r.associations.set(t,{textures:e}),t})).catch((function(){return null}));return this.textureCache[o]=l,l}loadImageSource(e,t){const n=this.json,r=this.options;if(void 0!==this.sourceCache[e])return this.sourceCache[e].then(e=>e.clone());const i=n.images[e],s=self.URL||self.webkitURL;let a=i.uri||"",o=!1;if(void 0!==i.bufferView)a=this.getDependency("bufferView",i.bufferView).then((function(e){o=!0;const t=new Blob([e],{type:i.mimeType});return a=s.createObjectURL(t),a}));else if(void 0===i.uri)throw new Error("THREE.GLTFLoader: Image "+e+" is missing URI and bufferView");const l=Promise.resolve(a).then((function(e){return new Promise((function(n,i){let s=n;!0===t.isImageBitmapLoader&&(s=function(e){const t=new le(e);t.needsUpdate=!0,n(t)}),t.load(v.resolveURL(e,r.path),s,void 0,i)}))})).then((function(e){var t;return!0===o&&s.revokeObjectURL(a),e.userData.mimeType=i.mimeType||((t=i.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",a),e}));return this.sourceCache[e]=l,l}assignTexture(e,t,n,r){const i=this;return this.getDependency("texture",n.index).then((function(s){if(!s)return null;if(void 0!==n.texCoord&&n.texCoord>0&&((s=s.clone()).channel=n.texCoord),i.extensions[vn.KHR_TEXTURE_TRANSFORM]){const e=void 0!==n.extensions?n.extensions[vn.KHR_TEXTURE_TRANSFORM]:void 0;if(e){const t=i.associations.get(s);s=i.extensions[vn.KHR_TEXTURE_TRANSFORM].extendTexture(s,e),i.associations.set(s,t)}}return void 0!==r&&(s.colorSpace=r),e[t]=s,s}))}assignFinalMaterial(e){const t=e.geometry;let n=e.material;const r=void 0===t.attributes.tangent,i=void 0!==t.attributes.color,s=void 0===t.attributes.normal;if(e.isPoints){const e="PointsMaterial:"+n.uuid;let t=this.cache.get(e);t||(t=new O,D.prototype.copy.call(t,n),t.color.copy(n.color),t.map=n.map,t.sizeAttenuation=!1,this.cache.add(e,t)),n=t}else if(e.isLine){const e="LineBasicMaterial:"+n.uuid;let t=this.cache.get(e);t||(t=new L,D.prototype.copy.call(t,n),t.color.copy(n.color),t.map=n.map,this.cache.add(e,t)),n=t}if(r||i||s){let e="ClonedMaterial:"+n.uuid+":";r&&(e+="derivative-tangents:"),i&&(e+="vertex-colors:"),s&&(e+="flat-shading:");let t=this.cache.get(e);t||(t=n.clone(),i&&(t.vertexColors=!0),s&&(t.flatShading=!0),r&&(t.normalScale&&(t.normalScale.y*=-1),t.clearcoatNormalScale&&(t.clearcoatNormalScale.y*=-1)),this.cache.add(e,t),this.associations.set(t,this.associations.get(n))),n=t}e.material=n}getMaterialType(){return U}loadMaterial(e){const t=this,n=this.json,r=this.extensions,i=n.materials[e];let a;const o={},l=[];if((i.extensions||{})[vn.KHR_MATERIALS_UNLIT]){const e=r[vn.KHR_MATERIALS_UNLIT];a=e.getMaterialType(),l.push(e.extendParams(o,i,t))}else{const n=i.pbrMetallicRoughness||{};if(o.color=new h(1,1,1),o.opacity=1,Array.isArray(n.baseColorFactor)){const e=n.baseColorFactor;o.color.fromArray(e),o.opacity=e[3]}void 0!==n.baseColorTexture&&l.push(t.assignTexture(o,"map",n.baseColorTexture,y)),o.metalness=void 0!==n.metallicFactor?n.metallicFactor:1,o.roughness=void 0!==n.roughnessFactor?n.roughnessFactor:1,void 0!==n.metallicRoughnessTexture&&(l.push(t.assignTexture(o,"metalnessMap",n.metallicRoughnessTexture)),l.push(t.assignTexture(o,"roughnessMap",n.metallicRoughnessTexture))),a=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===i.doubleSided&&(o.side=F);const d=i.alphaMode||"OPAQUE";if("BLEND"===d?(o.transparent=!0,o.depthWrite=!1):(o.transparent=!1,"MASK"===d&&(o.alphaTest=void 0!==i.alphaCutoff?i.alphaCutoff:.5)),void 0!==i.normalTexture&&a!==_&&(l.push(t.assignTexture(o,"normalMap",i.normalTexture)),o.normalScale=new s(1,1),void 0!==i.normalTexture.scale)){const e=i.normalTexture.scale;o.normalScale.set(e,e)}return void 0!==i.occlusionTexture&&a!==_&&(l.push(t.assignTexture(o,"aoMap",i.occlusionTexture)),void 0!==i.occlusionTexture.strength&&(o.aoMapIntensity=i.occlusionTexture.strength)),void 0!==i.emissiveFactor&&a!==_&&(o.emissive=(new h).fromArray(i.emissiveFactor)),void 0!==i.emissiveTexture&&a!==_&&l.push(t.assignTexture(o,"emissiveMap",i.emissiveTexture,y)),Promise.all(l).then((function(){const n=new a(o);return i.name&&(n.name=i.name),Zn(n,i),t.associations.set(n,{materials:e}),i.extensions&&Yn(r,n,i),n}))}createUniqueName(e){const t=B.sanitizeNodeName(e||"");return t in this.nodeNamesUsed?t+"_"+ ++this.nodeNamesUsed[t]:(this.nodeNamesUsed[t]=0,t)}loadGeometries(e){const t=this,n=this.extensions,r=this.primitiveCache;function i(e){return n[vn.KHR_DRACO_MESH_COMPRESSION].decodePrimitive(e,t).then((function(n){return ir(n,e,t)}))}const s=[];for(let n=0,a=e.length;n<a;n++){const a=e[n],o=$n(a),l=r[o];if(l)s.push(l.promise);else{let e;e=a.extensions&&a.extensions[vn.KHR_DRACO_MESH_COMPRESSION]?i(a):ir(new c,a,t),r[o]={primitive:a,promise:e},s.push(e)}}return Promise.all(s)}loadMesh(e){const t=this,n=this.json,r=this.extensions,i=n.meshes[e],s=i.primitives,a=[];for(let e=0,t=s.length;e<t;e++){const t=void 0===s[e].material?(void 0===(o=this.cache).DefaultMaterial&&(o.DefaultMaterial=new U({color:16777215,emissive:0,metalness:1,roughness:1,transparent:!1,depthTest:!0,side:ae})),o.DefaultMaterial):this.getDependency("material",s[e].material);a.push(t)}var o;return a.push(t.loadGeometries(s)),Promise.all(a).then((function(n){const a=n.slice(0,n.length-1),o=n[n.length-1],l=[];for(let n=0,h=o.length;n<h;n++){const h=o[n],d=s[n];let c;const u=a[n];if(d.mode===jn.TRIANGLES||d.mode===jn.TRIANGLE_STRIP||d.mode===jn.TRIANGLE_FAN||void 0===d.mode)c=!0===i.isSkinnedMesh?new N(h,u):new z(h,u),!0===c.isSkinnedMesh&&c.normalizeSkinWeights(),d.mode===jn.TRIANGLE_STRIP?c.geometry=mn(c.geometry,f):d.mode===jn.TRIANGLE_FAN&&(c.geometry=mn(c.geometry,m));else if(d.mode===jn.LINES)c=new H(h,u);else if(d.mode===jn.LINE_STRIP)c=new j(h,u);else if(d.mode===jn.LINE_LOOP)c=new V(h,u);else{if(d.mode!==jn.POINTS)throw new Error("THREE.GLTFLoader: Primitive mode unsupported: "+d.mode);c=new G(h,u)}Object.keys(c.geometry.morphAttributes).length>0&&Jn(c,i),c.name=t.createUniqueName(i.name||"mesh_"+e),Zn(c,i),d.extensions&&Yn(r,c,d),t.assignFinalMaterial(c),l.push(c)}for(let n=0,r=l.length;n<r;n++)t.associations.set(l[n],{meshes:e,primitives:n});if(1===l.length)return i.extensions&&Yn(r,l[0],i),l[0];const h=new K;i.extensions&&Yn(r,h,i),t.associations.set(h,{meshes:e});for(let e=0,t=l.length;e<t;e++)h.add(l[e]);return h}))}loadCamera(e){let t;const n=this.json.cameras[e],r=n[n.type];if(r)return"perspective"===n.type?t=new W(X.radToDeg(r.yfov),r.aspectRatio||1,r.znear||1,r.zfar||2e6):"orthographic"===n.type&&(t=new q(-r.xmag,r.xmag,r.ymag,-r.ymag,r.znear,r.zfar)),n.name&&(t.name=this.createUniqueName(n.name)),Zn(t,n),Promise.resolve(t);console.warn("THREE.GLTFLoader: Missing camera parameters.")}loadSkin(e){const t=this.json.skins[e],n=[];for(let e=0,r=t.joints.length;e<r;e++)n.push(this._loadNodeShallow(t.joints[e]));return void 0!==t.inverseBindMatrices?n.push(this.getDependency("accessor",t.inverseBindMatrices)):n.push(null),Promise.all(n).then((function(e){const n=e.pop(),r=e,i=[],s=[];for(let e=0,a=r.length;e<a;e++){const a=r[e];if(a){i.push(a);const t=new S;null!==n&&t.fromArray(n.array,16*e),s.push(t)}else console.warn('THREE.GLTFLoader: Joint "%s" could not be found.',t.joints[e])}return new Q(i,s)}))}loadAnimation(e){const t=this.json,n=this,r=t.animations[e],i=r.name?r.name:"animation_"+e,s=[],a=[],o=[],l=[],h=[];for(let e=0,t=r.channels.length;e<t;e++){const t=r.channels[e],n=r.samplers[t.sampler],i=t.target,d=i.node,c=void 0!==r.parameters?r.parameters[n.input]:n.input,u=void 0!==r.parameters?r.parameters[n.output]:n.output;void 0!==i.node&&(s.push(this.getDependency("node",d)),a.push(this.getDependency("accessor",c)),o.push(this.getDependency("accessor",u)),l.push(n),h.push(i))}return Promise.all([Promise.all(s),Promise.all(a),Promise.all(o),Promise.all(l),Promise.all(h)]).then((function(e){const t=e[0],r=e[1],s=e[2],a=e[3],o=e[4],l=[];for(let e=0,i=t.length;e<i;e++){const i=t[e],h=r[e],d=s[e],c=a[e],u=o[e];if(void 0===i)continue;i.updateMatrix&&i.updateMatrix();const p=n._createAnimationTracks(i,h,d,c,u);if(p)for(let e=0;e<p.length;e++)l.push(p[e])}return new Y(i,void 0,l)}))}createNodeMesh(e){const t=this.json,n=this,r=t.nodes[e];return void 0===r.mesh?null:n.getDependency("mesh",r.mesh).then((function(e){const t=n._getNodeRef(n.meshCache,r.mesh,e);return void 0!==r.weights&&t.traverse((function(e){if(e.isMesh)for(let t=0,n=r.weights.length;t<n;t++)e.morphTargetInfluences[t]=r.weights[t]})),t}))}loadNode(e){const t=this,n=this.json.nodes[e],r=t._loadNodeShallow(e),i=[],s=n.children||[];for(let e=0,n=s.length;e<n;e++)i.push(t.getDependency("node",s[e]));const a=void 0===n.skin?Promise.resolve(null):t.getDependency("skin",n.skin);return Promise.all([r,Promise.all(i),a]).then((function(e){const t=e[0],n=e[1],r=e[2];null!==r&&t.traverse((function(e){e.isSkinnedMesh&&e.bind(r,nr)}));for(let e=0,r=n.length;e<r;e++)t.add(n[e]);return t}))}_loadNodeShallow(e){const t=this.json,n=this.extensions,r=this;if(void 0!==this.nodeCache[e])return this.nodeCache[e];const i=t.nodes[e],s=i.name?r.createUniqueName(i.name):"",a=[],o=r._invokeOne((function(t){return t.createNodeMesh&&t.createNodeMesh(e)}));return o&&a.push(o),void 0!==i.camera&&a.push(r.getDependency("camera",i.camera).then((function(e){return r._getNodeRef(r.cameraCache,i.camera,e)}))),r._invokeAll((function(t){return t.createNodeAttachment&&t.createNodeAttachment(e)})).forEach((function(e){a.push(e)})),this.nodeCache[e]=Promise.all(a).then((function(t){let a;if(a=!0===i.isBone?new Z:t.length>1?new K:1===t.length?t[0]:new T,a!==t[0])for(let e=0,n=t.length;e<n;e++)a.add(t[e]);if(i.name&&(a.userData.name=i.name,a.name=s),Zn(a,i),i.extensions&&Yn(n,a,i),void 0!==i.matrix){const e=new S;e.fromArray(i.matrix),a.applyMatrix4(e)}else void 0!==i.translation&&a.position.fromArray(i.translation),void 0!==i.rotation&&a.quaternion.fromArray(i.rotation),void 0!==i.scale&&a.scale.fromArray(i.scale);return r.associations.has(a)||r.associations.set(a,{}),r.associations.get(a).nodes=e,a})),this.nodeCache[e]}loadScene(e){const t=this.extensions,n=this.json.scenes[e],r=this,i=new K;n.name&&(i.name=r.createUniqueName(n.name)),Zn(i,n),n.extensions&&Yn(t,i,n);const s=n.nodes||[],a=[];for(let e=0,t=s.length;e<t;e++)a.push(r.getDependency("node",s[e]));return Promise.all(a).then((function(e){for(let t=0,n=e.length;t<n;t++)i.add(e[t]);return r.associations=(e=>{const t=new Map;for(const[e,n]of r.associations)(e instanceof D||e instanceof le)&&t.set(e,n);return e.traverse(e=>{const n=r.associations.get(e);null!=n&&t.set(e,n)}),t})(i),i}))}_createAnimationTracks(e,t,n,r,i){const s=[],a=e.name?e.name:e.uuid,o=[];let l;switch(qn[i.path]===qn.weights?e.traverse((function(e){e.morphTargetInfluences&&o.push(e.name?e.name:e.uuid)})):o.push(a),qn[i.path]){case qn.weights:l=de;break;case qn.rotation:l=ce;break;case qn.position:case qn.scale:l=he;break;default:switch(n.itemSize){case 1:l=de;break;case 2:case 3:default:l=he}}const h=void 0!==r.interpolation?Qn[r.interpolation]:J,d=this._getArrayFromAccessor(n);for(let e=0,n=o.length;e<n;e++){const n=new l(o[e]+"."+qn[i.path],t.array,d,h);"CUBICSPLINE"===r.interpolation&&this._createCubicSplineTrackInterpolant(n),s.push(n)}return s}_getArrayFromAccessor(e){let t=e.array;if(e.normalized){const e=tr(t.constructor),n=new Float32Array(t.length);for(let r=0,i=t.length;r<i;r++)n[r]=t[r]*e;t=n}return t}_createCubicSplineTrackInterpolant(e){e.createInterpolant=function(e){return new(this instanceof ce?Hn:Nn)(this.times,this.values,this.getValueSize()/3,e)},e.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline=!0}}function ir(e,t,n){const r=t.attributes,i=[];function s(t,r){return n.getDependency("accessor",t).then((function(t){e.setAttribute(r,t)}))}for(const t in r){const n=Xn[t]||t.toLowerCase();n in e.attributes||i.push(s(r[t],n))}if(void 0!==t.indices&&!e.index){const r=n.getDependency("accessor",t.indices).then((function(t){e.setIndex(t)}));i.push(r)}return Zn(e,t),function(e,t,n){const r=t.attributes,i=new ue;if(void 0===r.POSITION)return;{const e=n.json.accessors[r.POSITION],t=e.min,s=e.max;if(void 0===t||void 0===s)return void console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.");if(i.set(new a(t[0],t[1],t[2]),new a(s[0],s[1],s[2])),e.normalized){const t=tr(Vn[e.componentType]);i.min.multiplyScalar(t),i.max.multiplyScalar(t)}}const s=t.targets;if(void 0!==s){const e=new a,t=new a;for(let r=0,i=s.length;r<i;r++){const i=s[r];if(void 0!==i.POSITION){const r=n.json.accessors[i.POSITION],s=r.min,a=r.max;if(void 0!==s&&void 0!==a){if(t.setX(Math.max(Math.abs(s[0]),Math.abs(a[0]))),t.setY(Math.max(Math.abs(s[1]),Math.abs(a[1]))),t.setZ(Math.max(Math.abs(s[2]),Math.abs(a[2]))),r.normalized){const e=tr(Vn[r.componentType]);t.multiplyScalar(e)}e.max(t)}else console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.")}}i.expandByVector(e)}e.boundingBox=i;const o=new pe;i.getCenter(o.center),o.radius=i.min.distanceTo(i.max)/2,e.boundingSphere=o}(e,t,n),Promise.all(i).then((function(){return void 0!==t.targets?function(e,t,n){let r=!1,i=!1,s=!1;for(let e=0,n=t.length;e<n;e++){const n=t[e];if(void 0!==n.POSITION&&(r=!0),void 0!==n.NORMAL&&(i=!0),void 0!==n.COLOR_0&&(s=!0),r&&i&&s)break}if(!r&&!i&&!s)return Promise.resolve(e);const a=[],o=[],l=[];for(let h=0,d=t.length;h<d;h++){const d=t[h];if(r){const t=void 0!==d.POSITION?n.getDependency("accessor",d.POSITION):e.attributes.position;a.push(t)}if(i){const t=void 0!==d.NORMAL?n.getDependency("accessor",d.NORMAL):e.attributes.normal;o.push(t)}if(s){const t=void 0!==d.COLOR_0?n.getDependency("accessor",d.COLOR_0):e.attributes.color;l.push(t)}}return Promise.all([Promise.all(a),Promise.all(o),Promise.all(l)]).then((function(t){const n=t[0],a=t[1],o=t[2];return r&&(e.morphAttributes.position=n),i&&(e.morphAttributes.normal=a),s&&(e.morphAttributes.color=o),e.morphTargetsRelative=!0,e}))}(e,t.targets,n):e}))}const sr=new WeakMap;class ar extends g{constructor(e){super(e),this.decoderPath="",this.decoderConfig={},this.decoderBinary=null,this.decoderPending=null,this.workerLimit=4,this.workerPool=[],this.workerNextTaskID=1,this.workerSourceURL="",this.defaultAttributeIDs={position:"POSITION",normal:"NORMAL",color:"COLOR",uv:"TEX_COORD"},this.defaultAttributeTypes={position:"Float32Array",normal:"Float32Array",color:"Float32Array",uv:"Float32Array"}}setDecoderPath(e){return this.decoderPath=e,this}setDecoderConfig(e){return this.decoderConfig=e,this}setWorkerLimit(e){return this.workerLimit=e,this}load(e,t,n,r){const i=new w(this.manager);i.setPath(this.path),i.setResponseType("arraybuffer"),i.setRequestHeader(this.requestHeader),i.setWithCredentials(this.withCredentials),i.load(e,e=>{this.parse(e,t,r)},n,r)}parse(e,t,n){this.decodeDracoFile(e,t,null,null,y).catch(n)}decodeDracoFile(e,t,n,r,i=fe){const s={attributeIDs:n||this.defaultAttributeIDs,attributeTypes:r||this.defaultAttributeTypes,useUniqueIDs:!!n,vertexColorSpace:i};return this.decodeGeometry(e,s).then(t)}decodeGeometry(e,t){const n=JSON.stringify(t);if(sr.has(e)){const t=sr.get(e);if(t.key===n)return t.promise;if(0===e.byteLength)throw new Error("THREE.DRACOLoader: Unable to re-decode a buffer with different settings. Buffer has already been transferred.")}let r;const i=this.workerNextTaskID++,s=e.byteLength,a=this._getWorker(i,s).then(n=>(r=n,new Promise((n,s)=>{r._callbacks[i]={resolve:n,reject:s},r.postMessage({type:"decode",id:i,taskConfig:t,buffer:e},[e])}))).then(e=>this._createGeometry(e.geometry));return a.catch(()=>!0).then(()=>{r&&i&&this._releaseTask(r,i)}),sr.set(e,{key:n,promise:a}),a}_createGeometry(e){const t=new c;e.index&&t.setIndex(new u(e.index.array,1));for(let n=0;n<e.attributes.length;n++){const r=e.attributes[n],i=r.name,s=r.array,a=r.itemSize,o=new u(s,a);"color"===i&&(this._assignVertexColorSpace(o,r.vertexColorSpace),o.normalized=s instanceof Float32Array==0),t.setAttribute(i,o)}return t}_assignVertexColorSpace(e,t){if(t!==y)return;const n=new h;for(let t=0,r=e.count;t<r;t++)n.fromBufferAttribute(e,t).convertSRGBToLinear(),e.setXYZ(t,n.r,n.g,n.b)}_loadLibrary(e,t){const n=new w(this.manager);return n.setPath(this.decoderPath),n.setResponseType(t),n.setWithCredentials(this.withCredentials),new Promise((t,r)=>{n.load(e,t,void 0,r)})}preload(){return this._initDecoder(),this}_initDecoder(){if(this.decoderPending)return this.decoderPending;const e="object"!=typeof WebAssembly||"js"===this.decoderConfig.type,t=[];return e?t.push(this._loadLibrary("draco_decoder.js","text")):(t.push(this._loadLibrary("draco_wasm_wrapper.js","text")),t.push(this._loadLibrary("draco_decoder.wasm","arraybuffer"))),this.decoderPending=Promise.all(t).then(t=>{const n=t[0];e||(this.decoderConfig.wasmBinary=t[1]);const r=or.toString(),i=["/* draco decoder */",n,"","/* worker */",r.substring(r.indexOf("{")+1,r.lastIndexOf("}"))].join("\n");this.workerSourceURL=URL.createObjectURL(new Blob([i]))}),this.decoderPending}_getWorker(e,t){return this._initDecoder().then(()=>{if(this.workerPool.length<this.workerLimit){const e=new Worker(this.workerSourceURL);e._callbacks={},e._taskCosts={},e._taskLoad=0,e.postMessage({type:"init",decoderConfig:this.decoderConfig}),e.onmessage=function(t){const n=t.data;switch(n.type){case"decode":e._callbacks[n.id].resolve(n);break;case"error":e._callbacks[n.id].reject(n);break;default:console.error('THREE.DRACOLoader: Unexpected message, "'+n.type+'"')}},this.workerPool.push(e)}else this.workerPool.sort((function(e,t){return e._taskLoad>t._taskLoad?-1:1}));const n=this.workerPool[this.workerPool.length-1];return n._taskCosts[e]=t,n._taskLoad+=t,n})}_releaseTask(e,t){e._taskLoad-=e._taskCosts[t],delete e._callbacks[t],delete e._taskCosts[t]}debug(){this.workerPool.map(e=>e._taskLoad)}dispose(){for(let e=0;e<this.workerPool.length;++e)this.workerPool[e].terminate();return this.workerPool.length=0,""!==this.workerSourceURL&&URL.revokeObjectURL(this.workerSourceURL),this}}function or(){let e,t;function n(e,t,n,r,i,s){const a=s.num_components(),o=n.num_points()*a,l=o*i.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,i),d=e._malloc(l);t.GetAttributeDataArrayForAllPoints(n,s,h,l,d);const c=new i(e.HEAPF32.buffer,d,o).slice();return e._free(d),{name:r,array:c,itemSize:a}}onmessage=function(r){const i=r.data;switch(i.type){case"init":e=i.decoderConfig,t=new Promise((function(t){e.onModuleLoaded=function(e){t({draco:e})},DracoDecoderModule(e)}));break;case"decode":const r=i.buffer,s=i.taskConfig;t.then(e=>{const t=e.draco,a=new t.Decoder;try{const e=function(e,t,r,i){const s=i.attributeIDs,a=i.attributeTypes;let o,l;const h=t.GetEncodedGeometryType(r);if(h===e.TRIANGULAR_MESH)o=new e.Mesh,l=t.DecodeArrayToMesh(r,r.byteLength,o);else{if(h!==e.POINT_CLOUD)throw new Error("THREE.DRACOLoader: Unexpected geometry type.");o=new e.PointCloud,l=t.DecodeArrayToPointCloud(r,r.byteLength,o)}if(!l.ok()||0===o.ptr)throw new Error("THREE.DRACOLoader: Decoding failed: "+l.error_msg());const d={index:null,attributes:[]};for(const r in s){const l=self[a[r]];let h,c;if(i.useUniqueIDs)c=s[r],h=t.GetAttributeByUniqueId(o,c);else{if(c=t.GetAttributeId(o,e[s[r]]),-1===c)continue;h=t.GetAttribute(o,c)}const u=n(e,t,o,r,l,h);"color"===r&&(u.vertexColorSpace=i.vertexColorSpace),d.attributes.push(u)}return h===e.TRIANGULAR_MESH&&(d.index=function(e,t,n){const r=3*n.num_faces(),i=4*r,s=e._malloc(i);t.GetTrianglesUInt32Array(n,i,s);const a=new Uint32Array(e.HEAPF32.buffer,s,r).slice();return e._free(s),{array:a,itemSize:1}}(e,t,o)),e.destroy(o),d}(t,a,new Int8Array(r),s),o=e.attributes.map(e=>e.array.buffer);e.index&&o.push(e.index.array.buffer),self.postMessage({type:"decode",id:i.id,geometry:e},o)}catch(e){console.error(e),self.postMessage({type:"error",id:i.id,error:e.message})}finally{t.destroy(a)}})}}}const lr={"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 hr{static setEnvMapIntensity(e){this._envMapIntensity=e}static createMeshPhysicalMaterial(e){return e.envMapIntensity=this._envMapIntensity,new x(e)}static createMeshStandardMaterial(e){return e.envMapIntensity=this._envMapIntensity,new U(e)}static getEnvMapIntensity(){return this._envMapIntensity}}e("V",hr),hr._envMapIntensity=1.5;class dr{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,n="rml_default",r=5){const i=this.getStore(n),s=i.entries.find(t=>t.id===e);if(s?(s.payload=t,s.date=Date.now()):i.entries.push({id:e,date:Date.now(),payload:t}),i.entries.length>r)for(i.entries.sort((e,t)=>t.date-e.date);i.entries.length>r;)i.entries.pop();this.saveStore(n,i)}getItem(e,t="rml_default"){const n=this.getStore(t).entries.find(t=>t.id===e);return n?n.payload:null}}tn([rn],dr.prototype,"_localStorage",void 0);const cr=e("t",(function(e){return e*(Math.PI/180)})),ur=e("y",(function(e){return e*(180/Math.PI)})),pr=(e("w",(function(e,t,n,r,i,s){e=Math.sqrt(e*e+n*n);const a=i/s,o=2*Math.atan(Math.tan(r*Math.PI/180/2)*a)*180/Math.PI,l=cr(r),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}),mr=(e("a0",(function(e,t){return Math.abs(e.y-t.y)+Math.abs(e.x-t.x)})),e("a9",e=>new a(e.x/1e3,e.z/1e3,e.y/-1e3))),fr=e=>new a(e.x/1e3,e.z/1e3,e.y/1e3),gr=e("h",e=>({x:Math.round(1e3*e.x),y:Math.round(-1e3*e.z),z:Math.round(1e3*e.y)})),vr=e=>decodeURIComponent(encodeURIComponent(e)),wr=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=br(e);for(let e=0;e<t.length;e++)t[e]=wr(t[e]);return"string"==typeof t?vr(t):t}if("object"==typeof e)for(let t in e)e.hasOwnProperty(t)&&(e[t]=wr(e[t]));return"string"==typeof e?vr(e):e}),br=e=>{let t=[];if(e){let n=e.size();for(let r=0;r<n;r++)t.push(e.get(r))}return t},_r=e=>{let t=new S,n=wr(e);return t.fromArray(n),t.transpose(),(e=>{let t=new S;t.set(1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1),t.scale(new a(.001,.001,.001));let n=new S;return n.set(1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1),n.scale(new a(1e3,1e3,1e3)),t.multiply(e).multiply(n)})(t)};function yr(e,t){var n=e.__state.conversionName.toString(),r=Math.round(e.r),i=Math.round(e.g),s=Math.round(e.b),a=e.a,o=Math.round(e.h),l=e.s.toFixed(1),h=e.v.toFixed(1);if(t||"THREE_CHAR_HEX"===n||"SIX_CHAR_HEX"===n){for(var d=e.hex.toString(16);d.length<6;)d="0"+d;return"#"+d}return"CSS_RGB"===n?"rgb("+r+","+i+","+s+")":"CSS_RGBA"===n?"rgba("+r+","+i+","+s+","+a+")":"HEX"===n?"0x"+e.hex.toString(16):"RGB_ARRAY"===n?"["+r+","+i+","+s+"]":"RGBA_ARRAY"===n?"["+r+","+i+","+s+","+a+"]":"RGB_OBJ"===n?"{r:"+r+",g:"+i+",b:"+s+"}":"RGBA_OBJ"===n?"{r:"+r+",g:"+i+",b:"+s+",a:"+a+"}":"HSV_OBJ"===n?"{h:"+o+",s:"+l+",v:"+h+"}":"HSVA_OBJ"===n?"{h:"+o+",s:"+l+",v:"+h+",a:"+a+"}":"unknown format"}var xr=Array.prototype.forEach,Sr=Array.prototype.slice,Cr={BREAK:{},extend:function(e){return this.each(Sr.call(arguments,1),(function(t){(this.isObject(t)?Object.keys(t):[]).forEach(function(n){this.isUndefined(t[n])||(e[n]=t[n])}.bind(this))}),this),e},defaults:function(e){return this.each(Sr.call(arguments,1),(function(t){(this.isObject(t)?Object.keys(t):[]).forEach(function(n){this.isUndefined(e[n])&&(e[n]=t[n])}.bind(this))}),this),e},compose:function(){var e=Sr.call(arguments);return function(){for(var t=Sr.call(arguments),n=e.length-1;n>=0;n--)t=[e[n].apply(this,t)];return t[0]}},each:function(e,t,n){if(e)if(xr&&e.forEach&&e.forEach===xr)e.forEach(t,n);else if(e.length===e.length+0){var r,i=void 0;for(i=0,r=e.length;i<r;i++)if(i in e&&t.call(n,e[i],i)===this.BREAK)return}else for(var s in e)if(t.call(n,e[s],s)===this.BREAK)return},defer:function(e){setTimeout(e,0)},debounce:function(e,t,n){var r=void 0;return function(){var i=this,s=arguments;function a(){r=null,n||e.apply(i,s)}var o=n||!r;clearTimeout(r),r=setTimeout(a,t),o&&e.apply(i,s)}},toArray:function(e){return e.toArray?e.toArray():Sr.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}},Mr=[{litmus:Cr.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:yr},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:yr},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:yr},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:yr}}},{litmus:Cr.isNumber,conversions:{HEX:{read:function(e){return{space:"HEX",hex:e,conversionName:"HEX"}},write:function(e){return e.hex}}}},{litmus:Cr.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:Cr.isObject,conversions:{RGBA_OBJ:{read:function(e){return!!(Cr.isNumber(e.r)&&Cr.isNumber(e.g)&&Cr.isNumber(e.b)&&Cr.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!!(Cr.isNumber(e.r)&&Cr.isNumber(e.g)&&Cr.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!!(Cr.isNumber(e.h)&&Cr.isNumber(e.s)&&Cr.isNumber(e.v)&&Cr.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!!(Cr.isNumber(e.h)&&Cr.isNumber(e.s)&&Cr.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}}}}}],Tr=void 0,Ar=void 0,Pr=function(){Ar=!1;var e=arguments.length>1?Cr.toArray(arguments):arguments[0];return Cr.each(Mr,(function(t){if(t.litmus(e))return Cr.each(t.conversions,(function(t,n){if(Tr=t.read(e),!1===Ar&&!1!==Tr)return Ar=Tr,Tr.conversionName=n,Tr.conversion=t,Cr.BREAK})),Cr.BREAK})),Ar},Rr=void 0,Er={hsv_to_rgb:function(e,t,n){var r=Math.floor(e/60)%6,i=e/60-Math.floor(e/60),s=n*(1-t),a=n*(1-i*t),o=n*(1-(1-i)*t),l=[[n,o,s],[a,n,s],[s,n,o],[s,a,n],[o,s,n],[n,s,a]][r];return{r:255*l[0],g:255*l[1],b:255*l[2]}},rgb_to_hsv:function(e,t,n){var r=Math.min(e,t,n),i=Math.max(e,t,n),s=i-r,a=void 0;return 0===i?{h:NaN,s:0,v:0}:(a=e===i?(t-n)/s:t===i?2+(n-e)/s:4+(e-t)/s,(a/=6)<0&&(a+=1),{h:360*a,s:s/i,v:i/255})},rgb_to_hex:function(e,t,n){var r=this.hex_with_component(0,2,e);return r=this.hex_with_component(r,1,t),this.hex_with_component(r,0,n)},component_from_hex:function(e,t){return e>>8*t&255},hex_with_component:function(e,t,n){return n<<(Rr=8*t)|e&~(255<<Rr)}},Ir="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},kr=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},Or=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}(),Dr=function e(t,n,r){null===t&&(t=Function.prototype);var i=Object.getOwnPropertyDescriptor(t,n);if(void 0===i){var s=Object.getPrototypeOf(t);return null===s?void 0:e(s,n,r)}if("value"in i)return i.value;var a=i.get;return void 0!==a?a.call(r):void 0},Lr=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof 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)},Ur=function(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t},Fr=function(){function e(){if(kr(this,e),this.__state=Pr.apply(this,arguments),!1===this.__state)throw new Error("Failed to interpret color arguments");this.__state.a=this.__state.a||1}return Or(e,[{key:"toString",value:function(){return yr(this)}},{key:"toHexString",value:function(){return yr(this,!0)}},{key:"toOriginal",value:function(){return this.__state.conversion.write(this)}}]),e}();function Br(e,t,n){Object.defineProperty(e,t,{get:function(){return"RGB"===this.__state.space||Fr.recalculateRGB(this,t,n),this.__state[t]},set:function(e){"RGB"!==this.__state.space&&(Fr.recalculateRGB(this,t,n),this.__state.space="RGB"),this.__state[t]=e}})}function Nr(e,t){Object.defineProperty(e,t,{get:function(){return"HSV"===this.__state.space||Fr.recalculateHSV(this),this.__state[t]},set:function(e){"HSV"!==this.__state.space&&(Fr.recalculateHSV(this),this.__state.space="HSV"),this.__state[t]=e}})}Fr.recalculateRGB=function(e,t,n){if("HEX"===e.__state.space)e.__state[t]=Er.component_from_hex(e.__state.hex,n);else{if("HSV"!==e.__state.space)throw new Error("Corrupted color state");Cr.extend(e.__state,Er.hsv_to_rgb(e.__state.h,e.__state.s,e.__state.v))}},Fr.recalculateHSV=function(e){var t=Er.rgb_to_hsv(e.r,e.g,e.b);Cr.extend(e.__state,{s:t.s,v:t.v}),Cr.isNaN(t.h)?Cr.isUndefined(e.__state.h)&&(e.__state.h=0):e.__state.h=t.h},Fr.COMPONENTS=["r","g","b","h","s","v","hex","a"],Br(Fr.prototype,"r",2),Br(Fr.prototype,"g",1),Br(Fr.prototype,"b",0),Nr(Fr.prototype,"h"),Nr(Fr.prototype,"s"),Nr(Fr.prototype,"v"),Object.defineProperty(Fr.prototype,"a",{get:function(){return this.__state.a},set:function(e){this.__state.a=e}}),Object.defineProperty(Fr.prototype,"hex",{get:function(){return"HEX"!==this.__state.space&&(this.__state.hex=Er.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 zr=function(){function e(t,n){kr(this,e),this.initialValue=t[n],this.domElement=document.createElement("div"),this.object=t,this.property=n,this.__onChange=void 0,this.__onFinishChange=void 0}return Or(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}(),Hr={};Cr.each({HTMLEvents:["change"],MouseEvents:["click","mousemove","mousedown","mouseup","mouseover"],KeyboardEvents:["keydown"]},(function(e,t){Cr.each(e,(function(e){Hr[e]=t}))}));var jr=/(\d+(\.\d+)?)px/;function Vr(e){if("0"===e||Cr.isUndefined(e))return 0;var t=e.match(jr);return Cr.isNull(t)?0:parseFloat(t[1])}var Gr={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,n){var r=n,i=t;Cr.isUndefined(i)&&(i=!0),Cr.isUndefined(r)&&(r=!0),e.style.position="absolute",i&&(e.style.left=0,e.style.right=0),r&&(e.style.top=0,e.style.bottom=0)},fakeEvent:function(e,t,n,r){var i=n||{},s=Hr[t];if(!s)throw new Error("Event type "+t+" not supported.");var a=document.createEvent(s);switch(s){case"MouseEvents":var o=i.x||i.clientX||0,l=i.y||i.clientY||0;a.initMouseEvent(t,i.bubbles||!1,i.cancelable||!0,window,i.clickCount||1,0,0,o,l,!1,!1,!1,!1,0,null);break;case"KeyboardEvents":var h=a.initKeyboardEvent||a.initKeyEvent;Cr.defaults(i,{cancelable:!0,ctrlKey:!1,altKey:!1,shiftKey:!1,metaKey:!1,keyCode:void 0,charCode:void 0}),h(t,i.bubbles||!1,i.cancelable,window,i.ctrlKey,i.altKey,i.shiftKey,i.metaKey,i.keyCode,i.charCode);break;default:a.initEvent(t,i.bubbles||!1,i.cancelable||!0)}Cr.defaults(a,r),e.dispatchEvent(a)},bind:function(e,t,n,r){var i=r||!1;return e.addEventListener?e.addEventListener(t,n,i):e.attachEvent&&e.attachEvent("on"+t,n),Gr},unbind:function(e,t,n,r){var i=r||!1;return e.removeEventListener?e.removeEventListener(t,n,i):e.detachEvent&&e.detachEvent("on"+t,n),Gr},addClass:function(e,t){if(void 0===e.className)e.className=t;else if(e.className!==t){var n=e.className.split(/ +/);-1===n.indexOf(t)&&(n.push(t),e.className=n.join(" ").replace(/^\s+/,"").replace(/\s+$/,""))}return Gr},removeClass:function(e,t){if(t)if(e.className===t)e.removeAttribute("class");else{var n=e.className.split(/ +/),r=n.indexOf(t);-1!==r&&(n.splice(r,1),e.className=n.join(" "))}else e.className=void 0;return Gr},hasClass:function(e,t){return new RegExp("(?:^|\\s+)"+t+"(?:\\s+|$)").test(e.className)||!1},getWidth:function(e){var t=getComputedStyle(e);return Vr(t["border-left-width"])+Vr(t["border-right-width"])+Vr(t["padding-left"])+Vr(t["padding-right"])+Vr(t.width)},getHeight:function(e){var t=getComputedStyle(e);return Vr(t["border-top-width"])+Vr(t["border-bottom-width"])+Vr(t["padding-top"])+Vr(t["padding-bottom"])+Vr(t.height)},getOffset:function(e){var t=e,n={left:0,top:0};if(t.offsetParent)do{n.left+=t.offsetLeft,n.top+=t.offsetTop,t=t.offsetParent}while(t);return n},isActive:function(e){return e===document.activeElement&&(e.type||e.href)}},Kr=function(e){function t(e,n){kr(this,t);var r=Ur(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n)),i=r;return r.__prev=r.getValue(),r.__checkbox=document.createElement("input"),r.__checkbox.setAttribute("type","checkbox"),Gr.bind(r.__checkbox,"change",(function(){i.setValue(!i.__prev)}),!1),r.domElement.appendChild(r.__checkbox),r.updateDisplay(),r}return Lr(t,e),Or(t,[{key:"setValue",value:function(e){var n=Dr(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(),n}},{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),Dr(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(zr),Wr=function(e){function t(e,n,r){kr(this,t);var i=Ur(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n)),s=r,a=i;if(i.__select=document.createElement("select"),Cr.isArray(s)){var o={};Cr.each(s,(function(e){o[e]=e})),s=o}return Cr.each(s,(function(e,t){var n=document.createElement("option");n.innerHTML=t,n.setAttribute("value",e),a.__select.appendChild(n)})),i.updateDisplay(),Gr.bind(i.__select,"change",(function(){var e=this.options[this.selectedIndex].value;a.setValue(e)})),i.domElement.appendChild(i.__select),i}return Lr(t,e),Or(t,[{key:"setValue",value:function(e){var n=Dr(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"setValue",this).call(this,e);return this.__onFinishChange&&this.__onFinishChange.call(this,this.getValue()),n}},{key:"updateDisplay",value:function(){return Gr.isActive(this.__select)?this:(this.__select.value=this.getValue(),Dr(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this))}}]),t}(zr),Xr=function(e){function t(e,n){kr(this,t);var r=Ur(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n)),i=r;function s(){i.setValue(i.__input.value)}return r.__input=document.createElement("input"),r.__input.setAttribute("type","text"),Gr.bind(r.__input,"keyup",s),Gr.bind(r.__input,"change",s),Gr.bind(r.__input,"blur",(function(){i.__onFinishChange&&i.__onFinishChange.call(i,i.getValue())})),Gr.bind(r.__input,"keydown",(function(e){13===e.keyCode&&this.blur()})),r.updateDisplay(),r.domElement.appendChild(r.__input),r}return Lr(t,e),Or(t,[{key:"updateDisplay",value:function(){return Gr.isActive(this.__input)||(this.__input.value=this.getValue()),Dr(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(zr);function qr(e){var t=e.toString();return t.indexOf(".")>-1?t.length-t.indexOf(".")-1:0}var Qr=function(e){function t(e,n,r){kr(this,t);var i=Ur(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n)),s=r||{};return i.__min=s.min,i.__max=s.max,i.__step=s.step,Cr.isUndefined(i.__step)?0===i.initialValue?i.__impliedStep=1:i.__impliedStep=Math.pow(10,Math.floor(Math.log(Math.abs(i.initialValue))/Math.LN10))/10:i.__impliedStep=i.__step,i.__precision=qr(i.__impliedStep),i}return Lr(t,e),Or(t,[{key:"setValue",value:function(e){var n=e;return void 0!==this.__min&&n<this.__min?n=this.__min:void 0!==this.__max&&n>this.__max&&(n=this.__max),void 0!==this.__step&&n%this.__step!=0&&(n=Math.round(n/this.__step)*this.__step),Dr(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"setValue",this).call(this,n)}},{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=qr(e),this}}]),t}(zr),Yr=function(e){function t(e,n,r){kr(this,t);var i=Ur(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n,r));i.__truncationSuspended=!1;var s=i,a=void 0;function o(){s.__onFinishChange&&s.__onFinishChange.call(s,s.getValue())}function l(e){var t=a-e.clientY;s.setValue(s.getValue()+t*s.__impliedStep),a=e.clientY}function h(){Gr.unbind(window,"mousemove",l),Gr.unbind(window,"mouseup",h),o()}return i.__input=document.createElement("input"),i.__input.setAttribute("type","text"),Gr.bind(i.__input,"change",(function(){var e=parseFloat(s.__input.value);Cr.isNaN(e)||s.setValue(e)})),Gr.bind(i.__input,"blur",(function(){o()})),Gr.bind(i.__input,"mousedown",(function(e){Gr.bind(window,"mousemove",l),Gr.bind(window,"mouseup",h),a=e.clientY})),Gr.bind(i.__input,"keydown",(function(e){13===e.keyCode&&(s.__truncationSuspended=!0,this.blur(),s.__truncationSuspended=!1,o())})),i.updateDisplay(),i.domElement.appendChild(i.__input),i}return Lr(t,e),Or(t,[{key:"updateDisplay",value:function(){var e,n,r;return this.__input.value=this.__truncationSuspended?this.getValue():(e=this.getValue(),n=this.__precision,r=Math.pow(10,n),Math.round(e*r)/r),Dr(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(Qr);function Zr(e,t,n,r,i){return r+(e-t)/(n-t)*(i-r)}var Jr=function(e){function t(e,n,r,i,s){kr(this,t);var a=Ur(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n,{min:r,max:i,step:s})),o=a;function l(e){e.preventDefault();var t=o.__background.getBoundingClientRect();return o.setValue(Zr(e.clientX,t.left,t.right,o.__min,o.__max)),!1}function h(){Gr.unbind(window,"mousemove",l),Gr.unbind(window,"mouseup",h),o.__onFinishChange&&o.__onFinishChange.call(o,o.getValue())}function d(e){var t=e.touches[0].clientX,n=o.__background.getBoundingClientRect();o.setValue(Zr(t,n.left,n.right,o.__min,o.__max))}function c(){Gr.unbind(window,"touchmove",d),Gr.unbind(window,"touchend",c),o.__onFinishChange&&o.__onFinishChange.call(o,o.getValue())}return a.__background=document.createElement("div"),a.__foreground=document.createElement("div"),Gr.bind(a.__background,"mousedown",(function(e){document.activeElement.blur(),Gr.bind(window,"mousemove",l),Gr.bind(window,"mouseup",h),l(e)})),Gr.bind(a.__background,"touchstart",(function(e){1===e.touches.length&&(Gr.bind(window,"touchmove",d),Gr.bind(window,"touchend",c),d(e))})),Gr.addClass(a.__background,"slider"),Gr.addClass(a.__foreground,"slider-fg"),a.updateDisplay(),a.__background.appendChild(a.__foreground),a.domElement.appendChild(a.__background),a}return Lr(t,e),Or(t,[{key:"updateDisplay",value:function(){var e=(this.getValue()-this.__min)/(this.__max-this.__min);return this.__foreground.style.width=100*e+"%",Dr(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(Qr),$r=function(e){function t(e,n,r){kr(this,t);var i=Ur(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n)),s=i;return i.__button=document.createElement("div"),i.__button.innerHTML=void 0===r?"Fire":r,Gr.bind(i.__button,"click",(function(e){return e.preventDefault(),s.fire(),!1})),Gr.addClass(i.__button,"button"),i.domElement.appendChild(i.__button),i}return Lr(t,e),Or(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}(zr),ei=function(e){function t(e,n){kr(this,t);var r=Ur(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n));r.__color=new Fr(r.getValue()),r.__temp=new Fr(0);var i=r;r.domElement=document.createElement("div"),Gr.makeSelectable(r.domElement,!1),r.__selector=document.createElement("div"),r.__selector.className="selector",r.__saturation_field=document.createElement("div"),r.__saturation_field.className="saturation-field",r.__field_knob=document.createElement("div"),r.__field_knob.className="field-knob",r.__field_knob_border="2px solid ",r.__hue_knob=document.createElement("div"),r.__hue_knob.className="hue-knob",r.__hue_field=document.createElement("div"),r.__hue_field.className="hue-field",r.__input=document.createElement("input"),r.__input.type="text",r.__input_textShadow="0 1px 1px ",Gr.bind(r.__input,"keydown",(function(e){13===e.keyCode&&c.call(this)})),Gr.bind(r.__input,"blur",c),Gr.bind(r.__selector,"mousedown",(function(){Gr.addClass(this,"drag").bind(window,"mouseup",(function(){Gr.removeClass(i.__selector,"drag")}))})),Gr.bind(r.__selector,"touchstart",(function(){Gr.addClass(this,"drag").bind(window,"touchend",(function(){Gr.removeClass(i.__selector,"drag")}))}));var s,a=document.createElement("div");function o(e){p(e),Gr.bind(window,"mousemove",p),Gr.bind(window,"touchmove",p),Gr.bind(window,"mouseup",h),Gr.bind(window,"touchend",h)}function l(e){m(e),Gr.bind(window,"mousemove",m),Gr.bind(window,"touchmove",m),Gr.bind(window,"mouseup",d),Gr.bind(window,"touchend",d)}function h(){Gr.unbind(window,"mousemove",p),Gr.unbind(window,"touchmove",p),Gr.unbind(window,"mouseup",h),Gr.unbind(window,"touchend",h),u()}function d(){Gr.unbind(window,"mousemove",m),Gr.unbind(window,"touchmove",m),Gr.unbind(window,"mouseup",d),Gr.unbind(window,"touchend",d),u()}function c(){var e=Pr(this.value);!1!==e?(i.__color.__state=e,i.setValue(i.__color.toOriginal())):this.value=i.__color.toString()}function u(){i.__onFinishChange&&i.__onFinishChange.call(i,i.__color.toOriginal())}function p(e){-1===e.type.indexOf("touch")&&e.preventDefault();var t=i.__saturation_field.getBoundingClientRect(),n=e.touches&&e.touches[0]||e,r=n.clientX,s=n.clientY,a=(r-t.left)/(t.right-t.left),o=1-(s-t.top)/(t.bottom-t.top);return o>1?o=1:o<0&&(o=0),a>1?a=1:a<0&&(a=0),i.__color.v=o,i.__color.s=a,i.setValue(i.__color.toOriginal()),!1}function m(e){-1===e.type.indexOf("touch")&&e.preventDefault();var t=i.__hue_field.getBoundingClientRect(),n=1-((e.touches&&e.touches[0]||e).clientY-t.top)/(t.bottom-t.top);return n>1?n=1:n<0&&(n=0),i.__color.h=360*n,i.setValue(i.__color.toOriginal()),!1}return Cr.extend(r.__selector.style,{width:"122px",height:"102px",padding:"3px",backgroundColor:"#222",boxShadow:"0px 1px 3px rgba(0,0,0,0.3)"}),Cr.extend(r.__field_knob.style,{position:"absolute",width:"12px",height:"12px",border:r.__field_knob_border+(r.__color.v<.5?"#fff":"#000"),boxShadow:"0px 1px 3px rgba(0,0,0,0.5)",borderRadius:"12px",zIndex:1}),Cr.extend(r.__hue_knob.style,{position:"absolute",width:"15px",height:"2px",borderRight:"4px solid #fff",zIndex:1}),Cr.extend(r.__saturation_field.style,{width:"100px",height:"100px",border:"1px solid #555",marginRight:"3px",display:"inline-block",cursor:"pointer"}),Cr.extend(a.style,{width:"100%",height:"100%",background:"none"}),ni(a,"top","rgba(0,0,0,0)","#000"),Cr.extend(r.__hue_field.style,{width:"15px",height:"100px",border:"1px solid #555",cursor:"ns-resize",position:"absolute",top:"3px",right:"3px"}),(s=r.__hue_field).style.background="",s.style.cssText+="background: -moz-linear-gradient(top, #ff0000 0%, #ff00ff 17%, #0000ff 34%, #00ffff 50%, #00ff00 67%, #ffff00 84%, #ff0000 100%);",s.style.cssText+="background: -webkit-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",s.style.cssText+="background: -o-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",s.style.cssText+="background: -ms-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",s.style.cssText+="background: linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",Cr.extend(r.__input.style,{outline:"none",textAlign:"center",color:"#fff",border:0,fontWeight:"bold",textShadow:r.__input_textShadow+"rgba(0,0,0,0.7)"}),Gr.bind(r.__saturation_field,"mousedown",o),Gr.bind(r.__saturation_field,"touchstart",o),Gr.bind(r.__field_knob,"mousedown",o),Gr.bind(r.__field_knob,"touchstart",o),Gr.bind(r.__hue_field,"mousedown",l),Gr.bind(r.__hue_field,"touchstart",l),r.__saturation_field.appendChild(a),r.__selector.appendChild(r.__field_knob),r.__selector.appendChild(r.__saturation_field),r.__selector.appendChild(r.__hue_field),r.__hue_field.appendChild(r.__hue_knob),r.domElement.appendChild(r.__input),r.domElement.appendChild(r.__selector),r.updateDisplay(),r}return Lr(t,e),Or(t,[{key:"updateDisplay",value:function(){var e=Pr(this.getValue());if(!1!==e){var t=!1;Cr.each(Fr.COMPONENTS,(function(n){if(!Cr.isUndefined(e[n])&&!Cr.isUndefined(this.__color.__state[n])&&e[n]!==this.__color.__state[n])return t=!0,{}}),this),t&&Cr.extend(this.__color.__state,e)}Cr.extend(this.__temp.__state,this.__color.__state),this.__temp.a=1;var n=this.__color.v<.5||this.__color.s>.5?255:0,r=255-n;Cr.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("+n+","+n+","+n+")"}),this.__hue_knob.style.marginTop=100*(1-this.__color.h/360)+"px",this.__temp.s=1,this.__temp.v=1,ni(this.__saturation_field,"left","#fff",this.__temp.toHexString()),this.__input.value=this.__color.toString(),Cr.extend(this.__input.style,{backgroundColor:this.__color.toHexString(),color:"rgb("+n+","+n+","+n+")",textShadow:this.__input_textShadow+"rgba("+r+","+r+","+r+",.7)"})}}]),t}(zr),ti=["-moz-","-o-","-webkit-","-ms-",""];function ni(e,t,n,r){e.style.background="",Cr.each(ti,(function(i){e.style.cssText+="background: "+i+"linear-gradient("+t+", "+n+" 0%, "+r+" 100%); "}))}var ri='<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>',ii=function(e,t){var n=e[t];return Cr.isArray(arguments[2])||Cr.isObject(arguments[2])?new Wr(e,t,arguments[2]):Cr.isNumber(n)?Cr.isNumber(arguments[2])&&Cr.isNumber(arguments[3])?Cr.isNumber(arguments[4])?new Jr(e,t,arguments[2],arguments[3],arguments[4]):new Jr(e,t,arguments[2],arguments[3]):Cr.isNumber(arguments[4])?new Yr(e,t,{min:arguments[2],max:arguments[3],step:arguments[4]}):new Yr(e,t,{min:arguments[2],max:arguments[3]}):Cr.isString(n)?new Xr(e,t):Cr.isFunction(n)?new $r(e,t,""):Cr.isBoolean(n)?new Kr(e,t):null},si=window.requestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(e){setTimeout(e,1e3/60)},ai=function(){function e(){kr(this,e),this.backgroundElement=document.createElement("div"),Cr.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"}),Gr.makeFullscreen(this.backgroundElement),this.backgroundElement.style.position="fixed",this.domElement=document.createElement("div"),Cr.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;Gr.bind(this.backgroundElement,"click",(function(){t.hide()}))}return Or(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(),Cr.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",Gr.unbind(e.domElement,"webkitTransitionEnd",t),Gr.unbind(e.domElement,"transitionend",t),Gr.unbind(e.domElement,"oTransitionEnd",t)};Gr.bind(this.domElement,"webkitTransitionEnd",t),Gr.bind(this.domElement,"transitionend",t),Gr.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-Gr.getWidth(this.domElement)/2+"px",this.domElement.style.top=window.innerHeight/2-Gr.getHeight(this.domElement)/2+"px"}}]),e}();!function(e,t){var n=document,r=document.createElement("style");r.type="text/css",r.innerHTML=e;var i=n.getElementsByTagName("head")[0];try{i.appendChild(r)}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 oi=function(){try{return!!window.localStorage}catch(e){return!1}}(),li=void 0,hi=!0,di=void 0,ci=!1,ui=[],pi=function e(t){var n=this,r=t||{};this.domElement=document.createElement("div"),this.__ul=document.createElement("ul"),this.domElement.appendChild(this.__ul),Gr.addClass(this.domElement,"dg"),this.__folders={},this.__controllers=[],this.__rememberedObjects=[],this.__rememberedObjectIndecesToControllers=[],this.__listening=[],r=Cr.defaults(r,{closeOnTop:!1,autoPlace:!0,width:e.DEFAULT_WIDTH}),r=Cr.defaults(r,{resizable:r.autoPlace,hideable:r.autoPlace}),Cr.isUndefined(r.load)?r.load={preset:"Default"}:r.preset&&(r.load.preset=r.preset),Cr.isUndefined(r.parent)&&r.hideable&&ui.push(this),r.resizable=Cr.isUndefined(r.parent)&&r.resizable,r.autoPlace&&Cr.isUndefined(r.scrollable)&&(r.scrollable=!0);var i,s=oi&&"true"===localStorage.getItem(bi(0,"isLocal")),a=void 0,o=void 0;if(Object.defineProperties(this,{parent:{get:function(){return r.parent}},scrollable:{get:function(){return r.scrollable}},autoPlace:{get:function(){return r.autoPlace}},closeOnTop:{get:function(){return r.closeOnTop}},preset:{get:function(){return n.parent?n.getRoot().preset:r.load.preset},set:function(e){n.parent?n.getRoot().preset=e:r.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),n.revert()}},width:{get:function(){return r.width},set:function(e){r.width=e,Ci(n,e)}},name:{get:function(){return r.name},set:function(e){r.name=e,o&&(o.innerHTML=r.name)}},closed:{get:function(){return r.closed},set:function(t){r.closed=t,r.closed?Gr.addClass(n.__ul,e.CLASS_CLOSED):Gr.removeClass(n.__ul,e.CLASS_CLOSED),this.onResize(),n.__closeButton&&(n.__closeButton.innerHTML=t?e.TEXT_OPEN:e.TEXT_CLOSED)}},load:{get:function(){return r.load}},useLocalStorage:{get:function(){return s},set:function(e){oi&&(s=e,e?Gr.bind(window,"unload",a):Gr.unbind(window,"unload",a),localStorage.setItem(bi(0,"isLocal"),e))}}}),Cr.isUndefined(r.parent)){if(this.closed=r.closed||!1,Gr.addClass(this.domElement,e.CLASS_MAIN),Gr.makeSelectable(this.domElement,!1),oi&&s){n.useLocalStorage=!0;var l=localStorage.getItem(bi(0,"gui"));l&&(r.load=JSON.parse(l))}this.__closeButton=document.createElement("div"),this.__closeButton.innerHTML=e.TEXT_CLOSED,Gr.addClass(this.__closeButton,e.CLASS_CLOSE_BUTTON),r.closeOnTop?(Gr.addClass(this.__closeButton,e.CLASS_CLOSE_TOP),this.domElement.insertBefore(this.__closeButton,this.domElement.childNodes[0])):(Gr.addClass(this.__closeButton,e.CLASS_CLOSE_BOTTOM),this.domElement.appendChild(this.__closeButton)),Gr.bind(this.__closeButton,"click",(function(){n.closed=!n.closed}))}else{void 0===r.closed&&(r.closed=!0);var h=document.createTextNode(r.name);Gr.addClass(h,"controller-name"),o=mi(n,h),Gr.addClass(this.__ul,e.CLASS_CLOSED),Gr.addClass(o,"title"),Gr.bind(o,"click",(function(e){return e.preventDefault(),n.closed=!n.closed,!1})),r.closed||(this.closed=!1)}r.autoPlace&&(Cr.isUndefined(r.parent)&&(hi&&(di=document.createElement("div"),Gr.addClass(di,"dg"),Gr.addClass(di,e.CLASS_AUTO_PLACE_CONTAINER),document.body.appendChild(di),hi=!1),di.appendChild(this.domElement),Gr.addClass(this.domElement,e.CLASS_AUTO_PLACE)),this.parent||Ci(n,r.width)),this.__resizeHandler=function(){n.onResizeDebounced()},Gr.bind(window,"resize",this.__resizeHandler),Gr.bind(this.__ul,"webkitTransitionEnd",this.__resizeHandler),Gr.bind(this.__ul,"transitionend",this.__resizeHandler),Gr.bind(this.__ul,"oTransitionEnd",this.__resizeHandler),this.onResize(),r.resizable&&Si(this),a=function(){oi&&"true"===localStorage.getItem(bi(0,"isLocal"))&&localStorage.setItem(bi(0,"gui"),JSON.stringify(n.getSaveObject()))},this.saveToLocalStorageIfPossible=a,r.parent||((i=n.getRoot()).width+=1,Cr.defer((function(){i.width-=1})))};function mi(e,t,n){var r=document.createElement("li");return t&&r.appendChild(t),n?e.__ul.insertBefore(r,n):e.__ul.appendChild(r),e.onResize(),r}function fi(e){Gr.unbind(window,"resize",e.__resizeHandler),e.saveToLocalStorageIfPossible&&Gr.unbind(window,"unload",e.saveToLocalStorageIfPossible)}function gi(e,t){var n=e.__preset_select[e.__preset_select.selectedIndex];n.innerHTML=t?n.value+"*":n.value}function vi(e,t){var n=e.getRoot(),r=n.__rememberedObjects.indexOf(t.object);if(-1!==r){var i=n.__rememberedObjectIndecesToControllers[r];if(void 0===i&&(i={},n.__rememberedObjectIndecesToControllers[r]=i),i[t.property]=t,n.load&&n.load.remembered){var s=n.load.remembered,a=void 0;if(s[e.preset])a=s[e.preset];else{if(!s.Default)return;a=s.Default}if(a[r]&&void 0!==a[r][t.property]){var o=a[r][t.property];t.initialValue=o,t.setValue(o)}}}}function wi(e,t,n,r){if(void 0===t[n])throw new Error('Object "'+t+'" has no property "'+n+'"');var i=void 0;if(r.color)i=new ei(t,n);else{var s=[t,n].concat(r.factoryArgs);i=ii.apply(e,s)}r.before instanceof zr&&(r.before=r.before.__li),vi(e,i),Gr.addClass(i.domElement,"c");var a=document.createElement("span");Gr.addClass(a,"property-name"),a.innerHTML=i.property;var o=document.createElement("div");o.appendChild(a),o.appendChild(i.domElement);var l=mi(e,o,r.before);return Gr.addClass(l,pi.CLASS_CONTROLLER_ROW),i instanceof ei?Gr.addClass(l,"color"):Gr.addClass(l,Ir(i.getValue())),function(e,t,n){if(n.__li=t,n.__gui=e,Cr.extend(n,{options:function(t){if(arguments.length>1){var r=n.__li.nextElementSibling;return n.remove(),wi(e,n.object,n.property,{before:r,factoryArgs:[Cr.toArray(arguments)]})}if(Cr.isArray(t)||Cr.isObject(t)){var i=n.__li.nextElementSibling;return n.remove(),wi(e,n.object,n.property,{before:i,factoryArgs:[t]})}},name:function(e){return n.__li.firstElementChild.firstElementChild.innerHTML=e,n},listen:function(){return n.__gui.listen(n),n},remove:function(){return n.__gui.remove(n),n}}),n instanceof Jr){var r=new Yr(n.object,n.property,{min:n.__min,max:n.__max,step:n.__step});Cr.each(["updateDisplay","onChange","onFinishChange","step","min","max"],(function(e){var t=n[e],i=r[e];n[e]=r[e]=function(){var e=Array.prototype.slice.call(arguments);return i.apply(r,e),t.apply(n,e)}})),Gr.addClass(t,"has-slider"),n.domElement.insertBefore(r.domElement,n.domElement.firstElementChild)}else if(n instanceof Yr){var i=function(t){if(Cr.isNumber(n.__min)&&Cr.isNumber(n.__max)){var r=n.__li.firstElementChild.firstElementChild.innerHTML,i=n.__gui.__listening.indexOf(n)>-1;n.remove();var s=wi(e,n.object,n.property,{before:n.__li.nextElementSibling,factoryArgs:[n.__min,n.__max,n.__step]});return s.name(r),i&&s.listen(),s}return t};n.min=Cr.compose(i,n.min),n.max=Cr.compose(i,n.max)}else n instanceof Kr?(Gr.bind(t,"click",(function(){Gr.fakeEvent(n.__checkbox,"click")})),Gr.bind(n.__checkbox,"click",(function(e){e.stopPropagation()}))):n instanceof $r?(Gr.bind(t,"click",(function(){Gr.fakeEvent(n.__button,"click")})),Gr.bind(t,"mouseover",(function(){Gr.addClass(n.__button,"hover")})),Gr.bind(t,"mouseout",(function(){Gr.removeClass(n.__button,"hover")}))):n instanceof ei&&(Gr.addClass(t,"color"),n.updateDisplay=Cr.compose((function(e){return t.style.borderLeftColor=n.__color.toString(),e}),n.updateDisplay),n.updateDisplay());n.setValue=Cr.compose((function(t){return e.getRoot().__preset_select&&n.isModified()&&gi(e.getRoot(),!0),t}),n.setValue)}(e,l,i),e.__controllers.push(i),i}function bi(e,t){return document.location.href+"."+t}function _i(e,t,n){var r=document.createElement("option");r.innerHTML=t,r.value=t,e.__preset_select.appendChild(r),n&&(e.__preset_select.selectedIndex=e.__preset_select.length-1)}function yi(e,t){t.style.display=e.useLocalStorage?"block":"none"}function xi(e){var t=e.__save_row=document.createElement("li");Gr.addClass(e.domElement,"has-save"),e.__ul.insertBefore(t,e.__ul.firstChild),Gr.addClass(t,"save-row");var n=document.createElement("span");n.innerHTML=" ",Gr.addClass(n,"button gears");var r=document.createElement("span");r.innerHTML="Save",Gr.addClass(r,"button"),Gr.addClass(r,"save");var i=document.createElement("span");i.innerHTML="New",Gr.addClass(i,"button"),Gr.addClass(i,"save-as");var s=document.createElement("span");s.innerHTML="Revert",Gr.addClass(s,"button"),Gr.addClass(s,"revert");var a=e.__preset_select=document.createElement("select");if(e.load&&e.load.remembered?Cr.each(e.load.remembered,(function(t,n){_i(e,n,n===e.preset)})):_i(e,"Default",!1),Gr.bind(a,"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(a),t.appendChild(n),t.appendChild(r),t.appendChild(i),t.appendChild(s),oi){var o=document.getElementById("dg-local-explain"),l=document.getElementById("dg-local-storage");document.getElementById("dg-save-locally").style.display="block","true"===localStorage.getItem(bi(0,"isLocal"))&&l.setAttribute("checked","checked"),yi(e,o),Gr.bind(l,"change",(function(){e.useLocalStorage=!e.useLocalStorage,yi(e,o)}))}var h=document.getElementById("dg-new-constructor");Gr.bind(h,"keydown",(function(e){!e.metaKey||67!==e.which&&67!==e.keyCode||li.hide()})),Gr.bind(n,"click",(function(){h.innerHTML=JSON.stringify(e.getSaveObject(),void 0,2),li.show(),h.focus(),h.select()})),Gr.bind(r,"click",(function(){e.save()})),Gr.bind(i,"click",(function(){var t=prompt("Enter a new preset name.");t&&e.saveAs(t)})),Gr.bind(s,"click",(function(){e.revert()}))}function Si(e){var t=void 0;function n(n){return n.preventDefault(),e.width+=t-n.clientX,e.onResize(),t=n.clientX,!1}function r(){Gr.removeClass(e.__closeButton,pi.CLASS_DRAG),Gr.unbind(window,"mousemove",n),Gr.unbind(window,"mouseup",r)}function i(i){return i.preventDefault(),t=i.clientX,Gr.addClass(e.__closeButton,pi.CLASS_DRAG),Gr.bind(window,"mousemove",n),Gr.bind(window,"mouseup",r),!1}e.__resize_handle=document.createElement("div"),Cr.extend(e.__resize_handle.style,{width:"6px",marginLeft:"-3px",height:"200px",cursor:"ew-resize",position:"absolute"}),Gr.bind(e.__resize_handle,"mousedown",i),Gr.bind(e.__closeButton,"mousedown",i),e.domElement.insertBefore(e.__resize_handle,e.domElement.firstElementChild)}function Ci(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 Mi(e,t){var n={};return Cr.each(e.__rememberedObjects,(function(r,i){var s={},a=e.__rememberedObjectIndecesToControllers[i];Cr.each(a,(function(e,n){s[n]=t?e.initialValue:e.getValue()})),n[i]=s})),n}pi.toggleHide=function(){ci=!ci,Cr.each(ui,(function(e){e.domElement.style.display=ci?"none":""}))},pi.CLASS_AUTO_PLACE="a",pi.CLASS_AUTO_PLACE_CONTAINER="ac",pi.CLASS_MAIN="main",pi.CLASS_CONTROLLER_ROW="cr",pi.CLASS_TOO_TALL="taller-than-window",pi.CLASS_CLOSED="closed",pi.CLASS_CLOSE_BUTTON="close-button",pi.CLASS_CLOSE_TOP="close-top",pi.CLASS_CLOSE_BOTTOM="close-bottom",pi.CLASS_DRAG="drag",pi.DEFAULT_WIDTH=245,pi.TEXT_CLOSED="Close Controls",pi.TEXT_OPEN="Open Controls",pi._keydownHandler=function(e){"text"===document.activeElement.type||72!==e.which&&72!==e.keyCode||pi.toggleHide()},Gr.bind(window,"keydown",pi._keydownHandler,!1),Cr.extend(pi.prototype,{add:function(e,t){return wi(this,e,t,{factoryArgs:Array.prototype.slice.call(arguments,2)})},addColor:function(e,t){return wi(this,e,t,{color:!0})},remove:function(e){this.__ul.removeChild(e.__li),this.__controllers.splice(this.__controllers.indexOf(e),1);var t=this;Cr.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&&di.removeChild(this.domElement);var e=this;Cr.each(this.__folders,(function(t){e.removeFolder(t)})),Gr.unbind(window,"keydown",pi._keydownHandler,!1),fi(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 n=new pi(t);this.__folders[e]=n;var r=mi(this,n.domElement);return Gr.addClass(r,"folder"),n},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],fi(e);var t=this;Cr.each(e.__folders,(function(t){e.removeFolder(t)})),Cr.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=Gr.getOffset(e.__ul).top,n=0;Cr.each(e.__ul.childNodes,(function(t){e.autoPlace&&t===e.__save_row||(n+=Gr.getHeight(t))})),window.innerHeight-t-20<n?(Gr.addClass(e.domElement,pi.CLASS_TOO_TALL),e.__ul.style.height=window.innerHeight-t-20+"px"):(Gr.removeClass(e.domElement,pi.CLASS_TOO_TALL),e.__ul.style.height="auto")}e.__resize_handle&&Cr.defer((function(){e.__resize_handle.style.height=e.__ul.offsetHeight+"px"})),e.__closeButton&&(e.__closeButton.style.width=e.width+"px")},onResizeDebounced:Cr.debounce((function(){this.onResize()}),50),remember:function(){if(Cr.isUndefined(li)&&((li=new ai).domElement.innerHTML=ri),this.parent)throw new Error("You can only call remember on a top level GUI.");var e=this;Cr.each(Array.prototype.slice.call(arguments),(function(t){0===e.__rememberedObjects.length&&xi(e),-1===e.__rememberedObjects.indexOf(t)&&e.__rememberedObjects.push(t)})),this.autoPlace&&Ci(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]=Mi(this)),e.folders={},Cr.each(this.__folders,(function(t,n){e.folders[n]=t.getSaveObject()})),e},save:function(){this.load.remembered||(this.load.remembered={}),this.load.remembered[this.preset]=Mi(this),gi(this,!1),this.saveToLocalStorageIfPossible()},saveAs:function(e){this.load.remembered||(this.load.remembered={},this.load.remembered.Default=Mi(this,!0)),this.load.remembered[e]=Mi(this),this.preset=e,_i(this,e,!0),this.saveToLocalStorageIfPossible()},revert:function(e){Cr.each(this.__controllers,(function(t){this.getRoot().load.remembered?vi(e||this.getRoot(),t):t.setValue(t.initialValue),t.__onFinishChange&&t.__onFinishChange.call(t,t.getValue())}),this),Cr.each(this.__folders,(function(e){e.revert(e)})),e||gi(this.getRoot(),!1)},listen:function(e){var t=0===this.__listening.length;this.__listening.push(e),t&&function e(t){0!==t.length&&si.call(window,(function(){e(t)})),Cr.each(t,(function(e){e.updateDisplay()}))}(this.__listening)},updateDisplay:function(){Cr.each(this.__controllers,(function(e){e.updateDisplay()})),Cr.each(this.__folders,(function(e){e.updateDisplay()}))}});var Ti=pi;e("j",(e,t,n,r)=>{if(!e||!t||0===n||0===r)return new a;let i=e.clone(),s=n/2,o=r/2;return i.project(t),i.x=Math.floor(i.x*s+s),i.y=Math.floor(-i.y*o+o),i.z=e.distanceTo(t.position),i});const Ai=e("k",(e,t)=>{t||(t=new a(0,0,0));let n=new a(e.size.x/1e3,e.size.z/1e3,e.size.y/1e3),r=new a(e.origin.x/1e3,e.origin.z/1e3,e.origin.y/-1e3),i=new a(0,0,-n.z).add(r).sub(t),s=new a(n.x,n.y,0).add(r).add(t);return new ue(i,s)});e("Q",(e,t)=>{let n=pr(e.x),r=pr(e.y),i=pr(e.z),s=pr(t.x),a=pr(t.y),o=pr(t.z);return n===s&&r===a&&i===o}),e("$",(e,t)=>{let n=pr(e.w),r=pr(e.x),i=pr(e.y),s=pr(e.z),a=pr(t.w),o=pr(t.x),l=pr(t.y),h=pr(t.z);return n===a&&r===o&&i===l&&s===h}),e("T",(e,t)=>{let n=pr(e.x),r=pr(e.y),i=pr(t.x),s=pr(t.y);return n===i&&r===s});let Pi=null;const Ri=()=>{if(Pi)return Pi;const e=new Uint8Array(4);for(let t=0;t<1;t++){const n=4*t;e[n]=255,e[n+1]=255,e[n+2]=255,e[n+3]=255}const t=new be(e,1,1,we);return t.needsUpdate=!0,t},Ei=(e,t,n,r)=>{const i=new Uint8Array(4),s=Math.floor(255*e),a=Math.floor(255*t),o=Math.floor(255*n),l=Math.floor(255*r);for(let e=0;e<4;e++){const t=4*e;i[t]=s,i[t+1]=a,i[t+2]=o,i[t+3]=l}const h=new be(i,1,1,we);return h.needsUpdate=!0,h},Ii=e("X",(e,t)=>ki(null,e,t)),ki=e("ao",(e,t,n)=>{e||(e=Oi()),e.name=t.id?t.id.toString():"",void 0!==t.shading.metallic&&(e.metalness=1===t.shading.metallic?1:.5,e.reflectivity=_e(t.shading.metallic,.5));let r=!1;if(t.shading.transmission&&t.shading.transmission>0?(e.opacity=1-t.shading.transmission,e.transparent=!0,e.depthWrite=!1,e.metalness=0,r=!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),r=!0),e.aoMapIntensity=_e(t.shading.occlusion,1),e.roughness=_e(t.shading.roughness,.5),e.alphaTest=_e(t.shading.alphaCutoff,0),void 0!==t.shading.basecolor){const n=new h(t.shading.basecolor.r,t.shading.basecolor.g,t.shading.basecolor.b);e.color.copy(n.convertSRGBToLinear())}return r||t.shading.doubleSided?e.side=F:e.side=ae,e.map||(Pi||(Pi=Ri()),e.map=Pi),e.envMapIntensity=n,e}),Oi=()=>hr.createMeshPhysicalMaterial({});e("ap",e=>{let t=e.color.clone().convertLinearToSRGB(),n={alpha:e.opacity,metallic:e.reflectivity,basecolor:{r:t.r,g:t.g,b:t.b},roughness:e.roughness,doubleSided:e.side===F,alphaCutoff:e.alphaTest,transmission:e.transmission};return 1===e.metalness?n.metallic=1:n.metallic=e.reflectivity,n});let Di=null;const Li=e("Y",(e,t,n,r,i,s,a=16)=>(Di||(Di=new A,Di.crossOrigin=""),new Promise((o,l)=>{if(!e)return console.warn("trying to add a texture without image",t),void o();Di.load(e,e=>{Ui(e,t,n,r,i,s,a),o()},l)}))),Ui=e("aq",(e,t,n,r,i,s,a=16)=>{e.anisotropy=r,e.wrapS=k,e.wrapT=k,"ORM"===t.mapping&&a<=8?console.warn("ORM maps are not supported on devices with only "+a+" texture units"):(e.repeat.set(i,s),"XYZ"===t.mapping?(n.normalMap=e,n.map===Ri()&&(n.map=null)):"ORM"===t.mapping?(n.aoMap=e,n.roughnessMap=e,n.metalnessMap=e):(e.colorSpace=y,n.map=e),"RGBA"===t.mapping&&(n.transparent=!0,n.name.includes("glow")&&(n.emissiveIntensity=.5,n.emissive=new h(16777215),n.emissiveMap=n.map)),n.needsUpdate=!0)}),Fi=e("Z",(e=!0)=>(window.__RML_GUI__||(window.__RML_GUI__=new Ti({autoPlace:e})),window.__RML_GUI__)),Bi=(e("af",(e,t)=>{let n=!1;for(const r of t){const t=r.getKernelObject();let i;if(2===t.wallType.value&&(i=mr(t.rightNormal)),1===t.wallType.value&&(i=mr(t.leftNormal)),!i)continue;let s=mr(r.getPlanElement().getCenter());s=s.applyMatrix4(e.matrixWorldInverse),i=i.transformDirection(e.matrixWorldInverse);const a=s.dot(i)>=0;a!==r.getContainer().visible&&(n=!0),a?r.show():r.isSelected||r.hide()}return n}),e("ai",(e,t,n=!0)=>{if(!e.userData.tween)if(t)if(e.transparent=!0,n){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(n){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 z&&TWEEN){const n=e.material;e.userData.tween&&e.userData.tween.stop();const r={opacity:n.opacity};t.transparent&&(n.transparent=t.transparent),e.userData.tween=new TWEEN.Tween(r).to(t,250).easing(TWEEN.Easing.Linear.None).onUpdate(()=>{n.opacity=r.opacity}).onStop(()=>{t.transparent||(n.transparent=t.transparent),n.opacity=t.opacity,n.needsUpdate=!0,e.userData.tween=void 0}).onComplete(()=>{t.transparent||(n.transparent=t.transparent),n.needsUpdate=!0,e.userData.tween=void 0}).start()}})}),e("ag",e=>{e.traverse(e=>{if(e instanceof z&&TWEEN){let t=e.material;if(0===t.opacity)return;let n={opacity:0,transparent:!0},r={opacity:t.opacity,transparent:t.transparent};t.transparent=n.transparent,t.opacity=n.opacity,new TWEEN.Tween(n).to(r,500).easing(TWEEN.Easing.Linear.None).onUpdate(()=>{t.opacity=n.opacity}).onComplete(()=>{t.transparent=r.transparent}).start()}})})),Ni=e("s",e=>{"Mesh"===e.type?Hi(e):zi(e)}),zi=e=>{e&&e.children&&0!==e.children.length&&e.children.forEach(e=>{Hi(e)})},Hi=e("g",e=>{e&&(e.material&&Vi(e.material),e.geometry&&ji(e.geometry),e.children&&e.children.length>0&&zi(e))}),ji=e=>{e&&e.dispose()},Vi=e=>{e&&(e.map&&e.map.dispose(),e.normalMap&&e.normalMap.dispose(),e.dispose())};let Gi;e("v",e=>0===e.x&&0===e.y&&0===e.z);const Ki=(e,t)=>{let n="";return e||""===e?(e.materialId&&""!==e.materialId?n=e.materialId:e.catalogItemId&&""!==e.catalogItemId?n=e.catalogItemId:e.rgbValue>0?n="rgb"+JSON.stringify(e.rgbValue):e.length>0?n=e:t&&1===t.value?n="default_wall_material_"+e.getSourceType().value:t&&7===t.value&&(n="default_ceiling_material_"+e.getSourceType().value),n):null},Wi=(e("u",e=>{let t=e.getWorldDirection(new a).clone();t.y=0,t.lengthSq()<.01&&(t=new a(0,1,0),t.applyQuaternion(e.quaternion),t.y=0),t.normalize();let n=Math.asin(t.x);return t.z<0&&(n=Math.PI-n),n<0&&(n+=2*Math.PI),n}),e("U",(e,t)=>{if(!e||!t)return 0;const n=e.clone().expandByScalar(.001).containsBox(t),r=t.clone().expandByScalar(.001).containsBox(e);return r&&n||!r&&!n?0:!0===n?1:-1}),e("aj",(e,t,n,r=1)=>{const i=t>n,s=i?15:0,o=i?0:10,l=e.getSize(new a),h=e.getCenter(new a);let d=l.x>2*s?l.x/2:s,c=l.z>2*o?l.z/2:o;return d*=r,c*=r,new ue(new a(h.x-d,h.y,h.z-c),new a(h.x+d,h.y,h.z+c))}),e("ab",e=>{const{x:t,y:n}=e;return{x:t,y:n}})),Xi=e=>{const{x:t,y:n,z:r}=e;return{x:t,y:n,z:r}};e("ah",(e,t,n)=>(new a).setFromSphericalCoords(e,Math.PI*(1-n),2*Math.PI*(1-t)));const qi=e("e",{CAMERA_2D:"2D",CAMERA_3D:"3D",CAMERA_FP:"FP"});e("a2",e=>{if(!e)return qi.CAMERA_3D;let t=e.toUpperCase();return-1===Object.values(qi).indexOf(t)&&(t=qi.CAMERA_3D),t});var Qi=e("a5","static/default_256-f1c66a2764f88cc0.exr");class Yi{constructor(e){this.autoQuality=!1,this.colors=ye,this.unit=null,this.unitStringType=null,this.meshSelection=!0,this.stats=!1,this._measureTraffic=!1,this.disableDebugGUI=!1,this.disableEnvMap=!1,this.envMapUrl=Qi,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=qi.CAMERA_3D,this.edit=!1,this.moc=!1,this.callbacksOnlyIfGeometryIsReady=!0,this._creator_=e}setOverrides(e){xe(this,e)}}e("av",Yi);const Zi=["language","browserLanguage","userLanguage","systemLanguage"];e("a8",/^((?!chrome|android).)*safari/i.test(navigator.userAgent));class Ji{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,n=Zi.length;e<n;e++){const n=t[Zi[e]];if(n)return n.substr(0,2)}return"en"})()||"en",this.overrideCountry=null,this._creator_=e}setOverrides(e){xe(this,e)}}e("au",Ji);class $i{_setMute(e){Se(this,"_isMute",!0),this._isMute=e,Se(this,"_isMute",!1)}mute(){this._setMute(!0)}unmute(){this._setMute(!1)}constructor(e){return this._isMute=!1,this.cameraStartsMoving=()=>{},this._creator_=e,Ce(this,"_isMute",{enumerable:!1,writable:!1}),Ce($i.prototype,"_setMute",{enumerable:!1,writable:!1}),Ce($i.prototype,"mute",{enumerable:!1,writable:!1}),Ce($i.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",$i);class es extends $i{constructor(){super(...arguments),this.onNetworkRequest=(e,t,n)=>{},this.onKernelMsg=(e,t,n={})=>{},this.onCheckExternalCache=async(e,t)=>Promise.resolve(null),this.onValidateNetworkResponse=(e,t)=>Promise.resolve(!0)}}e("at",es),e("l",{HSC:"rml-configurator",HSP:"rml-hsp",GLB:"rml-glb",RMV:"rml-mv"});class ts{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 s(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(){}}tn([rn],ts.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 ns{constructor(e){this._plugins=[],this._creator_=e}async init(e,n,r){this._scene=e,this._uiScene=n,this._cameraPosition=r;const{bananaForScale:i}=this._initData;i&&await t.import("./banana-for-scale-1b8f041a.nomodule.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(n=>n.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)}}tn([rn],ns.prototype,"_initData",void 0);class rs{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,n)=>{this._finishPromiseExecutor.push({resolve:t,reject:n});const r=e?"allSettled":"all";Promise[r](this._waitingPromises).then(e=>{if("allSettled"===r){const t=[];e.forEach(({value:e,status:n})=>{"fulfilled"===n&&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 is{constructor(e){this.materialQueue=new rs,this._geometryComponentMaterialCache=new Map,this._maxAnisotropy=1,this._maxTextures=16,this._textureLoader=new A,this._configuratorPreviewMaterial=hr.createMeshStandardMaterial({color:"#DDDDDD",transparent:!0,opacity:1,roughness:1,envMap:null}),this._creator_=e,this._previewMaterial=hr.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,n,r,i){let s;return e&&this._cacheHolder.geometryCache.has(e)?s=this._cacheHolder.geometryCache.get(e):(s=new c,s.setIndex(new Me(n,1)),s.setAttribute("position",new Te(t,3)),s.setAttribute("normal",new Te(i,3)),s.setAttribute("uv",new Te(r,2)),s.scale(.001,.001,.001),s.rotateX(-Math.PI/2),e&&this._cacheHolder.geometryCache.set(e,s)),s}changeMaterialOfMesh(e,t,n){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,n)):console.warn("could not assign material to mesh",{mesh:e},{material:t})}_updateMaterialProperties(e,t){var n;if(t&&Object.keys(t).length>0&&e.material instanceof U){const r=e.material.clone();r.userData.materialAttributes=t,t.color&&(r.color=new h(t.color)),t.alpha&&(r.opacity=parseFloat(t.alpha)),t.roughness&&(r.roughness=parseFloat(t.roughness)),t.metallic&&(r.metalness=parseFloat(t.metallic)),r instanceof x&&t.transmission&&(r.transmission=parseFloat(t.transmission)),r.transparent=r.opacity<1;const i=e.material;e.material=r,(null===(n=i.userData)||void 0===n?void 0:n.materialAttributes)&&i.dispose()}}_createMaterial(e,t,n,r,i){if(this._cacheHolder.materialCache.has(e))t();else if(e.startsWith("benchmarkMaterial")){let s=Ae(e),a=Ii(s,this._initData.envMapIntensity);this._loadBenchmarkTextures(s,a,r,i).then(t,n)}else this._rapiAccess.getMaterial(e).then(e=>{let s=Ii(e,this._initData.envMapIntensity);this._loadTextures(e,s,r,i).then(t,n)},n)}_loadBenchmarkTextures(e,t,n=1,r=1){return new Promise((i,s)=>{const a=Pe(e.id);Li(this._dataSyncer.requestAsset(a.image,!0),a,t,this._maxAnisotropy,n/(0===a.mmWidth?1:a.mmWidth),r/(0===a.mmHeight?1:a.mmHeight),this._maxTextures).then(()=>{this._cacheHolder.materialCache.set(e.id,t),i()},s)})}_loadTextures(e,t,n=1,r=1){return new Promise((i,s)=>{if(!e.textures||e.textures&&0===e.textures.length)return this._cacheHolder.materialCache.set(e.id,t),i();this._rapiAccess.getTexturesOf(e).then(a=>{let o=[];a.forEach(e=>{o.push(Li(this._dataSyncer.requestAsset(e.image,!0),e,t,this._maxAnisotropy,n/(0===e.mmWidth?1:e.mmWidth),r/(0===e.mmHeight?1:e.mmHeight),this._maxTextures))}),Promise.all(o).then(()=>{this._cacheHolder.materialCache.set(e.id,t),i()},s)})})}_loadMaterial(e,t,n){return new Promise((r,i)=>{this._singlePromiseFactory.create(6,e,(r,i)=>this._createMaterial(e,r,i,t,n)).then(()=>{setTimeout(()=>r(this._cacheHolder.materialCache.get(e)),0)},i)})}_assignMaterial(e,t,n){return this._cacheHolder.materialCache.has(t)?(this.changeMaterialOfMesh(e,this._cacheHolder.materialCache.get(t),n),Promise.resolve()):new Promise((r,i)=>{this._loadMaterial(t).then(i=>{e.userData.materialId===t&&this.changeMaterialOfMesh(e,i,n),r()},i)})}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(n=>{let r,i="rgb"+JSON.stringify(t);this._cacheHolder.materialCache.has(i)?r=this._cacheHolder.materialCache.get(i):(r=hr.createMeshPhysicalMaterial({color:t}),this._cacheHolder.materialCache.set(i,r)),this.changeMaterialOfMesh(e,r),setTimeout(()=>n(),0)})}_assignItem(e,t){return new Promise((n,r)=>{if(this._cacheHolder.materialCache.has(t))return this.changeMaterialOfMesh(e,this._cacheHolder.materialCache.get(t)),void n();this._rapiAccess.getItem(t).then(i=>{if(i.topImage)this._textureLoader.load(i.topImage,r=>{r.anisotropy=this._maxAnisotropy,r.wrapS=k,r.wrapT=k;let a=new s(1,1);i.width>0&&(a.x=1/i.width),i.depth>0&&(a.y=1/i.depth),r.repeat.set(a.x,a.y);const o=hr.createMeshPhysicalMaterial({map:r,roughness:.5,metalness:.1});this._cacheHolder.materialCache.set(t,o),this.changeMaterialOfMesh(e,o),setTimeout(()=>n(),0)});else{const e="can not set material, catalog item top image is not set";console.warn(e),r(e)}},r)})}setMaterialLoadedListener(e){this._materialLoaded=e}removeMaterialLoadedListener(){this._materialLoaded=void 0}_createMesh(e,t,n){if(e&&t){const r=this._getComponentMeshId(e,t);if(this._geometryComponentMaterialCache.has(r)){const e=this._geometryComponentMaterialCache.get(r);if(this._cacheHolder.materialCache.has(e)){const t=this._cacheHolder.materialCache.get(e);return new z(n,t)}}}return new z(n,this._configuratorPreviewMaterial.clone())}_getComponentMeshId(e,t){return e+"_"+t}}tn([rn],is.prototype,"_initData",void 0),tn([rn],is.prototype,"_rapiAccess",void 0),tn([rn],is.prototype,"_dataSyncer",void 0),tn([rn],is.prototype,"_singlePromiseFactory",void 0),tn([rn],is.prototype,"_cacheHolder",void 0),tn([rn],is.prototype,"_plannerMeshGenerator",void 0);class ss extends is{constructor(e){super(e)}generateMesh(e=0,t=null,n,r,i,s,a,o=!1,l){let h;h=o?this._generateGeometry(t,r,i,s,a).clone():this._generateGeometry(t,r,i,s,a);const d=this._createMesh(e,t,h);return d.userData.materialId=n,d.layers.set(4),n&&this.materialQueue.push(this._assignMaterial(d,n,l).then(()=>{e&&t&&this._geometryComponentMaterialCache.set(this._getComponentMeshId(e,t),n)})),d}setMaterial(e,t,n,r){return this._assignMaterial(e,t,r)}loadMaterial(e,t,n){return super._loadMaterial(e,t,n)}loadTextures(e,t,n,r){return super._loadTextures(e,t,n,r)}}e("as",ss);class as{constructor(){this._listeners={},this._disabled=!1}_addEventListener(e,t,n){this._listeners[e]||(this._listeners[e]=[]),this._listeners[e].push({callback:t,scope:n})}addEventListener(e,t,n){this._addEventListener(e,t,n)}dispatchEvent(e,t){if(!this._listeners[e]||this._disabled)return;const n=this._listeners[e];let r=n.length;for(let e=0;e<r;e++){const r=n[e];t?r.callback.apply(r.scope,[t]):r.callback.call(r.scope)}}removeEventListener(e,t){const n=this._listeners[e];if(n)for(let e=0,r=n.length;e<r;e++)if(n[e].callback===t)return void n.splice(e,1)}enableEvents(){this._disabled=!1}disableEvents(){this._disabled=!0}}e("E",as);const os={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 ls{constructor(e,t,n,r,i){this.position=e,this.positionRelative=t,this.type=n,this.rotation=r,this.event=i}}const hs=e("a1",5*window.devicePixelRatio),ds=3*window.devicePixelRatio;class cs extends as{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(os).map(e=>os[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,n=null,r=null;window.TouchEvent&&e instanceof TouchEvent?(n=this._getTouchPosition(t),r=this._getTouchPositionRelative(t)):(n=this._getMousePosition(t),r=this._getMousePositionRelative(t)),n.x>0&&n.y>0&&this._move(n,r)}_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],n=e.touches[1],r=t.pageX-n.pageX,i=t.pageY-n.pageY,s=Math.abs(r)+Math.abs(i);this._pinchDistance>-1&&(s>this._pinchDistance+ds?(this._setState(3),this.dispatchEvent(7,new ls(this._getTouchPosition(e),this._getTouchPositionRelative(e)))):s<this._pinchDistance-ds?(this._setState(3),this.dispatchEvent(8,new ls(this._getTouchPosition(e),this._getTouchPositionRelative(e)))):s<=this._pinchDistance+ds&&s>=this._pinchDistance-ds&&(this._setState(5),this.dispatchEvent(11,new ls(this._getTouchPosition(e),this._getTouchPositionRelative(e))))),this._pinchDistance=s,this._lastTouchEvent=e}_setState(e){this._state=e}_move(e,t,n,r){void 0===n&&(n=0),void 0===this._dragEnabled&&(this._dragEnabled=!1),1===this._state&&this._canDrag(n)&&(this._delta=this._getDelta(e),(this._delta>hs||this._elementHit)&&(this._setState(2),this._longClickTimer&&clearTimeout(this._longClickTimer),this.dispatchEvent(0,new ls(this._downPosition,this._downPositionRelative)))),2===this._state&&this.dispatchEvent(1,new ls(e,t)),this.dispatchEvent(6,new ls(e,t,n,null,r))}_longClick(e){2!==e&&(this._setState(2),this._longClickTimer&&clearTimeout(this._longClickTimer),this.dispatchEvent(0,new ls(this._downPosition,this._downPositionRelative)),this.dispatchEvent(1,new ls(this._downPosition,this._downPositionRelative))),this.dispatchEvent(14,new ls(this._downPosition,this._downPositionRelative,2))}_onUp(e,t,n){this.dispatchEvent(4,new ls(e,t,n)),this._getDelta(e)<=hs&&this.dispatchEvent(5,new ls(e,t)),2===this._state&&this.dispatchEvent(2,new ls(e,t)),4===this._state&&(this.dispatchEvent(10,new ls(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:n}=e.touches[0];if(e.touches.length>1){const r=e.touches[1],i=r.clientX,s=r.clientY;t=(t+i)/2,n=(n+s)/2}return{x:t,y:n}}const t=e.changedTouches[0];return{x:t.clientX,y:t.clientY}}_getTouchPositionRelative(e){const t=this._getBoundingClientRect(),{clientWidth:n,clientHeight:r}=this._domHelper.element;if(e.touches.length){const{clientX:i,clientY:s}=e.touches[0];return{x:(i-t.left)/n*2-1,y:-(s-t.top)/r*2+1}}const i=e.changedTouches[0];return{x:(i.clientX-t.left)/n*2-1,y:-(i.clientY-t.top)/r*2+1}}_getMousePosition(e){if(0!==e.clientX&&0!==e.clientY)return{x:e.clientX,y:e.clientY};{let{x:t,y:n}=this._getFireFoxMousePosition(e);return{x:t,y:n}}}_getFireFoxMousePosition(e){let{x:t,y:n}=this._domHelper.getClientDimensions();return{x:t-(t+e.offsetX),y:n-(n+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 os.SCROLL:this._boundingClientRectInvalid=!0;break;case os.MOUSE_MOVE:this._onMouseMove(e);break;case os.DOUBLE_CLICK:this._onDoubleClick(e);break;case os.MOUSE_DOWN:this._onMouseDown(e);break;case os.MOUSE_UP:this._onMouseUp(e);break;case os.MOUSE_LEAVE:this._onMouseLeave(e);break;case os.MOUSE_ENTER:this._onMouseEnter(e);break;case os.MOUSE_WHEEL:this._onMouseWheel(e);break;case os.TOUCH_MOVE:this._onTouchMove(e);break;case os.TOUCH_START:this._onTouchStart(e);break;case os.TOUCH_END:this._onTouchEnd(e);break;case os.CONTEXT_MENU:this._onContextMenu(e)}}_onMouseDown(e){if(e.preventDefault(),2===e.detail)return;let{x:t,y:n}=this._getMousePosition(e);this._downPosition={x:t,y:n},this._downPositionRelative=this._getMousePositionRelative(e),this.dispatchEvent(3,new ls({x:t,y:n},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 ls(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 ls(this._getMousePosition(e),this._getMousePositionRelative(e),1,0,e)):this.dispatchEvent(8,new ls(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 r=e.touches[0],i=e.touches[1],s=function(e){let t=ur(e);return t<0&&(t=180+(180+t)),t}((t={x:r.pageX,y:r.pageY},n={x:i.pageX,y:i.pageY},Math.atan2(n.y-t.y,n.x-t.x)));this._rotationAngle<0&&(this._rotationAngle=s);const a=s-this._rotationAngle;this._rotationAngle=s,this.dispatchEvent(9,new ls(this._getTouchPosition(e),this._getTouchPositionRelative(e),2,cr(a))),this._setState(4)}else this._move2(e);var t,n}_onTouchStart(e){if(e.preventDefault(),1===e.touches.length){let{x:t,y:n}=this._getTouchPosition(e);this._downPosition={x:t,y:n},this._downPositionRelative=this._getTouchPositionRelative(e),this.dispatchEvent(3,new ls({x:t,y:n},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 ls(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",cs),tn([rn],cs.prototype,"_domHelper",void 0);class us{constructor(e){const{component:t,resetCamera:n,consecutive:r}=e;this.component=t,this.resetCamera=void 0===n||n,this.consecutive=void 0===r||r}}class ps extends g{constructor(e){super(e)}load(e,t,n,r){const i=this,s=new w(this.manager);s.setPath(this.path),s.setRequestHeader(this.requestHeader),s.setWithCredentials(this.withCredentials),s.load(e,(function(e){const n=i.parse(JSON.parse(e));t&&t(n)}),n,r)}parse(e){return new ms(e)}}class ms{constructor(e){this.isFont=!0,this.type="Font",this.data=e}generateShapes(e,t=100){const n=[],r=function(e,t,n){const r=Array.from(e),i=t/n.resolution,s=(n.boundingBox.yMax-n.boundingBox.yMin+n.underlineThickness)*i,a=[];let o=0,l=0;for(let e=0;e<r.length;e++){const t=r[e];if("\n"===t)o=0,l-=s;else{const e=fs(t,i,o,l,n);o+=e.offsetX,a.push(e.path)}}return a}(e,t,this.data);for(let e=0,t=r.length;e<t;e++)n.push(...r[e].toShapes());return n}}function fs(e,t,n,r,i){const s=i.glyphs[e]||i.glyphs["?"];if(!s)return void console.error('THREE.Font: character "'+e+'" does not exists in font family '+i.familyName+".");const a=new Re;let o,l,h,d,c,u,p,m;if(s.o){const e=s._cachedOutline||(s._cachedOutline=s.o.split(" "));for(let i=0,s=e.length;i<s;)switch(e[i++]){case"m":o=e[i++]*t+n,l=e[i++]*t+r,a.moveTo(o,l);break;case"l":o=e[i++]*t+n,l=e[i++]*t+r,a.lineTo(o,l);break;case"q":h=e[i++]*t+n,d=e[i++]*t+r,c=e[i++]*t+n,u=e[i++]*t+r,a.quadraticCurveTo(c,u,h,d);break;case"b":h=e[i++]*t+n,d=e[i++]*t+r,c=e[i++]*t+n,u=e[i++]*t+r,p=e[i++]*t+n,m=e[i++]*t+r,a.bezierCurveTo(c,u,p,m,h,d)}}return{offsetX:s.ha*t,path:a}}const gs=new Map,vs=new Map;class ws{static loadFont(e){if(vs.has(e))return new Promise(t=>{t(vs.get(e))});if(gs.has(e))return new Promise((t,n)=>{gs.get(e).push({resolve:t,reject:n})});let t=new ps;return new Promise((r,i)=>{gs.set(e,[{resolve:r,reject:i}]),t.load(n()+e,t=>{vs.set(e,t),ws._resolveAll(e,t)})})}static _resolveAll(e,t){gs.has(e)&&gs.get(e).forEach(e=>e.resolve(t)),gs.delete(e)}}e("aw",ws);class bs{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 n=this._plannerKernelAccess.kernelInstance.getComponent(e.runtimeId),r=n.dimensionings;if(this._componentDimensioningsExist.set(e.runtimeId,r.length>0),!r||0===r.length||this._camera.position.z<0)return!1;const i=Ai(n.boxForMeasurement),s={x:this._camera.position.x,y:this._camera.position.z};return t.import("./component-dimensioning-a747c60d.nomodule.js").then(t=>{ws.loadFont("static/rubik_regular-bc008a7de2daee79.json").then(n=>{r.forEach(r=>{var a;e.add(new t.default(((a=r).from=a.from/1e3,a.to=a.to/1e3,1===a.type.value?(a.type={value:2},a.from*=-1,a.to*=-1):2===a.type.value&&(a.type={value:1}),a),i,n,s))})})}),this._activeComponents.push(e),!0}remove(e,n=!0){return new Promise(r=>{t.import("./component-dimensioning-a747c60d.nomodule.js").then(t=>{let i=[];e.children.forEach(e=>{e instanceof t.default&&i.push(e)}),i.forEach(t=>{e.remove(t),Ni(t)}),n&&Ee(this._activeComponents,e),r()})})}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()}}tn([rn],bs.prototype,"_plannerKernelAccess",void 0);class _s{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,n)=>{this._promiseExecutors.forEach(t=>t.reject(e)),this._promiseExecutors=[],n(e)})}}class ys 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 _s,this._topView=!1;const t=mr(e.getCenter());this._container=new T,this._container.position.copy(t),this._boundingBox=this._generateBoundingBox(),Bi(this._boundingBox),this._container.add(this._boundingBox),2!==this.getPlanElement().getType().value&&(this._object=new T,this._container.add(this._object))}getSize(){return this._object?(new ue).setFromObject(this._object).getSize(new a):new a}update(){this._container.position.copy(mr(this.getPlanElement().getMeshCenter())),this._boundingBox&&this._updateBoundingBox()}_updateBoundingBox(){const e=this.getSize();this._boundingBox.geometry=new Ie(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=Ai(this.getPlanElement().boxForMeasurement),e.applyMatrix4(this.getContainer().matrix)):(e=new ue,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=Ki(e,this.getPlanElement().getType());return this._object.children.find(e=>e.userData.material===t)}getContainer(){return this._container}getId(){return this.getPlanElement().getId()}clear(){Ni(this._container),this._selectionMesh&&Ni(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=(Gi||(Gi=new _,Gi.visible=!1),Gi))}_generateBoundingBox(){const e=this.getSize(),t=new Ie(e.x,e.y,e.z);let n=new h("#DDDDDD");const r=this.getPlanElement().customColor;r>0&&(n=(e=>{let t=new h;return t.setRGB((e>>16)/255,(e>>8&255)/255,(e>>0&255)/255),t})(r));let i=hr.createMeshStandardMaterial({color:n,opacity:1,transparent:!0}),s=new z(t,i);return s.name="bounding box",s.position.y=e.y/2,s.castShadow=!1,s.receiveShadow=!1,s.layers.set(6),s}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 xs extends ys{constructor(e){super(e),this._initDone=!1,this._initFailed=null,this._initWaiter=new _s,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 fr(this.getPlanObject().size)}update(){super.update(),this._container.rotation.y=this.getPlanObject().rotation}}class Ss extends xs{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",Ss);let Cs=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"}}));Cs.isUnitTesting=!1,void 0!==t&&t.exports||(window.IS_DEBUG=!0);const Ms={ENV_DEBUG:function(e=!1){if(e){let e=JSON.parse(JSON.stringify(Cs));const t={...e.APP,SHORTENER_URL:"http://localhost:4747/?isItem=false&id="},n={...e.features};return{...e,isProduction:!1,APP:t,features:n}}}(),ENV_PRODUCTION:JSON.parse(JSON.stringify(Cs))};var Ts=e("m",Ms.ENV_PRODUCTION);class As extends xs{constructor(e){super(e),this._originalSize=new a,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=ke(e),!this._glbUrl)return Promise.reject("No glb url found");let n=e.scaleable?fr(t.size):void 0,r=new a(1,1,1);t.flipX&&(r.x*=-1),t.flipY&&(r.z*=-1);try{const i=await this._staticItemLoader.loadGLB(this._glbUrl,void 0,void 0,n,r,t.customColor,e.colorable);this._originalSize.copy(i.boundingBox.getSize(new a)),i.scene.name=e.label,this.setObject(i.scene),((e,t)=>{let n=(new ue).setFromObject(e),r=n.getSize(new a),i=Math.min(r.x,r.y,r.z),s=!0;i>5&&(console.warn("GLB seems to be too big ("+i+")",t),s=!1),n.min.y<-.01&&(console.warn("GLB seems to be under the floor ("+n.min.y+"): ",t),s=!1)})(i.scene,this._glbUrl),Bi(i.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=fr(this.getPlanElement().size),t=this.getObject();if(!t)return;if(e){const{x:n,y:r,z:i}=this._originalSize;let s=new a(e.x/n,e.y/r,e.z/i);t.scale.copy(s)}this.getPlanElement().flipX&&(t.scale.x*=-1),this.getPlanElement().flipY&&(t.scale.z*=-1);const n=this.getPlanElement().customColor;t.traverse(e=>{if(e instanceof z&&e.material instanceof U){const t=e.material;if(this._rapiItem.colorable&&n&&n>0){let e=new h(n);t.color=e.copySRGBToLinear(e)}t.envMapIntensity=hr.getEnvMapIntensity(),t.needsUpdate=!0}}),super.update()}}let Ps;e("S",As),tn([rn],As.prototype,"_staticItemLoader",void 0),e("ak",e=>{const{id:t,textRotation:n,length:r,lengthFormatted:i}=e;return{id:t,fromWithoutPadding:Xi(e.fromWithoutPadding),toWithoutPadding:Xi(e.toWithoutPadding),fromPosition3d:Xi(e.fromPosition3d),toPosition3d:Xi(e.toPosition3d),textPosition3d:Xi(e.textPosition3d),fromPosition2d:Wi(e.fromPosition2d),toPosition2d:Wi(e.toPosition2d),textPosition2d:Wi(e.textPosition2d),textDirection:Xi(e.textDirection),textRotation:n,length:r,lengthFormatted:i}});const Rs=()=>(Ps||(Ps=hr.createMeshPhysicalMaterial({color:0})),Ps);class Es extends ys{constructor(e){super(e),this._container.name="Wall Plan Element"}get isSelected(){return this._isSelected}getWallDimension(e){const t=this.getPlanElement(),n=mr(t.getCenter()),r=t.getPreferredSide();let i,s;0===r.value?(i=mr(t.getCornerFromLeft()),s=mr(t.getCornerToLeft())):1===r.value&&(i=mr(t.getCornerFromRight()),s=mr(t.getCornerToRight()));const o=i.clone().add(s).divideScalar(2),l=i.clone().sub(s),h=l.clone().cross(new a(0,1,0)).normalize();h.clone().dot(o.clone().sub(n))<0&&h.multiplyScalar(-1);const d={maxZoomedIn:Math.max(.7,e),maxZoomedOut:.01,minPadding:.05,maxPadding:.25},c=Oe(e,d.maxZoomedIn,d.maxZoomedOut,d.minPadding,d.maxPadding),u=h.clone().multiplyScalar(c/2),p=i.clone().add(u),m=s.clone().add(u),f=h.multiplyScalar(c),g=i.add(f),v=s.add(f),w=l.clone();l.dot(new a(1,0,0))<0&&w.multiplyScalar(-1);const b=Math.atan2(w.z,w.x),_=g.clone().add(v).divideScalar(2);return{id:t.getId(),fromPosition3d:g,toPosition3d:v,textPosition3d:_,textDirection:w,textRotation:b,length:t.getLength(r.value),fromWithoutPadding:p,toWithoutPadding:m}}addMesh(e){e.traverse(e=>{this._setMaterial(e)}),e.layers.set(9),super.addMesh(e);const t=(new ue).setFromObject(this.getObject()).getSize(new a);this._boundingBox.geometry=new Ie(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 z&&!e.userData.originalMaterial&&e.material&&e!==this._boundingBox&&(e.userData.originalMaterial=e.material,e.material=Rs())}_disableTopView(){this._container.traverse(e=>{e instanceof z&&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 z&&e.material&&e!==this._boundingBox&&(e.userData.originalMaterial||(e.userData.originalMaterial=e.material),this._topView&&this._isSelected?e.material=new _({color:10526880,side:F}):this._topView&&!this._isSelected?e.material=Rs():(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",Es);class Is extends ys{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",Is);class ks extends ys{constructor(e){super(e),this._container.name="Ceiling Plan Element"}addMesh(e){super.addMesh(e),e.castShadow=!1;const t=(new ue).setFromObject(this.getObject()).getSize(new a);this._boundingBox.geometry=new Ie(t.x,.01,t.z)}}e("f",ks);const Os=new Map;class Ds{static start(e){if(!window.performance||!window.performance.getEntriesByName)return"";let t=window.performance.getEntriesByName(e).length++,n="";t<100&&(n="0"),t<10&&(n="0"+n);const r=t>0?e+"_"+n+t:e,i=r+"_start";return window.performance.mark(i),r}static addMeta(e,t){const n=Ds.getMeta(e);Os.set(e,Object.assign(n,t))}static getMeta(e){return Os.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 n=[];for(let r=0,i=t.length;r<i;r++){const i=t[r];e&&-1===i.name.indexOf(e)||n.push({Start:parseFloat(i.startTime.toFixed(2)),Name:i.name,Duration:parseFloat(i.duration.toFixed(2))})}console.table(n)}}e("B",Ds);class Ls{static init(e={}){const{kernelInstance:t,kernelContainer:n,planObjectId:r}=e;Ls.kernelInstance=t,Ls.kernelContainer=n,Ls.planObjectId=r}static cleanUp(){Ls.useHDGeometry=!1,Ls.kernelInstance=null,Ls.kernelContainer=null,Ls.planObjectId=null}}e("A",Ls),Ls.useHDGeometry=!1,Ls.kernelInstance=null,Ls.kernelContainer=null,Ls.planObjectId=null;const Us=new Map,Fs=function(e,t,n){let r=Us.get(e);if(r){const i=n?[n]:void 0;r.forEach(({resolve:e,reject:n})=>t?e.apply(e,i):n.apply(n,i)),Us.delete(e)}};class Bs{static finishOperation(e,t){Fs(e,!0,t)}static failOperation(e,t){Fs(e,!1,t)}static waitFor(e,t){return new Promise((n,r)=>{let i=Us.get(e);i||(Us.set(e,[]),i=Us.get(e)),i.push({resolve:n,reject:r}),"function"==typeof t&&t.apply(t)})}}e("J",Bs);const Ns=e("K",(function(e){return e.validRange&&"string"==typeof e.validRange.type})),zs=function(e){return e.validValues&&e.validValues.length>0},Hs=e("M",(function(e){return"Material"===e.type}));let js,Vs,Gs,Ks,Ws;const Xs={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"}}},qs=!!window.WebAssembly;class Qs{_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=qs,this._kernelPath=qs?Gs:Ks}_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:n,locale:r}=this._globalInitData;n&&(this._kernelInstance.resetPriceListIds(),this._kernelInstance.addPriceList(n)),this._kernelInstance.setEnvironmentVariable("language",r)}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";js=Xs.ASM[t].MEM_URL,Vs=Xs.WASM[t].URL,Gs=Xs.WASM[t].LOADER,Ks=Xs.ASM[t].LOADER,Ws=!0}_setupEmsModule(e){const t=this;this._kernelContainer={locateFile(t){const r=0===e?/RoomleCoreJs[\-a-z0-9]*\.js\.mem/:/ConfiguratorKernelJs[\-a-z0-9]*\.js\.mem/;return t.match(r)?n()+js:t},wasmBinaryFile:n()+Vs,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")}},Ws&&qs&&(this._kernelContainer.instantiateWasm=function(e,t){return((e,t,r)=>{const i="function"==typeof WebAssembly.instantiateStreaming;Ds.addMeta("kernel_is_ready",{cachedInIndexedDB:!1});let s=null;i?(Ds.start("kernel_stream_compile"),s=WebAssembly.instantiateStreaming(fetch(n()+e),t)):(Ds.start("kernel_legacy_compile"),s=fetch(n()+e).then(e=>e.arrayBuffer()).then(e=>WebAssembly.instantiate(e,t))),Ds.addMeta("kernel_is_ready",{instantiateStreaming:i}),s.then(e=>{r(e.instance)},e=>console.error(e))})(Vs,e,t),{}})}_passSubComponentsToKernel(e,t){const n=e.id,r=t.get(n);if(r)for(let t=0,i=r.length;t<i;t++){const{parentId:i,partId:s}=r[t];this._kernelIo.setMeta({componentId:n}),this._kernelInstance.loadedSubComponent(i,s,n,e.configuration)}}_fetchSubComponents(e){let t=[...e.keys()];t.length&&this._rapiAccess.getComponents(t).then(t=>{for(let n=0,r=t.length;n<r;n++)this._passSubComponentsToKernel(t[n],e);this._flushSubComponentsWaiters()})}_flushSubComponentsWaiters(){this._fetchSubComponents(this._subComponentsWaiters),this._subComponentsWaiters=new Map,this._shouldWait=!1}isReady(){this._kernelContainer.setExternalHelpers(this._kernelIo,{convertCObject:wr}),Ts.isProduction||Ts.isUnitTesting||this.addDebugInfo(),window.KernelCallback&&(window.KernelCallback=null,delete window.KernelCallback)}addDebugInfo(){const e=function(t,n=[]){const r=Object.getPrototypeOf(t),i=r?Object.getOwnPropertyNames(r):[],s=t?Object.getOwnPropertyNames(t):[];return r?e(r,[...n,...s,...i]):[...s,...i,...n]},t=e(this),n=["constructor","hasOwnProperty","isPrototypeOf","propertyIsEnumerable","toString","valueOf"];[...new Set(t)].forEach(e=>{if(!e.startsWith("_")&&"function"==typeof this[e]&&-1===n.indexOf(e))try{const t=this[e].bind(this);this[e]=function(...n){return this._kernelIo.log("[ KernelCommunication ]: "+e),t(...n)}}catch(e){}})}getConfigurationData(e){return new Promise(t=>{var n;const r=this.kernelInstance.getPlanObject(e),i=(new Date).toISOString(),s=this.kernelInstance.getComponentId(e),a=Zt(s),o=(null===(n=r.boxForMeasurement)||void 0===n?void 0:n.size)||r.bounds;t({created:i,lastAccess:i,configuration:this.kernelInstance.getSerializedConfiguration(e),configurationHash:this.kernelInstance.getHashOfConfiguration(e),parts:JSON.stringify(this.kernelInstance.getPartList(e)),rootComponentId:s,width:o.x,height:o.z,depth:o.y,catalog:a,orderable:!1,requestable:!1})})}loadComponent(e,t,n){this._rapiAccess.getComponent(t.componentId).then(r=>{var i;let s=r.configuration;s||(s="error",null===(i=this._configuratorUiCallbacks)||void 0===i||i.onContentProblem({rapiPath:"components",ids:[t.componentId],message:t.componentId+" has no configuration"})),this._kernelIo.setMeta({componentId:t.componentId}),this._kernelInstance.loadComponent(e,s,t,n),this._flushSubComponentsWaiters()},r=>{var i;this._kernelInstance.loadComponent(e,"error",t,n),this.onLoadComponentError(r,t.componentId),null===(i=this._configuratorUiCallbacks)||void 0===i||i.onError(new Error(`Component with id "${t.componentId}" can not be loaded. "${r}"`)),this._flushSubComponentsWaiters()})}loadSubComponent(e,t,n){if(this._shouldWait){let r=this._subComponentsWaiters.get(n);r||this._subComponentsWaiters.set(n,[]),r=this._subComponentsWaiters.get(n),r.push({parentId:e,partId:t}),this._subComponentsWaiters.set(n,r)}else this._rapiAccess.getComponent(n).then(r=>{var i;let s=r.configuration;s||(s="error",null===(i=this._configuratorUiCallbacks)||void 0===i||i.onContentProblem({rapiPath:"components",ids:[n],message:"SubComponent "+n+" has no configuration"})),this._kernelIo.setMeta({componentId:n,parentId:e}),this._kernelInstance.loadedSubComponent(e,t,n,s)})}async loadItemConfigurations(e,t){let n=Array.isArray(t)?t:[t];if(this._requestedItemIds.push(...n),await De(0),!this._requestedItemIds.length)return;const r=[...this._requestedItemIds];this._requestedItemIds=[],(await this._rapiAccess.getItems(r)).forEach(t=>{this._kernelInstance.loadedItemConfiguration(e,t.id,t.configuration)})}requestDeleteComponent(e){var t,n;e&&((null===(n=null===(t=this._initData)||void 0===t?void 0:t.featureFlags)||void 0===n?void 0:n.reDock)?this._kernelInstance.deletePlanComponent(e):this._kernelInstance.deleteComponent(e))}dockComponentWithPosition(e,t,n,r,i){var s;this._kernelInstance.dockComponentWithPosition(n,r,e,t,i);const a=this._kernelInstance.getComponentId(n),o=this._kernelInstance.getComponentId(e);null===(s=this._configuratorUiCallbacks)||void 0===s||s.onUserInitiatedDockDone(a,r,o,t,i)}Editor3dAddBakedMesh(e,t,n,r,i,s,a,o){this._configuratorKernelCallbackListener.forEach(l=>l.Editor3dAddBakedMesh(e,t,n,r,i,s,a,o))}Editor3dAddNamedMesh(e,t,n,r,i,s,a,o,l,h,d,c){this._configuratorKernelCallbackListener.forEach(u=>u.Editor3dAddNamedMesh(e,t,n,r,i,s,a,o,l,h,d,c))}Editor3ChangedNamedMesh(e,t,n,r,i,s,a){this._configuratorKernelCallbackListener.forEach(o=>o.Editor3ChangedNamedMesh(e,t,n,r,i,s,a))}Editor3dRemoveNamedMesh(e,t){this._configuratorKernelCallbackListener.forEach(n=>n.Editor3dRemoveNamedMesh(e,t))}Editor3dBeginConstruction(e,t){this._configuratorKernelCallbackListener.forEach(n=>n.Editor3dBeginConstruction(e,t))}Editor3dEndConstruction(e){this._configuratorKernelCallbackListener.forEach(t=>t.Editor3dEndConstruction(e))}Editor3dComponentCreated(e,t,n,r){this._configuratorKernelCallbackListener.forEach(i=>i.Editor3dComponentCreated(e,t,n,r,!1))}Editor3dComponentDocked(e,t,n,r){this._configuratorKernelCallbackListener.forEach(i=>i.Editor3dComponentDocked(e,t,n,r))}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,Bs.waitFor(4).then(()=>{this._rapiAccess.getMaterialsByGroup(this._cachedGroupIds).then(e=>{let t=[];e.forEach(e=>{const n=[];e.materials.forEach(e=>n.push(e.id));const r=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:r,materials:n})}),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 De(0),!this._requestedMaterialIds.length)return;const n=[...this._requestedMaterialIds];this._requestedMaterialIds=[];const r=await this._rapiAccess.getMaterials(n);let i=[];r.forEach(e=>{const t=new this._kernelContainer.StringStringMap,n=e.properties||{};for(let e in n)n.hasOwnProperty(e)&&t.set(e,n[e]);t.size()&&i.push({id:e.id,properties:t})}),i.length&&this._kernelInstance.setMaterialProperties(i)}registerCallbacks(){this._kernelContainer.registerConfiguratorCallback(this)}pause(){this.cleanUpCallbacks()}resume(){this.cleanUpCallbacks(),this.registerCallbacks()}destroy(){}_handleCortoMesh(e,t,n){var r;try{this._kernelInstance.addMeshCorto(t,n,new Uint8Array(e))}catch(e){console.error(e),null===(r=this._configuratorUiCallbacks)||void 0===r||r.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 n=!!e&&!!e.fullList&&!!e.fullList.length;if(this._initData.useRoomlePrice&&n){const n=e.fullList[0].currencySymbol,r=e.fullList.reduce((e,t)=>e+(t.count?t.count:0)*(t.price?t.price:0),0),i=Ue(r,2);return this._configuratorUiCallbacks.onUpdatePrice(n,i),Promise.resolve({totalSum:i,partMap:t})}if(this._initData.usePriceService&&n){const n=e.fullList.reduce((e,n)=>{const r=Jt(n);return r&&(t.set(r,n),e.push(r)),e},[]);return new Promise((r,i)=>{this._rapiAccess.getPrices(n).then(n=>{if(!n.length)return i(new Error("prices are empty"));let s=0;const a=Le(n,"priceId");for(const t of e.fullList){const e=Jt(t);if(!a.has(e)){console.warn("PriceId: "+e+" has no corresponding kernel-part");continue}const{price:n,currencySymbol:r}=a.get(e);t.price=n,t.currencySymbol=r,s+=n*t.count}return s=Ue(s,2),this._configuratorUiCallbacks.onUpdatePrice(n[0].currencySymbol,s),r({totalSum:s,partMap:t})},e=>{console.error(e),i(e)})})}return Promise.resolve({totalSum:0,partMap:t})}async addUiDataAndPriceToPartList(e,t){const{fullList:n,originPart:r}=e,i=e.perMainComponent;let s;this.addUiDataToPartList(n,t);try{const t=await this._calcPrice(e);s=t.partMap}catch(e){console.error(e),s=new Map}const a=this._initData.usePriceService||this._initData.useRoomlePrice,o=e=>{a||(e.price=null,e.currencySymbol=null);const t=Jt(e);if(!t)return;if(!s.has(t))return;const{price:n,currencySymbol:r}=s.get(t);"number"==typeof n&&(e.price=n,e.currencySymbol=r)};return n.forEach(o),i.forEach(({fullList:e,perMainComponent:n})=>{n.length>0&&console.error("Not implemented! perMainComponent is deeper than one level"),this.addUiDataToPartList(e,t),e.forEach(o)}),{fullList:n,perMainComponent:i,originPart:r}}addUiDataToPartList(e,t){const n=[];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),Hs(e)){const t=this._rapiAccess.peekMaterial(e.value);t?e.valueLabel=t.label||t.name||e.value:-1===n.indexOf(e.value)&&n.push(e.value)}})}),n.length&&this._rapiAccess.getMaterials(n).then(e=>{const n=this._lastPartListHash!==t;Array.isArray(e)&&e.length&&n&&(this._lastPartListHash=t,this.requestPartListAndUpdatePricesOfParts())}),e}async requestPartListAndUpdatePricesOfParts(e,t){let n=this._kernelInstance.getFullPartList();e||(e=this._kernelInstance.getHashOfConfiguration(this._configuratorContext.planObjectId));const r=await this.addUiDataAndPriceToPartList(n,e);this._configuratorUiCallbacks.onPartListUpdate(r,btoa(e))}}tn([rn],Qs.prototype,"_rapiAccess",void 0),tn([rn],Qs.prototype,"_scriptLoader",void 0),tn([rn],Qs.prototype,"_kernelIo",void 0),tn([rn],Qs.prototype,"_dataSyncer",void 0),tn([rn],Qs.prototype,"_lifeCycleManager",void 0),tn([rn],Qs.prototype,"_configuratorUiCallbacks",void 0),tn([rn],Qs.prototype,"_globalCallback",void 0),tn([rn],Qs.prototype,"_initData",void 0),tn([rn],Qs.prototype,"_unitFormatter",void 0),tn([rn],Qs.prototype,"_configuratorContext",void 0),tn([rn],Qs.prototype,"_globalInitData",void 0);const{APP:Ys}=Ts,{RAPI:Zs}=Ys,Js=Zs.headers,$s=Zs.itemHeaders,ea=Js.token,ta=e("al",e=>e.startsWith("ps_")),na=Fe();let ra=new Map,ia=new Map,sa=new Map,aa=new Map,oa=new Map,la=new Map,ha=new Map,da=new Map,ca=new Map;const ua=e=>ra.get(e)||ra.get(na+e),pa=e=>e&&e.tags&&e.tags.length,ma=e=>!pa(e)&&e.group;class fa{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((n,r)=>{if(!navigator.onLine)return n();if(this._dataSyncer.getIsCatalogSynced(Zt(e)))return n();if(ha.get(e))return n();const i=t?"?itemId=":"?configurationId=";this._get("/preloads/components/"+i+e,"preloads/components").then(t=>{if(ha.get(e))return n();t.forEach(e=>{this._prepareData(e,"components")}),ha.set(e,!0),n()},r)})}changeUseOfHDGeometry(){const e=aa.get("components");ha.clear(),la.clear(),e&&aa.delete("components")}getHSCPackage(e){return new Promise((t,n)=>{if(la.get(e))return t();this._get("/catalogs/"+e+"/package","package").then(n=>{if(la.get(e))return t(n);n.components.forEach(e=>{this._prepareData(e,"components")}),n.materials.forEach(e=>{this._prepareData(e,"materials"),this._prepareGroups(e)}),n.textures.forEach(e=>{this._prepareData(e,"textures")}),la.set(e,!0),t(n)},n)})}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:$s})}getComponents(e){return this._getByIds(e,"components")}getItems(e){return this._getByIds(e,"items",{additionalHeaders:$s})}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",n=50){return this._getById(e,"meshes",{pathSuffix:"/data?format="+t+"&targetQuality="+n.toString()})}getMeshesOfCatalog(e){return new Promise((t,n)=>{const r=oa.get(e);r?t(r):this._get("/meshes?catalog="+e,"catalogMeshes").then(n=>{oa.set(e,n),t(n)},n)})}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=[],n=[];return e.forEach(e=>{const r=ia.get(e.id.toString());r?n.push(...r):t.push(e.id.toString())}),new Promise((e,r)=>{0!==t.length?this._getByIdsPackets(t,"itemAdditionalContents",{filterKey:"itemIds"}).then(t=>{t.forEach(e=>{let t=ia.get(e.itemId);t||(t=[]);for(let n=0,r=t.length;n<r;n++)if(t[n].id===e.id)return;t.push(e),ia.set(e.itemId,t)}),e([...t,...n])},r):e(n)})}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(){ra=new Map,sa=new Map,aa=new Map,la=new Map,ha=new Map,da=new Map,ia=new Map}cleanUp(){fa.clearCaches()}getMaterialsByGroup(e){const t=e.slice(),n=[];let r=t.length;for(let e=0;e<r;e++){const i=ua(t[e]);if(i){const s=i.length;for(let e=0;e<s;e++){const t=this._getCache("materials").get(i[e]);n.push(t)}t.splice(e,1),r--,e--}}return new Promise((e,r)=>{0!==t.length&&navigator.onLine?this._getByIdsPackets(t,"materials",{filterKey:"groups",embed:["textures"]}).then(t=>{e(this.combineMaterialsToGroups([...t,...n]))},r):e(this.combineMaterialsToGroups(n))})}_flushOfflineQueue(){return new Promise((e,t)=>{const n=this._localStorage.getItem("hsc_configurations_offline_queue_v1"),r=[];for(let e in n)if(n.hasOwnProperty(e)){const t=n[e];r.push(new Promise((e,n)=>{this.saveConfiguration(t.data).then(r=>{const i=[];t.perspectiveImage&&!r.perspectiveImage&&i.push(this.savePerspectiveImage(r,t.perspectiveImage)),t.topImage&&!r.topImage&&i.push(this.savePerspectiveImage(r,t.topImage)),Promise.all(i).then(e,n)},n)}))}Promise.all(r).then(()=>{this._localStorage.setItem("hsc_configurations_offline_queue_v1",{}),e()},t)})}_setQueuedConfiguration(e,t={}){const n=e.configurationHash,{perspectiveImage:r,topImage:i}=t;let s=this._localStorage.getItem("hsc_configurations_offline_queue_v1")||{},a=s[n]||{};a.data=e,a.perspectiveImage=r,a.topImage=i,s[n]=a,this._localStorage.setItem("hsc_configurations_offline_queue_v1",s)}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((n,r)=>this._fetchJson("/shortIds","shortIds",{method:"POST",resolve:n,reject:r,data:JSON.stringify({shortId:{type:t,referencedId:e}}),accept:"application/json",contentType:"application/json; charset=UTF-8"}))}_peekData(e,t){const n=aa.get(t);return n&&n.get(e)||null}_saveConfigurationImage(e,t,n){if(!navigator.onLine){const r={};return r[n]=t,this._setQueuedConfiguration(e,r),this._markConfigurationAsLocally(e),e[n]=t.image,Promise.resolve(e)}const r=this._formDataUtil.create(t.image,e.configurationHash,Wt.PNG,n);return this._save("/configurations/"+e.id+"/"+n,r,"configurations",{accept:"application/json"})}_savePlanSnapshotImage(e,t,n){const r=this._formDataUtil.create(t.image,e.id,Wt.PNG,"file");return r.append("type",n),this._save("/planSnapshots/"+e.id,r,"planSnapshots",{accept:"application/json",method:"PUT"})}_markConfigurationAsLocally(e){e.isLocally=!0,e.id=e.configurationHash}_save(e,t,n,r={}){const i=t instanceof FormData?t:JSON.stringify(t);return new Promise((t,s)=>{const a={method:r.method||"POST",data:i,resolve:t,reject:s};r.contentType&&(a.contentType=r.contentType),r.accept&&(a.accept=r.accept),this._fetchJson(e,n,a)})}combineMaterialsToGroups(e){return new Promise((t,n)=>{const r=new Map,i={id:null,label:null,materials:[]},s=[];for(let t=0,n=e.length;t<n;t++){const n=e[t],a=n.tags&&n.tags.length?n.tags.map(e=>({isTag:!0,id:e})):[];n.group&&a.push({isTag:!1,id:na+n.group,legacyId:n.group}),a.length||a.push({isTag:!1,id:null}),n.tags&&n.tags.length&&n.tags.forEach(e=>-1===s.indexOf(e)?s.push(e):null),a.forEach(({isTag:e,id:t,legacyId:s})=>{const a=n.id;let o=t?ua(t):[];o||(ra.set(t,[]),o=ua(t)),-1===o.indexOf(a.toString())&&o.push(a.toString());const l=pa(n),h=l&&e,d=ma(n);if(h||d&&!e||!l&&!d&&!t){let e=t?r.get(t):i;e||(r.set(t,{id:t,label:n.groupLabel,legacyId:s,materials:[]}),e=r.get(t)),e.materials.push(n)}})}const a=i.materials.length?[i]:[];this.getTags(s).then(e=>{const n=e.reduce((e,t)=>(e[t.id]=t,e),{});return r.forEach((e,t)=>{a.push({id:t,label:n[t]?n[t].label:e.label,materials:e.materials,legacyId:e.legacyId,sort:n[t]?n[t].sort:void 0})}),t(a)},n)})}_getByIds(e,t,n={}){const r=this._getCache(t),i=this._getErrorCache(t),s=[],a=[...new Set(e)];let o=a.length;if(r&&r.size){const e=(new Date).getTime();for(let t=0;t<o;t++){const n=a[t],l=r.get(n),h=i.get(n);let d=!1;null!=l?(s.push(l),d=!0):d=void 0!==h&&(e-h.timestamp<6e4||!1===navigator.onLine),d&&(a.splice(t,1),o--,t--)}}return new Promise((e,r)=>{0!==a.length&&navigator.onLine?this._getByIdsPackets(a,t,n).then(t=>{e([...t,...s])},r):e(s)})}_getByIdsPackets(e,t,n={}){const r=n.filterKey||"ids";let i,s="/"+t+"/",a="?",o=[];const l=e.length;if(!l)return new Promise(e=>e([]));let h=!0,d=[];for(i=0;i<l;i++){h=!1;const n=e[i],l=a+r+"[]="+n,c=l.length+s.length;d.push(n),a="&",c<=1500?s+=l:(c>1500&&(d.pop(),i--),o.push({url:s,ids:d}),h=!0,s="/"+t+"/",a="?",d=[])}h||o.push({url:s,ids:d});const c=[];return o.forEach(e=>c.push(this._getByIdsSingle(e.ids,e.url,t,n))),new Promise((e,t)=>{Promise.all(c).then(t=>{const n=[];t.length&&t.forEach(e=>n.push(...e)),e(n)},t)})}_getByIdsSingle(e,t,n,r={}){return new Promise((i,s)=>{this._get(t,n,r).then(t=>{for(let n=0,i=t.length;n<i;n++){const i=r&&r.cacheKey?t[n][r.cacheKey]:t[n].id,s=e.indexOf(i.toString());-1!==s&&e.splice(s,1)}const s=e.length;if(s){const t=this._getCache(n),r=this._getErrorCache(n),i=(new Date).getTime();for(let n=0;n<s;n++)r.set(e[n],{code:0,timestamp:i}),t.delete(e[n]);this._errorHandler.dispatch(2,[n,e.map(e=>'"'+e+'"').join(",")])}i(t)},s)})}_getById(e,t,n={}){if(!e||""===e||"string"!=typeof e)return console.error("no id passed to _getById"),Promise.reject(new Error("no id passed to _getById"));const r=this._getCache(t).get(e);if(r)return new Promise(e=>e(r));if(!navigator.onLine)return Promise.reject("Nothing cached but tried to fetch in offline mode");const i={...n,id:e},s=n.pathSuffix||"";return this._get("/"+t+"/"+e+s,t,i)}_get(e,t,n={}){const r=Ls.useHDGeometry?"includeGeometryHD=true":"";let i=-1===e.indexOf("?")?"?":"&";return""!==r&&(e+=i+r),n.embed&&Array.isArray(n.embed)&&n.embed.forEach(t=>{e+=i+"embed"+(t[0].toUpperCase()+t.substr(1))+"=true",i="&"}),new Promise((r,i)=>{const s=da.get(e);Array.isArray(s)&&s.length>0?s.push({resolve:r,reject:i}):(da.set(e,[{resolve:r,reject:i}]),this._fetchJson(e,t,n))})}_fetchJson(e,t,n={}){this._fetch(e,n).then(Be.bind(this)).then(this._handleJson(e,t,n).bind(this)).catch(this._handleError(e,n).bind(this))}async _fetch(e,t){const n={method:t.method?t.method:"GET",headers:this._createHeaders(t),mode:"cors",cache:"default"};t.data&&(n.body=t.data);let r=Zs.server;const i=this._globalInitData.overrideRapi;i&&(r="live"===i?Zs.liveServer:Zs.testServer),(this._globalInitData.customApiUrl||""===this._globalInitData.customApiUrl)&&(r=this._globalInitData.customApiUrl);const s=new Request(r+e,n);this._globalCallback.onNetworkRequest(e,n,t);const a=await this._globalCallback.onCheckExternalCache(e,n);return a?{headers:{get:()=>"application/json"},json:()=>Promise.resolve(a)}:this._networkLayer.fetch(s,{},{checkResponse:e=>this._globalCallback.onValidateNetworkResponse("rapi-access",e)})}_createHeaders(e={}){const t={...Js};this._globalInitData.overrideTenant&&(t.currentTenant=this._globalInitData.overrideTenant),this._globalInitData.overrideCountry&&(t.country=this._globalInitData.overrideCountry);const n=this._globalInitData.locale||"en";t.language=n,t.locale=n;const{contentType:r,accept:i,additionalHeaders:s,data:a}=e;if(r&&(t["content-type"]=e.contentType),i&&(t.accept=e.accept),s)for(let e in s)s.hasOwnProperty(e)&&(t[e]=s[e]);this._globalInitData.configuratorId&&(t.configurator=this._globalInitData.configuratorId);const o=this._currentToken||ea;t.token="03-"+window.btoa((new Date).toISOString()+";"+o+";"+Js.apiKey);const l=new Headers(t);return a instanceof FormData&&l.delete("content-type"),l}_handleJson(e,t,n={}){return r=>{let i=null,s=null;"number"==typeof r&&(i=r);for(let e in r)"meta"!==e&&r.hasOwnProperty(e)&&(i=r[e],s=e);if("error"===s)return this._handleError(e,n)(new Error(JSON.stringify(i)));if(!i)throw new TypeError("RAPI returned empty JSON");if(Array.isArray(i))for(let e=0,r=i.length;e<r;e++)this._prepareData(i[e],t,n),this._prepareEmbeddedData(i[e],t,n);else this._prepareData(i,t,n),this._prepareEmbeddedData(i,t,n);n.resolve?n.resolve(i):this._notifyWaiters(e,null,i)}}_prepareEmbeddedData(e,t,n={}){n.embed&&Array.isArray(n.embed)&&n.embed.forEach(r=>{const i=e[r.slice(0,-1)+"Objects"];if(Array.isArray(i)){for(let e=0,t=i.length;e<t;e++)this._prepareData(i[e],r,n);this._prepareRelationalData(t,r,e.id,i)}else i&&(this._prepareData(i,r,n),this._prepareRelationalData(t,r,e.id,[i]))})}_getCache(e){return this._getCacheFrom(e,aa)}_getErrorCache(e){return this._getCacheFrom(e,ca)}_getCacheFrom(e,t){let n=t.get(e);return n||(t.set(e,new Map),n=t.get(e)),n}_setCache(e,t,n){n.set(e.toString(),t)}_prepareData(e,t,n=null){let r=this._getCache(t);const i=n&&n.cacheKey?e[n.cacheKey]:e.id;if(i||n&&n.id||"tenants/me"===t)if("tenants/me"!==t){{const t=i||n.id;this._setCache(t,e,r)}e.__rapi_path__=t}else this._setCache("0",e,r);else"shortIds"!==t&&console.error("Can not cache because there is no ID!")}_getRelationsCacheFor(e,t,n){let r=sa.get(t);if(!r){const i=new Map,s=new Map;s.set(n,void 0),i.set(e,s),sa.set(t,i),r=sa.get(t)}let i=r.get(e);if(!i){const t=new Map;t.set(n,void 0),r.set(e,t),i=r.get(e)}return i.get(n)}_prepareGroups(e){const t=e.group,n=e.id;let r=ua(t);r||(ra.set(t,[]),r=ua(t)),-1===r.indexOf(n.toString())&&r.push(n.toString())}_handleError(e,t={}){return n=>{navigator.onLine?(n.rmlErrorCode=1,n.message='Failed to load "'+e+'" because of "'+n.message+'"',this._errorHandler.dispatch(1,[n])):(n.rmlErrorCode=0,n.message='Failed to load "'+e+'" because of "'+n.message+'"',this._errorHandler.dispatch(0,[n])),t.reject?t.reject(n):this._notifyWaiters(e,n,null)}}_getRelationData(e,t,n={}){const r=e.id;if(!r)return Promise.resolve([]);const i=e.__rapi_path__,s=t.rapiPath;let a=this._getCache(s),o=this._getRelationsCacheFor(r.toString(),i,s),l=[];return o?(o.forEach(e=>l.push(a.get(e))),new Promise(e=>e(l))):navigator.onLine?new Promise((e,t)=>{this._get("/"+i+"/"+r+"/"+s,s,n).then(t=>{this._prepareRelationalData(i,s,r,t),e(t)},t)}):Promise.resolve([])}_prepareRelationalData(e,t,n,r){sa.has(e)||sa.set(e,new Map);let i=sa.get(e);const s=n.toString();i.has(s)||i.set(s,new Map);let a=i.get(s),o=this._getCache(t),l=[];for(let e=0,t=r.length;e<t;e++){const t=r[e],n=t.id.toString();l.push(n),o.set(n,t)}a.set(t,l)}_notifyWaiters(e,t,n){const r=da.get(e);if(r&&r.length){for(let e=0,i=r.length;e<i;e++)t?r[e].reject(t):r[e].resolve(n);da.delete(e)}}_tenantMe(){return new Promise((e,t)=>{const n=this._getCache("tenants/me"),r=this._globalInitData.overrideTenant?this._globalInitData.overrideTenant:n.get("0");if(r)return e(r);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,n,r){const i="/"+r+"/"+e+"/shares",s=new FormData;return s.append("email",t),s.append("type",n.toString()),new Promise((e,t)=>{const n={method:"POST",data:s,resolve:e,reject:t,accept:"application/json",contentType:"application/json; charset=UTF-8"};this._fetch(i,n).then(n.resolve,n.reject)})}shareConfiguration(e,t,n){return this._share(e,t,n,"configurations")}sharePlanSnapshot(e,t,n){return this._share(e,t,n,"planSnapshots")}export3D(e,t,n,r={}){const i="/"+(ta(e)?"planSnapshots":"configurations")+"/"+e+"/3d-exports",s={formats:[{file_format:n,pack_external_data:!0,...r}]},a=JSON.stringify(s),o=new FormData;return o.append("email",t),o.append("settings",a),new Promise((e,t)=>{const n={method:"POST",data:o,resolve:e,reject:t};this._fetch(i,n).then(n.resolve,n.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 n=null===(e=null===window||void 0===window?void 0:window.location)||void 0===e?void 0:e.href;if(!n)return null;if(t){if(!document.referrer)return null;n=document.referrer}const{hostname:r}=new URL(n);return r})())&&(Yt.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:n}=this._globalInitData,r={module:3,action:1,actionId:e,actionLabel:n};await this.sendUserAction(r),this._itemLoaded=!0}signinUser(e,t){return new Promise((n,r)=>{const i={method:"POST",accept:"application/json",contentType:"application/json; charset=UTF-8",data:JSON.stringify({identification:e,passwordMD5:t}),cacheKey:"token",resolve:n,reject:r};this._fetchJson("/auth/signin","auth",i)})}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",fa),tn([rn],fa.prototype,"_formDataUtil",void 0),tn([rn],fa.prototype,"_errorHandler",void 0),tn([rn],fa.prototype,"_dataSyncer",void 0),tn([rn],fa.prototype,"_networkLayer",void 0),tn([rn],fa.prototype,"_localStorage",void 0),tn([rn],fa.prototype,"_globalInitData",void 0),tn([rn],fa.prototype,"_globalCallback",void 0);const ga=e("o",1500),va=e("n",5);function wa(){class e extends T{static _generateOutline(e,t){let n=new H(new ze(e),new He({color:"#000000",dashSize:.03,gapSize:.01,linewidth:1}));return n.translateOnAxis(t,1),n.userData.ignoreComponentRaycast=!0,n}static cloneDockLine(e,t){let n=new H(e.geometry,e.material);return n.translateOnAxis(t.getCenter(new a),1),n.name="dockline",n.layers.set(5),n.userData.ignoreComponentRaycast=!0,n}_setValues(e,t,n,r){e&&(this.runtimeId=e,this.name=e.toString()),t&&(this.roomlePosition=Object.assign({},t)),n&&(this.roomleRotation=Object.assign({},n)),r&&(this.parentObjectId=r)}constructor(e,t,n,r){super(),this._selected=!1,this.geometryChanged=!0,this.meshes=[],this.castShadow=!1,this.receiveShadow=!0,this._setValues(e,t,n,r)}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 z(e.geometry,e.material))})}addMesh(e,t){e.renderOrder=2,e.userData.meshType=0,t&&e.applyMatrix4(_r(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),Hi(e),t<0||this.meshes.splice(t,1)}removeAllMeshes(e=!0){this.meshes.forEach(t=>{this.remove(t),e&&Hi(t)}),this.meshes=[],this._removeLoadingMesh(),this.remove(this._boundingBoxMesh),Hi(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:n}=this._kernelBoundingBox.getSize(new a);let r=new Ie(e,t,n);this._loadingMesh=new z(r,hr.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 a),1),this._loadingMesh.renderOrder=3,this.add(this._loadingMesh)}_removeLoadingMesh(){this._loadingMesh&&(this.remove(this._loadingMesh),Hi(this._loadingMesh),this._loadingMesh=null)}loadingFinished(){this._removeLoadingMesh(),this._showAllMeshes()}deselect(){this._selected=!1}hoverOn(){Ne("pointer")}hoverOff(){Ne("default")}removeFromParent(){return this.parent&&(this.parent.remove(this),this.removeAllMeshes()),this}computeBoundingBox(t,n=!1){if(this._boundingBoxMesh&&this.remove(this._boundingBoxMesh),!n&&t&&0===t.size.x&&0===t.size.y&&0===t.size.z)return;let r;if(!t||n){this._boundingBox=new ue;let e=new a;this.meshes.forEach(t=>{if(t.geometry instanceof c){let n=t.geometry.attributes.position;if(void 0!==n)for(let r=0,i=n.count;r<i;r++)e.fromBufferAttribute(n,r).applyMatrix4(t.matrix),this._boundingBox.expandByPoint(e)}}),this._kernelBoundingBox=this._boundingBox.clone();let t=this._boundingBox.max.x-this._boundingBox.min.x,n=this._boundingBox.max.y-this._boundingBox.min.y,i=this._boundingBox.max.z-this._boundingBox.min.z;r=new Ie(t,n,i)}else{this._kernelBoundingBox=Ai(t),this._boundingBox=this._kernelBoundingBox.clone();let{x:e,y:n,z:i}=this._boundingBox.getSize(new a);r=new Ie(e,n,i)}this._boundingBoxMesh=new z(r,hr.createMeshStandardMaterial({color:"#FFFFFF",transparent:!0,opacity:0,polygonOffset:!0,polygonOffsetFactor:-1,visible:!1})),this._boundingBoxMesh.name="bounding box mesh";let i=this._boundingBox.getCenter(new a);this._boundingBoxMesh.position.add(i),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(r,i),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(n=>{n instanceof e&&t.push(...n.recursiveMeshes())}),t}isChild(t){let n=!1;return this.children.forEach(r=>{r instanceof e&&!n&&(n=r.runtimeId===t||r.isChild(t))}),n}getKernelPosition(e){let t=this.parent.localToWorld(this.position);return gr(e.worldToLocal(t))}}class t extends e{constructor(e,t){super(e,null,null,null),this.glbUrl=t}}class n extends e{constructor(e,t,n,r,i){super(t,n,r,i),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 U&&(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},n={opacity:.3};new TWEEN.Tween(t).to(n,ga).easing(TWEEN.Easing.Sinusoidal.In).onUpdate(()=>{e.material.opacity=t.opacity}).yoyo(!0).repeat(va).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)}),Ne("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)}),Ne("default")}clonePreview(t){const r=new n(this._creator_,this.runtimeId,this.roomlePosition,this.roomleRotation,this.parentObjectId);return r._stringId=this.runtimeId+"_"+t,this.children.forEach(e=>{e instanceof z&&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}preparePreview(){this.add(this._dockline),this.add(this._boundingBoxMesh)}}tn([rn],n.prototype,"_initData",void 0);class r extends n{constructor(e,t,n,r,i,s){super(e,t,n,r,i),s&&(this._stringId=this.runtimeId+"_has_additional_dock_point_copy")}set roomleLineFrom(e){this._roomleLineFrom=e,this.lineFrom=mr(e)}get roomleLineFrom(){return this._roomleLineFrom}set roomleLineTo(e){this._roomleLineTo=e;let t=mr(e);t.equals(this.lineFrom)&&(console.warn("lineFrom and lineTo are equal!"),t.add(new a(0,.01,0))),this.lineTo=t}get roomleLineTo(){return this._roomleLineTo}set roomlePositionFrom(e){this._roomlePositionFrom=e,this.positionFrom=mr(e)}get roomlePositionFrom(){return this._roomlePositionFrom}set roomlePositionTo(e){this._roomlePositionTo=e;let t=mr(e);t.equals(this.positionFrom)&&(console.warn("positionFrom and positionTo are equal!"),t.add(new a(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,Ne("pointer")}hoverOff(){this._dockline.visible=!1,Ne("default")}preparePreview(){super.preparePreview(),this._dockline.visible=!1;let e=this.lineTo.clone(),t=this.lineFrom.clone();const n=(new a).subVectors(e,t);let r=n.length(),i=n.normalize(),s=new je(i,t),o=new Ve(.01,.01,r,16,1);this.lineMesh=new z(o,hr.createMeshStandardMaterial({color:"#DDDDDD",transparent:!0,opacity:.4})),this.lineMesh.name="line mesh";const l=(new C).setFromEuler(s.rotation);this.lineMesh.quaternion.multiply(l),this.lineMesh.renderOrder=1;let h=(new a).addVectors(e,t).multiplyScalar(.5);this.lineMesh.position.copy((new a).subVectors(h,this.position.clone())),this.add(this.lineMesh);let d=this._boundingBox.getCenter(new a).applyEuler(this.docklineRotation),c=null,u=0,p=Math.abs(i.x),m=Math.abs(i.y),f=Math.abs(i.z);p>=m&&p>=f?(c=new a(d.x,0,0),u=Math.sqrt(d.y*d.y+d.z*d.z)):m>=p&&m>=f?(c=new a(0,d.y,0),u=Math.sqrt(d.x*d.x+d.z*d.z)):f>=m&&f>=p&&(c=new a(0,0,d.z),u=Math.sqrt(d.y*d.y+d.x*d.x)),u=u>0?u:.01;let g=(new a).subVectors(this.positionTo.clone(),this.positionFrom.clone()).length()+c.length(),v=new Ve(1.1*u,1.1*u,g,32,1);this.boundingLineMesh=new z(v,hr.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(),_=(new a).subVectors(w,b).normalize(),y=new je(_,b);const x=(new C).setFromEuler(y.rotation);this.boundingLineMesh.quaternion.multiply(x),this.boundingLineMesh.renderOrder=3;let S=(new a).addVectors(this.positionTo.clone(),this.positionFrom.clone()).multiplyScalar(.5).add(d);this.boundingLineMesh.position.copy((new a).subVectors(S,this.position.clone())),this.add(this.boundingLineMesh)}clonePreviewLine(t){let n=new r(this._creator_,this.runtimeId,this.roomlePosition,this.roomleRotation,this.parentObjectId,this.receivedPointAssociation);return n._stringId=this.runtimeId+"_"+t,this.children.forEach(e=>{e instanceof z&&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}getPositionForIntersectionPoint(e){let t=this._boundingBox.getCenter(new a).applyEuler(this.docklineRotation),n=this.positionTo.clone().add(t),r=this.positionFrom.clone().add(t),i=new Ge(r,n).closestPointToPoint(e,!0,new a);return(isNaN(i.x)||isNaN(i.y)||isNaN(i.z))&&i.copy(e),i.sub(t)}updatePreviewPosition(e){let t=this.getPositionForIntersectionPoint(e),n=this.parent.localToWorld(t);this._newPosition=this.worldToLocal(n);let r=this._boundingBox.getCenter(new a).applyEuler(this.docklineRotation);this._dockline.position.copy((new a).addVectors(this._newPosition,r)),this._dockline.rotation.copy(this.docklineRotation)}hideSelectionLine(){this._dockline.visible=!1}getKernelPosition(e){if(this._newPosition){let t=this.localToWorld(this._newPosition);return gr(e.worldToLocal(t))}return super.getKernelPosition(e)}}class i extends q{constructor(e,t,n,r,i,s,a){super(e,t,n,r,i,s),a||(a={left:0,top:1,right:1,bottom:0}),this.offset=a}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 S).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 n=t.from,r=t.to;const i=this._scaleRange(e.bottom,e.top,this._offset.bottom,this._offset.top);let s=i.from,a=i.to;const o=(e.right-e.left)/(e.top-e.bottom),l=(r-n)/(a-s);if(l>o){const e=(s+a)/2,t=(a-s)*l/o;s=e-t/2,a=e+t/2}else{const e=(n+r)/2,t=(r-n)*o/l;n=e-t/2,r=e+t/2}return(new S).makeOrthographic(n,r,a,s,this.near,this.far)}_scaleRange(e,t,n,r){const i=(t-e)/(r-n);return{from:e-i*n,to:t+i*(1-r)}}_calculate2DPlanes(){const e=(this.right-this.left)/(2*this.zoom),t=(this.top-this.bottom)/(2*this.zoom),n=(this.right+this.left)/2,r=(this.top+this.bottom)/2;let i=n-e,s=n+e,a=r+t,o=r-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;i+=e*this.view.offsetX,s=i+e*this.view.width,a-=t*this.view.offsetY,o=a-t*this.view.height}return{left:i,right:s,top:a,bottom:o}}}class o extends W{constructor(e,t,n,r,i){super(e,t,n,r),i||(i={left:0,top:1,right:1,bottom:0}),this.offset=i}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,n,r,i=this.fov*(2*Math.PI/360)/2;n=Math.tan(i),r=-n;let a=Math.atan(this.aspect*Math.tan(i));t=Math.tan(a),e=-t;let o=this._offset.left,l=this._offset.right,h=this._offset.top,d=this._offset.bottom,c=new s(l-o,h-d),u=new s(o+c.x/2,d+c.y/2);if(c.x<c.y){let i=(1-u.x)/(c.x/2),s=u.x/(c.x/2);t*=i,e*=s;let a=(i+s)/2;n*=a,r*=a}else{let i=(1-u.y)/(c.y/2),s=u.y/(c.y/2);n*=i,r*=s;let a=(s+i)/2;e*=a,t*=a}e*=this.near,t*=this.near,n*=this.near,r*=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,n-=this.view.offsetY*p/this.view.fullHeight,t+=this.view.offsetX*m/this.view.fullWidth,r-=this.view.offsetY*p/this.view.fullHeight),(new S).makePerspective(e,t,n,r,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,n,r,i){return new e(t,n,r,i)},createPreview:function(e,t,r){return new n(r,e,{x:0,y:0,z:0},{x:0,y:0,z:0},t)},createStatic:function(e,n){return new t(e,n)},createPreviewLine:function(e,t){let n=new r(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(),n.addMesh(t)}),n.computeBoundingBox(),n},isPreview:function(e){return e instanceof n},isPreviewLine:function(e){return e instanceof r},createPerspectiveCamera:function(e,t,n,r,i){return new o(e,t,n,r,i)},createOrthographicCamera:function(e,t,n,r,s,a,o){return new i(e,t,n,r,s,a,o)}}}const ba=e("z",9);class _a{constructor(e){this._mergeThreshold=3,this._componentsToMerge=new ya,this._mergeInProgress=!1,this._components=new Map,this._previews=new Map,this._componentNumberOfPossibleChildren=new Map,this._creator_=e,this._getKernelAccess().addConfiguratorListener(this),this._componentFactory=wa()}get materialQueue(){return this.getMeshGenerator().materialQueue}_getKernelAccess(){return oh.lookup("planner-kernel-access",this._creator_)}_applyMeshTransform(e,t,n,r,i){if(n){const r=e.userData.transform=_r(n);t&&(e.userData.transform=r),e.applyMatrix4(r)}this._applyMeshUVTransform(e,t,r,i)}_applyMeshUVTransform(e,t,n,r){if(6!==(null==n?void 0:n.length)||(e=>1===e[0]&&0===e[1]&&0===e[2]&&1===e[3]&&0===e[4]&&0===e[5])(n))t&&(t.uvTransform=void 0),r&&(e.geometry=r);else{const i=(e=>{const t=new S;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})(n);t&&(t.uvTransform=i);const s=null!=r?r:e.geometry;if(s&&s.attributes.uv){const t=s.clone();t.attributes.uv.applyMatrix4(i),e.geometry=t}}}_addMeshToSubPart(e,t,n,r,i,s,a,o,l,h){const d=this._generateMesh(e,t,n,s,a,o,l,void 0,void 0,h);this._applyMeshTransform(d,null,r,i),this._subPartObject.add(d)}_addMeshToComponent(e,t,n,r,i,s,a,o,l,h,d,c){if(this._subPartGuard&&this._subPartGuard.info===e)return void this._addMeshToSubPart(e,null,r,null,null,a,o,l,h,c);const u=this.getComponent(e);if(!u)return;const p=this._componentFactory.isPreview(u),m=this._generateMesh(e,n,p?null:r,a,o,l,h,void 0,void 0,c);m.userData.meshId=t,m.userData.geometryId=n,m.userData.materialId=r,this._applyMeshTransform(m,m.userData,i,s),p&&m.layers.set(5),u&&u.addMesh(m),u.meshes.length>this._mergeThreshold&&this._componentsToMerge.set(e,u.meshes.length)}_changeMeshOfComponent(e,t,n,r,i,s,a){const o=this.getComponent(e);if(!o)return;const l=o.getMeshById(t);if(l){l.userData.geometryId!==n&&console.warn("Geometry of mesh has changed!"),l.userData.materialId=r,l.userData.materialAttributes=a;const e=l.material.clone();this._configuratorMeshGenerator.setMaterial(l,r,void 0,a),e.opacity!==l.material.opacity&&this._requestRenderCallback&&this._requestRenderCallback(),i&&(l.position.set(0,0,0),l.scale.set(1,1,1),l.rotation.set(0,0,0));const t=this._configuratorMeshGenerator.getGeometry(n);this._applyMeshTransform(l,l.userData,i,s,t)}}_removeMeshFromComponent(e,t){const n=this.getComponent(e);n&&n.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,n=[],r=[];t.meshes.forEach(t=>{const i=t.userData.materialId;if(!i)return void console.warn("mesh has no material id set");if(!e.has(i)){const r=new z(new c,t.material);r.userData.materialId=i,r.receiveShadow=!0,r.castShadow=!0,r.layers.set(3),this._setMaterial(r,i),n.push(r),e.set(i,r)}const s=e.get(i),a=s.geometry;t.userData.transform&&t.geometry.applyMatrix4(t.userData.transform),s.geometry=function(e,t=!1){const n=null!==e[0].index,r=new Set(Object.keys(e[0].attributes)),i=new Set(Object.keys(e[0].morphAttributes)),s={},a={},o=e[0].morphTargetsRelative,l=new c;let h=0;for(let d=0;d<e.length;++d){const c=e[d];let u=0;if(n!==(null!==c.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(const e in c.attributes){if(!r.has(e))return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+d+'. All geometries must have compatible attributes; make sure "'+e+'" attribute exists among all geometries, or in none of them.'),null;void 0===s[e]&&(s[e]=[]),s[e].push(c.attributes[e]),u++}if(u!==r.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!==c.morphTargetsRelative)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+d+". .morphTargetsRelative must be consistent throughout all geometries."),null;for(const e in c.morphAttributes){if(!i.has(e))return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+d+". .morphAttributes must be consistent throughout all geometries."),null;void 0===a[e]&&(a[e]=[]),a[e].push(c.morphAttributes[e])}if(t){let e;if(n)e=c.index.count;else{if(void 0===c.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;e=c.attributes.position.count}l.addGroup(h,e,d),h+=e}}if(n){let t=0;const n=[];for(let r=0;r<e.length;++r){const i=e[r].index;for(let e=0;e<i.count;++e)n.push(i.getX(e)+t);t+=e[r].attributes.position.count}l.setIndex(n)}for(const e in s){const t=pn(s[e]);if(!t)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed while trying to merge the "+e+" attribute."),null;l.setAttribute(e,t)}for(const e in a){const t=a[e][0].length;if(0===t)break;l.morphAttributes=l.morphAttributes||{},l.morphAttributes[e]=[];for(let n=0;n<t;++n){const t=[];for(let r=0;r<a[e].length;++r)t.push(a[e][r][n]);const r=pn(t);if(!r)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed while trying to merge the "+e+" morphAttribute."),null;l.morphAttributes[e].push(r)}}return l}([a,t.geometry]),r.push(t)}),n.forEach(e=>t.addMesh(e)),r.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,n,r){let i=this._components.get(t),s=this._components.get(e);s&&(s.roomlePosition=n,s.roomleRotation=r,i&&i.add(s))}dockComponentWithPosition(e,t){let n,r=this._components.get(e.parentId);n=t?t.getKernelPosition(r):e.getKernelPosition(r),Ds.start("dock_component_with_position_"+e.childId),this._getKernelAccess().dockComponentWithPosition(e.parentId,e.parentDockId,e.childId,e.childDockId,n),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 n=!0;t&&(n=t.geometryChanged),this._listener&&this._listener.planObjectUpdated(e,n)}Editor3dAddBakedMesh(e,t,n,r,i,s,a,o){this._addMeshToComponent(e,null,null,t,null,null,n,r,i,s,a,o)}Editor3dAddDockPreview(e,t){const n=this._componentFactory.createPreview(t,e,this._creator_);this._previews.set(t.toString(),n)}Editor3dAddNamedMesh(e,t,n,r,i,s,a,o,l,h,d,c){this._addMeshToComponent(e,t,n,r,i,d,s,a,o,l,h,c)}Editor3ChangedNamedMesh(e,t,n,r,i,s,a){this._changeMeshOfComponent(e,t,n,r,i,s,a)}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 T)}Editor3dComponentCreated(e,t,n,r,i){i&&(this._configuratorContext.rootComponentId=e);let s=null;this._components.has(e)?(s=this._components.get(e),s.removeAllMeshes()):(s=this._componentFactory.create(e,t,n,r),s.layers.set(3)),this._components.set(e,s),i&&this._addRootComponent(s)}Editor3dComponentDocked(e,t,n,r){this.dockComponent(e,t,n,r)}Editor3dEndConstruction(e){if(this._subPartGuard&&this._subPartGuard.info===e)return void this._subPartGuard.resolve(this._subPartObject);const t=this._getKernelAccess().kernelInstance.getComponent(e),n=this._components.get(e);n&&(n.computeBoundingBox(t.boxForMeasurement),n.boundingBoxMesh&&this._listener&&this._listener.addComponentHandlers(n));let r=this._previews.get(e.toString());r&&r.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),n=[t,this._getKernelAccess().kernelInstance.getFullPartList(),this._getKernelAccess().kernelInstance.getHashOfConfiguration(e),this._getKernelAccess().kernelInstance.getComponentId(t.rootPlanComponentId)];Bs.finishOperation(2,n),this._updatePlanObject(t),this._listener&&this._listener.planObjectConstructionDone(t)}Editor3dPreviewConstructionDone(e,t){let n=!1;this._previews.forEach(e=>{null!==e.parent&&(this._listener&&(this._componentFactory.isPreviewLine(e)?this._listener.addPreviewLineHandlers(e):this._listener.addPreviewHandlers(e)),n=!0)}),this._listener&&this._listener.previewConstructionDone(this._components.get(e),n)}Editor3dSetPreviewLineAssociations(e,t){let n=this._previews.get(t.toString());if(n.clear(),!n)return;let r=this._componentFactory.createPreviewLine(n,this._creator_),i=this._components.get(this._configuratorContext.rootComponentId);for(let t=0;t<e.length;t++){let n;n=0===t?r:r.clonePreviewLine(t),n.name="Preview Line",n.parentDockId=e[t].parentDockId,n.parentId=e[t].parentId,n.childDockId=e[t].childDockId,n.childId=e[t].childId,n.docklineRotation=(s=e[t].rotation,new ge(s.x,s.z,-s.y)),n.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?(n.roomleLineFrom=e[t].lineTo,n.roomleLineTo=e[t].lineFrom):(n.roomleLineFrom=e[t].lineFrom,n.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?(n.roomlePositionFrom=e[t].positionTo,n.roomlePositionTo=e[t].positionFrom):(n.roomlePositionFrom=e[t].positionFrom,n.roomlePositionTo=e[t].positionTo),i.add(n),n.preparePreview(),this._previews.set(n.stringId,n)}var s}Editor3dSetPreviewPointAssociations(e,t){let n=this._previews.get(t.toString());if(!n)return;let r=this._components.get(this._configuratorContext.rootComponentId);for(let t=0;t<e.length;t++){let i;0===t?i=n:(i=n.clonePreview(t),this._previews.set(i.stringId,i)),i.name="Preview Point",i.parentDockId=e[t].parentDockId,i.parentId=e[t].parentId,i.childDockId=e[t].childDockId,i.childId=e[t].childId,i.preparePreview(),i.receivedPointAssociation=!0,i.userData.ignoreComponentRaycast=!0,r.add(i),i.roomlePosition=e[t].position,i.roomleRotation=e[t].rotation,i.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 n=this._getRuntimeComponent(e);n&&(n.geometryChanged=t)}_getRuntimeComponent(e){let t=this._components.get(e);return t||(t=this._previews.get(e.toString()),t)?t:null}configurationLoaded(e,t,n,r,i){10===e&&(this._configuratorContext.dockingRootComponentId=n);let s=0===t;s?this._getKernelAccess().kernelInstance.requestPlanComponentConstructionRecursive(n):this._getKernelAccess().kernelInstance.requestPlanObjectConstruction(t);let a=this._getKernelAccess().kernelInstance.getComponent(n),o=this._components.get(n);o&&(o.computeBoundingBox(a.boxForMeasurement),o.hash=a.hash),this._listener&&this._listener.configurationLoaded(o,s&&void 0!==o.boundingBoxMesh)}finishParameterChange(e,t){this.materialQueue.registerCallback(e)}planObjectConfigurationUpdated(e,t,n){let r=this._getKernelAccess().kernelInstance.getPlanObject(e);this._updatePlanObject(r)}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 Ai(e.boxForMeasurement)}else if(this._configuratorContext.rootComponentId){const e=this._components.get(this._configuratorContext.rootComponentId);return(new ue).setFromObject(e)}return null}getBoundingBoxWithPreviews(){const e=this._components.get(this._configuratorContext.rootComponentId);return e?(new ue).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 n=this._components.get(e);n&&t.push(n)}),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,n,r,i,s,a,o,l,h){return this._configuratorMeshGenerator.generateMesh(e,t,n,r,i,s,a,!1,h)}_setMaterial(e,t,n){this._configuratorMeshGenerator.setMaterial(e,t)}constructComponents(e){this._getKernelAccess().kernelInstance.requestPlanObjectConstruction(e)}requestSubPartConstruction(e){return this._subPartGuard=new un(e),this._getKernelAccess().requestPlanComponentConstruction(e,!1),this._subPartGuard.wait()}getMeshGenerator(){return this._configuratorMeshGenerator}setRequestRenderCallback(e){this._requestRenderCallback=e}}e("C",_a),tn([rn],_a.prototype,"_configuratorMeshGenerator",void 0),tn([rn],_a.prototype,"_configuratorContext",void 0),tn([rn],_a.prototype,"_cacheHolder",void 0),tn([rn],_a.prototype,"_initData",void 0);class ya extends Map{largestValue(){let e=this.entries().next().value[0],t=0;return this.forEach((n,r)=>{n>t&&(e=r,t=n)}),e}}const xa=["material"];class Sa extends Qs{constructor(e){super(e),this.externalMeshQueue=new rs,this.muteKernelCallbacks=!1,this.listOfVariants=(e,t)=>{}}init(e){super.init(e),Ds.addMeta("kernel_is_ready",{isWasm:this._useWASM}),Ls.kernelInstance?(this._kernelContainer=Ls.kernelContainer,setTimeout(()=>this._loadSuccess(),0)):this._scriptLoader.fetch(this._kernelPath,{id:"kernel"}).then(this._loadSuccess.bind(this),this._loadError.bind(this))}_loadSuccess(){Ds.start("kernel_is_ready"),window.ConfiguratorKernel&&(Ls.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);Bs.finishOperation(1,t)}_updateComponentParameters(e){let t=this._kernelInstance.getComponentParameters(e);const n=this._kernelInstance.getComponent(e);this._configuratorKernelAccessCallback.updateParameters(t,n.parameterGroups,e,1)}selectionChange(e,t){let n=!1,r=[];if(e){let t=this._kernelInstance.getComponent(e);t.componentId=this._kernelInstance.getComponentId(e),t&&t.childIds&&t.childIds.length>0&&(n=!0),r.push(t)}this._configuratorUiCallbacks.onSelectionChange("standard",t,n,r)}multiSelectionChange(e,t){this._updateCommonComponentDependencies(e);let n=!1,r=!1,i=[];e&&e.forEach(e=>{let s=this._kernelInstance.getComponent(e);s.componentId=this._kernelInstance.getComponentId(e),s&&s.childIds&&s.childIds.length>0&&(n=!0),s.id===t&&(r=!0),i.push(s)}),this._configuratorUiCallbacks.onSelectionChange("multiselect",r,n,i)}_updateCommonComponentDependencies(e){const{parameters:t,parameterGroups:n}=this._kernelInstance.getCommonPlanComponentParameters(this._utilityToLongArray(e));this._configuratorKernelAccessCallback.updateParameters(t,n,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,n=this._kernelInstance.getPlanObjectParameters(e);if(0===n.length){let r=this._kernelInstance.getRootPlanComponentIdFromObjectId(e);n=this._kernelInstance.getComponentParameters(r),this._enableRootComponentParametersAsGlobal(),t=this._kernelInstance.getComponent(r)}else this._configuratorContext.rootComponentParametersAsGlobal=!1,t=this._kernelInstance.getPlanObject(e);this._configuratorKernelAccessCallback.updateParameters(n,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 n=t.childIds.size?t.childIds.size():t.childIds.length;this._configuratorUiCallbacks.onConfigurationHasChildren(n>0)}dockComponent(e,t,n,r){const i=this._kernelInstance.getComponentId(n),s=this._kernelInstance.getComponentId(e);this._kernelInstance.dockComponent(n,r,e,t),this._configuratorUiCallbacks.onUserInitiatedDockDone(i,r,s,t,null)}changeUseOfHDGeometry(e,t){this._rapiAccess.changeUseOfHDGeometry();const n=e.planObjectId,r=e.lastLoadedRapiId?e.lastLoadedRapiId:this._kernelInstance.getComponentId(n),i=this._kernelInstance.getSerializedConfiguration(n);this._kernelInstance.clearAll(),this._kernelInstance.useHDGeometry(t),Bs.finishOperation(3,[i,r])}webGlPreviewDockings(e,t){Bs.waitFor(4).then(({componentId:n})=>{t&&this.requestPlanComponentConstruction(n),this._kernelInstance.requestPreviewGeometry(n,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(ba,e,{x:0,y:0,z:0})}changeCommonComponentParameter(e,t,n,r,i,s){"string"==typeof r?this._kernelInstance.setPlanComponentParameters(this._utilityToLongArray(e),t,r):console.warn("tried to set a parameter to a none string value!",r,t,n),this._finishParameterChange(n,i,s),this._updateCommonComponentDependencies(e)}changeComponentParameter(e,t,n,r,i,s){"string"==typeof r?this._kernelInstance.setComponentParameter(e,t,r):console.warn("tried to set a parameter to a none string value!",r,t,n),this._finishParameterChange(n,i,s),this._updateComponentDependencies(e)}changePlanObjectParameter(e,t,n,r,i,s){"string"==typeof r?this._kernelInstance.setPlanObjectParameter(e,t,r):console.warn("tried to set a parameter to a none string value!",r,t,n),this._finishParameterChange(n,i,s)}_finishParameterChange(e,t,n){-1===xa.indexOf(e)?setTimeout(()=>t(),0):this._configuratorKernelCallbackListener.forEach(e=>e.finishParameterChange(t,n))}requestDeleteComponents(e){e&&this._kernelInstance.deletePlanComponents(this._utilityToLongArray(e))}requestDeletePlanComponent(e){var t,n;e&&(null===(n=null===(t=this._initData)||void 0===t?void 0:t.featureFlags)||void 0===n?void 0:n.reDock)&&this._kernelInstance.deletePlanComponent(e)}loadComponentIntoKernel(e,t){this._kernelIo.setMeta({componentId:t}),this._kernelInstance.loadComponentDefinition(10,e)}async requestPartListAndUpdatePricesOfParts(e,t){let n=this._kernelInstance.getFullPartList();e||(e=this._kernelInstance.getHashOfConfiguration(this._configuratorContext.planObjectId));const r=await this.addUiDataAndPriceToPartList(n,e);this._configuratorUiCallbacks.onPartListUpdate(r,btoa(e))}requestSync(e,t){this.planObjectCreated(e,t),this._kernelInstance.syncPlanObjectToView(e,t)}getGlobalParameters(e,t){return new Promise(n=>{let r=this._kernelInstance.getPlanObjectParameters,i=e;t&&(r=this._kernelInstance.getComponentParameters,i=this._kernelInstance.getRootPlanComponentIdFromObjectId(e)),n(r.apply(this._kernelInstance,[i]))})}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(),Ts.isProduction||(window.__RML__DEBUG__.Kernel=this._kernelInstance,window.__RML__DEBUG__.KernelContainer=this._kernelContainer,window.__RML__DEBUG__.Helper={convertCObject:wr}),this._configuratorKernelAccessCallback.isReady(),this._configuratorUiCallbacks.onConfiguratorKernelIsReady(this._kernelContainer,this._kernelInstance),Ls.planObjectId&&this.planObjectCreated(-1,Ls.planObjectId)}_setupKernel(){1===this._kernelType&&(Ds.start("kernel_create_instance"),Ls.kernelInstance?this._kernelInstance=Ls.kernelInstance:this._kernelInstance=new this._kernelContainer.Kernel),this._initKernel()}onLoadComponentError(e,t){this._configuratorUiCallbacks.onComponentLoadError(e,t)}configurationLoaded(e,t,n,r,i,s){Bs.finishOperation(4,{conversationId:e,objectId:t,componentId:n,hash:r,errors:wr(i)}),this._configuratorKernelCallbackListener.forEach(s=>s.configurationLoaded(e,t,n,r,i))}componentDefinitionLoaded(e,t){Bs.finishOperation(0,t)}componentDefinitionLoadingError(e,t){this._kernelIo.error(t),Bs.failOperation(0,new Error(t))}configurationLoadingError(e,t){let n="Configuration loading error";if(t){const e=wr(t);Array.isArray(e)&&(n=e.join("\n"),e.forEach(e=>this._kernelIo.error(e)))}Bs.failOperation(4,new Error(n)),Bs.failOperation(2,new Error(n))}componentConfigurationUpdated(e,t){this._configuratorKernelCallbackListener.forEach(n=>n.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(n=>n.planObjectCreated(e,t))}planObjectUpdated(e){const t=this._kernelInstance.getPlanObject(e);this._onBoundsUpdate(t),this._configuratorKernelCallbackListener.forEach(e=>e.planObjectUpdated(t))}planObjectConfigurationUpdated(e,t,n,r,i){this.updatePlanObjectDependencies(e);let s=this._kernelInstance.getComponent(this._kernelInstance.getRootPlanComponentIdFromObjectId(e));this._configuratorKernelCallbackListener.forEach(r=>r.planObjectConfigurationUpdated(e,t,n));const a=this._kernelInstance.getPlanObject(e);return this._onBoundsUpdate(a),this._configuratorHistory.push(t),this._updateConfigurationHasChildren(e,s),this.requestPartListAndUpdatePricesOfParts(n)}_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 n=()=>{};const r=new Promise((e,t)=>{n=e});let i;this.externalMeshQueue.push(r),this._configuratorUiCallbacks.onRequestExternalMesh(e,t);try{i=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 r=await fetch(new Request(this._dataSyncer.requestAsset(i.url,!0))),s=await r.arrayBuffer();this._handleCortoMesh(s,e,t),n()}catch(t){return this._handleInvalidMesh(e),this._configuratorUiCallbacks.onError(new Error(`Mesh with id "${e}" breaks. "${t}"`)),void console.error(t)}}Editor3dComponentCreated(e,t,n,r){this._configuratorKernelCallbackListener.forEach(i=>i.Editor3dComponentCreated(e,t,n,r,!1)),r&&r>0&&this._configuratorKernelCallbackListener.forEach(i=>i.Editor3dComponentDocked(e,r,t,n))}Editor3dRootComponentCreated(e,t,n,r){this._configuratorKernelCallbackListener.forEach(i=>i.Editor3dComponentCreated(e,t,n,r,!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(n=>n.Editor3dAddDockPreview(e,t))}Editor3dSetPreviewPointAssociations(e,t){this._configuratorKernelCallbackListener.forEach(n=>n.Editor3dSetPreviewPointAssociations(e,t))}Editor3dSetPreviewLineAssociations(e,t){this._configuratorKernelCallbackListener.forEach(n=>n.Editor3dSetPreviewLineAssociations(e,t))}Editor3dPreviewConstructionDone(e,t){this._configuratorKernelCallbackListener.forEach(n=>n.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)}}tn([rn],Sa.prototype,"_memoryManager",void 0),tn([rn],Sa.prototype,"_configuratorKernelAccessCallback",void 0),tn([rn],Sa.prototype,"_initData",void 0),tn([rn],Sa.prototype,"_configuratorHistory",void 0);class Ca extends ys{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 Ke(.05,32),t=new _({color:16777215});this._sphere=new z(e,t);const n=new We(.05,.07,32),r=new _({color:0,side:F});this._innerRingMesh=new z(n,r),this._innerRingMesh.rotation.set(Math.PI/2,0,0);const i=new We(.07,.08,32),s=new _({color:16777215,side:F});this._outerRingMesh=new z(i,s),this._outerRingMesh.rotation.set(Math.PI/2,0,0),this._nodeUiMesh=new z,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 ue).setFromObject(this._nodeUiMesh).getSize(new a)}show(){this._nodeUiMesh.visible=this._topView}hide(){this._nodeUiMesh.visible=!1}select(){this._innerRingMesh.material=new _({color:10526880,side:F}),super.select()}deselect(){this._innerRingMesh.material=new _({color:0,side:F}),super.deselect()}hoverOn(){this._sphere.geometry=new Ke(.07,32),this._innerRingMesh.geometry=new We(.07,.07+.02,32),this._outerRingMesh.geometry=new We(.07+.02,.1,32),super.hoverOn()}hoverOff(){this._sphere.geometry=new Ke(.05,32),this._innerRingMesh.geometry=new We(.05,.07,32),this._outerRingMesh.geometry=new We(.07,.08,32),super.hoverOff()}_generateBoundingBox(){const e=super._generateBoundingBox();return e.layers.set(9),e}addMesh(e){super.addMesh(e)}}e("N",Ca);class Ma extends As{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 K;const e=this.getPlanElement(),{x:t,z:n}=fr(e.size),r=new Ie(t,.01,n);if(this._topGreyMesh=new z(r,hr.createMeshStandardMaterial({transparent:!0,opacity:1,color:11645361})),this._topViewContainer.add(this._topGreyMesh),"window"===e.getObjectType()){const e=new Ie(t,.02,.05);this._topBlackMesh=new z(e,hr.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 Ie(t.x,this._topView?5:t.y,t.z),e}_updateBoundingBox(){super._updateBoundingBox();const e=this.getSize();this._boundingBox.geometry=new Ie(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}=fr(this.getPlanElement().size);this._topGreyMesh.geometry=new Ie(e,.01,t),this._topBlackMesh&&(this._topBlackMesh.geometry=new Ie(e,.02,.05))}}e("d",Ma);class Ta extends Sa{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),Ts.isProduction||(window.__RML__DEBUG__.ConfiguratorKernel=this._kernelInstance,window.__RML__DEBUG__.PlannerKernelContainer=this._kernelContainer),this._kernelAccessCallback.isReady()}_setupKernel(){0===this._kernelType&&(this._createPlanInteractionHandler(),Ls.kernelInstance?this._kernelInstance=Ls.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 n=e.count||1;for(let r=0;r<n;r++)e.count||(e.count=0),t.push_back(this._rapiItemToKernelItem(e))});const n=this.planInteractionHandler.getPlan().extRef.jsObject,r=n.getPlanObjectViewModelsFromRapiId().reduce((e,t)=>(e[t.getId()]=!0,e),{});this.planInteractionHandler.addPlanObjects(t,!0),await Promise.allSettled([Promise.allSettled(n.getStaticPlanObjectViewModels().map(async e=>{if(e.needsRapiItem()){const t=await this._rapiAccess.getItem(e.getPlanObject().getCatalogItemId());e.setRapiItem(t)}})),Promise.allSettled(n.getConfigurablePlanObjectViewModels().map(e=>e.isInitDone()))]);const i=n.getPlanObjectViewModelsFromRapiId().map(e=>e.getId()).filter(e=>!r[e]);return this.planInteractionHandler.endInteraction(),i}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),n=t.size;return n.x=e.width||0,n.y=e.depth||0,n.z=e.height||0,t.size=n,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(n=>n.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 n;n=this.isConstructionPlanElement(t)?new Ma(t):new As(t),this.coupleReferences(n,t),e.extRef.jsObject.addPlanElementViewModel(n);const r=t.getCatalogItemId();if(r){const e=await this._rapiAccess.getItem(r);n.setRapiItem(e),this._plannerKernelCallbackListener.forEach(e=>e.addPlanObjectToScene(n))}}_onConfigurableItemAdded(e,t){const n=new Ss(t);this.coupleReferences(n,t),e.extRef.jsObject.addPlanElementViewModel(n),this._plannerKernelCallbackListener.forEach(e=>e.addPlanObjectToScene(n))}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 n=t;let r;if(t.getType()===this._kernelContainer.PlanElementType.WALL?r=new Es(n):t.getType()===this._kernelContainer.PlanElementType.FLOOR?r=new Is(n):t.getType()===this._kernelContainer.PlanElementType.CEILING?r=new ks(n):t.getType()===this._kernelContainer.PlanElementType.NODE&&(r=new Ca(n)),!r)return;this.coupleReferences(r,n),e.extRef.jsObject.addPlanElementViewModel(r),r.setPrimaryColor(this._initData.colors.PRIMARY),this.planModelViewHelper.requestMesh3d(t),this._plannerKernelCallbackListener.forEach(e=>e.addPlanObjectToScene(null))}}planElementChanged(e,t){if(t.extRef){let n=t.extRef.jsObject;n.update(),this._plannerKernelCallbackListener.forEach(t=>t.planElementChanged(e,n))}}planHistoryStateChanged(){this.planInteractionHandler&&(this._plannerKernelCallbackListener.forEach(e=>e.planHistoryStateChanged()),this._roomlePlannerUiCallback.onHistoryChange(this.planInteractionHandler.isUndoPossible(),this.planInteractionHandler.isRedoPossible()))}planObjectConfigurationCreated(e,t){}planObjectConfigurationLoaded(e,t,n){e&&e.extRef&&t&&t.extRef&&t.extRef.jsObject.getPlanObject().getConfigurationRuntimeId()>0&&this._plannerKernelCallbackListener.forEach(r=>r.planObjectConfigurationLoaded(e,t,n))}requestCatalogItem(e){}startedDrawing(){this._plannerKernelCallbackListener.forEach(e=>e.startedDrawing())}stoppedDrawing(){this._plannerKernelCallbackListener.forEach(e=>e.stoppedDrawing())}updateMesh2d(){}beginConstruction(){}addMesh(e,t,n,r,i,s){this._plannerKernelCallbackListener.forEach(a=>a.addMesh(e,t,n,r,i,s))}endConstruction(){}beginPlanConstruction(e){this._plannerKernelCallbackListener.forEach(t=>t.beginPlanConstruction(e))}addPlanMesh(e,t,n,r,i,s,a){this._plannerKernelCallbackListener.forEach(o=>o.addPlanMesh(e,t,n,r,i,s,a))}endPlanConstruction(e){this._plannerKernelCallbackListener.forEach(t=>t.endPlanConstruction(e))}async addPlanObjectFromItem(e,t,n){if(!t&&!n){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]}n=n||0===n?n:0,t=t||{x:0,y:0,z:0};const r=this._planInteractionHandler.addPlanObjectFromItem(this._rapiItemToKernelItem(e),t,n,!1),i=this._planInteractionHandler.getPlan().extRef.jsObject;let s;return r.hasConfiguration()?(s=i.getConfigurablePlanObjectForId(r.getId()),s||console.warn("Could not find configuration")):(s=i.getStaticPlanObjectViewModelForId(r.getId()),s?await s.setRapiItem(e):console.warn("Could not find static item")),await s.isInitDone(),s.getId()}coupleReferences(e,t){let n=new this._kernelContainer.EMSReference;n.jsObject=e,t.extRef=n}_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",Ta),tn([rn],Ta.prototype,"_kernelAccessCallback",void 0),tn([rn],Ta.prototype,"_roomlePlannerUiCallback",void 0);class Aa extends is{constructor(e){super(e),this._wallMeshes=[],this._defaultMaterial=hr.createMeshPhysicalMaterial({color:"#ffffff",side:F})}generateGeometry(e=null,t,n,r,i,s=!1){let a;return a=s?this._generateGeometry(e,t,n,r,i).clone():this._generateGeometry(e,t,n,r,i),a}generateMesh(e=0,t=null,n,r,i,s,a,o,l=!1,h){let d;d=l?this._generateGeometry(t,r,i,s,a).clone():this._generateGeometry(t,r,i,s,a);const c=this._createMesh(e,t,d);return c.userData.materialId=n,c.layers.set(4),n&&this.setMaterial(c,n,o,h).then(()=>{e&&t&&n&&this._geometryComponentMaterialCache.set(this._getComponentMeshId(e,t),n);const r=o&&3===o.value,i=o&&1===o.value;c.castShadow=!r&&!i,c.userData.isFloor=r}),this._checkWallMaterial(c,o),c}async setMaterial(e,t,n,r){if(e.userData.materialId=Ki(t,n),Xe(t))t?await this._assignMaterial(e,t,r):(console.warn("Used default material because material is empty"),this.changeMaterialOfMesh(e,this._getDefaultMaterial(n)));else{if(!t)return void this.changeMaterialOfMesh(e,this._configuratorPreviewMaterial);2===(t=t).getSourceType().value?await this._assignMaterial(e,t.materialId,r):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(n)):(this.changeMaterialOfMesh(e,this._getDefaultMaterial(n)),1!==n.value&&7!==n.value&&3!==n.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=>{Hi(e)}),this._wallMeshes=[]}get wallMeshes(){return this._wallMeshes}}e("an",Aa);let Pa={InchFeet:null,Feet:null,MM:null,CM:null,Inch:null},Ra={NoUnitString:null,LongUnitString:null,ShortUnitString:null};const Ea=["mm","cm","feet"],Ia=["inch","inchfeet"];class ka{constructor(e){this._formatter=null,this._precision=0,this._creator_=e}init(e){const t=new e.UnitMeasureFormatter;Pa=e.Unit,Ra=e.UnitStringType,this._initActualUnit(),this._initMeasurementSystemType(),this._initActualUnitStringType();const{precisionCm:n,precisionInch:r}=this._initData;this._actualUnit===Pa.InchFeet?this._precision=void 0!==r?parseInt(r,10):2:this._actualUnit===Pa.CM&&(this._precision=void 0!==n?parseInt(n,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=Ea.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=Pa.CM,this._actualUnitString="cm")}if("imperial"===e){t||(t="inch");const e=Ia.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=Pa.Inch,this._actualUnitString="inch")}}else{this._actualUnitString=t;const e=Ea.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 Pa.CM;case"mm":return Pa.MM;case"inchfeet":return Pa.InchFeet;case"feet":return Pa.Feet;case"inch":return Pa.Inch;default:return Pa.CM}}_initActualUnitStringType(){const{unitStringType:e}=this._initData;e&&"short"!==e&&console.warn("Only short unit strings is supported at the moment"),this._actualUnitStringType=Ra.ShortUnitString}_isFormatterReady(){return!!this._formatter||(console.warn("Formatter is not ready..."),!1)}formatAngleValueToUnitString(e,t){const n="Integer"===t.type?0:2;return e.toFixed(n)+"°"}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),Hs(e))e.uiType="Material";else if(function(e){return"Boolean"===e.type}(e))e.uiType="Boolean";else if(Ns(e)){e.uiType="Range";const t=null!==e.validRange.valueFrom?e.validRange.valueFrom:Number.MIN_SAFE_INTEGER,n=null!==e.validRange.valueTo?e.validRange.valueTo:Number.MAX_SAFE_INTEGER;e.validRangeLabels={valueFrom:this._formatParameterValue(t.toString(),e.unitType),valueTo:this._formatParameterValue(n.toString(),e.unitType),type:e.validRange.type}}else zs(e)?(e.uiType="Options",function(e){return!!zs(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===Pa.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)}}tn([rn],ka.prototype,"_initData",void 0),tn([rn],ka.prototype,"_plannerKernelAccess",void 0);class Oa{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}}tn([rn],Oa.prototype,"_configuratorUiCallbacks",void 0),e("ae",{ADDED:"added",CHANGED:"changed",REMOVED:"removed"});class Da{constructor(e){this._kernelCallbacks={isReady:()=>{},throw:e=>console.error("Kernel exception",e),log:e=>{},error:(e,t,n,r)=>{},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?n()+"static/RoomleToolsCore-e914e875d1df9396.wasm":e,wasmBinaryFile:n()+"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 r=await window.RoomleToolsCore(t);r.setContext(this._kernelCallbacks),this._toolsCoreInstance=new r.ToolsCore}analyzeComponent(e,t){const n=[];return this._analyzeComponentCallback=e=>{n.push(e)},this._toolsCoreInstance.analyzeComponent(e,t),this._analyzeComponentCallback=null,Promise.resolve(n)}}tn([rn],Da.prototype,"_scriptLoader",void 0),tn([rn],Da.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 La=function(e){return URL.createObjectURL(new Blob([e],{type:"text/javascript"}))};try{URL.revokeObjectURL(La(""))}catch(e){La=function(e){return"data:application/javascript;charset=UTF-8,"+encodeURI(e)}}var Ua=Uint8Array,Fa=Uint16Array,Ba=Uint32Array,Na=new Ua([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]),za=new Ua([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]),Ha=new Ua([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),ja=function(e,t){for(var n=new Fa(31),r=0;r<31;++r)n[r]=t+=1<<e[r-1];var i=new Ba(n[30]);for(r=1;r<30;++r)for(var s=n[r];s<n[r+1];++s)i[s]=s-n[r]<<5|r;return[n,i]},Va=ja(Na,2),Ga=Va[0],Ka=Va[1];Ga[28]=258,Ka[258]=28;for(var Wa=ja(za,0)[0],Xa=new Fa(32768),qa=0;qa<32768;++qa){var Qa=(43690&qa)>>>1|(21845&qa)<<1;Qa=(61680&(Qa=(52428&Qa)>>>2|(13107&Qa)<<2))>>>4|(3855&Qa)<<4,Xa[qa]=((65280&Qa)>>>8|(255&Qa)<<8)>>>1}var Ya=function(e,t,n){for(var r=e.length,i=0,s=new Fa(t);i<r;++i)++s[e[i]-1];var a,o=new Fa(t);for(i=0;i<t;++i)o[i]=o[i-1]+s[i-1]<<1;if(n){a=new Fa(1<<t);var l=15-t;for(i=0;i<r;++i)if(e[i])for(var h=i<<4|e[i],d=t-e[i],c=o[e[i]-1]++<<d,u=c|(1<<d)-1;c<=u;++c)a[Xa[c]>>>l]=h}else for(a=new Fa(r),i=0;i<r;++i)e[i]&&(a[i]=Xa[o[e[i]-1]++]>>>15-e[i]);return a},Za=new Ua(288);for(qa=0;qa<144;++qa)Za[qa]=8;for(qa=144;qa<256;++qa)Za[qa]=9;for(qa=256;qa<280;++qa)Za[qa]=7;for(qa=280;qa<288;++qa)Za[qa]=8;var Ja=new Ua(32);for(qa=0;qa<32;++qa)Ja[qa]=5;var $a=Ya(Za,9,1),eo=Ya(Ja,5,1),to=function(e){for(var t=e[0],n=1;n<e.length;++n)e[n]>t&&(t=e[n]);return t},no=function(e,t,n){var r=t/8|0;return(e[r]|e[r+1]<<8)>>(7&t)&n},ro=function(e,t){var n=t/8|0;return(e[n]|e[n+1]<<8|e[n+2]<<16)>>(7&t)},io=new Ua(0);function so(e,t){return function(e,t,n){var r=e.length;if(!r||n&&!n.l&&r<5)return t||new Ua(0);var i=!t||n,s=!n||n.i;n||(n={}),t||(t=new Ua(3*r));var a,o=function(e){var n=t.length;if(e>n){var r=new Ua(Math.max(2*n,e));r.set(t),t=r}},l=n.f||0,h=n.p||0,d=n.b||0,c=n.l,u=n.d,p=n.m,m=n.n,f=8*r;do{if(!c){n.f=l=no(e,h,1);var g=no(e,h+1,3);if(h+=3,!g){var v=e[(P=((a=h)/8|0)+(7&a&&1)+4)-4]|e[P-3]<<8,w=P+v;if(w>r){if(s)throw"unexpected EOF";break}i&&o(d+v),t.set(e.subarray(P,w),d),n.b=d+=v,n.p=h=8*w;continue}if(1==g)c=$a,u=eo,p=9,m=5;else{if(2!=g)throw"invalid block type";var b=no(e,h,31)+257,_=no(e,h+10,15)+4,y=b+no(e,h+5,31)+1;h+=14;for(var x=new Ua(y),S=new Ua(19),C=0;C<_;++C)S[Ha[C]]=no(e,h+3*C,7);h+=3*_;var M=to(S),T=(1<<M)-1,A=Ya(S,M,1);for(C=0;C<y;){var P,R=A[no(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+no(e,h,3),h+=2,E=x[C-1]):17==P?(I=3+no(e,h,7),h+=3):18==P&&(I=11+no(e,h,127),h+=7);I--;)x[C++]=E}}var k=x.subarray(0,b),O=x.subarray(b);p=to(k),m=to(O),c=Ya(k,p,1),u=Ya(O,m,1)}if(h>f){if(s)throw"unexpected EOF";break}}i&&o(d+131072);for(var D=(1<<p)-1,L=(1<<m)-1,U=h;;U=h){var F=(E=c[ro(e,h)&D])>>>4;if((h+=15&E)>f){if(s)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=Na[C=F-257];B=no(e,h,(1<<N)-1)+Ga[C],h+=N}var z=u[ro(e,h)&L],H=z>>>4;if(!z)throw"invalid distance";if(h+=15&z,O=Wa[H],H>3&&(N=za[H],O+=ro(e,h)&(1<<N)-1,h+=N),h>f){if(s)throw"unexpected EOF";break}i&&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}}n.l=c,n.p=U,n.b=d,c&&(l=1,n.m=p,n.d=u,n.n=m)}while(!l);return d==t.length?t:function(e,t,n){(null==t||t<0)&&(t=0),(null==n||n>e.length)&&(n=e.length);var r=new(e instanceof Fa?Fa:e instanceof Ba?Ba:Ua)(n-t);return r.set(e.subarray(t,n)),r}(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 ao="undefined"!=typeof TextDecoder&&new TextDecoder;try{ao.decode(io,{stream:!0})}catch(e){}class oo extends qe{constructor(e){super(e),this.type=Qe}parse(e){const t=Math.pow(2.7182818,2.2),n={l:0,c:0,lc:0};function r(e,t,r,i,s){for(;r<e;)t=t<<8|D(i,s),r+=8;r-=e,n.l=t>>r&(1<<e)-1,n.c=t,n.lc=r}const i=new Array(59);function s(e){return 63&e}function a(e){return e>>6}const o={c:0,lc:0};function l(e,t,n,r){e=e<<8|D(n,r),t+=8,o.c=e,o.lc=t}const h={c:0,lc:0};function d(e,t,n,r,i,s,a,d,c){if(e==t){r<8&&(l(n,r,i,s),n=o.c,r=o.lc);let e=n>>(r-=8);if(e=new Uint8Array([e])[0],d.value+e>c)return!1;const t=a[d.value-1];for(;e-- >0;)a[d.value++]=t}else{if(!(d.value<c))return!1;a[d.value++]=e}h.c=n,h.lc=r}function c(e){return 65535&e}function u(e){const t=c(e);return t>32767?t-65536:t}const p={a:0,b:0};function m(e,t){const n=u(e),r=u(t),i=n+(1&r)+(r>>1),s=i,a=i-r;p.a=s,p.b=a}function f(e,t){const n=c(e),r=c(t),i=n-(r>>1)&65535,s=r+i-32768&65535;p.a=s,p.b=i}function g(e,t,n,r,i,s,a){const o=a<16384,l=n>i?i:n;let h,d,c=1;for(;c<=l;)c<<=1;for(c>>=1,h=c,c>>=1;c>=1;){d=0;const a=d+s*(i-h),l=s*c,u=s*h,g=r*c,v=r*h;let w,b,_,y;for(;d<=a;d+=u){let i=d;const s=d+r*(n-h);for(;i<=s;i+=v){const n=i+g,r=i+l,s=r+g;o?(m(e[i+t],e[r+t]),w=p.a,_=p.b,m(e[n+t],e[s+t]),b=p.a,y=p.b,m(w,b),e[i+t]=p.a,e[n+t]=p.b,m(_,y),e[r+t]=p.a,e[s+t]=p.b):(f(e[i+t],e[r+t]),w=p.a,_=p.b,f(e[n+t],e[s+t]),b=p.a,y=p.b,f(w,b),e[i+t]=p.a,e[n+t]=p.b,f(_,y),e[r+t]=p.a,e[s+t]=p.b)}if(n&c){const n=i+l;o?m(e[i+t],e[n+t]):f(e[i+t],e[n+t]),w=p.a,e[n+t]=p.b,e[i+t]=w}}if(i&c){let i=d;const s=d+r*(n-h);for(;i<=s;i+=v){const n=i+g;o?m(e[i+t],e[n+t]):f(e[i+t],e[n+t]),w=p.a,e[n+t]=p.b,e[i+t]=w}}h=c,c>>=1}return d}function v(e,t,c,u,p,m){const f=c.value,g=O(t,c),v=O(t,c);c.value+=4;const w=O(t,c);if(c.value+=4,g<0||g>=65537||v<0||v>=65537)throw new Error("Something wrong with HUF_ENCSIZE");const b=new Array(65537),_=new Array(16384);if(function(e){for(let t=0;t<16384;t++)e[t]={},e[t].len=0,e[t].lit=0,e[t].p=null}(_),function(e,t,s,a,o,l){const h=t;let d=0,c=0;for(;a<=o;a++){if(h.value-t.value>s)return!1;r(6,d,c,e,h);const i=n.l;if(d=n.c,c=n.lc,l[a]=i,63==i){if(h.value-t.value>s)throw new Error("Something wrong with hufUnpackEncTable");r(8,d,c,e,h);let i=n.l+6;if(d=n.c,c=n.lc,a+i>o+1)throw new Error("Something wrong with hufUnpackEncTable");for(;i--;)l[a++]=0;a--}else if(i>=59){let e=i-59+2;if(a+e>o+1)throw new Error("Something wrong with hufUnpackEncTable");for(;e--;)l[a++]=0;a--}}!function(e){for(let e=0;e<=58;++e)i[e]=0;for(let t=0;t<65537;++t)i[e[t]]+=1;let t=0;for(let e=58;e>0;--e){const n=t+i[e]>>1;i[e]=t,t=n}for(let t=0;t<65537;++t){const n=e[t];n>0&&(e[t]=n|i[n]++<<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,n,r){for(;t<=n;t++){const n=a(e[t]),i=s(e[t]);if(n>>i)throw new Error("Invalid table entry");if(i>14){const e=r[n>>i-14];if(e.len)throw new Error("Invalid table entry");if(e.lit++,e.p){const t=e.p;e.p=new Array(e.lit);for(let n=0;n<e.lit-1;++n)e.p[n]=t[n]}else e.p=new Array(1);e.p[e.lit-1]=t}else if(i){let e=0;for(let s=1<<14-i;s>0;s--){const s=r[(n<<14-i)+e];if(s.len||s.p)throw new Error("Invalid table entry");s.len=i,s.lit=t,e++}}}}(b,g,v,_),function(e,t,n,r,i,c,u,p,m){let f=0,g=0;const v=u,w=Math.trunc(r.value+(i+7)/8);for(;r.value<w;)for(l(f,g,n,r),f=o.c,g=o.lc;g>=14;){const i=t[f>>g-14&16383];if(i.len)g-=i.len,d(i.lit,c,f,g,n,r,p,m,v),f=h.c,g=h.lc;else{if(!i.p)throw new Error("hufDecode issues");let t;for(t=0;t<i.lit;t++){const u=s(e[i.p[t]]);for(;g<u&&r.value<w;)l(f,g,n,r),f=o.c,g=o.lc;if(g>=u&&a(e[i.p[t]])==(f>>g-u&(1<<u)-1)){g-=u,d(i.p[t],c,f,g,n,r,p,m,v),f=h.c,g=h.lc;break}}if(t==i.lit)throw new Error("hufDecode issues")}}const b=8-i&7;for(f>>=b,g-=b;g>0;){const e=t[f<<14-g&16383];if(!e.len)throw new Error("hufDecode issues");g-=e.len,d(e.lit,c,f,g,n,r,p,m,v),f=h.c,g=h.lc}}(b,_,e,c,w,v,m,p,{value:0})}function w(e){for(let t=1;t<e.length;t++){const n=e[t-1]+e[t]-128;e[t]=n}}function b(e,t){let n=0,r=Math.floor((e.length+1)/2),i=0;const s=e.length-1;for(;!(i>s||(t[i++]=e[n++],i>s));)t[i++]=e[r++]}function _(e){let t=e.byteLength;const n=new Array;let r=0;const i=new DataView(e);for(;t>0;){const e=i.getInt8(r++);if(e<0){const s=-e;t-=s+1;for(let e=0;e<s;e++)n.push(i.getUint8(r++))}else{const s=e;t-=2;const a=i.getUint8(r++);for(let e=0;e<s+1;e++)n.push(a)}}return n}function y(e,t,n){let r,i=1;for(;i<64;)r=t[e.value],65280==r?i=64:r>>8==255?i+=255&r:(n[i]=r,i++),e.value++}function x(e){const t=.5*Math.cos(.7853975),n=.5*Math.cos(3.14159/16),r=.5*Math.cos(3.14159/8),i=.5*Math.cos(3*3.14159/16),s=.5*Math.cos(.981746875),a=.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);for(let u=0;u<8;++u){const p=8*u;l[0]=r*e[p+2],l[1]=a*e[p+2],l[2]=r*e[p+6],l[3]=a*e[p+6],h[0]=n*e[p+1]+i*e[p+3]+s*e[p+5]+o*e[p+7],h[1]=i*e[p+1]-o*e[p+3]-n*e[p+5]-s*e[p+7],h[2]=s*e[p+1]-n*e[p+3]+o*e[p+5]+i*e[p+7],h[3]=o*e[p+1]-s*e[p+3]+i*e[p+5]-n*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(let u=0;u<8;++u)l[0]=r*e[16+u],l[1]=a*e[16+u],l[2]=r*e[48+u],l[3]=a*e[48+u],h[0]=n*e[8+u]+i*e[24+u]+s*e[40+u]+o*e[56+u],h[1]=i*e[8+u]-o*e[24+u]-n*e[40+u]-s*e[56+u],h[2]=s*e[8+u]-n*e[24+u]+o*e[40+u]+i*e[56+u],h[3]=o*e[8+u]-s*e[24+u]+i*e[40+u]-n*e[56+u],d[0]=t*(e[u]+e[32+u]),d[3]=t*(e[u]-e[32+u]),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+u]=c[0]+h[0],e[8+u]=c[1]+h[1],e[16+u]=c[2]+h[2],e[24+u]=c[3]+h[3],e[32+u]=c[3]-h[3],e[40+u]=c[2]-h[2],e[48+u]=c[1]-h[1],e[56+u]=c[0]-h[0]}function S(e){for(let t=0;t<64;++t){const n=e[0][t],r=e[1][t],i=e[2][t];e[0][t]=n+1.5747*i,e[1][t]=n-.1873*r-.4682*i,e[2][t]=n+1.8556*r}}function C(e,n,r){for(let s=0;s<64;++s)n[r+s]=$e.toHalfFloat((i=e[s])<=1?Math.sign(i)*Math.pow(Math.abs(i),2.2):Math.sign(i)*Math.pow(t,Math.abs(i)-1));var i}function M(e){return new DataView(e.array.buffer,e.offset.value,e.size)}function T(e){const t=e.viewer.buffer.slice(e.offset.value,e.offset.value+e.size),n=new Uint8Array(_(t)),r=new Uint8Array(n.length);return w(n),b(n,r),new DataView(r.buffer)}function A(e){const t=so(e.array.slice(e.offset.value,e.offset.value+e.size)),n=new Uint8Array(t.length);return w(t),b(t,n),new DataView(n.buffer)}function P(e){const t=e.viewer,n={value:e.offset.value},r=new Uint16Array(e.width*e.scanlineBlockSize*(e.channels*e.type)),i=new Uint8Array(8192);let s=0;const a=new Array(e.channels);for(let t=0;t<e.channels;t++)a[t]={},a[t].start=s,a[t].end=a[t].start,a[t].nx=e.width,a[t].ny=e.lines,a[t].size=e.type,s+=a[t].nx*a[t].ny*a[t].size;const o=z(t,n),l=z(t,n);if(l>=8192)throw new Error("Something is wrong with PIZ_COMPRESSION BITMAP_SIZE");if(o<=l)for(let e=0;e<l-o+1;e++)i[e+o]=L(t,n);const h=new Uint16Array(65536),d=function(e,t){let n=0;for(let r=0;r<65536;++r)(0==r||e[r>>3]&1<<(7&r))&&(t[n++]=r);const r=n-1;for(;n<65536;)t[n++]=0;return r}(i,h),c=O(t,n);v(e.array,t,n,c,r,s);for(let t=0;t<e.channels;++t){const e=a[t];for(let n=0;n<a[t].size;++n)g(r,e.start+n,e.nx,e.size,e.ny,e.nx*e.size,d)}!function(e,t,n){for(let r=0;r<n;++r)t[r]=e[t[r]]}(h,r,s);let u=0;const p=new Uint8Array(r.buffer.byteLength);for(let t=0;t<e.lines;t++)for(let t=0;t<e.channels;t++){const e=a[t],n=e.nx*e.size,i=new Uint8Array(r.buffer,2*e.end,2*n);p.set(i,u),u+=2*n,e.end+=n}return new DataView(p.buffer)}function R(e){const t=so(e.array.slice(e.offset.value,e.offset.value+e.size)),n=e.lines*e.channels*e.width,r=1==e.type?new Uint16Array(n):new Uint32Array(n);let i=0,s=0;const a=new Array(4);for(let n=0;n<e.lines;n++)for(let n=0;n<e.channels;n++){let n=0;switch(e.type){case 1:a[0]=i,a[1]=a[0]+e.width,i=a[1]+e.width;for(let i=0;i<e.width;++i)n+=t[a[0]++]<<8|t[a[1]++],r[s]=n,s++;break;case 2:a[0]=i,a[1]=a[0]+e.width,a[2]=a[1]+e.width,i=a[2]+e.width;for(let i=0;i<e.width;++i)n+=t[a[0]++]<<24|t[a[1]++]<<16|t[a[2]++]<<8,r[s]=n,s++}}return new DataView(r.buffer)}function E(e){const t=e.viewer,n={value:e.offset.value},r=new Uint8Array(e.width*e.lines*(e.channels*e.type*2)),i={version:U(t,n),unknownUncompressedSize:U(t,n),unknownCompressedSize:U(t,n),acCompressedSize:U(t,n),dcCompressedSize:U(t,n),rleCompressedSize:U(t,n),rleUncompressedSize:U(t,n),rleRawSize:U(t,n),totalAcUncompressedCount:U(t,n),totalDcUncompressedCount:U(t,n),acCompression:U(t,n)};if(i.version<2)throw new Error("EXRLoader.parse: "+W.compression+" version "+i.version+" is unsupported");const s=new Array;let a=z(t,n)-2;for(;a>0;){const e=I(t.buffer,n),r=L(t,n),i=r>>2&3,o=new Int8Array([(r>>4)-1])[0],l=L(t,n);s.push({name:e,index:o,type:l,compression:i}),a-=e.length+3}const o=W.channels,l=new Array(e.channels);for(let t=0;t<e.channels;++t){const n=l[t]={},r=o[t];n.name=r.name,n.compression=0,n.decoded=!1,n.type=r.pixelType,n.pLinear=r.pLinear,n.width=e.width,n.height=e.lines}const h={idx:new Array(3)};for(let t=0;t<e.channels;++t){const e=l[t];for(let n=0;n<s.length;++n){const r=s[n];e.name==r.name&&(e.compression=r.compression,r.index>=0&&(h.idx[r.index]=t),e.offset=t)}}let d,c,u;if(i.acCompressedSize>0)switch(i.acCompression){case 0:d=new Uint16Array(i.totalAcUncompressedCount),v(e.array,t,n,i.acCompressedSize,d,i.totalAcUncompressedCount);break;case 1:const r=so(e.array.slice(n.value,n.value+i.totalAcUncompressedCount));d=new Uint16Array(r.buffer),n.value+=i.totalAcUncompressedCount}if(i.dcCompressedSize>0){const t={array:e.array,offset:n,size:i.dcCompressedSize};c=new Uint16Array(A(t).buffer),n.value+=i.dcCompressedSize}i.rleRawSize>0&&(u=_(so(e.array.slice(n.value,n.value+i.rleCompressedSize)).buffer),n.value+=i.rleCompressedSize);let p=0;const m=new Array(l.length);for(let e=0;e<m.length;++e)m[e]=new Array;for(let t=0;t<e.lines;++t)for(let t=0;t<l.length;++t)m[t].push(p),p+=l[t].width*e.type*2;!function(e,t,n,r,i,s){let a=new DataView(s.buffer);const o=n[e.idx[0]].width,l=n[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);for(let n=0;n<3;++n)b[n]=t[e.idx[n]],f[n]=n<1?0:f[n-1]+d*c,g[n]=new Float32Array(64),v[n]=new Uint16Array(64),w[n]=new Uint16Array(64*d);for(let t=0;t<c;++t){let s=8;t==c-1&&(s=p);let o=8;for(let e=0;e<d;++e){e==d-1&&(o=u);for(let e=0;e<3;++e)v[e].fill(0),v[e][0]=i[f[e]++],y(m,r,v[e]),_=v[e],(M=g[e])[0]=N(_[0]),M[1]=N(_[1]),M[2]=N(_[5]),M[3]=N(_[6]),M[4]=N(_[14]),M[5]=N(_[15]),M[6]=N(_[27]),M[7]=N(_[28]),M[8]=N(_[2]),M[9]=N(_[4]),M[10]=N(_[7]),M[11]=N(_[13]),M[12]=N(_[16]),M[13]=N(_[26]),M[14]=N(_[29]),M[15]=N(_[42]),M[16]=N(_[3]),M[17]=N(_[8]),M[18]=N(_[12]),M[19]=N(_[17]),M[20]=N(_[25]),M[21]=N(_[30]),M[22]=N(_[41]),M[23]=N(_[43]),M[24]=N(_[9]),M[25]=N(_[11]),M[26]=N(_[18]),M[27]=N(_[24]),M[28]=N(_[31]),M[29]=N(_[40]),M[30]=N(_[44]),M[31]=N(_[53]),M[32]=N(_[10]),M[33]=N(_[19]),M[34]=N(_[23]),M[35]=N(_[32]),M[36]=N(_[39]),M[37]=N(_[45]),M[38]=N(_[52]),M[39]=N(_[54]),M[40]=N(_[20]),M[41]=N(_[22]),M[42]=N(_[33]),M[43]=N(_[38]),M[44]=N(_[46]),M[45]=N(_[51]),M[46]=N(_[55]),M[47]=N(_[60]),M[48]=N(_[21]),M[49]=N(_[34]),M[50]=N(_[37]),M[51]=N(_[47]),M[52]=N(_[50]),M[53]=N(_[56]),M[54]=N(_[59]),M[55]=N(_[61]),M[56]=N(_[35]),M[57]=N(_[36]),M[58]=N(_[48]),M[59]=N(_[49]),M[60]=N(_[57]),M[61]=N(_[58]),M[62]=N(_[62]),M[63]=N(_[63]),x(g[e]);S(g);for(let t=0;t<3;++t)C(g[t],w[t],64*e)}let l=0;for(let r=0;r<3;++r){const i=n[e.idx[r]].type;for(let e=8*t;e<8*t+s;++e){l=b[r][e];for(let t=0;t<h;++t){const n=64*t+8*(7&e);a.setUint16(l+0*i,w[r][n+0],!0),a.setUint16(l+2*i,w[r][n+1],!0),a.setUint16(l+4*i,w[r][n+2],!0),a.setUint16(l+6*i,w[r][n+3],!0),a.setUint16(l+8*i,w[r][n+4],!0),a.setUint16(l+10*i,w[r][n+5],!0),a.setUint16(l+12*i,w[r][n+6],!0),a.setUint16(l+14*i,w[r][n+7],!0),l+=16*i}}if(h!=d)for(let e=8*t;e<8*t+s;++e){const t=b[r][e]+8*h*2*i,n=64*h+8*(7&e);for(let e=0;e<o;++e)a.setUint16(t+2*e*i,w[r][n+e],!0)}}}var _,M;const T=new Uint16Array(o);a=new DataView(s.buffer);for(let t=0;t<3;++t){n[e.idx[t]].decoded=!0;const r=n[e.idx[t]].type;if(2==n[t].type)for(let e=0;e<l;++e){const n=b[t][e];for(let e=0;e<o;++e)T[e]=a.getUint16(n+2*e*r,!0);for(let e=0;e<o;++e)a.setFloat32(n+2*e*r,N(T[e]),!0)}}}(h,m,l,d,c,r);for(let t=0;t<l.length;++t){const n=l[t];if(!n.decoded)switch(n.compression){case 2:let i=0,s=0;for(let a=0;a<e.lines;++a){let e=m[t][i];for(let t=0;t<n.width;++t){for(let t=0;t<2*n.type;++t)r[e++]=u[s+t*n.width*n.height];s++}i++}break;case 1:default:throw new Error("EXRLoader.parse: unsupported channel compression")}}return new DataView(r.buffer)}function I(e,t){const n=new Uint8Array(e);let r=0;for(;0!=n[t.value+r];)r+=1;const i=(new TextDecoder).decode(n.slice(t.value,t.value+r));return t.value=t.value+r+1,i}function k(e,t){const n=e.getInt32(t.value,!0);return t.value=t.value+4,n}function O(e,t){const n=e.getUint32(t.value,!0);return t.value=t.value+4,n}function D(e,t){const n=e[t.value];return t.value=t.value+1,n}function L(e,t){const n=e.getUint8(t.value);return t.value=t.value+1,n}const U=function(e,t){let n;return n="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,n};function F(e,t){const n=e.getFloat32(t.value,!0);return t.value+=4,n}function B(e,t){return $e.toHalfFloat(F(e,t))}function N(e){const t=(31744&e)>>10,n=1023&e;return(e>>15?-1:1)*(t?31===t?n?NaN:1/0:Math.pow(2,t-15)*(1+n/1024):n/1024*6103515625e-14)}function z(e,t){const n=e.getUint16(t.value,!0);return t.value+=2,n}function H(e,t){return N(z(e,t))}function j(e,t,n,r,i){return"string"===r||"stringvector"===r||"iccProfile"===r?function(e,t,n){const r=(new TextDecoder).decode(new Uint8Array(e).slice(t.value,t.value+n));return t.value=t.value+n,r}(t,n,i):"chlist"===r?function(e,t,n,r){const i=n.value,s=[];for(;n.value<i+r-1;){const r=I(t,n),i=k(e,n),a=L(e,n);n.value+=3;const o=k(e,n),l=k(e,n);s.push({name:r,pixelType:i,pLinear:a,xSampling:o,ySampling:l})}return n.value+=1,s}(e,t,n,i):"chromaticities"===r?function(e,t){return{redX:F(e,t),redY:F(e,t),greenX:F(e,t),greenY:F(e,t),blueX:F(e,t),blueY:F(e,t),whiteX:F(e,t),whiteY:F(e,t)}}(e,n):"compression"===r?function(e,t){return["NO_COMPRESSION","RLE_COMPRESSION","ZIPS_COMPRESSION","ZIP_COMPRESSION","PIZ_COMPRESSION","PXR24_COMPRESSION","B44_COMPRESSION","B44A_COMPRESSION","DWAA_COMPRESSION","DWAB_COMPRESSION"][L(e,t)]}(e,n):"box2i"===r?function(e,t){return{xMin:O(e,t),yMin:O(e,t),xMax:O(e,t),yMax:O(e,t)}}(e,n):"lineOrder"===r?function(e,t){return["INCREASING_Y"][L(e,t)]}(e,n):"float"===r?F(e,n):"v2f"===r?function(e,t){return[F(e,t),F(e,t)]}(e,n):"v3f"===r?function(e,t){return[F(e,t),F(e,t),F(e,t)]}(e,n):"int"===r?k(e,n):"rational"===r?function(e,t){return[k(e,t),O(e,t)]}(e,n):"timecode"===r?function(e,t){return[O(e,t),O(e,t)]}(e,n):"preview"===r?(n.value+=i,"skipped"):void(n.value+=i)}const V=new DataView(e),G=new Uint8Array(e),K={value:0},W=function(e,t,n){const r={};if(20000630!=e.getUint32(0,!0))throw new Error("THREE.EXRLoader: provided file doesn't appear to be in OpenEXR format.");r.version=e.getUint8(4);const i=e.getUint8(5);r.spec={singleTile:!!(2&i),longName:!!(4&i),deepFormat:!!(8&i),multiPart:!!(16&i)},n.value=8;let s=!0;for(;s;){const i=I(t,n);if(0==i)s=!1;else{const s=I(t,n),a=j(e,t,n,s,O(e,n));void 0===a?console.warn(`EXRLoader.parse: skipped unknown header attribute type '${s}'.`):r[i]=a}}if(0!=(-5&i))throw console.error("EXRHeader:",r),new Error("THREE.EXRLoader: provided file is currently unsupported.");return r}(V,e,K),X=function(e,t,n,r,i){const s={size:0,viewer:t,array:n,offset:r,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:fe};switch(e.compression){case"NO_COMPRESSION":s.lines=1,s.uncompress=M;break;case"RLE_COMPRESSION":s.lines=1,s.uncompress=T;break;case"ZIPS_COMPRESSION":s.lines=1,s.uncompress=A;break;case"ZIP_COMPRESSION":s.lines=16,s.uncompress=A;break;case"PIZ_COMPRESSION":s.lines=32,s.uncompress=P;break;case"PXR24_COMPRESSION":s.lines=16,s.uncompress=R;break;case"DWAA_COMPRESSION":s.lines=32,s.uncompress=E;break;case"DWAB_COMPRESSION":s.lines=256,s.uncompress=E;break;default:throw new Error("EXRLoader.parse: "+e.compression+" is unsupported")}if(s.scanlineBlockSize=s.lines,1==s.type)switch(i){case Ye:s.getter=H,s.inputSize=2;break;case Qe:s.getter=z,s.inputSize=2}else{if(2!=s.type)throw new Error("EXRLoader.parse: unsupported pixelType "+s.type+" for "+e.compression+".");switch(i){case Ye:s.getter=F,s.inputSize=4;break;case Qe:s.getter=B,s.inputSize=4}}s.blockCount=(e.dataWindow.yMax+1)/s.scanlineBlockSize;for(let e=0;e<s.blockCount;e++)U(t,r);s.outputChannels=3==s.channels?4:s.channels;const a=s.width*s.height*s.outputChannels;switch(i){case Ye:s.byteArray=new Float32Array(a),s.channels<s.outputChannels&&s.byteArray.fill(1,0,a);break;case Qe:s.byteArray=new Uint16Array(a),s.channels<s.outputChannels&&s.byteArray.fill(15360,0,a);break;default:console.error("THREE.EXRLoader: unsupported type: ",i)}return s.bytesPerLine=s.width*s.inputSize*s.channels,4==s.outputChannels?(s.format=we,s.colorSpace=fe):(s.format=Ze,s.colorSpace=Je),s}(W,V,G,K,this.type),q={value:0},Q={R:0,G:1,B:2,A:3,Y:0};for(let e=0;e<X.height/X.scanlineBlockSize;e++){const t=O(V,K);X.size=O(V,K),X.lines=t+X.scanlineBlockSize>X.height?X.height-t:X.scanlineBlockSize;const n=X.size<X.lines*X.bytesPerLine?X.uncompress(X):M(X);K.value+=X.size;for(let t=0;t<X.scanlineBlockSize;t++){const r=t+e*X.scanlineBlockSize;if(r>=X.height)break;for(let e=0;e<X.channels;e++){const i=Q[W.channels[e].name];for(let s=0;s<X.width;s++){q.value=(t*(X.channels*X.width)+e*X.width+s)*X.inputSize;const a=(X.height-1-r)*(X.width*X.outputChannels)+s*X.outputChannels+i;X.byteArray[a]=X.getter(n,q)}}}}return{header:W,width:X.width,height:X.height,data:X.byteArray,format:X.format,colorSpace:X.colorSpace,type:this.type}}setDataType(e){return this.type=e,this}load(e,t,n,r){return super.load(e,(function(e,n){e.colorSpace=n.colorSpace,e.minFilter=E,e.magFilter=E,e.generateMipmaps=!1,e.flipY=!1,t&&t(e,n)}),n,r)}}class lo extends qe{constructor(e){super(e),this.type=Qe}parse(e){const 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},n=function(e,t,n){t=t||1024;let r=e.pos,i=-1,s=0,a="",o=String.fromCharCode.apply(null,new Uint16Array(e.subarray(r,r+128)));for(;0>(i=o.indexOf("\n"))&&s<t&&r<e.byteLength;)a+=o,s+=o.length,r+=128,o+=String.fromCharCode.apply(null,new Uint16Array(e.subarray(r,r+128)));return-1<i&&(!1!==n&&(e.pos+=s+i+1),a+o.slice(0,i))},r=function(e,t,n,r){const i=e[t+3],s=Math.pow(2,i-128)/255;n[r+0]=e[t+0]*s,n[r+1]=e[t+1]*s,n[r+2]=e[t+2]*s,n[r+3]=1},i=function(e,t,n,r){const i=e[t+3],s=Math.pow(2,i-128)/255;n[r+0]=$e.toHalfFloat(Math.min(e[t+0]*s,65504)),n[r+1]=$e.toHalfFloat(Math.min(e[t+1]*s,65504)),n[r+2]=$e.toHalfFloat(Math.min(e[t+2]*s,65504)),n[r+3]=$e.toHalfFloat(1)},s=new Uint8Array(e);s.pos=0;const a=function(e){const r=/^\s*GAMMA\s*=\s*(\d+(\.\d+)?)\s*$/,i=/^\s*EXPOSURE\s*=\s*(\d+(\.\d+)?)\s*$/,s=/^\s*FORMAT=(\S+)\s*$/,a=/^\s*\-Y\s+(\d+)\s+\+X\s+(\d+)\s*$/,o={valid:0,string:"",comments:"",programtype:"RGBE",format:"",gamma:1,exposure:1,width:0,height:0};let l,h;if(e.pos>=e.byteLength||!(l=n(e)))return t(1,"no header found");if(!(h=l.match(/^#\?(\S+)/)))return t(3,"bad initial token");for(o.valid|=1,o.programtype=h[1],o.string+=l+"\n";l=n(e),!1!==l;)if(o.string+=l+"\n","#"!==l.charAt(0)){if((h=l.match(r))&&(o.gamma=parseFloat(h[1])),(h=l.match(i))&&(o.exposure=parseFloat(h[1])),(h=l.match(s))&&(o.valid|=2,o.format=h[1]),(h=l.match(a))&&(o.valid|=4,o.height=parseInt(h[1],10),o.width=parseInt(h[2],10)),2&o.valid&&4&o.valid)break}else o.comments+=l+"\n";return 2&o.valid?4&o.valid?o:t(3,"missing image size specifier"):t(3,"missing format specifier")}(s);if(-1!==a){const e=a.width,n=a.height,o=function(e,n,r){const i=n;if(i<8||i>32767||2!==e[0]||2!==e[1]||128&e[2])return new Uint8Array(e);if(i!==(e[2]<<8|e[3]))return t(3,"wrong scanline width");const s=new Uint8Array(4*n*r);if(!s.length)return t(4,"unable to allocate buffer space");let a=0,o=0;const l=4*i,h=new Uint8Array(4),d=new Uint8Array(l);let c=r;for(;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])!=i)return t(3,"bad rgbe scanline format");let n,r=0;for(;r<l&&o<e.byteLength;){n=e[o++];const i=n>128;if(i&&(n-=128),0===n||r+n>l)return t(3,"bad scanline data");if(i){const t=e[o++];for(let e=0;e<n;e++)d[r++]=t}else d.set(e.subarray(o,o+n),r),r+=n,o+=n}const u=i;for(let e=0;e<u;e++){let t=0;s[a]=d[e+t],t+=i,s[a+1]=d[e+t],t+=i,s[a+2]=d[e+t],t+=i,s[a+3]=d[e+t],a+=4}c--}return s}(s.subarray(s.pos),e,n);if(-1!==o){let t,s,l;switch(this.type){case Ye:l=o.length/4;const e=new Float32Array(4*l);for(let t=0;t<l;t++)r(o,4*t,e,4*t);t=e,s=Ye;break;case Qe:l=o.length/4;const n=new Uint16Array(4*l);for(let e=0;e<l;e++)i(o,4*e,n,4*e);t=n,s=Qe;break;default:console.error("THREE.RGBELoader: unsupported type: ",this.type)}return{width:e,height:n,data:t,header:a.string,gamma:a.gamma,exposure:a.exposure,type:s}}}return null}setDataType(e){return this.type=e,this}load(e,t,n,r){return super.load(e,(function(e,n){switch(e.type){case Ye:case Qe:e.colorSpace=fe,e.minFilter=E,e.magFilter=E,e.generateMipmaps=!1,e.flipY=!0}t&&t(e,n)}),n,r)}}const ho={uniforms:{tDiffuse:{value:null},colorTransform:{value:new S},colorBase:{value:new tt(0,0,0,0)},multiplyChannels:{value:0},uvTransform:{value:new nt}},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 S,uo=(new S).set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,0),po=(new S).set(0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0),mo=(new S).set(1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1),fo=(new S).set(1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1),go=new tt(0,0,0,0),vo=new tt(0,0,0,1),wo=new nt,bo=(new nt).set(1,0,0,0,-1,1,0,0,1);var _o;!function(e){e[e.DEFAULT=0]="DEFAULT",e[e.ADDITIVE=1]="ADDITIVE"}(_o||(_o={}));class yo extends rt{constructor(e,t=_o.ADDITIVE){const n=t===_o.ADDITIVE?{blendSrc:it,blendDst:st,blendEquation:at,blendSrcAlpha:ot,blendDstAlpha:st,blendEquationAlpha:at}:{};super({uniforms:lt.clone(ho.uniforms),vertexShader:ho.vertexShader,fragmentShader:ho.fragmentShader,transparent:!0,depthTest:!1,depthWrite:!1,...n}),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 xo={uniforms:{tDiffuse:{value:null},rangeMin:{value:new s(1/512,1/512)},rangeMax:{value:new s(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 s(.1,.9),new s(.1,.9);class So extends rt{constructor(e){super({defines:Object.assign({},So.linearDepthShader.defines),uniforms:lt.clone(So.linearDepthShader.uniforms),vertexShader:So.linearDepthShader.vertexShader,fragmentShader:So.linearDepthShader.fragmentShader,blending:ht}),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}}So.linearDepthShader={uniforms:{tDepth:{value:null},depthFilter:{value:new tt(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 Co extends rt{constructor(e){var t;super({defines:Object.assign({...Co.normalAndDepthShader.defines,FLOAT_BUFFER:(null==e?void 0:e.floatBufferType)?1:0,LINEAR_DEPTH:(null==e?void 0:e.linearDepth)?1:0}),uniforms:lt.clone(Co.normalAndDepthShader.uniforms),vertexShader:Co.normalAndDepthShader.vertexShader,fragmentShader:Co.normalAndDepthShader.fragmentShader,blending:null!==(t=null==e?void 0:e.blending)&&void 0!==t?t:ht}),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}}Co.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 }"};const Mo=new q(-1,1,1,-1,0,1),To=new c;To.setAttribute("position",new Te([-1,3,0,-1,-1,0,3,-1,0],3)),To.setAttribute("uv",new Te([0,2,0,0,2,0],2));class Ao{constructor(e){this._mesh=new z(To,e)}dispose(){this._mesh.geometry.dispose()}render(e){e.render(this._mesh,Mo)}get material(){return this._mesh.material}set material(e){this._mesh.material=e}}new A;class Po{constructor(){this.bounds=new ue(new a(-1,-1,-1),new a(1,1,1)),this.size=new a(2,2,2),this.center=new a(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 a(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 q?((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 W&&((e,t)=>{const n=Math.min(-t.min.z,-t.max.z),r=Math.max(-t.min.z,-t.max.z);if(n<.001)return;const i=Math.max(Math.abs(t.min.x),Math.abs(t.max.x)),s=Math.max(Math.abs(t.min.y),Math.abs(t.max.y));e.aspect=i/s,e.fov=X.radToDeg(2*Math.atan2(s,n)),e.near=n,e.far=r,e.updateProjectionMatrix()})(e,t)}getNearAndFarForPerspectiveCamera(e,t=1){const n=e.clone().sub(this.center).length();return[Math.max(.01,n-this.maxSceneDistanceFromCenter-.01),n+this.maxSceneDistanceFromCenter*t+.01]}}class Ro{changed(e){var t,n;const r=!(null===(t=this.lastCameraProjection)||void 0===t?void 0:t.equals(e.projectionMatrix))||!(null===(n=this.lastCameraWorld)||void 0===n?void 0:n.equals(e.matrixWorld));return this.lastCameraProjection=e.projectionMatrix.clone(),this.lastCameraWorld=e.matrixWorld.clone(),r}}class Eo{constructor(e,t,n){this._visibilityCache=new Map,this.background=n,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 n=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=n)}}class Io{constructor(){this.originalClearColor=new h,this.originalClearAlpha=0,this.originalAutoClear=!1,this.originalRenderTarget=null,this.screenSpaceQuad=new Ao(void 0)}renderWithOverrideMaterial(e,t,n,r,i,s,a){this.backup(e),this.prepareRenderer(e,i,s,a);const o=t.overrideMaterial;t.overrideMaterial=r,e.render(t,n),t.overrideMaterial=o,this.restore(e)}render(e,t,n,r,i,s){this.backup(e),this.prepareRenderer(e,r,i,s),e.render(t,n),this.restore(e)}renderScreenSpace(e,t,n,r,i){this.backup(e),this.prepareRenderer(e,n,r,i),this.screenSpaceQuad.material=t,this.screenSpaceQuad.render(e),this.restore(e)}prepareRenderer(e,t,n,r){e.setRenderTarget(t),e.autoClear=!1,null!=n&&(e.setClearColor(n),e.setClearAlpha(r||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 ko{constructor(e,t){var n;this.renderPass=null!==(n=null==t?void 0:t.renderPass)&&void 0!==n?n:new Io,this.blurMaterial=new rt(null!=e?e:xo),this.blurMaterial.depthTest=!1}dispose(){this.blurMaterial.dispose()}render(e,t,n,r){this.blurMaterial.uniforms.tDiffuse.value=t[0].texture,this.blurMaterial.uniforms.rangeMin.value.x=n[0],this.blurMaterial.uniforms.rangeMin.value.y=0,this.blurMaterial.uniforms.rangeMax.value.x=r[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=n[1],this.blurMaterial.uniforms.rangeMax.value.x=0,this.blurMaterial.uniforms.rangeMax.value.y=r[1],this.renderPass.renderScreenSpace(e,this.blurMaterial,t[2])}}e("a6",(e,t)=>{e.traverse(e=>{if(e instanceof z){const n=e.material;n&&(n.envMapIntensity=t)}})});class Oo{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 Co({blending:ht,floatBufferType:!0,linearDepth:!1}):new dt({blending:ht}),this._normalRenderMaterial}get depthNormalRenderTarget(){if(!this._depthNormalRenderTarget)if(this.floatGBufferRgbNormalAlphaDepth)this._depthNormalRenderTarget=new ct(this.width*this.parameters.depthNormalScale,this.height*this.parameters.depthNormalScale,{minFilter:this.targetMinificationTextureFilter,magFilter:this.targetMagnificationTextureFilter,type:Ye,samples:this.samples});else{const e=new ut(this.width*this.parameters.depthNormalScale,this.height*this.parameters.depthNormalScale);e.format=pt,e.type=mt,this._depthNormalRenderTarget=new ct(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 ct(this.width*this.parameters.depthNormalScale,this.height*this.parameters.depthNormalScale,{minFilter:this.targetMinificationTextureFilter,magFilter:this.targetMagnificationTextureFilter,type:Ye,samples:0})),this._separateDeptRenderTarget}constructor(e){var t,n,r,i,s,a,o,l,h,d,c;this.floatGBufferRgbNormalAlphaDepth=!1,this.copyToSeparateDepthBuffer=!1,this.needsUpdate=!0,this.floatGBufferRgbNormalAlphaDepth=null!==(n=null===(t=null==e?void 0:e.capabilities)||void 0===t?void 0:t.isWebGL2)&&void 0!==n&&n,this.parameters={depthNormalScale:null!==(r=null==e?void 0:e.depthNormalScale)&&void 0!==r?r:1},this.targetMinificationTextureFilter=null!==(i=null==e?void 0:e.textureMinificationFilter)&&void 0!==i?i:$,this.targetMagnificationTextureFilter=null!==(s=null==e?void 0:e.textureMagnificationFilter)&&void 0!==s?s:$,this.width=null!==(a=null==e?void 0:e.width)&&void 0!==a?a: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 Io,this.renderOverrideVisibility=null!==(c=null==e?void 0:e.renderOverrideVisibility)&&void 0!==c?c:new Eo(!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 x)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 n;this.width=e,this.height=t,null===(n=this._depthNormalRenderTarget)||void 0===n||n.setSize(this.width*this.parameters.depthNormalScale,this.height*this.parameters.depthNormalScale)}render(e,t,n){if(this.shared&&!this.needsUpdate)return;this.needsUpdate=!1;const r=this.normalRenderMaterial;r instanceof Co&&r.update({camera:n}),this.renderOverrideVisibility.render(t,()=>{this.renderPass.renderWithOverrideMaterial(e,t,n,r,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 yo),this.copyMaterial.update(e)}copyDepthToSeparateDepthTexture(e,t){this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:t.texture,blending:ht,colorTransform:po,colorBase:vo,multiplyChannels:0,uvTransform:wo}),this.separateDeptRenderTarget)}}class Do{constructor(e,t,n){var r;this.needsUpdate=!0,this.noNeedOfUpdateCount=0,this.blurScale=1,this.shadowScale=1,this.renderOverrideVisibility=new Eo(!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 n=e.material;return!n.transparent||n.opacity>.5})(e)||void 0!==e.name&&["Ground","Floor"].includes(e.name)),this.groundGroup=t,this.shadowMapSize=null!==(r=n.shadowMapSize)&&void 0!==r?r:1024,this.parameters=this.getDefaultParameters(n),this.groundShadowFar=this.parameters.cameraFar,this.renderer=e,this.renderTarget=new ct(this.shadowMapSize,this.shadowMapSize),this.renderTarget.texture.generateMipmaps=!1,this.renderTargetBlur=new ct(this.shadowMapSize,this.shadowMapSize),this.renderTargetBlur.texture.generateMipmaps=!1,this.shadowGroundPlane=new Lo(this.renderTarget.texture,this.parameters),this.groundGroup.add(this.shadowGroundPlane),this.groundContactCamera=new Uo,this.groundGroup.add(this.groundContactCamera),this.depthMaterial=new vt,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 );",Lo.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=F,this.depthMaterial.depthTest=!0,this.depthMaterial.depthWrite=!0,this.blurPass=new ko(xo,n),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 n;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 r=Math.max(e.size.x,e.size.z);this.parameters.planeSize=r+2*Math.max(this.blurScale,null!==(n=this.shadowScale)&&void 0!==n?n: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 n=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(n),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])}}Do.addTestMesh=!1;class Lo extends z{constructor(e,t){const n=new _({transparent:!0,depthWrite:!1});Lo.alphaMap&&n.color.set(0),n.polygonOffset=!0,super(new ft(1,1,10,10),n),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,Lo.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()}}Lo.alphaMap=!1;class Uo extends q{constructor(){super(-1,1,-1,1,-1,1),this.rotation.x=Math.PI}updateCameraFormPlaneSize(e,t){var n;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===(n=this.cameraHelper)||void 0===n||n.update()}updateCameraFarPlane(e){var t;this.far=e,this.updateProjectionMatrix(),null===(t=this.cameraHelper)||void 0===t||t.update()}updateCameraHelper(e,t){var n,r,i;e?(this.cameraHelper=null!==(n=this.cameraHelper)&&void 0!==n?n:new gt(this),this.cameraHelper.visible=!0,null==t||t.add(this.cameraHelper)):(null===(r=this.cameraHelper)||void 0===r?void 0:r.parent)&&(null===(i=this.cameraHelper)||void 0===i||i.removeFromParent())}setCameraHelperVisibility(e){this.cameraHelper&&(this.cameraHelper.visible=e)}}const Fo={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}"},Bo={uniforms:{tDiffuse:{value:null},resolution:{value:new s(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 No extends class{constructor(){this.isPass=!0,this.enabled=!0,this.needsSwap=!0,this.clear=!1,this.renderToScreen=!1}setSize(){}render(){console.error("THREE.Pass: .render() must be implemented in derived pass.")}dispose(){}}{constructor(e,t,n,r,i){var a;super(),this.patternTexture=null,this.gBufferRenderTarget=null==i?void 0:i.gBufferRenderTarget,this.renderScene=t,this.renderCamera=n,this.selectedObjects=void 0!==r?r:[],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==i?void 0:i.downSampleRatio)||2,this.pulsePeriod=0,this.edgeDetectionFxaa=(null==i?void 0:i.edgeDetectionFxaa)||!1,this._visibilityCache=new Map,this.resolution=void 0!==e?new s(e.x,e.y):new s(256,256);const o=Math.round(this.resolution.x/this.downSampleRatio),l=Math.round(this.resolution.y/this.downSampleRatio);this.renderTargetMaskBuffer=new ct(this.resolution.x,this.resolution.y),this.renderTargetMaskBuffer.texture.name="OutlinePass.mask",this.renderTargetMaskBuffer.texture.generateMipmaps=!1,this.gBufferRenderTarget||(this.depthMaterial=new vt,this.depthMaterial.side=F,this.depthMaterial.depthPacking=wt,this.depthMaterial.blending=ht),this.prepareMaskMaterial=this.getPrepareMaskMaterial(null===(a=this.gBufferRenderTarget)||void 0===a?void 0:a.isFloatGBufferWithRgbNormalAlphaDepth),this.prepareMaskMaterial.side=F,this.prepareMaskMaterial.fragmentShader=function(e,t){const n=t.isPerspectiveCamera?"perspective":"orthographic";return e.replace(/DEPTH_TO_VIEW_Z/g,n+"DepthToViewZ")}(this.prepareMaskMaterial.fragmentShader,this.renderCamera),this.gBufferRenderTarget||(this.renderTargetDepthBuffer=new ct(this.resolution.x,this.resolution.y),this.renderTargetDepthBuffer.texture.name="OutlinePass.depth",this.renderTargetDepthBuffer.texture.generateMipmaps=!1),this.edgeDetectionFxaa&&(this.fxaaRenderMaterial=new rt(Bo),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 ct(this.resolution.x,this.resolution.y),this.renderTargetFxaaBuffer.texture.name="OutlinePass.fxaa",this.renderTargetFxaaBuffer.texture.generateMipmaps=!1),this.renderTargetMaskDownSampleBuffer=new ct(o,l),this.renderTargetMaskDownSampleBuffer.texture.name="OutlinePass.depthDownSample",this.renderTargetMaskDownSampleBuffer.texture.generateMipmaps=!1,this.renderTargetBlurBuffer1=new ct(o,l),this.renderTargetBlurBuffer1.texture.name="OutlinePass.blur1",this.renderTargetBlurBuffer1.texture.generateMipmaps=!1,this.renderTargetBlurBuffer2=new ct(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 ct(o,l),this.renderTargetEdgeBuffer1.texture.name="OutlinePass.edge1",this.renderTargetEdgeBuffer1.texture.generateMipmaps=!1,this.renderTargetEdgeBuffer2=new ct(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=Fo;this.copyUniforms=lt.clone(d.uniforms),this.copyUniforms.opacity.value=1,this.materialCopy=new rt({uniforms:this.copyUniforms,vertexShader:d.vertexShader,fragmentShader:d.fragmentShader,blending:ht,depthTest:!1,depthWrite:!1,transparent:!0}),this.enabled=!0,this.needsSwap=!1,this._oldClearColor=new h,this.oldClearAlpha=1,this.fsQuad=new Ao(void 0),this.tempPulseColor1=new h,this.tempPulseColor2=new h,this.textureMatrix=new S}dispose(){var e,t,n,r;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===(n=this.depthMaterial)||void 0===n||n.dispose(),this.prepareMaskMaterial.dispose(),null===(r=this.fxaaRenderMaterial)||void 0===r||r.dispose(),this.edgeDetectionMaterial.dispose(),this.separableBlurMaterial1.dispose(),this.separableBlurMaterial2.dispose(),this.overlayMaterial.dispose(),this.materialCopy.dispose(),this.fsQuad.dispose()}setSize(e,t){var n,r,i;this.renderTargetMaskBuffer.setSize(e,t),null===(n=this.renderTargetDepthBuffer)||void 0===n||n.setSize(e,t);let s=Math.round(e/this.downSampleRatio),a=Math.round(t/this.downSampleRatio);this.renderTargetMaskDownSampleBuffer.setSize(s,a),this.renderTargetBlurBuffer1.setSize(s,a),this.renderTargetEdgeBuffer1.setSize(s,a),this.separableBlurMaterial1.uniforms.texSize.value.set(s,a),s=Math.round(s/2),a=Math.round(a/2),this.renderTargetBlurBuffer2.setSize(s,a),this.renderTargetEdgeBuffer2.setSize(s,a),this.separableBlurMaterial2.uniforms.texSize.value.set(s,a),null===(r=this.fxaaRenderMaterial)||void 0===r||r.uniforms.resolution.value.set(1/this.resolution.x,1/this.resolution.y),null===(i=this.renderTargetFxaaBuffer)||void 0===i||i.setSize(e,t)}changeVisibilityOfSelectedObjects(e){const t=this._visibilityCache;function n(n){n.isMesh&&(!0===e?n.visible=t.get(n):(t.set(n,n.visible),n.visible=e))}this.selectedObjects.forEach(e=>e.traverse(n))}changeVisibilityOfNonSelectedObjects(e){const t=this._visibilityCache,n=[];function r(e){e.isMesh&&n.push(e)}this.selectedObjects.forEach(e=>e.traverse(r)),this.renderScene.traverse((function(r){if(r.isMesh||r.isSprite){if(!1===n.some(e=>e.id===r.id)){const n=r.visible;!1!==e&&!0!==t.get(r)||(r.visible=e),t.set(r,n)}}else(r.isPoints||r.isLine)&&(!0===e?r.visible=t.get(r):(t.set(r,r.visible),r.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,n,r,i){var s,a;if(this.selectedObjects.length>0){null===(s=this.gBufferRenderTarget)||void 0===s||s.render(e,this.renderScene,this.renderCamera),e.getClearColor(this._oldClearColor),this.oldClearAlpha=e.getClearAlpha();const t=e.autoClear;e.autoClear=!1,i&&e.state.buffers.stencil.setTest(!1),e.setClearColor(16777215,1),this.changeVisibilityOfSelectedObjects(!1);const r=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===(a=this.renderTargetDepthBuffer)||void 0===a?void 0:a.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=r;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=No.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=No.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=No.BlurDirectionX,e.setRenderTarget(this.renderTargetBlurBuffer2),e.clear(),this.fsQuad.render(e),this.separableBlurMaterial2.uniforms.colorTexture.value=this.renderTargetBlurBuffer2.texture,this.separableBlurMaterial2.uniforms.direction.value=No.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,i&&e.state.buffers.stencil.setTest(!0),e.setRenderTarget(n),this.fsQuad.render(e),e.setClearColor(this._oldClearColor,this.oldClearAlpha),e.autoClear=t}this.renderToScreen&&n&&(this.fsQuad.material=this.materialCopy,this.copyUniforms.tDiffuse.value=n.texture,e.setRenderTarget(null),this.fsQuad.render(e))}getPrepareMaskMaterial(e){return new rt({uniforms:{depthTexture:{value:null},cameraNearFar:{value:new s(.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 rt({uniforms:{maskTexture:{value:null},texSize:{value:new s(.5,.5)},visibleEdgeColor:{value:new a(1,1,1)},hiddenEdgeColor:{value:new a(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 rt({defines:{MAX_RADIUS:e},uniforms:{colorTexture:{value:null},texSize:{value:new s(.5,.5)},direction:{value:new s(.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 rt({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:bt,depthTest:!1,depthWrite:!1,transparent:!0})}}No.BlurDirectionX=new s(1,0),No.BlurDirectionY=new s(0,1);class zo{get isOutlinePassActivated(){return this.outlinePassActivated}constructor(e,t,n,r){this.width=0,this.height=0,this.effectComposer=null,this.outlinePass=null,this.outlinePassActivated=!1,this.effectComposer=e,this.gBufferRenderTarget=null==r?void 0:r.gBufferRenderTarget,this.width=t,this.height=n,this.parameters={enabled:!0,edgeStrength:2,edgeGlow:1,edgeThickness:2,pulsePeriod:0,usePatternTexture:!1,visibleEdgeColor:16777215,hiddenEdgeColor:16777215,...r}}dispose(){var e;null===(e=this.outlinePass)||void 0===e||e.dispose()}setSize(e,t){var n;this.width=e,this.height=t,null===(n=this.outlinePass)||void 0===n||n.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 n;if(!this.parameters.enabled)return void this.deactivateOutline();const r=(null===(n=this.outlinePass)||void 0===n?void 0:n.renderCamera)&&t.isPerspectiveCamera!==this.outlinePass.renderCamera.isPerspectiveCamera;this.outlinePass&&(this.outlinePass.renderScene=e,this.outlinePass.renderCamera=t),!r&&this.outlinePassActivated||(!r&&this.outlinePass||(this.outlinePass=new No(new s(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,n){n.length>0?(this.activateOutline(e,t),this.outlinePass&&(this.outlinePass.selectedObjects=n)):this.deactivateOutline()}}class Ho extends j{constructor(e,t){const n=new c;n.setAttribute("position",new Te([1,1,0,-1,1,0,-1,-1,0,1,-1,0,1,1,0],3)),n.computeBoundingSphere(),super(n,new L({fog:!1})),this.light=e,this.color=t,this.type="RectAreaLightHelper";const r=new c;r.setAttribute("position",new Te([1,1,0,-1,1,0,-1,-1,0,1,1,0,-1,-1,0,1,-1,0],3)),r.computeBoundingSphere(),this.add(new z(r,new _({side:_t,fog:!1})))}updateMatrixWorld(){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);const 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)}dispose(){this.geometry.dispose(),this.material.dispose(),this.children[0].geometry.dispose(),this.children[0].material.dispose()}}var jo;!function(e){e[e.DirectionalLightShadow=0]="DirectionalLightShadow",e[e.SpotLightShadow=1]="SpotLightShadow"}(jo||(jo={}));const Vo={alwaysUpdate:!1,enableShadowMap:!0,layers:null,shadowLightSourceType:jo.DirectionalLightShadow,maximumNumberOfLightSources:-1,fadeOutDistance:.3,fadeOutBlur:60},Go="\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",Ko="\n#ifdef DYNAMIC_SHADOW_RADIUS\n shadow = shadowBase + shadowScale * (\n#else\n shadow = (\n#endif\n";class Wo{get shadowTexture(){return this.shadowRenderTarget.texture}constructor(e,t){var n,r;this.needsUpdate=!1,this.shadowTypeNeedsUpdate=!0,this.shadowConfiguration=new Qo,this.shadowLightSources=[],this.shadowScale=1,this.cameraUpdate=new Ro,this.viewportSize=new s(e.x,e.y),this.samples=null!==(n=null==t?void 0:t.samples)&&void 0!==n?n:0,this.shadowMapSize=null!==(r=null==t?void 0:t.shadowMapSize)&&void 0!==r?r:1024,this.parameters=this.getScreenSpaceShadowMapParameters(t),this.castShadow=this.parameters.enableShadowMap,this.shadowMapPassOverrideMaterials=new qo(this.parameters);const i=this.samples;this.shadowRenderTarget=new ct(this.viewportSize.x,this.viewportSize.y,{samples:i,format:Ze})}getScreenSpaceShadowMapParameters(e){return{...Vo,...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 n=this.shadowScale;this.shadowScale=t,Math.abs(n-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 n=new Zo(e,{shadowMapSize:this.shadowMapSize,shadowLightSourceType:this.parameters.shadowLightSourceType});this.shadowLightSources.push(n),n.addTo(t),n.updatePositionAndTarget(),this.needsUpdate=!0}updateRectAreaLights(e,t){this.shadowLightSources=this.shadowLightSources.filter(n=>{if(n instanceof Zo){const t=n.getRectAreaLight();if(e.includes(t))return n.updatePositionAndTarget(),!0}return n.removeFrom(t),n.dispose(),!1}),e.forEach(e=>{this.shadowLightSources.find(t=>t instanceof Zo&&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 n=1/(t.length>0?Math.max(...t.map(e=>e.maxIntensity)):1);this.addShadowFromLightSources(t,n),this.shadowLightSources.forEach(t=>{t.addTo(e),t.updatePositionAndTarget()}),this.needsUpdate=!0,this.shadowTypeNeedsUpdate=!0}addShadowFromLightSources(e,t){e.forEach(e=>{const n=e.maxIntensity*t;if(n>=.1&&e.position.z>=0){const t=new a(e.position.x,e.position.z,e.position.y).multiplyScalar(7),r=new Jo(t,n,{shadowMapSize:this.shadowMapSize,shadowLightSourceType:this.parameters.shadowLightSourceType});this.shadowLightSources.push(r)}})}setSize(e,t){this.viewportSize=new s(e,t),this.shadowRenderTarget.setSize(this.viewportSize.x,this.viewportSize.y)}updatePositionAndTarget(){this.shadowLightSources.forEach(e=>e.updatePositionAndTarget())}renderShadowMap(e,t,n){if(!(this.needsUpdate||this.parameters.alwaysUpdate||this.cameraUpdate.changed(n)))return;this.needsUpdate=!1,this.shadowTypeNeedsUpdate&&(this.shadowTypeNeedsUpdate=!1,this.needsUpdate=!0,this.updateShadowType(e));const r=t.background,i=t.environment,s=n.layers.mask;t.environment=null,t.background=null,this.parameters.layers&&(n.layers.mask=this.parameters.layers.mask),this.renderSimpleShadowMapFromShadowLightSources(e,t,n),n.layers.mask=s,t.environment=i,t.background=r}renderSimpleShadowMapFromShadowLightSources(e,t,n){this.shadowMapPassOverrideMaterials.setShadowFadeOut(this.parameters.fadeOutDistance*this.shadowScale,this.parameters.fadeOutBlur);const r=this.getSortedShadowLightSources();this.setShadowLightSourcesIntensity(r),this.shadowMapPassOverrideMaterials.render(e,t,n,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 n=0;for(let t=0;t<e.length;t++){const r=e[t];(this.parameters.maximumNumberOfLightSources<0||t<this.parameters.maximumNumberOfLightSources)&&(n+=r.intensity)}for(let r=0;r<e.length;r++){const i=e[r];this.parameters.maximumNumberOfLightSources<0||r<this.parameters.maximumNumberOfLightSources?(i.light.visible=!0,i.light.intensity=i.intensity/n,(t=i.light).castShadow&&(t.castShadow=this.castShadow)):(i.light.visible=!1,i.light.intensity=0,i.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 Xo;!function(e){e[e.Default=0]="Default",e[e.Unlit=1]="Unlit",e[e.Emissive=2]="Emissive",e[e.Shadow=3]="Shadow"}(Xo||(Xo={}));class qo{constructor(e){var t,n;this.boxMin=new a(1,1,1),this.boxMax=new a(-1,-1,-1),this.viewToWorldMatrix=new S,this.shadowFadeOut=new s(null!==(t=null==e?void 0:e.fadeOutTo)&&void 0!==t?t:.5,null!==(n=null==e?void 0:e.fadeOutBlur)&&void 0!==n?n:60),this.renderPass=new Io,this.shadowObjectMaterial=this.createShadowMaterial(Xo.Default),this.unlitMaterial=this.createShadowMaterial(Xo.Unlit),this.emissiveMaterial=this.createShadowMaterial(Xo.Emissive),this.receiveShadowMaterial=this.createShadowMaterial(Xo.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===Xo.Emissive||e===Xo.Unlit?new _({color:16777215,side:F}):e===Xo.Shadow?new Mt({side:F}):qo.useModifiedMaterial?this.createCustomerShadowMaterial():new Tt({color:16777215,shininess:0,polygonOffsetFactor:0,polygonOffsetUnits:0,side:F}),t}createCustomerShadowMaterial(){if(!qo.shaderChunkChanged){qo.shaderChunkChanged=!0;let e=Pt.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 ) { "+Go),e=e.replace("if(frustumTest){","if(frustumTest){ "+Go),e=e.replace("shadow = (",Ko),e=e.replace("shadow=(",Ko),Pt.shadowmap_pars_fragment=e}const e=new At({side:F});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,n,r){this.viewToWorldMatrix.copy(n.matrixWorld);const i=new Map;t.traverse(e=>{e.isMesh&&e.visible?(i.set(e,{visible:e.visible,castShadow:e.castShadow,material:e.material}),this.setMeshMaterialAndVisibility(e)):(e.isLine||e.isLight&&!e.userData.shadowLightSource)&&(i.set(e,{visible:e.visible,castShadow:e.castShadow,material:e.material}),e.visible=!1)}),this.renderPass.render(e,t,n,r,16777215,1),i.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 U&&e.material.emissiveIntensity>0?this.setMeshShadowStandardMaterial(e,e.material):e.visible=!1:this.setMeshShadowOpaqueMaterial(e)}setMeshShadowOpaqueMaterial(e){const t=e.material;t instanceof L||t instanceof _?e.material=this.unlitMaterial:t instanceof U?this.setMeshShadowStandardMaterial(e,t):e.material=e.receiveShadow?this.shadowObjectMaterial:this.unlitMaterial}setMeshShadowStandardMaterial(e,t){const n=t.emissiveIntensity>0&&(t.emissive.r>0||t.emissive.g>0||t.emissive.b>0);e.material=n?this.emissiveMaterial:e.receiveShadow?this.shadowObjectMaterial:this.unlitMaterial,n&&(e.castShadow=!1)}}qo.shaderChunkChanged=!1,qo.useModifiedMaterial=!0;class Qo{constructor(){var e;this.types=new Map([["off",Qo.noShadow],["BasicShadowMap",Qo.basicShadow],["PCFShadowMap",Qo.pcfShadow],["PCFSoftShadowMap",Qo.pcfSoftShadow],["VSMShadowMap",Qo.vcmShadow]]),this.shadowType="PCFShadowMap",this.currentConfiguration=null!==(e=this.types.get(this.shadowType))&&void 0!==e?e:Qo.defaultType}switchType(e){var t;return!!this.types.has(e)&&(this.currentConfiguration=null!==(t=this.types.get(e))&&void 0!==t?t:Qo.defaultType,!0)}}Qo.noShadow={castShadow:!1,type:yt,bias:0,normalBias:0,radius:0},Qo.basicShadow={castShadow:!0,type:xt,bias:-5e-5,normalBias:.005,radius:0},Qo.pcfShadow={castShadow:!0,type:yt,bias:-5e-5,normalBias:.01,radius:4},Qo.pcfSoftShadow={castShadow:!0,type:St,bias:-5e-5,normalBias:.01,radius:1},Qo.vcmShadow={castShadow:!0,type:Ct,bias:1e-4,normalBias:0,radius:15},Qo.defaultType=Qo.pcfShadow;class Yo{constructor(e,t){var n,r;this.isVisibleBackup=!0,this.castShadowBackup=!0,this.shadowMapSize=null!==(n=null==t?void 0:t.shadowMapSize)&&void 0!==n?n:1024,this.blurSamples=null!==(r=null==t?void 0:t.blurSamples)&&void 0!==r?r:8,this._shadowLightSource=e,this._shadowLightSource.visible=!1,this._shadowLightSource.castShadow=!0,this._shadowLightSource.shadow&&(this._shadowLightSource.shadow.mapSize=new s(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 a(0,0,0))}updateBounds(e){if(this._shadowLightSource instanceof l){const t=this._shadowLightSource.shadow.camera,n=e.bounds.clone().applyMatrix4(t.matrixWorldInverse),r=Math.max(.001,Math.min(-n.min.z,-n.max.z)),i=Math.max(-n.min.z,-n.max.z),s=Math.max(Math.abs(n.min.x),Math.abs(n.max.x)),a=Math.max(Math.abs(n.min.y),Math.abs(n.max.y)),o=Math.atan2(1.05*Math.hypot(a,s),r);t.aspect=1,t.near=r,t.far=i,this._shadowLightSource.angle=o}else if(this._shadowLightSource.shadow){const t=this._shadowLightSource.shadow.camera;e.updateCameraViewVolumeFromBounds(t);const n=t;n.far+=n.far-n.near,n.updateProjectionMatrix()}this._shadowLightSource.shadow&&(this._shadowLightSource.shadow.needsUpdate=!0)}updateShadowPositionAndTarget(e,t){var n,r,i;if(this._shadowLightSource instanceof l){const n=t.clone().sub(e),r=n.length();n.normalize();const i=t.clone().sub(n.clone().multiplyScalar(4*r));this._shadowLightSource.shadow.camera.position.copy(i),this._shadowLightSource.shadow.camera.position.copy(i),this._shadowLightSource.shadow.camera.lookAt(t),this._shadowLightSource.position.copy(i),this._shadowLightSource.lookAt(t)}else this._shadowLightSource.position.copy(e),this._shadowLightSource.lookAt(t),null===(n=this._shadowLightSource.shadow)||void 0===n||n.camera.position.copy(e),null===(r=this._shadowLightSource.shadow)||void 0===r||r.camera.lookAt(t);null===(i=this._shadowLightSource.shadow)||void 0===i||i.camera.updateMatrixWorld(),this._shadowLightSource.updateMatrixWorld()}updateShadowType(e,t){const n=this._shadowLightSource.shadow;n&&(n.bias=e.bias,n.normalBias=e.normalBias*t,n.radius=e.radius,n.needsUpdate=!0)}prepareRenderShadow(){return[]}finishRenderShadow(){}}class Zo extends Yo{constructor(e,t){let n;switch(null==t?void 0:t.shadowLightSourceType){default:case jo.DirectionalLightShadow:n=new i(16777215,1);break;case jo.SpotLightShadow:n=new l(16777215,1,0,Math.PI/4,0)}n.position.copy(e.position),n.lookAt(0,0,0),super(n,t),this._rectAreaLight=e,this._rectAreaLight.userData.shadowLightSource=this,(null==t?void 0:t.addHelper)&&(this._rectLightHelper=new Ho(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 Jo extends Yo{constructor(e,t,n){const r=new i(16777215,t);r.position.copy(e),r.lookAt(0,0,0),r.updateMatrix(),r.castShadow=!0,super(r,n),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}}
|
|
9
|
+
/**
|
|
10
|
+
* postprocessing v6.33.0 build Fri Aug 11 2023
|
|
11
|
+
* https://github.com/pmndrs/postprocessing
|
|
12
|
+
* Copyright 2015-2023 Raoul van Rüschen
|
|
13
|
+
* @license Zlib
|
|
14
|
+
*/
|
|
15
|
+
var $o=new It,el=null,tl=class e{constructor(e="Pass",t=new Rt,n=$o){this.name=e,this.renderer=null,this.scene=t,this.camera=n,this.screen=null,this.rtt=!0,this.needsSwap=!0,this.needsDepthTexture=!1,this.enabled=!0}get renderToScreen(){return!this.rtt}set renderToScreen(e){if(this.rtt===e){const t=this.fullscreenMaterial;null!==t&&(t.needsUpdate=!0),this.rtt=!e}}set mainScene(e){}set mainCamera(e){}setRenderer(e){this.renderer=e}isEnabled(){return this.enabled}setEnabled(e){this.enabled=e}get fullscreenMaterial(){return null!==this.screen?this.screen.material:null}set fullscreenMaterial(e){let t=this.screen;null!==t?t.material=e:(t=new z(function(){if(null===el){const e=new Float32Array([-1,-1,0,3,-1,0,-1,3,0]),t=new Float32Array([0,0,2,0,0,2]);void 0!==(el=new c).setAttribute?(el.setAttribute("position",new u(e,3)),el.setAttribute("uv",new u(t,2))):(el.addAttribute("position",new u(e,3)),el.addAttribute("uv",new u(t,2)))}return el}(),e),t.frustumCulled=!1,null===this.scene&&(this.scene=new Rt),this.scene.add(t),this.screen=t)}getFullscreenMaterial(){return this.fullscreenMaterial}setFullscreenMaterial(e){this.fullscreenMaterial=e}getDepthTexture(){return null}setDepthTexture(e,t=Et){}render(e,t,n,r,i){throw new Error("Render method not implemented!")}setSize(e,t){}initialize(e,t,n){}dispose(){for(const t of Object.keys(this)){const n=this[t];(n instanceof ct||n instanceof D||n instanceof le||n instanceof e)&&this[t].dispose()}}},nl="data:image/png;base64,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",rl="#define GLSLIFY 1\nvarying vec2 vUv;void main(){vUv=position.xy*0.5+0.5;gl_Position=vec4(position.xy,1.0,1.0);}",il="#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;}";class sl extends tl{constructor(e,t,n){super(),this._camera=e,this._scene=t,this.renderTarget=new ct(1,1,{type:Qe,depthBuffer:!1});const r=n.replace("#include <sampleBlueNoise>",il);this.fullscreenMaterial=new rt({fragmentShader:r,vertexShader:rl,uniforms:{depthTexture:{value:null},normalTexture:{value:null},cameraNear:{value:0},cameraFar:{value:0},viewMatrix:{value:this._camera.matrixWorldInverse},projectionViewMatrix:{value:new S},projectionMatrixInverse:{value:this._camera.projectionMatrixInverse},cameraMatrixWorld:{value:this._camera.matrixWorld},texSize:{value:new s},blueNoiseTexture:{value:null},blueNoiseRepeat:{value:new s},aoDistance:{value:0},distancePower:{value:0},bias:{value:0},thickness:{value:0},power:{value:0},frame:{value:0}},blending:ht,depthWrite:!1,depthTest:!1,toneMapped:!1}),(new A).load(nl,e=>{e.minFilter=$,e.magFilter=$,e.wrapS=k,e.wrapT=k,e.colorSpace=Je,this.fullscreenMaterial.uniforms.blueNoiseTexture.value=e})}get texture(){return this.renderTarget.texture}setSize(e,t){this.renderTarget.setSize(e,t),this.fullscreenMaterial.uniforms.texSize.value.set(this.renderTarget.width,this.renderTarget.height)}render(e){const 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);const n=this.fullscreenMaterial.uniforms.blueNoiseTexture.value;if(n){const{width:e,height:t}=n.source.data;this.fullscreenMaterial.uniforms.blueNoiseRepeat.value.set(this.renderTarget.width/e,this.renderTarget.height/t)}e.setRenderTarget(this.renderTarget),e.render(this.scene,this.camera)}}class al extends sl{constructor(e,t){super(e,t,"#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);}")}}const ol="#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);}");class ll extends sl{constructor(e,t){super(e,t,ol)}}const hl="#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>",il),dl={iterations:1,radius:8,rings:5.625,lumaPhi:10,depthPhi:2,normalPhi:3.25,samples:16,normalTexture:null};class cl extends tl{iterations=dl.iterations;index=0;constructor(e,t,n,r=dl){super("PoissionBlurPass"),r={...dl,...r},this.inputTexture=t,this.fullscreenMaterial=new rt({fragmentShader:hl,vertexShader:rl,uniforms:{depthTexture:{value:null},inputTexture:{value:null},projectionMatrixInverse:{value:new S},cameraMatrixWorld:{value:new S},lumaPhi:{value:5},depthPhi:{value:5},normalPhi:{value:5},resolution:{value:new s},blueNoiseTexture:{value:null},index:{value:0},blueNoiseRepeat:{value:new s}}});const i={type:Qe,depthBuffer:!1};this.renderTargetA=new ct(1,1,i),this.renderTargetB=new ct(1,1,i);const{uniforms:a}=this.fullscreenMaterial;a.inputTexture.value=this.inputTexture,a.depthTexture.value=n,a.projectionMatrixInverse.value=e.projectionMatrixInverse,a.cameraMatrixWorld.value=e.matrixWorld,a.depthPhi.value=r.depthPhi,a.normalPhi.value=r.normalPhi,r.normalTexture?a.normalTexture={value:r.normalTexture}:this.fullscreenMaterial.defines.NORMAL_IN_RGB="";for(const e of["radius","rings","samples"])Object.defineProperty(this,e,{get:()=>r[e],set:t=>{r[e]=t,this.setSize(this.renderTargetA.width,this.renderTargetA.height)}});(new A).load(nl,e=>{e.minFilter=$,e.magFilter=$,e.wrapS=k,e.wrapT=k,e.colorSpace=Je,this.fullscreenMaterial.uniforms.blueNoiseTexture.value=e})}setSize(e,t){this.renderTargetA.setSize(e,t),this.renderTargetB.setSize(e,t),this.fullscreenMaterial.uniforms.resolution.value.set(e,t);const n=function(e,t,n,r){const i=2*Math.PI*t/e,a=1/e,o=a,l=[];let h=a,d=0;for(let t=0;t<e;t++){const e=new s(Math.cos(d),Math.sin(d)).multiplyScalar(Math.pow(h,.75)).multiply(r).multiplyScalar(n);l.push(e),h+=o,d+=i}return l}(this.samples,this.rings,this.radius,new s(1/e,1/t)),r=`const int samples = ${this.samples};\n`,i=function(e){const t=e.length;let n="const vec2 poissonDisk[samples] = vec2[samples](\n";for(let r=0;r<t;r++){const i=e[r];n+=` vec2(${i.x}, ${i.y})`,r<t-1&&(n+=","),n+="\n"}return n+=");",n}(n);this.fullscreenMaterial.fragmentShader=r+i+"\n"+hl,this.fullscreenMaterial.needsUpdate=!0}get texture(){return this.renderTargetB.texture}render(e){this.fullscreenMaterial.uniforms.index.value=0;const t=this.fullscreenMaterial.uniforms.blueNoiseTexture.value;if(t){const{width:e,height:n}=t.source.data;this.fullscreenMaterial.uniforms.blueNoiseRepeat.value.set(this.renderTargetA.width/e,this.renderTargetA.height/n)}for(let t=0;t<2*this.iterations;t++){const n=t%2==0,r=n?this.renderTargetB:this.renderTargetA;this.fullscreenMaterial.uniforms.inputTexture.value=0===t?this.inputTexture:r.texture;const i=n?this.renderTargetA:this.renderTargetB;e.setRenderTarget(i),e.render(this.scene,this.camera),this.fullscreenMaterial.uniforms.index.value=(this.fullscreenMaterial.uniforms.index.value+1)%4}}}var ul,pl;cl.DefaultOptions=dl,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"}(ul||(ul={})),function(e){e[e.SEPARATE_BUFFER=0]="SEPARATE_BUFFER",e[e.NORMAL_VECTOR_ALPHA=1]="NORMAL_VECTOR_ALPHA"}(pl||(pl={}));const ml={resolutionScale:1,spp:16,distance:.25,distancePower:.25,power:2,bias:40,thickness:.075},fl={resolutionScale:1,spp:16,distance:.25,distancePower:1,power:2,bias:20,thickness:.05},gl={iterations:1,radius:10,rings:5.625,lumaPhi:10,depthPhi:12,normalPhi:3.25,samples:16};class vl{get texture(){return this.ssaoPass?this.ssaoPass.texture:null}constructor(e,t,n){this.needsUpdate=!0,this.parameters={...ml},this.width=0,this.height=0,this.loaded=!1,this.normalVectorSourceType=ul.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=pl.NORMAL_VECTOR_ALPHA,this.modulateRedChannel=!1,this.depthTexture=null,this.normalTexture=null,this.width=e,this.height=t,this.normalVectorSourceType=(null==n?void 0:n.normalVectorSourceType)||ul.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=(null==n?void 0:n.depthValueSourceType)||pl.NORMAL_VECTOR_ALPHA,this.modulateRedChannel=(null==n?void 0:n.modulateRedChannel)||!1,(null==n?void 0:n.ssaoParameters)&&(this.parameters=n.ssaoParameters),n&&this.updateParameters(n)}getPass(e,t){if(!this.ssaoPass){this.ssaoPass=new al(e,t);const n=this.ssaoPass.fullscreenMaterial;n.defines.useNormalTexture="",this.modulateRedChannel&&(n.blending=kt,n.blendEquation=Ot,n.blendEquationAlpha=null,n.blendSrc=Dt,n.blendSrcAlpha=null,n.blendDst=Dt,n.blendDstAlpha=null),n.onBeforeCompile=e=>{this.normalVectorSourceType===ul.FLOAT_BUFFER_NORMAL&&(e.fragmentShader=e.fragmentShader.replace("computeNormal(worldPos, vUv)","normalize(textureLod(normalTexture, vUv, 0.).rgb)")),this.depthValueSourceType===pl.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 n;this.width=e,this.height=t,null===(n=this.ssaoPass)||void 0===n||n.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,n,r){var i;this.loaded||null===(null===(i=this.ssaoPass)||void 0===i?void 0:i.fullscreenMaterial.uniforms.blueNoiseTexture.value)||(this.loaded=!0,this.needsUpdate=!0);const s=!this.ssaoPass,o=this.getPass(t,n);if(this.needsUpdate||s){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===pl.NORMAL_VECTOR_ALPHA?this.normalTexture:this.depthTexture,o.fullscreenMaterial.uniforms.normalTexture.value=this.normalTexture,o.fullscreenMaterial.needsUpdate=!0,s){const e=Math.round(this.parameters.spp);o.fullscreenMaterial.defines.spp=e;const t=function(e){const t=[],n=Math.PI*(3-Math.sqrt(5)),r=2/e;for(let i=0;i<e;i++){const e=i*r-1+r/2,s=Math.sqrt(1-e*e),o=i*n;t.push(new a(Math.cos(o)*s,e,Math.sin(o)*s))}return t}(e),n=[];for(let t=0;t<e;t++)n.push((t+1)/e);o.fullscreenMaterial.uniforms.samples={value:t},o.fullscreenMaterial.uniforms.samplesR={value:n}}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();r&&(o.renderTarget=r),o.render(e),e.setRenderTarget(l)}}class wl{get texture(){return this.hbaoPass.texture}constructor(e,t,n){this.needsUpdate=!0,this.parameters={...fl},this.width=0,this.height=0,this.loaded=!1,this.normalVectorSourceType=ul.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=pl.NORMAL_VECTOR_ALPHA,this.modulateRedChannel=!1,this.depthTexture=null,this.normalTexture=null,this.width=e,this.height=t,this.normalVectorSourceType=(null==n?void 0:n.normalVectorSourceType)||ul.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=(null==n?void 0:n.depthValueSourceType)||pl.NORMAL_VECTOR_ALPHA,this.modulateRedChannel=(null==n?void 0:n.modulateRedChannel)||!1,(null==n?void 0:n.hbaoParameters)&&(this.parameters=n.hbaoParameters),n&&this.updateParameters(n)}getPass(e,t){if(!this.hbaoPass){this.hbaoPass=new ll(e,t);const n=this.hbaoPass.fullscreenMaterial;n.defines.useNormalTexture="",this.modulateRedChannel&&(n.blending=kt,n.blendEquation=Ot,n.blendEquationAlpha=null,n.blendSrc=Dt,n.blendSrcAlpha=null,n.blendDst=Dt,n.blendDstAlpha=null),n.onBeforeCompile=e=>{this.normalVectorSourceType===ul.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===pl.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 n;this.width=e,this.height=t,null===(n=this.hbaoPass)||void 0===n||n.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,n,r){var i;this.loaded||null===(null===(i=this.hbaoPass)||void 0===i?void 0:i.fullscreenMaterial.uniforms.blueNoiseTexture.value)||(this.loaded=!0,this.needsUpdate=!0);const s=this.getPass(t,n);if(this.needsUpdate){this.needsUpdate=!1;const e=Math.round(this.parameters.spp);s.fullscreenMaterial.defines.spp=e,s.fullscreenMaterial.uniforms.aoDistance.value=this.parameters.distance,s.fullscreenMaterial.uniforms.distancePower.value=this.parameters.distancePower,s.fullscreenMaterial.uniforms.bias.value=this.parameters.bias,s.fullscreenMaterial.uniforms.thickness.value=this.parameters.thickness,s.fullscreenMaterial.uniforms.power.value=this.parameters.power,s.fullscreenMaterial.uniforms.depthTexture.value=this.depthValueSourceType===pl.NORMAL_VECTOR_ALPHA?this.normalTexture:this.depthTexture,s.fullscreenMaterial.uniforms.normalTexture.value=this.normalTexture,s.fullscreenMaterial.needsUpdate=!0,s.setSize(this.width,this.height),s.renderToScreen=!1}s._camera=t,s.fullscreenMaterial.uniforms.viewMatrix.value=t.matrixWorldInverse,s.fullscreenMaterial.uniforms.projectionMatrixInverse.value=t.projectionMatrixInverse,s.fullscreenMaterial.uniforms.cameraMatrixWorld.value=t.matrixWorld;const a=e.getRenderTarget();r&&(s.renderTarget=r),s.render(e),e.setRenderTarget(a)}}class bl{get texture(){return this.denoisePass?this.denoisePass.texture:null}set inputTexture(e){this._inputTexture=e}constructor(e,t,n){this.needsUpdate=!0,this.parameters={...gl},this.width=0,this.height=0,this.normalVectorSourceType=ul.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=pl.NORMAL_VECTOR_ALPHA,this.rgInputTexture=!0,this._inputTexture=null,this.depthTexture=null,this.normalTexture=null,this.width=e,this.height=t,this.normalVectorSourceType=(null==n?void 0:n.normalVectorSourceType)||ul.FLOAT_BUFFER_NORMAL,this.depthValueSourceType=(null==n?void 0:n.depthValueSourceType)||pl.NORMAL_VECTOR_ALPHA,this.rgInputTexture=(null==n?void 0:n.rgInputTexture)||!0,this._inputTexture=(null==n?void 0:n.inputTexture)||null,this.depthTexture=(null==n?void 0:n.depthTexture)||null,this.normalTexture=(null==n?void 0:n.normalTexture)||null,n.poisonDenoiseParameters?this.parameters=n.poisonDenoiseParameters:n&&this.updateParameters(n)}getPass(e){return this.denoisePass||(this.normalTexture?(this.denoisePass=new cl(e,this._inputTexture,this.depthTexture,{normalTexture:this.normalTexture}),this.denoisePass.fullscreenMaterial.onBeforeCompile=e=>{switch(this.normalVectorSourceType){default:break;case ul.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 ul.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===pl.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 cl(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 n;this.width=e,this.height=t,null===(n=this.denoisePass)||void 0===n||n.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 n=this.getPass(t);this.needsUpdate&&(this.needsUpdate=!1,n.iterations=this.parameters.iterations,n.samples=this.parameters.samples,n.rings=this.parameters.rings,n.radius=this.parameters.radius,n.fullscreenMaterial.uniforms.lumaPhi.value=this.parameters.lumaPhi,n.fullscreenMaterial.uniforms.depthPhi.value=this.parameters.depthPhi,n.fullscreenMaterial.uniforms.normalPhi.value=this.parameters.normalPhi,n.fullscreenMaterial.needsUpdate=!0,n.setSize(this.width,this.height),n.renderToScreen=!1,this.normalTexture?(n.fullscreenMaterial.uniforms.depthTexture.value=this.depthValueSourceType===pl.NORMAL_VECTOR_ALPHA?this.normalTexture:this.depthTexture,n.fullscreenMaterial.uniforms.normalTexture.value=this.normalTexture):n.fullscreenMaterial.uniforms.depthTexture.value=this.depthTexture),n.inputTexture=this._inputTexture,n.fullscreenMaterial.uniforms.projectionMatrixInverse.value=t.projectionMatrixInverse,n.fullscreenMaterial.uniforms.cameraMatrixWorld.value=t.matrixWorld;const r=new h;e.getClearColor(r);const i=e.getClearAlpha(),s=e.autoClear,a=e.getRenderTarget();e.autoClear=!0,e.setClearColor(16777215,1),e.setRenderTarget(this.denoisePass.renderTargetA),e.setRenderTarget(this.denoisePass.renderTargetB),e.clear(!0,!1,!1),n.render(e),e.setClearColor(r),e.setClearAlpha(i),e.setRenderTarget(a),e.autoClear=s}}var _l,yl;!function(e){e[e.OFF=0]="OFF",e[e.HARD=1]="HARD",e[e.POISSON=2]="POISSON",e[e.FULL=3]="FULL"}(_l||(_l={})),function(e){e[e.NONE=0]="NONE",e[e.SSAO=1]="SSAO",e[e.EffectsSSAO=2]="EffectsSSAO",e[e.EffectsHBAO=3]="EffectsHBAO"}(yl||(yl={}));const xl={aoKernelRadius:.25,aoDepthBias:1e-4,aoMaxDistance:.5,aoMaxDepth:.99,aoFadeout:.5,shadowRadius:.1},Sl={enabled:!0,aoType:yl.SSAO,aoIntensity:.5,shadowIntensity:.3,aoOnGround:!0,shadowOnGround:!1,alwaysUpdate:!1};class Cl{get gBufferRenderTarget(){var e;return this._sharedGBufferRenderTarget?this._sharedGBufferRenderTarget:(this._gBufferRenderTarget=null!==(e=this._gBufferRenderTarget)&&void 0!==e?e:new Oo({width:this.width,height:this.height,samples:this.samples,renderPass:this.renderPass,renderOverrideVisibility:this._renderOverrideVisibility,textureFilter:$}),this._gBufferRenderTarget)}get SSAOEffect(){return this._ssaoEffect||(this._ssaoEffect=new vl(this.width,this.height,{normalVectorSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?ul.FLOAT_BUFFER_NORMAL:ul.INPUT_RGB_NORMAL,depthValueSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?pl.NORMAL_VECTOR_ALPHA:pl.SEPARATE_BUFFER,modulateRedChannel:!0,ssaoParameters:this.parameters.ssao})),this._ssaoEffect}get HBAOEffect(){return this._hbaoEffect||(this._hbaoEffect=new wl(this.width,this.height,{normalVectorSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?ul.FLOAT_BUFFER_NORMAL:ul.INPUT_RGB_NORMAL,depthValueSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?pl.NORMAL_VECTOR_ALPHA:pl.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 ct(this.width,this.height,{format:Lt,magFilter:E,minFilter:E}),this._fadeRenderTarget}get denoisePass(){return this.poissonDenoiseEffect||(this.poissonDenoiseEffect=new bl(this.width,this.height,{inputTexture:this.shadowAndAoRenderTargets.passRenderTarget.texture,depthTexture:this.gBufferRenderTarget.depthBufferTexture,normalTexture:this.gBufferRenderTarget.gBufferTexture,normalVectorSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?ul.FLOAT_BUFFER_NORMAL:ul.INPUT_RGB_NORMAL,depthValueSourceType:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?pl.NORMAL_VECTOR_ALPHA:pl.SEPARATE_BUFFER,rgInputTexture:!0,poisonDenoiseParameters:this.parameters.poissonDenoise})),this.poissonDenoiseEffect}get denoiseRenderTargetTexture(){return this.denoisePass?this.denoisePass.texture:null}constructor(e,t,n,r){var i,s,a,o,l,h,d;this.needsUpdate=!0,this.renderPass=new Io,this._renderOverrideVisibility=new Eo(!0),this.cameraUpdate=new Ro,(null==r?void 0:r.gBufferRenderTarget)&&(this._sharedGBufferRenderTarget=null==r?void 0:r.gBufferRenderTarget),this.width=e,this.height=t,this.samples=n,this.shadowAndAoRenderTargets=new Ml(this.gBufferRenderTarget,{...r,width:e,height:t,samples:n,renderPass:this.renderPass}),this.parameters={enabled:null!==(i=null==r?void 0:r.enabled)&&void 0!==i?i:Sl.enabled,aoType:null!==(s=null==r?void 0:r.aoType)&&void 0!==s?s:Sl.aoType,aoIntensity:null!==(a=null==r?void 0:r.aoIntensity)&&void 0!==a?a:Sl.aoIntensity,shadowIntensity:null!==(o=null==r?void 0:r.shadowIntensity)&&void 0!==o?o:Sl.shadowIntensity,aoOnGround:null!==(l=null==r?void 0:r.aoOnGround)&&void 0!==l?l:Sl.aoOnGround,shadowOnGround:null!==(h=null==r?void 0:r.shadowOnGround)&&void 0!==h?h:Sl.shadowOnGround,alwaysUpdate:null!==(d=null==r?void 0:r.alwaysUpdate)&&void 0!==d?d:Sl.alwaysUpdate,shAndAo:this.shadowAndAoRenderTargets.shadowAndAoParameters,ssao:{...ml},hbao:{...fl},poissonDenoise:{...gl}},this._copyMaterial=new yo,this._blendMaterial=new yo({},_o.DEFAULT)}dispose(){var e,t,n,r,i,s,a;null===(e=this.gBufferRenderTarget)||void 0===e||e.dispose(),this.shadowAndAoRenderTargets.dispose(),null===(t=this._ssaoEffect)||void 0===t||t.dispose(),null===(n=this._hbaoEffect)||void 0===n||n.dispose(),null===(r=this._fadeRenderTarget)||void 0===r||r.dispose(),null===(i=this.poissonDenoiseEffect)||void 0===i||i.dispose(),null===(s=this._copyMaterial)||void 0===s||s.dispose(),null===(a=this._blendMaterial)||void 0===a||a.dispose()}setSize(e,t){var n,r,i,s,a;this.width=e,this.height=t,null===(n=this._gBufferRenderTarget)||void 0===n||n.setSize(e,t),this.shadowAndAoRenderTargets.setSize(e,t),null===(r=this._ssaoEffect)||void 0===r||r.setSize(e,t),null===(i=this._hbaoEffect)||void 0===i||i.setSize(e,t),null===(s=this._fadeRenderTarget)||void 0===s||s.setSize(e,t),null===(a=this.poissonDenoiseEffect)||void 0===a||a.setSize(this.width,this.height),this._renderOverrideVisibility=new Eo,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,n,r;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===(n=this._ssaoEffect)||void 0===n||n.updateParameters(null==e?void 0:e.hbao)),(null==e?void 0:e.poissonDenoise)&&(null===(r=this.poissonDenoiseEffect)||void 0===r||r.updateParameters(null==e?void 0:e.poissonDenoise))}updateBounds(e,t){this.shadowAndAoRenderTargets.updateBounds(e,t)}render(e,t,n,r,i=_l.FULL,s=_l.FULL,a=0){if(!this.setRenderState())return;let o=!1;const l=s===_l.POISSON&&a>.001,h=s===_l.HARD&&a>.001&&a<.999,d=s===_l.HARD&&!h;!d&&i===_l.FULL&&this.evaluateIfUpdateIsNeeded(n)&&(this.renderShadowAndAo(e,t,n,r),o=!0);let c=d?r:this.denoiseRenderTargetTexture;l&&(c=this.renderDynamicShadow(e,this.shadowAndAoRenderTargets.passRenderTarget.texture,r,a),o=!0),o&&(c=this.renderDenoise(e,n,l)),h&&(c=this.renderDynamicShadow(e,this.denoiseRenderTargetTexture,r,a)),this.renderToTarget(e,c,d)}setRenderState(){return this.shadowAndAoRenderTargets.aoEnabled=this.parameters.aoType===yl.SSAO,this.shadowAndAoRenderTargets.shadowEnabled=this.parameters.shadowIntensity>.01,!(!this.parameters.enabled||this.parameters.aoType===yl.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,n,r){this.shadowAndAoRenderTargets.updateShadowTexture(r),this.gBufferRenderTarget.render(e,t,n),this.shadowAndAoRenderTargets.render(e,n),this.renderAoEffect(e,t,n)}renderAoEffect(e,t,n){if(this.parameters.aoType!==yl.EffectsSSAO&&this.parameters.aoType!==yl.EffectsHBAO)return;const r=this.gBufferRenderTarget.depthBufferTexture,i=this.gBufferRenderTarget.gBufferTexture,s=this.shadowAndAoRenderTargets.passRenderTarget,a=e.autoClear;switch(e.autoClear=!1,this.parameters.aoType){default:break;case yl.EffectsSSAO:{const a=this.SSAOEffect;a.depthTexture=r,a.normalTexture=i,a.render(e,n,t,s)}break;case yl.EffectsHBAO:{const a=this.HBAOEffect;a.depthTexture=r,a.normalTexture=i,a.render(e,n,t,s)}}e.autoClear=a}renderDynamicShadow(e,t,n,r=1){const i=r<.999;return i&&(this._copyMaterial.update({texture:t,blending:ht,colorTransform:co,multiplyChannels:0}),this.renderPass.renderScreenSpace(e,this._copyMaterial,this.fadeRenderTarget)),r>.001&&(this._blendMaterial.update({texture:n,blending:i?kt:ht,colorTransform:(new S).set(0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,i?r:1),multiplyChannels:0}),this.renderPass.renderScreenSpace(e,this._blendMaterial,this.fadeRenderTarget)),this.fadeRenderTarget.texture}renderDenoise(e,t,n){return this.denoisePass.inputTexture=n?this.fadeRenderTarget.texture:this.shadowAndAoRenderTargets.passRenderTarget.texture,this.denoisePass.render(e,t),this.denoisePass.texture}renderToTarget(e,t,n){const r=n?this.parameters.shadowIntensity:this.parameters.aoIntensity,i=n?0:this.parameters.shadowIntensity;var s,a;this.renderPass.renderScreenSpace(e,this._copyMaterial.update({texture:t,blending:kt,colorTransform:(s=r,a=i,(new S).set(s,0,0,1-s,0,a,0,1-a,0,0,0,1,0,0,0,1)),multiplyChannels:1}),e.getRenderTarget())}}Cl.shadowTransform=(new S).set(0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,1);class Ml{get passRenderTarget(){var e;return this._passRenderTarget=null!==(e=this._passRenderTarget)&&void 0!==e?e:new ct(this.width,this.height,{samples:this.aoTargetSamples,format:Lt,magFilter:E,minFilter:E}),this._passRenderTarget}get passRenderMaterial(){var e;return this._passRenderMaterial=null!==(e=this._passRenderMaterial)&&void 0!==e?e:new Tl({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 n=Math.floor(t/2)+t%2*8,r=2*Math.PI*n/16,i=new a(Math.cos(r),Math.sin(r),0).normalize();e[4*t]=255*(.5*i.x+.5),e[4*t+1]=255*(.5*i.y+.5),e[4*t+2]=127,e[4*t+3]=0}const t=new be(e,4,4);return t.wrapS=k,t.wrapT=k,t.needsUpdate=!0,t})(),this._noiseTexture}get sampleKernel(){return this._sampleKernel.length||(this._sampleKernel=(e=>{const t=[];for(let n=0;n<e;n++){const r=n*Math.PI*(3-Math.sqrt(5)),i=.99-n/(e-1)*.8,s=Math.sqrt(1-i*i),o=Math.cos(r)*s,l=Math.sin(r)*s,h=8,d=Math.floor(e/h);let c=1-(Math.floor(n/h)+n%h*d)/e;c=X.lerp(.1,1,c*c),t.push(new a(o*c,l*c,i*c))}return t})(Tl.kernelSize)),this._sampleKernel}constructor(e,t){var n,r,i,s;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!==(n=null==t?void 0:t.width)&&void 0!==n?n:1024,this.height=null!==(r=null==t?void 0:t.height)&&void 0!==r?r:1024,this.samples=null!==(i=null==t?void 0:t.samples)&&void 0!==i?i:0,this.depthAndNormalTextures=e,this.renderPass=null!==(s=null==t?void 0:t.renderPass)&&void 0!==s?s:new Io}getShadowAndAoParameters(e){return{...xl,...e}}dispose(){var e,t,n;null===(e=this._noiseTexture)||void 0===e||e.dispose(),null===(t=this._passRenderMaterial)||void 0===t||t.dispose(),null===(n=this._passRenderTarget)||void 0===n||n.dispose()}setSize(e,t){var n;this.width=e,this.height=t,null===(n=this._passRenderMaterial)||void 0===n||n.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 Tl extends rt{constructor(e){var t,n;super({defines:Object.assign({...Tl.shader.defines,KERNEL_SIZE:null!==(n=null===(t=null==e?void 0:e.sampleKernel)||void 0===t?void 0:t.length)&&void 0!==n?n:Tl.kernelSize,FLOAT_GBUFFER_RGB_NORMAL_ALPHA_DEPTH:(null==e?void 0:e.floatGBufferRgbNormalAlphaDepth)?1:0}),uniforms:lt.clone(Tl.shader.uniforms),vertexShader:Tl.shader.vertexShader,fragmentShader:Tl.shader.fragmentShader,blending:ht}),this.update(e)}update(e){return this.updateDependencies(e),this.updateSettings(e),this}updateDependencies(e){var t,n;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 r=null!==(t=null==e?void 0:e.width)&&void 0!==t?t:this.uniforms.resolution.value.x,i=null!==(n=null==e?void 0:e.width)&&void 0!==n?n:this.uniforms.resolution.value.y;this.uniforms.resolution.value.set(r,i)}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)}}Tl.kernelSize=32,Tl.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 s},cameraProjectionMatrix:{value:new S},cameraInverseProjectionMatrix:{value:new S},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:Tl.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 Al{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,n){var r;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,...n},this._copyMaterial=new yo({}),this.updateCopyMaterial(null),this.reflectionIntensityMaterial=new Pl,this.blurPass=new ko(xo,n),this.renderPass=null!==(r=null==n?void 0:n.renderPass)&&void 0!==r?r:new Io}newRenderTarget(e){const t=this.width/this.parameters.renderTargetDownScale,n=this.height/this.parameters.renderTargetDownScale;let r={};if(e){const e=new ut(t,n);e.format=pt,e.type=mt,r.minFilter=$,r.magFilter=$,r.depthTexture=e}else r.samples=1;return new ct(t,n,{format:we,...r})}dispose(){var e,t,n;null===(e=this._reflectionRenderTarget)||void 0===e||e.dispose(),null===(t=this._intensityRenderTarget)||void 0===t||t.dispose(),null===(n=this._blurRenderTarget)||void 0===n||n.dispose(),this._copyMaterial.dispose()}setSize(e,t){var n,r,i;this.width=e,this.height=t,null===(n=this._reflectionRenderTarget)||void 0===n||n.setSize(this.width/this.parameters.renderTargetDownScale,this.height/this.parameters.renderTargetDownScale),null===(r=this._intensityRenderTarget)||void 0===r||r.setSize(this.width/this.parameters.renderTargetDownScale,this.height/this.parameters.renderTargetDownScale),null===(i=this._blurRenderTarget)||void 0===i||i.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 n;const r=this.parameters.intensity*t,i=this.parameters.brightness;this._copyMaterial.update({texture:null!==(n=null==e?void 0:e.texture)&&void 0!==n?n:void 0,colorTransform:(new S).set(i,0,0,0,0,i,0,0,0,0,i,0,0,0,0,r),multiplyChannels:0,uvTransform:bo}),this._copyMaterial.depthTest=!0,this._copyMaterial.depthWrite=!1}render(e,t,n,r=1){if(!(this.parameters.enabled&&n instanceof W))return;const i=this.createGroundReflectionCamera(n);this.renderGroundReflection(e,t,i,this.reflectionRenderTarget),this.renderGroundReflectionIntensity(e,i,this.intensityRenderTarget),(this.parameters.blurHorizontal>0||this.parameters.blurVertical>0)&&this.blurReflection(e,n,[this.intensityRenderTarget,this.blurRenderTarget,this.intensityRenderTarget]),this.updateCopyMaterial(this.intensityRenderTarget,r),this.renderPass.renderScreenSpace(e,this._copyMaterial,e.getRenderTarget())}renderGroundReflection(e,t,n,r){const i=e.getRenderTarget();r&&e.setRenderTarget(r),e.render(t,n),r&&e.setRenderTarget(i)}renderGroundReflectionIntensity(e,t,n){const r=e.getRenderTarget();e.setRenderTarget(n),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(r)}blurReflection(e,t,n){const r=new a(t.matrixWorld.elements[4],t.matrixWorld.elements[5],t.matrixWorld.elements[6]),i=this.parameters.blurHorizontal/this.width,s=this.parameters.blurVertical/this.height*Math.abs(r.dot(new a(0,0,1)));this.blurPass.render(e,n,[4*i,4*s],[4*i*(1+this.parameters.blurAscent),4*s*(1+this.parameters.blurAscent)])}createGroundReflectionCamera(e){const t=e.clone(),n=t;return n._offset&&(n._offset={left:n._offset.left,top:1-n._offset.bottom,right:n._offset.right,bottom:1-n._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 Pl extends rt{constructor(e){super({defines:Object.assign({},Pl.shader.defines),uniforms:lt.clone(Pl.shader.uniforms),vertexShader:Pl.shader.vertexShader,fragmentShader:Pl.shader.fragmentShader,blending:ht}),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}}Pl.shader={uniforms:{tDiffuse:{value:null},tDepth:{value:null},resolution:{value:new s},cameraNear:{value:.1},cameraFar:{value:1},cameraProjectionMatrix:{value:new S},cameraInverseProjectionMatrix:{value:new S},inverseViewMatrix:{value:new S},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 Rl=e=>{const t=Math.atan2(e.y,e.x)/(2*Math.PI)+.5,n=Math.asin(e.z)/Math.PI+.5;return new s(t,n)};class El{get colorRenderTarget(){var e;return this._colorRenderTarget=null!==(e=this._colorRenderTarget)&&void 0!==e?e:new ct,this._colorRenderTarget}get grayscaleRenderTarget(){var e;return this._grayscaleRenderTarget=null!==(e=this._grayscaleRenderTarget)&&void 0!==e?e:new ct,this._grayscaleRenderTarget}get grayscaleShaderMaterial(){var e;return this._grayscaleShaderMaterial=null!==(e=this._grayscaleShaderMaterial)&&void 0!==e?e:new kl,this._grayscaleShaderMaterial}get camera(){var e;return this._camera=null!==(e=this._camera)&&void 0!==e?e:new q(-1,1,1,-1,-1,1),this._camera}scaleTexture(e,t,n,r){var i;this.colorRenderTarget.setSize(n,r),this.planeMesh=null!==(i=this.planeMesh)&&void 0!==i?i:new z(new ft(2,2),new _({map:t}));const s=e.getRenderTarget();e.setRenderTarget(this.colorRenderTarget),e.render(this.planeMesh,this.camera),e.setRenderTarget(s);const a=this.grayscaleRenderTarget.texture,o=new Uint8Array(n*r*4);return e.readRenderTargetPixels(this.colorRenderTarget,0,0,n,r,o),{texture:a,pixels:o}}newGrayscaleTexture(e,t,n,r){var i;this.grayscaleRenderTarget.setSize(n,r),this.grayscaleShaderMaterial.setSourceTexture(t),this.planeMesh=null!==(i=this.planeMesh)&&void 0!==i?i:new z(new ft(2,2),this.grayscaleShaderMaterial);const s=e.getRenderTarget();e.setRenderTarget(this.grayscaleRenderTarget),e.render(this.planeMesh,this.camera),e.setRenderTarget(s);const a=this.grayscaleRenderTarget.texture,o=new Uint8Array(n*r*4);return e.readRenderTargetPixels(this.grayscaleRenderTarget,0,0,n,r,o),{texture:a,pixels:o}}}const Il={tDiffuse:{value:null}};class kl extends rt{constructor(){super({uniforms:lt.clone(Il),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 Ol{constructor(e){var t,n,r,i;this.samplePoints=[],this.sampleUVs=[],this.grayscaleTexture={texture:new le,pixels:new Uint8Array(0)},this.detectorTexture=new le,this.detectorArray=new Float32Array(0),this.lightSamples=[],this.lightGraph=new Ll(0),this.lightSources=[],this.createEquirectangularSamplePoints=e=>{const t=[];for(let n=0;n<e;n++){const r=n*Math.PI*(3-Math.sqrt(5)),i=1-n/(e-1)*2,s=Math.sqrt(1-i*i),o=Math.cos(r)*s,l=Math.sin(r)*s;t.push(new a(o,l,i))}return t},this.numberOfSamples=null!==(t=null==e?void 0:e.numberOfSamples)&&void 0!==t?t:1e3,this.width=null!==(n=null==e?void 0:e.width)&&void 0!==n?n:1024,this.height=null!==(r=null==e?void 0:e.height)&&void 0!==r?r:512,this.sampleThreshold=null!==(i=null==e?void 0:e.sampleThreshold)&&void 0!==i?i:.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=>Rl(e))}detectLightSources(e,t,n){var r;this.textureData=n,this.textureConverter=null!==(r=this.textureConverter)&&void 0!==r?r:new El,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 n=new Float32Array(e.length/4);let r=1,i=0;for(let t=0;t<e.length/4;++t){const s=e[4*t]/255;r=Math.min(r,s),i=Math.max(i,s),n[t]=s}if(t)for(let e=0;e<n.length;++e){const s=(n[e]-r)/(i-r);n[e]=Math.pow(s,t)}else for(let e=0;e<n.length;++e)n[e]=(n[e]-r)/(i-r);return n}grayscaleTextureFromFloatArray(e,t,n){const r=t*n,i=new Uint8Array(4*r);for(let t=0;t<r;t++){const n=255*e[t];i[4*t+0]=n,i[4*t+1]=n,i[4*t+2]=n,i[4*t+3]=255}const s=new be(i,t,n);return s.needsUpdate=!0,s}filterLightSamples(e){const t=[];for(let n=0;n<this.sampleUVs.length;n++){const r=this.sampleUVs[n];this.detectorTextureLuminanceValueFromUV(r)>e&&t.push(new Dl(this.samplePoints[n],r))}return t}detectorTextureLuminanceValueFromUV(e){const t=Math.floor(e.x*this.width),n=Math.floor(e.y*this.height)*this.width+t;return this.detectorArray[n]}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),n=Math.floor(e.y*this.textureData.height);let r=0;for(let e=Math.max(0,t-2);e<Math.max(0,t+2);++e)for(let t=Math.max(0,n-2);t<Math.max(0,n+2);++t){const n=t*this.textureData.width+e,i=(this.textureData.data[4*n]+this.textureData.data[4*n+1]+this.textureData.data[4*n+2])/3;r=Math.max(r,i)}return r}findClusterSegments(e,t){const n=2*this.pixelDistance,r=1.5*this.pointDistance,i=new Ll(e.length);for(let s=0;s<e.length;s++)for(let a=s+1;a<e.length;a++)if(e[s].position.angleTo(e[a].position)<r){const r=e[a].position.clone().sub(e[s].position),o=Math.floor(r.length()/n);let l=!0,h=0;for(let n=1;n<o;n++){const i=r.clone().multiplyScalar(n/o),a=Rl(e[s].position.clone().add(i).normalize());if(this.detectorTextureLuminanceValueFromUV(a)<t){if(h++,h>1){l=!1;break}}else h=0}l&&(i.adjacent[s].push(a),i.adjacent[a].push(s),i.edges.push([s,a]))}return i}createLightSourcesFromLightGraph(e,t){const n=t.components.filter(e=>e.length>1).map(t=>new Ul(t.map(t=>e[t])));return n.forEach(e=>e.calculateLightSourceProperties(e=>this.originalLuminanceValueFromUV(e))),n}}class Dl{constructor(e,t){this.position=e,this.uv=t}}class Ll{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 n=[];this.dfs(t,e,n),this.components.push(n)}this.components.sort((e,t)=>t.length-e.length)}dfs(e,t,n){t[e]=!0,n.push(e);for(const r of this.adjacent[e])t[r]||this.dfs(r,t,n)}}class Ul{constructor(e){this.position=new a,this.uv=new s,this.averageIntensity=0,this.maxIntensity=0,this.size=0,this.lightSamples=e}calculateLightSourceProperties(e){this.position=new a,this.averageIntensity=0,this.maxIntensity=0;for(const t of this.lightSamples){this.position.add(t.position);const n=e(t.uv);this.averageIntensity+=n,this.maxIntensity=Math.max(this.maxIntensity,n)}this.averageIntensity/=this.lightSamples.length,this.position.normalize(),this.uv=Rl(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 Fl{constructor(e){this.grayMaterial=hr.createMeshStandardMaterial({color:12632256,side:F,envMapIntensity:.4}),this.renderPass=new Io,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 yo,this.copyMaterial.update(e)}getDepthRenderMaterial(e){var t;return this.depthRenderMaterial=null!==(t=this.depthRenderMaterial)&&void 0!==t?t:new So({depthTexture:this.gBufferRenderTarget.textureWithDepthValue,depthFilter:this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?new tt(0,0,0,1):new tt(1,0,0,0)}),this.depthRenderMaterial.update({camera:e})}render(e,t,n){var r,i,s,a;switch(n){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===(r=this.gBufferRenderTarget)||void 0===r?void 0:r.gBufferTexture,blending:ht,colorTransform:(new S).set(.5,0,0,0,0,.5,0,0,0,0,.5,0,0,0,0,0),colorBase:new tt(.5,.5,.5,1),multiplyChannels:0,uvTransform:wo}),null):this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:null===(i=this.gBufferRenderTarget)||void 0===i?void 0:i.gBufferTexture,blending:ht,colorTransform:uo,colorBase:vo,multiplyChannels:0,uvTransform:wo}),null);break;case"g-depth":this.gBufferRenderTarget.isFloatGBufferWithRgbNormalAlphaDepth?this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:null===(s=this.gBufferRenderTarget)||void 0===s?void 0:s.gBufferTexture,blending:ht,colorTransform:po,colorBase:vo,multiplyChannels:0,uvTransform:wo}),null):this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:null===(a=this.gBufferRenderTarget)||void 0===a?void 0:a.depthBufferTexture,blending:ht,colorTransform:mo,colorBase:vo,multiplyChannels:0,uvTransform:wo}),null);break;case"ssao":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.shadowAndAoPass.shadowAndAoRenderTargets.passRenderTarget.texture,blending:ht,colorTransform:fo,colorBase:go,multiplyChannels:0,uvTransform:wo}),null);break;case"ssaodenoise":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.shadowAndAoPass.denoiseRenderTargetTexture,blending:ht,colorTransform:fo,colorBase:go,multiplyChannels:0,uvTransform:wo}),null);break;case"shadowmap":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.screenSpaceShadow.shadowTexture,blending:ht,colorTransform:fo,colorBase:go,multiplyChannels:0,uvTransform:wo}),null);break;case"shadow":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.shadowAndAoPass.shadowAndAoRenderTargets.passRenderTarget.texture,blending:ht,colorTransform:Cl.shadowTransform,colorBase:go,multiplyChannels:0,uvTransform:wo}),null);break;case"shadowblur":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.shadowAndAoPass.denoiseRenderTargetTexture,blending:ht,colorTransform:Cl.shadowTransform,colorBase:go,multiplyChannels:0,uvTransform:wo}),null);break;case"shadowfadein":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.shadowAndAoPass.fadeRenderTarget.texture,blending:ht,colorTransform:Cl.shadowTransform,colorBase:go,multiplyChannels:0,uvTransform:wo}),null);break;case"groundreflection":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.groundReflectionPass.reflectionRenderTarget.texture,blending:ht,colorTransform:co,colorBase:go,multiplyChannels:0,uvTransform:bo}),null);break;case"bakedgroundshadow":this.renderPass.renderScreenSpace(e,this.getCopyMaterial({texture:this.bakedGroundContactShadow.renderTarget.texture,blending:ht,colorTransform:co,colorBase:go,multiplyChannels:0,uvTransform:wo}),null)}}}var Bl;!function(e){e[e.HIGHEST=0]="HIGHEST",e[e.HIGH=1]="HIGH",e[e.MEDIUM=2]="MEDIUM",e[e.LOW=3]="LOW"}(Bl||(Bl={}));class Nl{constructor(e,t,n){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 Ro,this.width=0,this.height=0,this.maxSamples=1,this.cameraChanged=!0,this.boundingVolume=new Po,this.boundingVolumeSet=!1,this.debugRenderOverrideVisibility=new Eo(!0),this.invisibleGroundOverrideVisibility=new Eo(!0,e=>e===this.groundGroup),this.renderPass=new Io,this.selectedObjects=[],this.groundGroup=new K,this.qualityLevel=Bl.HIGHEST,this.qualityMap=new Map,this.width=t,this.height=n,this.maxSamples=e.capabilities.maxSamples,this.renderer=e,this.gBufferRenderTarget=new Oo({shared:!0,capabilities:e.capabilities,width:this.width,height:this.height,samples:1,renderPass:this.renderPass,textureFilter:$}),this.shadowAndAoPass=new Cl(this.width,this.height,1,{gBufferRenderTarget:this.gBufferRenderTarget}),this.screenSpaceShadow=new Wo(new s(this.width,this.height),{samples:this.maxSamples,alwaysUpdate:!1}),this.groundReflectionPass=new Al(this.width,this.height,{renderPass:this.renderPass}),this.bakedGroundContactShadow=new Do(this.renderer,this.groundGroup,{renderPass:this.renderPass}),this.groundGroup.rotateX(-Math.PI/2),this.outlineRenderer=new zo(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:_l.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 yo,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,n){const r=new Ol;r.detectLightSources(this.renderer,t,n),this.createShadowFromLightSources(e,r.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 n=this.boundingVolume.size,r=(n.x+n.y+n.z)/3,i=Math.min(n.x,n.y,n.z),s=Math.max(n.x,n.y,n.z),a=i<.5?i/.5:n.z>5?n.z/5:1;this.bakedGroundContactShadow.setScale(t?r:a,r),this.groundReflectionPass.updateBounds(this.groundLevel,Math.min(1,s)),this.screenSpaceShadow.updateBounds(this.boundingVolume,r),this.shadowAndAoPass.updateBounds(this.boundingVolume,t?r:Math.min(1,2*s))}updateNearAndFarPlaneOfPerspectiveCamera(e,t){const n=this.boundingVolume.getNearAndFarForPerspectiveCamera(e.position,3);e.near=Math.max(1e-5,.9*n[0]),e.far=Math.max(null!=t?t:e.near,n[1]),e.updateProjectionMatrix()}setRenderState(e,t){var n;const r=this.debugOutput!==this.prevDebugOutput;this.prevDebugOutput=this.debugOutput,this.screenSpaceShadow.parameters.alwaysUpdate=this.shadowAndAoPass.parameters.alwaysUpdate,this.cameraChanged=this.cameraUpdate.changed(t),(n=this.gBufferRenderTarget).needsUpdate||(n.needsUpdate=this.cameraChanged||r)}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 n;if(!(null===(n=t.userData)||void 0===n?void 0:n.equirectangularEnvironmentMap))return;e.userData||(e.userData={});const r=e.userData;if(r&&(!r.environmentTexture||r.equirectangularEnvironmentMap!==t.userData.equirectangularEnvironmentMap)){r.equirectangularEnvironmentMap=t.userData.equirectangularEnvironmentMap;const n=new Ut(e).fromEquirectangular(r.equirectangularEnvironmentMap);r.environmentTexture=n.texture}t.environment=null==r?void 0:r.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 Fl(this),this.debugPass.render(this.renderer,e,this.debugOutput))}renderScene(e,t,n){var r;const i=new Set;t.traverse(e=>{var t;(null===(t=e.userData)||void 0===t?void 0:t.isFloor)&&e instanceof z&&e.material instanceof U&&e.material.depthWrite&&(i.add(e.material),e.material.depthWrite=!1)}),"grayscale"===this.debugOutput?(this.debugPass=null!==(r=this.debugPass)&&void 0!==r?r:new Fl(this),this.debugRenderOverrideVisibility.render(t,()=>{var r;this.renderPass.renderWithOverrideMaterial(e,t,n,null===(r=this.debugPass)||void 0===r?void 0:r.grayMaterial,null,0,1)})):(this.bakedGroundContactShadow.setGroundVisibility(!0,n),e.render(t,n),this.bakedGroundContactShadow.setGroundVisibility(!1,n)),i.forEach(e=>e.depthWrite=!0),this.renderShadowAndAo(e,t,n)}renderShadowAndAo(e,t,n){const r=this.evaluateIfShadowAndAoUpdateIsNeeded(n);if(r.needsUpdate||r.shadowOnCameraChange!==_l.OFF){if(!this.parameters.suspendGroundReflection||r.needsUpdate){const i=this.parameters.suspendGroundReflection?r.intensityScale:1;this.renderGroundReflection(e,t,n,i)}this.gBufferRenderTarget.needsUpdate=r.needsUpdate||r.shadowOnCameraChange===_l.POISSON,this.renderEffectsWithGround(e,t,n),this.renderEffectsWithoutGround(e,t,n),this.shadowAndAoPass.render(e,t,n,this.screenSpaceShadow.shadowTexture,r.needsUpdate?_l.FULL:r.shadowOnCameraChange,r.shadowOnCameraChange,1-r.intensityScale)}}evaluateIfShadowAndAoUpdateIsNeeded(e){const t=this.shadowAndAoPass.parameters.alwaysUpdate||this.screenSpaceShadow.needsUpdate||this.screenSpaceShadow.shadowTypeNeedsUpdate;let n=(this.shadowAndAoPass.parameters.enabled||this.groundReflectionPass.parameters.enabled)&&(0===this.parameters.effectSuspendFrames||this.cameraChanged);n&&(this.noUpdateNeededCount=0);let r=1;return!t&&this.parameters.effectSuspendFrames>0&&(this.noUpdateNeededCount++,n=this.noUpdateNeededCount>=this.parameters.effectSuspendFrames,r=Math.max(0,Math.min(1,(this.noUpdateNeededCount-this.parameters.effectSuspendFrames)/this.parameters.effectFadeInFrames))),n=t||n,{needsUpdate:n,shadowOnCameraChange:!n||r<.99?this.parameters.shadowOnCameraChange:_l.OFF,intensityScale:r}}renderGroundReflection(e,t,n,r=1){this.groundReflectionPass.parameters.enabled&&this.invisibleGroundOverrideVisibility.render(t,()=>{this.groundReflectionPass.render(e,t,n,r)})}renderEffectsWithGround(e,t,n){const r=this.boundingVolumeSet&&this.shadowAndAoPass.parameters.aoOnGround,i=this.shadowAndAoPass.parameters.shadowIntensity>0&&this.boundingVolumeSet&&this.shadowAndAoPass.parameters.shadowOnGround,s=this.bakedGroundContactShadow.shadowGroundPlane;if(r){const r=null===this.bakedGroundContactShadow.parameters.hardLayers;r&&s.setDepthWrite(!0),this.gBufferRenderTarget.render(e,t,n),r&&s.setDepthWrite(!1)}i&&(s.setReceiveShadow(!0),this.screenSpaceShadow.renderShadowMap(e,t,n),s.setReceiveShadow(!1))}renderEffectsWithoutGround(e,t,n){const r=!this.boundingVolumeSet||!this.shadowAndAoPass.parameters.aoOnGround,i=this.shadowAndAoPass.parameters.shadowIntensity>0&&(!this.boundingVolumeSet||!this.shadowAndAoPass.parameters.shadowOnGround);(r||i)&&this.invisibleGroundOverrideVisibility.render(t,()=>{r&&this.gBufferRenderTarget.render(e,t,n),i&&this.screenSpaceShadow.renderShadowMap(e,t,n)})}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 zl{constructor(e){this.qualityLevel="",this.ambientOcclusionType="",this.sceneRenderer=e}addGUI(e,t){this.addRepresentationalGUI(e,t),this.addDebugGUI(e,t);const n=e.addFolder("Shadow type");this.addShadowTypeGUI(n,t);const r=e.addFolder("Shadow and Ambient Occlusion");this.addShadowAndAoGUI(r,t);const i=e.addFolder("Ground Reflection");this.addGroundReflectionGUI(i,t);const s=e.addFolder("Baked Ground Contact Shadow");this.addBakedGroundContactShadowGUI(s,t);const a=e.addFolder("Outline");this.addOutlineGUI(a,t)}addRepresentationalGUI(e,t){const n=new Map([["LinearSRGBColorSpace",fe],["SRGBColorSpace",y]]),r=[];n.forEach((e,t)=>{r.push(t),this.sceneRenderer.renderer.outputColorSpace===e&&(this.sceneRenderer.outputColorSpace=t)}),e.add(this.sceneRenderer,"outputColorSpace",r).onChange(e=>{var r;n.has(e)&&(this.sceneRenderer.renderer.outputColorSpace=null!==(r=n.get(e))&&void 0!==r?r:y,t())});const i=new Map([["NoToneMapping",Ft],["LinearToneMapping",Bt],["ReinhardToneMapping",Nt],["CineonToneMapping",zt],["ACESFilmicToneMapping",Ht]]),s=[];i.forEach((e,t)=>{s.push(t),this.sceneRenderer.renderer.toneMapping===e&&(this.sceneRenderer.toneMapping=t)}),e.add(this.sceneRenderer,"toneMapping",s).onChange(e=>{var n;i.has(e)&&(this.sceneRenderer.renderer.toneMapping=null!==(n=i.get(e))&&void 0!==n?n:Ft,t())})}addDebugGUI(e,t){const n=new Map([["HIGHEST",Bl.HIGHEST],["HIGH",Bl.HIGH],["MEDIUM",Bl.MEDIUM],["LOW",Bl.LOW]]),r=[];n.forEach((e,t)=>r.push(t)),e.add(this,"qualityLevel",r).onChange(e=>{var t;n.has(e)&&this.sceneRenderer.setQualityLevel(null!==(t=n.get(e))&&void 0!==t?t:Bl.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 n=this.sceneRenderer.screenSpaceShadow.shadowConfiguration,r=[];n.types.forEach((e,t)=>{r.push(t)});const i=()=>{this.sceneRenderer.screenSpaceShadow.needsUpdate=!0,this.sceneRenderer.screenSpaceShadow.shadowTypeNeedsUpdate=!0,this.sceneRenderer.shadowAndAoPass.needsUpdate=!0,t()};e.add(n,"shadowType",r).onChange(e=>{this.sceneRenderer.screenSpaceShadow.switchType(e)&&(s.object=n.currentConfiguration,a.object=n.currentConfiguration,o.object=n.currentConfiguration,s.updateDisplay(),a.updateDisplay(),o.updateDisplay(),i())});const s=e.add(n.currentConfiguration,"bias",-.001,.001,1e-5).onChange(()=>i()),a=e.add(n.currentConfiguration,"normalBias",-.05,.05).onChange(()=>i()),o=e.add(n.currentConfiguration,"radius",0,100).onChange(()=>i())}addShadowAndAoGUI(e,t){const n=()=>{this.sceneRenderer.gBufferRenderTarget.needsUpdate=!0,this.sceneRenderer.screenSpaceShadow.needsUpdate=!0,this.sceneRenderer.shadowAndAoPass.needsUpdate=!0,this.sceneRenderer.shadowAndAoPass.shadowAndAoRenderTargets.parametersNeedsUpdate=!0,t()},r=this.sceneRenderer.shadowAndAoPass.parameters,i=r.shAndAo,s=this.sceneRenderer.screenSpaceShadow.parameters,a=r.ssao,o=r.hbao,l=r.poissonDenoise;e.add(r,"enabled").onChange(()=>n());const h=new Map([["none",yl.NONE],["SSAO",yl.SSAO],["effects SSAO",yl.EffectsSSAO],["effects HBAO",yl.EffectsHBAO]]),d=Array.from(h.keys());h.forEach((e,t)=>{e===r.aoType&&(this.ambientOcclusionType=t)}),e.add(this,"ambientOcclusionType",d).onChange(e=>{var t;h.has(e)&&(r.aoType=null!==(t=h.get(e))&&void 0!==t?t:yl.SSAO,n())}),e.add(r,"aoIntensity",0,1).onChange(()=>{n()}),e.add(r,"aoOnGround").onChange(()=>{n()}),e.add(r,"shadowOnGround").onChange(()=>{n()}),e.add(r,"shadowIntensity",0,1).onChange(()=>n()),e.add(r,"alwaysUpdate").onChange(()=>n());const c=e.addFolder("Shadow and Monte Carlo integration");c.add(s,"maximumNumberOfLightSources").onChange(()=>n()),c.add(s,"fadeOutDistance",0,1).onChange(()=>n()),c.add(s,"fadeOutBlur",0,100).onChange(()=>n()),c.add(i,"shadowRadius",.001,.5).onChange(()=>n());const u=e.addFolder("Roomle SSAO");u.add(i,"aoFadeout",0,1).onChange(()=>n()),u.add(i,"aoKernelRadius",.001,1).onChange(()=>n()),u.add(i,"aoDepthBias",1e-4,.01).onChange(()=>n()),u.add(i,"aoMaxDistance",.01,1).onChange(()=>n()),u.add(i,"aoMaxDepth",.9,1).onChange(()=>n());const p=e.addFolder("effects SSAO");p.add(a,"resolutionScale",.25,1,.25).onChange(()=>n()),p.add(a,"spp",1,64,1).onChange(()=>n()),p.add(a,"distance",.1,10,.1).onChange(()=>n()),p.add(a,"distancePower",0,2,.125).onChange(()=>n()),p.add(a,"bias",0,500,1).onChange(()=>n()),p.add(a,"power",.5,32,.5).onChange(()=>n()),p.add(a,"thickness",0,.1,.001).onChange(()=>n());const m=e.addFolder("effects HBAO");m.add(o,"resolutionScale",.25,1,.2).onChange(()=>n()),m.add(o,"spp",1,64,1).onChange(()=>n()),m.add(o,"distance",.1,10,.01).onChange(()=>n()),m.add(o,"distancePower",.1,10,.1).onChange(()=>n()),m.add(o,"bias",0,100,1).onChange(()=>n()),m.add(o,"power",.5,8,.5).onChange(()=>n()),m.add(o,"thickness",0,.1,.001).onChange(()=>n());const f=e.addFolder("Possion Denoise");f.add(l,"iterations",0,3,1).onChange(()=>n()),f.add(l,"radius",0,32,1).onChange(()=>n()),f.add(l,"rings",0,16,.125).onChange(()=>n()),f.add(l,"samples",0,32,1).onChange(()=>n()),f.add(l,"lumaPhi",0,20,.001).onChange(()=>n()),f.add(l,"depthPhi",0,20,.001).onChange(()=>n()),f.add(l,"normalPhi",0,20,.001).onChange(()=>n())}addGroundReflectionGUI(e,t){const n=this.sceneRenderer.parameters.groundReflectionParameters;e.add(n,"enabled"),e.add(n,"intensity",0,1).onChange(()=>t()),e.add(n,"fadeOutDistance",0,4).onChange(()=>t()),e.add(n,"fadeOutExponent",.1,10).onChange(()=>t()),e.add(n,"brightness",0,2).onChange(()=>t()),e.add(n,"blurHorizontal",0,10).onChange(()=>t()),e.add(n,"blurVertical",0,10).onChange(()=>t())}addBakedGroundContactShadowGUI(e,t){const n=()=>{this.sceneRenderer.bakedGroundContactShadow.applyParameters(),t()},r=this.sceneRenderer.parameters.bakedGroundContactShadowParameters;e.add(r,"enabled"),e.add(r,"cameraHelper").onChange(()=>n()),e.add(r,"alwaysUpdate"),e.add(r,"fadeIn"),e.add(r,"blurMin",0,.2,.001).onChange(()=>n()),e.add(r,"blurMax",0,.5,.01).onChange(()=>n()),e.add(r,"fadeoutFalloff",0,1,.01).onChange(()=>n()),e.add(r,"fadeoutBias",0,.5).onChange(()=>n()),e.add(r,"opacity",0,1,.01).onChange(()=>n()),e.add(r,"cameraFar",.1,10,.1).onChange(()=>n())}addOutlineGUI(e,t){const n=()=>{this.sceneRenderer.outlineRenderer.applyParameters(),t()},r=this.sceneRenderer.outlineRenderer.parameters;e.add(r,"enabled"),e.add(r,"edgeStrength",.5,20).onChange(()=>n()),e.add(r,"edgeGlow",0,20).onChange(()=>n()),e.add(r,"edgeThickness",.5,20).onChange(()=>n()),e.add(r,"pulsePeriod",0,5).onChange(()=>n()),e.addColor(r,"visibleEdgeColor").onChange(()=>n()),e.addColor(r,"hiddenEdgeColor").onChange(()=>n())}}const Hl={effectSuspendFrames:0,effectFadeInFrames:0,suspendGroundReflection:!1,shadowOnCameraChange:_l.FULL},jl={effectSuspendFrames:5,effectFadeInFrames:5,suspendGroundReflection:!1,shadowOnCameraChange:_l.POISSON},Vl={effectSuspendFrames:5,effectFadeInFrames:5,suspendGroundReflection:!0,shadowOnCameraChange:_l.HARD},Gl=e("a4",new Map([[Bl.HIGHEST,{...Hl,shAndAoPassParameters:{enabled:!0,aoOnGround:!0,shadowOnGround:!0},groundReflectionParameters:{enabled:!0},bakedGroundContactShadowParameters:{enabled:!1}}],[Bl.HIGH,{...jl,shAndAoPassParameters:{enabled:!0,aoOnGround:!0,shadowOnGround:!0},groundReflectionParameters:{enabled:!0},bakedGroundContactShadowParameters:{enabled:!1}}],[Bl.MEDIUM,{...Vl,shAndAoPassParameters:{enabled:!0,aoOnGround:!0,shadowOnGround:!0},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:{enabled:!1}}],[Bl.LOW,{shAndAoPassParameters:{enabled:!1,aoOnGround:!1,shadowOnGround:!1},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:{enabled:!0}}]])),Kl=new jt;Kl.enable(3);const Wl=new jt;Wl.disableAll(),Wl.enable(9);const Xl={enabled:!0,aoType:yl.SSAO,aoIntensity:.5,shadowIntensity:0,aoOnGround:!0,shadowOnGround:!1},ql={enabled:!0,aoType:yl.EffectsHBAO,aoIntensity:.5,shadowIntensity:0,aoOnGround:!0,shadowOnGround:!1},Ql=ql,Yl={enabled:!0,fadeoutFalloff:.9,blurMax:.1,opacity:.5,hardLayers:null,softLayers:null,polygonOffset:2},Zl={enabled:!0,fadeoutFalloff:.8,blurMax:.15,opacity:.5,hardLayers:Wl,softLayers:null,polygonOffset:-1},Jl={enabled:!1},$l=new Map([[Bl.HIGHEST,{...Hl,shAndAoPassParameters:Xl,screenSpaceShadowMapParameters:{layers:Kl},groundReflectionParameters:{enabled:!0},bakedGroundContactShadowParameters:Yl}],[Bl.HIGH,{...jl,shAndAoPassParameters:Xl,screenSpaceShadowMapParameters:{layers:Kl},groundReflectionParameters:{enabled:!0},bakedGroundContactShadowParameters:Yl}],[Bl.MEDIUM,{...Vl,shAndAoPassParameters:Xl,screenSpaceShadowMapParameters:{layers:Kl},groundReflectionParameters:{enabled:!0},bakedGroundContactShadowParameters:Yl}],[Bl.LOW,{shAndAoPassParameters:{enabled:!1,aoOnGround:!1,shadowOnGround:!1},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:Yl}]]),eh=new Map([[Bl.HIGHEST,{...Hl,shAndAoPassParameters:ql,screenSpaceShadowMapParameters:{layers:Kl},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:Zl}],[Bl.HIGH,{...jl,shAndAoPassParameters:ql,screenSpaceShadowMapParameters:{layers:Kl},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:Zl}],[Bl.MEDIUM,{...Vl,shAndAoPassParameters:ql,screenSpaceShadowMapParameters:{layers:Kl},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:Zl}],[Bl.LOW,{shAndAoPassParameters:{enabled:!1,aoOnGround:!1,shadowOnGround:!1},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:Zl}]]),th=new Map([[Bl.HIGHEST,{...Hl,shAndAoPassParameters:Ql,screenSpaceShadowMapParameters:{layers:Kl},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:Jl}],[Bl.HIGH,{...jl,shAndAoPassParameters:Ql,screenSpaceShadowMapParameters:{layers:Kl},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:Jl}],[Bl.MEDIUM,{...Vl,shAndAoPassParameters:Ql,screenSpaceShadowMapParameters:{layers:Kl},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:Jl}],[Bl.LOW,{shAndAoPassParameters:{enabled:!1,aoOnGround:!1,shadowOnGround:!1},groundReflectionParameters:{enabled:!1},bakedGroundContactShadowParameters:Jl}]]);class nh{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 rh;e("ad",rh),function(e){e[e.Mode3D=0]="Mode3D",e[e.Mode2D=1]="Mode2D"}(rh||e("ad",rh={}));class ih{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,n){this.configuratorMode=!0,this.uiInteractionMode=!0,this._renderer=e,this.sceneRenderer=new Nl(this._renderer,t,n),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,ih.enableRectAreaLightShadow&&(Qt.rectAreaLightReplacement=!1,Qt.rectAreaLightLoadingListener=this.loadRectAreLight),this.sceneRenderer.setQualityLevel(Bl.HIGHEST),this.SceneRendererGUI=new zl(this.sceneRenderer)}dispose(){this.sceneRenderer.dispose()}setSize(e,t){this.sceneRenderer.setSize(e,t)}setAutoQuality(e){!this._fpsCounter&&e?this._fpsCounter=new nh: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){ih.rectAreaLightsNeedsUpdate=!0}updateRectAreaLight(e){let t=[];e.traverse(e=>{e instanceof o&&t.push(e)}),this.sceneRenderer.updateRectAreaLights(t,e),ih.rectAreaLightsNeedsUpdate=!1}forceShadowUpdates(e){this.sceneRenderer.forceShadowUpdates(e)}switchToConfigurator(){this.configuratorMode=!0,this.sceneRenderer.setQualityMap($l)}switchToPlanner(e){rh.Mode3D,this.configuratorMode=!1,e===rh.Mode3D?this.sceneRenderer.setQualityMap(eh):this.sceneRenderer.setQualityMap(th)}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 n;ih.rectAreaLightsNeedsUpdate&&this.updateRectAreaLight(e),t.updateMatrixWorld(),(t instanceof W||t instanceof q)&&t.updateProjectionMatrix();const r=ih.updateNearAndFarPlaneOfPerspectiveCamera?this.createRenderCamera(t):t;if(this.sceneRenderer.render(e,r),this.sceneRenderer.movingCamera&&this._fpsCounter){null===(n=this._fpsCounter)||void 0===n||n.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 W&&(this.sceneRenderer.updateNearAndFarPlaneOfPerspectiveCamera(t,120),t.updateProjectionMatrix()),t}showGUI(e){const t=Fi();this.SceneRendererGUI.addGUI(t,e)}createShadowFromEnvironmentMap(e,t,n){this.sceneRenderer.createShadowFromEnvironmentMap(e,t,n)}}e("a3",ih),ih.enableRectAreaLightShadow=!0,ih.rectAreaLightsNeedsUpdate=!1,ih.updateNearAndFarPlaneOfPerspectiveCamera=!1;class sh{_getRoomleRenderer(){if(!this._roomleRenderer){const e=new Vt({antialias:!0,alpha:!0});e.outputColorSpace=y,e.autoClear=!0,e.setSize(1024,1024),e.outputColorSpace=y,e.autoClear=!1,e.shadowMap.enabled=!0,e.shadowMap.type=St,this._roomleRenderer=new ih(e,1024,1024),this._roomleRenderer.setQualityMap(Gl),this._roomleRenderer.setSize(1024,1024)}return this._roomleRenderer}setEnvMap(e,t){this._getRoomleRenderer().createShadowFromEnvironmentMap(e,t)}switchToPlannerSettings(){this._getRoomleRenderer().switchToPlanner(rh.Mode3D)}switchToConfiguratorSettings(){this._getRoomleRenderer().switchToConfigurator()}static getCameraTargetForBBox(e,t=0){if(!e){const e=new a;return{center:e,bounds:e,diagonal:0}}const n=e.getSize(new a);return n.addScalar(t),{center:e.getCenter(new a),bounds:n,diagonal:Math.sqrt(Math.pow(n.x,2)+Math.pow(n.y,2)+Math.pow(n.z,2))}}preparePerspectiveImage(e,t,n,r,i={},s=0){return new Promise(a=>{const{size:o=1024,showDimensions:l}=i,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,n.layers.disable(2),n.layers.disable(6),n.layers.disable(5),l?n.layers.enable(8):n.layers.disable(8);const u=-30+ur(s);sh.placeCameraForPerspectiveImage(n,r,-20,u);const p=this._render(h,e,t,n);n.layers.enable(2),n.layers.enable(6),n.layers.enable(5),e.background=c,e.fog=d,a({image:p,width:o,height:o,blob:null})})}renderPerspectiveImage(e,t,n,r){return new Promise(i=>{r||(r=1024);const s=this._getRoomleRenderer();s.setSize(r,r);const a=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),n?sh.placeCameraForPerspectiveImage(t,n,-20,-30):(t.aspect=1,t.updateProjectionMatrix());const l=this._render(s,e,null,t);t.layers.enable(2),t.layers.enable(6),t.layers.enable(5),e.background=o,e.fog=a,i({image:l,width:r,height:r,blob:null})})}static placeCameraForPerspectiveImage(e,t,n,r){e.far=1e3,e.fov=15,e.aspect=1,e.position.copy(t.center),e.rotation.set(0,0,0),e.rotateY(cr(r)),e.rotateX(cr(n)),e.translateZ(3.8*t.diagonal),e.updateProjectionMatrix()}prepareTopImage(e,t,n,r={}){const{showDimensions:i=!1}=r;return new Promise(r=>{const s=this._getRoomleRenderer();let a=new q(-n.bounds.x/2,n.bounds.x/2,n.bounds.z/2,-n.bounds.z/2,.5);a.position.copy(n.center),a.rotateX(cr(-90)),a.translateZ(n.bounds.y+1),a.far=a.position.y+.5,a.layers.mask=65535;let o=200*n.bounds.x,l=200*n.bounds.z;if(o>4096||l>4096){let e=0;o>4096?e=o/4096:l>4096&&(e=l/4096),o/=e,l/=e}s.setSize(o,l);let h=e.fog?e.fog.clone():null,d=e.background?e.background.clone():null;e.background=null,e.fog=null,a.layers.disable(2),a.layers.disable(6),a.layers.disable(5),i?a.layers.enable(8):a.layers.disable(8);const c=this._render(s,e,t,a);a.layers.enable(2),a.layers.enable(6),a.layers.enable(5),e.background=d,e.fog=h,r({image:c,width:o,height:l,blob:null})})}_render(e,t,n,r){return e.forceShadowUpdates(!0),e.render(t,r),e.render(t,r),n&&(e.renderer.autoClear=!1,e.renderer.clearDepth(),e.renderer.render(n,r),e.renderer.autoClear=!0),e.renderer.domElement.toDataURL()}}e("r",sh);const ah=e("I",[new Kt("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 n=this._listeners[e];let r=n.length;for(let e=0;e<r;e++){const r=n[e];r.apply(r,t)}}unsubscribe(e,t){if(!this._listeners[e])return;const n=this._listeners[e];let r=n.length;for(let e=0;e<r;e++)if(n[e]===t)return n.splice(e,1),r--,void e--}softReject(e,t,n){return this.dispatch(n,[t]),e()}}),new Kt("form-data-util",Xt),new Kt("hdr-environment-loader",class{constructor(e){this._creator_=e;const t=new h("#DDDDDD");this._environmentMap=((e,t,n,r)=>{const i=new ve;i.format=we,i.generateMipmaps=!1;for(let r=0;r<6;++r){const s=Ei(e,t,n,1);s.format=i.format,s.type=i.type,s.minFilter=i.minFilter,s.magFilter=i.magFilter,s.generateMipmaps=i.generateMipmaps,s.needsUpdate=!0,i.images[r]=s}return i.needsUpdate=!0,i})(t.r,t.g,t.b)}async loadUrl(e,t){const n=t.toLowerCase();this._environmentMap=n.endsWith(".exr")?await this._loadExr(t):await this._loadRgbe(t),this._environmentMap.mapping=et;const r={url:t,environmentMap:this._environmentMap};return this._envChangedCallback(r),r}_loadExr(e){var t;return this._exrLoader=null!==(t=this._exrLoader)&&void 0!==t?t:new oo,this._exrLoader.setPath(e.startsWith("http")?"":n()),this._exrLoader.loadAsync(e)}_loadRgbe(e){var t;return this._rgbeLoader=null!==(t=this._rgbeLoader)&&void 0!==t?t:new lo,this._rgbeLoader.setPath(e.startsWith("http")?"":n()),this._rgbeLoader.loadAsync(e)}registerEnvironmentChangedCallback(e){this._envChangedCallback=e}}),new Kt("static-item-loader",class{constructor(e){this._gltfLoaderGuard=new un,this._creator_=e,this._initLoaders()}_initLoaders(){this._gltfLoader=new fn;const e=new ar,t=e._loadLibrary.bind(e._loadLibrary);e._loadLibrary=(e,r)=>{const i=lr[e];if(!i)throw new Error('Can not load draco dependency "'+e+'" did three.js update DracoLoader lib? Available files'+JSON.stringify(lr));return t(n()+i,r)},e.setDecoderConfig({type:"wasm"}),this._gltfLoader.setDRACOLoader(e),this._gltfLoaderGuard.resolve(this._gltfLoader)}async loadGLB(e,t,n,r,i,s,a,o){return await this._gltfLoaderGuard.wait(),new Promise((l,h)=>{this._gltfLoader.load(e,e=>{l(this._handleGLTFScene("GLB",e,t,n,r,i,s,a))},e=>{o&&o(e.loaded/e.total)},e=>{h(e)})})}async loadGLTF(e,t,n,r,i,s,a,o){return await this._gltfLoaderGuard.wait(),new Promise((l,h)=>{this._gltfLoader.parse(e,null,e=>{l(this._handleGLTFScene("GLTF",e,t,n,r,i,s,a))},e=>{o&&o(e.loaded/e.total)},e=>{h(e)})})}_handleGLTFScene(e,t,n,r,i,s,o,l){if(!t||!t.scene||!t.scene.children||0===t.scene.children.length)return null;n&&t.scene.position.copy(n),r&&(t.scene.rotation.y=r);const d=new ue;if(d.setFromObject(t.scene),i){const{x:e,y:n,z:r}=d.getSize(new a);let s=new a(i.x/e,i.y/n,i.z/r);t.scene.scale.copy(s)}return s&&t.scene.scale.multiply(s),t.scene.type=e,t.scene.traverse(e=>{if(e instanceof z){if(e.layers.set(3),e.material instanceof U){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=hr.getEnvMapIntensity()}e.castShadow=!0,e.receiveShadow=!0}}),{boundingBox:d,scene:t.scene}}},0),new Kt("form-data-util",Xt),new Kt("single-promise-factory",class{constructor(e){this._promises=new Map,this._creator_=e}create(e,t,n){return new Promise((r,i)=>{let s=this._promises.get(e),a=!0;if(!s){const t=new Map;this._promises.set(e,t),s=this._promises.get(e),a=!1}s.get(t)||(s.set(t,[]),a=!1);const o=s.get(t);o.push({resolve:r,reject:i}),s.set(t,o);const l=()=>{s.delete(t),0===s.size&&this._promises.delete(e)};a||new Promise(n).then(e=>{s.get(t).forEach(({resolve:t})=>t(e)),l()},e=>{s.get(t).forEach(({reject:t})=>t(e)),l()})})}},1),new Kt("dynamic-light-setting-loader",Qt),new Kt("network-layer",en),new Kt("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 n=JSON.stringify(t);this._localStorage.setItem(e,n)}catch(e){console.error(e)}}}),new Kt("network-layer",en),new Kt("kernel-io",an,0),new Kt("data-syncer",cn),new Kt("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 Kt("life-cycle-manager",class{constructor(){this._listeners=[]}addEventListener(e){this._listeners.push(e)}removeEventListener(e){const t=this._listeners;let n=t.length;if(n)for(let r=0;r<n;r++)t[r]===e&&(t.splice(r,1),r--,n--)}pause(){this._listeners.forEach(e=>e.pause())}resume(){this._listeners.forEach(e=>e.resume())}destroy(){this._listeners.forEach(e=>e.destroy())}},1),new Kt("local-storage-helper",dr),new Kt("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())zi(e);for(const e of this._materialCache.values())Vi(e);for(const e of this._geometryCache.values())ji(e);this._componentCache.clear(),this._geometryCache.clear(),this._materialCache.clear()}},0),new Kt("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 Kt("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,n){this._callbackListener.forEach(r=>r.updatePossibleChildren(e,t,n))}updateParameters(e,t,n,r){this._callbackListener.forEach(i=>i.updateParameters(e,t,n,r))}loadError(e){this._callbackListener.forEach(t=>t.loadError(e))}},1),new Kt("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 Kt("init-data",Yi,1),new Kt("global-init-data",Ji,0),new Kt("global-callback",es,0),new Kt("dom-helper",ts,1),new Kt("unit-formatter",ka,0),new Kt("plugin-system",ns,1),new Kt("configurator-mesh-generator",ss),new Kt("configurator-input-manager",class extends cs{},1),new Kt("selection-handler",class extends as{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 us({component:e}))})}_checkStandard(e){this._selectedComponents.has(e.runtimeId)?this.dispatchEvent(0,new us({component:e,consecutive:!0})):(this._selectedComponents.size>0&&this._selectedComponents.forEach((e,t)=>{this._selectedComponents.delete(t),this.dispatchEvent(1,new us({component:e,resetCamera:!1}))}),this._selectedComponents.set(e.runtimeId,e),this.dispatchEvent(0,new us({component:e,consecutive:!1})))}_checkMulti(e){if(this._selectedComponents.has(e.runtimeId))return this._selectedComponents.delete(e.runtimeId),void this.dispatchEvent(1,new us({component:e,resetCamera:0===this._selectedComponents.size}));this._selectedComponents.set(e.runtimeId,e),this.dispatchEvent(0,new us({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 Kt("component-dimensioning-helper",bs,1),new Kt("component-dimensioning-helper",bs,1),new Kt("planner-kernel-access",Ta),new Kt("planner-mesh-generator",Aa,1),new Kt("unit-formatter",ka),new Kt("configurator-history",Oa,1),new Kt("roomle-planner-ui-callback",class extends $i{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,n,r,i)=>{},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 Kt("configurator-ui-callbacks",class extends $i{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,n,r)=>{},this.onSelectionCancel=()=>{},this.onPartListUpdate=(e,t)=>{},this.onBoundsUpdate=e=>{},this.onLoadConfiguration=()=>{},this.onConfigurationReady=(e,t,n)=>{},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,n,r)=>{},this.onUserInitiatedDockDone=(e,t,n,r,i)=>{},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,n)=>{},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 Kt("roomle-tools-core",Da,0),new Kt("image-renderer",sh,0)]);class oh{static _ensureContainer(){window.__RML__DI__||(window.__RML__DI__=new Gt,window.__RML__DI__.addDependencyInjectionAssignments(ah))}static setup(e){oh.addToContainer(e)}static lookup(e,t){return window.__RML__DI__?window.__RML__DI__.lookup(e,t):null}static getContext(e){return oh._ensureContainer(),window.__RML__DI__.getContext(e)}static cleanUp(e){return window.__RML__DI__?window.__RML__DI__.cleanUp(e):null}static addToContainer(e){oh._ensureContainer(),window.__RML__DI__.addDependencyInjectionAssignments(e)}}e("b",oh)}}}));
|
|
16
|
+
//# sourceMappingURL=roomle-dependency-injection-f0a6e177.nomodule.js.map
|