verify-account-noreply-kt8l00.vercel.app Open in urlscan Pro
76.76.21.22  Public Scan

URL: https://verify-account-noreply-kt8l00.vercel.app/index_files/webgl-graphic.js
Submission: On October 21 via api from US — Scanned from US

Form analysis 0 forms found in the DOM

Text Content

(()=>{"use strict";function A(A){let t=A[0],e=A[1],i=A[2];return Math.sqrt(t*t+e*e+i*i)}function t(A,t){return A[0]=t[0],A[1]=t[1],A[2]=t[2],A}function e(A,t,e){return A[0]=t[0]+e[0],A[1]=t[1]+e[1],A[2]=t[2]+e[2],A}function i(A,t,e){return A[0]=t[0]-e[0],A[1]=t[1]-e[1],A[2]=t[2]-e[2],A}function r(A,t,e){return A[0]=t[0]*e,A[1]=t[1]*e,A[2]=t[2]*e,A}function n(A){let t=A[0],e=A[1],i=A[2];return t*t+e*e+i*i}function s(A,t){let e=t[0],i=t[1],r=t[2],n=e*e+i*i+r*r;return n>0&&(n=1/Math.sqrt(n)),A[0]=t[0]*n,A[1]=t[1]*n,A[2]=t[2]*n,A}function a(A,t){return A[0]*t[0]+A[1]*t[1]+A[2]*t[2]}function o(A,t,e){let i=t[0],r=t[1],n=t[2],s=e[0],a=e[1],o=e[2];return A[0]=r*o-n*a,A[1]=n*s-i*o,A[2]=i*a-r*s,A}const h=function(){const A=[0,0,0],e=[0,0,0];return function(i,r){t(A,i),t(e,r),s(A,A),s(e,e);let n=a(A,e);return n>1?0:n<-1?Math.PI:Math.acos(n)}}();class l extends Array{constructor(A=0,t=A,e=A){return super(A,t,e),this}get x(){return this[0]}get y(){return this[1]}get z(){return this[2]}set x(A){this[0]=A}set y(A){this[1]=A}set z(A){this[2]=A}set(A,t=A,e=A){return A.length?this.copy(A):(function(A,t,e,i){A[0]=t,A[1]=e,A[2]=i}(this,A,t,e),this)}copy(A){return t(this,A),this}add(A,t){return t?e(this,A,t):e(this,this,A),this}sub(A,t){return t?i(this,A,t):i(this,this,A),this}multiply(A){var t,e,i;return A.length?(e=this,i=A,(t=this)[0]=e[0]*i[0],t[1]=e[1]*i[1],t[2]=e[2]*i[2]):r(this,this,A),this}divide(A){var t,e,i;return A.length?(e=this,i=A,(t=this)[0]=e[0]/i[0],t[1]=e[1]/i[1],t[2]=e[2]/i[2]):r(this,this,1/A),this}inverse(A=this){var t,e;return e=A,(t=this)[0]=1/e[0],t[1]=1/e[1],t[2]=1/e[2],this}len(){return A(this)}distance(t){return t?function(A,t){let e=t[0]-A[0],i=t[1]-A[1],r=t[2]-A[2];return Math.sqrt(e*e+i*i+r*r)}(this,t):A(this)}squaredLen(){return n(this)}squaredDistance(A){return A?function(A,t){let e=t[0]-A[0],i=t[1]-A[1],r=t[2]-A[2];return e*e+i*i+r*r}(this,A):n(this)}negate(A=this){var t,e;return e=A,(t=this)[0]=-e[0],t[1]=-e[1],t[2]=-e[2],this}cross(A,t){return t?o(this,A,t):o(this,this,A),this}scale(A){return r(this,this,A),this}normalize(){return s(this,this),this}dot(A){return a(this,A)}equals(A){return t=A,this[0]===t[0]&&this[1]===t[1]&&this[2]===t[2];var t}applyMatrix3(A){return function(A,t,e){let i=t[0],r=t[1],n=t[2];A[0]=i*e[0]+r*e[3]+n*e[6],A[1]=i*e[1]+r*e[4]+n*e[7],A[2]=i*e[2]+r*e[5]+n*e[8]}(this,this,A),this}applyMatrix4(A){return function(A,t,e){let i=t[0],r=t[1],n=t[2],s=e[3]*i+e[7]*r+e[11]*n+e[15];s=s||1,A[0]=(e[0]*i+e[4]*r+e[8]*n+e[12])/s,A[1]=(e[1]*i+e[5]*r+e[9]*n+e[13])/s,A[2]=(e[2]*i+e[6]*r+e[10]*n+e[14])/s}(this,this,A),this}scaleRotateMatrix4(A){return function(A,t,e){let i=t[0],r=t[1],n=t[2],s=e[3]*i+e[7]*r+e[11]*n+e[15];s=s||1,A[0]=(e[0]*i+e[4]*r+e[8]*n)/s,A[1]=(e[1]*i+e[5]*r+e[9]*n)/s,A[2]=(e[2]*i+e[6]*r+e[10]*n)/s}(this,this,A),this}applyQuaternion(A){return function(A,t,e){let i=t[0],r=t[1],n=t[2],s=e[0],a=e[1],o=e[2],h=a*n-o*r,l=o*i-s*n,c=s*r-a*i,g=a*c-o*l,u=o*h-s*c,d=s*l-a*h,p=2*e[3];h*=p,l*=p,c*=p,g*=2,u*=2,d*=2,A[0]=i+h+g,A[1]=r+l+u,A[2]=n+c+d}(this,this,A),this}angle(A){return h(this,A)}lerp(A,t){return function(A,t,e,i){let r=t[0],n=t[1],s=t[2];A[0]=r+i*(e[0]-r),A[1]=n+i*(e[1]-n),A[2]=s+i*(e[2]-s)}(this,this,A,t),this}clone(){return new l(this[0],this[1],this[2])}fromArray(A,t=0){return this[0]=A[t],this[1]=A[t+1],this[2]=A[t+2],this}toArray(A=[],t=0){return A[t]=this[0],A[t+1]=this[1],A[t+2]=this[2],A}transformDirection(A){const t=this[0],e=this[1],i=this[2];return this[0]=A[0]*t+A[4]*e+A[8]*i,this[1]=A[1]*t+A[5]*e+A[9]*i,this[2]=A[2]*t+A[6]*e+A[10]*i,this.normalize()}}function c(A,t,e){let i=t[0],r=t[1],n=t[2],s=t[3],a=e[0],o=e[1],h=e[2],l=e[3];return A[0]=i*l+s*a+r*h-n*o,A[1]=r*l+s*o+n*a-i*h,A[2]=n*l+s*h+i*o-r*a,A[3]=s*l-i*a-r*o-n*h,A}class g extends Array{constructor(A=0,t=0,e=0,i=1){return super(A,t,e,i),this.onChange=()=>{},this}get x(){return this[0]}get y(){return this[1]}get z(){return this[2]}get w(){return this[3]}set x(A){this[0]=A,this.onChange()}set y(A){this[1]=A,this.onChange()}set z(A){this[2]=A,this.onChange()}set w(A){this[3]=A,this.onChange()}identity(){var A;return(A=this)[0]=0,A[1]=0,A[2]=0,A[3]=1,this.onChange(),this}set(A,t,e,i){return A.length?this.copy(A):(function(A,t,e,i,r){A[0]=t,A[1]=e,A[2]=i,A[3]=r}(this,A,t,e,i),this.onChange(),this)}rotateX(A){return function(A,t,e){e*=.5;let i=t[0],r=t[1],n=t[2],s=t[3],a=Math.sin(e),o=Math.cos(e);A[0]=i*o+s*a,A[1]=r*o+n*a,A[2]=n*o-r*a,A[3]=s*o-i*a}(this,this,A),this.onChange(),this}rotateY(A){return function(A,t,e){e*=.5;let i=t[0],r=t[1],n=t[2],s=t[3],a=Math.sin(e),o=Math.cos(e);A[0]=i*o-n*a,A[1]=r*o+s*a,A[2]=n*o+i*a,A[3]=s*o-r*a}(this,this,A),this.onChange(),this}rotateZ(A){return function(A,t,e){e*=.5;let i=t[0],r=t[1],n=t[2],s=t[3],a=Math.sin(e),o=Math.cos(e);A[0]=i*o+r*a,A[1]=r*o-i*a,A[2]=n*o+s*a,A[3]=s*o-n*a}(this,this,A),this.onChange(),this}inverse(A=this){return function(A,t){let e=t[0],i=t[1],r=t[2],n=t[3],s=e*e+i*i+r*r+n*n,a=s?1/s:0;A[0]=-e*a,A[1]=-i*a,A[2]=-r*a,A[3]=n*a}(this,A),this.onChange(),this}conjugate(A=this){var t,e;return e=A,(t=this)[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=e[3],this.onChange(),this}copy(A){return e=A,(t=this)[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],this.onChange(),this;var t,e}normalize(A=this){return function(A,t){let e=t[0],i=t[1],r=t[2],n=t[3],s=e*e+i*i+r*r+n*n;s>0&&(s=1/Math.sqrt(s)),A[0]=e*s,A[1]=i*s,A[2]=r*s,A[3]=n*s}(this,A),this.onChange(),this}multiply(A,t){return t?c(this,A,t):c(this,this,A),this.onChange(),this}dot(A){return e=A,(t=this)[0]*e[0]+t[1]*e[1]+t[2]*e[2]+t[3]*e[3];var t,e}fromMatrix3(A){return function(A,t){let e,i=t[0]+t[4]+t[8];if(i>0)e=Math.sqrt(i+1),A[3]=.5*e,e=.5/e,A[0]=(t[5]-t[7])*e,A[1]=(t[6]-t[2])*e,A[2]=(t[1]-t[3])*e;else{let i=0;t[4]>t[0]&&(i=1),t[8]>t[3*i+i]&&(i=2);let r=(i+1)%3,n=(i+2)%3;e=Math.sqrt(t[3*i+i]-t[3*r+r]-t[3*n+n]+1),A[i]=.5*e,e=.5/e,A[3]=(t[3*r+n]-t[3*n+r])*e,A[r]=(t[3*r+i]+t[3*i+r])*e,A[n]=(t[3*n+i]+t[3*i+n])*e}}(this,A),this.onChange(),this}fromEuler(A){return function(A,t,e="YXZ"){let i=Math.sin(.5*t[0]),r=Math.cos(.5*t[0]),n=Math.sin(.5*t[1]),s=Math.cos(.5*t[1]),a=Math.sin(.5*t[2]),o=Math.cos(.5*t[2]);"XYZ"===e?(A[0]=i*s*o+r*n*a,A[1]=r*n*o-i*s*a,A[2]=r*s*a+i*n*o,A[3]=r*s*o-i*n*a):"YXZ"===e?(A[0]=i*s*o+r*n*a,A[1]=r*n*o-i*s*a,A[2]=r*s*a-i*n*o,A[3]=r*s*o+i*n*a):"ZXY"===e?(A[0]=i*s*o-r*n*a,A[1]=r*n*o+i*s*a,A[2]=r*s*a+i*n*o,A[3]=r*s*o-i*n*a):"ZYX"===e?(A[0]=i*s*o-r*n*a,A[1]=r*n*o+i*s*a,A[2]=r*s*a-i*n*o,A[3]=r*s*o+i*n*a):"YZX"===e?(A[0]=i*s*o+r*n*a,A[1]=r*n*o+i*s*a,A[2]=r*s*a-i*n*o,A[3]=r*s*o-i*n*a):"XZY"===e&&(A[0]=i*s*o-r*n*a,A[1]=r*n*o-i*s*a,A[2]=r*s*a+i*n*o,A[3]=r*s*o+i*n*a)}(this,A,A.order),this}fromAxisAngle(A,t){return function(A,t,e){e*=.5;let i=Math.sin(e);A[0]=i*t[0],A[1]=i*t[1],A[2]=i*t[2],A[3]=Math.cos(e)}(this,A,t),this}slerp(A,t){return function(A,t,e,i){let r,n,s,a,o,h=t[0],l=t[1],c=t[2],g=t[3],u=e[0],d=e[1],p=e[2],f=e[3];n=h*u+l*d+c*p+g*f,n<0&&(n=-n,u=-u,d=-d,p=-p,f=-f),1-n>1e-6?(r=Math.acos(n),s=Math.sin(r),a=Math.sin((1-i)*r)/s,o=Math.sin(i*r)/s):(a=1-i,o=i),A[0]=a*h+o*u,A[1]=a*l+o*d,A[2]=a*c+o*p,A[3]=a*g+o*f}(this,this,A,t),this}fromArray(A,t=0){return this[0]=A[t],this[1]=A[t+1],this[2]=A[t+2],this[3]=A[t+3],this}toArray(A=[],t=0){return A[t]=this[0],A[t+1]=this[1],A[t+2]=this[2],A[t+3]=this[3],A}}function u(A,t,e){let i=t[0],r=t[1],n=t[2],s=t[3],a=t[4],o=t[5],h=t[6],l=t[7],c=t[8],g=t[9],u=t[10],d=t[11],p=t[12],f=t[13],m=t[14],E=t[15],x=e[0],I=e[1],R=e[2],v=e[3];return A[0]=x*i+I*a+R*c+v*p,A[1]=x*r+I*o+R*g+v*f,A[2]=x*n+I*h+R*u+v*m,A[3]=x*s+I*l+R*d+v*E,x=e[4],I=e[5],R=e[6],v=e[7],A[4]=x*i+I*a+R*c+v*p,A[5]=x*r+I*o+R*g+v*f,A[6]=x*n+I*h+R*u+v*m,A[7]=x*s+I*l+R*d+v*E,x=e[8],I=e[9],R=e[10],v=e[11],A[8]=x*i+I*a+R*c+v*p,A[9]=x*r+I*o+R*g+v*f,A[10]=x*n+I*h+R*u+v*m,A[11]=x*s+I*l+R*d+v*E,x=e[12],I=e[13],R=e[14],v=e[15],A[12]=x*i+I*a+R*c+v*p,A[13]=x*r+I*o+R*g+v*f,A[14]=x*n+I*h+R*u+v*m,A[15]=x*s+I*l+R*d+v*E,A}function d(A,t){let e=t[0],i=t[1],r=t[2],n=t[4],s=t[5],a=t[6],o=t[8],h=t[9],l=t[10];return A[0]=Math.hypot(e,i,r),A[1]=Math.hypot(n,s,a),A[2]=Math.hypot(o,h,l),A}const p=function(){const A=[0,0,0];return function(t,e){let i=A;d(i,e);let r=1/i[0],n=1/i[1],s=1/i[2],a=e[0]*r,o=e[1]*n,h=e[2]*s,l=e[4]*r,c=e[5]*n,g=e[6]*s,u=e[8]*r,p=e[9]*n,f=e[10]*s,m=a+c+f,E=0;return m>0?(E=2*Math.sqrt(m+1),t[3]=.25*E,t[0]=(g-p)/E,t[1]=(u-h)/E,t[2]=(o-l)/E):a>c&&a>f?(E=2*Math.sqrt(1+a-c-f),t[3]=(g-p)/E,t[0]=.25*E,t[1]=(o+l)/E,t[2]=(u+h)/E):c>f?(E=2*Math.sqrt(1+c-a-f),t[3]=(u-h)/E,t[0]=(o+l)/E,t[1]=.25*E,t[2]=(g+p)/E):(E=2*Math.sqrt(1+f-a-c),t[3]=(o-l)/E,t[0]=(u+h)/E,t[1]=(g+p)/E,t[2]=.25*E),t}}();class f extends Array{constructor(A=1,t=0,e=0,i=0,r=0,n=1,s=0,a=0,o=0,h=0,l=1,c=0,g=0,u=0,d=0,p=1){return super(A,t,e,i,r,n,s,a,o,h,l,c,g,u,d,p),this}get x(){return this[12]}get y(){return this[13]}get z(){return this[14]}get w(){return this[15]}set x(A){this[12]=A}set y(A){this[13]=A}set z(A){this[14]=A}set w(A){this[15]=A}set(A,t,e,i,r,n,s,a,o,h,l,c,g,u,d,p){return A.length?this.copy(A):(function(A,t,e,i,r,n,s,a,o,h,l,c,g,u,d,p,f){A[0]=t,A[1]=e,A[2]=i,A[3]=r,A[4]=n,A[5]=s,A[6]=a,A[7]=o,A[8]=h,A[9]=l,A[10]=c,A[11]=g,A[12]=u,A[13]=d,A[14]=p,A[15]=f}(this,A,t,e,i,r,n,s,a,o,h,l,c,g,u,d,p),this)}translate(A,t=this){return function(A,t,e){let i,r,n,s,a,o,h,l,c,g,u,d,p=e[0],f=e[1],m=e[2];t===A?(A[12]=t[0]*p+t[4]*f+t[8]*m+t[12],A[13]=t[1]*p+t[5]*f+t[9]*m+t[13],A[14]=t[2]*p+t[6]*f+t[10]*m+t[14],A[15]=t[3]*p+t[7]*f+t[11]*m+t[15]):(i=t[0],r=t[1],n=t[2],s=t[3],a=t[4],o=t[5],h=t[6],l=t[7],c=t[8],g=t[9],u=t[10],d=t[11],A[0]=i,A[1]=r,A[2]=n,A[3]=s,A[4]=a,A[5]=o,A[6]=h,A[7]=l,A[8]=c,A[9]=g,A[10]=u,A[11]=d,A[12]=i*p+a*f+c*m+t[12],A[13]=r*p+o*f+g*m+t[13],A[14]=n*p+h*f+u*m+t[14],A[15]=s*p+l*f+d*m+t[15])}(this,t,A),this}rotate(A,t,e=this){return function(A,t,e,i){let r,n,s,a,o,h,l,c,g,u,d,p,f,m,E,x,I,R,v,C,y,B,F,M,w=i[0],Q=i[1],S=i[2],b=Math.hypot(w,Q,S);Math.abs(b)<1e-6||(b=1/b,w*=b,Q*=b,S*=b,r=Math.sin(e),n=Math.cos(e),s=1-n,a=t[0],o=t[1],h=t[2],l=t[3],c=t[4],g=t[5],u=t[6],d=t[7],p=t[8],f=t[9],m=t[10],E=t[11],x=w*w*s+n,I=Q*w*s+S*r,R=S*w*s-Q*r,v=w*Q*s-S*r,C=Q*Q*s+n,y=S*Q*s+w*r,B=w*S*s+Q*r,F=Q*S*s-w*r,M=S*S*s+n,A[0]=a*x+c*I+p*R,A[1]=o*x+g*I+f*R,A[2]=h*x+u*I+m*R,A[3]=l*x+d*I+E*R,A[4]=a*v+c*C+p*y,A[5]=o*v+g*C+f*y,A[6]=h*v+u*C+m*y,A[7]=l*v+d*C+E*y,A[8]=a*B+c*F+p*M,A[9]=o*B+g*F+f*M,A[10]=h*B+u*F+m*M,A[11]=l*B+d*F+E*M,t!==A&&(A[12]=t[12],A[13]=t[13],A[14]=t[14],A[15]=t[15]))}(this,e,A,t),this}scale(A,t=this){return function(A,t,e){let i=e[0],r=e[1],n=e[2];A[0]=t[0]*i,A[1]=t[1]*i,A[2]=t[2]*i,A[3]=t[3]*i,A[4]=t[4]*r,A[5]=t[5]*r,A[6]=t[6]*r,A[7]=t[7]*r,A[8]=t[8]*n,A[9]=t[9]*n,A[10]=t[10]*n,A[11]=t[11]*n,A[12]=t[12],A[13]=t[13],A[14]=t[14],A[15]=t[15]}(this,t,"number"==typeof A?[A,A,A]:A),this}multiply(A,t){return t?u(this,A,t):u(this,this,A),this}identity(){var A;return(A=this)[0]=1,A[1]=0,A[2]=0,A[3]=0,A[4]=0,A[5]=1,A[6]=0,A[7]=0,A[8]=0,A[9]=0,A[10]=1,A[11]=0,A[12]=0,A[13]=0,A[14]=0,A[15]=1,this}copy(A){var t,e;return e=A,(t=this)[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[8]=e[8],t[9]=e[9],t[10]=e[10],t[11]=e[11],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],this}fromPerspective({fov:A,aspect:t,near:e,far:i}={}){return function(A,t,e,i,r){let n=1/Math.tan(t/2),s=1/(i-r);A[0]=n/e,A[1]=0,A[2]=0,A[3]=0,A[4]=0,A[5]=n,A[6]=0,A[7]=0,A[8]=0,A[9]=0,A[10]=(r+i)*s,A[11]=-1,A[12]=0,A[13]=0,A[14]=2*r*i*s,A[15]=0}(this,A,t,e,i),this}fromOrthogonal({left:A,right:t,bottom:e,top:i,near:r,far:n}){return function(A,t,e,i,r,n,s){let a=1/(t-e),o=1/(i-r),h=1/(n-s);A[0]=-2*a,A[1]=0,A[2]=0,A[3]=0,A[4]=0,A[5]=-2*o,A[6]=0,A[7]=0,A[8]=0,A[9]=0,A[10]=2*h,A[11]=0,A[12]=(t+e)*a,A[13]=(r+i)*o,A[14]=(s+n)*h,A[15]=1}(this,A,t,e,i,r,n),this}fromQuaternion(A){return function(A,t){let e=t[0],i=t[1],r=t[2],n=t[3],s=e+e,a=i+i,o=r+r,h=e*s,l=i*s,c=i*a,g=r*s,u=r*a,d=r*o,p=n*s,f=n*a,m=n*o;A[0]=1-c-d,A[1]=l+m,A[2]=g-f,A[3]=0,A[4]=l-m,A[5]=1-h-d,A[6]=u+p,A[7]=0,A[8]=g+f,A[9]=u-p,A[10]=1-h-c,A[11]=0,A[12]=0,A[13]=0,A[14]=0,A[15]=1}(this,A),this}setPosition(A){return this.x=A[0],this.y=A[1],this.z=A[2],this}inverse(A=this){return function(A,t){let e=t[0],i=t[1],r=t[2],n=t[3],s=t[4],a=t[5],o=t[6],h=t[7],l=t[8],c=t[9],g=t[10],u=t[11],d=t[12],p=t[13],f=t[14],m=t[15],E=e*a-i*s,x=e*o-r*s,I=e*h-n*s,R=i*o-r*a,v=i*h-n*a,C=r*h-n*o,y=l*p-c*d,B=l*f-g*d,F=l*m-u*d,M=c*f-g*p,w=c*m-u*p,Q=g*m-u*f,S=E*Q-x*w+I*M+R*F-v*B+C*y;S&&(S=1/S,A[0]=(a*Q-o*w+h*M)*S,A[1]=(r*w-i*Q-n*M)*S,A[2]=(p*C-f*v+m*R)*S,A[3]=(g*v-c*C-u*R)*S,A[4]=(o*F-s*Q-h*B)*S,A[5]=(e*Q-r*F+n*B)*S,A[6]=(f*I-d*C-m*x)*S,A[7]=(l*C-g*I+u*x)*S,A[8]=(s*w-a*F+h*y)*S,A[9]=(i*F-e*w-n*y)*S,A[10]=(d*v-p*I+m*E)*S,A[11]=(c*I-l*v-u*E)*S,A[12]=(a*B-s*M-o*y)*S,A[13]=(e*M-i*B+r*y)*S,A[14]=(p*x-d*R-f*E)*S,A[15]=(l*R-c*x+g*E)*S)}(this,A),this}compose(A,t,e){return function(A,t,e,i){let r=t[0],n=t[1],s=t[2],a=t[3],o=r+r,h=n+n,l=s+s,c=r*o,g=r*h,u=r*l,d=n*h,p=n*l,f=s*l,m=a*o,E=a*h,x=a*l,I=i[0],R=i[1],v=i[2];A[0]=(1-(d+f))*I,A[1]=(g+x)*I,A[2]=(u-E)*I,A[3]=0,A[4]=(g-x)*R,A[5]=(1-(c+f))*R,A[6]=(p+m)*R,A[7]=0,A[8]=(u+E)*v,A[9]=(p-m)*v,A[10]=(1-(c+d))*v,A[11]=0,A[12]=e[0],A[13]=e[1],A[14]=e[2],A[15]=1}(this,A,t,e),this}getRotation(A){return p(A,this),this}getTranslation(A){var t,e;return e=this,(t=A)[0]=e[12],t[1]=e[13],t[2]=e[14],this}getScaling(A){return d(A,this),this}getMaxScaleOnAxis(){return function(A){let t=A[0],e=A[1],i=A[2],r=A[4],n=A[5],s=A[6],a=A[8],o=A[9],h=A[10];const l=t*t+e*e+i*i,c=r*r+n*n+s*s,g=a*a+o*o+h*h;return Math.sqrt(Math.max(l,c,g))}(this)}lookAt(A,t,e){return function(A,t,e,i){let r=t[0],n=t[1],s=t[2],a=i[0],o=i[1],h=i[2],l=r-e[0],c=n-e[1],g=s-e[2],u=l*l+c*c+g*g;0===u?g=1:(u=1/Math.sqrt(u),l*=u,c*=u,g*=u);let d=o*g-h*c,p=h*l-a*g,f=a*c-o*l;u=d*d+p*p+f*f,0===u&&(h?a+=1e-6:o?h+=1e-6:o+=1e-6,d=o*g-h*c,p=h*l-a*g,f=a*c-o*l,u=d*d+p*p+f*f),u=1/Math.sqrt(u),d*=u,p*=u,f*=u,A[0]=d,A[1]=p,A[2]=f,A[3]=0,A[4]=c*f-g*p,A[5]=g*d-l*f,A[6]=l*p-c*d,A[7]=0,A[8]=l,A[9]=c,A[10]=g,A[11]=0,A[12]=r,A[13]=n,A[14]=s,A[15]=1}(this,A,t,e),this}determinant(){return function(A){let t=A[0],e=A[1],i=A[2],r=A[3],n=A[4],s=A[5],a=A[6],o=A[7],h=A[8],l=A[9],c=A[10],g=A[11],u=A[12],d=A[13],p=A[14],f=A[15];return(t*s-e*n)*(c*f-g*p)-(t*a-i*n)*(l*f-g*d)+(t*o-r*n)*(l*p-c*d)+(e*a-i*s)*(h*f-g*u)-(e*o-r*s)*(h*p-c*u)+(i*o-r*a)*(h*d-l*u)}(this)}fromArray(A,t=0){return this[0]=A[t],this[1]=A[t+1],this[2]=A[t+2],this[3]=A[t+3],this[4]=A[t+4],this[5]=A[t+5],this[6]=A[t+6],this[7]=A[t+7],this[8]=A[t+8],this[9]=A[t+9],this[10]=A[t+10],this[11]=A[t+11],this[12]=A[t+12],this[13]=A[t+13],this[14]=A[t+14],this[15]=A[t+15],this}toArray(A=[],t=0){return A[t]=this[0],A[t+1]=this[1],A[t+2]=this[2],A[t+3]=this[3],A[t+4]=this[4],A[t+5]=this[5],A[t+6]=this[6],A[t+7]=this[7],A[t+8]=this[8],A[t+9]=this[9],A[t+10]=this[10],A[t+11]=this[11],A[t+12]=this[12],A[t+13]=this[13],A[t+14]=this[14],A[t+15]=this[15],A}}const m=new f;class E extends Array{constructor(A=0,t=A,e=A,i="YXZ"){return super(A,t,e),this.order=i,this.onChange=()=>{},this}get x(){return this[0]}get y(){return this[1]}get z(){return this[2]}set x(A){this[0]=A,this.onChange()}set y(A){this[1]=A,this.onChange()}set z(A){this[2]=A,this.onChange()}set(A,t=A,e=A){return A.length?this.copy(A):(this[0]=A,this[1]=t,this[2]=e,this.onChange(),this)}copy(A){return this[0]=A[0],this[1]=A[1],this[2]=A[2],this.onChange(),this}reorder(A){return this.order=A,this.onChange(),this}fromRotationMatrix(A,t=this.order){return function(A,t,e="YXZ"){"XYZ"===e?(A[1]=Math.asin(Math.min(Math.max(t[8],-1),1)),Math.abs(t[8])<.99999?(A[0]=Math.atan2(-t[9],t[10]),A[2]=Math.atan2(-t[4],t[0])):(A[0]=Math.atan2(t[6],t[5]),A[2]=0)):"YXZ"===e?(A[0]=Math.asin(-Math.min(Math.max(t[9],-1),1)),Math.abs(t[9])<.99999?(A[1]=Math.atan2(t[8],t[10]),A[2]=Math.atan2(t[1],t[5])):(A[1]=Math.atan2(-t[2],t[0]),A[2]=0)):"ZXY"===e?(A[0]=Math.asin(Math.min(Math.max(t[6],-1),1)),Math.abs(t[6])<.99999?(A[1]=Math.atan2(-t[2],t[10]),A[2]=Math.atan2(-t[4],t[5])):(A[1]=0,A[2]=Math.atan2(t[1],t[0]))):"ZYX"===e?(A[1]=Math.asin(-Math.min(Math.max(t[2],-1),1)),Math.abs(t[2])<.99999?(A[0]=Math.atan2(t[6],t[10]),A[2]=Math.atan2(t[1],t[0])):(A[0]=0,A[2]=Math.atan2(-t[4],t[5]))):"YZX"===e?(A[2]=Math.asin(Math.min(Math.max(t[1],-1),1)),Math.abs(t[1])<.99999?(A[0]=Math.atan2(-t[9],t[5]),A[1]=Math.atan2(-t[2],t[0])):(A[0]=0,A[1]=Math.atan2(t[8],t[10]))):"XZY"===e&&(A[2]=Math.asin(-Math.min(Math.max(t[4],-1),1)),Math.abs(t[4])<.99999?(A[0]=Math.atan2(t[6],t[5]),A[1]=Math.atan2(t[8],t[0])):(A[0]=Math.atan2(-t[9],t[10]),A[1]=0))}(this,A,t),this}fromQuaternion(A,t=this.order){return m.fromQuaternion(A),this.fromRotationMatrix(m,t)}toArray(A=[],t=0){return A[t]=this[0],A[t+1]=this[1],A[t+2]=this[2],A}}class x{constructor(){this.parent=null,this.children=[],this.visible=!0,this.matrix=new f,this.worldMatrix=new f,this.matrixAutoUpdate=!0,this.position=new l,this.quaternion=new g,this.scale=new l(1),this.rotation=new E,this.up=new l(0,1,0),this.rotation.onChange=()=>this.quaternion.fromEuler(this.rotation),this.quaternion.onChange=()=>this.rotation.fromQuaternion(this.quaternion)}setParent(A,t=!0){this.parent&&A!==this.parent&&this.parent.removeChild(this,!1),this.parent=A,t&&A&&A.addChild(this,!1)}addChild(A,t=!0){~this.children.indexOf(A)||this.children.push(A),t&&A.setParent(this,!1)}removeChild(A,t=!0){~this.children.indexOf(A)&&this.children.splice(this.children.indexOf(A),1),t&&A.setParent(null,!1)}updateMatrixWorld(A){this.matrixAutoUpdate&&this.updateMatrix(),(this.worldMatrixNeedsUpdate||A)&&(null===this.parent?this.worldMatrix.copy(this.matrix):this.worldMatrix.multiply(this.parent.worldMatrix,this.matrix),this.worldMatrixNeedsUpdate=!1,A=!0);for(let t=0,e=this.children.length;t<e;t++)this.children[t].updateMatrixWorld(A)}updateMatrix(){this.matrix.compose(this.quaternion,this.position,this.scale),this.worldMatrixNeedsUpdate=!0}traverse(A){if(!A(this))for(let t=0,e=this.children.length;t<e;t++)this.children[t].traverse(A)}decompose(){this.matrix.getTranslation(this.position),this.matrix.getRotation(this.quaternion),this.matrix.getScaling(this.scale),this.rotation.fromQuaternion(this.quaternion)}lookAt(A,t=!1){t?this.matrix.lookAt(this.position,A,this.up):this.matrix.lookAt(A,this.position,this.up),this.matrix.getRotation(this.quaternion),this.rotation.fromQuaternion(this.quaternion)}}const I=new f,R=new l,v=new l,C=new Uint8Array(4);function y(A){return 0==(A&A-1)}let B=1;class F{constructor(A,{image:t,target:e=A.TEXTURE_2D,type:i=A.UNSIGNED_BYTE,format:r=A.RGBA,internalFormat:n=r,wrapS:s=A.CLAMP_TO_EDGE,wrapT:a=A.CLAMP_TO_EDGE,generateMipmaps:o=!0,minFilter:h=(o?A.NEAREST_MIPMAP_LINEAR:A.LINEAR),magFilter:l=A.LINEAR,premultiplyAlpha:c=!1,unpackAlignment:g=4,flipY:u=e==A.TEXTURE_2D,anisotropy:d=0,level:p=0,width:f,height:m=f}={}){this.gl=A,this.id=B++,this.image=t,this.target=e,this.type=i,this.format=r,this.internalFormat=n,this.minFilter=h,this.magFilter=l,this.wrapS=s,this.wrapT=a,this.generateMipmaps=o,this.premultiplyAlpha=c,this.unpackAlignment=g,this.flipY=u,this.anisotropy=Math.min(d,this.gl.renderer.parameters.maxAnisotropy),this.level=p,this.width=f,this.height=m,this.texture=this.gl.createTexture(),this.store={image:null},this.glState=this.gl.renderer.state,this.state={},this.state.minFilter=this.gl.NEAREST_MIPMAP_LINEAR,this.state.magFilter=this.gl.LINEAR,this.state.wrapS=this.gl.REPEAT,this.state.wrapT=this.gl.REPEAT,this.state.anisotropy=0}bind(){this.glState.textureUnits[this.glState.activeTextureUnit]!==this.id&&(this.gl.bindTexture(this.target,this.texture),this.glState.textureUnits[this.glState.activeTextureUnit]=this.id)}update(A=0){const t=!(this.image===this.store.image&&!this.needsUpdate);if((t||this.glState.textureUnits[A]!==this.id)&&(this.gl.renderer.activeTexture(A),this.bind()),t){if(this.needsUpdate=!1,this.flipY!==this.glState.flipY&&(this.gl.pixelStorei(this.gl.UNPACK_FLIP_Y_WEBGL,this.flipY),this.glState.flipY=this.flipY),this.premultiplyAlpha!==this.glState.premultiplyAlpha&&(this.gl.pixelStorei(this.gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL,this.premultiplyAlpha),this.glState.premultiplyAlpha=this.premultiplyAlpha),this.unpackAlignment!==this.glState.unpackAlignment&&(this.gl.pixelStorei(this.gl.UNPACK_ALIGNMENT,this.unpackAlignment),this.glState.unpackAlignment=this.unpackAlignment),this.minFilter!==this.state.minFilter&&(this.gl.texParameteri(this.target,this.gl.TEXTURE_MIN_FILTER,this.minFilter),this.state.minFilter=this.minFilter),this.magFilter!==this.state.magFilter&&(this.gl.texParameteri(this.target,this.gl.TEXTURE_MAG_FILTER,this.magFilter),this.state.magFilter=this.magFilter),this.wrapS!==this.state.wrapS&&(this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_S,this.wrapS),this.state.wrapS=this.wrapS),this.wrapT!==this.state.wrapT&&(this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_T,this.wrapT),this.state.wrapT=this.wrapT),this.anisotropy&&this.anisotropy!==this.state.anisotropy&&(this.gl.texParameterf(this.target,this.gl.renderer.getExtension("EXT_texture_filter_anisotropic").TEXTURE_MAX_ANISOTROPY_EXT,this.anisotropy),this.state.anisotropy=this.anisotropy),this.image){if(this.image.width&&(this.width=this.image.width,this.height=this.image.height),this.target===this.gl.TEXTURE_CUBE_MAP)for(let A=0;A<6;A++)this.gl.texImage2D(this.gl.TEXTURE_CUBE_MAP_POSITIVE_X+A,this.level,this.internalFormat,this.format,this.type,this.image[A]);else if(ArrayBuffer.isView(this.image))this.gl.texImage2D(this.target,this.level,this.internalFormat,this.width,this.height,0,this.format,this.type,this.image);else if(this.image.isCompressedTexture)for(let A=0;A<this.image.length;A++)this.gl.compressedTexImage2D(this.target,A,this.internalFormat,this.image[A].width,this.image[A].height,0,this.image[A].data);else this.gl.texImage2D(this.target,this.level,this.internalFormat,this.format,this.type,this.image);this.generateMipmaps&&(this.gl.renderer.isWebgl2||y(this.image.width)&&y(this.image.height)?this.gl.generateMipmap(this.target):(this.generateMipmaps=!1,this.wrapS=this.wrapT=this.gl.CLAMP_TO_EDGE,this.minFilter=this.gl.LINEAR)),this.onUpdate&&this.onUpdate()}else if(this.target===this.gl.TEXTURE_CUBE_MAP)for(let A=0;A<6;A++)this.gl.texImage2D(this.gl.TEXTURE_CUBE_MAP_POSITIVE_X+A,0,this.gl.RGBA,1,1,0,this.gl.RGBA,this.gl.UNSIGNED_BYTE,C);else this.width?this.gl.texImage2D(this.target,this.level,this.internalFormat,this.width,this.height,0,this.format,this.type,null):this.gl.texImage2D(this.target,0,this.gl.RGBA,1,1,0,this.gl.RGBA,this.gl.UNSIGNED_BYTE,C);this.store.image=this.image}}}function M(A,t,e){return A[0]=t[0]+e[0],A[1]=t[1]+e[1],A}function w(A,t,e){return A[0]=t[0]-e[0],A[1]=t[1]-e[1],A}function Q(A,t,e){return A[0]=t[0]*e,A[1]=t[1]*e,A}function S(A){var t=A[0],e=A[1];return Math.sqrt(t*t+e*e)}function b(A,t){return A[0]*t[1]-A[1]*t[0]}class U extends Array{constructor(A=0,t=A){return super(A,t),this}get x(){return this[0]}get y(){return this[1]}set x(A){this[0]=A}set y(A){this[1]=A}set(A,t=A){return A.length?this.copy(A):(function(A,t,e){A[0]=t,A[1]=e}(this,A,t),this)}copy(A){var t,e;return e=A,(t=this)[0]=e[0],t[1]=e[1],this}add(A,t){return t?M(this,A,t):M(this,this,A),this}sub(A,t){return t?w(this,A,t):w(this,this,A),this}multiply(A){var t,e;return A.length?(this,e=A,(t=this)[0]=this[0]*e[0],t[1]=this[1]*e[1]):Q(this,this,A),this}divide(A){var t,e;return A.length?(this,e=A,(t=this)[0]=this[0]/e[0],t[1]=this[1]/e[1]):Q(this,this,1/A),this}inverse(A=this){var t,e;return e=A,(t=this)[0]=1/e[0],t[1]=1/e[1],this}len(){return S(this)}distance(A){return A?(this,e=(t=A)[0]-this[0],i=t[1]-this[1],Math.sqrt(e*e+i*i)):S(this);var t,e,i}squaredLen(){return this.squaredDistance()}squaredDistance(A){return A?(this,(e=(t=A)[0]-this[0])*e+(i=t[1]-this[1])*i):function(A){var t=A[0],e=A[1];return t*t+e*e}(this);var t,e,i}negate(A=this){var t,e;return e=A,(t=this)[0]=-e[0],t[1]=-e[1],this}cross(A,t){return t?b(A,t):b(this,A)}scale(A){return Q(this,this,A),this}normalize(){var A,t,e,i;return this,(i=(t=(A=this)[0])*t+(e=A[1])*e)>0&&(i=1/Math.sqrt(i)),this[0]=A[0]*i,this[1]=A[1]*i,this}dot(A){return t=A,this[0]*t[0]+this[1]*t[1];var t}equals(A){return t=A,this[0]===t[0]&&this[1]===t[1];var t}applyMatrix3(A){var t,e,i;return this,t=A,e=this[0],i=this[1],this[0]=t[0]*e+t[3]*i+t[6],this[1]=t[1]*e+t[4]*i+t[7],this}applyMatrix4(A){return function(A,t,e){let i=t[0],r=t[1];A[0]=e[0]*i+e[4]*r+e[12],A[1]=e[1]*i+e[5]*r+e[13]}(this,this,A),this}lerp(A,t){return function(A,t,e,i){var r=t[0],n=t[1];A[0]=r+i*(e[0]-r),A[1]=n+i*(e[1]-n)}(this,this,A,t),this}clone(){return new U(this[0],this[1])}fromArray(A,t=0){return this[0]=A[t],this[1]=A[t+1],this}toArray(A=[],t=0){return A[t]=this[0],A[t+1]=this[1],A}}const L=-1,P=new l,j=new U,K=new U;function T(A,t,e){let i=t[0],r=t[1],n=t[2],s=t[3],a=t[4],o=t[5],h=t[6],l=t[7],c=t[8],g=e[0],u=e[1],d=e[2],p=e[3],f=e[4],m=e[5],E=e[6],x=e[7],I=e[8];return A[0]=g*i+u*s+d*h,A[1]=g*r+u*a+d*l,A[2]=g*n+u*o+d*c,A[3]=p*i+f*s+m*h,A[4]=p*r+f*a+m*l,A[5]=p*n+f*o+m*c,A[6]=E*i+x*s+I*h,A[7]=E*r+x*a+I*l,A[8]=E*n+x*o+I*c,A}class q extends Array{constructor(A=1,t=0,e=0,i=0,r=1,n=0,s=0,a=0,o=1){return super(A,t,e,i,r,n,s,a,o),this}set(A,t,e,i,r,n,s,a,o){return A.length?this.copy(A):(function(A,t,e,i,r,n,s,a,o,h){A[0]=t,A[1]=e,A[2]=i,A[3]=r,A[4]=n,A[5]=s,A[6]=a,A[7]=o,A[8]=h}(this,A,t,e,i,r,n,s,a,o),this)}translate(A,t=this){return function(A,t,e){let i=t[0],r=t[1],n=t[2],s=t[3],a=t[4],o=t[5],h=t[6],l=t[7],c=t[8],g=e[0],u=e[1];A[0]=i,A[1]=r,A[2]=n,A[3]=s,A[4]=a,A[5]=o,A[6]=g*i+u*s+h,A[7]=g*r+u*a+l,A[8]=g*n+u*o+c}(this,t,A),this}rotate(A,t=this){return function(A,t,e){let i=t[0],r=t[1],n=t[2],s=t[3],a=t[4],o=t[5],h=t[6],l=t[7],c=t[8],g=Math.sin(e),u=Math.cos(e);A[0]=u*i+g*s,A[1]=u*r+g*a,A[2]=u*n+g*o,A[3]=u*s-g*i,A[4]=u*a-g*r,A[5]=u*o-g*n,A[6]=h,A[7]=l,A[8]=c}(this,t,A),this}scale(A,t=this){return function(A,t,e){let i=e[0],r=e[1];A[0]=i*t[0],A[1]=i*t[1],A[2]=i*t[2],A[3]=r*t[3],A[4]=r*t[4],A[5]=r*t[5],A[6]=t[6],A[7]=t[7],A[8]=t[8]}(this,t,A),this}multiply(A,t){return t?T(this,A,t):T(this,this,A),this}identity(){var A;return(A=this)[0]=1,A[1]=0,A[2]=0,A[3]=0,A[4]=1,A[5]=0,A[6]=0,A[7]=0,A[8]=1,this}copy(A){var t,e;return e=A,(t=this)[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[8]=e[8],this}fromMatrix4(A){var t,e;return e=A,(t=this)[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[4],t[4]=e[5],t[5]=e[6],t[6]=e[8],t[7]=e[9],t[8]=e[10],this}fromQuaternion(A){return function(A,t){let e=t[0],i=t[1],r=t[2],n=t[3],s=e+e,a=i+i,o=r+r,h=e*s,l=i*s,c=i*a,g=r*s,u=r*a,d=r*o,p=n*s,f=n*a,m=n*o;A[0]=1-c-d,A[3]=l-m,A[6]=g+f,A[1]=l+m,A[4]=1-h-d,A[7]=u-p,A[2]=g-f,A[5]=u+p,A[8]=1-h-c}(this,A),this}fromBasis(A,t,e){return this.set(A[0],A[1],A[2],t[0],t[1],t[2],e[0],e[1],e[2]),this}inverse(A=this){return function(A,t){let e=t[0],i=t[1],r=t[2],n=t[3],s=t[4],a=t[5],o=t[6],h=t[7],l=t[8],c=l*s-a*h,g=-l*n+a*o,u=h*n-s*o,d=e*c+i*g+r*u;d&&(d=1/d,A[0]=c*d,A[1]=(-l*i+r*h)*d,A[2]=(a*i-r*s)*d,A[3]=g*d,A[4]=(l*e-r*o)*d,A[5]=(-a*e+r*n)*d,A[6]=u*d,A[7]=(-h*e+i*o)*d,A[8]=(s*e-i*n)*d)}(this,A),this}getNormalMatrix(A){return function(A,t){let e=t[0],i=t[1],r=t[2],n=t[3],s=t[4],a=t[5],o=t[6],h=t[7],l=t[8],c=t[9],g=t[10],u=t[11],d=t[12],p=t[13],f=t[14],m=t[15],E=e*a-i*s,x=e*o-r*s,I=e*h-n*s,R=i*o-r*a,v=i*h-n*a,C=r*h-n*o,y=l*p-c*d,B=l*f-g*d,F=l*m-u*d,M=c*f-g*p,w=c*m-u*p,Q=g*m-u*f,S=E*Q-x*w+I*M+R*F-v*B+C*y;S&&(S=1/S,A[0]=(a*Q-o*w+h*M)*S,A[1]=(o*F-s*Q-h*B)*S,A[2]=(s*w-a*F+h*y)*S,A[3]=(r*w-i*Q-n*M)*S,A[4]=(e*Q-r*F+n*B)*S,A[5]=(i*F-e*w-n*y)*S,A[6]=(p*C-f*v+m*R)*S,A[7]=(f*I-d*C-m*x)*S,A[8]=(d*v-p*I+m*E)*S)}(this,A),this}}let Y=0;class D extends x{constructor(A,{geometry:t,program:e,mode:i=A.TRIANGLES,frustumCulled:r=!0,renderOrder:n=0}={}){super(),A.canvas||console.error("gl not passed as first argument to Mesh"),this.gl=A,this.id=Y++,this.geometry=t,this.program=e,this.mode=i,this.frustumCulled=r,this.renderOrder=n,this.modelViewMatrix=new f,this.normalMatrix=new q,this.beforeRenderCallbacks=[],this.afterRenderCallbacks=[]}onBeforeRender(A){return this.beforeRenderCallbacks.push(A),this}onAfterRender(A){return this.afterRenderCallbacks.push(A),this}draw({camera:A}={}){this.beforeRenderCallbacks.forEach((t=>t&&t({mesh:this,camera:A}))),A&&(this.program.uniforms.modelMatrix||Object.assign(this.program.uniforms,{modelMatrix:{value:null},viewMatrix:{value:null},modelViewMatrix:{value:null},normalMatrix:{value:null},projectionMatrix:{value:null},cameraPosition:{value:null}}),this.program.uniforms.projectionMatrix.value=A.projectionMatrix,this.program.uniforms.cameraPosition.value=A.worldPosition,this.program.uniforms.viewMatrix.value=A.viewMatrix,this.modelViewMatrix.multiply(A.viewMatrix,this.worldMatrix),this.normalMatrix.getNormalMatrix(this.modelViewMatrix),this.program.uniforms.modelMatrix.value=this.worldMatrix,this.program.uniforms.modelViewMatrix.value=this.modelViewMatrix,this.program.uniforms.normalMatrix.value=this.normalMatrix);let t=this.program.cullFace&&this.worldMatrix.determinant()<0;this.program.use({flipFaces:t}),this.geometry.draw({mode:this.mode,program:this.program}),this.afterRenderCallbacks.forEach((t=>t&&t({mesh:this,camera:A})))}}const G=new l;let V=1,X=1,z=!1;class O{constructor(A,t={}){A.canvas||console.error("gl not passed as first argument to Geometry"),this.gl=A,this.attributes=t,this.id=V++,this.VAOs={},this.drawRange={start:0,count:0},this.instancedCount=0,this.gl.renderer.bindVertexArray(null),this.gl.renderer.currentGeometry=null,this.glState=this.gl.renderer.state;for(let A in t)this.addAttribute(A,t[A])}addAttribute(A,t){if(this.attributes[A]=t,t.id=X++,t.size=t.size||1,t.type=t.type||(t.data.constructor===Float32Array?this.gl.FLOAT:t.data.constructor===Uint16Array?this.gl.UNSIGNED_SHORT:this.gl.UNSIGNED_INT),t.target="index"===A?this.gl.ELEMENT_ARRAY_BUFFER:this.gl.ARRAY_BUFFER,t.normalized=t.normalized||!1,t.stride=t.stride||0,t.offset=t.offset||0,t.count=t.count||(t.stride?t.data.byteLength/t.stride:t.data.length/t.size),t.divisor=t.instanced||0,t.needsUpdate=!1,t.usage=t.usage||this.gl.STATIC_DRAW,t.buffer||this.updateAttribute(t),t.divisor){if(this.isInstanced=!0,this.instancedCount&&this.instancedCount!==t.count*t.divisor)return console.warn("geometry has multiple instanced buffers of different length"),this.instancedCount=Math.min(this.instancedCount,t.count*t.divisor);this.instancedCount=t.count*t.divisor}else"index"===A?this.drawRange.count=t.count:this.attributes.index||(this.drawRange.count=Math.max(this.drawRange.count,t.count))}updateAttribute(A){const t=!A.buffer;t&&(A.buffer=this.gl.createBuffer()),this.glState.boundBuffer!==A.buffer&&(this.gl.bindBuffer(A.target,A.buffer),this.glState.boundBuffer=A.buffer),t?this.gl.bufferData(A.target,A.data,A.usage):this.gl.bufferSubData(A.target,0,A.data),A.needsUpdate=!1}setIndex(A){this.addAttribute("index",A)}setDrawRange(A,t){this.drawRange.start=A,this.drawRange.count=t}setInstancedCount(A){this.instancedCount=A}createVAO(A){this.VAOs[A.attributeOrder]=this.gl.renderer.createVertexArray(),this.gl.renderer.bindVertexArray(this.VAOs[A.attributeOrder]),this.bindAttributes(A)}bindAttributes(A){A.attributeLocations.forEach(((A,{name:t,type:e})=>{if(!this.attributes[t])return void console.warn(`active attribute ${t} not being supplied`);const i=this.attributes[t];this.gl.bindBuffer(i.target,i.buffer),this.glState.boundBuffer=i.buffer;let r=1;35674===e&&(r=2),35675===e&&(r=3),35676===e&&(r=4);const n=i.size/r,s=1===r?0:r*r*r,a=1===r?0:r*r;for(let t=0;t<r;t++)this.gl.vertexAttribPointer(A+t,n,i.type,i.normalized,i.stride+s,i.offset+t*a),this.gl.enableVertexAttribArray(A+t),this.gl.renderer.vertexAttribDivisor(A+t,i.divisor)})),this.attributes.index&&this.gl.bindBuffer(this.gl.ELEMENT_ARRAY_BUFFER,this.attributes.index.buffer)}draw({program:A,mode:t=this.gl.TRIANGLES}){this.gl.renderer.currentGeometry!==`${this.id}_${A.attributeOrder}`&&(this.VAOs[A.attributeOrder]||this.createVAO(A),this.gl.renderer.bindVertexArray(this.VAOs[A.attributeOrder]),this.gl.renderer.currentGeometry=`${this.id}_${A.attributeOrder}`),A.attributeLocations.forEach(((A,{name:t})=>{const e=this.attributes[t];e.needsUpdate&&this.updateAttribute(e)})),this.isInstanced?this.attributes.index?this.gl.renderer.drawElementsInstanced(t,this.drawRange.count,this.attributes.index.type,this.attributes.index.offset+2*this.drawRange.start,this.instancedCount):this.gl.renderer.drawArraysInstanced(t,this.drawRange.start,this.drawRange.count,this.instancedCount):this.attributes.index?this.gl.drawElements(t,this.drawRange.count,this.attributes.index.type,this.attributes.index.offset+2*this.drawRange.start):this.gl.drawArrays(t,this.drawRange.start,this.drawRange.count)}getPosition(){const A=this.attributes.position;return A.data?A:z?void 0:(console.warn("No position buffer data found to compute bounds"),z=!0)}computeBoundingBox(A){A||(A=this.getPosition());const t=A.data,e=A.stride?A.stride/t.BYTES_PER_ELEMENT:A.size;this.bounds||(this.bounds={min:new l,max:new l,center:new l,scale:new l,radius:1/0});const i=this.bounds.min,r=this.bounds.max,n=this.bounds.center,s=this.bounds.scale;i.set(1/0),r.set(-1/0);for(let A=0,n=t.length;A<n;A+=e){const e=t[A],n=t[A+1],s=t[A+2];i.x=Math.min(e,i.x),i.y=Math.min(n,i.y),i.z=Math.min(s,i.z),r.x=Math.max(e,r.x),r.y=Math.max(n,r.y),r.z=Math.max(s,r.z)}s.sub(r,i),n.add(i,r).divide(2)}computeBoundingSphere(A){A||(A=this.getPosition());const t=A.data,e=A.stride?A.stride/t.BYTES_PER_ELEMENT:A.size;this.bounds||this.computeBoundingBox(A);let i=0;for(let A=0,r=t.length;A<r;A+=e)G.fromArray(t,A),i=Math.max(i,this.bounds.center.squaredDistance(G));this.bounds.radius=Math.sqrt(i)}remove(){for(let A in this.VAOs)this.gl.renderer.deleteVertexArray(this.VAOs[A]),delete this.VAOs[A];for(let A in this.attributes)this.gl.deleteBuffer(this.attributes[A].buffer),delete this.attributes[A]}}let k=1;const J={};class H{constructor(A,{vertex:t,fragment:e,uniforms:i={},transparent:r=!1,cullFace:n=A.BACK,frontFace:s=A.CCW,depthTest:a=!0,depthWrite:o=!0,depthFunc:h=A.LESS}={}){A.canvas||console.error("gl not passed as fist argument to Program"),this.gl=A,this.uniforms=i,this.id=k++,t||console.warn("vertex shader not supplied"),e||console.warn("fragment shader not supplied"),this.transparent=r,this.cullFace=n,this.frontFace=s,this.depthTest=a,this.depthWrite=o,this.depthFunc=h,this.blendFunc={},this.blendEquation={},this.transparent&&!this.blendFunc.src&&(this.gl.renderer.premultipliedAlpha?this.setBlendFunc(this.gl.ONE,this.gl.ONE_MINUS_SRC_ALPHA):this.setBlendFunc(this.gl.SRC_ALPHA,this.gl.ONE_MINUS_SRC_ALPHA));const l=A.createShader(A.VERTEX_SHADER);A.shaderSource(l,t),A.compileShader(l),""!==A.getShaderInfoLog(l)&&console.warn(`${A.getShaderInfoLog(l)}\nVertex Shader\n${N(t)}`);const c=A.createShader(A.FRAGMENT_SHADER);if(A.shaderSource(c,e),A.compileShader(c),""!==A.getShaderInfoLog(c)&&console.warn(`${A.getShaderInfoLog(c)}\nFragment Shader\n${N(e)}`),this.program=A.createProgram(),A.attachShader(this.program,l),A.attachShader(this.program,c),A.linkProgram(this.program),!A.getProgramParameter(this.program,A.LINK_STATUS))return console.warn(A.getProgramInfoLog(this.program));A.deleteShader(l),A.deleteShader(c),this.uniformLocations=new Map;let g=A.getProgramParameter(this.program,A.ACTIVE_UNIFORMS);for(let t=0;t<g;t++){let e=A.getActiveUniform(this.program,t);this.uniformLocations.set(e,A.getUniformLocation(this.program,e.name));const i=e.name.match(/(\w+)/g);e.uniformName=i[0],3===i.length?(e.isStructArray=!0,e.structIndex=Number(i[1]),e.structProperty=i[2]):2===i.length&&isNaN(Number(i[1]))&&(e.isStruct=!0,e.structProperty=i[1])}this.attributeLocations=new Map;const u=[],d=A.getProgramParameter(this.program,A.ACTIVE_ATTRIBUTES);for(let t=0;t<d;t++){const e=A.getActiveAttrib(this.program,t),i=A.getAttribLocation(this.program,e.name);u[i]=e.name,this.attributeLocations.set(e,i)}this.attributeOrder=u.join("")}setBlendFunc(A,t,e,i){this.blendFunc.src=A,this.blendFunc.dst=t,this.blendFunc.srcAlpha=e,this.blendFunc.dstAlpha=i,A&&(this.transparent=!0)}setBlendEquation(A,t){this.blendEquation.modeRGB=A,this.blendEquation.modeAlpha=t}applyState(){this.depthTest?this.gl.renderer.enable(this.gl.DEPTH_TEST):this.gl.renderer.disable(this.gl.DEPTH_TEST),this.cullFace?this.gl.renderer.enable(this.gl.CULL_FACE):this.gl.renderer.disable(this.gl.CULL_FACE),this.blendFunc.src?this.gl.renderer.enable(this.gl.BLEND):this.gl.renderer.disable(this.gl.BLEND),this.cullFace&&this.gl.renderer.setCullFace(this.cullFace),this.gl.renderer.setFrontFace(this.frontFace),this.gl.renderer.setDepthMask(this.depthWrite),this.gl.renderer.setDepthFunc(this.depthFunc),this.blendFunc.src&&this.gl.renderer.setBlendFunc(this.blendFunc.src,this.blendFunc.dst,this.blendFunc.srcAlpha,this.blendFunc.dstAlpha),this.gl.renderer.setBlendEquation(this.blendEquation.modeRGB,this.blendEquation.modeAlpha)}use({flipFaces:A=!1}={}){let t=-1;this.gl.renderer.currentProgram===this.id||(this.gl.useProgram(this.program),this.gl.renderer.currentProgram=this.id),this.uniformLocations.forEach(((A,e)=>{let i=e.uniformName,r=this.uniforms[i];if(e.isStruct&&(r=r[e.structProperty],i+=`.${e.structProperty}`),e.isStructArray&&(r=r[e.structIndex][e.structProperty],i+=`[${e.structIndex}].${e.structProperty}`),!r)return _(`Active uniform ${i} has not been supplied`);if(r&&void 0===r.value)return _(`${i} uniform is missing a value parameter`);if(r.value.texture)return t+=1,r.value.update(t),W(this.gl,e.type,A,t);if(r.value.length&&r.value[0].texture){const i=[];return r.value.forEach((A=>{t+=1,A.update(t),i.push(t)})),W(this.gl,e.type,A,i)}W(this.gl,e.type,A,r.value)})),this.applyState(),A&&this.gl.renderer.setFrontFace(this.frontFace===this.gl.CCW?this.gl.CW:this.gl.CCW)}remove(){this.gl.deleteProgram(this.program)}}function W(A,t,e,i){i=i.length?function(A){const t=A.length,e=A[0].length;if(void 0===e)return A;const i=t*e;let r=J[i];r||(J[i]=r=new Float32Array(i));for(let i=0;i<t;i++)r.set(A[i],i*e);return r}(i):i;const r=A.renderer.state.uniformLocations.get(e);if(i.length)if(void 0===r||r.length!==i.length)A.renderer.state.uniformLocations.set(e,i.slice(0));else{if(function(A,t){if(A.length!==t.length)return!1;for(let e=0,i=A.length;e<i;e++)if(A[e]!==t[e])return!1;return!0}(r,i))return;r.set?r.set(i):function(A,t){for(let e=0,i=A.length;e<i;e++)A[e]=t[e]}(r,i),A.renderer.state.uniformLocations.set(e,r)}else{if(r===i)return;A.renderer.state.uniformLocations.set(e,i)}switch(t){case 5126:return i.length?A.uniform1fv(e,i):A.uniform1f(e,i);case 35664:return A.uniform2fv(e,i);case 35665:return A.uniform3fv(e,i);case 35666:return A.uniform4fv(e,i);case 35670:case 5124:case 35678:case 35680:return i.length?A.uniform1iv(e,i):A.uniform1i(e,i);case 35671:case 35667:return A.uniform2iv(e,i);case 35672:case 35668:return A.uniform3iv(e,i);case 35673:case 35669:return A.uniform4iv(e,i);case 35674:return A.uniformMatrix2fv(e,!1,i);case 35675:return A.uniformMatrix3fv(e,!1,i);case 35676:return A.uniformMatrix4fv(e,!1,i)}}function N(A){let t=A.split("\n");for(let A=0;A<t.length;A++)t[A]=A+1+": "+t[A];return t.join("\n")}let Z=0;function _(A){Z>100||(console.warn(A),Z++,Z>100&&console.warn("More than 100 program warnings - stopping logs."))}const $=new class{#A={};on=(A,t)=>{this.#A[A]||(this.#A[A]=[]),this.#A[A].push(t)};off=(A,t)=>{const e=this.#A[A];if(e){let A=e.indexOf(t);-1!==A&&e.splice(A,1)}};dispatch=(A,t)=>{this.#A[A]&&this.#A[A].forEach((A=>A(t)))}},AA={},tA=(A,t)=>(A in AA||(void 0===t&&(t=null),AA[A]={value:t}),AA[A]),eA=(A,t)=>{A in AA?AA[A].value=t:AA[A]={value:t}};const iA="attribute vec2 uv;\nattribute vec2 position;\n\nvarying vec2 vUv;\nvarying vec2 vPos;\n\nvoid main() {\n  vUv = uv;\n  vPos = position;\n  gl_Position = vec4(position, inject_z, 1.);\n}\n";class rA extends O{constructor(A,{attributes:t={}}={}){Object.assign(t,{position:{size:2,data:new Float32Array([-1,-1,3,-1,-1,3])},uv:{size:2,data:new Float32Array([0,0,2,0,0,2])}}),super(A,t)}}const nA={black:"#000000",white:"#ffffff",red:"#ff0000",green:"#00ff00",blue:"#0000ff",fuchsia:"#ff00ff",cyan:"#00ffff",yellow:"#ffff00",orange:"#ff8000"};function sA(A){4===A.length&&(A=A[0]+A[1]+A[1]+A[2]+A[2]+A[3]+A[3]);const t=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(A);return t||console.warn(`Unable to convert hex string ${A} to rgb values`),[parseInt(t[1],16)/255,parseInt(t[2],16)/255,parseInt(t[3],16)/255]}function aA(A){return[((A=parseInt(A))>>16&255)/255,(A>>8&255)/255,(255&A)/255]}function oA(A){return void 0===A?[0,0,0]:3===arguments.length?arguments:isNaN(A)?"#"===A[0]?sA(A):nA[A.toLowerCase()]?sA(nA[A.toLowerCase()]):(console.warn("Color format not recognised"),[0,0,0]):aA(A)}class hA extends Array{constructor(A){return Array.isArray(A)?super(...A):super(...oA(...arguments))}get r(){return this[0]}get g(){return this[1]}get b(){return this[2]}set r(A){this[0]=A}set g(A){this[1]=A}set b(A){this[2]=A}set(A){return Array.isArray(A)?this.copy(A):this.copy(oA(...arguments))}copy(A){return this[0]=A[0],this[1]=A[1],this[2]=A[2],this}}var lA=function(){var A=0,t=document.createElement("div");function e(A){return t.appendChild(A.dom),A}function i(e){for(var i=0;i<t.children.length;i++)t.children[i].style.display=i===e?"block":"none";A=e}t.style.cssText="position:fixed;top:0;left:0;cursor:pointer;opacity:0.9;z-index:10000",t.addEventListener("click",(function(e){e.preventDefault(),i(++A%t.children.length)}),!1);var r=(performance||Date).now(),n=r,s=0,a=e(new lA.Panel("FPS","#0ff","#002")),o=e(new lA.Panel("MS","#0f0","#020"));if(self.performance&&self.performance.memory)var h=e(new lA.Panel("MB","#f08","#201"));return i(0),{REVISION:16,dom:t,addPanel:e,showPanel:i,begin:function(){r=(performance||Date).now()},end:function(){s++;var A=(performance||Date).now();if(o.update(A-r,200),A>=n+1e3&&(a.update(1e3*s/(A-n),100),n=A,s=0,h)){var t=performance.memory;h.update(t.usedJSHeapSize/1048576,t.jsHeapSizeLimit/1048576)}return A},update:function(){r=this.end()},domElement:t,setMode:i}};lA.Panel=function(A,t,e){var i=1/0,r=0,n=Math.round,s=n(window.devicePixelRatio||1),a=80*s,o=48*s,h=3*s,l=2*s,c=3*s,g=15*s,u=74*s,d=30*s,p=document.createElement("canvas");p.width=a,p.height=o,p.style.cssText="width:80px;height:48px";var f=p.getContext("2d");return f.font="bold "+9*s+"px Helvetica,Arial,sans-serif",f.textBaseline="top",f.fillStyle=e,f.fillRect(0,0,a,o),f.fillStyle=t,f.fillText(A,h,l),f.fillRect(c,g,u,d),f.fillStyle=e,f.globalAlpha=.9,f.fillRect(c,g,u,d),{dom:p,update:function(o,m){i=Math.min(i,o),r=Math.max(r,o),f.fillStyle=e,f.globalAlpha=1,f.fillRect(0,0,a,g),f.fillStyle=t,f.fillText(n(o)+" "+A+" ("+n(i)+"-"+n(r)+")",h,l),f.drawImage(p,c+s,g,u-s,d,c,g,u-s,d),f.fillRect(c+u-s,g,s,d),f.fillStyle=e,f.globalAlpha=.9,f.fillRect(c+u-s,g,s,n((1-o/m)*d))}}};const cA=new l;let gA=1;class uA{constructor({canvas:A=document.createElement("canvas"),width:t=300,height:e=150,dpr:i=1,alpha:r=!1,depth:n=!0,stencil:s=!1,antialias:a=!1,premultipliedAlpha:o=!1,preserveDrawingBuffer:h=!1,powerPreference:l="default",autoClear:c=!0,webgl:g=2}={}){const u={alpha:r,depth:n,stencil:s,antialias:a,premultipliedAlpha:o,preserveDrawingBuffer:h,powerPreference:l};this.dpr=i,this.alpha=r,this.color=!0,this.depth=n,this.stencil=s,this.premultipliedAlpha=o,this.autoClear=c,this.id=gA++,2===g&&(this.gl=A.getContext("webgl2",u)),this.isWebgl2=!!this.gl,this.gl||(this.gl=A.getContext("webgl",u)),this.gl||console.error("unable to create webgl context"),this.gl.renderer=this,this.setSize(t,e),this.state={},this.state.blendFunc={src:this.gl.ONE,dst:this.gl.ZERO},this.state.blendEquation={modeRGB:this.gl.FUNC_ADD},this.state.cullFace=null,this.state.frontFace=this.gl.CCW,this.state.depthMask=!0,this.state.depthFunc=this.gl.LESS,this.state.premultiplyAlpha=!1,this.state.flipY=!1,this.state.unpackAlignment=4,this.state.framebuffer=null,this.state.viewport={x:0,y:0,width:null,height:null},this.state.textureUnits=[],this.state.activeTextureUnit=0,this.state.boundBuffer=null,this.state.uniformLocations=new Map,this.extensions={},this.isWebgl2?(this.getExtension("EXT_color_buffer_float"),this.getExtension("OES_texture_float_linear")):(this.getExtension("OES_texture_float"),this.getExtension("OES_texture_float_linear"),this.getExtension("OES_texture_half_float"),this.getExtension("OES_texture_half_float_linear"),this.getExtension("OES_element_index_uint"),this.getExtension("OES_standard_derivatives"),this.getExtension("EXT_sRGB"),this.getExtension("WEBGL_depth_texture"),this.getExtension("WEBGL_draw_buffers")),this.getExtension("WEBGL_compressed_texture_astc"),this.getExtension("EXT_texture_compression_bptc"),this.getExtension("WEBGL_compressed_texture_s3tc"),this.getExtension("WEBGL_compressed_texture_etc1"),this.getExtension("WEBGL_compressed_texture_pvrtc"),this.getExtension("WEBKIT_WEBGL_compressed_texture_pvrtc"),this.vertexAttribDivisor=this.getExtension("ANGLE_instanced_arrays","vertexAttribDivisor","vertexAttribDivisorANGLE"),this.drawArraysInstanced=this.getExtension("ANGLE_instanced_arrays","drawArraysInstanced","drawArraysInstancedANGLE"),this.drawElementsInstanced=this.getExtension("ANGLE_instanced_arrays","drawElementsInstanced","drawElementsInstancedANGLE"),this.createVertexArray=this.getExtension("OES_vertex_array_object","createVertexArray","createVertexArrayOES"),this.bindVertexArray=this.getExtension("OES_vertex_array_object","bindVertexArray","bindVertexArrayOES"),this.deleteVertexArray=this.getExtension("OES_vertex_array_object","deleteVertexArray","deleteVertexArrayOES"),this.drawBuffers=this.getExtension("WEBGL_draw_buffers","drawBuffers","drawBuffersWEBGL"),this.parameters={},this.parameters.maxTextureUnits=this.gl.getParameter(this.gl.MAX_COMBINED_TEXTURE_IMAGE_UNITS),this.parameters.maxAnisotropy=this.getExtension("EXT_texture_filter_anisotropic")?this.gl.getParameter(this.getExtension("EXT_texture_filter_anisotropic").MAX_TEXTURE_MAX_ANISOTROPY_EXT):0}setSize(A,t){this.width=A,this.height=t,this.gl.canvas.width=A*this.dpr,this.gl.canvas.height=t*this.dpr,Object.assign(this.gl.canvas.style,{width:A+"px",height:t+"px"})}setViewport(A,t,e=0,i=0){this.state.viewport.width===A&&this.state.viewport.height===t||(this.state.viewport.width=A,this.state.viewport.height=t,this.state.viewport.x=e,this.state.viewport.y=i,this.gl.viewport(e,i,A,t))}setScissor(A,t,e=0,i=0){this.gl.scissor(e,i,A,t)}enable(A){!0!==this.state[A]&&(this.gl.enable(A),this.state[A]=!0)}disable(A){!1!==this.state[A]&&(this.gl.disable(A),this.state[A]=!1)}setBlendFunc(A,t,e,i){this.state.blendFunc.src===A&&this.state.blendFunc.dst===t&&this.state.blendFunc.srcAlpha===e&&this.state.blendFunc.dstAlpha===i||(this.state.blendFunc.src=A,this.state.blendFunc.dst=t,this.state.blendFunc.srcAlpha=e,this.state.blendFunc.dstAlpha=i,void 0!==e?this.gl.blendFuncSeparate(A,t,e,i):this.gl.blendFunc(A,t))}setBlendEquation(A,t){A=A||this.gl.FUNC_ADD,this.state.blendEquation.modeRGB===A&&this.state.blendEquation.modeAlpha===t||(this.state.blendEquation.modeRGB=A,this.state.blendEquation.modeAlpha=t,void 0!==t?this.gl.blendEquationSeparate(A,t):this.gl.blendEquation(A))}setCullFace(A){this.state.cullFace!==A&&(this.state.cullFace=A,this.gl.cullFace(A))}setFrontFace(A){this.state.frontFace!==A&&(this.state.frontFace=A,this.gl.frontFace(A))}setDepthMask(A){this.state.depthMask!==A&&(this.state.depthMask=A,this.gl.depthMask(A))}setDepthFunc(A){this.state.depthFunc!==A&&(this.state.depthFunc=A,this.gl.depthFunc(A))}activeTexture(A){this.state.activeTextureUnit!==A&&(this.state.activeTextureUnit=A,this.gl.activeTexture(this.gl.TEXTURE0+A))}bindFramebuffer({target:A=this.gl.FRAMEBUFFER,buffer:t=null}={}){this.state.framebuffer!==t&&(this.state.framebuffer=t,this.gl.bindFramebuffer(A,t))}getExtension(A,t,e){return t&&this.gl[t]?this.gl[t].bind(this.gl):(this.extensions[A]||(this.extensions[A]=this.gl.getExtension(A)),t?this.extensions[A]?this.extensions[A][e].bind(this.extensions[A]):null:this.extensions[A])}sortOpaque(A,t){return A.renderOrder!==t.renderOrder?A.renderOrder-t.renderOrder:A.program.id!==t.program.id?A.program.id-t.program.id:A.zDepth!==t.zDepth?A.zDepth-t.zDepth:t.id-A.id}sortTransparent(A,t){return A.renderOrder!==t.renderOrder?A.renderOrder-t.renderOrder:A.zDepth!==t.zDepth?t.zDepth-A.zDepth:t.id-A.id}sortUI(A,t){return A.renderOrder!==t.renderOrder?A.renderOrder-t.renderOrder:A.program.id!==t.program.id?A.program.id-t.program.id:t.id-A.id}getRenderList({scene:A,camera:t,frustumCull:e,sort:i}){let r=[];if(t&&e&&t.updateFrustum(),A.traverse((A=>{if(!A.visible)return!0;A.draw&&(e&&A.frustumCulled&&t&&!t.frustumIntersectsMesh(A)||r.push(A))})),i){const A=[],e=[],i=[];r.forEach((r=>{r.program.transparent?r.program.depthTest?e.push(r):i.push(r):A.push(r),r.zDepth=0,0===r.renderOrder&&r.program.depthTest&&t&&(r.worldMatrix.getTranslation(cA),cA.applyMatrix4(t.projectionViewMatrix),r.zDepth=cA.z)})),A.sort(this.sortOpaque),e.sort(this.sortTransparent),i.sort(this.sortUI),r=A.concat(e,i)}return r}render({scene:A,camera:t,target:e=null,update:i=!0,sort:r=!0,frustumCull:n=!0,clear:s}){null===e?(this.bindFramebuffer(),this.setViewport(this.width*this.dpr,this.height*this.dpr)):(this.bindFramebuffer(e),this.setViewport(e.width,e.height)),(s||this.autoClear&&!1!==s)&&(!this.depth||e&&!e.depth||(this.enable(this.gl.DEPTH_TEST),this.setDepthMask(!0)),this.gl.clear((this.color?this.gl.COLOR_BUFFER_BIT:0)|(this.depth?this.gl.DEPTH_BUFFER_BIT:0)|(this.stencil?this.gl.STENCIL_BUFFER_BIT:0))),i&&A.updateMatrixWorld(),t&&t.updateMatrixWorld(),this.getRenderList({scene:A,camera:t,frustumCull:n,sort:r}).forEach((A=>{A.draw({camera:t})}))}}class dA{constructor(A,{width:t=A.canvas.width,height:e=A.canvas.height,target:i=A.FRAMEBUFFER,color:r=1,depth:n=!0,stencil:s=!1,depthTexture:a=!1,wrapS:o=A.CLAMP_TO_EDGE,wrapT:h=A.CLAMP_TO_EDGE,minFilter:l=A.LINEAR,magFilter:c=l,type:g=A.UNSIGNED_BYTE,format:u=A.RGBA,internalFormat:d=u,unpackAlignment:p,premultiplyAlpha:f}={}){this.gl=A,this.width=t,this.height=e,this.depth=n,this.buffer=this.gl.createFramebuffer(),this.target=i,this.gl.bindFramebuffer(this.target,this.buffer),this.textures=[];const m=[];for(let i=0;i<r;i++)this.textures.push(new F(A,{width:t,height:e,wrapS:o,wrapT:h,minFilter:l,magFilter:c,type:g,format:u,internalFormat:d,unpackAlignment:p,premultiplyAlpha:f,flipY:!1,generateMipmaps:!1})),this.textures[i].update(),this.gl.framebufferTexture2D(this.target,this.gl.COLOR_ATTACHMENT0+i,this.gl.TEXTURE_2D,this.textures[i].texture,0),m.push(this.gl.COLOR_ATTACHMENT0+i);m.length>1&&this.gl.renderer.drawBuffers(m),this.texture=this.textures[0],a&&(this.gl.renderer.isWebgl2||this.gl.renderer.getExtension("WEBGL_depth_texture"))?(this.depthTexture=new F(A,{width:t,height:e,minFilter:this.gl.NEAREST,magFilter:this.gl.NEAREST,format:this.gl.DEPTH_COMPONENT,internalFormat:A.renderer.isWebgl2?this.gl.DEPTH_COMPONENT16:this.gl.DEPTH_COMPONENT,type:this.gl.UNSIGNED_INT}),this.depthTexture.update(),this.gl.framebufferTexture2D(this.target,this.gl.DEPTH_ATTACHMENT,this.gl.TEXTURE_2D,this.depthTexture.texture,0)):(n&&!s&&(this.depthBuffer=this.gl.createRenderbuffer(),this.gl.bindRenderbuffer(this.gl.RENDERBUFFER,this.depthBuffer),this.gl.renderbufferStorage(this.gl.RENDERBUFFER,this.gl.DEPTH_COMPONENT16,t,e),this.gl.framebufferRenderbuffer(this.target,this.gl.DEPTH_ATTACHMENT,this.gl.RENDERBUFFER,this.depthBuffer)),s&&!n&&(this.stencilBuffer=this.gl.createRenderbuffer(),this.gl.bindRenderbuffer(this.gl.RENDERBUFFER,this.stencilBuffer),this.gl.renderbufferStorage(this.gl.RENDERBUFFER,this.gl.STENCIL_INDEX8,t,e),this.gl.framebufferRenderbuffer(this.target,this.gl.STENCIL_ATTACHMENT,this.gl.RENDERBUFFER,this.stencilBuffer)),n&&s&&(this.depthStencilBuffer=this.gl.createRenderbuffer(),this.gl.bindRenderbuffer(this.gl.RENDERBUFFER,this.depthStencilBuffer),this.gl.renderbufferStorage(this.gl.RENDERBUFFER,this.gl.DEPTH_STENCIL,t,e),this.gl.framebufferRenderbuffer(this.target,this.gl.DEPTH_STENCIL_ATTACHMENT,this.gl.RENDERBUFFER,this.depthStencilBuffer))),this.gl.bindFramebuffer(this.target,null)}setSize(A,t){if(this.width!==A||this.height!==t){this.width=A,this.height=t,this.gl.bindFramebuffer(this.target,this.buffer);for(let e=0;e<this.textures.length;e++)this.textures[e].width=A,this.textures[e].height=t,this.textures[e].needsUpdate=!0,this.textures[e].update(),this.gl.framebufferTexture2D(this.target,this.gl.COLOR_ATTACHMENT0+e,this.gl.TEXTURE_2D,this.textures[e].texture,0);this.depthTexture?(this.depthTexture.width=A,this.depthTexture.height=t,this.depthTexture.needsUpdate=!0,this.depthTexture.update(),this.gl.framebufferTexture2D(this.target,this.gl.DEPTH_ATTACHMENT,this.gl.TEXTURE_2D,this.depthTexture.texture,0)):(this.depthBuffer&&(this.gl.bindRenderbuffer(this.gl.RENDERBUFFER,this.depthBuffer),this.gl.renderbufferStorage(this.gl.RENDERBUFFER,this.gl.DEPTH_COMPONENT16,A,t)),this.stencilBuffer&&(this.gl.bindRenderbuffer(this.gl.RENDERBUFFER,this.stencilBuffer),this.gl.renderbufferStorage(this.gl.RENDERBUFFER,this.gl.STENCIL_INDEX8,A,t)),this.depthStencilBuffer&&(this.gl.bindRenderbuffer(this.gl.RENDERBUFFER,this.depthStencilBuffer),this.gl.renderbufferStorage(this.gl.RENDERBUFFER,this.gl.DEPTH_STENCIL,A,t))),this.gl.bindFramebuffer(this.target,null)}}}const pA="precision highp float;\nattribute vec2 uv;\n\nvarying vec2 vUv;\n\nvoid main() {\n  vUv = uv;\n  gl_Position = vec4(2. * uv - 1., 0., 1.);\n}\n";class fA{constructor(A,t){t.forEach((A=>!A.out&&(A.out={})));const e=Object.assign({map:tA("post.screen")},...t.map((A=>A.out.uniforms))),i=`\nprecision highp float;\n#define saturate(x) clamp(x, 0., 1.)\nvarying vec2 vUv;\nuniform sampler2D map;\n\n${t.map((A=>A.out.declarations)).join("")}\n\nvoid main() {\n  vec2 uv = vUv;\n  vec3 color = texture2D(map, uv).rgb;\n\n  ${t.map((A=>A.out.inject)).join("")}\n\n  gl_FragColor = vec4(saturate(color), 1.);\n}\n    `;this.program=new H(A,{uniforms:e,vertex:pA,fragment:i,depthTest:!1})}render=({renderer:A,quad:t,camera:e})=>{t.program=this.program,A.render({scene:t,camera:e})}}class mA{constructor(A,{width:t,height:e},i){this.superSampling=2,this.filterProgram=new H(A,{uniforms:{map:tA("post.screen"),pixelSize:tA("screen.pixelSize")},vertex:pA,fragment:"precision highp float;\n#define s(x) clamp(x, 0., 1.)\n\nvarying vec2 vUv;\n\nuniform sampler2D map;\nuniform vec2 pixelSize;\n\nvoid main() {\n  vec3 c = s(texture2D(map, vUv).rgb);\n  vec3 N = s(texture2D(map, vec2(vUv.x, vUv.y - pixelSize.y)).rgb);\n  vec3 S = s(texture2D(map, vec2(vUv.x, vUv.y + pixelSize.y)).rgb);\n  vec3 W = s(texture2D(map, vec2(vUv.x - pixelSize.x, vUv.y)).rgb);\n  vec3 E = s(texture2D(map, vec2(vUv.x + pixelSize.x, vUv.y)).rgb);\n  vec3 m = max(\n    max(abs(c - N), abs(c - S)),\n    max(abs(c - W), abs(c - E))\n  );\n  float v = s(m.x + m.y + m.z);\n  gl_FragColor = vec4(v, 0., 0., 1.);\n}\n"}),this.filterRenderTarget=new dA(A,{width:t,height:e,...i}),eA("post.essaa.filter",this.filterRenderTarget.texture),this.overlayProgram=new H(A,{uniforms:{scene:tA("post.screen"),edges:{value:this.filterRenderTarget.texture}},vertex:pA,fragment:"precision highp float;\nvarying vec2 vUv;\n\nuniform sampler2D scene;\nuniform sampler2D edges;\n\nvoid main() {\n  if (texture2D(edges, vUv).r > .5) discard;\n  gl_FragColor = texture2D(scene, vUv);\n}\n"}),this.overlayRenderTarget=new dA(A,{width:this.superSampling*t,height:this.superSampling*e,...i}),eA("post.essaa.overlay",this.overlayRenderTarget.texture),$.on("resize",this.onResize)}render=({renderer:A,scene:t,quad:e,camera:i})=>{e.program=this.filterProgram,A.render({scene:e,camera:i,target:this.filterRenderTarget}),e.program=this.overlayProgram,A.render({scene:e,camera:i,target:this.overlayRenderTarget}),$.dispatch("essaa.needsDepth",!1),eA("screen.superSample",this.superSampling);const r=A.autoClear;A.autoClear=!1,A.render({scene:t,camera:i,target:this.overlayRenderTarget}),$.dispatch("essaa.needsDepth",!0),eA("screen.superSample",1),A.autoClear=r,eA("post.screen",this.overlayRenderTarget.texture)};onResize=({width:A,height:t})=>{this.filterRenderTarget.setSize(A,t),this.overlayRenderTarget.setSize(A*this.superSampling,t*this.superSampling)}}class EA{out={inject:"{\n      float vignette = saturate(length(uv * 2. - 1.));\n      vignette = smoothstep(.5, 1., vignette);\n      color = mix(color, vec3(1.), vignette);\n    }"}}const xA={visible:!0,minDistance:6,maxDistance:12,count:40,rotationSpeed:.08,modulationRate:.6,size:50,yShift:-1};let IA=0,RA=0,vA=1,CA=!0,yA=!0,BA=!1,FA=!0,MA=!1,wA=0,QA=!1;const SA=document.getElementById("canvas"),bA=new class{constructor(A){if(this.container=A,this.renderer=new uA({powerPreference:"high-performance",dpr:window.devicePixelRatio,webgl:1}),this.gl=this.renderer.gl,!this.gl)return void $.dispatch("noWebGL");this.container.appendChild(this.gl.canvas),this.rtParameters={magFilter:this.gl.LINEAR,minFilter:this.gl.LINEAR,generateMipmaps:!1},this.quad=new D(this.gl,{geometry:new rA(this.gl)}),this.sceneRenderTarget=new dA(this.gl,{width:this.renderer.width,height:this.renderer.height,...this.rtParameters}),eA("post.screen",this.sceneRenderTarget.texture),this.pixelSize=new U,eA("screen.pixelSize",this.pixelSize),eA("screen.superSample",1);let t=!0;this.gl.getSupportedExtensions().indexOf("EXT_frag_depth")>=0?this.gl.getExtension("EXT_frag_depth"):t=!1,this.fx=[],t&&this.fx.push(new mA(this.gl,this.renderer,this.rtParameters)),this.fx.push(new EA),this.fx.push(new fA(this.gl,this.fx)),this.gl.clearColor(1,1,1,1),window.addEventListener("resize",this.onResize,!1),this.onResize()}render=({scene:A,camera:t})=>{this.renderer.render({scene:A,camera:t,target:this.sceneRenderTarget}),eA("post.screen",this.sceneRenderTarget.texture),this.fx.forEach((e=>e.render&&e.render({renderer:this.renderer,quad:this.quad,scene:A,camera:t})))};clear=()=>{this.gl.clear(this.gl.COLOR_BUFFER_BIT)};onResize=()=>{this.renderer.setSize(this.container.clientWidth,this.container.clientHeight),this.sceneRenderTarget.setSize(this.renderer.width,this.renderer.height),this.pixelSize.set(1/this.renderer.width,1/this.renderer.height),$.dispatch("resize",this.renderer)}}(SA),UA=bA.gl,LA={x:0,y:0},PA=new class{done=!1;framesSkipped=0;frame=0;startTime=0;onFrame=A=>{if(!this.done)if(this.framesSkipped<5)this.framesSkipped++;else if(0==this.frame&&(this.startTime=A),this.frame++,this.frame>5){this.done=!0;const t=5/(A-this.startTime);$.dispatch("benchmark.done",t)}};reset=()=>{this.done=!1,this.framesSkipped=0,this.frame=0,this.startTime=0}};requestAnimationFrame((()=>bA.clear()));const jA=new class extends x{constructor(A,{near:t=.1,far:e=100,fov:i=45,aspect:r=1,left:n,right:s,bottom:a,top:o,zoom:h=1}={}){super(),Object.assign(this,{near:t,far:e,fov:i,aspect:r,left:n,right:s,bottom:a,top:o,zoom:h}),this.projectionMatrix=new f,this.viewMatrix=new f,this.projectionViewMatrix=new f,this.worldPosition=new l,this.type=n||s?"orthographic":"perspective","orthographic"===this.type?this.orthographic():this.perspective()}perspective({near:A=this.near,far:t=this.far,fov:e=this.fov,aspect:i=this.aspect}={}){return Object.assign(this,{near:A,far:t,fov:e,aspect:i}),this.projectionMatrix.fromPerspective({fov:e*(Math.PI/180),aspect:i,near:A,far:t}),this.type="perspective",this}orthographic({near:A=this.near,far:t=this.far,left:e=this.left,right:i=this.right,bottom:r=this.bottom,top:n=this.top,zoom:s=this.zoom}={}){return Object.assign(this,{near:A,far:t,left:e,right:i,bottom:r,top:n,zoom:s}),e/=s,i/=s,r/=s,n/=s,this.projectionMatrix.fromOrthogonal({left:e,right:i,bottom:r,top:n,near:A,far:t}),this.type="orthographic",this}updateMatrixWorld(){return super.updateMatrixWorld(),this.viewMatrix.inverse(this.worldMatrix),this.worldMatrix.getTranslation(this.worldPosition),this.projectionViewMatrix.multiply(this.projectionMatrix,this.viewMatrix),this}lookAt(A){return super.lookAt(A,!0),this}project(A){return A.applyMatrix4(this.viewMatrix),A.applyMatrix4(this.projectionMatrix),this}unproject(A){return A.applyMatrix4(I.inverse(this.projectionMatrix)),A.applyMatrix4(this.worldMatrix),this}updateFrustum(){this.frustum||(this.frustum=[new l,new l,new l,new l,new l,new l]);const A=this.projectionViewMatrix;this.frustum[0].set(A[3]-A[0],A[7]-A[4],A[11]-A[8]).constant=A[15]-A[12],this.frustum[1].set(A[3]+A[0],A[7]+A[4],A[11]+A[8]).constant=A[15]+A[12],this.frustum[2].set(A[3]+A[1],A[7]+A[5],A[11]+A[9]).constant=A[15]+A[13],this.frustum[3].set(A[3]-A[1],A[7]-A[5],A[11]-A[9]).constant=A[15]-A[13],this.frustum[4].set(A[3]-A[2],A[7]-A[6],A[11]-A[10]).constant=A[15]-A[14],this.frustum[5].set(A[3]+A[2],A[7]+A[6],A[11]+A[10]).constant=A[15]+A[14];for(let A=0;A<6;A++){const t=1/this.frustum[A].distance();this.frustum[A].multiply(t),this.frustum[A].constant*=t}}frustumIntersectsMesh(A){if(!A.geometry.attributes.position)return!0;if(A.geometry.bounds&&A.geometry.bounds.radius!==1/0||A.geometry.computeBoundingSphere(),!A.geometry.bounds)return!0;const t=R;t.copy(A.geometry.bounds.center),t.applyMatrix4(A.worldMatrix);const e=A.geometry.bounds.radius*A.worldMatrix.getMaxScaleOnAxis();return this.frustumIntersectsSphere(t,e)}frustumIntersectsSphere(A,t){const e=v;for(let i=0;i<6;i++){const r=this.frustum[i];if(e.copy(r).dot(A)+r.constant<-t)return!1}return!0}}(UA,{left:-6,right:6,top:6,bottom:-6,near:-18,far:18}),KA=0*Math.PI;jA.position.set(6*Math.cos(KA)*Math.SQRT1_2,6*Math.sin(KA),6*Math.cos(KA)*Math.SQRT1_2);const TA=new function(A,{element:t=document,enabled:e=!0,target:i=new l,ease:r=.25,inertia:n=.85,enableRotate:s=!0,rotateSpeed:a=.1,autoRotate:o=!1,autoRotateSpeed:h=1,enableZoom:c=!0,zoomSpeed:g=1,zoomStyle:u="dolly",enablePan:d=!0,panSpeed:p=.1,minPolarAngle:f=0,maxPolarAngle:m=Math.PI,minAzimuthAngle:E=-1/0,maxAzimuthAngle:x=1/0,minDistance:I=0,maxDistance:R=1/0}={}){this.enabled=e,this.target=i,this.zoomStyle=u,r=r||1,n=n||0,this.minDistance=I,this.maxDistance=R;const v={radius:1,phi:0,theta:0},C={radius:1,phi:0,theta:0},y={radius:1,phi:0,theta:0},B=new l;this.spherical=y,this.sphericalDelta=v,this.autoRotate=o;const F=new l;F.copy(A.position).sub(this.target),y.radius=C.radius=F.distance(),y.theta=C.theta=Math.atan2(F.x,F.z),y.phi=C.phi=Math.acos(Math.min(Math.max(F.y/C.radius,-1),1)),this.offset=F,this.update=()=>{this.autoRotate&&function(){const A=2*Math.PI/60/60*h;v.theta-=A}(),C.radius*=v.radius,C.theta+=v.theta,C.phi+=v.phi,C.theta=Math.max(E,Math.min(x,C.theta)),C.phi=Math.max(f,Math.min(m,C.phi)),C.radius=Math.max(this.minDistance,Math.min(this.maxDistance,C.radius)),y.phi+=(C.phi-y.phi)*r,y.theta+=(C.theta-y.theta)*r,y.radius+=(C.radius-y.radius)*r,this.target.add(B);let t=y.radius*Math.sin(Math.max(1e-6,y.phi));F.x=t,F.y=y.radius*Math.cos(y.phi),F.z=t,A.position.copy(this.target).add(F),A.lookAt(this.target),v.theta*=n,v.phi*=n,B.multiply(n),v.radius=1},this.forcePosition=()=>{F.copy(A.position).sub(this.target),y.radius=C.radius=F.distance(),y.theta=C.theta=Math.atan2(F.x,F.z),y.phi=C.phi=Math.acos(Math.min(Math.max(F.y/C.radius,-1),1)),A.lookAt(this.target)};const M=new U,w=new U,Q=new U;let S=L;function b(){return Math.pow(.95,g)}this.mouseButtons={ORBIT:0,ZOOM:1,PAN:2};const T=(e,i)=>{let r=t===document?document.body:t;P.copy(A.position).sub(this.target);let n=P.distance();var s,a;n*=Math.tan((A.fov||45)/2*Math.PI/180),s=2*e*n/r.clientHeight,a=A.matrix,P.set(a[0],a[1],a[2]),P.multiply(-s),B.add(P),function(A,t){P.set(t[4],t[5],t[6]),P.multiply(A),B.add(P)}(2*i*n/r.clientHeight,A.matrix)},q=t=>{"dolly"===this.zoomStyle?v.radius/=t:(A.fov/=t,"orthographic"===A.type?A.orthographic():A.perspective())};function Y(A,e){j.set(A,e),K.sub(j,M).multiply(a);let i=t===document?document.body:t;v.theta+=2*Math.PI*K.x/i.clientHeight,v.phi-=2*Math.PI*K.y/i.clientHeight,M.copy(j)}function D(A,t){j.set(A,t),K.sub(j,w).multiply(p),T(K.x,K.y),w.copy(j)}const G=A=>{if(this.enabled){switch(A.button){case this.mouseButtons.ORBIT:if(!1===s)return;M.set(A.clientX,A.clientY),S=0;break;case this.mouseButtons.ZOOM:if(!1===c)return;Q.set(A.clientX,A.clientY),S=1;break;case this.mouseButtons.PAN:if(!1===d)return;w.set(A.clientX,A.clientY),S=2}S!==L&&(window.addEventListener("mousemove",V,!1),window.addEventListener("mouseup",X,!1))}},V=A=>{if(this.enabled)switch(S){case 0:if(!1===s)return;Y(A.clientX,A.clientY);break;case 1:if(!1===c)return;!function(A){j.set(A.clientX,A.clientY),K.sub(j,Q),K.y>0?q(b()):K.y<0&&q(1/b()),Q.copy(j)}(A);break;case 2:if(!1===d)return;D(A.clientX,A.clientY)}},X=()=>{window.removeEventListener("mousemove",V,!1),window.removeEventListener("mouseup",X,!1),S=L},z=A=>{this.enabled&&c&&(S===L||0===S)&&(A.stopPropagation(),A.preventDefault(),A.deltaY<0?q(1/b()):A.deltaY>0&&q(b()))},O=A=>{if(this.enabled)switch(A.touches.length){case 1:if(!1===s)return;M.set(A.touches[0].pageX,A.touches[0].pageY),S=0;break;case 2:if(!1===c&&!1===d)return;!function(A){if(c){let t=A.touches[0].pageX-A.touches[1].pageX,e=A.touches[0].pageY-A.touches[1].pageY,i=Math.sqrt(t*t+e*e);Q.set(0,i)}if(d){let t=.5*(A.touches[0].pageX+A.touches[1].pageX),e=.5*(A.touches[0].pageY+A.touches[1].pageY);w.set(t,e)}}(A),S=3;break;default:S=L}},k=A=>{if(this.enabled)switch(A.touches.length){case 1:if(!1===s)return;Y(A.touches[0].pageX,A.touches[0].pageY);break;case 2:if(!1===c&&!1===d)return;!function(A){if(c){let t=A.touches[0].pageX-A.touches[1].pageX,e=A.touches[0].pageY-A.touches[1].pageY,i=Math.sqrt(t*t+e*e);j.set(0,i),K.set(0,Math.pow(j.y/Q.y,g)),q(K.y),Q.copy(j)}d&&D(.5*(A.touches[0].pageX+A.touches[1].pageX),.5*(A.touches[0].pageY+A.touches[1].pageY))}(A);break;default:S=L}},J=()=>{this.enabled&&(S=L)},H=A=>{d&&A.preventDefault()};this.remove=function(){t.removeEventListener("contextmenu",H),t.removeEventListener("mousedown",G),t.removeEventListener("wheel",z),t.removeEventListener("touchstart",O),t.removeEventListener("touchend",J),t.removeEventListener("touchmove",k),window.removeEventListener("mousemove",V),window.removeEventListener("mouseup",X)},t.addEventListener("contextmenu",H,!1),t.addEventListener("mousedown",G,!1),t.addEventListener("wheel",z,{passive:!1}),t.addEventListener("touchstart",O,{passive:!1}),t.addEventListener("touchend",J,!1),t.addEventListener("touchmove",k,{passive:!1})}(jA,{autoRotate:!1,autoRotateSpeed:.5,minPolarAngle:.25*Math.PI,maxPolarAngle:.5*Math.PI,enableZoom:!1,enablePan:!1});eA("camera.worldMatrix",jA.worldMatrix);const qA=new x;function YA(A){return new Promise((t=>{const e=document.createElement("img");e.onload=()=>{t(new F(UA,{image:e}))},e.src=A}))}new class extends D{constructor(A,t,e){super(A,{geometry:new rA(A)});const{shapeScale:i,morphingSpeed:r,rotationSpeed:n,lockFloorRotation:s,color:a=16711808,enableGrid:o}=e,h=new hA(a);this.defines=`\n      #define AA ${window.devicePixelRatio<1.5?2:1}\n      #define scale ${(1/i).toFixed(5)}\n      #define floorShift ${(1.75*i).toFixed(5)}\n      #define morphRate ${r.toFixed(5)}\n      #define rotationSpeed ${n.toFixed(5)}\n      #define lockFloorRotation ${s}\n      #define brandColor vec3(${h.join(", ")})\n    `,o&&(this.defines+="#define enableGrid 1\n"),this.gl=A,this.settings=e,this.camProjMatInv=new f,this.appearable=0,this.morph=0,this.changeQuality(!1),t.addChild(this),$.on("object.appear",(()=>this.appearable=1)),$.on("quality",this.changeQuality),$.on("frame",this.onFrame),$.on("essaa.needsDepth",this.switchDepthWrite)}onFrame=({time:A,dt:t,animationDirection:e,rotation:i,camera:r,controls:n})=>{this.camProjMatInv.copy(r.projectionMatrix).inverse(),this.morph+=t*e*.001,eA("raymarch.seconds",.001*A),eA("raymarch.morph",this.morph),eA("raymarch.appear",this.appearable*(1-5e-4*A)),eA("raymarch.theta",n.spherical.theta+i*this.settings.rotationSpeed*.001)};changeQuality=A=>{const t={seconds:tA("raymarch.seconds"),morph:tA("raymarch.morph"),appear:tA("raymarch.appear"),theta:tA("raymarch.theta"),filmMap:tA("texture.film"),brandMap:tA("texture.brand"),pixelSize:tA("screen.pixelSize"),cameraMatrixWorld:tA("camera.worldMatrix"),projectionMatrixInverse:{value:this.camProjMatInv}},e=A?"precision highp float;\n\ninject_defines\n\nvarying vec2 vUv;\nvarying vec2 vPos;\n\n#define pi 3.141592653589793\n#define maxDist 15.\n#define hitDist .001\n#define minMarchDist .0125\n#define maxMarchSteps 128\n#define saturate(x) clamp(x, 0., 1.)\n\nuniform float appear;\nuniform float seconds;\nuniform float morph;\nuniform float theta;\nuniform vec2 pixelSize;\nuniform mat4 cameraMatrixWorld;\nuniform mat4 projectionMatrixInverse;\nuniform sampler2D filmMap;\nuniform mat4 viewMatrix;\nuniform mat4 projectionMatrix;\n\nfloat sappear;\nmat2 rot45;\n\nfloat handleAnim(float a) {\n  float x = saturate(a);\n  return x * x * x * (x * (x * 6. - 15.) + 10.);\n}\n\nvec4 permute(vec4 x) {\n  return mod(((x * 34.) + 1.) * x, 289.);\n}\nvec4 taylorInvSqrt(vec4 r) {\n  return 1.79284291400159 - 0.85373472095314 * r;\n}\nvec3 fade(vec3 t) {\n  return t * t * t * (t * (t * 6. - 15.) + 10.);\n}\n\nfloat cnoise(vec3 P){\n  vec3 Pi0 = floor(P); // Integer part for indexing\n  vec3 Pi1 = Pi0 + vec3(1.0); // Integer part + 1\n  Pi0 = mod(Pi0, 289.0);\n  Pi1 = mod(Pi1, 289.0);\n  vec3 Pf0 = fract(P); // Fractional part for interpolation\n  vec3 Pf1 = Pf0 - vec3(1.0); // Fractional part - 1.0\n  vec4 ix = vec4(Pi0.x, Pi1.x, Pi0.x, Pi1.x);\n  vec4 iy = vec4(Pi0.yy, Pi1.yy);\n  vec4 iz0 = Pi0.zzzz;\n  vec4 iz1 = Pi1.zzzz;\n\n  vec4 ixy = permute(permute(ix) + iy);\n  vec4 ixy0 = permute(ixy + iz0);\n  vec4 ixy1 = permute(ixy + iz1);\n\n  vec4 gx0 = ixy0 / 7.0;\n  vec4 gy0 = fract(floor(gx0) / 7.0) - 0.5;\n  gx0 = fract(gx0);\n  vec4 gz0 = vec4(0.5) - abs(gx0) - abs(gy0);\n  vec4 sz0 = step(gz0, vec4(0.0));\n  gx0 -= sz0 * (step(0.0, gx0) - 0.5);\n  gy0 -= sz0 * (step(0.0, gy0) - 0.5);\n\n  vec4 gx1 = ixy1 / 7.0;\n  vec4 gy1 = fract(floor(gx1) / 7.0) - 0.5;\n  gx1 = fract(gx1);\n  vec4 gz1 = vec4(0.5) - abs(gx1) - abs(gy1);\n  vec4 sz1 = step(gz1, vec4(0.0));\n  gx1 -= sz1 * (step(0.0, gx1) - 0.5);\n  gy1 -= sz1 * (step(0.0, gy1) - 0.5);\n\n  vec3 g000 = vec3(gx0.x,gy0.x,gz0.x);\n  vec3 g100 = vec3(gx0.y,gy0.y,gz0.y);\n  vec3 g010 = vec3(gx0.z,gy0.z,gz0.z);\n  vec3 g110 = vec3(gx0.w,gy0.w,gz0.w);\n  vec3 g001 = vec3(gx1.x,gy1.x,gz1.x);\n  vec3 g101 = vec3(gx1.y,gy1.y,gz1.y);\n  vec3 g011 = vec3(gx1.z,gy1.z,gz1.z);\n  vec3 g111 = vec3(gx1.w,gy1.w,gz1.w);\n\n  vec4 norm0 = taylorInvSqrt(vec4(dot(g000, g000), dot(g010, g010), dot(g100, g100), dot(g110, g110)));\n  g000 *= norm0.x;\n  g010 *= norm0.y;\n  g100 *= norm0.z;\n  g110 *= norm0.w;\n  vec4 norm1 = taylorInvSqrt(vec4(dot(g001, g001), dot(g011, g011), dot(g101, g101), dot(g111, g111)));\n  g001 *= norm1.x;\n  g011 *= norm1.y;\n  g101 *= norm1.z;\n  g111 *= norm1.w;\n\n  float n000 = dot(g000, Pf0);\n  float n100 = dot(g100, vec3(Pf1.x, Pf0.yz));\n  float n010 = dot(g010, vec3(Pf0.x, Pf1.y, Pf0.z));\n  float n110 = dot(g110, vec3(Pf1.xy, Pf0.z));\n  float n001 = dot(g001, vec3(Pf0.xy, Pf1.z));\n  float n101 = dot(g101, vec3(Pf1.x, Pf0.y, Pf1.z));\n  float n011 = dot(g011, vec3(Pf0.x, Pf1.yz));\n  float n111 = dot(g111, Pf1);\n\n  vec3 fade_xyz = fade(Pf0);\n  vec4 n_z = mix(vec4(n000, n100, n010, n110), vec4(n001, n101, n011, n111), fade_xyz.z);\n  vec2 n_yz = mix(n_z.xy, n_z.zw, fade_xyz.y);\n  float n_xyz = mix(n_yz.x, n_yz.y, fade_xyz.x);\n  return 2.2 * n_xyz;\n}\n\nmat2 rotation2d(float angle) {\n\tfloat s = sin(angle), c = cos(angle);\n\treturn mat2(c, -s, s, c);\n}\n\nfloat opSmoothSubtraction( float d1, float d2, float k ) {\n  float h = clamp(.5 - .5 * (d2 + d1) / k, 0., 1.);\n  return mix(d2, -d1, h) + k * h * (1. - h);\n}\n\nfloat sdBox(vec2 p, vec2 b) {\n  vec2 d = abs(p) - b;\n  return length(max(d, 0.)) + min(max(d.x, d.y), 0.);\n}\n\nfloat sdBox(vec3 p, vec3 b) {\n  vec3 q = abs(p) - b;\n  return length(max(q, 0.)) + min(max(q.x, max(q.y, q.z)),0.);\n}\n\nfloat sdOctahedron(vec3 p, float s) {\n  p = abs(p);\n  float m = p.x + p.y + p.z - s;\n  vec3 q;\n  if (3. * p.x < m) q = p.xyz;\n  else if (3. * p.y < m) q = p.yzx;\n  else if (3. * p.z < m) q = p.zxy;\n  else return m * .57735027;\n\n  float k = clamp(.5 * (q.z - q.y + s), 0., s);\n  return length(vec3(q.x, q.y - s + k, q.z - k));\n}\n\nfloat map(vec3 space) {\n  float anim = mod(morph * morphRate, 4.);\n  mat2 rotAnim = rotation2d(theta);\n\n  vec3 q = space * scale;\n  q.xz *= rotAnim;\n\n  vec3 p = q;\n  p.xy *= rot45;\n\n  q.y *= 0.7;\n  q.xz *= rot45;\n\n  float crystal = sdOctahedron(q, 1.) - .2;\n\n  vec3 tripetSideSize = vec3(1., 1., .05) * smoothstep(.5, 1., anim);\n  float triplet =        sdBox(p                   , vec3(1., 1., .05));\n  triplet = min(triplet, sdBox(p + vec3(0., 0., 1.), tripetSideSize));\n  triplet = min(triplet, sdBox(p - vec3(0., 0., 1.), tripetSideSize));\n  triplet -= .1;\n  float tripletCrystalHole = sdOctahedron(q, .8) - .1;\n  tripletCrystalHole = opSmoothSubtraction(tripletCrystalHole, triplet, .1);\n\n  float cubeWalls = abs(sdBox(p.xy, vec2(.8)) - .2);\n  cubeWalls = length(vec2(cubeWalls, max(abs(p.z) - 1., 0.))) - .1;\n\n  float cube = sdBox(p, vec3(.9));\n  float nathan = max(1.2 - length(p), cube) - .2;\n  float crystalInside = sdOctahedron(q, .7) - .2;\n  cube = max(-crystalInside, cube - .2);\n\n  float d;\n  d = mix(crystal, tripletCrystalHole, handleAnim(anim));\n  d = mix(d, cubeWalls, handleAnim(anim - 1.));\n  d = mix(d, cube, handleAnim(anim * 2. - 4.));\n  d = mix(d, nathan, handleAnim(anim * 2. - 5.));\n  d = mix(d, crystal, handleAnim(anim - 3.));\n\n  float shapeAppear = smoothstep(.5, 0., sappear);\n  float start = length(p) - shapeAppear;\n  d = mix(start, d, shapeAppear);\n\n  return d;\n}\n\nvec3 calcNormal(vec3 pos) {\n  const float h = .01; // replace by an appropriate value\n  const vec2 k = vec2(1., -1.);\n  return normalize(k.xyy * map(pos + k.xyy * h) +\n                   k.yyx * map(pos + k.yyx * h) +\n                   k.yxy * map(pos + k.yxy * h) +\n                   k.xxx * map(pos + k.xxx * h));\n}\n\nvec3 getTint(float d) {\n  return mix(vec3(1.), brandColor, (1. - exp(-.5 * d)));\n}\n\nfloat getFilmThickness(vec3 r, vec3 n, vec3 pos) {\n  return\n    pow(1. - abs(dot(r, n)), 5.) * .75 + .085\n    + max(cnoise(pos + seconds * .4) + pos.y + scale, 0.) * .1\n  ;\n}\n\nvec3 getFilmColor(vec3 rd, vec3 n, vec3 p) {\n  vec3 color = texture2D(filmMap, vec2(getFilmThickness(rd, n, p), .5)).rgb;\n  color = max(color, brandColor) * .3 + .7;\n  return color;\n}\n\nstruct RaymarchResult {\n  float d;\n  float sdf;\n  vec3 pos;\n  vec3 rd;\n};\n\nRaymarchResult march(vec3 ro, vec3 rd) {\n  RaymarchResult r;\n  r.rd = rd;\n  r.d = minMarchDist;\n\n  float maxDistL = -(ro.y + floorShift) / rd.y;\n  maxDistL = maxDistL > 0. ? min(maxDist, maxDistL) : maxDist;\n\n  for (int i = 0; i < maxMarchSteps; i++) {\n    r.pos = ro + rd * r.d;\n    r.sdf = map(r.pos);\n    float asdf = abs(r.sdf);\n    r.d += asdf;\n    if (r.d > maxDistL || asdf < hitDist) {\n      break;\n    }\n  }\n\n  return r;\n}\n\nstruct Hit {\n  vec3 normal;\n  vec3 ro;\n  vec3 rd;\n};\n\nHit processHit(RaymarchResult rr, float shiftSign, float rfrRate) {\n  Hit hit;\n  hit.normal = calcNormal(rr.pos);\n  hit.rd = normalize(refract(rr.rd, -shiftSign * hit.normal, rfrRate));\n  hit.ro = rr.pos + hitDist * (rr.rd + shiftSign * hit.normal);\n  return hit;\n}\n\nstruct Layer {\n  vec3 ro;\n  vec3 rd;\n  vec3 pos;\n  bool firstLayer;\n  vec3 color;\n  bool done;\n};\n\nLayer processLayer(Layer prevLayer, float ior) {\n  Layer res;\n  res.color = vec3(1.);\n  res.firstLayer = false;\n  res.done = true;\n\n  RaymarchResult iter0 = march(prevLayer.ro, prevLayer.rd);\n  if (iter0.sdf < hitDist) {\n    Hit hit0 = processHit(iter0, -1., ior);\n\n    RaymarchResult iter1 = march(hit0.ro, hit0.rd);\n    Hit hit1 = processHit(iter1, 1., ior);\n\n    res.color =\n      getFilmColor(prevLayer.rd, hit0.normal, iter0.pos) *\n      getFilmColor(hit0.rd, hit1.normal, iter1.pos) *\n      getTint(iter1.d)\n    ;\n    res.done = false;\n    res.ro = hit1.ro;\n    res.rd = hit1.rd;\n    res.pos = iter0.pos;\n\n  } else {\n\n    float grid = -(prevLayer.ro.y + floorShift) / prevLayer.rd.y;\n    vec3 pos = prevLayer.ro + prevLayer.rd * grid;\n    #ifdef enableGrid\n    res.color = vec3(min(\n      smoothstep(0., .02, abs(.5 - fract(pos.x))),\n      smoothstep(0., .02, abs(.5 - fract(pos.z)))\n    ) * .04 + .96);\n    #endif\n\n    if (prevLayer.firstLayer) {\n      float shadow = exp(-map(pos)) * .5;\n      res.color *= mix(vec3(1.), brandColor, shadow);\n      res.pos = pos;\n    }\n\n    res.color = mix(res.color, vec3(1.), sappear);\n  }\n\n  return res;\n}\n\nvoid main() {\n\n  rot45 = rotation2d(pi * .25);\n  sappear = saturate(appear);\n\n  vec3 rd = normalize(vec3(0., -.5 * floorShift, 0.) - cameraMatrixWorld[3].xyz);\n  vec2 ndc = vPos;\n  vec4 targetWorld4 = cameraMatrixWorld * projectionMatrixInverse * vec4(ndc, 0., 1.);\n  vec3 ro = targetWorld4.xyz / targetWorld4.w;\n\n  vec3 color = vec3(1.), pos;\n\n  Layer currentLayer;\n  currentLayer.ro = ro;\n  currentLayer.rd = rd;\n  currentLayer.firstLayer = true;\n  for (int i = 0; i < 3; i++) {\n    Layer meh = currentLayer;\n    currentLayer = processLayer(currentLayer, .9);\n    color *= currentLayer.color;\n    if (meh.firstLayer) {\n      pos = currentLayer.pos;\n    }\n    if (currentLayer.done) {\n      break;\n    }\n  }\n\n  color = saturate(color);\n\n  gl_FragColor = vec4(color, 1.);\n\n  inject_depth\n\n}\n":"precision highp float;\n\ninject_defines\n\nvarying vec2 vUv;\nvarying vec2 vPos;\n\n#define pi 3.141592653589793\n#define maxDist 15.\n#define hitDist .001\n#define minMarchDist .0125\n#define maxMarchSteps 128\n#define saturate(x) clamp(x, 0., 1.)\n\nuniform float appear;\nuniform float seconds;\nuniform float morph;\nuniform float theta;\nuniform vec2 pixelSize;\nuniform mat4 cameraMatrixWorld;\nuniform mat4 projectionMatrixInverse;\nuniform sampler2D filmMap;\nuniform sampler2D brandMap;\nuniform mat4 viewMatrix;\nuniform mat4 projectionMatrix;\n\nfloat sappear;\nmat2 rot45;\n\nfloat handleAnim(float a) {\n  float x = saturate(a);\n  return x * x * x * (x * (x * 6. - 15.) + 10.);\n}\n\nvec4 permute(vec4 x) {\n  return mod(((x * 34.) + 1.) * x, 289.);\n}\nvec4 taylorInvSqrt(vec4 r) {\n  return 1.79284291400159 - 0.85373472095314 * r;\n}\nvec3 fade(vec3 t) {\n  return t * t * t * (t * (t * 6. - 15.) + 10.);\n}\n\nfloat cnoise(vec3 P){\n  vec3 Pi0 = floor(P); // Integer part for indexing\n  vec3 Pi1 = Pi0 + vec3(1.0); // Integer part + 1\n  Pi0 = mod(Pi0, 289.0);\n  Pi1 = mod(Pi1, 289.0);\n  vec3 Pf0 = fract(P); // Fractional part for interpolation\n  vec3 Pf1 = Pf0 - vec3(1.0); // Fractional part - 1.0\n  vec4 ix = vec4(Pi0.x, Pi1.x, Pi0.x, Pi1.x);\n  vec4 iy = vec4(Pi0.yy, Pi1.yy);\n  vec4 iz0 = Pi0.zzzz;\n  vec4 iz1 = Pi1.zzzz;\n\n  vec4 ixy = permute(permute(ix) + iy);\n  vec4 ixy0 = permute(ixy + iz0);\n  vec4 ixy1 = permute(ixy + iz1);\n\n  vec4 gx0 = ixy0 / 7.0;\n  vec4 gy0 = fract(floor(gx0) / 7.0) - 0.5;\n  gx0 = fract(gx0);\n  vec4 gz0 = vec4(0.5) - abs(gx0) - abs(gy0);\n  vec4 sz0 = step(gz0, vec4(0.0));\n  gx0 -= sz0 * (step(0.0, gx0) - 0.5);\n  gy0 -= sz0 * (step(0.0, gy0) - 0.5);\n\n  vec4 gx1 = ixy1 / 7.0;\n  vec4 gy1 = fract(floor(gx1) / 7.0) - 0.5;\n  gx1 = fract(gx1);\n  vec4 gz1 = vec4(0.5) - abs(gx1) - abs(gy1);\n  vec4 sz1 = step(gz1, vec4(0.0));\n  gx1 -= sz1 * (step(0.0, gx1) - 0.5);\n  gy1 -= sz1 * (step(0.0, gy1) - 0.5);\n\n  vec3 g000 = vec3(gx0.x,gy0.x,gz0.x);\n  vec3 g100 = vec3(gx0.y,gy0.y,gz0.y);\n  vec3 g010 = vec3(gx0.z,gy0.z,gz0.z);\n  vec3 g110 = vec3(gx0.w,gy0.w,gz0.w);\n  vec3 g001 = vec3(gx1.x,gy1.x,gz1.x);\n  vec3 g101 = vec3(gx1.y,gy1.y,gz1.y);\n  vec3 g011 = vec3(gx1.z,gy1.z,gz1.z);\n  vec3 g111 = vec3(gx1.w,gy1.w,gz1.w);\n\n  vec4 norm0 = taylorInvSqrt(vec4(dot(g000, g000), dot(g010, g010), dot(g100, g100), dot(g110, g110)));\n  g000 *= norm0.x;\n  g010 *= norm0.y;\n  g100 *= norm0.z;\n  g110 *= norm0.w;\n  vec4 norm1 = taylorInvSqrt(vec4(dot(g001, g001), dot(g011, g011), dot(g101, g101), dot(g111, g111)));\n  g001 *= norm1.x;\n  g011 *= norm1.y;\n  g101 *= norm1.z;\n  g111 *= norm1.w;\n\n  float n000 = dot(g000, Pf0);\n  float n100 = dot(g100, vec3(Pf1.x, Pf0.yz));\n  float n010 = dot(g010, vec3(Pf0.x, Pf1.y, Pf0.z));\n  float n110 = dot(g110, vec3(Pf1.xy, Pf0.z));\n  float n001 = dot(g001, vec3(Pf0.xy, Pf1.z));\n  float n101 = dot(g101, vec3(Pf1.x, Pf0.y, Pf1.z));\n  float n011 = dot(g011, vec3(Pf0.x, Pf1.yz));\n  float n111 = dot(g111, Pf1);\n\n  vec3 fade_xyz = fade(Pf0);\n  vec4 n_z = mix(vec4(n000, n100, n010, n110), vec4(n001, n101, n011, n111), fade_xyz.z);\n  vec2 n_yz = mix(n_z.xy, n_z.zw, fade_xyz.y);\n  float n_xyz = mix(n_yz.x, n_yz.y, fade_xyz.x);\n  return 2.2 * n_xyz;\n}\n\nmat2 rotation2d(float angle) {\n\tfloat s = sin(angle), c = cos(angle);\n\treturn mat2(c, -s, s, c);\n}\n\nfloat opSmoothSubtraction( float d1, float d2, float k ) {\n  float h = clamp(.5 - .5 * (d2 + d1) / k, 0., 1.);\n  return mix(d2, -d1, h) + k * h * (1. - h);\n}\n\nfloat sdBox(vec2 p, vec2 b) {\n  vec2 d = abs(p) - b;\n  return length(max(d, 0.)) + min(max(d.x, d.y), 0.);\n}\n\nfloat sdBox(vec3 p, vec3 b) {\n  vec3 q = abs(p) - b;\n  return length(max(q, 0.)) + min(max(q.x, max(q.y, q.z)),0.);\n}\n\nfloat sdOctahedron(vec3 p, float s) {\n  p = abs(p);\n  return (p.x + p.y + p.z - s) * .57735027;\n}\n\nfloat map(vec3 space) {\n  float anim = mod(morph * morphRate, 4.);\n  mat2 rotAnim = rotation2d(theta);\n\n  vec3 q = space * scale;\n  q.xz *= rotAnim;\n\n  vec3 p = q;\n  p.xy *= rot45;\n\n  q.y *= 0.75;\n  q.xz *= rot45;\n\n  float crystal = sdOctahedron(q, 1.) - .2;\n\n  vec3 tripetSideSize = vec3(1., 1., .05) * smoothstep(.5, 1., anim);\n  float triplet =        sdBox(p                   , vec3(1., 1., .05));\n  triplet = min(triplet, sdBox(p + vec3(0., 0., 1.), tripetSideSize));\n  triplet = min(triplet, sdBox(p - vec3(0., 0., 1.), tripetSideSize));\n  triplet -= .1;\n  float tripletCrystalHole = sdOctahedron(q, .8) - .1;\n  tripletCrystalHole = opSmoothSubtraction(tripletCrystalHole, triplet, .1);\n\n  float cubeWalls = abs(sdBox(p.xy, vec2(.8)) - .2);\n  cubeWalls = length(vec2(cubeWalls, max(abs(p.z) - 1., 0.))) - .1;\n\n  float cube = sdBox(p, vec3(.9)) - .2;\n\n  float d = crystal;\n  d = mix(d, tripletCrystalHole, handleAnim(anim));\n  d = mix(d, cubeWalls, handleAnim(anim - 1.));\n  d = mix(d, cube, handleAnim(anim - 2.));\n  d = mix(d, crystal, handleAnim(anim - 3.));\n\n  float shapeAppear = smoothstep(.5, 0., sappear);\n  float start = length(p) - shapeAppear;\n  d = mix(start, d, shapeAppear);\n\n  return d;\n}\n\nvec3 calcNormal(vec3 pos) {\n  const float h = .01; // replace by an appropriate value\n  const vec2 k = vec2(1., -1.);\n  return normalize(k.xyy * map(pos + k.xyy * h) +\n                   k.yyx * map(pos + k.yyx * h) +\n                   k.yxy * map(pos + k.yxy * h) +\n                   k.xxx * map(pos + k.xxx * h));\n}\n\nvoid main() {\n\n  rot45 = rotation2d(pi * .25);\n  sappear = saturate(appear);\n\n  vec3 rd = normalize(vec3(0., -.5 * floorShift, 0.) - cameraMatrixWorld[3].xyz);\n  vec3 aaColor = vec3(0.);\n  vec2 ndc = vPos;\n  vec4 targetWorld4 = cameraMatrixWorld * projectionMatrixInverse * vec4(ndc, 0., 1.);\n  vec3 ro = targetWorld4.xyz / targetWorld4.w;\n\n  vec3 color, pos;\n  float maxDistL = -(ro.y + floorShift) / rd.y;\n  maxDistL = maxDistL > 0. ? min(maxDist, maxDistL) : maxDist;\n\n  float d = minMarchDist, sdf;\n  for (int i = 0; i < maxMarchSteps; i++) {\n    pos = ro + rd * d;\n    sdf = map(pos);\n    d += sdf;\n    if (d > maxDistL || sdf < hitDist) {\n      break;\n    }\n  }\n  if (sdf < hitDist) {\n    vec3 normal = calcNormal(pos);\n\n    float noise = max(cnoise(pos + seconds * .4) + pos.y + scale, 0.) * .1;\n\n    float grad = .8 - .3 * abs(dot(normal, rd)) + noise;\n    color = texture2D(brandMap, vec2(grad, .5)).rgb;\n\n    float fresnel = pow(1. - abs(dot(normal, rd)), 5.);\n    vec3 filmColor = texture2D(filmMap, vec2(fresnel * .75 + .085 + noise, .5)).rgb;\n    color += filmColor * .25 * (fresnel * .5 + .5) + fresnel * .5;\n  } else {\n\n    float grid = -(ro.y + floorShift) / rd.y;\n    pos = ro + rd * grid;\n    #ifdef enableGrid\n    color = vec3(min(\n      smoothstep(0., .02, abs(.5 - fract(pos.x))),\n      smoothstep(0., .02, abs(.5 - fract(pos.z)))\n    ) * .04 + .96);\n    #else\n    color = vec3(1.);\n    #endif\n\n    float shadow = exp(-map(pos)) * .5;\n    color *= mix(vec3(1.), brandColor, shadow);\n\n    color = mix(color, vec3(1.), sappear);\n  }\n\n  gl_FragColor = vec4(saturate(color), 1.);\n\n  inject_depth\n}\n",i=iA.replace("inject_z","0."),r="#extension GL_EXT_frag_depth: enable\n"+e.replace("inject_defines",this.defines).replace("inject_depth","vec4 projected = projectionMatrix * viewMatrix * vec4(pos, 1.);\ngl_FragDepthEXT = saturate(projected.z / projected.w * .5 + .5);\ngl_FragDepthEXT = max(gl_FragDepthEXT, .5);\n"),n=iA.replace("inject_z",.5),s=e.replace("inject_defines",this.defines).replace("inject_depth","");this.programDepth=new H(this.gl,{vertex:i,fragment:r,uniforms:t}),this.programUsual=new H(this.gl,{vertex:n,fragment:s,uniforms:t}),this.program=this.programDepth};switchDepthWrite=A=>{this.program=A?this.programDepth:this.programUsual}}(UA,qA,{lockFloorRotation:!0,rotationSpeed:.2,morphingSpeed:.08,shapeScale:1.25,color:6649052,enableGrid:!1}),xA.visible&&new class extends D{constructor(A,t,e){const{count:i,minDistance:r,maxDistance:n,rotationSpeed:s,modulationRate:a,size:o=250,edgeSharpness:h=.475,yShift:c}=e,g=new Float32Array(3*i),u=new Float32Array(4*i);for(let A=0;A<i;A++)g.set(new l(12*Math.random()-6,.5*Math.random(),12*Math.random()-6).normalize().multiply(Math.random()*(n-r)+r),3*A),u.set([Math.random(),Math.random(),Math.random(),Math.random()],4*A);const d=new O(A,{position:{size:3,data:g},random:{size:4,data:u}}),p=`\n            #define rotationSpeed ${s.toFixed(5)}\n            #define modulationRate ${a.toFixed(5)}\n            #define size ${o.toFixed(5)}\n            #define yShift ${c.toFixed(5)}\n          `,f=`\n            #define edgeSharpness ${h.toFixed(5)}\n          `,m=new H(A,{vertex:"precision highp float;\n\ninject_defines\n\nattribute vec3 position;\nattribute vec4 random;\n\nvarying vec4 vRandom;\n\nuniform mat4 viewMatrix;\nuniform mat4 projectionMatrix;\nuniform float seconds;\nuniform float appear;\nuniform float theta;\nuniform float scale;\n\nmat2 rotation2d(float angle) {\n\tfloat s = sin(angle), c = cos(angle);\n\treturn mat2(c, -s, s, c);\n}\n\nvoid main() {\n  vRandom = random;\n\n  vec3 pos = position;\n  pos.xz = rotation2d(theta) * pos.xz;\n  pos.y += yShift;\n\n  float t = seconds * .6;\n  pos.x += sin(t * random.z + 6.28 * random.w) * random.x;\n  pos.y += sin(t * random.y + 6.28 * random.x) * random.w;\n  pos.z += sin(t * random.w + 6.28 * random.y) * random.z;\n\n  vec4 mvPos = viewMatrix * vec4(pos, 1.);\n  gl_PointSize = scale * appear * size / (length(mvPos.xyz) + 2. + random.y);\n\n  gl_Position = projectionMatrix * mvPos;\n\n  vec2 ndc = gl_Position.xy / gl_Position.w;\n}\n".replace("inject_defines",p),fragment:"precision highp float;\n\ninject_defines\n\nuniform float seconds;\nuniform sampler2D brandMap;\n\nvarying vec4 vRandom;\n\nvoid main() {\n  vec2 uv = gl_PointCoord.xy;\n\n  if (length(uv - .5) > .5) discard;\n\n  gl_FragColor = vec4(\n    texture2D(brandMap, vec2(vRandom.z * .8 + .1 * (1. + uv.y - uv.x), .5)).rgb,\n    1.\n  );\n}\n".replace("inject_defines",f),uniforms:{seconds:{value:0},theta:{value:0},appear:{value:1},scale:tA("screen.superSample"),brandMap:tA("texture.brand")}});super(A,{mode:A.POINTS,geometry:d,program:m}),t.addChild(this),this.settings=e,this.uniforms=this.program.uniforms,$.on("frame",this.onFrame)}onFrame=({time:A,rotation:t,controls:e})=>{this.uniforms.seconds.value=.001*A,this.uniforms.appear.value=Math.min(1,5e-4*A),this.uniforms.theta.value=e.spherical.theta+t*this.settings.rotationSpeed*.001}}(UA,qA,xA);const DA=[YA(""),YA("")];function GA(A){if(yA&&CA){let t=Math.min(1e3/30,A-RA);IA+=t,wA+=MA?0:t,TA.update(),$.dispatch("frame",{time:IA,dt:t,rotation:wA,animationDirection:vA,camera:jA,controls:TA}),bA.render({scene:qA,camera:jA}),PA.done||(PA.onFrame(.001*A),bA.clear())}RA=A,FA&&requestAnimationFrame(GA)}function VA(A){FA=!1,SA.removeChild(UA.canvas);const t=new Image;t.src="",t.style.opacity=0,SA.appendChild(t),requestAnimationFrame((()=>{t.style.opacity=1}))}Promise.all(DA).then((([A,t])=>{eA("texture.film",A),eA("texture.brand",t),RA=performance.now(),requestAnimationFrame(GA)})),UA.canvas.addEventListener("webglcontextlost",VA),$.on("noWebGL",VA),$.on("benchmark.done",(function(A){IA=0,QA?(A<30&&(QA=!1,$.dispatch("quality",QA)),$.dispatch("object.appear")):A<30?VA():A>45?(QA=!0,$.dispatch("quality",QA),PA.reset()):$.dispatch("object.appear")})),window.addEventListener("mousemove",(function(A){const t=A.clientX/window.innerWidth*2-1,e=1-A.clientY/window.innerHeight*2;LA.x=t,LA.y=e,BA=!0})),SA.addEventListener("mousedown",(()=>{BA=!1,MA=!0})),SA.addEventListener("mouseup",(()=>{BA||(vA*=-1),MA=!1})),document.addEventListener("visibilitychange",(()=>{CA="hidden"!==document.visibilityState})),new IntersectionObserver((A=>{const[t]=A;yA=t.isIntersecting})).observe(UA.canvas)})();
//# sourceMappingURL=bundle.js.map