@tresjs/cientos 2.0.0-alpha.3 → 2.0.0-alpha.5

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.
@@ -1,11 +1,11 @@
1
1
  /**
2
2
  * name: @tresjs/cientos
3
- * version: v2.0.0-alpha.2
3
+ * version: v2.0.0-alpha.4
4
4
  * (c) 2023
5
5
  * description: Collection of useful helpers and fully functional, ready-made abstractions for Tres
6
6
  * author: Alvaro Saburido <hola@alvarosaburido.dev> (https://github.com/alvarosabu/)
7
7
  */
8
- (function(ae,L){typeof exports=="object"&&typeof module<"u"?L(exports,require("vue"),require("@tresjs/core"),require("three")):typeof define=="function"&&define.amd?define(["exports","vue","@tresjs/core","three"],L):(ae=typeof globalThis<"u"?globalThis:ae||self,L(ae.trescientos={},ae.Vue,ae.TresjsCore,ae.Three))})(this,function(ae,L,zt,f){"use strict";function Uo(g,i){for(var r=0;r<i.length;r++){const s=i[r];if(typeof s!="string"&&!Array.isArray(s)){for(const a in s)if(a!=="default"&&!(a in g)){const c=Object.getOwnPropertyDescriptor(s,a);c&&Object.defineProperty(g,a,c.get?c:{enumerable:!0,get:()=>s[a]})}}}return Object.freeze(Object.defineProperty(g,Symbol.toStringTag,{value:"Module"}))}function Nn(g){return Nn=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(i){return typeof i}:function(i){return i&&typeof Symbol=="function"&&i.constructor===Symbol&&i!==Symbol.prototype?"symbol":typeof i},Nn(g)}function Ro(g,i){if(Nn(g)!=="object"||g===null)return g;var r=g[Symbol.toPrimitive];if(r!==void 0){var s=r.call(g,i||"default");if(Nn(s)!=="object")return s;throw new TypeError("@@toPrimitive must return a primitive value.")}return(i==="string"?String:Number)(g)}function Go(g){var i=Ro(g,"string");return Nn(i)==="symbol"?i:String(i)}function S(g,i,r){return i=Go(i),i in g?Object.defineProperty(g,i,{value:r,enumerable:!0,configurable:!0,writable:!0}):g[i]=r,g}var Ye=Uint8Array,Pt=Uint16Array,ts=Uint32Array,br=new Ye([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]),gr=new Ye([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]),Ko=new Ye([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),_r=function(g,i){for(var r=new Pt(31),s=0;s<31;++s)r[s]=i+=1<<g[s-1];for(var a=new ts(r[30]),s=1;s<30;++s)for(var c=r[s];c<r[s+1];++c)a[c]=c-r[s]<<5|s;return[r,a]},wr=_r(br,2),yr=wr[0],$o=wr[1];yr[28]=258,$o[258]=28;for(var Xo=_r(gr,0),Yo=Xo[0],ns=new Pt(32768),xe=0;xe<32768;++xe){var Mt=(xe&43690)>>>1|(xe&21845)<<1;Mt=(Mt&52428)>>>2|(Mt&13107)<<2,Mt=(Mt&61680)>>>4|(Mt&3855)<<4,ns[xe]=((Mt&65280)>>>8|(Mt&255)<<8)>>>1}for(var Fn=function(g,i,r){for(var s=g.length,a=0,c=new Pt(i);a<s;++a)++c[g[a]-1];var u=new Pt(i);for(a=0;a<i;++a)u[a]=u[a-1]+c[a-1]<<1;var h;if(r){h=new Pt(1<<i);var d=15-i;for(a=0;a<s;++a)if(g[a])for(var _=a<<4|g[a],y=i-g[a],w=u[g[a]-1]++<<y,x=w|(1<<y)-1;w<=x;++w)h[ns[w]>>>d]=_}else for(h=new Pt(s),a=0;a<s;++a)g[a]&&(h[a]=ns[u[g[a]-1]++]>>>15-g[a]);return h},jn=new Ye(288),xe=0;xe<144;++xe)jn[xe]=8;for(var xe=144;xe<256;++xe)jn[xe]=9;for(var xe=256;xe<280;++xe)jn[xe]=7;for(var xe=280;xe<288;++xe)jn[xe]=8;for(var xr=new Ye(32),xe=0;xe<32;++xe)xr[xe]=5;var qo=Fn(jn,9,1),Qo=Fn(xr,5,1),is=function(g){for(var i=g[0],r=1;r<g.length;++r)g[r]>i&&(i=g[r]);return i},tt=function(g,i,r){var s=i/8|0;return(g[s]|g[s+1]<<8)>>(i&7)&r},ss=function(g,i){var r=i/8|0;return(g[r]|g[r+1]<<8|g[r+2]<<16)>>(i&7)},Zo=function(g){return(g/8|0)+(g&7&&1)},Wo=function(g,i,r){(i==null||i<0)&&(i=0),(r==null||r>g.length)&&(r=g.length);var s=new(g instanceof Pt?Pt:g instanceof ts?ts:Ye)(r-i);return s.set(g.subarray(i,r)),s},Jo=function(g,i,r){var s=g.length;if(!s||r&&!r.l&&s<5)return i||new Ye(0);var a=!i||r,c=!r||r.i;r||(r={}),i||(i=new Ye(s*3));var u=function(Ae){var De=i.length;if(Ae>De){var we=new Ye(Math.max(De*2,Ae));we.set(i),i=we}},h=r.f||0,d=r.p||0,_=r.b||0,y=r.l,w=r.d,x=r.m,M=r.n,O=s*8;do{if(!y){r.f=h=tt(g,d,1);var I=tt(g,d+1,3);if(d+=3,I)if(I==1)y=qo,w=Qo,x=9,M=5;else if(I==2){var B=tt(g,d,31)+257,N=tt(g,d+10,15)+4,Q=B+tt(g,d+5,31)+1;d+=14;for(var $=new Ye(Q),j=new Ye(19),F=0;F<N;++F)j[Ko[F]]=tt(g,d+F*3,7);d+=N*3;for(var X=is(j),Y=(1<<X)-1,Z=Fn(j,X,1),F=0;F<Q;){var ue=Z[tt(g,d,Y)];d+=ue&15;var E=ue>>>4;if(E<16)$[F++]=E;else{var ge=0,pe=0;for(E==16?(pe=3+tt(g,d,3),d+=2,ge=$[F-1]):E==17?(pe=3+tt(g,d,7),d+=3):E==18&&(pe=11+tt(g,d,127),d+=7);pe--;)$[F++]=ge}}var me=$.subarray(0,B),he=$.subarray(B);x=is(me),M=is(he),y=Fn(me,x,1),w=Fn(he,M,1)}else throw"invalid block type";else{var E=Zo(d)+4,R=g[E-4]|g[E-3]<<8,z=E+R;if(z>s){if(c)throw"unexpected EOF";break}a&&u(_+R),i.set(g.subarray(E,z),_),r.b=_+=R,r.p=d=z*8;continue}if(d>O){if(c)throw"unexpected EOF";break}}a&&u(_+131072);for(var ee=(1<<x)-1,q=(1<<M)-1,Ce=d;;Ce=d){var ge=y[ss(g,d)&ee],fe=ge>>>4;if(d+=ge&15,d>O){if(c)throw"unexpected EOF";break}if(!ge)throw"invalid length/literal";if(fe<256)i[_++]=fe;else if(fe==256){Ce=d,y=null;break}else{var le=fe-254;if(fe>264){var F=fe-257,ne=br[F];le=tt(g,d,(1<<ne)-1)+yr[F],d+=ne}var be=w[ss(g,d)&q],V=be>>>4;if(!be)throw"invalid distance";d+=be&15;var he=Yo[V];if(V>3){var ne=gr[V];he+=ss(g,d)&(1<<ne)-1,d+=ne}if(d>O){if(c)throw"unexpected EOF";break}a&&u(_+131072);for(var ce=_+le;_<ce;_+=4)i[_]=i[_-he],i[_+1]=i[_+1-he],i[_+2]=i[_+2-he],i[_+3]=i[_+3-he];_=ce}}r.l=y,r.p=Ce,r.b=_,y&&(h=1,r.m=x,r.d=w,r.n=M)}while(!h);return _==i.length?i:Wo(i,0,_)},Ho=new Ye(0),ea=function(g){if((g[0]&15)!=8||g[0]>>>4>7||(g[0]<<8|g[1])%31)throw"invalid zlib data";if(g[1]&32)throw"invalid zlib data: preset dictionaries not supported"};function ta(g,i){return Jo((ea(g),g.subarray(2,-4)),i)}var na=typeof TextDecoder<"u"&&new TextDecoder,ia=0;try{na.decode(Ho,{stream:!0}),ia=1}catch{}class sa extends f.Object3D{constructor(i,r){super(),S(this,"isTransformControls",!0),S(this,"visible",!1),S(this,"domElement",void 0),S(this,"raycaster",new f.Raycaster),S(this,"gizmo",void 0),S(this,"plane",void 0),S(this,"tempVector",new f.Vector3),S(this,"tempVector2",new f.Vector3),S(this,"tempQuaternion",new f.Quaternion),S(this,"unit",{X:new f.Vector3(1,0,0),Y:new f.Vector3(0,1,0),Z:new f.Vector3(0,0,1)}),S(this,"pointStart",new f.Vector3),S(this,"pointEnd",new f.Vector3),S(this,"offset",new f.Vector3),S(this,"rotationAxis",new f.Vector3),S(this,"startNorm",new f.Vector3),S(this,"endNorm",new f.Vector3),S(this,"rotationAngle",0),S(this,"cameraPosition",new f.Vector3),S(this,"cameraQuaternion",new f.Quaternion),S(this,"cameraScale",new f.Vector3),S(this,"parentPosition",new f.Vector3),S(this,"parentQuaternion",new f.Quaternion),S(this,"parentQuaternionInv",new f.Quaternion),S(this,"parentScale",new f.Vector3),S(this,"worldPositionStart",new f.Vector3),S(this,"worldQuaternionStart",new f.Quaternion),S(this,"worldScaleStart",new f.Vector3),S(this,"worldPosition",new f.Vector3),S(this,"worldQuaternion",new f.Quaternion),S(this,"worldQuaternionInv",new f.Quaternion),S(this,"worldScale",new f.Vector3),S(this,"eye",new f.Vector3),S(this,"positionStart",new f.Vector3),S(this,"quaternionStart",new f.Quaternion),S(this,"scaleStart",new f.Vector3),S(this,"camera",void 0),S(this,"object",void 0),S(this,"enabled",!0),S(this,"axis",null),S(this,"mode","translate"),S(this,"translationSnap",null),S(this,"rotationSnap",null),S(this,"scaleSnap",null),S(this,"space","world"),S(this,"size",1),S(this,"dragging",!1),S(this,"showX",!0),S(this,"showY",!0),S(this,"showZ",!0),S(this,"changeEvent",{type:"change"}),S(this,"mouseDownEvent",{type:"mouseDown",mode:this.mode}),S(this,"mouseUpEvent",{type:"mouseUp",mode:this.mode}),S(this,"objectChangeEvent",{type:"objectChange"}),S(this,"intersectObjectWithRay",(a,c,u)=>{const h=c.intersectObject(a,!0);for(let d=0;d<h.length;d++)if(h[d].object.visible||u)return h[d];return!1}),S(this,"attach",a=>(this.object=a,this.visible=!0,this)),S(this,"detach",()=>(this.object=void 0,this.visible=!1,this.axis=null,this)),S(this,"reset",()=>this.enabled?(this.dragging&&this.object!==void 0&&(this.object.position.copy(this.positionStart),this.object.quaternion.copy(this.quaternionStart),this.object.scale.copy(this.scaleStart),this.dispatchEvent(this.changeEvent),this.dispatchEvent(this.objectChangeEvent),this.pointStart.copy(this.pointEnd)),this):this),S(this,"updateMatrixWorld",()=>{this.object!==void 0&&(this.object.updateMatrixWorld(),this.object.parent===null?console.error("TransformControls: The attached 3D object must be a part of the scene graph."):this.object.parent.matrixWorld.decompose(this.parentPosition,this.parentQuaternion,this.parentScale),this.object.matrixWorld.decompose(this.worldPosition,this.worldQuaternion,this.worldScale),this.parentQuaternionInv.copy(this.parentQuaternion).invert(),this.worldQuaternionInv.copy(this.worldQuaternion).invert()),this.camera.updateMatrixWorld(),this.camera.matrixWorld.decompose(this.cameraPosition,this.cameraQuaternion,this.cameraScale),this.eye.copy(this.cameraPosition).sub(this.worldPosition).normalize(),super.updateMatrixWorld()}),S(this,"pointerHover",a=>{if(this.object===void 0||this.dragging===!0)return;this.raycaster.setFromCamera(a,this.camera);const c=this.intersectObjectWithRay(this.gizmo.picker[this.mode],this.raycaster);c?this.axis=c.object.name:this.axis=null}),S(this,"pointerDown",a=>{if(!(this.object===void 0||this.dragging===!0||a.button!==0)&&this.axis!==null){this.raycaster.setFromCamera(a,this.camera);const c=this.intersectObjectWithRay(this.plane,this.raycaster,!0);if(c){let u=this.space;if(this.mode==="scale"?u="local":(this.axis==="E"||this.axis==="XYZE"||this.axis==="XYZ")&&(u="world"),u==="local"&&this.mode==="rotate"){const h=this.rotationSnap;this.axis==="X"&&h&&(this.object.rotation.x=Math.round(this.object.rotation.x/h)*h),this.axis==="Y"&&h&&(this.object.rotation.y=Math.round(this.object.rotation.y/h)*h),this.axis==="Z"&&h&&(this.object.rotation.z=Math.round(this.object.rotation.z/h)*h)}this.object.updateMatrixWorld(),this.object.parent&&this.object.parent.updateMatrixWorld(),this.positionStart.copy(this.object.position),this.quaternionStart.copy(this.object.quaternion),this.scaleStart.copy(this.object.scale),this.object.matrixWorld.decompose(this.worldPositionStart,this.worldQuaternionStart,this.worldScaleStart),this.pointStart.copy(c.point).sub(this.worldPositionStart)}this.dragging=!0,this.mouseDownEvent.mode=this.mode,this.dispatchEvent(this.mouseDownEvent)}}),S(this,"pointerMove",a=>{const c=this.axis,u=this.mode,h=this.object;let d=this.space;if(u==="scale"?d="local":(c==="E"||c==="XYZE"||c==="XYZ")&&(d="world"),h===void 0||c===null||this.dragging===!1||a.button!==-1)return;this.raycaster.setFromCamera(a,this.camera);const _=this.intersectObjectWithRay(this.plane,this.raycaster,!0);if(_){if(this.pointEnd.copy(_.point).sub(this.worldPositionStart),u==="translate")this.offset.copy(this.pointEnd).sub(this.pointStart),d==="local"&&c!=="XYZ"&&this.offset.applyQuaternion(this.worldQuaternionInv),c.indexOf("X")===-1&&(this.offset.x=0),c.indexOf("Y")===-1&&(this.offset.y=0),c.indexOf("Z")===-1&&(this.offset.z=0),d==="local"&&c!=="XYZ"?this.offset.applyQuaternion(this.quaternionStart).divide(this.parentScale):this.offset.applyQuaternion(this.parentQuaternionInv).divide(this.parentScale),h.position.copy(this.offset).add(this.positionStart),this.translationSnap&&(d==="local"&&(h.position.applyQuaternion(this.tempQuaternion.copy(this.quaternionStart).invert()),c.search("X")!==-1&&(h.position.x=Math.round(h.position.x/this.translationSnap)*this.translationSnap),c.search("Y")!==-1&&(h.position.y=Math.round(h.position.y/this.translationSnap)*this.translationSnap),c.search("Z")!==-1&&(h.position.z=Math.round(h.position.z/this.translationSnap)*this.translationSnap),h.position.applyQuaternion(this.quaternionStart)),d==="world"&&(h.parent&&h.position.add(this.tempVector.setFromMatrixPosition(h.parent.matrixWorld)),c.search("X")!==-1&&(h.position.x=Math.round(h.position.x/this.translationSnap)*this.translationSnap),c.search("Y")!==-1&&(h.position.y=Math.round(h.position.y/this.translationSnap)*this.translationSnap),c.search("Z")!==-1&&(h.position.z=Math.round(h.position.z/this.translationSnap)*this.translationSnap),h.parent&&h.position.sub(this.tempVector.setFromMatrixPosition(h.parent.matrixWorld))));else if(u==="scale"){if(c.search("XYZ")!==-1){let y=this.pointEnd.length()/this.pointStart.length();this.pointEnd.dot(this.pointStart)<0&&(y*=-1),this.tempVector2.set(y,y,y)}else this.tempVector.copy(this.pointStart),this.tempVector2.copy(this.pointEnd),this.tempVector.applyQuaternion(this.worldQuaternionInv),this.tempVector2.applyQuaternion(this.worldQuaternionInv),this.tempVector2.divide(this.tempVector),c.search("X")===-1&&(this.tempVector2.x=1),c.search("Y")===-1&&(this.tempVector2.y=1),c.search("Z")===-1&&(this.tempVector2.z=1);h.scale.copy(this.scaleStart).multiply(this.tempVector2),this.scaleSnap&&this.object&&(c.search("X")!==-1&&(this.object.scale.x=Math.round(h.scale.x/this.scaleSnap)*this.scaleSnap||this.scaleSnap),c.search("Y")!==-1&&(h.scale.y=Math.round(h.scale.y/this.scaleSnap)*this.scaleSnap||this.scaleSnap),c.search("Z")!==-1&&(h.scale.z=Math.round(h.scale.z/this.scaleSnap)*this.scaleSnap||this.scaleSnap))}else if(u==="rotate"){this.offset.copy(this.pointEnd).sub(this.pointStart);const y=20/this.worldPosition.distanceTo(this.tempVector.setFromMatrixPosition(this.camera.matrixWorld));c==="E"?(this.rotationAxis.copy(this.eye),this.rotationAngle=this.pointEnd.angleTo(this.pointStart),this.startNorm.copy(this.pointStart).normalize(),this.endNorm.copy(this.pointEnd).normalize(),this.rotationAngle*=this.endNorm.cross(this.startNorm).dot(this.eye)<0?1:-1):c==="XYZE"?(this.rotationAxis.copy(this.offset).cross(this.eye).normalize(),this.rotationAngle=this.offset.dot(this.tempVector.copy(this.rotationAxis).cross(this.eye))*y):(c==="X"||c==="Y"||c==="Z")&&(this.rotationAxis.copy(this.unit[c]),this.tempVector.copy(this.unit[c]),d==="local"&&this.tempVector.applyQuaternion(this.worldQuaternion),this.rotationAngle=this.offset.dot(this.tempVector.cross(this.eye).normalize())*y),this.rotationSnap&&(this.rotationAngle=Math.round(this.rotationAngle/this.rotationSnap)*this.rotationSnap),d==="local"&&c!=="E"&&c!=="XYZE"?(h.quaternion.copy(this.quaternionStart),h.quaternion.multiply(this.tempQuaternion.setFromAxisAngle(this.rotationAxis,this.rotationAngle)).normalize()):(this.rotationAxis.applyQuaternion(this.parentQuaternionInv),h.quaternion.copy(this.tempQuaternion.setFromAxisAngle(this.rotationAxis,this.rotationAngle)),h.quaternion.multiply(this.quaternionStart).normalize())}this.dispatchEvent(this.changeEvent),this.dispatchEvent(this.objectChangeEvent)}}),S(this,"pointerUp",a=>{a.button===0&&(this.dragging&&this.axis!==null&&(this.mouseUpEvent.mode=this.mode,this.dispatchEvent(this.mouseUpEvent)),this.dragging=!1,this.axis=null)}),S(this,"getPointer",a=>{var c;if(this.domElement&&(c=this.domElement.ownerDocument)!==null&&c!==void 0&&c.pointerLockElement)return{x:0,y:0,button:a.button};{var u;const h=a.changedTouches?a.changedTouches[0]:a,d=(u=this.domElement)===null||u===void 0?void 0:u.getBoundingClientRect();return{x:(h.clientX-d.left)/d.width*2-1,y:-(h.clientY-d.top)/d.height*2+1,button:a.button}}}),S(this,"onPointerHover",a=>{if(this.enabled)switch(a.pointerType){case"mouse":case"pen":this.pointerHover(this.getPointer(a));break}}),S(this,"onPointerDown",a=>{!this.enabled||!this.domElement||(this.domElement.style.touchAction="none",this.domElement.ownerDocument.addEventListener("pointermove",this.onPointerMove),this.pointerHover(this.getPointer(a)),this.pointerDown(this.getPointer(a)))}),S(this,"onPointerMove",a=>{this.enabled&&this.pointerMove(this.getPointer(a))}),S(this,"onPointerUp",a=>{!this.enabled||!this.domElement||(this.domElement.style.touchAction="",this.domElement.ownerDocument.removeEventListener("pointermove",this.onPointerMove),this.pointerUp(this.getPointer(a)))}),S(this,"getMode",()=>this.mode),S(this,"setMode",a=>{this.mode=a}),S(this,"setTranslationSnap",a=>{this.translationSnap=a}),S(this,"setRotationSnap",a=>{this.rotationSnap=a}),S(this,"setScaleSnap",a=>{this.scaleSnap=a}),S(this,"setSize",a=>{this.size=a}),S(this,"setSpace",a=>{this.space=a}),S(this,"update",()=>{console.warn("THREE.TransformControls: update function has no more functionality and therefore has been deprecated.")}),S(this,"connect",a=>{a===document&&console.error('THREE.OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.'),this.domElement=a,this.domElement.addEventListener("pointerdown",this.onPointerDown),this.domElement.addEventListener("pointermove",this.onPointerHover),this.domElement.ownerDocument.addEventListener("pointerup",this.onPointerUp)}),S(this,"dispose",()=>{var a,c,u,h,d,_;(a=this.domElement)===null||a===void 0||a.removeEventListener("pointerdown",this.onPointerDown),(c=this.domElement)===null||c===void 0||c.removeEventListener("pointermove",this.onPointerHover),(u=this.domElement)===null||u===void 0||(h=u.ownerDocument)===null||h===void 0||h.removeEventListener("pointermove",this.onPointerMove),(d=this.domElement)===null||d===void 0||(_=d.ownerDocument)===null||_===void 0||_.removeEventListener("pointerup",this.onPointerUp),this.traverse(y=>{const w=y;w.geometry&&w.geometry.dispose(),w.material&&w.material.dispose()})}),this.domElement=r,this.camera=i,this.gizmo=new ra,this.add(this.gizmo),this.plane=new oa,this.add(this.plane);const s=(a,c)=>{let u=c;Object.defineProperty(this,a,{get:function(){return u!==void 0?u:c},set:function(h){u!==h&&(u=h,this.plane[a]=h,this.gizmo[a]=h,this.dispatchEvent({type:a+"-changed",value:h}),this.dispatchEvent(this.changeEvent))}}),this[a]=c,this.plane[a]=c,this.gizmo[a]=c};s("camera",this.camera),s("object",this.object),s("enabled",this.enabled),s("axis",this.axis),s("mode",this.mode),s("translationSnap",this.translationSnap),s("rotationSnap",this.rotationSnap),s("scaleSnap",this.scaleSnap),s("space",this.space),s("size",this.size),s("dragging",this.dragging),s("showX",this.showX),s("showY",this.showY),s("showZ",this.showZ),s("worldPosition",this.worldPosition),s("worldPositionStart",this.worldPositionStart),s("worldQuaternion",this.worldQuaternion),s("worldQuaternionStart",this.worldQuaternionStart),s("cameraPosition",this.cameraPosition),s("cameraQuaternion",this.cameraQuaternion),s("pointStart",this.pointStart),s("pointEnd",this.pointEnd),s("rotationAxis",this.rotationAxis),s("rotationAngle",this.rotationAngle),s("eye",this.eye),r!==void 0&&this.connect(r)}}class ra extends f.Object3D{constructor(){super(),S(this,"isTransformControlsGizmo",!0),S(this,"type","TransformControlsGizmo"),S(this,"tempVector",new f.Vector3(0,0,0)),S(this,"tempEuler",new f.Euler),S(this,"alignVector",new f.Vector3(0,1,0)),S(this,"zeroVector",new f.Vector3(0,0,0)),S(this,"lookAtMatrix",new f.Matrix4),S(this,"tempQuaternion",new f.Quaternion),S(this,"tempQuaternion2",new f.Quaternion),S(this,"identityQuaternion",new f.Quaternion),S(this,"unitX",new f.Vector3(1,0,0)),S(this,"unitY",new f.Vector3(0,1,0)),S(this,"unitZ",new f.Vector3(0,0,1)),S(this,"gizmo",void 0),S(this,"picker",void 0),S(this,"helper",void 0),S(this,"rotationAxis",new f.Vector3),S(this,"cameraPosition",new f.Vector3),S(this,"worldPositionStart",new f.Vector3),S(this,"worldQuaternionStart",new f.Quaternion),S(this,"worldPosition",new f.Vector3),S(this,"worldQuaternion",new f.Quaternion),S(this,"eye",new f.Vector3),S(this,"camera",null),S(this,"enabled",!0),S(this,"axis",null),S(this,"mode","translate"),S(this,"space","world"),S(this,"size",1),S(this,"dragging",!1),S(this,"showX",!0),S(this,"showY",!0),S(this,"showZ",!0),S(this,"updateMatrixWorld",()=>{let fe=this.space;this.mode==="scale"&&(fe="local");const le=fe==="local"?this.worldQuaternion:this.identityQuaternion;this.gizmo.translate.visible=this.mode==="translate",this.gizmo.rotate.visible=this.mode==="rotate",this.gizmo.scale.visible=this.mode==="scale",this.helper.translate.visible=this.mode==="translate",this.helper.rotate.visible=this.mode==="rotate",this.helper.scale.visible=this.mode==="scale";let ne=[];ne=ne.concat(this.picker[this.mode].children),ne=ne.concat(this.gizmo[this.mode].children),ne=ne.concat(this.helper[this.mode].children);for(let be=0;be<ne.length;be++){const V=ne[be];V.visible=!0,V.rotation.set(0,0,0),V.position.copy(this.worldPosition);let ce;if(this.camera.isOrthographicCamera?ce=(this.camera.top-this.camera.bottom)/this.camera.zoom:ce=this.worldPosition.distanceTo(this.cameraPosition)*Math.min(1.9*Math.tan(Math.PI*this.camera.fov/360)/this.camera.zoom,7),V.scale.set(1,1,1).multiplyScalar(ce*this.size/7),V.tag==="helper"){V.visible=!1,V.name==="AXIS"?(V.position.copy(this.worldPositionStart),V.visible=!!this.axis,this.axis==="X"&&(this.tempQuaternion.setFromEuler(this.tempEuler.set(0,0,0)),V.quaternion.copy(le).multiply(this.tempQuaternion),Math.abs(this.alignVector.copy(this.unitX).applyQuaternion(le).dot(this.eye))>.9&&(V.visible=!1)),this.axis==="Y"&&(this.tempQuaternion.setFromEuler(this.tempEuler.set(0,0,Math.PI/2)),V.quaternion.copy(le).multiply(this.tempQuaternion),Math.abs(this.alignVector.copy(this.unitY).applyQuaternion(le).dot(this.eye))>.9&&(V.visible=!1)),this.axis==="Z"&&(this.tempQuaternion.setFromEuler(this.tempEuler.set(0,Math.PI/2,0)),V.quaternion.copy(le).multiply(this.tempQuaternion),Math.abs(this.alignVector.copy(this.unitZ).applyQuaternion(le).dot(this.eye))>.9&&(V.visible=!1)),this.axis==="XYZE"&&(this.tempQuaternion.setFromEuler(this.tempEuler.set(0,Math.PI/2,0)),this.alignVector.copy(this.rotationAxis),V.quaternion.setFromRotationMatrix(this.lookAtMatrix.lookAt(this.zeroVector,this.alignVector,this.unitY)),V.quaternion.multiply(this.tempQuaternion),V.visible=this.dragging),this.axis==="E"&&(V.visible=!1)):V.name==="START"?(V.position.copy(this.worldPositionStart),V.visible=this.dragging):V.name==="END"?(V.position.copy(this.worldPosition),V.visible=this.dragging):V.name==="DELTA"?(V.position.copy(this.worldPositionStart),V.quaternion.copy(this.worldQuaternionStart),this.tempVector.set(1e-10,1e-10,1e-10).add(this.worldPositionStart).sub(this.worldPosition).multiplyScalar(-1),this.tempVector.applyQuaternion(this.worldQuaternionStart.clone().invert()),V.scale.copy(this.tempVector),V.visible=this.dragging):(V.quaternion.copy(le),this.dragging?V.position.copy(this.worldPositionStart):V.position.copy(this.worldPosition),this.axis&&(V.visible=this.axis.search(V.name)!==-1));continue}V.quaternion.copy(le),this.mode==="translate"||this.mode==="scale"?((V.name==="X"||V.name==="XYZX")&&Math.abs(this.alignVector.copy(this.unitX).applyQuaternion(le).dot(this.eye))>.99&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),(V.name==="Y"||V.name==="XYZY")&&Math.abs(this.alignVector.copy(this.unitY).applyQuaternion(le).dot(this.eye))>.99&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),(V.name==="Z"||V.name==="XYZZ")&&Math.abs(this.alignVector.copy(this.unitZ).applyQuaternion(le).dot(this.eye))>.99&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),V.name==="XY"&&Math.abs(this.alignVector.copy(this.unitZ).applyQuaternion(le).dot(this.eye))<.2&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),V.name==="YZ"&&Math.abs(this.alignVector.copy(this.unitX).applyQuaternion(le).dot(this.eye))<.2&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),V.name==="XZ"&&Math.abs(this.alignVector.copy(this.unitY).applyQuaternion(le).dot(this.eye))<.2&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),V.name.search("X")!==-1&&(this.alignVector.copy(this.unitX).applyQuaternion(le).dot(this.eye)<0?V.tag==="fwd"?V.visible=!1:V.scale.x*=-1:V.tag==="bwd"&&(V.visible=!1)),V.name.search("Y")!==-1&&(this.alignVector.copy(this.unitY).applyQuaternion(le).dot(this.eye)<0?V.tag==="fwd"?V.visible=!1:V.scale.y*=-1:V.tag==="bwd"&&(V.visible=!1)),V.name.search("Z")!==-1&&(this.alignVector.copy(this.unitZ).applyQuaternion(le).dot(this.eye)<0?V.tag==="fwd"?V.visible=!1:V.scale.z*=-1:V.tag==="bwd"&&(V.visible=!1))):this.mode==="rotate"&&(this.tempQuaternion2.copy(le),this.alignVector.copy(this.eye).applyQuaternion(this.tempQuaternion.copy(le).invert()),V.name.search("E")!==-1&&V.quaternion.setFromRotationMatrix(this.lookAtMatrix.lookAt(this.eye,this.zeroVector,this.unitY)),V.name==="X"&&(this.tempQuaternion.setFromAxisAngle(this.unitX,Math.atan2(-this.alignVector.y,this.alignVector.z)),this.tempQuaternion.multiplyQuaternions(this.tempQuaternion2,this.tempQuaternion),V.quaternion.copy(this.tempQuaternion)),V.name==="Y"&&(this.tempQuaternion.setFromAxisAngle(this.unitY,Math.atan2(this.alignVector.x,this.alignVector.z)),this.tempQuaternion.multiplyQuaternions(this.tempQuaternion2,this.tempQuaternion),V.quaternion.copy(this.tempQuaternion)),V.name==="Z"&&(this.tempQuaternion.setFromAxisAngle(this.unitZ,Math.atan2(this.alignVector.y,this.alignVector.x)),this.tempQuaternion.multiplyQuaternions(this.tempQuaternion2,this.tempQuaternion),V.quaternion.copy(this.tempQuaternion))),V.visible=V.visible&&(V.name.indexOf("X")===-1||this.showX),V.visible=V.visible&&(V.name.indexOf("Y")===-1||this.showY),V.visible=V.visible&&(V.name.indexOf("Z")===-1||this.showZ),V.visible=V.visible&&(V.name.indexOf("E")===-1||this.showX&&this.showY&&this.showZ),V.material.tempOpacity=V.material.tempOpacity||V.material.opacity,V.material.tempColor=V.material.tempColor||V.material.color.clone(),V.material.color.copy(V.material.tempColor),V.material.opacity=V.material.tempOpacity,this.enabled?this.axis&&(V.name===this.axis?(V.material.opacity=1,V.material.color.lerp(new f.Color(1,1,1),.5)):this.axis.split("").some(function(Ae){return V.name===Ae})?(V.material.opacity=1,V.material.color.lerp(new f.Color(1,1,1),.5)):(V.material.opacity*=.25,V.material.color.lerp(new f.Color(1,1,1),.5))):(V.material.opacity*=.5,V.material.color.lerp(new f.Color(1,1,1),.5))}super.updateMatrixWorld()});const i=new f.MeshBasicMaterial({depthTest:!1,depthWrite:!1,transparent:!0,side:f.DoubleSide,fog:!1,toneMapped:!1}),r=new f.LineBasicMaterial({depthTest:!1,depthWrite:!1,transparent:!0,linewidth:1,fog:!1,toneMapped:!1}),s=i.clone();s.opacity=.15;const a=i.clone();a.opacity=.33;const c=i.clone();c.color.set(16711680);const u=i.clone();u.color.set(65280);const h=i.clone();h.color.set(255);const d=i.clone();d.opacity=.25;const _=d.clone();_.color.set(16776960);const y=d.clone();y.color.set(65535);const w=d.clone();w.color.set(16711935),i.clone().color.set(16776960);const M=r.clone();M.color.set(16711680);const O=r.clone();O.color.set(65280);const I=r.clone();I.color.set(255);const E=r.clone();E.color.set(65535);const R=r.clone();R.color.set(16711935);const z=r.clone();z.color.set(16776960);const B=r.clone();B.color.set(7895160);const N=z.clone();N.opacity=.25;const Q=new f.CylinderGeometry(0,.05,.2,12,1,!1),$=new f.BoxGeometry(.125,.125,.125),j=new f.BufferGeometry;j.setAttribute("position",new f.Float32BufferAttribute([0,0,0,1,0,0],3));const F=(fe,le)=>{const ne=new f.BufferGeometry,be=[];for(let V=0;V<=64*le;++V)be.push(0,Math.cos(V/32*Math.PI)*fe,Math.sin(V/32*Math.PI)*fe);return ne.setAttribute("position",new f.Float32BufferAttribute(be,3)),ne},X=()=>{const fe=new f.BufferGeometry;return fe.setAttribute("position",new f.Float32BufferAttribute([0,0,0,1,1,1],3)),fe},Y={X:[[new f.Mesh(Q,c),[1,0,0],[0,0,-Math.PI/2],null,"fwd"],[new f.Mesh(Q,c),[1,0,0],[0,0,Math.PI/2],null,"bwd"],[new f.Line(j,M)]],Y:[[new f.Mesh(Q,u),[0,1,0],null,null,"fwd"],[new f.Mesh(Q,u),[0,1,0],[Math.PI,0,0],null,"bwd"],[new f.Line(j,O),null,[0,0,Math.PI/2]]],Z:[[new f.Mesh(Q,h),[0,0,1],[Math.PI/2,0,0],null,"fwd"],[new f.Mesh(Q,h),[0,0,1],[-Math.PI/2,0,0],null,"bwd"],[new f.Line(j,I),null,[0,-Math.PI/2,0]]],XYZ:[[new f.Mesh(new f.OctahedronGeometry(.1,0),d.clone()),[0,0,0],[0,0,0]]],XY:[[new f.Mesh(new f.PlaneGeometry(.295,.295),_.clone()),[.15,.15,0]],[new f.Line(j,z),[.18,.3,0],null,[.125,1,1]],[new f.Line(j,z),[.3,.18,0],[0,0,Math.PI/2],[.125,1,1]]],YZ:[[new f.Mesh(new f.PlaneGeometry(.295,.295),y.clone()),[0,.15,.15],[0,Math.PI/2,0]],[new f.Line(j,E),[0,.18,.3],[0,0,Math.PI/2],[.125,1,1]],[new f.Line(j,E),[0,.3,.18],[0,-Math.PI/2,0],[.125,1,1]]],XZ:[[new f.Mesh(new f.PlaneGeometry(.295,.295),w.clone()),[.15,0,.15],[-Math.PI/2,0,0]],[new f.Line(j,R),[.18,0,.3],null,[.125,1,1]],[new f.Line(j,R),[.3,0,.18],[0,-Math.PI/2,0],[.125,1,1]]]},Z={X:[[new f.Mesh(new f.CylinderGeometry(.2,0,1,4,1,!1),s),[.6,0,0],[0,0,-Math.PI/2]]],Y:[[new f.Mesh(new f.CylinderGeometry(.2,0,1,4,1,!1),s),[0,.6,0]]],Z:[[new f.Mesh(new f.CylinderGeometry(.2,0,1,4,1,!1),s),[0,0,.6],[Math.PI/2,0,0]]],XYZ:[[new f.Mesh(new f.OctahedronGeometry(.2,0),s)]],XY:[[new f.Mesh(new f.PlaneGeometry(.4,.4),s),[.2,.2,0]]],YZ:[[new f.Mesh(new f.PlaneGeometry(.4,.4),s),[0,.2,.2],[0,Math.PI/2,0]]],XZ:[[new f.Mesh(new f.PlaneGeometry(.4,.4),s),[.2,0,.2],[-Math.PI/2,0,0]]]},ue={START:[[new f.Mesh(new f.OctahedronGeometry(.01,2),a),null,null,null,"helper"]],END:[[new f.Mesh(new f.OctahedronGeometry(.01,2),a),null,null,null,"helper"]],DELTA:[[new f.Line(X(),a),null,null,null,"helper"]],X:[[new f.Line(j,a.clone()),[-1e3,0,0],null,[1e6,1,1],"helper"]],Y:[[new f.Line(j,a.clone()),[0,-1e3,0],[0,0,Math.PI/2],[1e6,1,1],"helper"]],Z:[[new f.Line(j,a.clone()),[0,0,-1e3],[0,-Math.PI/2,0],[1e6,1,1],"helper"]]},ge={X:[[new f.Line(F(1,.5),M)],[new f.Mesh(new f.OctahedronGeometry(.04,0),c),[0,0,.99],null,[1,3,1]]],Y:[[new f.Line(F(1,.5),O),null,[0,0,-Math.PI/2]],[new f.Mesh(new f.OctahedronGeometry(.04,0),u),[0,0,.99],null,[3,1,1]]],Z:[[new f.Line(F(1,.5),I),null,[0,Math.PI/2,0]],[new f.Mesh(new f.OctahedronGeometry(.04,0),h),[.99,0,0],null,[1,3,1]]],E:[[new f.Line(F(1.25,1),N),null,[0,Math.PI/2,0]],[new f.Mesh(new f.CylinderGeometry(.03,0,.15,4,1,!1),N),[1.17,0,0],[0,0,-Math.PI/2],[1,1,.001]],[new f.Mesh(new f.CylinderGeometry(.03,0,.15,4,1,!1),N),[-1.17,0,0],[0,0,Math.PI/2],[1,1,.001]],[new f.Mesh(new f.CylinderGeometry(.03,0,.15,4,1,!1),N),[0,-1.17,0],[Math.PI,0,0],[1,1,.001]],[new f.Mesh(new f.CylinderGeometry(.03,0,.15,4,1,!1),N),[0,1.17,0],[0,0,0],[1,1,.001]]],XYZE:[[new f.Line(F(1,1),B),null,[0,Math.PI/2,0]]]},pe={AXIS:[[new f.Line(j,a.clone()),[-1e3,0,0],null,[1e6,1,1],"helper"]]},me={X:[[new f.Mesh(new f.TorusGeometry(1,.1,4,24),s),[0,0,0],[0,-Math.PI/2,-Math.PI/2]]],Y:[[new f.Mesh(new f.TorusGeometry(1,.1,4,24),s),[0,0,0],[Math.PI/2,0,0]]],Z:[[new f.Mesh(new f.TorusGeometry(1,.1,4,24),s),[0,0,0],[0,0,-Math.PI/2]]],E:[[new f.Mesh(new f.TorusGeometry(1.25,.1,2,24),s)]],XYZE:[[new f.Mesh(new f.SphereGeometry(.7,10,8),s)]]},he={X:[[new f.Mesh($,c),[.8,0,0],[0,0,-Math.PI/2]],[new f.Line(j,M),null,null,[.8,1,1]]],Y:[[new f.Mesh($,u),[0,.8,0]],[new f.Line(j,O),null,[0,0,Math.PI/2],[.8,1,1]]],Z:[[new f.Mesh($,h),[0,0,.8],[Math.PI/2,0,0]],[new f.Line(j,I),null,[0,-Math.PI/2,0],[.8,1,1]]],XY:[[new f.Mesh($,_),[.85,.85,0],null,[2,2,.2]],[new f.Line(j,z),[.855,.98,0],null,[.125,1,1]],[new f.Line(j,z),[.98,.855,0],[0,0,Math.PI/2],[.125,1,1]]],YZ:[[new f.Mesh($,y),[0,.85,.85],null,[.2,2,2]],[new f.Line(j,E),[0,.855,.98],[0,0,Math.PI/2],[.125,1,1]],[new f.Line(j,E),[0,.98,.855],[0,-Math.PI/2,0],[.125,1,1]]],XZ:[[new f.Mesh($,w),[.85,0,.85],null,[2,.2,2]],[new f.Line(j,R),[.855,0,.98],null,[.125,1,1]],[new f.Line(j,R),[.98,0,.855],[0,-Math.PI/2,0],[.125,1,1]]],XYZX:[[new f.Mesh(new f.BoxGeometry(.125,.125,.125),d.clone()),[1.1,0,0]]],XYZY:[[new f.Mesh(new f.BoxGeometry(.125,.125,.125),d.clone()),[0,1.1,0]]],XYZZ:[[new f.Mesh(new f.BoxGeometry(.125,.125,.125),d.clone()),[0,0,1.1]]]},ee={X:[[new f.Mesh(new f.CylinderGeometry(.2,0,.8,4,1,!1),s),[.5,0,0],[0,0,-Math.PI/2]]],Y:[[new f.Mesh(new f.CylinderGeometry(.2,0,.8,4,1,!1),s),[0,.5,0]]],Z:[[new f.Mesh(new f.CylinderGeometry(.2,0,.8,4,1,!1),s),[0,0,.5],[Math.PI/2,0,0]]],XY:[[new f.Mesh($,s),[.85,.85,0],null,[3,3,.2]]],YZ:[[new f.Mesh($,s),[0,.85,.85],null,[.2,3,3]]],XZ:[[new f.Mesh($,s),[.85,0,.85],null,[3,.2,3]]],XYZX:[[new f.Mesh(new f.BoxGeometry(.2,.2,.2),s),[1.1,0,0]]],XYZY:[[new f.Mesh(new f.BoxGeometry(.2,.2,.2),s),[0,1.1,0]]],XYZZ:[[new f.Mesh(new f.BoxGeometry(.2,.2,.2),s),[0,0,1.1]]]},q={X:[[new f.Line(j,a.clone()),[-1e3,0,0],null,[1e6,1,1],"helper"]],Y:[[new f.Line(j,a.clone()),[0,-1e3,0],[0,0,Math.PI/2],[1e6,1,1],"helper"]],Z:[[new f.Line(j,a.clone()),[0,0,-1e3],[0,-Math.PI/2,0],[1e6,1,1],"helper"]]},Ce=fe=>{const le=new f.Object3D;for(let ne in fe)for(let be=fe[ne].length;be--;){const V=fe[ne][be][0].clone(),ce=fe[ne][be][1],Ae=fe[ne][be][2],De=fe[ne][be][3],we=fe[ne][be][4];V.name=ne,V.tag=we,ce&&V.position.set(ce[0],ce[1],ce[2]),Ae&&V.rotation.set(Ae[0],Ae[1],Ae[2]),De&&V.scale.set(De[0],De[1],De[2]),V.updateMatrix();const qe=V.geometry.clone();qe.applyMatrix4(V.matrix),V.geometry=qe,V.renderOrder=1/0,V.position.set(0,0,0),V.rotation.set(0,0,0),V.scale.set(1,1,1),le.add(V)}return le};this.gizmo={},this.picker={},this.helper={},this.add(this.gizmo.translate=Ce(Y)),this.add(this.gizmo.rotate=Ce(ge)),this.add(this.gizmo.scale=Ce(he)),this.add(this.picker.translate=Ce(Z)),this.add(this.picker.rotate=Ce(me)),this.add(this.picker.scale=Ce(ee)),this.add(this.helper.translate=Ce(ue)),this.add(this.helper.rotate=Ce(pe)),this.add(this.helper.scale=Ce(q)),this.picker.translate.visible=!1,this.picker.rotate.visible=!1,this.picker.scale.visible=!1}}class oa extends f.Mesh{constructor(){super(new f.PlaneGeometry(1e5,1e5,2,2),new f.MeshBasicMaterial({visible:!1,wireframe:!0,side:f.DoubleSide,transparent:!0,opacity:.1,toneMapped:!1})),S(this,"isTransformControlsPlane",!0),S(this,"type","TransformControlsPlane"),S(this,"unitX",new f.Vector3(1,0,0)),S(this,"unitY",new f.Vector3(0,1,0)),S(this,"unitZ",new f.Vector3(0,0,1)),S(this,"tempVector",new f.Vector3),S(this,"dirVector",new f.Vector3),S(this,"alignVector",new f.Vector3),S(this,"tempMatrix",new f.Matrix4),S(this,"identityQuaternion",new f.Quaternion),S(this,"cameraQuaternion",new f.Quaternion),S(this,"worldPosition",new f.Vector3),S(this,"worldQuaternion",new f.Quaternion),S(this,"eye",new f.Vector3),S(this,"axis",null),S(this,"mode","translate"),S(this,"space","world"),S(this,"updateMatrixWorld",()=>{let i=this.space;switch(this.position.copy(this.worldPosition),this.mode==="scale"&&(i="local"),this.unitX.set(1,0,0).applyQuaternion(i==="local"?this.worldQuaternion:this.identityQuaternion),this.unitY.set(0,1,0).applyQuaternion(i==="local"?this.worldQuaternion:this.identityQuaternion),this.unitZ.set(0,0,1).applyQuaternion(i==="local"?this.worldQuaternion:this.identityQuaternion),this.alignVector.copy(this.unitY),this.mode){case"translate":case"scale":switch(this.axis){case"X":this.alignVector.copy(this.eye).cross(this.unitX),this.dirVector.copy(this.unitX).cross(this.alignVector);break;case"Y":this.alignVector.copy(this.eye).cross(this.unitY),this.dirVector.copy(this.unitY).cross(this.alignVector);break;case"Z":this.alignVector.copy(this.eye).cross(this.unitZ),this.dirVector.copy(this.unitZ).cross(this.alignVector);break;case"XY":this.dirVector.copy(this.unitZ);break;case"YZ":this.dirVector.copy(this.unitX);break;case"XZ":this.alignVector.copy(this.unitZ),this.dirVector.copy(this.unitY);break;case"XYZ":case"E":this.dirVector.set(0,0,0);break}break;case"rotate":default:this.dirVector.set(0,0,0)}this.dirVector.length()===0?this.quaternion.copy(this.cameraQuaternion):(this.tempMatrix.lookAt(this.tempVector.set(0,0,0),this.dirVector,this.alignVector),this.quaternion.setFromRotationMatrix(this.tempMatrix)),super.updateMatrixWorld()})}}const Cr=(g,i)=>(g%i+i)%i;class aa extends f.EventDispatcher{constructor(i,r){super(),S(this,"object",void 0),S(this,"domElement",void 0),S(this,"enabled",!0),S(this,"target",new f.Vector3),S(this,"minDistance",0),S(this,"maxDistance",1/0),S(this,"minZoom",0),S(this,"maxZoom",1/0),S(this,"minPolarAngle",0),S(this,"maxPolarAngle",Math.PI),S(this,"minAzimuthAngle",-1/0),S(this,"maxAzimuthAngle",1/0),S(this,"enableDamping",!1),S(this,"dampingFactor",.05),S(this,"enableZoom",!0),S(this,"zoomSpeed",1),S(this,"enableRotate",!0),S(this,"rotateSpeed",1),S(this,"enablePan",!0),S(this,"panSpeed",1),S(this,"screenSpacePanning",!0),S(this,"keyPanSpeed",7),S(this,"autoRotate",!1),S(this,"autoRotateSpeed",2),S(this,"reverseOrbit",!1),S(this,"keys",{LEFT:"ArrowLeft",UP:"ArrowUp",RIGHT:"ArrowRight",BOTTOM:"ArrowDown"}),S(this,"mouseButtons",{LEFT:f.MOUSE.ROTATE,MIDDLE:f.MOUSE.DOLLY,RIGHT:f.MOUSE.PAN}),S(this,"touches",{ONE:f.TOUCH.ROTATE,TWO:f.TOUCH.DOLLY_PAN}),S(this,"target0",void 0),S(this,"position0",void 0),S(this,"zoom0",void 0),S(this,"_domElementKeyEvents",null),S(this,"getPolarAngle",void 0),S(this,"getAzimuthalAngle",void 0),S(this,"setPolarAngle",void 0),S(this,"setAzimuthalAngle",void 0),S(this,"getDistance",void 0),S(this,"listenToKeyEvents",void 0),S(this,"saveState",void 0),S(this,"reset",void 0),S(this,"update",void 0),S(this,"connect",void 0),S(this,"dispose",void 0),this.object=i,this.domElement=r,this.target0=this.target.clone(),this.position0=this.object.position.clone(),this.zoom0=this.object instanceof f.PerspectiveCamera?this.object.zoom:1,this.getPolarAngle=()=>y.phi,this.getAzimuthalAngle=()=>y.theta,this.setPolarAngle=D=>{let K=Cr(D,2*Math.PI),J=y.phi;J<0&&(J+=2*Math.PI),K<0&&(K+=2*Math.PI);let ie=Math.abs(K-J);2*Math.PI-ie<ie&&(K<J?K+=2*Math.PI:J+=2*Math.PI),w.phi=K-J,s.update()},this.setAzimuthalAngle=D=>{let K=Cr(D,2*Math.PI),J=y.theta;J<0&&(J+=2*Math.PI),K<0&&(K+=2*Math.PI);let ie=Math.abs(K-J);2*Math.PI-ie<ie&&(K<J?K+=2*Math.PI:J+=2*Math.PI),w.theta=K-J,s.update()},this.getDistance=()=>s.object.position.distanceTo(s.target),this.listenToKeyEvents=D=>{D.addEventListener("keydown",at),this._domElementKeyEvents=D},this.saveState=()=>{s.target0.copy(s.target),s.position0.copy(s.object.position),s.zoom0=s.object instanceof f.PerspectiveCamera?s.object.zoom:1},this.reset=()=>{s.target.copy(s.target0),s.object.position.copy(s.position0),s.object instanceof f.PerspectiveCamera&&(s.object.zoom=s.zoom0,s.object.updateProjectionMatrix()),s.dispatchEvent(a),s.update(),d=h.NONE},this.update=(()=>{const D=new f.Vector3,K=new f.Quaternion().setFromUnitVectors(i.up,new f.Vector3(0,1,0)),J=K.clone().invert(),ie=new f.Vector3,ye=new f.Quaternion,Ve=2*Math.PI;return function(){const qt=s.object.position;D.copy(qt).sub(s.target),D.applyQuaternion(K),y.setFromVector3(D),s.autoRotate&&d===h.NONE&&ue(Y()),s.enableDamping?(y.theta+=w.theta*s.dampingFactor,y.phi+=w.phi*s.dampingFactor):(y.theta+=w.theta,y.phi+=w.phi);let Oe=s.minAzimuthAngle,Be=s.maxAzimuthAngle;return isFinite(Oe)&&isFinite(Be)&&(Oe<-Math.PI?Oe+=Ve:Oe>Math.PI&&(Oe-=Ve),Be<-Math.PI?Be+=Ve:Be>Math.PI&&(Be-=Ve),Oe<=Be?y.theta=Math.max(Oe,Math.min(Be,y.theta)):y.theta=y.theta>(Oe+Be)/2?Math.max(Oe,y.theta):Math.min(Be,y.theta)),y.phi=Math.max(s.minPolarAngle,Math.min(s.maxPolarAngle,y.phi)),y.makeSafe(),y.radius*=x,y.radius=Math.max(s.minDistance,Math.min(s.maxDistance,y.radius)),s.enableDamping===!0?s.target.addScaledVector(M,s.dampingFactor):s.target.add(M),D.setFromSpherical(y),D.applyQuaternion(J),qt.copy(s.target).add(D),s.object.lookAt(s.target),s.enableDamping===!0?(w.theta*=1-s.dampingFactor,w.phi*=1-s.dampingFactor,M.multiplyScalar(1-s.dampingFactor)):(w.set(0,0,0),M.set(0,0,0)),x=1,O||ie.distanceToSquared(s.object.position)>_||8*(1-ye.dot(s.object.quaternion))>_?(s.dispatchEvent(a),ie.copy(s.object.position),ye.copy(s.object.quaternion),O=!1,!0):!1}})(),this.connect=D=>{D===document&&console.error('THREE.OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.'),s.domElement=D,s.domElement.style.touchAction="none",s.domElement.addEventListener("contextmenu",Yt),s.domElement.addEventListener("pointerdown",Qe),s.domElement.addEventListener("pointercancel",bn),s.domElement.addEventListener("wheel",_n)},this.dispose=()=>{var D,K,J,ie,ye,Ve;(D=s.domElement)===null||D===void 0||D.removeEventListener("contextmenu",Yt),(K=s.domElement)===null||K===void 0||K.removeEventListener("pointerdown",Qe),(J=s.domElement)===null||J===void 0||J.removeEventListener("pointercancel",bn),(ie=s.domElement)===null||ie===void 0||ie.removeEventListener("wheel",_n),(ye=s.domElement)===null||ye===void 0||ye.ownerDocument.removeEventListener("pointermove",Xt),(Ve=s.domElement)===null||Ve===void 0||Ve.ownerDocument.removeEventListener("pointerup",it),s._domElementKeyEvents!==null&&s._domElementKeyEvents.removeEventListener("keydown",at)};const s=this,a={type:"change"},c={type:"start"},u={type:"end"},h={NONE:-1,ROTATE:0,DOLLY:1,PAN:2,TOUCH_ROTATE:3,TOUCH_PAN:4,TOUCH_DOLLY_PAN:5,TOUCH_DOLLY_ROTATE:6};let d=h.NONE;const _=1e-6,y=new f.Spherical,w=new f.Spherical;let x=1;const M=new f.Vector3;let O=!1;const I=new f.Vector2,E=new f.Vector2,R=new f.Vector2,z=new f.Vector2,B=new f.Vector2,N=new f.Vector2,Q=new f.Vector2,$=new f.Vector2,j=new f.Vector2,F=[],X={};function Y(){return 2*Math.PI/60/60*s.autoRotateSpeed}function Z(){return Math.pow(.95,s.zoomSpeed)}function ue(D){s.reverseOrbit?w.theta+=D:w.theta-=D}function ge(D){s.reverseOrbit?w.phi+=D:w.phi-=D}const pe=(()=>{const D=new f.Vector3;return function(J,ie){D.setFromMatrixColumn(ie,0),D.multiplyScalar(-J),M.add(D)}})(),me=(()=>{const D=new f.Vector3;return function(J,ie){s.screenSpacePanning===!0?D.setFromMatrixColumn(ie,1):(D.setFromMatrixColumn(ie,0),D.crossVectors(s.object.up,D)),D.multiplyScalar(J),M.add(D)}})(),he=(()=>{const D=new f.Vector3;return function(J,ie){const ye=s.domElement;if(ye&&s.object instanceof f.PerspectiveCamera&&s.object.isPerspectiveCamera){const Ve=s.object.position;D.copy(Ve).sub(s.target);let St=D.length();St*=Math.tan(s.object.fov/2*Math.PI/180),pe(2*J*St/ye.clientHeight,s.object.matrix),me(2*ie*St/ye.clientHeight,s.object.matrix)}else ye&&s.object instanceof f.OrthographicCamera&&s.object.isOrthographicCamera?(pe(J*(s.object.right-s.object.left)/s.object.zoom/ye.clientWidth,s.object.matrix),me(ie*(s.object.top-s.object.bottom)/s.object.zoom/ye.clientHeight,s.object.matrix)):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."),s.enablePan=!1)}})();function ee(D){s.object instanceof f.PerspectiveCamera&&s.object.isPerspectiveCamera?x/=D:s.object instanceof f.OrthographicCamera&&s.object.isOrthographicCamera?(s.object.zoom=Math.max(s.minZoom,Math.min(s.maxZoom,s.object.zoom*D)),s.object.updateProjectionMatrix(),O=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),s.enableZoom=!1)}function q(D){s.object instanceof f.PerspectiveCamera&&s.object.isPerspectiveCamera?x*=D:s.object instanceof f.OrthographicCamera&&s.object.isOrthographicCamera?(s.object.zoom=Math.max(s.minZoom,Math.min(s.maxZoom,s.object.zoom/D)),s.object.updateProjectionMatrix(),O=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),s.enableZoom=!1)}function Ce(D){I.set(D.clientX,D.clientY)}function fe(D){Q.set(D.clientX,D.clientY)}function le(D){z.set(D.clientX,D.clientY)}function ne(D){E.set(D.clientX,D.clientY),R.subVectors(E,I).multiplyScalar(s.rotateSpeed);const K=s.domElement;K&&(ue(2*Math.PI*R.x/K.clientHeight),ge(2*Math.PI*R.y/K.clientHeight)),I.copy(E),s.update()}function be(D){$.set(D.clientX,D.clientY),j.subVectors($,Q),j.y>0?ee(Z()):j.y<0&&q(Z()),Q.copy($),s.update()}function V(D){B.set(D.clientX,D.clientY),N.subVectors(B,z).multiplyScalar(s.panSpeed),he(N.x,N.y),z.copy(B),s.update()}function ce(D){D.deltaY<0?q(Z()):D.deltaY>0&&ee(Z()),s.update()}function Ae(D){let K=!1;switch(D.code){case s.keys.UP:he(0,s.keyPanSpeed),K=!0;break;case s.keys.BOTTOM:he(0,-s.keyPanSpeed),K=!0;break;case s.keys.LEFT:he(s.keyPanSpeed,0),K=!0;break;case s.keys.RIGHT:he(-s.keyPanSpeed,0),K=!0;break}K&&(D.preventDefault(),s.update())}function De(){if(F.length==1)I.set(F[0].pageX,F[0].pageY);else{const D=.5*(F[0].pageX+F[1].pageX),K=.5*(F[0].pageY+F[1].pageY);I.set(D,K)}}function we(){if(F.length==1)z.set(F[0].pageX,F[0].pageY);else{const D=.5*(F[0].pageX+F[1].pageX),K=.5*(F[0].pageY+F[1].pageY);z.set(D,K)}}function qe(){const D=F[0].pageX-F[1].pageX,K=F[0].pageY-F[1].pageY,J=Math.sqrt(D*D+K*K);Q.set(0,J)}function fn(){s.enableZoom&&qe(),s.enablePan&&we()}function ze(){s.enableZoom&&qe(),s.enableRotate&&De()}function vn(D){if(F.length==1)E.set(D.pageX,D.pageY);else{const J=ft(D),ie=.5*(D.pageX+J.x),ye=.5*(D.pageY+J.y);E.set(ie,ye)}R.subVectors(E,I).multiplyScalar(s.rotateSpeed);const K=s.domElement;K&&(ue(2*Math.PI*R.x/K.clientHeight),ge(2*Math.PI*R.y/K.clientHeight)),I.copy(E)}function $t(D){if(F.length==1)B.set(D.pageX,D.pageY);else{const K=ft(D),J=.5*(D.pageX+K.x),ie=.5*(D.pageY+K.y);B.set(J,ie)}N.subVectors(B,z).multiplyScalar(s.panSpeed),he(N.x,N.y),z.copy(B)}function nt(D){const K=ft(D),J=D.pageX-K.x,ie=D.pageY-K.y,ye=Math.sqrt(J*J+ie*ie);$.set(0,ye),j.set(0,Math.pow($.y/Q.y,s.zoomSpeed)),ee(j.y),Q.copy($)}function dt(D){s.enableZoom&&nt(D),s.enablePan&&$t(D)}function Ee(D){s.enableZoom&&nt(D),s.enableRotate&&vn(D)}function Qe(D){if(s.enabled!==!1){if(F.length===0){var K,J;(K=s.domElement)===null||K===void 0||K.ownerDocument.addEventListener("pointermove",Xt),(J=s.domElement)===null||J===void 0||J.ownerDocument.addEventListener("pointerup",it)}yn(D),D.pointerType==="touch"?mt(D):Kn(D)}}function Xt(D){s.enabled!==!1&&(D.pointerType==="touch"?wn(D):gn(D))}function it(D){if(lt(D),F.length===0){var K,J,ie;(K=s.domElement)===null||K===void 0||K.releasePointerCapture(D.pointerId),(J=s.domElement)===null||J===void 0||J.ownerDocument.removeEventListener("pointermove",Xt),(ie=s.domElement)===null||ie===void 0||ie.ownerDocument.removeEventListener("pointerup",it)}s.dispatchEvent(u),d=h.NONE}function bn(D){lt(D)}function Kn(D){let K;switch(D.button){case 0:K=s.mouseButtons.LEFT;break;case 1:K=s.mouseButtons.MIDDLE;break;case 2:K=s.mouseButtons.RIGHT;break;default:K=-1}switch(K){case f.MOUSE.DOLLY:if(s.enableZoom===!1)return;fe(D),d=h.DOLLY;break;case f.MOUSE.ROTATE:if(D.ctrlKey||D.metaKey||D.shiftKey){if(s.enablePan===!1)return;le(D),d=h.PAN}else{if(s.enableRotate===!1)return;Ce(D),d=h.ROTATE}break;case f.MOUSE.PAN:if(D.ctrlKey||D.metaKey||D.shiftKey){if(s.enableRotate===!1)return;Ce(D),d=h.ROTATE}else{if(s.enablePan===!1)return;le(D),d=h.PAN}break;default:d=h.NONE}d!==h.NONE&&s.dispatchEvent(c)}function gn(D){if(s.enabled!==!1)switch(d){case h.ROTATE:if(s.enableRotate===!1)return;ne(D);break;case h.DOLLY:if(s.enableZoom===!1)return;be(D);break;case h.PAN:if(s.enablePan===!1)return;V(D);break}}function _n(D){s.enabled===!1||s.enableZoom===!1||d!==h.NONE&&d!==h.ROTATE||(D.preventDefault(),s.dispatchEvent(c),ce(D),s.dispatchEvent(u))}function at(D){s.enabled===!1||s.enablePan===!1||Ae(D)}function mt(D){switch(st(D),F.length){case 1:switch(s.touches.ONE){case f.TOUCH.ROTATE:if(s.enableRotate===!1)return;De(),d=h.TOUCH_ROTATE;break;case f.TOUCH.PAN:if(s.enablePan===!1)return;we(),d=h.TOUCH_PAN;break;default:d=h.NONE}break;case 2:switch(s.touches.TWO){case f.TOUCH.DOLLY_PAN:if(s.enableZoom===!1&&s.enablePan===!1)return;fn(),d=h.TOUCH_DOLLY_PAN;break;case f.TOUCH.DOLLY_ROTATE:if(s.enableZoom===!1&&s.enableRotate===!1)return;ze(),d=h.TOUCH_DOLLY_ROTATE;break;default:d=h.NONE}break;default:d=h.NONE}d!==h.NONE&&s.dispatchEvent(c)}function wn(D){switch(st(D),d){case h.TOUCH_ROTATE:if(s.enableRotate===!1)return;vn(D),s.update();break;case h.TOUCH_PAN:if(s.enablePan===!1)return;$t(D),s.update();break;case h.TOUCH_DOLLY_PAN:if(s.enableZoom===!1&&s.enablePan===!1)return;dt(D),s.update();break;case h.TOUCH_DOLLY_ROTATE:if(s.enableZoom===!1&&s.enableRotate===!1)return;Ee(D),s.update();break;default:d=h.NONE}}function Yt(D){s.enabled!==!1&&D.preventDefault()}function yn(D){F.push(D)}function lt(D){delete X[D.pointerId];for(let K=0;K<F.length;K++)if(F[K].pointerId==D.pointerId){F.splice(K,1);return}}function st(D){let K=X[D.pointerId];K===void 0&&(K=new f.Vector2,X[D.pointerId]=K),K.set(D.pageX,D.pageY)}function ft(D){const K=D.pointerId===F[0].pointerId?F[1]:F[0];return X[K.pointerId]}r!==void 0&&this.connect(r),this.update()}}class la extends f.Loader{constructor(i){super(i),this.dracoLoader=null,this.ktx2Loader=null,this.meshoptDecoder=null,this.pluginCallbacks=[],this.register(function(r){return new da(r)}),this.register(function(r){return new wa(r)}),this.register(function(r){return new ya(r)}),this.register(function(r){return new fa(r)}),this.register(function(r){return new va(r)}),this.register(function(r){return new ba(r)}),this.register(function(r){return new ga(r)}),this.register(function(r){return new ha(r)}),this.register(function(r){return new _a(r)}),this.register(function(r){return new ma(r)}),this.register(function(r){return new pa(r)}),this.register(function(r){return new xa(r)})}load(i,r,s,a){const c=this;let u;this.resourcePath!==""?u=this.resourcePath:this.path!==""?u=this.path:u=f.LoaderUtils.extractUrlBase(i),this.manager.itemStart(i);const h=function(_){a?a(_):console.error(_),c.manager.itemError(i),c.manager.itemEnd(i)},d=new f.FileLoader(this.manager);d.setPath(this.path),d.setResponseType("arraybuffer"),d.setRequestHeader(this.requestHeader),d.setWithCredentials(this.withCredentials),d.load(i,function(_){try{c.parse(_,u,function(y){r(y),c.manager.itemEnd(i)},h)}catch(y){h(y)}},s,h)}setDRACOLoader(i){return this.dracoLoader=i,this}setDDSLoader(){throw new Error('THREE.GLTFLoader: "MSFT_texture_dds" no longer supported. Please update to "KHR_texture_basisu".')}setKTX2Loader(i){return this.ktx2Loader=i,this}setMeshoptDecoder(i){return this.meshoptDecoder=i,this}register(i){return this.pluginCallbacks.indexOf(i)===-1&&this.pluginCallbacks.push(i),this}unregister(i){return this.pluginCallbacks.indexOf(i)!==-1&&this.pluginCallbacks.splice(this.pluginCallbacks.indexOf(i),1),this}parse(i,r,s,a){let c;const u={},h={};if(typeof i=="string")c=i;else if(f.LoaderUtils.decodeText(new Uint8Array(i,0,4))===Pr){try{u[se.KHR_BINARY_GLTF]=new Ca(i)}catch(w){a&&a(w);return}c=u[se.KHR_BINARY_GLTF].content}else c=f.LoaderUtils.decodeText(new Uint8Array(i));const d=JSON.parse(c);if(d.asset===void 0||d.asset.version[0]<2){a&&a(new Error("THREE.GLTFLoader: Unsupported asset. glTF versions >=2.0 are supported."));return}const _=new Ba(d,{path:r||this.resourcePath||"",crossOrigin:this.crossOrigin,requestHeader:this.requestHeader,manager:this.manager,ktx2Loader:this.ktx2Loader,meshoptDecoder:this.meshoptDecoder});_.fileLoader.setRequestHeader(this.requestHeader);for(let y=0;y<this.pluginCallbacks.length;y++){const w=this.pluginCallbacks[y](_);h[w.name]=w,u[w.name]=!0}if(d.extensionsUsed)for(let y=0;y<d.extensionsUsed.length;++y){const w=d.extensionsUsed[y],x=d.extensionsRequired||[];switch(w){case se.KHR_MATERIALS_UNLIT:u[w]=new ua;break;case se.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS:u[w]=new ka;break;case se.KHR_DRACO_MESH_COMPRESSION:u[w]=new Pa(d,this.dracoLoader);break;case se.KHR_TEXTURE_TRANSFORM:u[w]=new Ma;break;case se.KHR_MESH_QUANTIZATION:u[w]=new Sa;break;default:x.indexOf(w)>=0&&h[w]===void 0&&console.warn('THREE.GLTFLoader: Unknown extension "'+w+'".')}}_.setExtensions(u),_.setPlugins(h),_.parse(s,a)}parseAsync(i,r){const s=this;return new Promise(function(a,c){s.parse(i,r,a,c)})}}function ca(){let g={};return{get:function(i){return g[i]},add:function(i,r){g[i]=r},remove:function(i){delete g[i]},removeAll:function(){g={}}}}const se={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_PBR_SPECULAR_GLOSSINESS:"KHR_materials_pbrSpecularGlossiness",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_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_MESHOPT_COMPRESSION:"EXT_meshopt_compression"};class pa{constructor(i){this.parser=i,this.name=se.KHR_LIGHTS_PUNCTUAL,this.cache={refs:{},uses:{}}}_markDefs(){const i=this.parser,r=this.parser.json.nodes||[];for(let s=0,a=r.length;s<a;s++){const c=r[s];c.extensions&&c.extensions[this.name]&&c.extensions[this.name].light!==void 0&&i._addNodeRef(this.cache,c.extensions[this.name].light)}}_loadLight(i){const r=this.parser,s="light:"+i;let a=r.cache.get(s);if(a)return a;const c=r.json,d=((c.extensions&&c.extensions[this.name]||{}).lights||[])[i];let _;const y=new f.Color(16777215);d.color!==void 0&&y.fromArray(d.color);const w=d.range!==void 0?d.range:0;switch(d.type){case"directional":_=new f.DirectionalLight(y),_.target.position.set(0,0,-1),_.add(_.target);break;case"point":_=new f.PointLight(y),_.distance=w;break;case"spot":_=new f.SpotLight(y),_.distance=w,d.spot=d.spot||{},d.spot.innerConeAngle=d.spot.innerConeAngle!==void 0?d.spot.innerConeAngle:0,d.spot.outerConeAngle=d.spot.outerConeAngle!==void 0?d.spot.outerConeAngle:Math.PI/4,_.angle=d.spot.outerConeAngle,_.penumbra=1-d.spot.innerConeAngle/d.spot.outerConeAngle,_.target.position.set(0,0,-1),_.add(_.target);break;default:throw new Error("THREE.GLTFLoader: Unexpected light type: "+d.type)}return _.position.set(0,0,0),_.decay=2,d.intensity!==void 0&&(_.intensity=d.intensity),_.name=r.createUniqueName(d.name||"light_"+i),a=Promise.resolve(_),r.cache.add(s,a),a}createNodeAttachment(i){const r=this,s=this.parser,c=s.json.nodes[i],h=(c.extensions&&c.extensions[this.name]||{}).light;return h===void 0?null:this._loadLight(h).then(function(d){return s._getNodeRef(r.cache,h,d)})}}class ua{constructor(){this.name=se.KHR_MATERIALS_UNLIT}getMaterialType(){return f.MeshBasicMaterial}extendParams(i,r,s){const a=[];i.color=new f.Color(1,1,1),i.opacity=1;const c=r.pbrMetallicRoughness;if(c){if(Array.isArray(c.baseColorFactor)){const u=c.baseColorFactor;i.color.fromArray(u),i.opacity=u[3]}c.baseColorTexture!==void 0&&a.push(s.assignTexture(i,"map",c.baseColorTexture,f.sRGBEncoding))}return Promise.all(a)}}class ha{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_EMISSIVE_STRENGTH}extendMaterialParams(i,r){const a=this.parser.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=a.extensions[this.name].emissiveStrength;return c!==void 0&&(r.emissiveIntensity=c),Promise.resolve()}}class da{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_CLEARCOAT}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[],u=a.extensions[this.name];if(u.clearcoatFactor!==void 0&&(r.clearcoat=u.clearcoatFactor),u.clearcoatTexture!==void 0&&c.push(s.assignTexture(r,"clearcoatMap",u.clearcoatTexture)),u.clearcoatRoughnessFactor!==void 0&&(r.clearcoatRoughness=u.clearcoatRoughnessFactor),u.clearcoatRoughnessTexture!==void 0&&c.push(s.assignTexture(r,"clearcoatRoughnessMap",u.clearcoatRoughnessTexture)),u.clearcoatNormalTexture!==void 0&&(c.push(s.assignTexture(r,"clearcoatNormalMap",u.clearcoatNormalTexture)),u.clearcoatNormalTexture.scale!==void 0)){const h=u.clearcoatNormalTexture.scale;r.clearcoatNormalScale=new f.Vector2(h,h)}return Promise.all(c)}}class ma{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_IRIDESCENCE}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[],u=a.extensions[this.name];return u.iridescenceFactor!==void 0&&(r.iridescence=u.iridescenceFactor),u.iridescenceTexture!==void 0&&c.push(s.assignTexture(r,"iridescenceMap",u.iridescenceTexture)),u.iridescenceIor!==void 0&&(r.iridescenceIOR=u.iridescenceIor),r.iridescenceThicknessRange===void 0&&(r.iridescenceThicknessRange=[100,400]),u.iridescenceThicknessMinimum!==void 0&&(r.iridescenceThicknessRange[0]=u.iridescenceThicknessMinimum),u.iridescenceThicknessMaximum!==void 0&&(r.iridescenceThicknessRange[1]=u.iridescenceThicknessMaximum),u.iridescenceThicknessTexture!==void 0&&c.push(s.assignTexture(r,"iridescenceThicknessMap",u.iridescenceThicknessTexture)),Promise.all(c)}}class fa{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_SHEEN}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[];r.sheenColor=new f.Color(0,0,0),r.sheenRoughness=0,r.sheen=1;const u=a.extensions[this.name];return u.sheenColorFactor!==void 0&&r.sheenColor.fromArray(u.sheenColorFactor),u.sheenRoughnessFactor!==void 0&&(r.sheenRoughness=u.sheenRoughnessFactor),u.sheenColorTexture!==void 0&&c.push(s.assignTexture(r,"sheenColorMap",u.sheenColorTexture,f.sRGBEncoding)),u.sheenRoughnessTexture!==void 0&&c.push(s.assignTexture(r,"sheenRoughnessMap",u.sheenRoughnessTexture)),Promise.all(c)}}class va{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_TRANSMISSION}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[],u=a.extensions[this.name];return u.transmissionFactor!==void 0&&(r.transmission=u.transmissionFactor),u.transmissionTexture!==void 0&&c.push(s.assignTexture(r,"transmissionMap",u.transmissionTexture)),Promise.all(c)}}class ba{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_VOLUME}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[],u=a.extensions[this.name];r.thickness=u.thicknessFactor!==void 0?u.thicknessFactor:0,u.thicknessTexture!==void 0&&c.push(s.assignTexture(r,"thicknessMap",u.thicknessTexture)),r.attenuationDistance=u.attenuationDistance||1/0;const h=u.attenuationColor||[1,1,1];return r.attenuationColor=new f.Color(h[0],h[1],h[2]),Promise.all(c)}}class ga{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_IOR}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const a=this.parser.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=a.extensions[this.name];return r.ior=c.ior!==void 0?c.ior:1.5,Promise.resolve()}}class _a{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_SPECULAR}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[],u=a.extensions[this.name];r.specularIntensity=u.specularFactor!==void 0?u.specularFactor:1,u.specularTexture!==void 0&&c.push(s.assignTexture(r,"specularIntensityMap",u.specularTexture));const h=u.specularColorFactor||[1,1,1];return r.specularColor=new f.Color(h[0],h[1],h[2]),u.specularColorTexture!==void 0&&c.push(s.assignTexture(r,"specularColorMap",u.specularColorTexture,f.sRGBEncoding)),Promise.all(c)}}class wa{constructor(i){this.parser=i,this.name=se.KHR_TEXTURE_BASISU}loadTexture(i){const r=this.parser,s=r.json,a=s.textures[i];if(!a.extensions||!a.extensions[this.name])return null;const c=a.extensions[this.name],u=r.options.ktx2Loader;if(!u){if(s.extensionsRequired&&s.extensionsRequired.indexOf(this.name)>=0)throw new Error("THREE.GLTFLoader: setKTX2Loader must be called before loading KTX2 textures");return null}return r.loadTextureImage(i,c.source,u)}}class ya{constructor(i){this.parser=i,this.name=se.EXT_TEXTURE_WEBP,this.isSupported=null}loadTexture(i){const r=this.name,s=this.parser,a=s.json,c=a.textures[i];if(!c.extensions||!c.extensions[r])return null;const u=c.extensions[r],h=a.images[u.source];let d=s.textureLoader;if(h.uri){const _=s.options.manager.getHandler(h.uri);_!==null&&(d=_)}return this.detectSupport().then(function(_){if(_)return s.loadTextureImage(i,u.source,d);if(a.extensionsRequired&&a.extensionsRequired.indexOf(r)>=0)throw new Error("THREE.GLTFLoader: WebP required by asset but unsupported.");return s.loadTexture(i)})}detectSupport(){return this.isSupported||(this.isSupported=new Promise(function(i){const r=new Image;r.src="data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA",r.onload=r.onerror=function(){i(r.height===1)}})),this.isSupported}}class xa{constructor(i){this.name=se.EXT_MESHOPT_COMPRESSION,this.parser=i}loadBufferView(i){const r=this.parser.json,s=r.bufferViews[i];if(s.extensions&&s.extensions[this.name]){const a=s.extensions[this.name],c=this.parser.getDependency("buffer",a.buffer),u=this.parser.options.meshoptDecoder;if(!u||!u.supported){if(r.extensionsRequired&&r.extensionsRequired.indexOf(this.name)>=0)throw new Error("THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files");return null}return c.then(function(h){const d=a.byteOffset||0,_=a.byteLength||0,y=a.count,w=a.byteStride,x=new Uint8Array(h,d,_);return u.decodeGltfBufferAsync?u.decodeGltfBufferAsync(y,w,x,a.mode,a.filter).then(function(M){return M.buffer}):u.ready.then(function(){const M=new ArrayBuffer(y*w);return u.decodeGltfBuffer(new Uint8Array(M),y,w,x,a.mode,a.filter),M})})}else return null}}const Pr="glTF",zn=12,Mr={JSON:1313821514,BIN:5130562};class Ca{constructor(i){this.name=se.KHR_BINARY_GLTF,this.content=null,this.body=null;const r=new DataView(i,0,zn);if(this.header={magic:f.LoaderUtils.decodeText(new Uint8Array(i.slice(0,4))),version:r.getUint32(4,!0),length:r.getUint32(8,!0)},this.header.magic!==Pr)throw new Error("THREE.GLTFLoader: Unsupported glTF-Binary header.");if(this.header.version<2)throw new Error("THREE.GLTFLoader: Legacy binary file detected.");const s=this.header.length-zn,a=new DataView(i,zn);let c=0;for(;c<s;){const u=a.getUint32(c,!0);c+=4;const h=a.getUint32(c,!0);if(c+=4,h===Mr.JSON){const d=new Uint8Array(i,zn+c,u);this.content=f.LoaderUtils.decodeText(d)}else if(h===Mr.BIN){const d=zn+c;this.body=i.slice(d,d+u)}c+=u}if(this.content===null)throw new Error("THREE.GLTFLoader: JSON content not found.")}}class Pa{constructor(i,r){if(!r)throw new Error("THREE.GLTFLoader: No DRACOLoader instance provided.");this.name=se.KHR_DRACO_MESH_COMPRESSION,this.json=i,this.dracoLoader=r,this.dracoLoader.preload()}decodePrimitive(i,r){const s=this.json,a=this.dracoLoader,c=i.extensions[this.name].bufferView,u=i.extensions[this.name].attributes,h={},d={},_={};for(const y in u){const w=os[y]||y.toLowerCase();h[w]=u[y]}for(const y in i.attributes){const w=os[y]||y.toLowerCase();if(u[y]!==void 0){const x=s.accessors[i.attributes[y]],M=Un[x.componentType];_[w]=M.name,d[w]=x.normalized===!0}}return r.getDependency("bufferView",c).then(function(y){return new Promise(function(w){a.decodeDracoFile(y,function(x){for(const M in x.attributes){const O=x.attributes[M],I=d[M];I!==void 0&&(O.normalized=I)}w(x)},h,_)})})}}class Ma{constructor(){this.name=se.KHR_TEXTURE_TRANSFORM}extendTexture(i,r){return r.texCoord!==void 0&&console.warn('THREE.GLTFLoader: Custom UV sets in "'+this.name+'" extension not yet supported.'),r.offset===void 0&&r.rotation===void 0&&r.scale===void 0||(i=i.clone(),r.offset!==void 0&&i.offset.fromArray(r.offset),r.rotation!==void 0&&(i.rotation=r.rotation),r.scale!==void 0&&i.repeat.fromArray(r.scale),i.needsUpdate=!0),i}}class rs extends f.MeshStandardMaterial{constructor(i){super(),this.isGLTFSpecularGlossinessMaterial=!0;const r=["#ifdef USE_SPECULARMAP"," uniform sampler2D specularMap;","#endif"].join(`
8
+ (function(ae,A){typeof exports=="object"&&typeof module<"u"?A(exports,require("vue"),require("@tresjs/core"),require("three")):typeof define=="function"&&define.amd?define(["exports","vue","@tresjs/core","three"],A):(ae=typeof globalThis<"u"?globalThis:ae||self,A(ae.trescientos={},ae.Vue,ae.TresjsCore,ae.Three))})(this,function(ae,A,zt,f){"use strict";function Uo(g,i){for(var r=0;r<i.length;r++){const s=i[r];if(typeof s!="string"&&!Array.isArray(s)){for(const a in s)if(a!=="default"&&!(a in g)){const c=Object.getOwnPropertyDescriptor(s,a);c&&Object.defineProperty(g,a,c.get?c:{enumerable:!0,get:()=>s[a]})}}}return Object.freeze(Object.defineProperty(g,Symbol.toStringTag,{value:"Module"}))}function Nn(g){return Nn=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(i){return typeof i}:function(i){return i&&typeof Symbol=="function"&&i.constructor===Symbol&&i!==Symbol.prototype?"symbol":typeof i},Nn(g)}function Ro(g,i){if(Nn(g)!=="object"||g===null)return g;var r=g[Symbol.toPrimitive];if(r!==void 0){var s=r.call(g,i||"default");if(Nn(s)!=="object")return s;throw new TypeError("@@toPrimitive must return a primitive value.")}return(i==="string"?String:Number)(g)}function Go(g){var i=Ro(g,"string");return Nn(i)==="symbol"?i:String(i)}function S(g,i,r){return i=Go(i),i in g?Object.defineProperty(g,i,{value:r,enumerable:!0,configurable:!0,writable:!0}):g[i]=r,g}var Ye=Uint8Array,Pt=Uint16Array,ts=Uint32Array,br=new Ye([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]),gr=new Ye([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]),Ko=new Ye([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),_r=function(g,i){for(var r=new Pt(31),s=0;s<31;++s)r[s]=i+=1<<g[s-1];for(var a=new ts(r[30]),s=1;s<30;++s)for(var c=r[s];c<r[s+1];++c)a[c]=c-r[s]<<5|s;return[r,a]},wr=_r(br,2),yr=wr[0],$o=wr[1];yr[28]=258,$o[258]=28;for(var Xo=_r(gr,0),Yo=Xo[0],ns=new Pt(32768),xe=0;xe<32768;++xe){var Mt=(xe&43690)>>>1|(xe&21845)<<1;Mt=(Mt&52428)>>>2|(Mt&13107)<<2,Mt=(Mt&61680)>>>4|(Mt&3855)<<4,ns[xe]=((Mt&65280)>>>8|(Mt&255)<<8)>>>1}for(var Fn=function(g,i,r){for(var s=g.length,a=0,c=new Pt(i);a<s;++a)++c[g[a]-1];var u=new Pt(i);for(a=0;a<i;++a)u[a]=u[a-1]+c[a-1]<<1;var h;if(r){h=new Pt(1<<i);var d=15-i;for(a=0;a<s;++a)if(g[a])for(var _=a<<4|g[a],y=i-g[a],w=u[g[a]-1]++<<y,x=w|(1<<y)-1;w<=x;++w)h[ns[w]>>>d]=_}else for(h=new Pt(s),a=0;a<s;++a)g[a]&&(h[a]=ns[u[g[a]-1]++]>>>15-g[a]);return h},jn=new Ye(288),xe=0;xe<144;++xe)jn[xe]=8;for(var xe=144;xe<256;++xe)jn[xe]=9;for(var xe=256;xe<280;++xe)jn[xe]=7;for(var xe=280;xe<288;++xe)jn[xe]=8;for(var xr=new Ye(32),xe=0;xe<32;++xe)xr[xe]=5;var qo=Fn(jn,9,1),Qo=Fn(xr,5,1),is=function(g){for(var i=g[0],r=1;r<g.length;++r)g[r]>i&&(i=g[r]);return i},tt=function(g,i,r){var s=i/8|0;return(g[s]|g[s+1]<<8)>>(i&7)&r},ss=function(g,i){var r=i/8|0;return(g[r]|g[r+1]<<8|g[r+2]<<16)>>(i&7)},Zo=function(g){return(g/8|0)+(g&7&&1)},Wo=function(g,i,r){(i==null||i<0)&&(i=0),(r==null||r>g.length)&&(r=g.length);var s=new(g instanceof Pt?Pt:g instanceof ts?ts:Ye)(r-i);return s.set(g.subarray(i,r)),s},Jo=function(g,i,r){var s=g.length;if(!s||r&&!r.l&&s<5)return i||new Ye(0);var a=!i||r,c=!r||r.i;r||(r={}),i||(i=new Ye(s*3));var u=function(Ae){var De=i.length;if(Ae>De){var we=new Ye(Math.max(De*2,Ae));we.set(i),i=we}},h=r.f||0,d=r.p||0,_=r.b||0,y=r.l,w=r.d,x=r.m,M=r.n,O=s*8;do{if(!y){r.f=h=tt(g,d,1);var I=tt(g,d+1,3);if(d+=3,I)if(I==1)y=qo,w=Qo,x=9,M=5;else if(I==2){var B=tt(g,d,31)+257,N=tt(g,d+10,15)+4,Q=B+tt(g,d+5,31)+1;d+=14;for(var $=new Ye(Q),j=new Ye(19),F=0;F<N;++F)j[Ko[F]]=tt(g,d+F*3,7);d+=N*3;for(var X=is(j),Y=(1<<X)-1,Z=Fn(j,X,1),F=0;F<Q;){var ue=Z[tt(g,d,Y)];d+=ue&15;var E=ue>>>4;if(E<16)$[F++]=E;else{var ge=0,pe=0;for(E==16?(pe=3+tt(g,d,3),d+=2,ge=$[F-1]):E==17?(pe=3+tt(g,d,7),d+=3):E==18&&(pe=11+tt(g,d,127),d+=7);pe--;)$[F++]=ge}}var me=$.subarray(0,B),he=$.subarray(B);x=is(me),M=is(he),y=Fn(me,x,1),w=Fn(he,M,1)}else throw"invalid block type";else{var E=Zo(d)+4,R=g[E-4]|g[E-3]<<8,z=E+R;if(z>s){if(c)throw"unexpected EOF";break}a&&u(_+R),i.set(g.subarray(E,z),_),r.b=_+=R,r.p=d=z*8;continue}if(d>O){if(c)throw"unexpected EOF";break}}a&&u(_+131072);for(var ee=(1<<x)-1,q=(1<<M)-1,Ce=d;;Ce=d){var ge=y[ss(g,d)&ee],fe=ge>>>4;if(d+=ge&15,d>O){if(c)throw"unexpected EOF";break}if(!ge)throw"invalid length/literal";if(fe<256)i[_++]=fe;else if(fe==256){Ce=d,y=null;break}else{var le=fe-254;if(fe>264){var F=fe-257,ne=br[F];le=tt(g,d,(1<<ne)-1)+yr[F],d+=ne}var be=w[ss(g,d)&q],V=be>>>4;if(!be)throw"invalid distance";d+=be&15;var he=Yo[V];if(V>3){var ne=gr[V];he+=ss(g,d)&(1<<ne)-1,d+=ne}if(d>O){if(c)throw"unexpected EOF";break}a&&u(_+131072);for(var ce=_+le;_<ce;_+=4)i[_]=i[_-he],i[_+1]=i[_+1-he],i[_+2]=i[_+2-he],i[_+3]=i[_+3-he];_=ce}}r.l=y,r.p=Ce,r.b=_,y&&(h=1,r.m=x,r.d=w,r.n=M)}while(!h);return _==i.length?i:Wo(i,0,_)},Ho=new Ye(0),ea=function(g){if((g[0]&15)!=8||g[0]>>>4>7||(g[0]<<8|g[1])%31)throw"invalid zlib data";if(g[1]&32)throw"invalid zlib data: preset dictionaries not supported"};function ta(g,i){return Jo((ea(g),g.subarray(2,-4)),i)}var na=typeof TextDecoder<"u"&&new TextDecoder,ia=0;try{na.decode(Ho,{stream:!0}),ia=1}catch{}class sa extends f.Object3D{constructor(i,r){super(),S(this,"isTransformControls",!0),S(this,"visible",!1),S(this,"domElement",void 0),S(this,"raycaster",new f.Raycaster),S(this,"gizmo",void 0),S(this,"plane",void 0),S(this,"tempVector",new f.Vector3),S(this,"tempVector2",new f.Vector3),S(this,"tempQuaternion",new f.Quaternion),S(this,"unit",{X:new f.Vector3(1,0,0),Y:new f.Vector3(0,1,0),Z:new f.Vector3(0,0,1)}),S(this,"pointStart",new f.Vector3),S(this,"pointEnd",new f.Vector3),S(this,"offset",new f.Vector3),S(this,"rotationAxis",new f.Vector3),S(this,"startNorm",new f.Vector3),S(this,"endNorm",new f.Vector3),S(this,"rotationAngle",0),S(this,"cameraPosition",new f.Vector3),S(this,"cameraQuaternion",new f.Quaternion),S(this,"cameraScale",new f.Vector3),S(this,"parentPosition",new f.Vector3),S(this,"parentQuaternion",new f.Quaternion),S(this,"parentQuaternionInv",new f.Quaternion),S(this,"parentScale",new f.Vector3),S(this,"worldPositionStart",new f.Vector3),S(this,"worldQuaternionStart",new f.Quaternion),S(this,"worldScaleStart",new f.Vector3),S(this,"worldPosition",new f.Vector3),S(this,"worldQuaternion",new f.Quaternion),S(this,"worldQuaternionInv",new f.Quaternion),S(this,"worldScale",new f.Vector3),S(this,"eye",new f.Vector3),S(this,"positionStart",new f.Vector3),S(this,"quaternionStart",new f.Quaternion),S(this,"scaleStart",new f.Vector3),S(this,"camera",void 0),S(this,"object",void 0),S(this,"enabled",!0),S(this,"axis",null),S(this,"mode","translate"),S(this,"translationSnap",null),S(this,"rotationSnap",null),S(this,"scaleSnap",null),S(this,"space","world"),S(this,"size",1),S(this,"dragging",!1),S(this,"showX",!0),S(this,"showY",!0),S(this,"showZ",!0),S(this,"changeEvent",{type:"change"}),S(this,"mouseDownEvent",{type:"mouseDown",mode:this.mode}),S(this,"mouseUpEvent",{type:"mouseUp",mode:this.mode}),S(this,"objectChangeEvent",{type:"objectChange"}),S(this,"intersectObjectWithRay",(a,c,u)=>{const h=c.intersectObject(a,!0);for(let d=0;d<h.length;d++)if(h[d].object.visible||u)return h[d];return!1}),S(this,"attach",a=>(this.object=a,this.visible=!0,this)),S(this,"detach",()=>(this.object=void 0,this.visible=!1,this.axis=null,this)),S(this,"reset",()=>this.enabled?(this.dragging&&this.object!==void 0&&(this.object.position.copy(this.positionStart),this.object.quaternion.copy(this.quaternionStart),this.object.scale.copy(this.scaleStart),this.dispatchEvent(this.changeEvent),this.dispatchEvent(this.objectChangeEvent),this.pointStart.copy(this.pointEnd)),this):this),S(this,"updateMatrixWorld",()=>{this.object!==void 0&&(this.object.updateMatrixWorld(),this.object.parent===null?console.error("TransformControls: The attached 3D object must be a part of the scene graph."):this.object.parent.matrixWorld.decompose(this.parentPosition,this.parentQuaternion,this.parentScale),this.object.matrixWorld.decompose(this.worldPosition,this.worldQuaternion,this.worldScale),this.parentQuaternionInv.copy(this.parentQuaternion).invert(),this.worldQuaternionInv.copy(this.worldQuaternion).invert()),this.camera.updateMatrixWorld(),this.camera.matrixWorld.decompose(this.cameraPosition,this.cameraQuaternion,this.cameraScale),this.eye.copy(this.cameraPosition).sub(this.worldPosition).normalize(),super.updateMatrixWorld()}),S(this,"pointerHover",a=>{if(this.object===void 0||this.dragging===!0)return;this.raycaster.setFromCamera(a,this.camera);const c=this.intersectObjectWithRay(this.gizmo.picker[this.mode],this.raycaster);c?this.axis=c.object.name:this.axis=null}),S(this,"pointerDown",a=>{if(!(this.object===void 0||this.dragging===!0||a.button!==0)&&this.axis!==null){this.raycaster.setFromCamera(a,this.camera);const c=this.intersectObjectWithRay(this.plane,this.raycaster,!0);if(c){let u=this.space;if(this.mode==="scale"?u="local":(this.axis==="E"||this.axis==="XYZE"||this.axis==="XYZ")&&(u="world"),u==="local"&&this.mode==="rotate"){const h=this.rotationSnap;this.axis==="X"&&h&&(this.object.rotation.x=Math.round(this.object.rotation.x/h)*h),this.axis==="Y"&&h&&(this.object.rotation.y=Math.round(this.object.rotation.y/h)*h),this.axis==="Z"&&h&&(this.object.rotation.z=Math.round(this.object.rotation.z/h)*h)}this.object.updateMatrixWorld(),this.object.parent&&this.object.parent.updateMatrixWorld(),this.positionStart.copy(this.object.position),this.quaternionStart.copy(this.object.quaternion),this.scaleStart.copy(this.object.scale),this.object.matrixWorld.decompose(this.worldPositionStart,this.worldQuaternionStart,this.worldScaleStart),this.pointStart.copy(c.point).sub(this.worldPositionStart)}this.dragging=!0,this.mouseDownEvent.mode=this.mode,this.dispatchEvent(this.mouseDownEvent)}}),S(this,"pointerMove",a=>{const c=this.axis,u=this.mode,h=this.object;let d=this.space;if(u==="scale"?d="local":(c==="E"||c==="XYZE"||c==="XYZ")&&(d="world"),h===void 0||c===null||this.dragging===!1||a.button!==-1)return;this.raycaster.setFromCamera(a,this.camera);const _=this.intersectObjectWithRay(this.plane,this.raycaster,!0);if(_){if(this.pointEnd.copy(_.point).sub(this.worldPositionStart),u==="translate")this.offset.copy(this.pointEnd).sub(this.pointStart),d==="local"&&c!=="XYZ"&&this.offset.applyQuaternion(this.worldQuaternionInv),c.indexOf("X")===-1&&(this.offset.x=0),c.indexOf("Y")===-1&&(this.offset.y=0),c.indexOf("Z")===-1&&(this.offset.z=0),d==="local"&&c!=="XYZ"?this.offset.applyQuaternion(this.quaternionStart).divide(this.parentScale):this.offset.applyQuaternion(this.parentQuaternionInv).divide(this.parentScale),h.position.copy(this.offset).add(this.positionStart),this.translationSnap&&(d==="local"&&(h.position.applyQuaternion(this.tempQuaternion.copy(this.quaternionStart).invert()),c.search("X")!==-1&&(h.position.x=Math.round(h.position.x/this.translationSnap)*this.translationSnap),c.search("Y")!==-1&&(h.position.y=Math.round(h.position.y/this.translationSnap)*this.translationSnap),c.search("Z")!==-1&&(h.position.z=Math.round(h.position.z/this.translationSnap)*this.translationSnap),h.position.applyQuaternion(this.quaternionStart)),d==="world"&&(h.parent&&h.position.add(this.tempVector.setFromMatrixPosition(h.parent.matrixWorld)),c.search("X")!==-1&&(h.position.x=Math.round(h.position.x/this.translationSnap)*this.translationSnap),c.search("Y")!==-1&&(h.position.y=Math.round(h.position.y/this.translationSnap)*this.translationSnap),c.search("Z")!==-1&&(h.position.z=Math.round(h.position.z/this.translationSnap)*this.translationSnap),h.parent&&h.position.sub(this.tempVector.setFromMatrixPosition(h.parent.matrixWorld))));else if(u==="scale"){if(c.search("XYZ")!==-1){let y=this.pointEnd.length()/this.pointStart.length();this.pointEnd.dot(this.pointStart)<0&&(y*=-1),this.tempVector2.set(y,y,y)}else this.tempVector.copy(this.pointStart),this.tempVector2.copy(this.pointEnd),this.tempVector.applyQuaternion(this.worldQuaternionInv),this.tempVector2.applyQuaternion(this.worldQuaternionInv),this.tempVector2.divide(this.tempVector),c.search("X")===-1&&(this.tempVector2.x=1),c.search("Y")===-1&&(this.tempVector2.y=1),c.search("Z")===-1&&(this.tempVector2.z=1);h.scale.copy(this.scaleStart).multiply(this.tempVector2),this.scaleSnap&&this.object&&(c.search("X")!==-1&&(this.object.scale.x=Math.round(h.scale.x/this.scaleSnap)*this.scaleSnap||this.scaleSnap),c.search("Y")!==-1&&(h.scale.y=Math.round(h.scale.y/this.scaleSnap)*this.scaleSnap||this.scaleSnap),c.search("Z")!==-1&&(h.scale.z=Math.round(h.scale.z/this.scaleSnap)*this.scaleSnap||this.scaleSnap))}else if(u==="rotate"){this.offset.copy(this.pointEnd).sub(this.pointStart);const y=20/this.worldPosition.distanceTo(this.tempVector.setFromMatrixPosition(this.camera.matrixWorld));c==="E"?(this.rotationAxis.copy(this.eye),this.rotationAngle=this.pointEnd.angleTo(this.pointStart),this.startNorm.copy(this.pointStart).normalize(),this.endNorm.copy(this.pointEnd).normalize(),this.rotationAngle*=this.endNorm.cross(this.startNorm).dot(this.eye)<0?1:-1):c==="XYZE"?(this.rotationAxis.copy(this.offset).cross(this.eye).normalize(),this.rotationAngle=this.offset.dot(this.tempVector.copy(this.rotationAxis).cross(this.eye))*y):(c==="X"||c==="Y"||c==="Z")&&(this.rotationAxis.copy(this.unit[c]),this.tempVector.copy(this.unit[c]),d==="local"&&this.tempVector.applyQuaternion(this.worldQuaternion),this.rotationAngle=this.offset.dot(this.tempVector.cross(this.eye).normalize())*y),this.rotationSnap&&(this.rotationAngle=Math.round(this.rotationAngle/this.rotationSnap)*this.rotationSnap),d==="local"&&c!=="E"&&c!=="XYZE"?(h.quaternion.copy(this.quaternionStart),h.quaternion.multiply(this.tempQuaternion.setFromAxisAngle(this.rotationAxis,this.rotationAngle)).normalize()):(this.rotationAxis.applyQuaternion(this.parentQuaternionInv),h.quaternion.copy(this.tempQuaternion.setFromAxisAngle(this.rotationAxis,this.rotationAngle)),h.quaternion.multiply(this.quaternionStart).normalize())}this.dispatchEvent(this.changeEvent),this.dispatchEvent(this.objectChangeEvent)}}),S(this,"pointerUp",a=>{a.button===0&&(this.dragging&&this.axis!==null&&(this.mouseUpEvent.mode=this.mode,this.dispatchEvent(this.mouseUpEvent)),this.dragging=!1,this.axis=null)}),S(this,"getPointer",a=>{var c;if(this.domElement&&(c=this.domElement.ownerDocument)!==null&&c!==void 0&&c.pointerLockElement)return{x:0,y:0,button:a.button};{var u;const h=a.changedTouches?a.changedTouches[0]:a,d=(u=this.domElement)===null||u===void 0?void 0:u.getBoundingClientRect();return{x:(h.clientX-d.left)/d.width*2-1,y:-(h.clientY-d.top)/d.height*2+1,button:a.button}}}),S(this,"onPointerHover",a=>{if(this.enabled)switch(a.pointerType){case"mouse":case"pen":this.pointerHover(this.getPointer(a));break}}),S(this,"onPointerDown",a=>{!this.enabled||!this.domElement||(this.domElement.style.touchAction="none",this.domElement.ownerDocument.addEventListener("pointermove",this.onPointerMove),this.pointerHover(this.getPointer(a)),this.pointerDown(this.getPointer(a)))}),S(this,"onPointerMove",a=>{this.enabled&&this.pointerMove(this.getPointer(a))}),S(this,"onPointerUp",a=>{!this.enabled||!this.domElement||(this.domElement.style.touchAction="",this.domElement.ownerDocument.removeEventListener("pointermove",this.onPointerMove),this.pointerUp(this.getPointer(a)))}),S(this,"getMode",()=>this.mode),S(this,"setMode",a=>{this.mode=a}),S(this,"setTranslationSnap",a=>{this.translationSnap=a}),S(this,"setRotationSnap",a=>{this.rotationSnap=a}),S(this,"setScaleSnap",a=>{this.scaleSnap=a}),S(this,"setSize",a=>{this.size=a}),S(this,"setSpace",a=>{this.space=a}),S(this,"update",()=>{console.warn("THREE.TransformControls: update function has no more functionality and therefore has been deprecated.")}),S(this,"connect",a=>{a===document&&console.error('THREE.OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.'),this.domElement=a,this.domElement.addEventListener("pointerdown",this.onPointerDown),this.domElement.addEventListener("pointermove",this.onPointerHover),this.domElement.ownerDocument.addEventListener("pointerup",this.onPointerUp)}),S(this,"dispose",()=>{var a,c,u,h,d,_;(a=this.domElement)===null||a===void 0||a.removeEventListener("pointerdown",this.onPointerDown),(c=this.domElement)===null||c===void 0||c.removeEventListener("pointermove",this.onPointerHover),(u=this.domElement)===null||u===void 0||(h=u.ownerDocument)===null||h===void 0||h.removeEventListener("pointermove",this.onPointerMove),(d=this.domElement)===null||d===void 0||(_=d.ownerDocument)===null||_===void 0||_.removeEventListener("pointerup",this.onPointerUp),this.traverse(y=>{const w=y;w.geometry&&w.geometry.dispose(),w.material&&w.material.dispose()})}),this.domElement=r,this.camera=i,this.gizmo=new ra,this.add(this.gizmo),this.plane=new oa,this.add(this.plane);const s=(a,c)=>{let u=c;Object.defineProperty(this,a,{get:function(){return u!==void 0?u:c},set:function(h){u!==h&&(u=h,this.plane[a]=h,this.gizmo[a]=h,this.dispatchEvent({type:a+"-changed",value:h}),this.dispatchEvent(this.changeEvent))}}),this[a]=c,this.plane[a]=c,this.gizmo[a]=c};s("camera",this.camera),s("object",this.object),s("enabled",this.enabled),s("axis",this.axis),s("mode",this.mode),s("translationSnap",this.translationSnap),s("rotationSnap",this.rotationSnap),s("scaleSnap",this.scaleSnap),s("space",this.space),s("size",this.size),s("dragging",this.dragging),s("showX",this.showX),s("showY",this.showY),s("showZ",this.showZ),s("worldPosition",this.worldPosition),s("worldPositionStart",this.worldPositionStart),s("worldQuaternion",this.worldQuaternion),s("worldQuaternionStart",this.worldQuaternionStart),s("cameraPosition",this.cameraPosition),s("cameraQuaternion",this.cameraQuaternion),s("pointStart",this.pointStart),s("pointEnd",this.pointEnd),s("rotationAxis",this.rotationAxis),s("rotationAngle",this.rotationAngle),s("eye",this.eye),r!==void 0&&this.connect(r)}}class ra extends f.Object3D{constructor(){super(),S(this,"isTransformControlsGizmo",!0),S(this,"type","TransformControlsGizmo"),S(this,"tempVector",new f.Vector3(0,0,0)),S(this,"tempEuler",new f.Euler),S(this,"alignVector",new f.Vector3(0,1,0)),S(this,"zeroVector",new f.Vector3(0,0,0)),S(this,"lookAtMatrix",new f.Matrix4),S(this,"tempQuaternion",new f.Quaternion),S(this,"tempQuaternion2",new f.Quaternion),S(this,"identityQuaternion",new f.Quaternion),S(this,"unitX",new f.Vector3(1,0,0)),S(this,"unitY",new f.Vector3(0,1,0)),S(this,"unitZ",new f.Vector3(0,0,1)),S(this,"gizmo",void 0),S(this,"picker",void 0),S(this,"helper",void 0),S(this,"rotationAxis",new f.Vector3),S(this,"cameraPosition",new f.Vector3),S(this,"worldPositionStart",new f.Vector3),S(this,"worldQuaternionStart",new f.Quaternion),S(this,"worldPosition",new f.Vector3),S(this,"worldQuaternion",new f.Quaternion),S(this,"eye",new f.Vector3),S(this,"camera",null),S(this,"enabled",!0),S(this,"axis",null),S(this,"mode","translate"),S(this,"space","world"),S(this,"size",1),S(this,"dragging",!1),S(this,"showX",!0),S(this,"showY",!0),S(this,"showZ",!0),S(this,"updateMatrixWorld",()=>{let fe=this.space;this.mode==="scale"&&(fe="local");const le=fe==="local"?this.worldQuaternion:this.identityQuaternion;this.gizmo.translate.visible=this.mode==="translate",this.gizmo.rotate.visible=this.mode==="rotate",this.gizmo.scale.visible=this.mode==="scale",this.helper.translate.visible=this.mode==="translate",this.helper.rotate.visible=this.mode==="rotate",this.helper.scale.visible=this.mode==="scale";let ne=[];ne=ne.concat(this.picker[this.mode].children),ne=ne.concat(this.gizmo[this.mode].children),ne=ne.concat(this.helper[this.mode].children);for(let be=0;be<ne.length;be++){const V=ne[be];V.visible=!0,V.rotation.set(0,0,0),V.position.copy(this.worldPosition);let ce;if(this.camera.isOrthographicCamera?ce=(this.camera.top-this.camera.bottom)/this.camera.zoom:ce=this.worldPosition.distanceTo(this.cameraPosition)*Math.min(1.9*Math.tan(Math.PI*this.camera.fov/360)/this.camera.zoom,7),V.scale.set(1,1,1).multiplyScalar(ce*this.size/7),V.tag==="helper"){V.visible=!1,V.name==="AXIS"?(V.position.copy(this.worldPositionStart),V.visible=!!this.axis,this.axis==="X"&&(this.tempQuaternion.setFromEuler(this.tempEuler.set(0,0,0)),V.quaternion.copy(le).multiply(this.tempQuaternion),Math.abs(this.alignVector.copy(this.unitX).applyQuaternion(le).dot(this.eye))>.9&&(V.visible=!1)),this.axis==="Y"&&(this.tempQuaternion.setFromEuler(this.tempEuler.set(0,0,Math.PI/2)),V.quaternion.copy(le).multiply(this.tempQuaternion),Math.abs(this.alignVector.copy(this.unitY).applyQuaternion(le).dot(this.eye))>.9&&(V.visible=!1)),this.axis==="Z"&&(this.tempQuaternion.setFromEuler(this.tempEuler.set(0,Math.PI/2,0)),V.quaternion.copy(le).multiply(this.tempQuaternion),Math.abs(this.alignVector.copy(this.unitZ).applyQuaternion(le).dot(this.eye))>.9&&(V.visible=!1)),this.axis==="XYZE"&&(this.tempQuaternion.setFromEuler(this.tempEuler.set(0,Math.PI/2,0)),this.alignVector.copy(this.rotationAxis),V.quaternion.setFromRotationMatrix(this.lookAtMatrix.lookAt(this.zeroVector,this.alignVector,this.unitY)),V.quaternion.multiply(this.tempQuaternion),V.visible=this.dragging),this.axis==="E"&&(V.visible=!1)):V.name==="START"?(V.position.copy(this.worldPositionStart),V.visible=this.dragging):V.name==="END"?(V.position.copy(this.worldPosition),V.visible=this.dragging):V.name==="DELTA"?(V.position.copy(this.worldPositionStart),V.quaternion.copy(this.worldQuaternionStart),this.tempVector.set(1e-10,1e-10,1e-10).add(this.worldPositionStart).sub(this.worldPosition).multiplyScalar(-1),this.tempVector.applyQuaternion(this.worldQuaternionStart.clone().invert()),V.scale.copy(this.tempVector),V.visible=this.dragging):(V.quaternion.copy(le),this.dragging?V.position.copy(this.worldPositionStart):V.position.copy(this.worldPosition),this.axis&&(V.visible=this.axis.search(V.name)!==-1));continue}V.quaternion.copy(le),this.mode==="translate"||this.mode==="scale"?((V.name==="X"||V.name==="XYZX")&&Math.abs(this.alignVector.copy(this.unitX).applyQuaternion(le).dot(this.eye))>.99&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),(V.name==="Y"||V.name==="XYZY")&&Math.abs(this.alignVector.copy(this.unitY).applyQuaternion(le).dot(this.eye))>.99&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),(V.name==="Z"||V.name==="XYZZ")&&Math.abs(this.alignVector.copy(this.unitZ).applyQuaternion(le).dot(this.eye))>.99&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),V.name==="XY"&&Math.abs(this.alignVector.copy(this.unitZ).applyQuaternion(le).dot(this.eye))<.2&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),V.name==="YZ"&&Math.abs(this.alignVector.copy(this.unitX).applyQuaternion(le).dot(this.eye))<.2&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),V.name==="XZ"&&Math.abs(this.alignVector.copy(this.unitY).applyQuaternion(le).dot(this.eye))<.2&&(V.scale.set(1e-10,1e-10,1e-10),V.visible=!1),V.name.search("X")!==-1&&(this.alignVector.copy(this.unitX).applyQuaternion(le).dot(this.eye)<0?V.tag==="fwd"?V.visible=!1:V.scale.x*=-1:V.tag==="bwd"&&(V.visible=!1)),V.name.search("Y")!==-1&&(this.alignVector.copy(this.unitY).applyQuaternion(le).dot(this.eye)<0?V.tag==="fwd"?V.visible=!1:V.scale.y*=-1:V.tag==="bwd"&&(V.visible=!1)),V.name.search("Z")!==-1&&(this.alignVector.copy(this.unitZ).applyQuaternion(le).dot(this.eye)<0?V.tag==="fwd"?V.visible=!1:V.scale.z*=-1:V.tag==="bwd"&&(V.visible=!1))):this.mode==="rotate"&&(this.tempQuaternion2.copy(le),this.alignVector.copy(this.eye).applyQuaternion(this.tempQuaternion.copy(le).invert()),V.name.search("E")!==-1&&V.quaternion.setFromRotationMatrix(this.lookAtMatrix.lookAt(this.eye,this.zeroVector,this.unitY)),V.name==="X"&&(this.tempQuaternion.setFromAxisAngle(this.unitX,Math.atan2(-this.alignVector.y,this.alignVector.z)),this.tempQuaternion.multiplyQuaternions(this.tempQuaternion2,this.tempQuaternion),V.quaternion.copy(this.tempQuaternion)),V.name==="Y"&&(this.tempQuaternion.setFromAxisAngle(this.unitY,Math.atan2(this.alignVector.x,this.alignVector.z)),this.tempQuaternion.multiplyQuaternions(this.tempQuaternion2,this.tempQuaternion),V.quaternion.copy(this.tempQuaternion)),V.name==="Z"&&(this.tempQuaternion.setFromAxisAngle(this.unitZ,Math.atan2(this.alignVector.y,this.alignVector.x)),this.tempQuaternion.multiplyQuaternions(this.tempQuaternion2,this.tempQuaternion),V.quaternion.copy(this.tempQuaternion))),V.visible=V.visible&&(V.name.indexOf("X")===-1||this.showX),V.visible=V.visible&&(V.name.indexOf("Y")===-1||this.showY),V.visible=V.visible&&(V.name.indexOf("Z")===-1||this.showZ),V.visible=V.visible&&(V.name.indexOf("E")===-1||this.showX&&this.showY&&this.showZ),V.material.tempOpacity=V.material.tempOpacity||V.material.opacity,V.material.tempColor=V.material.tempColor||V.material.color.clone(),V.material.color.copy(V.material.tempColor),V.material.opacity=V.material.tempOpacity,this.enabled?this.axis&&(V.name===this.axis?(V.material.opacity=1,V.material.color.lerp(new f.Color(1,1,1),.5)):this.axis.split("").some(function(Ae){return V.name===Ae})?(V.material.opacity=1,V.material.color.lerp(new f.Color(1,1,1),.5)):(V.material.opacity*=.25,V.material.color.lerp(new f.Color(1,1,1),.5))):(V.material.opacity*=.5,V.material.color.lerp(new f.Color(1,1,1),.5))}super.updateMatrixWorld()});const i=new f.MeshBasicMaterial({depthTest:!1,depthWrite:!1,transparent:!0,side:f.DoubleSide,fog:!1,toneMapped:!1}),r=new f.LineBasicMaterial({depthTest:!1,depthWrite:!1,transparent:!0,linewidth:1,fog:!1,toneMapped:!1}),s=i.clone();s.opacity=.15;const a=i.clone();a.opacity=.33;const c=i.clone();c.color.set(16711680);const u=i.clone();u.color.set(65280);const h=i.clone();h.color.set(255);const d=i.clone();d.opacity=.25;const _=d.clone();_.color.set(16776960);const y=d.clone();y.color.set(65535);const w=d.clone();w.color.set(16711935),i.clone().color.set(16776960);const M=r.clone();M.color.set(16711680);const O=r.clone();O.color.set(65280);const I=r.clone();I.color.set(255);const E=r.clone();E.color.set(65535);const R=r.clone();R.color.set(16711935);const z=r.clone();z.color.set(16776960);const B=r.clone();B.color.set(7895160);const N=z.clone();N.opacity=.25;const Q=new f.CylinderGeometry(0,.05,.2,12,1,!1),$=new f.BoxGeometry(.125,.125,.125),j=new f.BufferGeometry;j.setAttribute("position",new f.Float32BufferAttribute([0,0,0,1,0,0],3));const F=(fe,le)=>{const ne=new f.BufferGeometry,be=[];for(let V=0;V<=64*le;++V)be.push(0,Math.cos(V/32*Math.PI)*fe,Math.sin(V/32*Math.PI)*fe);return ne.setAttribute("position",new f.Float32BufferAttribute(be,3)),ne},X=()=>{const fe=new f.BufferGeometry;return fe.setAttribute("position",new f.Float32BufferAttribute([0,0,0,1,1,1],3)),fe},Y={X:[[new f.Mesh(Q,c),[1,0,0],[0,0,-Math.PI/2],null,"fwd"],[new f.Mesh(Q,c),[1,0,0],[0,0,Math.PI/2],null,"bwd"],[new f.Line(j,M)]],Y:[[new f.Mesh(Q,u),[0,1,0],null,null,"fwd"],[new f.Mesh(Q,u),[0,1,0],[Math.PI,0,0],null,"bwd"],[new f.Line(j,O),null,[0,0,Math.PI/2]]],Z:[[new f.Mesh(Q,h),[0,0,1],[Math.PI/2,0,0],null,"fwd"],[new f.Mesh(Q,h),[0,0,1],[-Math.PI/2,0,0],null,"bwd"],[new f.Line(j,I),null,[0,-Math.PI/2,0]]],XYZ:[[new f.Mesh(new f.OctahedronGeometry(.1,0),d.clone()),[0,0,0],[0,0,0]]],XY:[[new f.Mesh(new f.PlaneGeometry(.295,.295),_.clone()),[.15,.15,0]],[new f.Line(j,z),[.18,.3,0],null,[.125,1,1]],[new f.Line(j,z),[.3,.18,0],[0,0,Math.PI/2],[.125,1,1]]],YZ:[[new f.Mesh(new f.PlaneGeometry(.295,.295),y.clone()),[0,.15,.15],[0,Math.PI/2,0]],[new f.Line(j,E),[0,.18,.3],[0,0,Math.PI/2],[.125,1,1]],[new f.Line(j,E),[0,.3,.18],[0,-Math.PI/2,0],[.125,1,1]]],XZ:[[new f.Mesh(new f.PlaneGeometry(.295,.295),w.clone()),[.15,0,.15],[-Math.PI/2,0,0]],[new f.Line(j,R),[.18,0,.3],null,[.125,1,1]],[new f.Line(j,R),[.3,0,.18],[0,-Math.PI/2,0],[.125,1,1]]]},Z={X:[[new f.Mesh(new f.CylinderGeometry(.2,0,1,4,1,!1),s),[.6,0,0],[0,0,-Math.PI/2]]],Y:[[new f.Mesh(new f.CylinderGeometry(.2,0,1,4,1,!1),s),[0,.6,0]]],Z:[[new f.Mesh(new f.CylinderGeometry(.2,0,1,4,1,!1),s),[0,0,.6],[Math.PI/2,0,0]]],XYZ:[[new f.Mesh(new f.OctahedronGeometry(.2,0),s)]],XY:[[new f.Mesh(new f.PlaneGeometry(.4,.4),s),[.2,.2,0]]],YZ:[[new f.Mesh(new f.PlaneGeometry(.4,.4),s),[0,.2,.2],[0,Math.PI/2,0]]],XZ:[[new f.Mesh(new f.PlaneGeometry(.4,.4),s),[.2,0,.2],[-Math.PI/2,0,0]]]},ue={START:[[new f.Mesh(new f.OctahedronGeometry(.01,2),a),null,null,null,"helper"]],END:[[new f.Mesh(new f.OctahedronGeometry(.01,2),a),null,null,null,"helper"]],DELTA:[[new f.Line(X(),a),null,null,null,"helper"]],X:[[new f.Line(j,a.clone()),[-1e3,0,0],null,[1e6,1,1],"helper"]],Y:[[new f.Line(j,a.clone()),[0,-1e3,0],[0,0,Math.PI/2],[1e6,1,1],"helper"]],Z:[[new f.Line(j,a.clone()),[0,0,-1e3],[0,-Math.PI/2,0],[1e6,1,1],"helper"]]},ge={X:[[new f.Line(F(1,.5),M)],[new f.Mesh(new f.OctahedronGeometry(.04,0),c),[0,0,.99],null,[1,3,1]]],Y:[[new f.Line(F(1,.5),O),null,[0,0,-Math.PI/2]],[new f.Mesh(new f.OctahedronGeometry(.04,0),u),[0,0,.99],null,[3,1,1]]],Z:[[new f.Line(F(1,.5),I),null,[0,Math.PI/2,0]],[new f.Mesh(new f.OctahedronGeometry(.04,0),h),[.99,0,0],null,[1,3,1]]],E:[[new f.Line(F(1.25,1),N),null,[0,Math.PI/2,0]],[new f.Mesh(new f.CylinderGeometry(.03,0,.15,4,1,!1),N),[1.17,0,0],[0,0,-Math.PI/2],[1,1,.001]],[new f.Mesh(new f.CylinderGeometry(.03,0,.15,4,1,!1),N),[-1.17,0,0],[0,0,Math.PI/2],[1,1,.001]],[new f.Mesh(new f.CylinderGeometry(.03,0,.15,4,1,!1),N),[0,-1.17,0],[Math.PI,0,0],[1,1,.001]],[new f.Mesh(new f.CylinderGeometry(.03,0,.15,4,1,!1),N),[0,1.17,0],[0,0,0],[1,1,.001]]],XYZE:[[new f.Line(F(1,1),B),null,[0,Math.PI/2,0]]]},pe={AXIS:[[new f.Line(j,a.clone()),[-1e3,0,0],null,[1e6,1,1],"helper"]]},me={X:[[new f.Mesh(new f.TorusGeometry(1,.1,4,24),s),[0,0,0],[0,-Math.PI/2,-Math.PI/2]]],Y:[[new f.Mesh(new f.TorusGeometry(1,.1,4,24),s),[0,0,0],[Math.PI/2,0,0]]],Z:[[new f.Mesh(new f.TorusGeometry(1,.1,4,24),s),[0,0,0],[0,0,-Math.PI/2]]],E:[[new f.Mesh(new f.TorusGeometry(1.25,.1,2,24),s)]],XYZE:[[new f.Mesh(new f.SphereGeometry(.7,10,8),s)]]},he={X:[[new f.Mesh($,c),[.8,0,0],[0,0,-Math.PI/2]],[new f.Line(j,M),null,null,[.8,1,1]]],Y:[[new f.Mesh($,u),[0,.8,0]],[new f.Line(j,O),null,[0,0,Math.PI/2],[.8,1,1]]],Z:[[new f.Mesh($,h),[0,0,.8],[Math.PI/2,0,0]],[new f.Line(j,I),null,[0,-Math.PI/2,0],[.8,1,1]]],XY:[[new f.Mesh($,_),[.85,.85,0],null,[2,2,.2]],[new f.Line(j,z),[.855,.98,0],null,[.125,1,1]],[new f.Line(j,z),[.98,.855,0],[0,0,Math.PI/2],[.125,1,1]]],YZ:[[new f.Mesh($,y),[0,.85,.85],null,[.2,2,2]],[new f.Line(j,E),[0,.855,.98],[0,0,Math.PI/2],[.125,1,1]],[new f.Line(j,E),[0,.98,.855],[0,-Math.PI/2,0],[.125,1,1]]],XZ:[[new f.Mesh($,w),[.85,0,.85],null,[2,.2,2]],[new f.Line(j,R),[.855,0,.98],null,[.125,1,1]],[new f.Line(j,R),[.98,0,.855],[0,-Math.PI/2,0],[.125,1,1]]],XYZX:[[new f.Mesh(new f.BoxGeometry(.125,.125,.125),d.clone()),[1.1,0,0]]],XYZY:[[new f.Mesh(new f.BoxGeometry(.125,.125,.125),d.clone()),[0,1.1,0]]],XYZZ:[[new f.Mesh(new f.BoxGeometry(.125,.125,.125),d.clone()),[0,0,1.1]]]},ee={X:[[new f.Mesh(new f.CylinderGeometry(.2,0,.8,4,1,!1),s),[.5,0,0],[0,0,-Math.PI/2]]],Y:[[new f.Mesh(new f.CylinderGeometry(.2,0,.8,4,1,!1),s),[0,.5,0]]],Z:[[new f.Mesh(new f.CylinderGeometry(.2,0,.8,4,1,!1),s),[0,0,.5],[Math.PI/2,0,0]]],XY:[[new f.Mesh($,s),[.85,.85,0],null,[3,3,.2]]],YZ:[[new f.Mesh($,s),[0,.85,.85],null,[.2,3,3]]],XZ:[[new f.Mesh($,s),[.85,0,.85],null,[3,.2,3]]],XYZX:[[new f.Mesh(new f.BoxGeometry(.2,.2,.2),s),[1.1,0,0]]],XYZY:[[new f.Mesh(new f.BoxGeometry(.2,.2,.2),s),[0,1.1,0]]],XYZZ:[[new f.Mesh(new f.BoxGeometry(.2,.2,.2),s),[0,0,1.1]]]},q={X:[[new f.Line(j,a.clone()),[-1e3,0,0],null,[1e6,1,1],"helper"]],Y:[[new f.Line(j,a.clone()),[0,-1e3,0],[0,0,Math.PI/2],[1e6,1,1],"helper"]],Z:[[new f.Line(j,a.clone()),[0,0,-1e3],[0,-Math.PI/2,0],[1e6,1,1],"helper"]]},Ce=fe=>{const le=new f.Object3D;for(let ne in fe)for(let be=fe[ne].length;be--;){const V=fe[ne][be][0].clone(),ce=fe[ne][be][1],Ae=fe[ne][be][2],De=fe[ne][be][3],we=fe[ne][be][4];V.name=ne,V.tag=we,ce&&V.position.set(ce[0],ce[1],ce[2]),Ae&&V.rotation.set(Ae[0],Ae[1],Ae[2]),De&&V.scale.set(De[0],De[1],De[2]),V.updateMatrix();const qe=V.geometry.clone();qe.applyMatrix4(V.matrix),V.geometry=qe,V.renderOrder=1/0,V.position.set(0,0,0),V.rotation.set(0,0,0),V.scale.set(1,1,1),le.add(V)}return le};this.gizmo={},this.picker={},this.helper={},this.add(this.gizmo.translate=Ce(Y)),this.add(this.gizmo.rotate=Ce(ge)),this.add(this.gizmo.scale=Ce(he)),this.add(this.picker.translate=Ce(Z)),this.add(this.picker.rotate=Ce(me)),this.add(this.picker.scale=Ce(ee)),this.add(this.helper.translate=Ce(ue)),this.add(this.helper.rotate=Ce(pe)),this.add(this.helper.scale=Ce(q)),this.picker.translate.visible=!1,this.picker.rotate.visible=!1,this.picker.scale.visible=!1}}class oa extends f.Mesh{constructor(){super(new f.PlaneGeometry(1e5,1e5,2,2),new f.MeshBasicMaterial({visible:!1,wireframe:!0,side:f.DoubleSide,transparent:!0,opacity:.1,toneMapped:!1})),S(this,"isTransformControlsPlane",!0),S(this,"type","TransformControlsPlane"),S(this,"unitX",new f.Vector3(1,0,0)),S(this,"unitY",new f.Vector3(0,1,0)),S(this,"unitZ",new f.Vector3(0,0,1)),S(this,"tempVector",new f.Vector3),S(this,"dirVector",new f.Vector3),S(this,"alignVector",new f.Vector3),S(this,"tempMatrix",new f.Matrix4),S(this,"identityQuaternion",new f.Quaternion),S(this,"cameraQuaternion",new f.Quaternion),S(this,"worldPosition",new f.Vector3),S(this,"worldQuaternion",new f.Quaternion),S(this,"eye",new f.Vector3),S(this,"axis",null),S(this,"mode","translate"),S(this,"space","world"),S(this,"updateMatrixWorld",()=>{let i=this.space;switch(this.position.copy(this.worldPosition),this.mode==="scale"&&(i="local"),this.unitX.set(1,0,0).applyQuaternion(i==="local"?this.worldQuaternion:this.identityQuaternion),this.unitY.set(0,1,0).applyQuaternion(i==="local"?this.worldQuaternion:this.identityQuaternion),this.unitZ.set(0,0,1).applyQuaternion(i==="local"?this.worldQuaternion:this.identityQuaternion),this.alignVector.copy(this.unitY),this.mode){case"translate":case"scale":switch(this.axis){case"X":this.alignVector.copy(this.eye).cross(this.unitX),this.dirVector.copy(this.unitX).cross(this.alignVector);break;case"Y":this.alignVector.copy(this.eye).cross(this.unitY),this.dirVector.copy(this.unitY).cross(this.alignVector);break;case"Z":this.alignVector.copy(this.eye).cross(this.unitZ),this.dirVector.copy(this.unitZ).cross(this.alignVector);break;case"XY":this.dirVector.copy(this.unitZ);break;case"YZ":this.dirVector.copy(this.unitX);break;case"XZ":this.alignVector.copy(this.unitZ),this.dirVector.copy(this.unitY);break;case"XYZ":case"E":this.dirVector.set(0,0,0);break}break;case"rotate":default:this.dirVector.set(0,0,0)}this.dirVector.length()===0?this.quaternion.copy(this.cameraQuaternion):(this.tempMatrix.lookAt(this.tempVector.set(0,0,0),this.dirVector,this.alignVector),this.quaternion.setFromRotationMatrix(this.tempMatrix)),super.updateMatrixWorld()})}}const Cr=(g,i)=>(g%i+i)%i;class aa extends f.EventDispatcher{constructor(i,r){super(),S(this,"object",void 0),S(this,"domElement",void 0),S(this,"enabled",!0),S(this,"target",new f.Vector3),S(this,"minDistance",0),S(this,"maxDistance",1/0),S(this,"minZoom",0),S(this,"maxZoom",1/0),S(this,"minPolarAngle",0),S(this,"maxPolarAngle",Math.PI),S(this,"minAzimuthAngle",-1/0),S(this,"maxAzimuthAngle",1/0),S(this,"enableDamping",!1),S(this,"dampingFactor",.05),S(this,"enableZoom",!0),S(this,"zoomSpeed",1),S(this,"enableRotate",!0),S(this,"rotateSpeed",1),S(this,"enablePan",!0),S(this,"panSpeed",1),S(this,"screenSpacePanning",!0),S(this,"keyPanSpeed",7),S(this,"autoRotate",!1),S(this,"autoRotateSpeed",2),S(this,"reverseOrbit",!1),S(this,"keys",{LEFT:"ArrowLeft",UP:"ArrowUp",RIGHT:"ArrowRight",BOTTOM:"ArrowDown"}),S(this,"mouseButtons",{LEFT:f.MOUSE.ROTATE,MIDDLE:f.MOUSE.DOLLY,RIGHT:f.MOUSE.PAN}),S(this,"touches",{ONE:f.TOUCH.ROTATE,TWO:f.TOUCH.DOLLY_PAN}),S(this,"target0",void 0),S(this,"position0",void 0),S(this,"zoom0",void 0),S(this,"_domElementKeyEvents",null),S(this,"getPolarAngle",void 0),S(this,"getAzimuthalAngle",void 0),S(this,"setPolarAngle",void 0),S(this,"setAzimuthalAngle",void 0),S(this,"getDistance",void 0),S(this,"listenToKeyEvents",void 0),S(this,"saveState",void 0),S(this,"reset",void 0),S(this,"update",void 0),S(this,"connect",void 0),S(this,"dispose",void 0),this.object=i,this.domElement=r,this.target0=this.target.clone(),this.position0=this.object.position.clone(),this.zoom0=this.object instanceof f.PerspectiveCamera?this.object.zoom:1,this.getPolarAngle=()=>y.phi,this.getAzimuthalAngle=()=>y.theta,this.setPolarAngle=D=>{let K=Cr(D,2*Math.PI),J=y.phi;J<0&&(J+=2*Math.PI),K<0&&(K+=2*Math.PI);let ie=Math.abs(K-J);2*Math.PI-ie<ie&&(K<J?K+=2*Math.PI:J+=2*Math.PI),w.phi=K-J,s.update()},this.setAzimuthalAngle=D=>{let K=Cr(D,2*Math.PI),J=y.theta;J<0&&(J+=2*Math.PI),K<0&&(K+=2*Math.PI);let ie=Math.abs(K-J);2*Math.PI-ie<ie&&(K<J?K+=2*Math.PI:J+=2*Math.PI),w.theta=K-J,s.update()},this.getDistance=()=>s.object.position.distanceTo(s.target),this.listenToKeyEvents=D=>{D.addEventListener("keydown",at),this._domElementKeyEvents=D},this.saveState=()=>{s.target0.copy(s.target),s.position0.copy(s.object.position),s.zoom0=s.object instanceof f.PerspectiveCamera?s.object.zoom:1},this.reset=()=>{s.target.copy(s.target0),s.object.position.copy(s.position0),s.object instanceof f.PerspectiveCamera&&(s.object.zoom=s.zoom0,s.object.updateProjectionMatrix()),s.dispatchEvent(a),s.update(),d=h.NONE},this.update=(()=>{const D=new f.Vector3,K=new f.Quaternion().setFromUnitVectors(i.up,new f.Vector3(0,1,0)),J=K.clone().invert(),ie=new f.Vector3,ye=new f.Quaternion,Ve=2*Math.PI;return function(){const qt=s.object.position;D.copy(qt).sub(s.target),D.applyQuaternion(K),y.setFromVector3(D),s.autoRotate&&d===h.NONE&&ue(Y()),s.enableDamping?(y.theta+=w.theta*s.dampingFactor,y.phi+=w.phi*s.dampingFactor):(y.theta+=w.theta,y.phi+=w.phi);let Oe=s.minAzimuthAngle,Be=s.maxAzimuthAngle;return isFinite(Oe)&&isFinite(Be)&&(Oe<-Math.PI?Oe+=Ve:Oe>Math.PI&&(Oe-=Ve),Be<-Math.PI?Be+=Ve:Be>Math.PI&&(Be-=Ve),Oe<=Be?y.theta=Math.max(Oe,Math.min(Be,y.theta)):y.theta=y.theta>(Oe+Be)/2?Math.max(Oe,y.theta):Math.min(Be,y.theta)),y.phi=Math.max(s.minPolarAngle,Math.min(s.maxPolarAngle,y.phi)),y.makeSafe(),y.radius*=x,y.radius=Math.max(s.minDistance,Math.min(s.maxDistance,y.radius)),s.enableDamping===!0?s.target.addScaledVector(M,s.dampingFactor):s.target.add(M),D.setFromSpherical(y),D.applyQuaternion(J),qt.copy(s.target).add(D),s.object.lookAt(s.target),s.enableDamping===!0?(w.theta*=1-s.dampingFactor,w.phi*=1-s.dampingFactor,M.multiplyScalar(1-s.dampingFactor)):(w.set(0,0,0),M.set(0,0,0)),x=1,O||ie.distanceToSquared(s.object.position)>_||8*(1-ye.dot(s.object.quaternion))>_?(s.dispatchEvent(a),ie.copy(s.object.position),ye.copy(s.object.quaternion),O=!1,!0):!1}})(),this.connect=D=>{D===document&&console.error('THREE.OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.'),s.domElement=D,s.domElement.style.touchAction="none",s.domElement.addEventListener("contextmenu",Yt),s.domElement.addEventListener("pointerdown",Qe),s.domElement.addEventListener("pointercancel",bn),s.domElement.addEventListener("wheel",_n)},this.dispose=()=>{var D,K,J,ie,ye,Ve;(D=s.domElement)===null||D===void 0||D.removeEventListener("contextmenu",Yt),(K=s.domElement)===null||K===void 0||K.removeEventListener("pointerdown",Qe),(J=s.domElement)===null||J===void 0||J.removeEventListener("pointercancel",bn),(ie=s.domElement)===null||ie===void 0||ie.removeEventListener("wheel",_n),(ye=s.domElement)===null||ye===void 0||ye.ownerDocument.removeEventListener("pointermove",Xt),(Ve=s.domElement)===null||Ve===void 0||Ve.ownerDocument.removeEventListener("pointerup",it),s._domElementKeyEvents!==null&&s._domElementKeyEvents.removeEventListener("keydown",at)};const s=this,a={type:"change"},c={type:"start"},u={type:"end"},h={NONE:-1,ROTATE:0,DOLLY:1,PAN:2,TOUCH_ROTATE:3,TOUCH_PAN:4,TOUCH_DOLLY_PAN:5,TOUCH_DOLLY_ROTATE:6};let d=h.NONE;const _=1e-6,y=new f.Spherical,w=new f.Spherical;let x=1;const M=new f.Vector3;let O=!1;const I=new f.Vector2,E=new f.Vector2,R=new f.Vector2,z=new f.Vector2,B=new f.Vector2,N=new f.Vector2,Q=new f.Vector2,$=new f.Vector2,j=new f.Vector2,F=[],X={};function Y(){return 2*Math.PI/60/60*s.autoRotateSpeed}function Z(){return Math.pow(.95,s.zoomSpeed)}function ue(D){s.reverseOrbit?w.theta+=D:w.theta-=D}function ge(D){s.reverseOrbit?w.phi+=D:w.phi-=D}const pe=(()=>{const D=new f.Vector3;return function(J,ie){D.setFromMatrixColumn(ie,0),D.multiplyScalar(-J),M.add(D)}})(),me=(()=>{const D=new f.Vector3;return function(J,ie){s.screenSpacePanning===!0?D.setFromMatrixColumn(ie,1):(D.setFromMatrixColumn(ie,0),D.crossVectors(s.object.up,D)),D.multiplyScalar(J),M.add(D)}})(),he=(()=>{const D=new f.Vector3;return function(J,ie){const ye=s.domElement;if(ye&&s.object instanceof f.PerspectiveCamera&&s.object.isPerspectiveCamera){const Ve=s.object.position;D.copy(Ve).sub(s.target);let St=D.length();St*=Math.tan(s.object.fov/2*Math.PI/180),pe(2*J*St/ye.clientHeight,s.object.matrix),me(2*ie*St/ye.clientHeight,s.object.matrix)}else ye&&s.object instanceof f.OrthographicCamera&&s.object.isOrthographicCamera?(pe(J*(s.object.right-s.object.left)/s.object.zoom/ye.clientWidth,s.object.matrix),me(ie*(s.object.top-s.object.bottom)/s.object.zoom/ye.clientHeight,s.object.matrix)):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."),s.enablePan=!1)}})();function ee(D){s.object instanceof f.PerspectiveCamera&&s.object.isPerspectiveCamera?x/=D:s.object instanceof f.OrthographicCamera&&s.object.isOrthographicCamera?(s.object.zoom=Math.max(s.minZoom,Math.min(s.maxZoom,s.object.zoom*D)),s.object.updateProjectionMatrix(),O=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),s.enableZoom=!1)}function q(D){s.object instanceof f.PerspectiveCamera&&s.object.isPerspectiveCamera?x*=D:s.object instanceof f.OrthographicCamera&&s.object.isOrthographicCamera?(s.object.zoom=Math.max(s.minZoom,Math.min(s.maxZoom,s.object.zoom/D)),s.object.updateProjectionMatrix(),O=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),s.enableZoom=!1)}function Ce(D){I.set(D.clientX,D.clientY)}function fe(D){Q.set(D.clientX,D.clientY)}function le(D){z.set(D.clientX,D.clientY)}function ne(D){E.set(D.clientX,D.clientY),R.subVectors(E,I).multiplyScalar(s.rotateSpeed);const K=s.domElement;K&&(ue(2*Math.PI*R.x/K.clientHeight),ge(2*Math.PI*R.y/K.clientHeight)),I.copy(E),s.update()}function be(D){$.set(D.clientX,D.clientY),j.subVectors($,Q),j.y>0?ee(Z()):j.y<0&&q(Z()),Q.copy($),s.update()}function V(D){B.set(D.clientX,D.clientY),N.subVectors(B,z).multiplyScalar(s.panSpeed),he(N.x,N.y),z.copy(B),s.update()}function ce(D){D.deltaY<0?q(Z()):D.deltaY>0&&ee(Z()),s.update()}function Ae(D){let K=!1;switch(D.code){case s.keys.UP:he(0,s.keyPanSpeed),K=!0;break;case s.keys.BOTTOM:he(0,-s.keyPanSpeed),K=!0;break;case s.keys.LEFT:he(s.keyPanSpeed,0),K=!0;break;case s.keys.RIGHT:he(-s.keyPanSpeed,0),K=!0;break}K&&(D.preventDefault(),s.update())}function De(){if(F.length==1)I.set(F[0].pageX,F[0].pageY);else{const D=.5*(F[0].pageX+F[1].pageX),K=.5*(F[0].pageY+F[1].pageY);I.set(D,K)}}function we(){if(F.length==1)z.set(F[0].pageX,F[0].pageY);else{const D=.5*(F[0].pageX+F[1].pageX),K=.5*(F[0].pageY+F[1].pageY);z.set(D,K)}}function qe(){const D=F[0].pageX-F[1].pageX,K=F[0].pageY-F[1].pageY,J=Math.sqrt(D*D+K*K);Q.set(0,J)}function fn(){s.enableZoom&&qe(),s.enablePan&&we()}function ze(){s.enableZoom&&qe(),s.enableRotate&&De()}function vn(D){if(F.length==1)E.set(D.pageX,D.pageY);else{const J=ft(D),ie=.5*(D.pageX+J.x),ye=.5*(D.pageY+J.y);E.set(ie,ye)}R.subVectors(E,I).multiplyScalar(s.rotateSpeed);const K=s.domElement;K&&(ue(2*Math.PI*R.x/K.clientHeight),ge(2*Math.PI*R.y/K.clientHeight)),I.copy(E)}function $t(D){if(F.length==1)B.set(D.pageX,D.pageY);else{const K=ft(D),J=.5*(D.pageX+K.x),ie=.5*(D.pageY+K.y);B.set(J,ie)}N.subVectors(B,z).multiplyScalar(s.panSpeed),he(N.x,N.y),z.copy(B)}function nt(D){const K=ft(D),J=D.pageX-K.x,ie=D.pageY-K.y,ye=Math.sqrt(J*J+ie*ie);$.set(0,ye),j.set(0,Math.pow($.y/Q.y,s.zoomSpeed)),ee(j.y),Q.copy($)}function dt(D){s.enableZoom&&nt(D),s.enablePan&&$t(D)}function Ee(D){s.enableZoom&&nt(D),s.enableRotate&&vn(D)}function Qe(D){if(s.enabled!==!1){if(F.length===0){var K,J;(K=s.domElement)===null||K===void 0||K.ownerDocument.addEventListener("pointermove",Xt),(J=s.domElement)===null||J===void 0||J.ownerDocument.addEventListener("pointerup",it)}yn(D),D.pointerType==="touch"?mt(D):Kn(D)}}function Xt(D){s.enabled!==!1&&(D.pointerType==="touch"?wn(D):gn(D))}function it(D){if(lt(D),F.length===0){var K,J,ie;(K=s.domElement)===null||K===void 0||K.releasePointerCapture(D.pointerId),(J=s.domElement)===null||J===void 0||J.ownerDocument.removeEventListener("pointermove",Xt),(ie=s.domElement)===null||ie===void 0||ie.ownerDocument.removeEventListener("pointerup",it)}s.dispatchEvent(u),d=h.NONE}function bn(D){lt(D)}function Kn(D){let K;switch(D.button){case 0:K=s.mouseButtons.LEFT;break;case 1:K=s.mouseButtons.MIDDLE;break;case 2:K=s.mouseButtons.RIGHT;break;default:K=-1}switch(K){case f.MOUSE.DOLLY:if(s.enableZoom===!1)return;fe(D),d=h.DOLLY;break;case f.MOUSE.ROTATE:if(D.ctrlKey||D.metaKey||D.shiftKey){if(s.enablePan===!1)return;le(D),d=h.PAN}else{if(s.enableRotate===!1)return;Ce(D),d=h.ROTATE}break;case f.MOUSE.PAN:if(D.ctrlKey||D.metaKey||D.shiftKey){if(s.enableRotate===!1)return;Ce(D),d=h.ROTATE}else{if(s.enablePan===!1)return;le(D),d=h.PAN}break;default:d=h.NONE}d!==h.NONE&&s.dispatchEvent(c)}function gn(D){if(s.enabled!==!1)switch(d){case h.ROTATE:if(s.enableRotate===!1)return;ne(D);break;case h.DOLLY:if(s.enableZoom===!1)return;be(D);break;case h.PAN:if(s.enablePan===!1)return;V(D);break}}function _n(D){s.enabled===!1||s.enableZoom===!1||d!==h.NONE&&d!==h.ROTATE||(D.preventDefault(),s.dispatchEvent(c),ce(D),s.dispatchEvent(u))}function at(D){s.enabled===!1||s.enablePan===!1||Ae(D)}function mt(D){switch(st(D),F.length){case 1:switch(s.touches.ONE){case f.TOUCH.ROTATE:if(s.enableRotate===!1)return;De(),d=h.TOUCH_ROTATE;break;case f.TOUCH.PAN:if(s.enablePan===!1)return;we(),d=h.TOUCH_PAN;break;default:d=h.NONE}break;case 2:switch(s.touches.TWO){case f.TOUCH.DOLLY_PAN:if(s.enableZoom===!1&&s.enablePan===!1)return;fn(),d=h.TOUCH_DOLLY_PAN;break;case f.TOUCH.DOLLY_ROTATE:if(s.enableZoom===!1&&s.enableRotate===!1)return;ze(),d=h.TOUCH_DOLLY_ROTATE;break;default:d=h.NONE}break;default:d=h.NONE}d!==h.NONE&&s.dispatchEvent(c)}function wn(D){switch(st(D),d){case h.TOUCH_ROTATE:if(s.enableRotate===!1)return;vn(D),s.update();break;case h.TOUCH_PAN:if(s.enablePan===!1)return;$t(D),s.update();break;case h.TOUCH_DOLLY_PAN:if(s.enableZoom===!1&&s.enablePan===!1)return;dt(D),s.update();break;case h.TOUCH_DOLLY_ROTATE:if(s.enableZoom===!1&&s.enableRotate===!1)return;Ee(D),s.update();break;default:d=h.NONE}}function Yt(D){s.enabled!==!1&&D.preventDefault()}function yn(D){F.push(D)}function lt(D){delete X[D.pointerId];for(let K=0;K<F.length;K++)if(F[K].pointerId==D.pointerId){F.splice(K,1);return}}function st(D){let K=X[D.pointerId];K===void 0&&(K=new f.Vector2,X[D.pointerId]=K),K.set(D.pageX,D.pageY)}function ft(D){const K=D.pointerId===F[0].pointerId?F[1]:F[0];return X[K.pointerId]}r!==void 0&&this.connect(r),this.update()}}class la extends f.Loader{constructor(i){super(i),this.dracoLoader=null,this.ktx2Loader=null,this.meshoptDecoder=null,this.pluginCallbacks=[],this.register(function(r){return new da(r)}),this.register(function(r){return new wa(r)}),this.register(function(r){return new ya(r)}),this.register(function(r){return new fa(r)}),this.register(function(r){return new va(r)}),this.register(function(r){return new ba(r)}),this.register(function(r){return new ga(r)}),this.register(function(r){return new ha(r)}),this.register(function(r){return new _a(r)}),this.register(function(r){return new ma(r)}),this.register(function(r){return new pa(r)}),this.register(function(r){return new xa(r)})}load(i,r,s,a){const c=this;let u;this.resourcePath!==""?u=this.resourcePath:this.path!==""?u=this.path:u=f.LoaderUtils.extractUrlBase(i),this.manager.itemStart(i);const h=function(_){a?a(_):console.error(_),c.manager.itemError(i),c.manager.itemEnd(i)},d=new f.FileLoader(this.manager);d.setPath(this.path),d.setResponseType("arraybuffer"),d.setRequestHeader(this.requestHeader),d.setWithCredentials(this.withCredentials),d.load(i,function(_){try{c.parse(_,u,function(y){r(y),c.manager.itemEnd(i)},h)}catch(y){h(y)}},s,h)}setDRACOLoader(i){return this.dracoLoader=i,this}setDDSLoader(){throw new Error('THREE.GLTFLoader: "MSFT_texture_dds" no longer supported. Please update to "KHR_texture_basisu".')}setKTX2Loader(i){return this.ktx2Loader=i,this}setMeshoptDecoder(i){return this.meshoptDecoder=i,this}register(i){return this.pluginCallbacks.indexOf(i)===-1&&this.pluginCallbacks.push(i),this}unregister(i){return this.pluginCallbacks.indexOf(i)!==-1&&this.pluginCallbacks.splice(this.pluginCallbacks.indexOf(i),1),this}parse(i,r,s,a){let c;const u={},h={};if(typeof i=="string")c=i;else if(f.LoaderUtils.decodeText(new Uint8Array(i,0,4))===Pr){try{u[se.KHR_BINARY_GLTF]=new Ca(i)}catch(w){a&&a(w);return}c=u[se.KHR_BINARY_GLTF].content}else c=f.LoaderUtils.decodeText(new Uint8Array(i));const d=JSON.parse(c);if(d.asset===void 0||d.asset.version[0]<2){a&&a(new Error("THREE.GLTFLoader: Unsupported asset. glTF versions >=2.0 are supported."));return}const _=new Ba(d,{path:r||this.resourcePath||"",crossOrigin:this.crossOrigin,requestHeader:this.requestHeader,manager:this.manager,ktx2Loader:this.ktx2Loader,meshoptDecoder:this.meshoptDecoder});_.fileLoader.setRequestHeader(this.requestHeader);for(let y=0;y<this.pluginCallbacks.length;y++){const w=this.pluginCallbacks[y](_);h[w.name]=w,u[w.name]=!0}if(d.extensionsUsed)for(let y=0;y<d.extensionsUsed.length;++y){const w=d.extensionsUsed[y],x=d.extensionsRequired||[];switch(w){case se.KHR_MATERIALS_UNLIT:u[w]=new ua;break;case se.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS:u[w]=new ka;break;case se.KHR_DRACO_MESH_COMPRESSION:u[w]=new Pa(d,this.dracoLoader);break;case se.KHR_TEXTURE_TRANSFORM:u[w]=new Ma;break;case se.KHR_MESH_QUANTIZATION:u[w]=new Sa;break;default:x.indexOf(w)>=0&&h[w]===void 0&&console.warn('THREE.GLTFLoader: Unknown extension "'+w+'".')}}_.setExtensions(u),_.setPlugins(h),_.parse(s,a)}parseAsync(i,r){const s=this;return new Promise(function(a,c){s.parse(i,r,a,c)})}}function ca(){let g={};return{get:function(i){return g[i]},add:function(i,r){g[i]=r},remove:function(i){delete g[i]},removeAll:function(){g={}}}}const se={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_PBR_SPECULAR_GLOSSINESS:"KHR_materials_pbrSpecularGlossiness",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_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_MESHOPT_COMPRESSION:"EXT_meshopt_compression"};class pa{constructor(i){this.parser=i,this.name=se.KHR_LIGHTS_PUNCTUAL,this.cache={refs:{},uses:{}}}_markDefs(){const i=this.parser,r=this.parser.json.nodes||[];for(let s=0,a=r.length;s<a;s++){const c=r[s];c.extensions&&c.extensions[this.name]&&c.extensions[this.name].light!==void 0&&i._addNodeRef(this.cache,c.extensions[this.name].light)}}_loadLight(i){const r=this.parser,s="light:"+i;let a=r.cache.get(s);if(a)return a;const c=r.json,d=((c.extensions&&c.extensions[this.name]||{}).lights||[])[i];let _;const y=new f.Color(16777215);d.color!==void 0&&y.fromArray(d.color);const w=d.range!==void 0?d.range:0;switch(d.type){case"directional":_=new f.DirectionalLight(y),_.target.position.set(0,0,-1),_.add(_.target);break;case"point":_=new f.PointLight(y),_.distance=w;break;case"spot":_=new f.SpotLight(y),_.distance=w,d.spot=d.spot||{},d.spot.innerConeAngle=d.spot.innerConeAngle!==void 0?d.spot.innerConeAngle:0,d.spot.outerConeAngle=d.spot.outerConeAngle!==void 0?d.spot.outerConeAngle:Math.PI/4,_.angle=d.spot.outerConeAngle,_.penumbra=1-d.spot.innerConeAngle/d.spot.outerConeAngle,_.target.position.set(0,0,-1),_.add(_.target);break;default:throw new Error("THREE.GLTFLoader: Unexpected light type: "+d.type)}return _.position.set(0,0,0),_.decay=2,d.intensity!==void 0&&(_.intensity=d.intensity),_.name=r.createUniqueName(d.name||"light_"+i),a=Promise.resolve(_),r.cache.add(s,a),a}createNodeAttachment(i){const r=this,s=this.parser,c=s.json.nodes[i],h=(c.extensions&&c.extensions[this.name]||{}).light;return h===void 0?null:this._loadLight(h).then(function(d){return s._getNodeRef(r.cache,h,d)})}}class ua{constructor(){this.name=se.KHR_MATERIALS_UNLIT}getMaterialType(){return f.MeshBasicMaterial}extendParams(i,r,s){const a=[];i.color=new f.Color(1,1,1),i.opacity=1;const c=r.pbrMetallicRoughness;if(c){if(Array.isArray(c.baseColorFactor)){const u=c.baseColorFactor;i.color.fromArray(u),i.opacity=u[3]}c.baseColorTexture!==void 0&&a.push(s.assignTexture(i,"map",c.baseColorTexture,f.sRGBEncoding))}return Promise.all(a)}}class ha{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_EMISSIVE_STRENGTH}extendMaterialParams(i,r){const a=this.parser.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=a.extensions[this.name].emissiveStrength;return c!==void 0&&(r.emissiveIntensity=c),Promise.resolve()}}class da{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_CLEARCOAT}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[],u=a.extensions[this.name];if(u.clearcoatFactor!==void 0&&(r.clearcoat=u.clearcoatFactor),u.clearcoatTexture!==void 0&&c.push(s.assignTexture(r,"clearcoatMap",u.clearcoatTexture)),u.clearcoatRoughnessFactor!==void 0&&(r.clearcoatRoughness=u.clearcoatRoughnessFactor),u.clearcoatRoughnessTexture!==void 0&&c.push(s.assignTexture(r,"clearcoatRoughnessMap",u.clearcoatRoughnessTexture)),u.clearcoatNormalTexture!==void 0&&(c.push(s.assignTexture(r,"clearcoatNormalMap",u.clearcoatNormalTexture)),u.clearcoatNormalTexture.scale!==void 0)){const h=u.clearcoatNormalTexture.scale;r.clearcoatNormalScale=new f.Vector2(h,h)}return Promise.all(c)}}class ma{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_IRIDESCENCE}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[],u=a.extensions[this.name];return u.iridescenceFactor!==void 0&&(r.iridescence=u.iridescenceFactor),u.iridescenceTexture!==void 0&&c.push(s.assignTexture(r,"iridescenceMap",u.iridescenceTexture)),u.iridescenceIor!==void 0&&(r.iridescenceIOR=u.iridescenceIor),r.iridescenceThicknessRange===void 0&&(r.iridescenceThicknessRange=[100,400]),u.iridescenceThicknessMinimum!==void 0&&(r.iridescenceThicknessRange[0]=u.iridescenceThicknessMinimum),u.iridescenceThicknessMaximum!==void 0&&(r.iridescenceThicknessRange[1]=u.iridescenceThicknessMaximum),u.iridescenceThicknessTexture!==void 0&&c.push(s.assignTexture(r,"iridescenceThicknessMap",u.iridescenceThicknessTexture)),Promise.all(c)}}class fa{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_SHEEN}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[];r.sheenColor=new f.Color(0,0,0),r.sheenRoughness=0,r.sheen=1;const u=a.extensions[this.name];return u.sheenColorFactor!==void 0&&r.sheenColor.fromArray(u.sheenColorFactor),u.sheenRoughnessFactor!==void 0&&(r.sheenRoughness=u.sheenRoughnessFactor),u.sheenColorTexture!==void 0&&c.push(s.assignTexture(r,"sheenColorMap",u.sheenColorTexture,f.sRGBEncoding)),u.sheenRoughnessTexture!==void 0&&c.push(s.assignTexture(r,"sheenRoughnessMap",u.sheenRoughnessTexture)),Promise.all(c)}}class va{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_TRANSMISSION}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[],u=a.extensions[this.name];return u.transmissionFactor!==void 0&&(r.transmission=u.transmissionFactor),u.transmissionTexture!==void 0&&c.push(s.assignTexture(r,"transmissionMap",u.transmissionTexture)),Promise.all(c)}}class ba{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_VOLUME}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[],u=a.extensions[this.name];r.thickness=u.thicknessFactor!==void 0?u.thicknessFactor:0,u.thicknessTexture!==void 0&&c.push(s.assignTexture(r,"thicknessMap",u.thicknessTexture)),r.attenuationDistance=u.attenuationDistance||1/0;const h=u.attenuationColor||[1,1,1];return r.attenuationColor=new f.Color(h[0],h[1],h[2]),Promise.all(c)}}class ga{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_IOR}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const a=this.parser.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=a.extensions[this.name];return r.ior=c.ior!==void 0?c.ior:1.5,Promise.resolve()}}class _a{constructor(i){this.parser=i,this.name=se.KHR_MATERIALS_SPECULAR}getMaterialType(i){const s=this.parser.json.materials[i];return!s.extensions||!s.extensions[this.name]?null:f.MeshPhysicalMaterial}extendMaterialParams(i,r){const s=this.parser,a=s.json.materials[i];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const c=[],u=a.extensions[this.name];r.specularIntensity=u.specularFactor!==void 0?u.specularFactor:1,u.specularTexture!==void 0&&c.push(s.assignTexture(r,"specularIntensityMap",u.specularTexture));const h=u.specularColorFactor||[1,1,1];return r.specularColor=new f.Color(h[0],h[1],h[2]),u.specularColorTexture!==void 0&&c.push(s.assignTexture(r,"specularColorMap",u.specularColorTexture,f.sRGBEncoding)),Promise.all(c)}}class wa{constructor(i){this.parser=i,this.name=se.KHR_TEXTURE_BASISU}loadTexture(i){const r=this.parser,s=r.json,a=s.textures[i];if(!a.extensions||!a.extensions[this.name])return null;const c=a.extensions[this.name],u=r.options.ktx2Loader;if(!u){if(s.extensionsRequired&&s.extensionsRequired.indexOf(this.name)>=0)throw new Error("THREE.GLTFLoader: setKTX2Loader must be called before loading KTX2 textures");return null}return r.loadTextureImage(i,c.source,u)}}class ya{constructor(i){this.parser=i,this.name=se.EXT_TEXTURE_WEBP,this.isSupported=null}loadTexture(i){const r=this.name,s=this.parser,a=s.json,c=a.textures[i];if(!c.extensions||!c.extensions[r])return null;const u=c.extensions[r],h=a.images[u.source];let d=s.textureLoader;if(h.uri){const _=s.options.manager.getHandler(h.uri);_!==null&&(d=_)}return this.detectSupport().then(function(_){if(_)return s.loadTextureImage(i,u.source,d);if(a.extensionsRequired&&a.extensionsRequired.indexOf(r)>=0)throw new Error("THREE.GLTFLoader: WebP required by asset but unsupported.");return s.loadTexture(i)})}detectSupport(){return this.isSupported||(this.isSupported=new Promise(function(i){const r=new Image;r.src="data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA",r.onload=r.onerror=function(){i(r.height===1)}})),this.isSupported}}class xa{constructor(i){this.name=se.EXT_MESHOPT_COMPRESSION,this.parser=i}loadBufferView(i){const r=this.parser.json,s=r.bufferViews[i];if(s.extensions&&s.extensions[this.name]){const a=s.extensions[this.name],c=this.parser.getDependency("buffer",a.buffer),u=this.parser.options.meshoptDecoder;if(!u||!u.supported){if(r.extensionsRequired&&r.extensionsRequired.indexOf(this.name)>=0)throw new Error("THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files");return null}return c.then(function(h){const d=a.byteOffset||0,_=a.byteLength||0,y=a.count,w=a.byteStride,x=new Uint8Array(h,d,_);return u.decodeGltfBufferAsync?u.decodeGltfBufferAsync(y,w,x,a.mode,a.filter).then(function(M){return M.buffer}):u.ready.then(function(){const M=new ArrayBuffer(y*w);return u.decodeGltfBuffer(new Uint8Array(M),y,w,x,a.mode,a.filter),M})})}else return null}}const Pr="glTF",zn=12,Mr={JSON:1313821514,BIN:5130562};class Ca{constructor(i){this.name=se.KHR_BINARY_GLTF,this.content=null,this.body=null;const r=new DataView(i,0,zn);if(this.header={magic:f.LoaderUtils.decodeText(new Uint8Array(i.slice(0,4))),version:r.getUint32(4,!0),length:r.getUint32(8,!0)},this.header.magic!==Pr)throw new Error("THREE.GLTFLoader: Unsupported glTF-Binary header.");if(this.header.version<2)throw new Error("THREE.GLTFLoader: Legacy binary file detected.");const s=this.header.length-zn,a=new DataView(i,zn);let c=0;for(;c<s;){const u=a.getUint32(c,!0);c+=4;const h=a.getUint32(c,!0);if(c+=4,h===Mr.JSON){const d=new Uint8Array(i,zn+c,u);this.content=f.LoaderUtils.decodeText(d)}else if(h===Mr.BIN){const d=zn+c;this.body=i.slice(d,d+u)}c+=u}if(this.content===null)throw new Error("THREE.GLTFLoader: JSON content not found.")}}class Pa{constructor(i,r){if(!r)throw new Error("THREE.GLTFLoader: No DRACOLoader instance provided.");this.name=se.KHR_DRACO_MESH_COMPRESSION,this.json=i,this.dracoLoader=r,this.dracoLoader.preload()}decodePrimitive(i,r){const s=this.json,a=this.dracoLoader,c=i.extensions[this.name].bufferView,u=i.extensions[this.name].attributes,h={},d={},_={};for(const y in u){const w=os[y]||y.toLowerCase();h[w]=u[y]}for(const y in i.attributes){const w=os[y]||y.toLowerCase();if(u[y]!==void 0){const x=s.accessors[i.attributes[y]],M=Un[x.componentType];_[w]=M.name,d[w]=x.normalized===!0}}return r.getDependency("bufferView",c).then(function(y){return new Promise(function(w){a.decodeDracoFile(y,function(x){for(const M in x.attributes){const O=x.attributes[M],I=d[M];I!==void 0&&(O.normalized=I)}w(x)},h,_)})})}}class Ma{constructor(){this.name=se.KHR_TEXTURE_TRANSFORM}extendTexture(i,r){return r.texCoord!==void 0&&console.warn('THREE.GLTFLoader: Custom UV sets in "'+this.name+'" extension not yet supported.'),r.offset===void 0&&r.rotation===void 0&&r.scale===void 0||(i=i.clone(),r.offset!==void 0&&i.offset.fromArray(r.offset),r.rotation!==void 0&&(i.rotation=r.rotation),r.scale!==void 0&&i.repeat.fromArray(r.scale),i.needsUpdate=!0),i}}class rs extends f.MeshStandardMaterial{constructor(i){super(),this.isGLTFSpecularGlossinessMaterial=!0;const r=["#ifdef USE_SPECULARMAP"," uniform sampler2D specularMap;","#endif"].join(`
9
9
  `),s=["#ifdef USE_GLOSSINESSMAP"," uniform sampler2D glossinessMap;","#endif"].join(`
10
10
  `),a=["vec3 specularFactor = specular;","#ifdef USE_SPECULARMAP"," vec4 texelSpecular = texture2D( specularMap, vUv );"," // reads channel RGB, compatible with a glTF Specular-Glossiness (RGBA) texture"," specularFactor *= texelSpecular.rgb;","#endif"].join(`
11
11
  `),c=["float glossinessFactor = glossiness;","#ifdef USE_GLOSSINESSMAP"," vec4 texelGlossiness = texture2D( glossinessMap, vUv );"," // reads channel A, compatible with a glTF Specular-Glossiness (RGBA) texture"," glossinessFactor *= texelGlossiness.a;","#endif"].join(`
@@ -16,7 +16,7 @@
16
16
  `;Y=x(B),Y!==!1;){if(X.string+=Y+`
17
17
  `,Y.charAt(0)==="#"){X.comments+=Y+`
18
18
  `;continue}if((Z=Y.match(Q))&&(X.gamma=parseFloat(Z[1])),(Z=Y.match($))&&(X.exposure=parseFloat(Z[1])),(Z=Y.match(j))&&(X.valid|=2,X.format=Z[1]),(Z=Y.match(F))&&(X.valid|=4,X.height=parseInt(Z[1],10),X.width=parseInt(Z[2],10)),X.valid&2&&X.valid&4)break}return X.valid&2?X.valid&4?X:h(3,"missing image size specifier"):h(3,"missing format specifier")},O=function(B,N,Q){const $=N;if($<8||$>32767||B[0]!==2||B[1]!==2||B[2]&128)return new Uint8Array(B);if($!==(B[2]<<8|B[3]))return h(3,"wrong scanline width");const j=new Uint8Array(4*N*Q);if(!j.length)return h(4,"unable to allocate buffer space");let F=0,X=0;const Y=4*$,Z=new Uint8Array(4),ue=new Uint8Array(Y);let ge=Q;for(;ge>0&&X<B.byteLength;){if(X+4>B.byteLength)return h(1);if(Z[0]=B[X++],Z[1]=B[X++],Z[2]=B[X++],Z[3]=B[X++],Z[0]!=2||Z[1]!=2||(Z[2]<<8|Z[3])!=$)return h(3,"bad rgbe scanline format");let pe=0,me;for(;pe<Y&&X<B.byteLength;){me=B[X++];const ee=me>128;if(ee&&(me-=128),me===0||pe+me>Y)return h(3,"bad scanline data");if(ee){const q=B[X++];for(let Ce=0;Ce<me;Ce++)ue[pe++]=q}else ue.set(B.subarray(X,X+me),pe),pe+=me,X+=me}const he=$;for(let ee=0;ee<he;ee++){let q=0;j[F]=ue[ee+q],q+=$,j[F+1]=ue[ee+q],q+=$,j[F+2]=ue[ee+q],q+=$,j[F+3]=ue[ee+q],F+=4}ge--}return j},I=function(B,N,Q,$){const j=B[N+3],F=Math.pow(2,j-128)/255;Q[$+0]=B[N+0]*F,Q[$+1]=B[N+1]*F,Q[$+2]=B[N+2]*F,Q[$+3]=1},E=function(B,N,Q,$){const j=B[N+3],F=Math.pow(2,j-128)/255;Q[$+0]=f.DataUtils.toHalfFloat(Math.min(B[N+0]*F,65504)),Q[$+1]=f.DataUtils.toHalfFloat(Math.min(B[N+1]*F,65504)),Q[$+2]=f.DataUtils.toHalfFloat(Math.min(B[N+2]*F,65504)),Q[$+3]=f.DataUtils.toHalfFloat(1)},R=new Uint8Array(i);R.pos=0;const z=M(R);if(z!==-1){const B=z.width,N=z.height,Q=O(R.subarray(R.pos),B,N);if(Q!==-1){let $,j,F;switch(this.type){case f.FloatType:F=Q.length/4;const X=new Float32Array(F*4);for(let Z=0;Z<F;Z++)I(Q,Z*4,X,Z*4);$=X,j=f.FloatType;break;case f.HalfFloatType:F=Q.length/4;const Y=new Uint16Array(F*4);for(let Z=0;Z<F;Z++)E(Q,Z*4,Y,Z*4);$=Y,j=f.HalfFloatType;break;default:console.error("THREE.RGBELoader: unsupported type: ",this.type);break}return{width:B,height:N,data:$,header:z.string,gamma:z.gamma,exposure:z.exposure,type:j}}}return null}setDataType(i){return this.type=i,this}load(i,r,s,a){function c(u,h){switch(u.type){case f.FloatType:case f.HalfFloatType:u.encoding=f.LinearEncoding,u.minFilter=f.LinearFilter,u.magFilter=f.LinearFilter,u.generateMipmaps=!1,u.flipY=!0;break}r&&r(u,h)}return super.load(i,c,s,a)}}const hs=new WeakMap;class cl extends f.Loader{constructor(i){super(i),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(i){return this.decoderPath=i,this}setDecoderConfig(i){return this.decoderConfig=i,this}setWorkerLimit(i){return this.workerLimit=i,this}load(i,r,s,a){const c=new f.FileLoader(this.manager);c.setPath(this.path),c.setResponseType("arraybuffer"),c.setRequestHeader(this.requestHeader),c.setWithCredentials(this.withCredentials),c.load(i,u=>{const h={attributeIDs:this.defaultAttributeIDs,attributeTypes:this.defaultAttributeTypes,useUniqueIDs:!1};this.decodeGeometry(u,h).then(r).catch(a)},s,a)}decodeDracoFile(i,r,s,a){const c={attributeIDs:s||this.defaultAttributeIDs,attributeTypes:a||this.defaultAttributeTypes,useUniqueIDs:!!s};this.decodeGeometry(i,c).then(r)}decodeGeometry(i,r){for(const d in r.attributeTypes){const _=r.attributeTypes[d];_.BYTES_PER_ELEMENT!==void 0&&(r.attributeTypes[d]=_.name)}const s=JSON.stringify(r);if(hs.has(i)){const d=hs.get(i);if(d.key===s)return d.promise;if(i.byteLength===0)throw new Error("THREE.DRACOLoader: Unable to re-decode a buffer with different settings. Buffer has already been transferred.")}let a;const c=this.workerNextTaskID++,u=i.byteLength,h=this._getWorker(c,u).then(d=>(a=d,new Promise((_,y)=>{a._callbacks[c]={resolve:_,reject:y},a.postMessage({type:"decode",id:c,taskConfig:r,buffer:i},[i])}))).then(d=>this._createGeometry(d.geometry));return h.catch(()=>!0).then(()=>{a&&c&&this._releaseTask(a,c)}),hs.set(i,{key:s,promise:h}),h}_createGeometry(i){const r=new f.BufferGeometry;i.index&&r.setIndex(new f.BufferAttribute(i.index.array,1));for(let s=0;s<i.attributes.length;s++){const a=i.attributes[s],c=a.name,u=a.array,h=a.itemSize;r.setAttribute(c,new f.BufferAttribute(u,h))}return r}_loadLibrary(i,r){const s=new f.FileLoader(this.manager);return s.setPath(this.decoderPath),s.setResponseType(r),s.setWithCredentials(this.withCredentials),new Promise((a,c)=>{s.load(i,a,void 0,c)})}preload(){return this._initDecoder(),this}_initDecoder(){if(this.decoderPending)return this.decoderPending;const i=typeof WebAssembly!="object"||this.decoderConfig.type==="js",r=[];return i?r.push(this._loadLibrary("draco_decoder.js","text")):(r.push(this._loadLibrary("draco_wasm_wrapper.js","text")),r.push(this._loadLibrary("draco_decoder.wasm","arraybuffer"))),this.decoderPending=Promise.all(r).then(s=>{const a=s[0];i||(this.decoderConfig.wasmBinary=s[1]);const c=pl.toString(),u=["/* draco decoder */",a,"","/* worker */",c.substring(c.indexOf("{")+1,c.lastIndexOf("}"))].join(`
19
- `);this.workerSourceURL=URL.createObjectURL(new Blob([u]))}),this.decoderPending}_getWorker(i,r){return this._initDecoder().then(()=>{if(this.workerPool.length<this.workerLimit){const a=new Worker(this.workerSourceURL);a._callbacks={},a._taskCosts={},a._taskLoad=0,a.postMessage({type:"init",decoderConfig:this.decoderConfig}),a.onmessage=function(c){const u=c.data;switch(u.type){case"decode":a._callbacks[u.id].resolve(u);break;case"error":a._callbacks[u.id].reject(u);break;default:console.error('THREE.DRACOLoader: Unexpected message, "'+u.type+'"')}},this.workerPool.push(a)}else this.workerPool.sort(function(a,c){return a._taskLoad>c._taskLoad?-1:1});const s=this.workerPool[this.workerPool.length-1];return s._taskCosts[i]=r,s._taskLoad+=r,s})}_releaseTask(i,r){i._taskLoad-=i._taskCosts[r],delete i._callbacks[r],delete i._taskCosts[r]}debug(){console.log("Task load: ",this.workerPool.map(i=>i._taskLoad))}dispose(){for(let i=0;i<this.workerPool.length;++i)this.workerPool[i].terminate();return this.workerPool.length=0,this}}function pl(){let g,i;onmessage=function(u){const h=u.data;switch(h.type){case"init":g=h.decoderConfig,i=new Promise(function(y){g.onModuleLoaded=function(w){y({draco:w})},DracoDecoderModule(g)});break;case"decode":const d=h.buffer,_=h.taskConfig;i.then(y=>{const w=y.draco,x=new w.Decoder,M=new w.DecoderBuffer;M.Init(new Int8Array(d),d.byteLength);try{const O=r(w,x,M,_),I=O.attributes.map(E=>E.array.buffer);O.index&&I.push(O.index.array.buffer),self.postMessage({type:"decode",id:h.id,geometry:O},I)}catch(O){console.error(O),self.postMessage({type:"error",id:h.id,error:O.message})}finally{w.destroy(M),w.destroy(x)}});break}};function r(u,h,d,_){const y=_.attributeIDs,w=_.attributeTypes;let x,M;const O=h.GetEncodedGeometryType(d);if(O===u.TRIANGULAR_MESH)x=new u.Mesh,M=h.DecodeBufferToMesh(d,x);else if(O===u.POINT_CLOUD)x=new u.PointCloud,M=h.DecodeBufferToPointCloud(d,x);else throw new Error("THREE.DRACOLoader: Unexpected geometry type.");if(!M.ok()||x.ptr===0)throw new Error("THREE.DRACOLoader: Decoding failed: "+M.error_msg());const I={index:null,attributes:[]};for(const E in y){const R=self[w[E]];let z,B;if(_.useUniqueIDs)B=y[E],z=h.GetAttributeByUniqueId(x,B);else{if(B=h.GetAttributeId(x,u[y[E]]),B===-1)continue;z=h.GetAttribute(x,B)}I.attributes.push(a(u,h,x,E,R,z))}return O===u.TRIANGULAR_MESH&&(I.index=s(u,h,x)),u.destroy(x),I}function s(u,h,d){const y=d.num_faces()*3,w=y*4,x=u._malloc(w);h.GetTrianglesUInt32Array(d,w,x);const M=new Uint32Array(u.HEAPF32.buffer,x,y).slice();return u._free(x),{array:M,itemSize:1}}function a(u,h,d,_,y,w){const x=w.num_components(),O=d.num_points()*x,I=O*y.BYTES_PER_ELEMENT,E=c(u,y),R=u._malloc(I);h.GetAttributeDataArrayForAllPoints(d,w,E,I,R);const z=new y(u.HEAPF32.buffer,R,O).slice();return u._free(R),{name:_,array:z,itemSize:x}}function c(u,h){switch(h){case Float32Array:return u.DT_FLOAT32;case Int8Array:return u.DT_INT8;case Int16Array:return u.DT_INT16;case Int32Array:return u.DT_INT32;case Uint8Array:return u.DT_UINT8;case Uint16Array:return u.DT_UINT16;case Uint32Array:return u.DT_UINT32}}}function Rt(){const{state:g,setState:i}=L.inject("useTres",zt.useTres()),r=L.inject("extend")||(()=>{});return{state:g,setState:i,extend:r}}const ul=["args"],hl=L.defineComponent({__name:"OrbitControls",props:{makeDefault:{type:Boolean,default:!1},camera:null,domElement:null,target:null,enableDamping:{type:Boolean}},setup(g){const i=g,{state:r,setState:s,extend:a}=Rt(),c=L.ref(null);return a({OrbitControls:aa}),L.watch(c,u=>{u&&i.makeDefault?s("controls",u):s("controls",null)}),(u,h)=>{var d;return L.unref(r).camera&&L.unref(r).renderer?(L.openBlock(),L.createElementBlock("TresOrbitControls",{key:0,ref_key:"controls",ref:c,args:[L.unref(L.unref(r).camera)||g.camera,((d=L.unref(r).renderer)==null?void 0:d.domElement)||g.domElement]},null,8,ul)):L.createCommentVNode("",!0)}}});function dl(g,i){const r={};for(const s of i)Object.prototype.hasOwnProperty.call(g,s)&&(r[s]=g[s]);return r}function ml(g,i){const r=`set${i[0].toUpperCase()}${i.slice(1)}`;return g[r]!==void 0}const fl=L.defineComponent({__name:"TransformControls",props:{object:null,mode:null,enabled:{type:Boolean,default:!0},axis:null,translationSnap:null,rotationSnap:null,scaleSnap:null,space:null,size:null,showX:{type:Boolean},showY:{type:Boolean},showZ:{type:Boolean}},emits:["dragging","change","mouseDown","mouseUp","objectChange"],setup(g,{emit:i}){const r=g;let s=L.shallowRef();const{state:a}=Rt(),c=L.computed(()=>dl(r,["enabled","axis","mode","translationSnap","rotationSnap","scaleSnap","space","size","showX","showY","showZ"])),u=()=>i("change",s.value),h=()=>i("mouseDown",s.value),d=()=>i("mouseUp",s.value),_=()=>i("objectChange",s.value),y=x=>{a.controls&&(a.controls.enabled=!x.value),i("dragging",x.value)};function w(x){x.addEventListener("dragging-changed",y),x.addEventListener("change",u),x.addEventListener("mouseDown",h),x.addEventListener("mouseUp",d),x.addEventListener("objectChange",_)}return L.watch(()=>r.object,()=>{a.camera&&a.renderer&&a.scene&&r.object&&(s.value=new sa(a.camera,L.unref(a.renderer).domElement),s.value.attach(L.unref(r.object)),a.scene.add(L.unref(s)),w(L.unref(s)))},{deep:!0}),L.watch([c,s],([x,M])=>{if(x&&M)for(const O in x)if(!ml(M,O))M[O]=x[O];else{const I=`set${O[0].toUpperCase()}${O.slice(1)}`;typeof M[I]=="function"&&x[O]!==void 0&&M[I](x[O])}},{immediate:!0}),L.onUnmounted(()=>{s.value&&(s.value.removeEventListener("dragging-changed",y),s.value.removeEventListener("change",u),s.value.removeEventListener("mouseDown",h),s.value.removeEventListener("mouseUp",d),s.value.removeEventListener("objectChange",_))}),(x,M)=>L.renderSlot(x.$slots,"default")}});var Kr;const $r=typeof window<"u",vl=g=>typeof g=="string",bl=()=>{};$r&&((Kr=window==null?void 0:window.navigator)!=null&&Kr.userAgent)&&/iP(ad|hone|od)/.test(window.navigator.userAgent);function Xr(g){return typeof g=="function"?g():L.unref(g)}function gl(g){return g}function _l(g){return L.getCurrentScope()?(L.onScopeDispose(g),!0):!1}function wl(g,i=!0){L.getCurrentInstance()?L.onMounted(g):i?g():L.nextTick(g)}function yl(g){var i;const r=Xr(g);return(i=r==null?void 0:r.$el)!=null?i:r}const ds=$r?window:void 0;function Gt(...g){let i,r,s,a;if(vl(g[0])||Array.isArray(g[0])?([r,s,a]=g,i=ds):[i,r,s,a]=g,!i)return bl;Array.isArray(r)||(r=[r]),Array.isArray(s)||(s=[s]);const c=[],u=()=>{c.forEach(y=>y()),c.length=0},h=(y,w,x,M)=>(y.addEventListener(w,x,M),()=>y.removeEventListener(w,x,M)),d=L.watch(()=>[yl(i),Xr(a)],([y,w])=>{u(),y&&c.push(...r.flatMap(x=>s.map(M=>h(y,x,M,w))))},{immediate:!0,flush:"post"}),_=()=>{d(),u()};return _l(_),_}const Yr=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{},qr="__vueuse_ssr_handlers__";Yr[qr]=Yr[qr]||{};function xl(g={}){const{type:i="page",touch:r=!0,resetOnTouchEnds:s=!1,initialValue:a={x:0,y:0},window:c=ds,eventFilter:u}=g,h=L.ref(a.x),d=L.ref(a.y),_=L.ref(null),y=I=>{i==="page"?(h.value=I.pageX,d.value=I.pageY):i==="client"?(h.value=I.clientX,d.value=I.clientY):i==="movement"&&(h.value=I.movementX,d.value=I.movementY),_.value="mouse"},w=()=>{h.value=a.x,d.value=a.y},x=I=>{if(I.touches.length>0){const E=I.touches[0];i==="page"?(h.value=E.pageX,d.value=E.pageY):i==="client"&&(h.value=E.clientX,d.value=E.clientY),_.value="touch"}},M=I=>u===void 0?y(I):u(()=>y(I),{}),O=I=>u===void 0?x(I):u(()=>x(I),{});return c&&(Gt(c,"mousemove",M,{passive:!0}),Gt(c,"dragover",M,{passive:!0}),r&&i!=="movement"&&(Gt(c,"touchstart",O,{passive:!0}),Gt(c,"touchmove",O,{passive:!0}),s&&Gt(c,"touchend",w,{passive:!0}))),{x:h,y:d,sourceType:_}}var Qr;(function(g){g.UP="UP",g.RIGHT="RIGHT",g.DOWN="DOWN",g.LEFT="LEFT",g.NONE="NONE"})(Qr||(Qr={}));var Cl=Object.defineProperty,Zr=Object.getOwnPropertySymbols,Pl=Object.prototype.hasOwnProperty,Ml=Object.prototype.propertyIsEnumerable,Wr=(g,i,r)=>i in g?Cl(g,i,{enumerable:!0,configurable:!0,writable:!0,value:r}):g[i]=r,kl=(g,i)=>{for(var r in i||(i={}))Pl.call(i,r)&&Wr(g,r,i[r]);if(Zr)for(var r of Zr(i))Ml.call(i,r)&&Wr(g,r,i[r]);return g};kl({linear:gl},{easeInSine:[.12,0,.39,0],easeOutSine:[.61,1,.88,1],easeInOutSine:[.37,0,.63,1],easeInQuad:[.11,0,.5,0],easeOutQuad:[.5,1,.89,1],easeInOutQuad:[.45,0,.55,1],easeInCubic:[.32,0,.67,0],easeOutCubic:[.33,1,.68,1],easeInOutCubic:[.65,0,.35,1],easeInQuart:[.5,0,.75,0],easeOutQuart:[.25,1,.5,1],easeInOutQuart:[.76,0,.24,1],easeInQuint:[.64,0,.78,0],easeOutQuint:[.22,1,.36,1],easeInOutQuint:[.83,0,.17,1],easeInExpo:[.7,0,.84,0],easeOutExpo:[.16,1,.3,1],easeInOutExpo:[.87,0,.13,1],easeInCirc:[.55,0,1,.45],easeOutCirc:[0,.55,.45,1],easeInOutCirc:[.85,0,.15,1],easeInBack:[.36,0,.66,-.56],easeOutBack:[.34,1.56,.64,1],easeInOutBack:[.68,-.6,.32,1.6]});function Sl(g={}){const{window:i=ds,initialWidth:r=1/0,initialHeight:s=1/0,listenOrientation:a=!0,includeScrollbar:c=!0}=g,u=L.ref(r),h=L.ref(s),d=()=>{i&&(c?(u.value=i.innerWidth,h.value=i.innerHeight):(u.value=i.document.documentElement.clientWidth,h.value=i.document.documentElement.clientHeight))};return d(),wl(d),Gt("resize",d,{passive:!0}),a&&Gt("orientationchange",d,{passive:!0}),{width:u,height:h}}function Jr(g=!1,i=5,r){const{x:s,y:a}=xl(),{logWarning:c}=zt.useLogger(),{width:u,height:h}=Sl(),d=L.computed(()=>(s.value/u.value-.5)*i),_=L.computed(()=>-(a.value/h.value-.5)*i);if(r){const{x:y,y:w}=r.position;L.watchEffect(()=>{g||r&&(r.position.x=y+d.value,r.position.y=w+_.value)})}else c("Scene must contain a Camera component to use this composable")}const Ll=L.defineComponent({name:"PamCameraMouse",props:["disabled","factor"],setup(g){const{state:i}=Rt();return L.watchEffect(()=>{if(i!=null&&i.camera){const r=i==null?void 0:i.camera;Jr(g.disabled,g.factor,r)}}),()=>{}}});var xi={},Al={get exports(){return xi},set exports(g){xi=g}};/*! Tweakpane 3.1.7 (c) 2016 cocopon, licensed under the MIT license. */(function(g,i){(function(r,s){s(i)})(Gr,function(r){class s{constructor(e){const[t,l]=e.split("-"),b=t.split(".");this.major=parseInt(b[0],10),this.minor=parseInt(b[1],10),this.patch=parseInt(b[2],10),this.prerelease=l??null}toString(){const e=[this.major,this.minor,this.patch].join(".");return this.prerelease!==null?[e,this.prerelease].join("-"):e}}class a{constructor(e){this.controller_=e}get element(){return this.controller_.view.element}get disabled(){return this.controller_.viewProps.get("disabled")}set disabled(e){this.controller_.viewProps.set("disabled",e)}get hidden(){return this.controller_.viewProps.get("hidden")}set hidden(e){this.controller_.viewProps.set("hidden",e)}dispose(){this.controller_.viewProps.set("disposed",!0)}}class c{constructor(e){this.target=e}}class u extends c{constructor(e,t,l,b){super(e),this.value=t,this.presetKey=l,this.last=b??!0}}class h extends c{constructor(e,t,l){super(e),this.value=t,this.presetKey=l}}class d extends c{constructor(e,t){super(e),this.expanded=t}}class _ extends c{constructor(e,t){super(e),this.index=t}}function y(n){return n}function w(n){return n==null}function x(n,e){if(n.length!==e.length)return!1;for(let t=0;t<n.length;t++)if(n[t]!==e[t])return!1;return!0}function M(n,e){let t=n;do{const l=Object.getOwnPropertyDescriptor(t,e);if(l&&(l.set!==void 0||l.writable===!0))return!0;t=Object.getPrototypeOf(t)}while(t!==null);return!1}const O={alreadydisposed:()=>"View has been already disposed",invalidparams:n=>`Invalid parameters for '${n.name}'`,nomatchingcontroller:n=>`No matching controller for '${n.key}'`,nomatchingview:n=>`No matching view for '${JSON.stringify(n.params)}'`,notbindable:()=>"Value is not bindable",propertynotfound:n=>`Property '${n.name}' not found`,shouldneverhappen:()=>"This error should never happen"};class I{static alreadyDisposed(){return new I({type:"alreadydisposed"})}static notBindable(){return new I({type:"notbindable"})}static propertyNotFound(e){return new I({type:"propertynotfound",context:{name:e}})}static shouldNeverHappen(){return new I({type:"shouldneverhappen"})}constructor(e){var t;this.message=(t=O[e.type](e.context))!==null&&t!==void 0?t:"Unexpected error",this.name=this.constructor.name,this.stack=new Error(this.message).stack,this.type=e.type}}class E{constructor(e,t,l){this.obj_=e,this.key_=t,this.presetKey_=l??t}static isBindable(e){return!(e===null||typeof e!="object")}get key(){return this.key_}get presetKey(){return this.presetKey_}read(){return this.obj_[this.key_]}write(e){this.obj_[this.key_]=e}writeProperty(e,t){const l=this.read();if(!E.isBindable(l))throw I.notBindable();if(!(e in l))throw I.propertyNotFound(e);l[e]=t}}class R extends a{get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}get title(){var e;return(e=this.controller_.valueController.props.get("title"))!==null&&e!==void 0?e:""}set title(e){this.controller_.valueController.props.set("title",e)}on(e,t){const l=t.bind(this);return this.controller_.valueController.emitter.on(e,()=>{l(new c(this))}),this}}class z{constructor(){this.observers_={}}on(e,t){let l=this.observers_[e];return l||(l=this.observers_[e]=[]),l.push({handler:t}),this}off(e,t){const l=this.observers_[e];return l&&(this.observers_[e]=l.filter(b=>b.handler!==t)),this}emit(e,t){const l=this.observers_[e];l&&l.forEach(b=>{b.handler(t)})}}const B="tp";function N(n){return(t,l)=>[B,"-",n,"v",t?`_${t}`:"",l?`-${l}`:""].join("")}function Q(n,e){return t=>e(n(t))}function $(n){return n.rawValue}function j(n,e){n.emitter.on("change",Q($,e)),e(n.rawValue)}function F(n,e,t){j(n.value(e),t)}function X(n,e,t){t?n.classList.add(e):n.classList.remove(e)}function Y(n,e){return t=>{X(n,e,t)}}function Z(n,e){j(n,t=>{e.textContent=t??""})}const ue=N("btn");class ge{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(ue()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("button");l.classList.add(ue("b")),t.viewProps.bindDisabled(l),this.element.appendChild(l),this.buttonElement=l;const b=e.createElement("div");b.classList.add(ue("t")),Z(t.props.value("title"),b),this.buttonElement.appendChild(b)}}class pe{constructor(e,t){this.emitter=new z,this.onClick_=this.onClick_.bind(this),this.props=t.props,this.viewProps=t.viewProps,this.view=new ge(e,{props:this.props,viewProps:this.viewProps}),this.view.buttonElement.addEventListener("click",this.onClick_)}onClick_(){this.emitter.emit("click",{sender:this})}}class me{constructor(e,t){var l;this.constraint_=t==null?void 0:t.constraint,this.equals_=(l=t==null?void 0:t.equals)!==null&&l!==void 0?l:(b,P)=>b===P,this.emitter=new z,this.rawValue_=e}get constraint(){return this.constraint_}get rawValue(){return this.rawValue_}set rawValue(e){this.setRawValue(e,{forceEmit:!1,last:!0})}setRawValue(e,t){const l=t??{forceEmit:!1,last:!0},b=this.constraint_?this.constraint_.constrain(e):e,P=this.rawValue_;this.equals_(P,b)&&!l.forceEmit||(this.emitter.emit("beforechange",{sender:this}),this.rawValue_=b,this.emitter.emit("change",{options:l,previousRawValue:P,rawValue:b,sender:this}))}}class he{constructor(e){this.emitter=new z,this.value_=e}get rawValue(){return this.value_}set rawValue(e){this.setRawValue(e,{forceEmit:!1,last:!0})}setRawValue(e,t){const l=t??{forceEmit:!1,last:!0},b=this.value_;b===e&&!l.forceEmit||(this.emitter.emit("beforechange",{sender:this}),this.value_=e,this.emitter.emit("change",{options:l,previousRawValue:b,rawValue:this.value_,sender:this}))}}function ee(n,e){const t=e==null?void 0:e.constraint,l=e==null?void 0:e.equals;return!t&&!l?new he(n):new me(n,e)}class q{constructor(e){this.emitter=new z,this.valMap_=e;for(const t in this.valMap_)this.valMap_[t].emitter.on("change",()=>{this.emitter.emit("change",{key:t,sender:this})})}static createCore(e){return Object.keys(e).reduce((l,b)=>Object.assign(l,{[b]:ee(e[b])}),{})}static fromObject(e){const t=this.createCore(e);return new q(t)}get(e){return this.valMap_[e].rawValue}set(e,t){this.valMap_[e].rawValue=t}value(e){return this.valMap_[e]}}function Ce(n,e){const l=Object.keys(e).reduce((b,P)=>{if(b===void 0)return;const A=e[P],U=A(n[P]);return U.succeeded?Object.assign(Object.assign({},b),{[P]:U.value}):void 0},{});return l}function fe(n,e){return n.reduce((t,l)=>{if(t===void 0)return;const b=e(l);if(!(!b.succeeded||b.value===void 0))return[...t,b.value]},[])}function le(n){return n===null?!1:typeof n=="object"}function ne(n){return e=>t=>{if(!e&&t===void 0)return{succeeded:!1,value:void 0};if(e&&t===void 0)return{succeeded:!0,value:void 0};const l=n(t);return l!==void 0?{succeeded:!0,value:l}:{succeeded:!1,value:void 0}}}function be(n){return{custom:e=>ne(e)(n),boolean:ne(e=>typeof e=="boolean"?e:void 0)(n),number:ne(e=>typeof e=="number"?e:void 0)(n),string:ne(e=>typeof e=="string"?e:void 0)(n),function:ne(e=>typeof e=="function"?e:void 0)(n),constant:e=>ne(t=>t===e?e:void 0)(n),raw:ne(e=>e)(n),object:e=>ne(t=>{if(le(t))return Ce(t,e)})(n),array:e=>ne(t=>{if(Array.isArray(t))return fe(t,e)})(n)}}const V={optional:be(!0),required:be(!1)};function ce(n,e){const t=V.required.object(e)(n);return t.succeeded?t.value:void 0}function Ae(n){console.warn([`Missing '${n.key}' of ${n.target} in ${n.place}.`,"Please rebuild plugins with the latest core package."].join(" "))}function De(n){return n&&n.parentElement&&n.parentElement.removeChild(n),null}class we{constructor(e){this.value_=e}static create(e){return[new we(e),(t,l)=>{e.setRawValue(t,l)}]}get emitter(){return this.value_.emitter}get rawValue(){return this.value_.rawValue}}const qe=N("");function fn(n,e){return Y(n,qe(void 0,e))}class ze extends q{constructor(e){var t;super(e),this.onDisabledChange_=this.onDisabledChange_.bind(this),this.onParentChange_=this.onParentChange_.bind(this),this.onParentGlobalDisabledChange_=this.onParentGlobalDisabledChange_.bind(this),[this.globalDisabled_,this.setGlobalDisabled_]=we.create(ee(this.getGlobalDisabled_())),this.value("disabled").emitter.on("change",this.onDisabledChange_),this.value("parent").emitter.on("change",this.onParentChange_),(t=this.get("parent"))===null||t===void 0||t.globalDisabled.emitter.on("change",this.onParentGlobalDisabledChange_)}static create(e){var t,l,b;const P=e??{};return new ze(q.createCore({disabled:(t=P.disabled)!==null&&t!==void 0?t:!1,disposed:!1,hidden:(l=P.hidden)!==null&&l!==void 0?l:!1,parent:(b=P.parent)!==null&&b!==void 0?b:null}))}get globalDisabled(){return this.globalDisabled_}bindClassModifiers(e){j(this.globalDisabled_,fn(e,"disabled")),F(this,"hidden",fn(e,"hidden"))}bindDisabled(e){j(this.globalDisabled_,t=>{e.disabled=t})}bindTabIndex(e){j(this.globalDisabled_,t=>{e.tabIndex=t?-1:0})}handleDispose(e){this.value("disposed").emitter.on("change",t=>{t&&e()})}getGlobalDisabled_(){const e=this.get("parent");return(e?e.globalDisabled.rawValue:!1)||this.get("disabled")}updateGlobalDisabled_(){this.setGlobalDisabled_(this.getGlobalDisabled_())}onDisabledChange_(){this.updateGlobalDisabled_()}onParentGlobalDisabledChange_(){this.updateGlobalDisabled_()}onParentChange_(e){var t;const l=e.previousRawValue;l==null||l.globalDisabled.emitter.off("change",this.onParentGlobalDisabledChange_),(t=this.get("parent"))===null||t===void 0||t.globalDisabled.emitter.on("change",this.onParentGlobalDisabledChange_),this.updateGlobalDisabled_()}}function vn(){return["veryfirst","first","last","verylast"]}const $t=N(""),nt={veryfirst:"vfst",first:"fst",last:"lst",verylast:"vlst"};class dt{constructor(e){this.parent_=null,this.blade=e.blade,this.view=e.view,this.viewProps=e.viewProps;const t=this.view.element;this.blade.value("positions").emitter.on("change",()=>{vn().forEach(l=>{t.classList.remove($t(void 0,nt[l]))}),this.blade.get("positions").forEach(l=>{t.classList.add($t(void 0,nt[l]))})}),this.viewProps.handleDispose(()=>{De(t)})}get parent(){return this.parent_}set parent(e){if(this.parent_=e,!("parent"in this.viewProps.valMap_)){Ae({key:"parent",target:ze.name,place:"BladeController.parent"});return}this.viewProps.set("parent",this.parent_?this.parent_.viewProps:null)}}const Ee="http://www.w3.org/2000/svg";function Qe(n){n.offsetHeight}function Xt(n,e){const t=n.style.transition;n.style.transition="none",e(),n.style.transition=t}function it(n){return n.ontouchstart!==void 0}function bn(){return globalThis}function Kn(){return bn().document}function gn(n){const e=n.ownerDocument.defaultView;return e&&"document"in e?n.getContext("2d",{willReadFrequently:!0}):null}const _n={check:'<path d="M2 8l4 4l8 -8"/>',dropdown:'<path d="M5 7h6l-3 3 z"/>',p2dpad:'<path d="M8 4v8"/><path d="M4 8h8"/><circle cx="12" cy="12" r="1.2"/>'};function at(n,e){const t=n.createElementNS(Ee,"svg");return t.innerHTML=_n[e],t}function mt(n,e,t){n.insertBefore(e,n.children[t])}function wn(n){n.parentElement&&n.parentElement.removeChild(n)}function Yt(n){for(;n.children.length>0;)n.removeChild(n.children[0])}function yn(n){for(;n.childNodes.length>0;)n.removeChild(n.childNodes[0])}function lt(n){return n.relatedTarget?n.relatedTarget:"explicitOriginalTarget"in n?n.explicitOriginalTarget:null}const st=N("lbl");function ft(n,e){const t=n.createDocumentFragment();return e.split(`
20
- `).map(b=>n.createTextNode(b)).forEach((b,P)=>{P>0&&t.appendChild(n.createElement("br")),t.appendChild(b)}),t}class D{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(st()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(st("l")),F(t.props,"label",P=>{w(P)?this.element.classList.add(st(void 0,"nol")):(this.element.classList.remove(st(void 0,"nol")),yn(l),l.appendChild(ft(e,P)))}),this.element.appendChild(l),this.labelElement=l;const b=e.createElement("div");b.classList.add(st("v")),this.element.appendChild(b),this.valueElement=b}}class K extends dt{constructor(e,t){const l=t.valueController.viewProps;super(Object.assign(Object.assign({},t),{view:new D(e,{props:t.props,viewProps:l}),viewProps:l})),this.props=t.props,this.valueController=t.valueController,this.view.valueElement.appendChild(this.valueController.view.element)}}const J={id:"button",type:"blade",accept(n){const e=V,t=ce(n,{title:e.required.string,view:e.required.constant("button"),label:e.optional.string});return t?{params:t}:null},controller(n){return new K(n.document,{blade:n.blade,props:q.fromObject({label:n.params.label}),valueController:new pe(n.document,{props:q.fromObject({title:n.params.title}),viewProps:n.viewProps})})},api(n){return!(n.controller instanceof K)||!(n.controller.valueController instanceof pe)?null:new R(n.controller)}};class ie extends dt{constructor(e){super(e),this.value=e.value}}function ye(){return new q({positions:ee([],{equals:x})})}class Ve extends q{constructor(e){super(e)}static create(e){const t={completed:!0,expanded:e,expandedHeight:null,shouldFixHeight:!1,temporaryExpanded:null},l=q.createCore(t);return new Ve(l)}get styleExpanded(){var e;return(e=this.get("temporaryExpanded"))!==null&&e!==void 0?e:this.get("expanded")}get styleHeight(){if(!this.styleExpanded)return"0";const e=this.get("expandedHeight");return this.get("shouldFixHeight")&&!w(e)?`${e}px`:"auto"}bindExpandedClass(e,t){const l=()=>{this.styleExpanded?e.classList.add(t):e.classList.remove(t)};F(this,"expanded",l),F(this,"temporaryExpanded",l)}cleanUpTransition(){this.set("shouldFixHeight",!1),this.set("expandedHeight",null),this.set("completed",!0)}}function St(n,e){let t=0;return Xt(e,()=>{n.set("expandedHeight",null),n.set("temporaryExpanded",!0),Qe(e),t=e.clientHeight,n.set("temporaryExpanded",null),Qe(e)}),t}function qt(n,e){e.style.height=n.styleHeight}function Oe(n,e){n.value("expanded").emitter.on("beforechange",()=>{if(n.set("completed",!1),w(n.get("expandedHeight"))){const t=St(n,e);t>0&&n.set("expandedHeight",t)}n.set("shouldFixHeight",!0),Qe(e)}),n.emitter.on("change",()=>{qt(n,e)}),qt(n,e),e.addEventListener("transitionend",t=>{t.propertyName==="height"&&n.cleanUpTransition()})}class Be extends a{constructor(e,t){super(e),this.rackApi_=t}}function fs(n,e){return n.addBlade(Object.assign(Object.assign({},e),{view:"button"}))}function vs(n,e){return n.addBlade(Object.assign(Object.assign({},e),{view:"folder"}))}function bs(n,e){const t=e??{};return n.addBlade(Object.assign(Object.assign({},t),{view:"separator"}))}function $n(n,e){return n.addBlade(Object.assign(Object.assign({},e),{view:"tab"}))}class vt{constructor(e){this.emitter=new z,this.items_=[],this.cache_=new Set,this.onSubListAdd_=this.onSubListAdd_.bind(this),this.onSubListRemove_=this.onSubListRemove_.bind(this),this.extract_=e}get items(){return this.items_}allItems(){return Array.from(this.cache_)}find(e){for(const t of this.allItems())if(e(t))return t;return null}includes(e){return this.cache_.has(e)}add(e,t){if(this.includes(e))throw I.shouldNeverHappen();const l=t!==void 0?t:this.items_.length;this.items_.splice(l,0,e),this.cache_.add(e);const b=this.extract_(e);b&&(b.emitter.on("add",this.onSubListAdd_),b.emitter.on("remove",this.onSubListRemove_),b.allItems().forEach(P=>{this.cache_.add(P)})),this.emitter.emit("add",{index:l,item:e,root:this,target:this})}remove(e){const t=this.items_.indexOf(e);if(t<0)return;this.items_.splice(t,1),this.cache_.delete(e);const l=this.extract_(e);l&&(l.emitter.off("add",this.onSubListAdd_),l.emitter.off("remove",this.onSubListRemove_)),this.emitter.emit("remove",{index:t,item:e,root:this,target:this})}onSubListAdd_(e){this.cache_.add(e.item),this.emitter.emit("add",{index:e.index,item:e.item,root:this,target:e.target})}onSubListRemove_(e){this.cache_.delete(e.item),this.emitter.emit("remove",{index:e.index,item:e.item,root:this,target:e.target})}}class Xn extends a{constructor(e){super(e),this.onBindingChange_=this.onBindingChange_.bind(this),this.emitter_=new z,this.controller_.binding.emitter.on("change",this.onBindingChange_)}get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}refresh(){this.controller_.binding.read()}onBindingChange_(e){const t=e.sender.target.read();this.emitter_.emit("change",{event:new u(this,t,this.controller_.binding.target.presetKey,e.options.last)})}}class Te extends K{constructor(e,t){super(e,t),this.binding=t.binding}}class Yn extends a{constructor(e){super(e),this.onBindingUpdate_=this.onBindingUpdate_.bind(this),this.emitter_=new z,this.controller_.binding.emitter.on("update",this.onBindingUpdate_)}get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}refresh(){this.controller_.binding.read()}onBindingUpdate_(e){const t=e.sender.target.read();this.emitter_.emit("update",{event:new h(this,t,this.controller_.binding.target.presetKey)})}}class Ze extends K{constructor(e,t){super(e,t),this.binding=t.binding,this.viewProps.bindDisabled(this.binding.ticker),this.viewProps.handleDispose(()=>{this.binding.dispose()})}}function Mi(n){return n instanceof xn?n.apiSet_:n instanceof Be?n.rackApi_.apiSet_:null}function Qt(n,e){const t=n.find(l=>l.controller_===e);if(!t)throw I.shouldNeverHappen();return t}function ki(n,e,t){if(!E.isBindable(n))throw I.notBindable();return new E(n,e,t)}class xn extends a{constructor(e,t){super(e),this.onRackAdd_=this.onRackAdd_.bind(this),this.onRackRemove_=this.onRackRemove_.bind(this),this.onRackInputChange_=this.onRackInputChange_.bind(this),this.onRackMonitorUpdate_=this.onRackMonitorUpdate_.bind(this),this.emitter_=new z,this.apiSet_=new vt(Mi),this.pool_=t;const l=this.controller_.rack;l.emitter.on("add",this.onRackAdd_),l.emitter.on("remove",this.onRackRemove_),l.emitter.on("inputchange",this.onRackInputChange_),l.emitter.on("monitorupdate",this.onRackMonitorUpdate_),l.children.forEach(b=>{this.setUpApi_(b)})}get children(){return this.controller_.rack.children.map(e=>Qt(this.apiSet_,e))}addInput(e,t,l){const b=l??{},P=this.controller_.view.element.ownerDocument,A=this.pool_.createInput(P,ki(e,t,b.presetKey),b),U=new Xn(A);return this.add(U,b.index)}addMonitor(e,t,l){const b=l??{},P=this.controller_.view.element.ownerDocument,A=this.pool_.createMonitor(P,ki(e,t),b),U=new Yn(A);return this.add(U,b.index)}addFolder(e){return vs(this,e)}addButton(e){return fs(this,e)}addSeparator(e){return bs(this,e)}addTab(e){return $n(this,e)}add(e,t){this.controller_.rack.add(e.controller_,t);const l=this.apiSet_.find(b=>b.controller_===e.controller_);return l&&this.apiSet_.remove(l),this.apiSet_.add(e),e}remove(e){this.controller_.rack.remove(e.controller_)}addBlade(e){const t=this.controller_.view.element.ownerDocument,l=this.pool_.createBlade(t,e),b=this.pool_.createBladeApi(l);return this.add(b,e.index)}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}setUpApi_(e){this.apiSet_.find(l=>l.controller_===e)||this.apiSet_.add(this.pool_.createBladeApi(e))}onRackAdd_(e){this.setUpApi_(e.bladeController)}onRackRemove_(e){if(e.isRoot){const t=Qt(this.apiSet_,e.bladeController);this.apiSet_.remove(t)}}onRackInputChange_(e){const t=e.bladeController;if(t instanceof Te){const l=Qt(this.apiSet_,t),b=t.binding;this.emitter_.emit("change",{event:new u(l,b.target.read(),b.target.presetKey,e.options.last)})}else if(t instanceof ie){const l=Qt(this.apiSet_,t);this.emitter_.emit("change",{event:new u(l,t.value.rawValue,void 0,e.options.last)})}}onRackMonitorUpdate_(e){if(!(e.bladeController instanceof Ze))throw I.shouldNeverHappen();const t=Qt(this.apiSet_,e.bladeController),l=e.bladeController.binding;this.emitter_.emit("update",{event:new h(t,l.target.read(),l.target.presetKey)})}}class qn extends Be{constructor(e,t){super(e,new xn(e.rackController,t)),this.emitter_=new z,this.controller_.foldable.value("expanded").emitter.on("change",l=>{this.emitter_.emit("fold",{event:new d(this,l.sender.rawValue)})}),this.rackApi_.on("change",l=>{this.emitter_.emit("change",{event:l})}),this.rackApi_.on("update",l=>{this.emitter_.emit("update",{event:l})})}get expanded(){return this.controller_.foldable.get("expanded")}set expanded(e){this.controller_.foldable.set("expanded",e)}get title(){return this.controller_.props.get("title")}set title(e){this.controller_.props.set("title",e)}get children(){return this.rackApi_.children}addInput(e,t,l){return this.rackApi_.addInput(e,t,l)}addMonitor(e,t,l){return this.rackApi_.addMonitor(e,t,l)}addFolder(e){return this.rackApi_.addFolder(e)}addButton(e){return this.rackApi_.addButton(e)}addSeparator(e){return this.rackApi_.addSeparator(e)}addTab(e){return this.rackApi_.addTab(e)}add(e,t){return this.rackApi_.add(e,t)}remove(e){this.rackApi_.remove(e)}addBlade(e){return this.rackApi_.addBlade(e)}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}}class Qn extends dt{constructor(e){super({blade:e.blade,view:e.view,viewProps:e.rackController.viewProps}),this.rackController=e.rackController}}class gs{constructor(e,t){const l=N(t.viewName);this.element=e.createElement("div"),this.element.classList.add(l()),t.viewProps.bindClassModifiers(this.element)}}function _s(n,e){for(let t=0;t<n.length;t++){const l=n[t];if(l instanceof Te&&l.binding===e)return l}return null}function ws(n,e){for(let t=0;t<n.length;t++){const l=n[t];if(l instanceof Ze&&l.binding===e)return l}return null}function ys(n,e){for(let t=0;t<n.length;t++){const l=n[t];if(l instanceof ie&&l.value===e)return l}return null}function Zn(n){return n instanceof Zt?n.rack:n instanceof Qn?n.rackController.rack:null}function xs(n){const e=Zn(n);return e?e.bcSet_:null}class Cs{constructor(e){var t,l;this.onBladePositionsChange_=this.onBladePositionsChange_.bind(this),this.onSetAdd_=this.onSetAdd_.bind(this),this.onSetRemove_=this.onSetRemove_.bind(this),this.onChildDispose_=this.onChildDispose_.bind(this),this.onChildPositionsChange_=this.onChildPositionsChange_.bind(this),this.onChildInputChange_=this.onChildInputChange_.bind(this),this.onChildMonitorUpdate_=this.onChildMonitorUpdate_.bind(this),this.onChildValueChange_=this.onChildValueChange_.bind(this),this.onChildViewPropsChange_=this.onChildViewPropsChange_.bind(this),this.onDescendantLayout_=this.onDescendantLayout_.bind(this),this.onDescendantInputChange_=this.onDescendantInputChange_.bind(this),this.onDescendantMonitorUpdate_=this.onDescendantMonitorUpdate_.bind(this),this.emitter=new z,this.blade_=(t=e.blade)!==null&&t!==void 0?t:null,(l=this.blade_)===null||l===void 0||l.value("positions").emitter.on("change",this.onBladePositionsChange_),this.viewProps=e.viewProps,this.bcSet_=new vt(xs),this.bcSet_.emitter.on("add",this.onSetAdd_),this.bcSet_.emitter.on("remove",this.onSetRemove_)}get children(){return this.bcSet_.items}add(e,t){var l;(l=e.parent)===null||l===void 0||l.remove(e),M(e,"parent")?e.parent=this:(e.parent_=this,Ae({key:"parent",target:"BladeController",place:"BladeRack.add"})),this.bcSet_.add(e,t)}remove(e){M(e,"parent")?e.parent=null:(e.parent_=null,Ae({key:"parent",target:"BladeController",place:"BladeRack.remove"})),this.bcSet_.remove(e)}find(e){return this.bcSet_.allItems().filter(t=>t instanceof e)}onSetAdd_(e){this.updatePositions_();const t=e.target===e.root;if(this.emitter.emit("add",{bladeController:e.item,index:e.index,isRoot:t,sender:this}),!t)return;const l=e.item;if(l.viewProps.emitter.on("change",this.onChildViewPropsChange_),l.blade.value("positions").emitter.on("change",this.onChildPositionsChange_),l.viewProps.handleDispose(this.onChildDispose_),l instanceof Te)l.binding.emitter.on("change",this.onChildInputChange_);else if(l instanceof Ze)l.binding.emitter.on("update",this.onChildMonitorUpdate_);else if(l instanceof ie)l.value.emitter.on("change",this.onChildValueChange_);else{const b=Zn(l);if(b){const P=b.emitter;P.on("layout",this.onDescendantLayout_),P.on("inputchange",this.onDescendantInputChange_),P.on("monitorupdate",this.onDescendantMonitorUpdate_)}}}onSetRemove_(e){this.updatePositions_();const t=e.target===e.root;if(this.emitter.emit("remove",{bladeController:e.item,isRoot:t,sender:this}),!t)return;const l=e.item;if(l instanceof Te)l.binding.emitter.off("change",this.onChildInputChange_);else if(l instanceof Ze)l.binding.emitter.off("update",this.onChildMonitorUpdate_);else if(l instanceof ie)l.value.emitter.off("change",this.onChildValueChange_);else{const b=Zn(l);if(b){const P=b.emitter;P.off("layout",this.onDescendantLayout_),P.off("inputchange",this.onDescendantInputChange_),P.off("monitorupdate",this.onDescendantMonitorUpdate_)}}}updatePositions_(){const e=this.bcSet_.items.filter(b=>!b.viewProps.get("hidden")),t=e[0],l=e[e.length-1];this.bcSet_.items.forEach(b=>{const P=[];b===t&&(P.push("first"),(!this.blade_||this.blade_.get("positions").includes("veryfirst"))&&P.push("veryfirst")),b===l&&(P.push("last"),(!this.blade_||this.blade_.get("positions").includes("verylast"))&&P.push("verylast")),b.blade.set("positions",P)})}onChildPositionsChange_(){this.updatePositions_(),this.emitter.emit("layout",{sender:this})}onChildViewPropsChange_(e){this.updatePositions_(),this.emitter.emit("layout",{sender:this})}onChildDispose_(){this.bcSet_.items.filter(t=>t.viewProps.get("disposed")).forEach(t=>{this.bcSet_.remove(t)})}onChildInputChange_(e){const t=_s(this.find(Te),e.sender);if(!t)throw I.alreadyDisposed();this.emitter.emit("inputchange",{bladeController:t,options:e.options,sender:this})}onChildMonitorUpdate_(e){const t=ws(this.find(Ze),e.sender);if(!t)throw I.alreadyDisposed();this.emitter.emit("monitorupdate",{bladeController:t,sender:this})}onChildValueChange_(e){const t=ys(this.find(ie),e.sender);if(!t)throw I.alreadyDisposed();this.emitter.emit("inputchange",{bladeController:t,options:e.options,sender:this})}onDescendantLayout_(e){this.updatePositions_(),this.emitter.emit("layout",{sender:this})}onDescendantInputChange_(e){this.emitter.emit("inputchange",{bladeController:e.bladeController,options:e.options,sender:this})}onDescendantMonitorUpdate_(e){this.emitter.emit("monitorupdate",{bladeController:e.bladeController,sender:this})}onBladePositionsChange_(){this.updatePositions_()}}class Zt extends dt{constructor(e,t){super(Object.assign(Object.assign({},t),{view:new gs(e,{viewName:"brk",viewProps:t.viewProps})})),this.onRackAdd_=this.onRackAdd_.bind(this),this.onRackRemove_=this.onRackRemove_.bind(this);const l=new Cs({blade:t.root?void 0:t.blade,viewProps:t.viewProps});l.emitter.on("add",this.onRackAdd_),l.emitter.on("remove",this.onRackRemove_),this.rack=l,this.viewProps.handleDispose(()=>{for(let b=this.rack.children.length-1;b>=0;b--)this.rack.children[b].viewProps.set("disposed",!0)})}onRackAdd_(e){e.isRoot&&mt(this.view.element,e.bladeController.view.element,e.index)}onRackRemove_(e){e.isRoot&&wn(e.bladeController.view.element)}}const Si=N("cnt");class Ps{constructor(e,t){var l;this.className_=N((l=t.viewName)!==null&&l!==void 0?l:"fld"),this.element=e.createElement("div"),this.element.classList.add(this.className_(),Si()),t.viewProps.bindClassModifiers(this.element),this.foldable_=t.foldable,this.foldable_.bindExpandedClass(this.element,this.className_(void 0,"expanded")),F(this.foldable_,"completed",Y(this.element,this.className_(void 0,"cpl")));const b=e.createElement("button");b.classList.add(this.className_("b")),F(t.props,"title",H=>{w(H)?this.element.classList.add(this.className_(void 0,"not")):this.element.classList.remove(this.className_(void 0,"not"))}),t.viewProps.bindDisabled(b),this.element.appendChild(b),this.buttonElement=b;const P=e.createElement("div");P.classList.add(this.className_("i")),this.element.appendChild(P);const A=e.createElement("div");A.classList.add(this.className_("t")),Z(t.props.value("title"),A),this.buttonElement.appendChild(A),this.titleElement=A;const U=e.createElement("div");U.classList.add(this.className_("m")),this.buttonElement.appendChild(U);const W=t.containerElement;W.classList.add(this.className_("c")),this.element.appendChild(W),this.containerElement=W}}class Cn extends Qn{constructor(e,t){var l;const b=Ve.create((l=t.expanded)!==null&&l!==void 0?l:!0),P=new Zt(e,{blade:t.blade,root:t.root,viewProps:t.viewProps});super(Object.assign(Object.assign({},t),{rackController:P,view:new Ps(e,{containerElement:P.view.element,foldable:b,props:t.props,viewName:t.root?"rot":void 0,viewProps:t.viewProps})})),this.onTitleClick_=this.onTitleClick_.bind(this),this.props=t.props,this.foldable=b,Oe(this.foldable,this.view.containerElement),this.rackController.rack.emitter.on("add",()=>{this.foldable.cleanUpTransition()}),this.rackController.rack.emitter.on("remove",()=>{this.foldable.cleanUpTransition()}),this.view.buttonElement.addEventListener("click",this.onTitleClick_)}get document(){return this.view.element.ownerDocument}onTitleClick_(){this.foldable.set("expanded",!this.foldable.get("expanded"))}}const Ms={id:"folder",type:"blade",accept(n){const e=V,t=ce(n,{title:e.required.string,view:e.required.constant("folder"),expanded:e.optional.boolean});return t?{params:t}:null},controller(n){return new Cn(n.document,{blade:n.blade,expanded:n.params.expanded,props:q.fromObject({title:n.params.title}),viewProps:n.viewProps})},api(n){return n.controller instanceof Cn?new qn(n.controller,n.pool):null}};class Lt extends ie{constructor(e,t){const l=t.valueController.viewProps;super(Object.assign(Object.assign({},t),{value:t.valueController.value,view:new D(e,{props:t.props,viewProps:l}),viewProps:l})),this.props=t.props,this.valueController=t.valueController,this.view.valueElement.appendChild(this.valueController.view.element)}}class Li extends a{}const Wn=N("spr");class ks{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(Wn()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("hr");l.classList.add(Wn("r")),this.element.appendChild(l)}}class Wt extends dt{constructor(e,t){super(Object.assign(Object.assign({},t),{view:new ks(e,{viewProps:t.viewProps})}))}}const Ss={id:"separator",type:"blade",accept(n){const t=ce(n,{view:V.required.constant("separator")});return t?{params:t}:null},controller(n){return new Wt(n.document,{blade:n.blade,viewProps:n.viewProps})},api(n){return n.controller instanceof Wt?new Li(n.controller):null}},Se=N("tbi");class Ls{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(Se()),t.viewProps.bindClassModifiers(this.element),F(t.props,"selected",P=>{P?this.element.classList.add(Se(void 0,"sel")):this.element.classList.remove(Se(void 0,"sel"))});const l=e.createElement("button");l.classList.add(Se("b")),t.viewProps.bindDisabled(l),this.element.appendChild(l),this.buttonElement=l;const b=e.createElement("div");b.classList.add(Se("t")),Z(t.props.value("title"),b),this.buttonElement.appendChild(b),this.titleElement=b}}class Pn{constructor(e,t){this.emitter=new z,this.onClick_=this.onClick_.bind(this),this.props=t.props,this.viewProps=t.viewProps,this.view=new Ls(e,{props:t.props,viewProps:t.viewProps}),this.view.buttonElement.addEventListener("click",this.onClick_)}onClick_(){this.emitter.emit("click",{sender:this})}}class Ai{constructor(e,t){this.onItemClick_=this.onItemClick_.bind(this),this.ic_=new Pn(e,{props:t.itemProps,viewProps:ze.create()}),this.ic_.emitter.on("click",this.onItemClick_),this.cc_=new Zt(e,{blade:ye(),viewProps:ze.create()}),this.props=t.props,F(this.props,"selected",l=>{this.itemController.props.set("selected",l),this.contentController.viewProps.set("hidden",!l)})}get itemController(){return this.ic_}get contentController(){return this.cc_}onItemClick_(){this.props.set("selected",!0)}}class Jn{constructor(e,t){this.controller_=e,this.rackApi_=t}get title(){var e;return(e=this.controller_.itemController.props.get("title"))!==null&&e!==void 0?e:""}set title(e){this.controller_.itemController.props.set("title",e)}get selected(){return this.controller_.props.get("selected")}set selected(e){this.controller_.props.set("selected",e)}get children(){return this.rackApi_.children}addButton(e){return this.rackApi_.addButton(e)}addFolder(e){return this.rackApi_.addFolder(e)}addSeparator(e){return this.rackApi_.addSeparator(e)}addTab(e){return this.rackApi_.addTab(e)}add(e,t){this.rackApi_.add(e,t)}remove(e){this.rackApi_.remove(e)}addInput(e,t,l){return this.rackApi_.addInput(e,t,l)}addMonitor(e,t,l){return this.rackApi_.addMonitor(e,t,l)}addBlade(e){return this.rackApi_.addBlade(e)}}class Vi extends Be{constructor(e,t){super(e,new xn(e.rackController,t)),this.onPageAdd_=this.onPageAdd_.bind(this),this.onPageRemove_=this.onPageRemove_.bind(this),this.onSelect_=this.onSelect_.bind(this),this.emitter_=new z,this.pageApiMap_=new Map,this.rackApi_.on("change",l=>{this.emitter_.emit("change",{event:l})}),this.rackApi_.on("update",l=>{this.emitter_.emit("update",{event:l})}),this.controller_.tab.selectedIndex.emitter.on("change",this.onSelect_),this.controller_.pageSet.emitter.on("add",this.onPageAdd_),this.controller_.pageSet.emitter.on("remove",this.onPageRemove_),this.controller_.pageSet.items.forEach(l=>{this.setUpPageApi_(l)})}get pages(){return this.controller_.pageSet.items.map(e=>{const t=this.pageApiMap_.get(e);if(!t)throw I.shouldNeverHappen();return t})}addPage(e){const t=this.controller_.view.element.ownerDocument,l=new Ai(t,{itemProps:q.fromObject({selected:!1,title:e.title}),props:q.fromObject({selected:!1})});this.controller_.add(l,e.index);const b=this.pageApiMap_.get(l);if(!b)throw I.shouldNeverHappen();return b}removePage(e){this.controller_.remove(e)}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}setUpPageApi_(e){const t=this.rackApi_.apiSet_.find(b=>b.controller_===e.contentController);if(!t)throw I.shouldNeverHappen();const l=new Jn(e,t);this.pageApiMap_.set(e,l)}onPageAdd_(e){this.setUpPageApi_(e.item)}onPageRemove_(e){if(!this.pageApiMap_.get(e.item))throw I.shouldNeverHappen();this.pageApiMap_.delete(e.item)}onSelect_(e){this.emitter_.emit("select",{event:new _(this,e.rawValue)})}}const Ii=-1;class As{constructor(){this.onItemSelectedChange_=this.onItemSelectedChange_.bind(this),this.empty=ee(!0),this.selectedIndex=ee(Ii),this.items_=[]}add(e,t){const l=t??this.items_.length;this.items_.splice(l,0,e),e.emitter.on("change",this.onItemSelectedChange_),this.keepSelection_()}remove(e){const t=this.items_.indexOf(e);t<0||(this.items_.splice(t,1),e.emitter.off("change",this.onItemSelectedChange_),this.keepSelection_())}keepSelection_(){if(this.items_.length===0){this.selectedIndex.rawValue=Ii,this.empty.rawValue=!0;return}const e=this.items_.findIndex(t=>t.rawValue);e<0?(this.items_.forEach((t,l)=>{t.rawValue=l===0}),this.selectedIndex.rawValue=0):(this.items_.forEach((t,l)=>{t.rawValue=l===e}),this.selectedIndex.rawValue=e),this.empty.rawValue=!1}onItemSelectedChange_(e){if(e.rawValue){const t=this.items_.findIndex(l=>l===e.sender);this.items_.forEach((l,b)=>{l.rawValue=b===t}),this.selectedIndex.rawValue=t}else this.keepSelection_()}}const At=N("tab");class Vt{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(At(),Si()),t.viewProps.bindClassModifiers(this.element),j(t.empty,Y(this.element,At(void 0,"nop")));const l=e.createElement("div");l.classList.add(At("t")),this.element.appendChild(l),this.itemsElement=l;const b=e.createElement("div");b.classList.add(At("i")),this.element.appendChild(b);const P=t.contentsElement;P.classList.add(At("c")),this.element.appendChild(P),this.contentsElement=P}}class Jt extends Qn{constructor(e,t){const l=new Zt(e,{blade:t.blade,viewProps:t.viewProps}),b=new As;super({blade:t.blade,rackController:l,view:new Vt(e,{contentsElement:l.view.element,empty:b.empty,viewProps:t.viewProps})}),this.onPageAdd_=this.onPageAdd_.bind(this),this.onPageRemove_=this.onPageRemove_.bind(this),this.pageSet_=new vt(()=>null),this.pageSet_.emitter.on("add",this.onPageAdd_),this.pageSet_.emitter.on("remove",this.onPageRemove_),this.tab=b}get pageSet(){return this.pageSet_}add(e,t){this.pageSet_.add(e,t)}remove(e){this.pageSet_.remove(this.pageSet_.items[e])}onPageAdd_(e){const t=e.item;mt(this.view.itemsElement,t.itemController.view.element,e.index),t.itemController.viewProps.set("parent",this.viewProps),this.rackController.rack.add(t.contentController,e.index),this.tab.add(t.props.value("selected"))}onPageRemove_(e){const t=e.item;wn(t.itemController.view.element),t.itemController.viewProps.set("parent",null),this.rackController.rack.remove(t.contentController),this.tab.remove(t.props.value("selected"))}}const Hn={id:"tab",type:"blade",accept(n){const e=V,t=ce(n,{pages:e.required.array(e.required.object({title:e.required.string})),view:e.required.constant("tab")});return!t||t.pages.length===0?null:{params:t}},controller(n){const e=new Jt(n.document,{blade:n.blade,viewProps:n.viewProps});return n.params.pages.forEach(t=>{const l=new Ai(n.document,{itemProps:q.fromObject({selected:!1,title:t.title}),props:q.fromObject({selected:!1})});e.add(l)}),e},api(n){return n.controller instanceof Jt?new Vi(n.controller,n.pool):null}};function Vs(n,e){const t=n.accept(e.params);if(!t)return null;const l=V.optional.boolean(e.params.disabled).value,b=V.optional.boolean(e.params.hidden).value;return n.controller({blade:ye(),document:e.document,params:Object.assign(Object.assign({},t.params),{disabled:l,hidden:b}),viewProps:ze.create({disabled:l,hidden:b})})}class Di{constructor(){this.disabled=!1,this.emitter=new z}dispose(){}tick(){this.disabled||this.emitter.emit("tick",{sender:this})}}class ei{constructor(e,t){this.disabled_=!1,this.timerId_=null,this.onTick_=this.onTick_.bind(this),this.doc_=e,this.emitter=new z,this.interval_=t,this.setTimer_()}get disabled(){return this.disabled_}set disabled(e){this.disabled_=e,this.disabled_?this.clearTimer_():this.setTimer_()}dispose(){this.clearTimer_()}clearTimer_(){if(this.timerId_===null)return;const e=this.doc_.defaultView;e&&e.clearInterval(this.timerId_),this.timerId_=null}setTimer_(){if(this.clearTimer_(),this.interval_<=0)return;const e=this.doc_.defaultView;e&&(this.timerId_=e.setInterval(this.onTick_,this.interval_))}onTick_(){this.disabled_||this.emitter.emit("tick",{sender:this})}}class Mn{constructor(e){this.onValueChange_=this.onValueChange_.bind(this),this.reader=e.reader,this.writer=e.writer,this.emitter=new z,this.value=e.value,this.value.emitter.on("change",this.onValueChange_),this.target=e.target,this.read()}read(){const e=this.target.read();e!==void 0&&(this.value.rawValue=this.reader(e))}write_(e){this.writer(this.target,e)}onValueChange_(e){this.write_(e.rawValue),this.emitter.emit("change",{options:e.options,rawValue:e.rawValue,sender:this})}}function Pe(n,e){for(;n.length<e;)n.push(void 0)}function Ti(n){const e=[];return Pe(e,n),ee(e)}function It(n){const e=n.indexOf(void 0);return e<0?n:n.slice(0,e)}function Ue(n,e){const t=[...It(n),e];return t.length>n.length?t.splice(0,t.length-n.length):Pe(t,n.length),t}class Is{constructor(e){this.onTick_=this.onTick_.bind(this),this.reader_=e.reader,this.target=e.target,this.emitter=new z,this.value=e.value,this.ticker=e.ticker,this.ticker.emitter.on("tick",this.onTick_),this.read()}dispose(){this.ticker.dispose()}read(){const e=this.target.read();if(e===void 0)return;const t=this.value.rawValue,l=this.reader_(e);this.value.rawValue=Ue(t,l),this.emitter.emit("update",{rawValue:l,sender:this})}onTick_(e){this.read()}}class Ht{constructor(e){this.constraints=e}constrain(e){return this.constraints.reduce((t,l)=>l.constrain(t),e)}}function $e(n,e){if(n instanceof e)return n;if(n instanceof Ht){const t=n.constraints.reduce((l,b)=>l||(b instanceof e?b:null),null);if(t)return t}return null}class Dt{constructor(e){this.values=q.fromObject({max:e.max,min:e.min})}constrain(e){const t=this.values.get("max"),l=this.values.get("min");return Math.min(Math.max(e,l),t)}}class en{constructor(e){this.values=q.fromObject({options:e})}get options(){return this.values.get("options")}constrain(e){const t=this.values.get("options");return t.length===0||t.filter(b=>b.value===e).length>0?e:t[0].value}}class ti{constructor(e){this.values=q.fromObject({max:e.max,min:e.min})}get maxValue(){return this.values.get("max")}get minValue(){return this.values.get("min")}constrain(e){const t=this.values.get("max"),l=this.values.get("min");let b=e;return w(l)||(b=Math.max(b,l)),w(t)||(b=Math.min(b,t)),b}}class kn{constructor(e,t=0){this.step=e,this.origin=t}constrain(e){const t=this.origin%this.step,l=Math.round((e-t)/this.step);return t+l*this.step}}const Tt=N("lst");class Ei{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),this.props_=t.props,this.element=e.createElement("div"),this.element.classList.add(Tt()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("select");l.classList.add(Tt("s")),F(this.props_,"options",P=>{Yt(l),P.forEach((A,U)=>{const W=e.createElement("option");W.dataset.index=String(U),W.textContent=A.text,W.value=String(A.value),l.appendChild(W)})}),t.viewProps.bindDisabled(l),this.element.appendChild(l),this.selectElement=l;const b=e.createElement("div");b.classList.add(Tt("m")),b.appendChild(at(e,"dropdown")),this.element.appendChild(b),t.value.emitter.on("change",this.onValueChange_),this.value_=t.value,this.update_()}update_(){this.selectElement.value=String(this.value_.rawValue)}onValueChange_(){this.update_()}}class tn{constructor(e,t){this.onSelectChange_=this.onSelectChange_.bind(this),this.props=t.props,this.value=t.value,this.viewProps=t.viewProps,this.view=new Ei(e,{props:this.props,value:this.value,viewProps:this.viewProps}),this.view.selectElement.addEventListener("change",this.onSelectChange_)}onSelectChange_(e){const l=e.currentTarget.selectedOptions.item(0);if(!l)return;const b=Number(l.dataset.index);this.value.rawValue=this.props.get("options")[b].value}}const Oi=N("pop");class Ds{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(Oi()),t.viewProps.bindClassModifiers(this.element),j(t.shows,Y(this.element,Oi(void 0,"v")))}}class Bi{constructor(e,t){this.shows=ee(!1),this.viewProps=t.viewProps,this.view=new Ds(e,{shows:this.shows,viewProps:this.viewProps})}}const Ni=N("txt");class Ts{constructor(e,t){this.onChange_=this.onChange_.bind(this),this.element=e.createElement("div"),this.element.classList.add(Ni()),t.viewProps.bindClassModifiers(this.element),this.props_=t.props,this.props_.emitter.on("change",this.onChange_);const l=e.createElement("input");l.classList.add(Ni("i")),l.type="text",t.viewProps.bindDisabled(l),this.element.appendChild(l),this.inputElement=l,t.value.emitter.on("change",this.onChange_),this.value_=t.value,this.refresh()}refresh(){const e=this.props_.get("formatter");this.inputElement.value=e(this.value_.rawValue)}onChange_(){this.refresh()}}class Sn{constructor(e,t){this.onInputChange_=this.onInputChange_.bind(this),this.parser_=t.parser,this.props=t.props,this.value=t.value,this.viewProps=t.viewProps,this.view=new Ts(e,{props:t.props,value:this.value,viewProps:this.viewProps}),this.view.inputElement.addEventListener("change",this.onInputChange_)}onInputChange_(e){const l=e.currentTarget.value,b=this.parser_(l);w(b)||(this.value.rawValue=b),this.view.refresh()}}function Es(n){return String(n)}function Fi(n){return n==="false"?!1:!!n}function ji(n){return Es(n)}class Os{constructor(e){this.text=e}evaluate(){return Number(this.text)}toString(){return this.text}}const Bs={"**":(n,e)=>Math.pow(n,e),"*":(n,e)=>n*e,"/":(n,e)=>n/e,"%":(n,e)=>n%e,"+":(n,e)=>n+e,"-":(n,e)=>n-e,"<<":(n,e)=>n<<e,">>":(n,e)=>n>>e,">>>":(n,e)=>n>>>e,"&":(n,e)=>n&e,"^":(n,e)=>n^e,"|":(n,e)=>n|e};class Ns{constructor(e,t,l){this.left=t,this.operator=e,this.right=l}evaluate(){const e=Bs[this.operator];if(!e)throw new Error(`unexpected binary operator: '${this.operator}`);return e(this.left.evaluate(),this.right.evaluate())}toString(){return["b(",this.left.toString(),this.operator,this.right.toString(),")"].join(" ")}}const zi={"+":n=>n,"-":n=>-n,"~":n=>~n};class Fs{constructor(e,t){this.operator=e,this.expression=t}evaluate(){const e=zi[this.operator];if(!e)throw new Error(`unexpected unary operator: '${this.operator}`);return e(this.expression.evaluate())}toString(){return["u(",this.operator,this.expression.toString(),")"].join(" ")}}function ni(n){return(e,t)=>{for(let l=0;l<n.length;l++){const b=n[l](e,t);if(b!=="")return b}return""}}function bt(n,e){var t;const l=n.substr(e).match(/^\s+/);return(t=l&&l[0])!==null&&t!==void 0?t:""}function js(n,e){const t=n.substr(e,1);return t.match(/^[1-9]$/)?t:""}function nn(n,e){var t;const l=n.substr(e).match(/^[0-9]+/);return(t=l&&l[0])!==null&&t!==void 0?t:""}function zs(n,e){const t=nn(n,e);if(t!=="")return t;const l=n.substr(e,1);if(e+=1,l!=="-"&&l!=="+")return"";const b=nn(n,e);return b===""?"":l+b}function We(n,e){const t=n.substr(e,1);if(e+=1,t.toLowerCase()!=="e")return"";const l=zs(n,e);return l===""?"":t+l}function Ui(n,e){const t=n.substr(e,1);if(t==="0")return t;const l=js(n,e);return e+=l.length,l===""?"":l+nn(n,e)}function Us(n,e){const t=Ui(n,e);if(e+=t.length,t==="")return"";const l=n.substr(e,1);if(e+=l.length,l!==".")return"";const b=nn(n,e);return e+=b.length,t+l+b+We(n,e)}function Ri(n,e){const t=n.substr(e,1);if(e+=t.length,t!==".")return"";const l=nn(n,e);return e+=l.length,l===""?"":t+l+We(n,e)}function Rs(n,e){const t=Ui(n,e);return e+=t.length,t===""?"":t+We(n,e)}const Gi=ni([Us,Ri,Rs]);function ii(n,e){var t;const l=n.substr(e).match(/^[01]+/);return(t=l&&l[0])!==null&&t!==void 0?t:""}function Gs(n,e){const t=n.substr(e,2);if(e+=t.length,t.toLowerCase()!=="0b")return"";const l=ii(n,e);return l===""?"":t+l}function Ki(n,e){var t;const l=n.substr(e).match(/^[0-7]+/);return(t=l&&l[0])!==null&&t!==void 0?t:""}function Re(n,e){const t=n.substr(e,2);if(e+=t.length,t.toLowerCase()!=="0o")return"";const l=Ki(n,e);return l===""?"":t+l}function Ks(n,e){var t;const l=n.substr(e).match(/^[0-9a-f]+/i);return(t=l&&l[0])!==null&&t!==void 0?t:""}function $s(n,e){const t=n.substr(e,2);if(e+=t.length,t.toLowerCase()!=="0x")return"";const l=Ks(n,e);return l===""?"":t+l}const si=ni([Gs,Re,$s]),Xs=ni([si,Gi]);function ct(n,e){const t=Xs(n,e);return e+=t.length,t===""?null:{evaluable:new Os(t),cursor:e}}function ri(n,e){const t=n.substr(e,1);if(e+=t.length,t!=="(")return null;const l=Ln(n,e);if(!l)return null;e=l.cursor,e+=bt(n,e).length;const b=n.substr(e,1);return e+=b.length,b!==")"?null:{evaluable:l.evaluable,cursor:e}}function Ys(n,e){var t;return(t=ct(n,e))!==null&&t!==void 0?t:ri(n,e)}function oi(n,e){const t=Ys(n,e);if(t)return t;const l=n.substr(e,1);if(e+=l.length,l!=="+"&&l!=="-"&&l!=="~")return null;const b=oi(n,e);return b?(e=b.cursor,{cursor:e,evaluable:new Fs(l,b.evaluable)}):null}function qs(n,e,t){t+=bt(e,t).length;const l=n.filter(b=>e.startsWith(b,t))[0];return l?(t+=l.length,t+=bt(e,t).length,{cursor:t,operator:l}):null}function gt(n,e){return(t,l)=>{const b=n(t,l);if(!b)return null;l=b.cursor;let P=b.evaluable;for(;;){const A=qs(e,t,l);if(!A)break;l=A.cursor;const U=n(t,l);if(!U)return null;l=U.cursor,P=new Ns(A.operator,P,U.evaluable)}return P?{cursor:l,evaluable:P}:null}}const $i=[["**"],["*","/","%"],["+","-"],["<<",">>>",">>"],["&"],["^"],["|"]].reduce((n,e)=>gt(n,e),oi);function Ln(n,e){return e+=bt(n,e).length,$i(n,e)}function Xi(n){const e=Ln(n,0);return!e||e.cursor+bt(n,e.cursor).length!==n.length?null:e.evaluable}function Je(n){var e;const t=Xi(n);return(e=t==null?void 0:t.evaluate())!==null&&e!==void 0?e:null}function rt(n){if(typeof n=="number")return n;if(typeof n=="string"){const e=Je(n);if(!w(e))return e}return 0}function Qs(n){return String(n)}function Le(n){return e=>e.toFixed(Math.max(Math.min(n,20),0))}const Yi=Le(0);function sn(n){return Yi(n)+"%"}function ai(n){return String(n)}function pt(n){return n}function Et({primary:n,secondary:e,forward:t,backward:l}){let b=!1;function P(A){b||(b=!0,A(),b=!1)}n.emitter.on("change",A=>{P(()=>{e.setRawValue(t(n,e),A.options)})}),e.emitter.on("change",A=>{P(()=>{n.setRawValue(l(n,e),A.options)}),P(()=>{e.setRawValue(t(n,e),A.options)})}),P(()=>{e.setRawValue(t(n,e),{forceEmit:!1,last:!0})})}function Ie(n,e){const t=n*(e.altKey?.1:1)*(e.shiftKey?10:1);return e.upKey?+t:e.downKey?-t:0}function rn(n){return{altKey:n.altKey,downKey:n.key==="ArrowDown",shiftKey:n.shiftKey,upKey:n.key==="ArrowUp"}}function He(n){return{altKey:n.altKey,downKey:n.key==="ArrowLeft",shiftKey:n.shiftKey,upKey:n.key==="ArrowRight"}}function qi(n){return n==="ArrowUp"||n==="ArrowDown"}function An(n){return qi(n)||n==="ArrowLeft"||n==="ArrowRight"}function li(n,e){var t,l;const b=e.ownerDocument.defaultView,P=e.getBoundingClientRect();return{x:n.pageX-(((t=b&&b.scrollX)!==null&&t!==void 0?t:0)+P.left),y:n.pageY-(((l=b&&b.scrollY)!==null&&l!==void 0?l:0)+P.top)}}class _t{constructor(e){this.lastTouch_=null,this.onDocumentMouseMove_=this.onDocumentMouseMove_.bind(this),this.onDocumentMouseUp_=this.onDocumentMouseUp_.bind(this),this.onMouseDown_=this.onMouseDown_.bind(this),this.onTouchEnd_=this.onTouchEnd_.bind(this),this.onTouchMove_=this.onTouchMove_.bind(this),this.onTouchStart_=this.onTouchStart_.bind(this),this.elem_=e,this.emitter=new z,e.addEventListener("touchstart",this.onTouchStart_,{passive:!1}),e.addEventListener("touchmove",this.onTouchMove_,{passive:!0}),e.addEventListener("touchend",this.onTouchEnd_),e.addEventListener("mousedown",this.onMouseDown_)}computePosition_(e){const t=this.elem_.getBoundingClientRect();return{bounds:{width:t.width,height:t.height},point:e?{x:e.x,y:e.y}:null}}onMouseDown_(e){var t;e.preventDefault(),(t=e.currentTarget)===null||t===void 0||t.focus();const l=this.elem_.ownerDocument;l.addEventListener("mousemove",this.onDocumentMouseMove_),l.addEventListener("mouseup",this.onDocumentMouseUp_),this.emitter.emit("down",{altKey:e.altKey,data:this.computePosition_(li(e,this.elem_)),sender:this,shiftKey:e.shiftKey})}onDocumentMouseMove_(e){this.emitter.emit("move",{altKey:e.altKey,data:this.computePosition_(li(e,this.elem_)),sender:this,shiftKey:e.shiftKey})}onDocumentMouseUp_(e){const t=this.elem_.ownerDocument;t.removeEventListener("mousemove",this.onDocumentMouseMove_),t.removeEventListener("mouseup",this.onDocumentMouseUp_),this.emitter.emit("up",{altKey:e.altKey,data:this.computePosition_(li(e,this.elem_)),sender:this,shiftKey:e.shiftKey})}onTouchStart_(e){e.preventDefault();const t=e.targetTouches.item(0),l=this.elem_.getBoundingClientRect();this.emitter.emit("down",{altKey:e.altKey,data:this.computePosition_(t?{x:t.clientX-l.left,y:t.clientY-l.top}:void 0),sender:this,shiftKey:e.shiftKey}),this.lastTouch_=t}onTouchMove_(e){const t=e.targetTouches.item(0),l=this.elem_.getBoundingClientRect();this.emitter.emit("move",{altKey:e.altKey,data:this.computePosition_(t?{x:t.clientX-l.left,y:t.clientY-l.top}:void 0),sender:this,shiftKey:e.shiftKey}),this.lastTouch_=t}onTouchEnd_(e){var t;const l=(t=e.targetTouches.item(0))!==null&&t!==void 0?t:this.lastTouch_,b=this.elem_.getBoundingClientRect();this.emitter.emit("up",{altKey:e.altKey,data:this.computePosition_(l?{x:l.clientX-b.left,y:l.clientY-b.top}:void 0),sender:this,shiftKey:e.shiftKey})}}function _e(n,e,t,l,b){const P=(n-e)/(t-e);return l+P*(b-l)}function ci(n){return String(n.toFixed(10)).split(".")[1].replace(/0+$/,"").length}function Me(n,e,t){return Math.min(Math.max(n,e),t)}function Ot(n,e){return(n%e+e)%e}const Ne=N("txt");class pi{constructor(e,t){this.onChange_=this.onChange_.bind(this),this.props_=t.props,this.props_.emitter.on("change",this.onChange_),this.element=e.createElement("div"),this.element.classList.add(Ne(),Ne(void 0,"num")),t.arrayPosition&&this.element.classList.add(Ne(void 0,t.arrayPosition)),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("input");l.classList.add(Ne("i")),l.type="text",t.viewProps.bindDisabled(l),this.element.appendChild(l),this.inputElement=l,this.onDraggingChange_=this.onDraggingChange_.bind(this),this.dragging_=t.dragging,this.dragging_.emitter.on("change",this.onDraggingChange_),this.element.classList.add(Ne()),this.inputElement.classList.add(Ne("i"));const b=e.createElement("div");b.classList.add(Ne("k")),this.element.appendChild(b),this.knobElement=b;const P=e.createElementNS(Ee,"svg");P.classList.add(Ne("g")),this.knobElement.appendChild(P);const A=e.createElementNS(Ee,"path");A.classList.add(Ne("gb")),P.appendChild(A),this.guideBodyElem_=A;const U=e.createElementNS(Ee,"path");U.classList.add(Ne("gh")),P.appendChild(U),this.guideHeadElem_=U;const W=e.createElement("div");W.classList.add(N("tt")()),this.knobElement.appendChild(W),this.tooltipElem_=W,t.value.emitter.on("change",this.onChange_),this.value=t.value,this.refresh()}onDraggingChange_(e){if(e.rawValue===null){this.element.classList.remove(Ne(void 0,"drg"));return}this.element.classList.add(Ne(void 0,"drg"));const t=e.rawValue/this.props_.get("draggingScale"),l=t+(t>0?-1:t<0?1:0),b=Me(-l,-4,4);this.guideHeadElem_.setAttributeNS(null,"d",[`M ${l+b},0 L${l},4 L${l+b},8`,`M ${t},-1 L${t},9`].join(" ")),this.guideBodyElem_.setAttributeNS(null,"d",`M 0,4 L${t},4`);const P=this.props_.get("formatter");this.tooltipElem_.textContent=P(this.value.rawValue),this.tooltipElem_.style.left=`${t}px`}refresh(){const e=this.props_.get("formatter");this.inputElement.value=e(this.value.rawValue)}onChange_(){this.refresh()}}class on{constructor(e,t){var l;this.originRawValue_=0,this.onInputChange_=this.onInputChange_.bind(this),this.onInputKeyDown_=this.onInputKeyDown_.bind(this),this.onInputKeyUp_=this.onInputKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.baseStep_=t.baseStep,this.parser_=t.parser,this.props=t.props,this.sliderProps_=(l=t.sliderProps)!==null&&l!==void 0?l:null,this.value=t.value,this.viewProps=t.viewProps,this.dragging_=ee(null),this.view=new pi(e,{arrayPosition:t.arrayPosition,dragging:this.dragging_,props:this.props,value:this.value,viewProps:this.viewProps}),this.view.inputElement.addEventListener("change",this.onInputChange_),this.view.inputElement.addEventListener("keydown",this.onInputKeyDown_),this.view.inputElement.addEventListener("keyup",this.onInputKeyUp_);const b=new _t(this.view.knobElement);b.emitter.on("down",this.onPointerDown_),b.emitter.on("move",this.onPointerMove_),b.emitter.on("up",this.onPointerUp_)}constrainValue_(e){var t,l;const b=(t=this.sliderProps_)===null||t===void 0?void 0:t.get("minValue"),P=(l=this.sliderProps_)===null||l===void 0?void 0:l.get("maxValue");let A=e;return b!==void 0&&(A=Math.max(A,b)),P!==void 0&&(A=Math.min(A,P)),A}onInputChange_(e){const l=e.currentTarget.value,b=this.parser_(l);w(b)||(this.value.rawValue=this.constrainValue_(b)),this.view.refresh()}onInputKeyDown_(e){const t=Ie(this.baseStep_,rn(e));t!==0&&this.value.setRawValue(this.constrainValue_(this.value.rawValue+t),{forceEmit:!1,last:!1})}onInputKeyUp_(e){Ie(this.baseStep_,rn(e))!==0&&this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}onPointerDown_(){this.originRawValue_=this.value.rawValue,this.dragging_.rawValue=0}computeDraggingValue_(e){if(!e.point)return null;const t=e.point.x-e.bounds.width/2;return this.constrainValue_(this.originRawValue_+t*this.props.get("draggingScale"))}onPointerMove_(e){const t=this.computeDraggingValue_(e.data);t!==null&&(this.value.setRawValue(t,{forceEmit:!1,last:!1}),this.dragging_.rawValue=this.value.rawValue-this.originRawValue_)}onPointerUp_(e){const t=this.computeDraggingValue_(e.data);t!==null&&(this.value.setRawValue(t,{forceEmit:!0,last:!0}),this.dragging_.rawValue=null)}}const ui=N("sld");class Fe{constructor(e,t){this.onChange_=this.onChange_.bind(this),this.props_=t.props,this.props_.emitter.on("change",this.onChange_),this.element=e.createElement("div"),this.element.classList.add(ui()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(ui("t")),t.viewProps.bindTabIndex(l),this.element.appendChild(l),this.trackElement=l;const b=e.createElement("div");b.classList.add(ui("k")),this.trackElement.appendChild(b),this.knobElement=b,t.value.emitter.on("change",this.onChange_),this.value=t.value,this.update_()}update_(){const e=Me(_e(this.value.rawValue,this.props_.get("minValue"),this.props_.get("maxValue"),0,100),0,100);this.knobElement.style.width=`${e}%`}onChange_(){this.update_()}}class hi{constructor(e,t){this.onKeyDown_=this.onKeyDown_.bind(this),this.onKeyUp_=this.onKeyUp_.bind(this),this.onPointerDownOrMove_=this.onPointerDownOrMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.baseStep_=t.baseStep,this.value=t.value,this.viewProps=t.viewProps,this.props=t.props,this.view=new Fe(e,{props:this.props,value:this.value,viewProps:this.viewProps}),this.ptHandler_=new _t(this.view.trackElement),this.ptHandler_.emitter.on("down",this.onPointerDownOrMove_),this.ptHandler_.emitter.on("move",this.onPointerDownOrMove_),this.ptHandler_.emitter.on("up",this.onPointerUp_),this.view.trackElement.addEventListener("keydown",this.onKeyDown_),this.view.trackElement.addEventListener("keyup",this.onKeyUp_)}handlePointerEvent_(e,t){e.point&&this.value.setRawValue(_e(Me(e.point.x,0,e.bounds.width),0,e.bounds.width,this.props.get("minValue"),this.props.get("maxValue")),t)}onPointerDownOrMove_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerUp_(e){this.handlePointerEvent_(e.data,{forceEmit:!0,last:!0})}onKeyDown_(e){const t=Ie(this.baseStep_,He(e));t!==0&&this.value.setRawValue(this.value.rawValue+t,{forceEmit:!1,last:!1})}onKeyUp_(e){Ie(this.baseStep_,He(e))!==0&&this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}const an=N("sldtxt");class di{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(an());const l=e.createElement("div");l.classList.add(an("s")),this.sliderView_=t.sliderView,l.appendChild(this.sliderView_.element),this.element.appendChild(l);const b=e.createElement("div");b.classList.add(an("t")),this.textView_=t.textView,b.appendChild(this.textView_.element),this.element.appendChild(b)}}class Vn{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.sliderC_=new hi(e,{baseStep:t.baseStep,props:t.sliderProps,value:t.value,viewProps:this.viewProps}),this.textC_=new on(e,{baseStep:t.baseStep,parser:t.parser,props:t.textProps,sliderProps:t.sliderProps,value:t.value,viewProps:t.viewProps}),this.view=new di(e,{sliderView:this.sliderC_.view,textView:this.textC_.view})}get sliderController(){return this.sliderC_}get textController(){return this.textC_}}function Xe(n,e){n.write(e)}function ln(n){const e=V;if(Array.isArray(n))return e.required.array(e.required.object({text:e.required.string,value:e.required.raw}))(n).value;if(typeof n=="object")return e.required.raw(n).value}function mi(n){if(n==="inline"||n==="popup")return n}function ot(n){const e=V;return e.required.object({max:e.optional.number,min:e.optional.number,step:e.optional.number})(n).value}function Qi(n){if(Array.isArray(n))return n;const e=[];return Object.keys(n).forEach(t=>{e.push({text:t,value:n[t]})}),e}function fi(n){return w(n)?null:new en(Qi(n))}function Zs(n){const e=n?$e(n,kn):null;return e?e.step:null}function In(n,e){const t=n&&$e(n,kn);return t?ci(t.step):Math.max(ci(e),2)}function wt(n){const e=Zs(n);return e??1}function yt(n,e){var t;const l=n&&$e(n,kn),b=Math.abs((t=l==null?void 0:l.step)!==null&&t!==void 0?t:e);return b===0?.1:Math.pow(10,Math.floor(Math.log10(b))-1)}const cn=N("ckb");class pn{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),this.element=e.createElement("div"),this.element.classList.add(cn()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("label");l.classList.add(cn("l")),this.element.appendChild(l);const b=e.createElement("input");b.classList.add(cn("i")),b.type="checkbox",l.appendChild(b),this.inputElement=b,t.viewProps.bindDisabled(this.inputElement);const P=e.createElement("div");P.classList.add(cn("w")),l.appendChild(P);const A=at(e,"check");P.appendChild(A),t.value.emitter.on("change",this.onValueChange_),this.value=t.value,this.update_()}update_(){this.inputElement.checked=this.value.rawValue}onValueChange_(){this.update_()}}class Zi{constructor(e,t){this.onInputChange_=this.onInputChange_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.view=new pn(e,{value:this.value,viewProps:this.viewProps}),this.view.inputElement.addEventListener("change",this.onInputChange_)}onInputChange_(e){const t=e.currentTarget;this.value.rawValue=t.checked}}function Wi(n){const e=[],t=fi(n.options);return t&&e.push(t),new Ht(e)}const Dn={id:"input-bool",type:"input",accept:(n,e)=>{if(typeof n!="boolean")return null;const l=ce(e,{options:V.optional.custom(ln)});return l?{initialValue:n,params:l}:null},binding:{reader:n=>Fi,constraint:n=>Wi(n.params),writer:n=>Xe},controller:n=>{const e=n.document,t=n.value,l=n.constraint,b=l&&$e(l,en);return b?new tn(e,{props:new q({options:b.values.value("options")}),value:t,viewProps:n.viewProps}):new Zi(e,{value:t,viewProps:n.viewProps})}},xt=N("col");class vi{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(xt()),t.foldable.bindExpandedClass(this.element,xt(void 0,"expanded")),F(t.foldable,"completed",Y(this.element,xt(void 0,"cpl")));const l=e.createElement("div");l.classList.add(xt("h")),this.element.appendChild(l);const b=e.createElement("div");b.classList.add(xt("s")),l.appendChild(b),this.swatchElement=b;const P=e.createElement("div");if(P.classList.add(xt("t")),l.appendChild(P),this.textElement=P,t.pickerLayout==="inline"){const A=e.createElement("div");A.classList.add(xt("p")),this.element.appendChild(A),this.pickerElement=A}else this.pickerElement=null}}function Ws(n,e,t){const l=Me(n/255,0,1),b=Me(e/255,0,1),P=Me(t/255,0,1),A=Math.max(l,b,P),U=Math.min(l,b,P),W=A-U;let H=0,de=0;const ve=(U+A)/2;return W!==0&&(de=W/(1-Math.abs(A+U-1)),l===A?H=(b-P)/W:b===A?H=2+(P-l)/W:H=4+(l-b)/W,H=H/6+(H<0?1:0)),[H*360,de*100,ve*100]}function Js(n,e,t){const l=(n%360+360)%360,b=Me(e/100,0,1),P=Me(t/100,0,1),A=(1-Math.abs(2*P-1))*b,U=A*(1-Math.abs(l/60%2-1)),W=P-A/2;let H,de,ve;return l>=0&&l<60?[H,de,ve]=[A,U,0]:l>=60&&l<120?[H,de,ve]=[U,A,0]:l>=120&&l<180?[H,de,ve]=[0,A,U]:l>=180&&l<240?[H,de,ve]=[0,U,A]:l>=240&&l<300?[H,de,ve]=[U,0,A]:[H,de,ve]=[A,0,U],[(H+W)*255,(de+W)*255,(ve+W)*255]}function Hs(n,e,t){const l=Me(n/255,0,1),b=Me(e/255,0,1),P=Me(t/255,0,1),A=Math.max(l,b,P),U=Math.min(l,b,P),W=A-U;let H;W===0?H=0:A===l?H=60*(((b-P)/W%6+6)%6):A===b?H=60*((P-l)/W+2):H=60*((l-b)/W+4);const de=A===0?0:W/A,ve=A;return[H,de*100,ve*100]}function Ji(n,e,t){const l=Ot(n,360),b=Me(e/100,0,1),P=Me(t/100,0,1),A=P*b,U=A*(1-Math.abs(l/60%2-1)),W=P-A;let H,de,ve;return l>=0&&l<60?[H,de,ve]=[A,U,0]:l>=60&&l<120?[H,de,ve]=[U,A,0]:l>=120&&l<180?[H,de,ve]=[0,A,U]:l>=180&&l<240?[H,de,ve]=[0,U,A]:l>=240&&l<300?[H,de,ve]=[U,0,A]:[H,de,ve]=[A,0,U],[(H+W)*255,(de+W)*255,(ve+W)*255]}function m(n,e,t){const l=t+e*(100-Math.abs(2*t-100))/200;return[n,l!==0?e*(100-Math.abs(2*t-100))/l:0,t+e*(100-Math.abs(2*t-100))/(2*100)]}function o(n,e,t){const l=100-Math.abs(t*(200-e)/100-100);return[n,l!==0?e*t/l:0,t*(200-e)/(2*100)]}function p(n){return[n[0],n[1],n[2]]}function v(n,e){return[n[0],n[1],n[2],e]}const C={hsl:{hsl:(n,e,t)=>[n,e,t],hsv:m,rgb:Js},hsv:{hsl:o,hsv:(n,e,t)=>[n,e,t],rgb:Ji},rgb:{hsl:Ws,hsv:Hs,rgb:(n,e,t)=>[n,e,t]}};function k(n,e){return[e==="float"?1:n==="rgb"?255:360,e==="float"?1:n==="rgb"?255:100,e==="float"?1:n==="rgb"?255:100]}function T(n,e){return n===e?e:Ot(n,e)}function G(n,e,t){var l;const b=k(e,t);return[e==="rgb"?Me(n[0],0,b[0]):T(n[0],b[0]),Me(n[1],0,b[1]),Me(n[2],0,b[2]),Me((l=n[3])!==null&&l!==void 0?l:1,0,1)]}function oe(n,e,t,l){const b=k(e,t),P=k(e,l);return n.map((A,U)=>A/b[U]*P[U])}function Ge(n,e,t){const l=oe(n,e.mode,e.type,"int"),b=C[e.mode][t.mode](...l);return oe(b,t.mode,"int",t.type)}function Ke(n,e){return typeof n!="object"||w(n)?!1:e in n&&typeof n[e]=="number"}class te{static black(e="int"){return new te([0,0,0],"rgb",e)}static fromObject(e,t="int"){const l="a"in e?[e.r,e.g,e.b,e.a]:[e.r,e.g,e.b];return new te(l,"rgb",t)}static toRgbaObject(e,t="int"){return e.toRgbaObject(t)}static isRgbColorObject(e){return Ke(e,"r")&&Ke(e,"g")&&Ke(e,"b")}static isRgbaColorObject(e){return this.isRgbColorObject(e)&&Ke(e,"a")}static isColorObject(e){return this.isRgbColorObject(e)}static equals(e,t){if(e.mode!==t.mode)return!1;const l=e.comps_,b=t.comps_;for(let P=0;P<l.length;P++)if(l[P]!==b[P])return!1;return!0}constructor(e,t,l="int"){this.mode=t,this.type=l,this.comps_=G(e,t,l)}getComponents(e,t="int"){return v(Ge(p(this.comps_),{mode:this.mode,type:this.type},{mode:e??this.mode,type:t}),this.comps_[3])}toRgbaObject(e="int"){const t=this.getComponents("rgb",e);return{r:t[0],g:t[1],b:t[2],a:t[3]}}}const ut=N("colp");class er{constructor(e,t){this.alphaViews_=null,this.element=e.createElement("div"),this.element.classList.add(ut()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(ut("hsv"));const b=e.createElement("div");b.classList.add(ut("sv")),this.svPaletteView_=t.svPaletteView,b.appendChild(this.svPaletteView_.element),l.appendChild(b);const P=e.createElement("div");P.classList.add(ut("h")),this.hPaletteView_=t.hPaletteView,P.appendChild(this.hPaletteView_.element),l.appendChild(P),this.element.appendChild(l);const A=e.createElement("div");if(A.classList.add(ut("rgb")),this.textView_=t.textView,A.appendChild(this.textView_.element),this.element.appendChild(A),t.alphaViews){this.alphaViews_={palette:t.alphaViews.palette,text:t.alphaViews.text};const U=e.createElement("div");U.classList.add(ut("a"));const W=e.createElement("div");W.classList.add(ut("ap")),W.appendChild(this.alphaViews_.palette.element),U.appendChild(W);const H=e.createElement("div");H.classList.add(ut("at")),H.appendChild(this.alphaViews_.text.element),U.appendChild(H),this.element.appendChild(U)}}get allFocusableElements(){const e=[this.svPaletteView_.element,this.hPaletteView_.element,this.textView_.modeSelectElement,...this.textView_.textViews.map(t=>t.inputElement)];return this.alphaViews_&&e.push(this.alphaViews_.palette.element,this.alphaViews_.text.inputElement),e}}function Lc(n){return n==="int"?"int":n==="float"?"float":void 0}function tr(n){const e=V;return ce(n,{alpha:e.optional.boolean,color:e.optional.object({alpha:e.optional.boolean,type:e.optional.custom(Lc)}),expanded:e.optional.boolean,picker:e.optional.custom(mi)})}function un(n){return n?.1:1}function hn(n){var e;return(e=n.color)===null||e===void 0?void 0:e.type}function Ac(n,e){return n.alpha===e.alpha&&n.mode===e.mode&&n.notation===e.notation&&n.type===e.type}function et(n,e){const t=n.match(/^(.+)%$/);return Math.min(t?parseFloat(t[1])*.01*e:parseFloat(n),e)}const Vc={deg:n=>n,grad:n=>n*360/400,rad:n=>n*360/(2*Math.PI),turn:n=>n*360};function no(n){const e=n.match(/^([0-9.]+?)(deg|grad|rad|turn)$/);if(!e)return parseFloat(n);const t=parseFloat(e[1]),l=e[2];return Vc[l](t)}function io(n){const e=n.match(/^rgb\(\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*\)$/);if(!e)return null;const t=[et(e[1],255),et(e[2],255),et(e[3],255)];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])?null:t}function so(n){return e=>{const t=io(e);return t?new te(t,"rgb",n):null}}function ro(n){const e=n.match(/^rgba\(\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*\)$/);if(!e)return null;const t=[et(e[1],255),et(e[2],255),et(e[3],255),et(e[4],1)];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])||isNaN(t[3])?null:t}function oo(n){return e=>{const t=ro(e);return t?new te(t,"rgb",n):null}}function ao(n){const e=n.match(/^hsl\(\s*([0-9A-Fa-f.]+(?:deg|grad|rad|turn)?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*\)$/);if(!e)return null;const t=[no(e[1]),et(e[2],100),et(e[3],100)];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])?null:t}function lo(n){return e=>{const t=ao(e);return t?new te(t,"hsl",n):null}}function co(n){const e=n.match(/^hsla\(\s*([0-9A-Fa-f.]+(?:deg|grad|rad|turn)?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*\)$/);if(!e)return null;const t=[no(e[1]),et(e[2],100),et(e[3],100),et(e[4],1)];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])||isNaN(t[3])?null:t}function po(n){return e=>{const t=co(e);return t?new te(t,"hsl",n):null}}function uo(n){const e=n.match(/^#([0-9A-Fa-f])([0-9A-Fa-f])([0-9A-Fa-f])$/);if(e)return[parseInt(e[1]+e[1],16),parseInt(e[2]+e[2],16),parseInt(e[3]+e[3],16)];const t=n.match(/^(?:#|0x)([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})$/);return t?[parseInt(t[1],16),parseInt(t[2],16),parseInt(t[3],16)]:null}function Ic(n){const e=uo(n);return e?new te(e,"rgb","int"):null}function ho(n){const e=n.match(/^#?([0-9A-Fa-f])([0-9A-Fa-f])([0-9A-Fa-f])([0-9A-Fa-f])$/);if(e)return[parseInt(e[1]+e[1],16),parseInt(e[2]+e[2],16),parseInt(e[3]+e[3],16),_e(parseInt(e[4]+e[4],16),0,255,0,1)];const t=n.match(/^(?:#|0x)?([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})$/);return t?[parseInt(t[1],16),parseInt(t[2],16),parseInt(t[3],16),_e(parseInt(t[4],16),0,255,0,1)]:null}function Dc(n){const e=ho(n);return e?new te(e,"rgb","int"):null}function mo(n){const e=n.match(/^\{\s*r\s*:\s*([0-9A-Fa-f.]+%?)\s*,\s*g\s*:\s*([0-9A-Fa-f.]+%?)\s*,\s*b\s*:\s*([0-9A-Fa-f.]+%?)\s*\}$/);if(!e)return null;const t=[parseFloat(e[1]),parseFloat(e[2]),parseFloat(e[3])];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])?null:t}function fo(n){return e=>{const t=mo(e);return t?new te(t,"rgb",n):null}}function vo(n){const e=n.match(/^\{\s*r\s*:\s*([0-9A-Fa-f.]+%?)\s*,\s*g\s*:\s*([0-9A-Fa-f.]+%?)\s*,\s*b\s*:\s*([0-9A-Fa-f.]+%?)\s*,\s*a\s*:\s*([0-9A-Fa-f.]+%?)\s*\}$/);if(!e)return null;const t=[parseFloat(e[1]),parseFloat(e[2]),parseFloat(e[3]),parseFloat(e[4])];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])||isNaN(t[3])?null:t}function bo(n){return e=>{const t=vo(e);return t?new te(t,"rgb",n):null}}const Tc=[{parser:uo,result:{alpha:!1,mode:"rgb",notation:"hex"}},{parser:ho,result:{alpha:!0,mode:"rgb",notation:"hex"}},{parser:io,result:{alpha:!1,mode:"rgb",notation:"func"}},{parser:ro,result:{alpha:!0,mode:"rgb",notation:"func"}},{parser:ao,result:{alpha:!1,mode:"hsl",notation:"func"}},{parser:co,result:{alpha:!0,mode:"hsl",notation:"func"}},{parser:mo,result:{alpha:!1,mode:"rgb",notation:"object"}},{parser:vo,result:{alpha:!0,mode:"rgb",notation:"object"}}];function Ec(n){return Tc.reduce((e,{parser:t,result:l})=>e||(t(n)?l:null),null)}function nr(n,e="int"){const t=Ec(n);return t?t.notation==="hex"&&e!=="float"?Object.assign(Object.assign({},t),{type:"int"}):t.notation==="func"?Object.assign(Object.assign({},t),{type:e}):null:null}const go={int:[Ic,Dc,so("int"),oo("int"),lo("int"),po("int"),fo("int"),bo("int")],float:[so("float"),oo("float"),lo("float"),po("float"),fo("float"),bo("float")]};function Oc(n){const e=go[n];return t=>{if(typeof t!="string")return te.black(n);const l=e.reduce((b,P)=>b||P(t),null);return l??te.black(n)}}function ir(n){const e=go[n];return t=>e.reduce((l,b)=>l||b(t),null)}function _o(n){const e=Me(Math.floor(n),0,255).toString(16);return e.length===1?`0${e}`:e}function wo(n,e="#"){const t=p(n.getComponents("rgb")).map(_o).join("");return`${e}${t}`}function sr(n,e="#"){const t=n.getComponents("rgb"),l=[t[0],t[1],t[2],t[3]*255].map(_o).join("");return`${e}${l}`}function yo(n,e){const t=Le(e==="float"?2:0);return`rgb(${p(n.getComponents("rgb",e)).map(b=>t(b)).join(", ")})`}function Bc(n){return e=>yo(e,n)}function Hi(n,e){const t=Le(2),l=Le(e==="float"?2:0);return`rgba(${n.getComponents("rgb",e).map((P,A)=>(A===3?t:l)(P)).join(", ")})`}function Nc(n){return e=>Hi(e,n)}function Fc(n){const e=[Le(0),sn,sn];return`hsl(${p(n.getComponents("hsl")).map((l,b)=>e[b](l)).join(", ")})`}function jc(n){const e=[Le(0),sn,sn,Le(2)];return`hsla(${n.getComponents("hsl").map((l,b)=>e[b](l)).join(", ")})`}function xo(n,e){const t=Le(e==="float"?2:0),l=["r","g","b"];return`{${p(n.getComponents("rgb",e)).map((P,A)=>`${l[A]}: ${t(P)}`).join(", ")}}`}function zc(n){return e=>xo(e,n)}function Co(n,e){const t=Le(2),l=Le(e==="float"?2:0),b=["r","g","b","a"];return`{${n.getComponents("rgb",e).map((A,U)=>{const W=U===3?t:l;return`${b[U]}: ${W(A)}`}).join(", ")}}`}function Uc(n){return e=>Co(e,n)}const Rc=[{format:{alpha:!1,mode:"rgb",notation:"hex",type:"int"},stringifier:wo},{format:{alpha:!0,mode:"rgb",notation:"hex",type:"int"},stringifier:sr},{format:{alpha:!1,mode:"hsl",notation:"func",type:"int"},stringifier:Fc},{format:{alpha:!0,mode:"hsl",notation:"func",type:"int"},stringifier:jc},...["int","float"].reduce((n,e)=>[...n,{format:{alpha:!1,mode:"rgb",notation:"func",type:e},stringifier:Bc(e)},{format:{alpha:!0,mode:"rgb",notation:"func",type:e},stringifier:Nc(e)},{format:{alpha:!1,mode:"rgb",notation:"object",type:e},stringifier:zc(e)},{format:{alpha:!0,mode:"rgb",notation:"object",type:e},stringifier:Uc(e)}],[])];function rr(n){return Rc.reduce((e,t)=>e||(Ac(t.format,n)?t.stringifier:null),null)}const bi=N("apl");class Gc{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),this.value=t.value,this.value.emitter.on("change",this.onValueChange_),this.element=e.createElement("div"),this.element.classList.add(bi()),t.viewProps.bindClassModifiers(this.element),t.viewProps.bindTabIndex(this.element);const l=e.createElement("div");l.classList.add(bi("b")),this.element.appendChild(l);const b=e.createElement("div");b.classList.add(bi("c")),l.appendChild(b),this.colorElem_=b;const P=e.createElement("div");P.classList.add(bi("m")),this.element.appendChild(P),this.markerElem_=P;const A=e.createElement("div");A.classList.add(bi("p")),this.markerElem_.appendChild(A),this.previewElem_=A,this.update_()}update_(){const e=this.value.rawValue,t=e.getComponents("rgb"),l=new te([t[0],t[1],t[2],0],"rgb"),b=new te([t[0],t[1],t[2],255],"rgb"),P=["to right",Hi(l),Hi(b)];this.colorElem_.style.background=`linear-gradient(${P.join(",")})`,this.previewElem_.style.backgroundColor=Hi(e);const A=_e(t[3],0,1,0,100);this.markerElem_.style.left=`${A}%`}onValueChange_(){this.update_()}}class Kc{constructor(e,t){this.onKeyDown_=this.onKeyDown_.bind(this),this.onKeyUp_=this.onKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.view=new Gc(e,{value:this.value,viewProps:this.viewProps}),this.ptHandler_=new _t(this.view.element),this.ptHandler_.emitter.on("down",this.onPointerDown_),this.ptHandler_.emitter.on("move",this.onPointerMove_),this.ptHandler_.emitter.on("up",this.onPointerUp_),this.view.element.addEventListener("keydown",this.onKeyDown_),this.view.element.addEventListener("keyup",this.onKeyUp_)}handlePointerEvent_(e,t){if(!e.point)return;const l=e.point.x/e.bounds.width,b=this.value.rawValue,[P,A,U]=b.getComponents("hsv");this.value.setRawValue(new te([P,A,U,l],"hsv"),t)}onPointerDown_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerMove_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerUp_(e){this.handlePointerEvent_(e.data,{forceEmit:!0,last:!0})}onKeyDown_(e){const t=Ie(un(!0),He(e));if(t===0)return;const l=this.value.rawValue,[b,P,A,U]=l.getComponents("hsv");this.value.setRawValue(new te([b,P,A,U+t],"hsv"),{forceEmit:!1,last:!1})}onKeyUp_(e){Ie(un(!0),He(e))!==0&&this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}const Tn=N("coltxt");function $c(n){const e=n.createElement("select"),t=[{text:"RGB",value:"rgb"},{text:"HSL",value:"hsl"},{text:"HSV",value:"hsv"}];return e.appendChild(t.reduce((l,b)=>{const P=n.createElement("option");return P.textContent=b.text,P.value=b.value,l.appendChild(P),l},n.createDocumentFragment())),e}class Xc{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(Tn()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(Tn("m")),this.modeElem_=$c(e),this.modeElem_.classList.add(Tn("ms")),l.appendChild(this.modeSelectElement),t.viewProps.bindDisabled(this.modeElem_);const b=e.createElement("div");b.classList.add(Tn("mm")),b.appendChild(at(e,"dropdown")),l.appendChild(b),this.element.appendChild(l);const P=e.createElement("div");P.classList.add(Tn("w")),this.element.appendChild(P),this.textsElem_=P,this.textViews_=t.textViews,this.applyTextViews_(),j(t.colorMode,A=>{this.modeElem_.value=A})}get modeSelectElement(){return this.modeElem_}get textViews(){return this.textViews_}set textViews(e){this.textViews_=e,this.applyTextViews_()}applyTextViews_(){Yt(this.textsElem_);const e=this.element.ownerDocument;this.textViews_.forEach(t=>{const l=e.createElement("div");l.classList.add(Tn("c")),l.appendChild(t.element),this.textsElem_.appendChild(l)})}}function Yc(n){return Le(n==="float"?2:0)}function qc(n,e,t){const l=k(n,e)[t];return new Dt({min:0,max:l})}function or(n,e,t){return new on(n,{arrayPosition:t===0?"fst":t===3-1?"lst":"mid",baseStep:un(!1),parser:e.parser,props:q.fromObject({draggingScale:e.colorType==="float"?.01:1,formatter:Yc(e.colorType)}),value:ee(0,{constraint:qc(e.colorMode,e.colorType,t)}),viewProps:e.viewProps})}class Qc{constructor(e,t){this.onModeSelectChange_=this.onModeSelectChange_.bind(this),this.colorType_=t.colorType,this.parser_=t.parser,this.value=t.value,this.viewProps=t.viewProps,this.colorMode=ee(this.value.rawValue.mode),this.ccs_=this.createComponentControllers_(e),this.view=new Xc(e,{colorMode:this.colorMode,textViews:[this.ccs_[0].view,this.ccs_[1].view,this.ccs_[2].view],viewProps:this.viewProps}),this.view.modeSelectElement.addEventListener("change",this.onModeSelectChange_)}createComponentControllers_(e){const t={colorMode:this.colorMode.rawValue,colorType:this.colorType_,parser:this.parser_,viewProps:this.viewProps},l=[or(e,t,0),or(e,t,1),or(e,t,2)];return l.forEach((b,P)=>{Et({primary:this.value,secondary:b.value,forward:A=>A.rawValue.getComponents(this.colorMode.rawValue,this.colorType_)[P],backward:(A,U)=>{const W=this.colorMode.rawValue,H=A.rawValue.getComponents(W,this.colorType_);return H[P]=U.rawValue,new te(v(p(H),H[3]),W,this.colorType_)}})}),l}onModeSelectChange_(e){const t=e.currentTarget;this.colorMode.rawValue=t.value,this.ccs_=this.createComponentControllers_(this.view.element.ownerDocument),this.view.textViews=[this.ccs_[0].view,this.ccs_[1].view,this.ccs_[2].view]}}const ar=N("hpl");class Zc{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),this.value=t.value,this.value.emitter.on("change",this.onValueChange_),this.element=e.createElement("div"),this.element.classList.add(ar()),t.viewProps.bindClassModifiers(this.element),t.viewProps.bindTabIndex(this.element);const l=e.createElement("div");l.classList.add(ar("c")),this.element.appendChild(l);const b=e.createElement("div");b.classList.add(ar("m")),this.element.appendChild(b),this.markerElem_=b,this.update_()}update_(){const e=this.value.rawValue,[t]=e.getComponents("hsv");this.markerElem_.style.backgroundColor=yo(new te([t,100,100],"hsv"));const l=_e(t,0,360,0,100);this.markerElem_.style.left=`${l}%`}onValueChange_(){this.update_()}}class Wc{constructor(e,t){this.onKeyDown_=this.onKeyDown_.bind(this),this.onKeyUp_=this.onKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.view=new Zc(e,{value:this.value,viewProps:this.viewProps}),this.ptHandler_=new _t(this.view.element),this.ptHandler_.emitter.on("down",this.onPointerDown_),this.ptHandler_.emitter.on("move",this.onPointerMove_),this.ptHandler_.emitter.on("up",this.onPointerUp_),this.view.element.addEventListener("keydown",this.onKeyDown_),this.view.element.addEventListener("keyup",this.onKeyUp_)}handlePointerEvent_(e,t){if(!e.point)return;const l=_e(Me(e.point.x,0,e.bounds.width),0,e.bounds.width,0,360),b=this.value.rawValue,[,P,A,U]=b.getComponents("hsv");this.value.setRawValue(new te([l,P,A,U],"hsv"),t)}onPointerDown_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerMove_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerUp_(e){this.handlePointerEvent_(e.data,{forceEmit:!0,last:!0})}onKeyDown_(e){const t=Ie(un(!1),He(e));if(t===0)return;const l=this.value.rawValue,[b,P,A,U]=l.getComponents("hsv");this.value.setRawValue(new te([b+t,P,A,U],"hsv"),{forceEmit:!1,last:!1})}onKeyUp_(e){Ie(un(!1),He(e))!==0&&this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}const lr=N("svp"),Po=64;class Jc{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),this.value=t.value,this.value.emitter.on("change",this.onValueChange_),this.element=e.createElement("div"),this.element.classList.add(lr()),t.viewProps.bindClassModifiers(this.element),t.viewProps.bindTabIndex(this.element);const l=e.createElement("canvas");l.height=Po,l.width=Po,l.classList.add(lr("c")),this.element.appendChild(l),this.canvasElement=l;const b=e.createElement("div");b.classList.add(lr("m")),this.element.appendChild(b),this.markerElem_=b,this.update_()}update_(){const e=gn(this.canvasElement);if(!e)return;const l=this.value.rawValue.getComponents("hsv"),b=this.canvasElement.width,P=this.canvasElement.height,A=e.getImageData(0,0,b,P),U=A.data;for(let de=0;de<P;de++)for(let ve=0;ve<b;ve++){const dn=_e(ve,0,b,0,100),_i=_e(de,0,P,100,0),wi=Ji(l[0],dn,_i),es=(de*b+ve)*4;U[es]=wi[0],U[es+1]=wi[1],U[es+2]=wi[2],U[es+3]=255}e.putImageData(A,0,0);const W=_e(l[1],0,100,0,100);this.markerElem_.style.left=`${W}%`;const H=_e(l[2],0,100,100,0);this.markerElem_.style.top=`${H}%`}onValueChange_(){this.update_()}}class Hc{constructor(e,t){this.onKeyDown_=this.onKeyDown_.bind(this),this.onKeyUp_=this.onKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.view=new Jc(e,{value:this.value,viewProps:this.viewProps}),this.ptHandler_=new _t(this.view.element),this.ptHandler_.emitter.on("down",this.onPointerDown_),this.ptHandler_.emitter.on("move",this.onPointerMove_),this.ptHandler_.emitter.on("up",this.onPointerUp_),this.view.element.addEventListener("keydown",this.onKeyDown_),this.view.element.addEventListener("keyup",this.onKeyUp_)}handlePointerEvent_(e,t){if(!e.point)return;const l=_e(e.point.x,0,e.bounds.width,0,100),b=_e(e.point.y,0,e.bounds.height,100,0),[P,,,A]=this.value.rawValue.getComponents("hsv");this.value.setRawValue(new te([P,l,b,A],"hsv"),t)}onPointerDown_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerMove_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerUp_(e){this.handlePointerEvent_(e.data,{forceEmit:!0,last:!0})}onKeyDown_(e){An(e.key)&&e.preventDefault();const[t,l,b,P]=this.value.rawValue.getComponents("hsv"),A=un(!1),U=Ie(A,He(e)),W=Ie(A,rn(e));U===0&&W===0||this.value.setRawValue(new te([t,l+U,b+W,P],"hsv"),{forceEmit:!1,last:!1})}onKeyUp_(e){const t=un(!1),l=Ie(t,He(e)),b=Ie(t,rn(e));l===0&&b===0||this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}class ep{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.hPaletteC_=new Wc(e,{value:this.value,viewProps:this.viewProps}),this.svPaletteC_=new Hc(e,{value:this.value,viewProps:this.viewProps}),this.alphaIcs_=t.supportsAlpha?{palette:new Kc(e,{value:this.value,viewProps:this.viewProps}),text:new on(e,{parser:Je,baseStep:.1,props:q.fromObject({draggingScale:.01,formatter:Le(2)}),value:ee(0,{constraint:new Dt({min:0,max:1})}),viewProps:this.viewProps})}:null,this.alphaIcs_&&Et({primary:this.value,secondary:this.alphaIcs_.text.value,forward:l=>l.rawValue.getComponents()[3],backward:(l,b)=>{const P=l.rawValue.getComponents();return P[3]=b.rawValue,new te(P,l.rawValue.mode)}}),this.textC_=new Qc(e,{colorType:t.colorType,parser:Je,value:this.value,viewProps:this.viewProps}),this.view=new er(e,{alphaViews:this.alphaIcs_?{palette:this.alphaIcs_.palette.view,text:this.alphaIcs_.text.view}:null,hPaletteView:this.hPaletteC_.view,supportsAlpha:t.supportsAlpha,svPaletteView:this.svPaletteC_.view,textView:this.textC_.view,viewProps:this.viewProps})}get textController(){return this.textC_}}const cr=N("colsw");class tp{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),t.value.emitter.on("change",this.onValueChange_),this.value=t.value,this.element=e.createElement("div"),this.element.classList.add(cr()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(cr("sw")),this.element.appendChild(l),this.swatchElem_=l;const b=e.createElement("button");b.classList.add(cr("b")),t.viewProps.bindDisabled(b),this.element.appendChild(b),this.buttonElement=b,this.update_()}update_(){const e=this.value.rawValue;this.swatchElem_.style.backgroundColor=sr(e)}onValueChange_(){this.update_()}}class np{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.view=new tp(e,{value:this.value,viewProps:this.viewProps})}}class pr{constructor(e,t){this.onButtonBlur_=this.onButtonBlur_.bind(this),this.onButtonClick_=this.onButtonClick_.bind(this),this.onPopupChildBlur_=this.onPopupChildBlur_.bind(this),this.onPopupChildKeydown_=this.onPopupChildKeydown_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.foldable_=Ve.create(t.expanded),this.swatchC_=new np(e,{value:this.value,viewProps:this.viewProps});const l=this.swatchC_.view.buttonElement;l.addEventListener("blur",this.onButtonBlur_),l.addEventListener("click",this.onButtonClick_),this.textC_=new Sn(e,{parser:t.parser,props:q.fromObject({formatter:t.formatter}),value:this.value,viewProps:this.viewProps}),this.view=new vi(e,{foldable:this.foldable_,pickerLayout:t.pickerLayout}),this.view.swatchElement.appendChild(this.swatchC_.view.element),this.view.textElement.appendChild(this.textC_.view.element),this.popC_=t.pickerLayout==="popup"?new Bi(e,{viewProps:this.viewProps}):null;const b=new ep(e,{colorType:t.colorType,supportsAlpha:t.supportsAlpha,value:this.value,viewProps:this.viewProps});b.view.allFocusableElements.forEach(P=>{P.addEventListener("blur",this.onPopupChildBlur_),P.addEventListener("keydown",this.onPopupChildKeydown_)}),this.pickerC_=b,this.popC_?(this.view.element.appendChild(this.popC_.view.element),this.popC_.view.element.appendChild(b.view.element),Et({primary:this.foldable_.value("expanded"),secondary:this.popC_.shows,forward:P=>P.rawValue,backward:(P,A)=>A.rawValue})):this.view.pickerElement&&(this.view.pickerElement.appendChild(this.pickerC_.view.element),Oe(this.foldable_,this.view.pickerElement))}get textController(){return this.textC_}onButtonBlur_(e){if(!this.popC_)return;const t=this.view.element,l=e.relatedTarget;(!l||!t.contains(l))&&(this.popC_.shows.rawValue=!1)}onButtonClick_(){this.foldable_.set("expanded",!this.foldable_.get("expanded")),this.foldable_.get("expanded")&&this.pickerC_.view.allFocusableElements[0].focus()}onPopupChildBlur_(e){if(!this.popC_)return;const t=this.popC_.view.element,l=lt(e);l&&t.contains(l)||l&&l===this.swatchC_.view.buttonElement&&!it(t.ownerDocument)||(this.popC_.shows.rawValue=!1)}onPopupChildKeydown_(e){this.popC_?e.key==="Escape"&&(this.popC_.shows.rawValue=!1):this.view.pickerElement&&e.key==="Escape"&&this.swatchC_.view.buttonElement.focus()}}function ip(n,e){return te.isColorObject(n)?te.fromObject(n,e):te.black(e)}function sp(n){return p(n.getComponents("rgb")).reduce((e,t)=>e<<8|Math.floor(t)&255,0)}function rp(n){return n.getComponents("rgb").reduce((e,t,l)=>{const b=Math.floor(l===3?t*255:t)&255;return e<<8|b},0)>>>0}function op(n){return new te([n>>16&255,n>>8&255,n&255],"rgb")}function ap(n){return new te([n>>24&255,n>>16&255,n>>8&255,_e(n&255,0,255,0,1)],"rgb")}function lp(n){return typeof n!="number"?te.black():op(n)}function cp(n){return typeof n!="number"?te.black():ap(n)}function pp(n){const e=rr(n);return e?(t,l)=>{Xe(t,e(l))}:null}function up(n){const e=n?rp:sp;return(t,l)=>{Xe(t,e(l))}}function hp(n,e,t){const l=e.toRgbaObject(t);n.writeProperty("r",l.r),n.writeProperty("g",l.g),n.writeProperty("b",l.b),n.writeProperty("a",l.a)}function dp(n,e,t){const l=e.toRgbaObject(t);n.writeProperty("r",l.r),n.writeProperty("g",l.g),n.writeProperty("b",l.b)}function mp(n,e){return(t,l)=>{n?hp(t,l,e):dp(t,l,e)}}function ur(n){var e;return!!(n!=null&&n.alpha||!((e=n==null?void 0:n.color)===null||e===void 0)&&e.alpha)}function fp(n){return n?e=>sr(e,"0x"):e=>wo(e,"0x")}function vp(n){return"color"in n||"view"in n&&n.view==="color"}const bp={id:"input-color-number",type:"input",accept:(n,e)=>{if(typeof n!="number"||!vp(e))return null;const t=tr(e);return t?{initialValue:n,params:t}:null},binding:{reader:n=>ur(n.params)?cp:lp,equals:te.equals,writer:n=>up(ur(n.params))},controller:n=>{const e=ur(n.params),t="expanded"in n.params?n.params.expanded:void 0,l="picker"in n.params?n.params.picker:void 0;return new pr(n.document,{colorType:"int",expanded:t??!1,formatter:fp(e),parser:ir("int"),pickerLayout:l??"popup",supportsAlpha:e,value:n.value,viewProps:n.viewProps})}};function gp(n){return te.isRgbaColorObject(n)}function _p(n){return e=>ip(e,n)}function wp(n,e){return t=>n?Co(t,e):xo(t,e)}const yp={id:"input-color-object",type:"input",accept:(n,e)=>{if(!te.isColorObject(n))return null;const t=tr(e);return t?{initialValue:n,params:t}:null},binding:{reader:n=>_p(hn(n.params)),equals:te.equals,writer:n=>mp(gp(n.initialValue),hn(n.params))},controller:n=>{var e;const t=te.isRgbaColorObject(n.initialValue),l="expanded"in n.params?n.params.expanded:void 0,b="picker"in n.params?n.params.picker:void 0,P=(e=hn(n.params))!==null&&e!==void 0?e:"int";return new pr(n.document,{colorType:P,expanded:l??!1,formatter:wp(t,P),parser:ir(P),pickerLayout:b??"popup",supportsAlpha:t,value:n.value,viewProps:n.viewProps})}},xp={id:"input-color-string",type:"input",accept:(n,e)=>{if(typeof n!="string"||"view"in e&&e.view==="text")return null;const t=nr(n,hn(e));if(!t||!rr(t))return null;const b=tr(e);return b?{initialValue:n,params:b}:null},binding:{reader:n=>{var e;return Oc((e=hn(n.params))!==null&&e!==void 0?e:"int")},equals:te.equals,writer:n=>{const e=nr(n.initialValue,hn(n.params));if(!e)throw I.shouldNeverHappen();const t=pp(e);if(!t)throw I.notBindable();return t}},controller:n=>{const e=nr(n.initialValue,hn(n.params));if(!e)throw I.shouldNeverHappen();const t=rr(e);if(!t)throw I.shouldNeverHappen();const l="expanded"in n.params?n.params.expanded:void 0,b="picker"in n.params?n.params.picker:void 0;return new pr(n.document,{colorType:e.type,expanded:l??!1,formatter:t,parser:ir(e.type),pickerLayout:b??"popup",supportsAlpha:e.alpha,value:n.value,viewProps:n.viewProps})}};class Bt{constructor(e){this.components=e.components,this.asm_=e.assembly}constrain(e){const t=this.asm_.toComponents(e).map((l,b)=>{var P,A;return(A=(P=this.components[b])===null||P===void 0?void 0:P.constrain(l))!==null&&A!==void 0?A:l});return this.asm_.fromComponents(t)}}const Mo=N("pndtxt");class Cp{constructor(e,t){this.textViews=t.textViews,this.element=e.createElement("div"),this.element.classList.add(Mo()),this.textViews.forEach(l=>{const b=e.createElement("div");b.classList.add(Mo("a")),b.appendChild(l.element),this.element.appendChild(b)})}}function Pp(n,e,t){return new on(n,{arrayPosition:t===0?"fst":t===e.axes.length-1?"lst":"mid",baseStep:e.axes[t].baseStep,parser:e.parser,props:e.axes[t].textProps,value:ee(0,{constraint:e.axes[t].constraint}),viewProps:e.viewProps})}class hr{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.acs_=t.axes.map((l,b)=>Pp(e,t,b)),this.acs_.forEach((l,b)=>{Et({primary:this.value,secondary:l.value,forward:P=>t.assembly.toComponents(P.rawValue)[b],backward:(P,A)=>{const U=t.assembly.toComponents(P.rawValue);return U[b]=A.rawValue,t.assembly.fromComponents(U)}})}),this.view=new Cp(e,{textViews:this.acs_.map(l=>l.view)})}}function ko(n,e){return"step"in n&&!w(n.step)?new kn(n.step,e):null}function So(n){return!w(n.max)&&!w(n.min)?new Dt({max:n.max,min:n.min}):!w(n.max)||!w(n.min)?new ti({max:n.max,min:n.min}):null}function Mp(n){const e=$e(n,Dt);if(e)return[e.values.get("min"),e.values.get("max")];const t=$e(n,ti);return t?[t.minValue,t.maxValue]:[void 0,void 0]}function kp(n,e){const t=[],l=ko(n,e);l&&t.push(l);const b=So(n);b&&t.push(b);const P=fi(n.options);return P&&t.push(P),new Ht(t)}const Sp={id:"input-number",type:"input",accept:(n,e)=>{if(typeof n!="number")return null;const t=V,l=ce(e,{format:t.optional.function,max:t.optional.number,min:t.optional.number,options:t.optional.custom(ln),step:t.optional.number});return l?{initialValue:n,params:l}:null},binding:{reader:n=>rt,constraint:n=>kp(n.params,n.initialValue),writer:n=>Xe},controller:n=>{var e;const t=n.value,l=n.constraint,b=l&&$e(l,en);if(b)return new tn(n.document,{props:new q({options:b.values.value("options")}),value:t,viewProps:n.viewProps});const P=(e="format"in n.params?n.params.format:void 0)!==null&&e!==void 0?e:Le(In(l,t.rawValue)),A=l&&$e(l,Dt);return A?new Vn(n.document,{baseStep:wt(l),parser:Je,sliderProps:new q({maxValue:A.values.value("max"),minValue:A.values.value("min")}),textProps:q.fromObject({draggingScale:yt(l,t.rawValue),formatter:P}),value:t,viewProps:n.viewProps}):new on(n.document,{baseStep:wt(l),parser:Je,props:q.fromObject({draggingScale:yt(l,t.rawValue),formatter:P}),value:t,viewProps:n.viewProps})}};class Nt{constructor(e=0,t=0){this.x=e,this.y=t}getComponents(){return[this.x,this.y]}static isObject(e){if(w(e))return!1;const t=e.x,l=e.y;return!(typeof t!="number"||typeof l!="number")}static equals(e,t){return e.x===t.x&&e.y===t.y}toObject(){return{x:this.x,y:this.y}}}const Lo={toComponents:n=>n.getComponents(),fromComponents:n=>new Nt(...n)},En=N("p2d");class Lp{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(En()),t.viewProps.bindClassModifiers(this.element),j(t.expanded,Y(this.element,En(void 0,"expanded")));const l=e.createElement("div");l.classList.add(En("h")),this.element.appendChild(l);const b=e.createElement("button");b.classList.add(En("b")),b.appendChild(at(e,"p2dpad")),t.viewProps.bindDisabled(b),l.appendChild(b),this.buttonElement=b;const P=e.createElement("div");if(P.classList.add(En("t")),l.appendChild(P),this.textElement=P,t.pickerLayout==="inline"){const A=e.createElement("div");A.classList.add(En("p")),this.element.appendChild(A),this.pickerElement=A}else this.pickerElement=null}}const Ft=N("p2dp");class Ap{constructor(e,t){this.onFoldableChange_=this.onFoldableChange_.bind(this),this.onValueChange_=this.onValueChange_.bind(this),this.invertsY_=t.invertsY,this.maxValue_=t.maxValue,this.element=e.createElement("div"),this.element.classList.add(Ft()),t.layout==="popup"&&this.element.classList.add(Ft(void 0,"p")),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(Ft("p")),t.viewProps.bindTabIndex(l),this.element.appendChild(l),this.padElement=l;const b=e.createElementNS(Ee,"svg");b.classList.add(Ft("g")),this.padElement.appendChild(b),this.svgElem_=b;const P=e.createElementNS(Ee,"line");P.classList.add(Ft("ax")),P.setAttributeNS(null,"x1","0"),P.setAttributeNS(null,"y1","50%"),P.setAttributeNS(null,"x2","100%"),P.setAttributeNS(null,"y2","50%"),this.svgElem_.appendChild(P);const A=e.createElementNS(Ee,"line");A.classList.add(Ft("ax")),A.setAttributeNS(null,"x1","50%"),A.setAttributeNS(null,"y1","0"),A.setAttributeNS(null,"x2","50%"),A.setAttributeNS(null,"y2","100%"),this.svgElem_.appendChild(A);const U=e.createElementNS(Ee,"line");U.classList.add(Ft("l")),U.setAttributeNS(null,"x1","50%"),U.setAttributeNS(null,"y1","50%"),this.svgElem_.appendChild(U),this.lineElem_=U;const W=e.createElement("div");W.classList.add(Ft("m")),this.padElement.appendChild(W),this.markerElem_=W,t.value.emitter.on("change",this.onValueChange_),this.value=t.value,this.update_()}get allFocusableElements(){return[this.padElement]}update_(){const[e,t]=this.value.rawValue.getComponents(),l=this.maxValue_,b=_e(e,-l,+l,0,100),P=_e(t,-l,+l,0,100),A=this.invertsY_?100-P:P;this.lineElem_.setAttributeNS(null,"x2",`${b}%`),this.lineElem_.setAttributeNS(null,"y2",`${A}%`),this.markerElem_.style.left=`${b}%`,this.markerElem_.style.top=`${A}%`}onValueChange_(){this.update_()}onFoldableChange_(){this.update_()}}function Ao(n,e,t){return[Ie(e[0],He(n)),Ie(e[1],rn(n))*(t?1:-1)]}class Vp{constructor(e,t){this.onPadKeyDown_=this.onPadKeyDown_.bind(this),this.onPadKeyUp_=this.onPadKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.baseSteps_=t.baseSteps,this.maxValue_=t.maxValue,this.invertsY_=t.invertsY,this.view=new Ap(e,{invertsY:this.invertsY_,layout:t.layout,maxValue:this.maxValue_,value:this.value,viewProps:this.viewProps}),this.ptHandler_=new _t(this.view.padElement),this.ptHandler_.emitter.on("down",this.onPointerDown_),this.ptHandler_.emitter.on("move",this.onPointerMove_),this.ptHandler_.emitter.on("up",this.onPointerUp_),this.view.padElement.addEventListener("keydown",this.onPadKeyDown_),this.view.padElement.addEventListener("keyup",this.onPadKeyUp_)}handlePointerEvent_(e,t){if(!e.point)return;const l=this.maxValue_,b=_e(e.point.x,0,e.bounds.width,-l,+l),P=_e(this.invertsY_?e.bounds.height-e.point.y:e.point.y,0,e.bounds.height,-l,+l);this.value.setRawValue(new Nt(b,P),t)}onPointerDown_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerMove_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerUp_(e){this.handlePointerEvent_(e.data,{forceEmit:!0,last:!0})}onPadKeyDown_(e){An(e.key)&&e.preventDefault();const[t,l]=Ao(e,this.baseSteps_,this.invertsY_);t===0&&l===0||this.value.setRawValue(new Nt(this.value.rawValue.x+t,this.value.rawValue.y+l),{forceEmit:!1,last:!1})}onPadKeyUp_(e){const[t,l]=Ao(e,this.baseSteps_,this.invertsY_);t===0&&l===0||this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}class Ip{constructor(e,t){var l,b;this.onPopupChildBlur_=this.onPopupChildBlur_.bind(this),this.onPopupChildKeydown_=this.onPopupChildKeydown_.bind(this),this.onPadButtonBlur_=this.onPadButtonBlur_.bind(this),this.onPadButtonClick_=this.onPadButtonClick_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.foldable_=Ve.create(t.expanded),this.popC_=t.pickerLayout==="popup"?new Bi(e,{viewProps:this.viewProps}):null;const P=new Vp(e,{baseSteps:[t.axes[0].baseStep,t.axes[1].baseStep],invertsY:t.invertsY,layout:t.pickerLayout,maxValue:t.maxValue,value:this.value,viewProps:this.viewProps});P.view.allFocusableElements.forEach(A=>{A.addEventListener("blur",this.onPopupChildBlur_),A.addEventListener("keydown",this.onPopupChildKeydown_)}),this.pickerC_=P,this.textC_=new hr(e,{assembly:Lo,axes:t.axes,parser:t.parser,value:this.value,viewProps:this.viewProps}),this.view=new Lp(e,{expanded:this.foldable_.value("expanded"),pickerLayout:t.pickerLayout,viewProps:this.viewProps}),this.view.textElement.appendChild(this.textC_.view.element),(l=this.view.buttonElement)===null||l===void 0||l.addEventListener("blur",this.onPadButtonBlur_),(b=this.view.buttonElement)===null||b===void 0||b.addEventListener("click",this.onPadButtonClick_),this.popC_?(this.view.element.appendChild(this.popC_.view.element),this.popC_.view.element.appendChild(this.pickerC_.view.element),Et({primary:this.foldable_.value("expanded"),secondary:this.popC_.shows,forward:A=>A.rawValue,backward:(A,U)=>U.rawValue})):this.view.pickerElement&&(this.view.pickerElement.appendChild(this.pickerC_.view.element),Oe(this.foldable_,this.view.pickerElement))}onPadButtonBlur_(e){if(!this.popC_)return;const t=this.view.element,l=e.relatedTarget;(!l||!t.contains(l))&&(this.popC_.shows.rawValue=!1)}onPadButtonClick_(){this.foldable_.set("expanded",!this.foldable_.get("expanded")),this.foldable_.get("expanded")&&this.pickerC_.view.allFocusableElements[0].focus()}onPopupChildBlur_(e){if(!this.popC_)return;const t=this.popC_.view.element,l=lt(e);l&&t.contains(l)||l&&l===this.view.buttonElement&&!it(t.ownerDocument)||(this.popC_.shows.rawValue=!1)}onPopupChildKeydown_(e){this.popC_?e.key==="Escape"&&(this.popC_.shows.rawValue=!1):this.view.pickerElement&&e.key==="Escape"&&this.view.buttonElement.focus()}}class On{constructor(e=0,t=0,l=0){this.x=e,this.y=t,this.z=l}getComponents(){return[this.x,this.y,this.z]}static isObject(e){if(w(e))return!1;const t=e.x,l=e.y,b=e.z;return!(typeof t!="number"||typeof l!="number"||typeof b!="number")}static equals(e,t){return e.x===t.x&&e.y===t.y&&e.z===t.z}toObject(){return{x:this.x,y:this.y,z:this.z}}}const Vo={toComponents:n=>n.getComponents(),fromComponents:n=>new On(...n)};function Dp(n){return On.isObject(n)?new On(n.x,n.y,n.z):new On}function Tp(n,e){n.writeProperty("x",e.x),n.writeProperty("y",e.y),n.writeProperty("z",e.z)}function Ep(n,e){return new Bt({assembly:Vo,components:[Ct("x"in n?n.x:void 0,e.x),Ct("y"in n?n.y:void 0,e.y),Ct("z"in n?n.z:void 0,e.z)]})}function dr(n,e){return{baseStep:wt(e),constraint:e,textProps:q.fromObject({draggingScale:yt(e,n),formatter:Le(In(e,n))})}}const Op={id:"input-point3d",type:"input",accept:(n,e)=>{if(!On.isObject(n))return null;const t=V,l=ce(e,{x:t.optional.custom(ot),y:t.optional.custom(ot),z:t.optional.custom(ot)});return l?{initialValue:n,params:l}:null},binding:{reader:n=>Dp,constraint:n=>Ep(n.params,n.initialValue),equals:On.equals,writer:n=>Tp},controller:n=>{const e=n.value,t=n.constraint;if(!(t instanceof Bt))throw I.shouldNeverHappen();return new hr(n.document,{assembly:Vo,axes:[dr(e.rawValue.x,t.components[0]),dr(e.rawValue.y,t.components[1]),dr(e.rawValue.z,t.components[2])],parser:Je,value:e,viewProps:n.viewProps})}};class Bn{constructor(e=0,t=0,l=0,b=0){this.x=e,this.y=t,this.z=l,this.w=b}getComponents(){return[this.x,this.y,this.z,this.w]}static isObject(e){if(w(e))return!1;const t=e.x,l=e.y,b=e.z,P=e.w;return!(typeof t!="number"||typeof l!="number"||typeof b!="number"||typeof P!="number")}static equals(e,t){return e.x===t.x&&e.y===t.y&&e.z===t.z&&e.w===t.w}toObject(){return{x:this.x,y:this.y,z:this.z,w:this.w}}}const Io={toComponents:n=>n.getComponents(),fromComponents:n=>new Bn(...n)};function Bp(n){return Bn.isObject(n)?new Bn(n.x,n.y,n.z,n.w):new Bn}function Np(n,e){n.writeProperty("x",e.x),n.writeProperty("y",e.y),n.writeProperty("z",e.z),n.writeProperty("w",e.w)}function Fp(n,e){return new Bt({assembly:Io,components:[Ct("x"in n?n.x:void 0,e.x),Ct("y"in n?n.y:void 0,e.y),Ct("z"in n?n.z:void 0,e.z),Ct("w"in n?n.w:void 0,e.w)]})}function jp(n,e){return{baseStep:wt(e),constraint:e,textProps:q.fromObject({draggingScale:yt(e,n),formatter:Le(In(e,n))})}}const zp={id:"input-point4d",type:"input",accept:(n,e)=>{if(!Bn.isObject(n))return null;const t=V,l=ce(e,{x:t.optional.custom(ot),y:t.optional.custom(ot),z:t.optional.custom(ot),w:t.optional.custom(ot)});return l?{initialValue:n,params:l}:null},binding:{reader:n=>Bp,constraint:n=>Fp(n.params,n.initialValue),equals:Bn.equals,writer:n=>Np},controller:n=>{const e=n.value,t=n.constraint;if(!(t instanceof Bt))throw I.shouldNeverHappen();return new hr(n.document,{assembly:Io,axes:e.rawValue.getComponents().map((l,b)=>jp(l,t.components[b])),parser:Je,value:e,viewProps:n.viewProps})}};function Up(n){const e=[],t=fi(n.options);return t&&e.push(t),new Ht(e)}const Rp={id:"input-string",type:"input",accept:(n,e)=>{if(typeof n!="string")return null;const l=ce(e,{options:V.optional.custom(ln)});return l?{initialValue:n,params:l}:null},binding:{reader:n=>ai,constraint:n=>Up(n.params),writer:n=>Xe},controller:n=>{const e=n.document,t=n.value,l=n.constraint,b=l&&$e(l,en);return b?new tn(e,{props:new q({options:b.values.value("options")}),value:t,viewProps:n.viewProps}):new Sn(e,{parser:P=>P,props:q.fromObject({formatter:pt}),value:t,viewProps:n.viewProps})}},gi={monitor:{defaultInterval:200,defaultLineCount:3}},Do=N("mll");class Gp{constructor(e,t){this.onValueUpdate_=this.onValueUpdate_.bind(this),this.formatter_=t.formatter,this.element=e.createElement("div"),this.element.classList.add(Do()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("textarea");l.classList.add(Do("i")),l.style.height=`calc(var(--bld-us) * ${t.lineCount})`,l.readOnly=!0,t.viewProps.bindDisabled(l),this.element.appendChild(l),this.textareaElem_=l,t.value.emitter.on("change",this.onValueUpdate_),this.value=t.value,this.update_()}update_(){const e=this.textareaElem_,t=e.scrollTop===e.scrollHeight-e.clientHeight,l=[];this.value.rawValue.forEach(b=>{b!==void 0&&l.push(this.formatter_(b))}),e.textContent=l.join(`
21
- `),t&&(e.scrollTop=e.scrollHeight)}onValueUpdate_(){this.update_()}}class mr{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.view=new Gp(e,{formatter:t.formatter,lineCount:t.lineCount,value:this.value,viewProps:this.viewProps})}}const To=N("sgl");class Kp{constructor(e,t){this.onValueUpdate_=this.onValueUpdate_.bind(this),this.formatter_=t.formatter,this.element=e.createElement("div"),this.element.classList.add(To()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("input");l.classList.add(To("i")),l.readOnly=!0,l.type="text",t.viewProps.bindDisabled(l),this.element.appendChild(l),this.inputElement=l,t.value.emitter.on("change",this.onValueUpdate_),this.value=t.value,this.update_()}update_(){const e=this.value.rawValue,t=e[e.length-1];this.inputElement.value=t!==void 0?this.formatter_(t):""}onValueUpdate_(){this.update_()}}class fr{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.view=new Kp(e,{formatter:t.formatter,value:this.value,viewProps:this.viewProps})}}const $p={id:"monitor-bool",type:"monitor",accept:(n,e)=>{if(typeof n!="boolean")return null;const l=ce(e,{lineCount:V.optional.number});return l?{initialValue:n,params:l}:null},binding:{reader:n=>Fi},controller:n=>{var e;return n.value.rawValue.length===1?new fr(n.document,{formatter:ji,value:n.value,viewProps:n.viewProps}):new mr(n.document,{formatter:ji,lineCount:(e=n.params.lineCount)!==null&&e!==void 0?e:gi.monitor.defaultLineCount,value:n.value,viewProps:n.viewProps})}},jt=N("grl");class Xp{constructor(e,t){this.onCursorChange_=this.onCursorChange_.bind(this),this.onValueUpdate_=this.onValueUpdate_.bind(this),this.element=e.createElement("div"),this.element.classList.add(jt()),t.viewProps.bindClassModifiers(this.element),this.formatter_=t.formatter,this.props_=t.props,this.cursor_=t.cursor,this.cursor_.emitter.on("change",this.onCursorChange_);const l=e.createElementNS(Ee,"svg");l.classList.add(jt("g")),l.style.height=`calc(var(--bld-us) * ${t.lineCount})`,this.element.appendChild(l),this.svgElem_=l;const b=e.createElementNS(Ee,"polyline");this.svgElem_.appendChild(b),this.lineElem_=b;const P=e.createElement("div");P.classList.add(jt("t"),N("tt")()),this.element.appendChild(P),this.tooltipElem_=P,t.value.emitter.on("change",this.onValueUpdate_),this.value=t.value,this.update_()}get graphElement(){return this.svgElem_}update_(){const e=this.svgElem_.getBoundingClientRect(),t=this.value.rawValue.length-1,l=this.props_.get("minValue"),b=this.props_.get("maxValue"),P=[];this.value.rawValue.forEach((de,ve)=>{if(de===void 0)return;const dn=_e(ve,0,t,0,e.width),_i=_e(de,l,b,e.height,0);P.push([dn,_i].join(","))}),this.lineElem_.setAttributeNS(null,"points",P.join(" "));const A=this.tooltipElem_,U=this.value.rawValue[this.cursor_.rawValue];if(U===void 0){A.classList.remove(jt("t","a"));return}const W=_e(this.cursor_.rawValue,0,t,0,e.width),H=_e(U,l,b,e.height,0);A.style.left=`${W}px`,A.style.top=`${H}px`,A.textContent=`${this.formatter_(U)}`,A.classList.contains(jt("t","a"))||(A.classList.add(jt("t","a"),jt("t","in")),Qe(A),A.classList.remove(jt("t","in")))}onValueUpdate_(){this.update_()}onCursorChange_(){this.update_()}}class Yp{constructor(e,t){if(this.onGraphMouseMove_=this.onGraphMouseMove_.bind(this),this.onGraphMouseLeave_=this.onGraphMouseLeave_.bind(this),this.onGraphPointerDown_=this.onGraphPointerDown_.bind(this),this.onGraphPointerMove_=this.onGraphPointerMove_.bind(this),this.onGraphPointerUp_=this.onGraphPointerUp_.bind(this),this.props_=t.props,this.value=t.value,this.viewProps=t.viewProps,this.cursor_=ee(-1),this.view=new Xp(e,{cursor:this.cursor_,formatter:t.formatter,lineCount:t.lineCount,props:this.props_,value:this.value,viewProps:this.viewProps}),!it(e))this.view.element.addEventListener("mousemove",this.onGraphMouseMove_),this.view.element.addEventListener("mouseleave",this.onGraphMouseLeave_);else{const l=new _t(this.view.element);l.emitter.on("down",this.onGraphPointerDown_),l.emitter.on("move",this.onGraphPointerMove_),l.emitter.on("up",this.onGraphPointerUp_)}}onGraphMouseLeave_(){this.cursor_.rawValue=-1}onGraphMouseMove_(e){const t=this.view.element.getBoundingClientRect();this.cursor_.rawValue=Math.floor(_e(e.offsetX,0,t.width,0,this.value.rawValue.length))}onGraphPointerDown_(e){this.onGraphPointerMove_(e)}onGraphPointerMove_(e){if(!e.data.point){this.cursor_.rawValue=-1;return}this.cursor_.rawValue=Math.floor(_e(e.data.point.x,0,e.data.bounds.width,0,this.value.rawValue.length))}onGraphPointerUp_(){this.cursor_.rawValue=-1}}function vr(n){return"format"in n&&!w(n.format)?n.format:Le(2)}function qp(n){var e;return n.value.rawValue.length===1?new fr(n.document,{formatter:vr(n.params),value:n.value,viewProps:n.viewProps}):new mr(n.document,{formatter:vr(n.params),lineCount:(e=n.params.lineCount)!==null&&e!==void 0?e:gi.monitor.defaultLineCount,value:n.value,viewProps:n.viewProps})}function Qp(n){var e,t,l;return new Yp(n.document,{formatter:vr(n.params),lineCount:(e=n.params.lineCount)!==null&&e!==void 0?e:gi.monitor.defaultLineCount,props:q.fromObject({maxValue:(t="max"in n.params?n.params.max:null)!==null&&t!==void 0?t:100,minValue:(l="min"in n.params?n.params.min:null)!==null&&l!==void 0?l:0}),value:n.value,viewProps:n.viewProps})}function Eo(n){return"view"in n&&n.view==="graph"}const Zp={id:"monitor-number",type:"monitor",accept:(n,e)=>{if(typeof n!="number")return null;const t=V,l=ce(e,{format:t.optional.function,lineCount:t.optional.number,max:t.optional.number,min:t.optional.number,view:t.optional.string});return l?{initialValue:n,params:l}:null},binding:{defaultBufferSize:n=>Eo(n)?64:1,reader:n=>rt},controller:n=>Eo(n.params)?Qp(n):qp(n)},Wp={id:"monitor-string",type:"monitor",accept:(n,e)=>{if(typeof n!="string")return null;const t=V,l=ce(e,{lineCount:t.optional.number,multiline:t.optional.boolean});return l?{initialValue:n,params:l}:null},binding:{reader:n=>ai},controller:n=>{var e;const t=n.value;return t.rawValue.length>1||"multiline"in n.params&&n.params.multiline?new mr(n.document,{formatter:pt,lineCount:(e=n.params.lineCount)!==null&&e!==void 0?e:gi.monitor.defaultLineCount,value:t,viewProps:n.viewProps}):new fr(n.document,{formatter:pt,value:t,viewProps:n.viewProps})}};function Jp(n,e){var t;const l=n.accept(e.target.read(),e.params);if(w(l))return null;const b=V,P={target:e.target,initialValue:l.initialValue,params:l.params},A=n.binding.reader(P),U=n.binding.constraint?n.binding.constraint(P):void 0,W=ee(A(l.initialValue),{constraint:U,equals:n.binding.equals}),H=new Mn({reader:A,target:e.target,value:W,writer:n.binding.writer(P)}),de=b.optional.boolean(e.params.disabled).value,ve=b.optional.boolean(e.params.hidden).value,dn=n.controller({constraint:U,document:e.document,initialValue:l.initialValue,params:l.params,value:H.value,viewProps:ze.create({disabled:de,hidden:ve})});return new Te(e.document,{binding:H,blade:ye(),props:q.fromObject({label:"label"in e.params?(t=b.optional.string(e.params.label).value)!==null&&t!==void 0?t:null:e.target.key}),valueController:dn})}function Hp(n,e){return e===0?new Di:new ei(n,e??gi.monitor.defaultInterval)}function eu(n,e){var t,l,b;const P=V,A=n.accept(e.target.read(),e.params);if(w(A))return null;const U={target:e.target,initialValue:A.initialValue,params:A.params},W=n.binding.reader(U),H=(l=(t=P.optional.number(e.params.bufferSize).value)!==null&&t!==void 0?t:n.binding.defaultBufferSize&&n.binding.defaultBufferSize(A.params))!==null&&l!==void 0?l:1,de=P.optional.number(e.params.interval).value,ve=new Is({reader:W,target:e.target,ticker:Hp(e.document,de),value:Ti(H)}),dn=P.optional.boolean(e.params.disabled).value,_i=P.optional.boolean(e.params.hidden).value,wi=n.controller({document:e.document,params:A.params,value:ve.value,viewProps:ze.create({disabled:dn,hidden:_i})});return new Ze(e.document,{binding:ve,blade:ye(),props:q.fromObject({label:"label"in e.params?(b=P.optional.string(e.params.label).value)!==null&&b!==void 0?b:null:e.target.key}),valueController:wi})}class tu{constructor(){this.pluginsMap_={blades:[],inputs:[],monitors:[]}}getAll(){return[...this.pluginsMap_.blades,...this.pluginsMap_.inputs,...this.pluginsMap_.monitors]}register(e){e.type==="blade"?this.pluginsMap_.blades.unshift(e):e.type==="input"?this.pluginsMap_.inputs.unshift(e):e.type==="monitor"&&this.pluginsMap_.monitors.unshift(e)}createInput(e,t,l){const b=t.read();if(w(b))throw new I({context:{key:t.key},type:"nomatchingcontroller"});const P=this.pluginsMap_.inputs.reduce((A,U)=>A??Jp(U,{document:e,target:t,params:l}),null);if(P)return P;throw new I({context:{key:t.key},type:"nomatchingcontroller"})}createMonitor(e,t,l){const b=this.pluginsMap_.monitors.reduce((P,A)=>P??eu(A,{document:e,params:l,target:t}),null);if(b)return b;throw new I({context:{key:t.key},type:"nomatchingcontroller"})}createBlade(e,t){const l=this.pluginsMap_.blades.reduce((b,P)=>b??Vs(P,{document:e,params:t}),null);if(!l)throw new I({type:"nomatchingview",context:{params:t}});return l}createBladeApi(e){if(e instanceof Te)return new Xn(e);if(e instanceof Ze)return new Yn(e);if(e instanceof Zt)return new xn(e,this);const t=this.pluginsMap_.blades.reduce((l,b)=>l??b.api({controller:e,pool:this}),null);if(!t)throw I.shouldNeverHappen();return t}}function nu(){const n=new tu;return[lu,Op,zp,Rp,Sp,xp,yp,bp,Dn,$p,Wp,Zp,J,Ms,Ss,Hn].forEach(e=>{n.register(e)}),n}function iu(n){return Nt.isObject(n)?new Nt(n.x,n.y):new Nt}function su(n,e){n.writeProperty("x",e.x),n.writeProperty("y",e.y)}function Ct(n,e){if(!n)return;const t=[],l=ko(n,e);l&&t.push(l);const b=So(n);return b&&t.push(b),new Ht(t)}function ru(n,e){return new Bt({assembly:Lo,components:[Ct("x"in n?n.x:void 0,e.x),Ct("y"in n?n.y:void 0,e.y)]})}function Oo(n,e){const[t,l]=n?Mp(n):[];if(!w(t)||!w(l))return Math.max(Math.abs(t??0),Math.abs(l??0));const b=wt(n);return Math.max(Math.abs(b)*10,Math.abs(e)*10)}function ou(n,e){const t=e instanceof Bt?e.components[0]:void 0,l=e instanceof Bt?e.components[1]:void 0,b=Oo(t,n.x),P=Oo(l,n.y);return Math.max(b,P)}function Bo(n,e){return{baseStep:wt(e),constraint:e,textProps:q.fromObject({draggingScale:yt(e,n),formatter:Le(In(e,n))})}}function au(n){if(!("y"in n))return!1;const e=n.y;return e&&"inverted"in e?!!e.inverted:!1}const lu={id:"input-point2d",type:"input",accept:(n,e)=>{if(!Nt.isObject(n))return null;const t=V,l=ce(e,{expanded:t.optional.boolean,picker:t.optional.custom(mi),x:t.optional.custom(ot),y:t.optional.object({inverted:t.optional.boolean,max:t.optional.number,min:t.optional.number,step:t.optional.number})});return l?{initialValue:n,params:l}:null},binding:{reader:n=>iu,constraint:n=>ru(n.params,n.initialValue),equals:Nt.equals,writer:n=>su},controller:n=>{const e=n.document,t=n.value,l=n.constraint;if(!(l instanceof Bt))throw I.shouldNeverHappen();const b="expanded"in n.params?n.params.expanded:void 0,P="picker"in n.params?n.params.picker:void 0;return new Ip(e,{axes:[Bo(t.rawValue.x,l.components[0]),Bo(t.rawValue.y,l.components[1])],expanded:b??!1,invertsY:au(n.params),maxValue:ou(t.rawValue,l),parser:Je,pickerLayout:P??"popup",value:t,viewProps:n.viewProps})}};class No extends a{constructor(e){super(e),this.emitter_=new z,this.controller_.valueController.value.emitter.on("change",t=>{this.emitter_.emit("change",{event:new u(this,t.rawValue)})})}get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}get options(){return this.controller_.valueController.props.get("options")}set options(e){this.controller_.valueController.props.set("options",e)}get value(){return this.controller_.valueController.value.rawValue}set value(e){this.controller_.valueController.value.rawValue=e}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}}class Fo extends a{constructor(e){super(e),this.emitter_=new z,this.controller_.valueController.value.emitter.on("change",t=>{this.emitter_.emit("change",{event:new u(this,t.rawValue)})})}get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}get maxValue(){return this.controller_.valueController.sliderController.props.get("maxValue")}set maxValue(e){this.controller_.valueController.sliderController.props.set("maxValue",e)}get minValue(){return this.controller_.valueController.sliderController.props.get("minValue")}set minValue(e){this.controller_.valueController.sliderController.props.set("minValue",e)}get value(){return this.controller_.valueController.value.rawValue}set value(e){this.controller_.valueController.value.rawValue=e}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}}class jo extends a{constructor(e){super(e),this.emitter_=new z,this.controller_.valueController.value.emitter.on("change",t=>{this.emitter_.emit("change",{event:new u(this,t.rawValue)})})}get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}get formatter(){return this.controller_.valueController.props.get("formatter")}set formatter(e){this.controller_.valueController.props.set("formatter",e)}get value(){return this.controller_.valueController.value.rawValue}set value(e){this.controller_.valueController.value.rawValue=e}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}}const cu=function(){return{id:"list",type:"blade",accept(n){const e=V,t=ce(n,{options:e.required.custom(ln),value:e.required.raw,view:e.required.constant("list"),label:e.optional.string});return t?{params:t}:null},controller(n){const e=new en(Qi(n.params.options)),t=ee(n.params.value,{constraint:e}),l=new tn(n.document,{props:new q({options:e.values.value("options")}),value:t,viewProps:n.viewProps});return new Lt(n.document,{blade:n.blade,props:q.fromObject({label:n.params.label}),valueController:l})},api(n){return!(n.controller instanceof Lt)||!(n.controller.valueController instanceof tn)?null:new No(n.controller)}}}();function pu(n){return n.reduce((e,t)=>Object.assign(e,{[t.presetKey]:t.read()}),{})}function uu(n,e){n.forEach(t=>{const l=e[t.target.presetKey];l!==void 0&&t.writer(t.target,t.reader(l))})}class hu extends qn{constructor(e,t){super(e,t)}get element(){return this.controller_.view.element}importPreset(e){const t=this.controller_.rackController.rack.find(Te).map(l=>l.binding);uu(t,e),this.refresh()}exportPreset(){const e=this.controller_.rackController.rack.find(Te).map(t=>t.binding.target);return pu(e)}refresh(){this.controller_.rackController.rack.find(Te).forEach(e=>{e.binding.read()}),this.controller_.rackController.rack.find(Ze).forEach(e=>{e.binding.read()})}}class du extends Cn{constructor(e,t){super(e,{expanded:t.expanded,blade:t.blade,props:t.props,root:!0,viewProps:t.viewProps})}}const mu={id:"slider",type:"blade",accept(n){const e=V,t=ce(n,{max:e.required.number,min:e.required.number,view:e.required.constant("slider"),format:e.optional.function,label:e.optional.string,value:e.optional.number});return t?{params:t}:null},controller(n){var e,t;const l=(e=n.params.value)!==null&&e!==void 0?e:0,b=new Dt({max:n.params.max,min:n.params.min}),P=new Vn(n.document,{baseStep:1,parser:Je,sliderProps:new q({maxValue:b.values.value("max"),minValue:b.values.value("min")}),textProps:q.fromObject({draggingScale:yt(void 0,l),formatter:(t=n.params.format)!==null&&t!==void 0?t:Qs}),value:ee(l,{constraint:b}),viewProps:n.viewProps});return new Lt(n.document,{blade:n.blade,props:q.fromObject({label:n.params.label}),valueController:P})},api(n){return!(n.controller instanceof Lt)||!(n.controller.valueController instanceof Vn)?null:new Fo(n.controller)}},fu=function(){return{id:"text",type:"blade",accept(n){const e=V,t=ce(n,{parse:e.required.function,value:e.required.raw,view:e.required.constant("text"),format:e.optional.function,label:e.optional.string});return t?{params:t}:null},controller(n){var e;const t=new Sn(n.document,{parser:n.params.parse,props:q.fromObject({formatter:(e=n.params.format)!==null&&e!==void 0?e:l=>String(l)}),value:ee(n.params.value),viewProps:n.viewProps});return new Lt(n.document,{blade:n.blade,props:q.fromObject({label:n.params.label}),valueController:t})},api(n){return!(n.controller instanceof Lt)||!(n.controller.valueController instanceof Sn)?null:new jo(n.controller)}}}();function vu(n){const e=n.createElement("div");return e.classList.add(N("dfw")()),n.body&&n.body.appendChild(e),e}function zo(n,e,t){if(n.querySelector(`style[data-tp-style=${e}]`))return;const l=n.createElement("style");l.dataset.tpStyle=e,l.textContent=t,n.head.appendChild(l)}class bu extends hu{constructor(e){var t,l;const b=e??{},P=(t=b.document)!==null&&t!==void 0?t:Kn(),A=nu(),U=new du(P,{expanded:b.expanded,blade:ye(),props:q.fromObject({title:b.title}),viewProps:ze.create()});super(U,A),this.pool_=A,this.containerElem_=(l=b.container)!==null&&l!==void 0?l:vu(P),this.containerElem_.appendChild(this.element),this.doc_=P,this.usesDefaultWrapper_=!b.container,this.setUpDefaultPlugins_()}get document(){if(!this.doc_)throw I.alreadyDisposed();return this.doc_}dispose(){const e=this.containerElem_;if(!e)throw I.alreadyDisposed();if(this.usesDefaultWrapper_){const t=e.parentElement;t&&t.removeChild(e)}this.containerElem_=null,this.doc_=null,super.dispose()}registerPlugin(e){("plugin"in e?[e.plugin]:"plugins"in e?e.plugins:[]).forEach(l=>{this.pool_.register(l),this.embedPluginStyle_(l)})}embedPluginStyle_(e){e.css&&zo(this.document,`plugin-${e.id}`,e.css)}setUpDefaultPlugins_(){zo(this.document,"default",'.tp-tbiv_b,.tp-coltxtv_ms,.tp-ckbv_i,.tp-rotv_b,.tp-fldv_b,.tp-mllv_i,.tp-sglv_i,.tp-grlv_g,.tp-txtv_i,.tp-p2dpv_p,.tp-colswv_sw,.tp-p2dv_b,.tp-btnv_b,.tp-lstv_s{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:rgba(0,0,0,0);border-width:0;font-family:inherit;font-size:inherit;font-weight:inherit;margin:0;outline:none;padding:0}.tp-p2dv_b,.tp-btnv_b,.tp-lstv_s{background-color:var(--btn-bg);border-radius:var(--elm-br);color:var(--btn-fg);cursor:pointer;display:block;font-weight:bold;height:var(--bld-us);line-height:var(--bld-us);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-p2dv_b:hover,.tp-btnv_b:hover,.tp-lstv_s:hover{background-color:var(--btn-bg-h)}.tp-p2dv_b:focus,.tp-btnv_b:focus,.tp-lstv_s:focus{background-color:var(--btn-bg-f)}.tp-p2dv_b:active,.tp-btnv_b:active,.tp-lstv_s:active{background-color:var(--btn-bg-a)}.tp-p2dv_b:disabled,.tp-btnv_b:disabled,.tp-lstv_s:disabled{opacity:.5}.tp-txtv_i,.tp-p2dpv_p,.tp-colswv_sw{background-color:var(--in-bg);border-radius:var(--elm-br);box-sizing:border-box;color:var(--in-fg);font-family:inherit;height:var(--bld-us);line-height:var(--bld-us);min-width:0;width:100%}.tp-txtv_i:hover,.tp-p2dpv_p:hover,.tp-colswv_sw:hover{background-color:var(--in-bg-h)}.tp-txtv_i:focus,.tp-p2dpv_p:focus,.tp-colswv_sw:focus{background-color:var(--in-bg-f)}.tp-txtv_i:active,.tp-p2dpv_p:active,.tp-colswv_sw:active{background-color:var(--in-bg-a)}.tp-txtv_i:disabled,.tp-p2dpv_p:disabled,.tp-colswv_sw:disabled{opacity:.5}.tp-mllv_i,.tp-sglv_i,.tp-grlv_g{background-color:var(--mo-bg);border-radius:var(--elm-br);box-sizing:border-box;color:var(--mo-fg);height:var(--bld-us);scrollbar-color:currentColor rgba(0,0,0,0);scrollbar-width:thin;width:100%}.tp-mllv_i::-webkit-scrollbar,.tp-sglv_i::-webkit-scrollbar,.tp-grlv_g::-webkit-scrollbar{height:8px;width:8px}.tp-mllv_i::-webkit-scrollbar-corner,.tp-sglv_i::-webkit-scrollbar-corner,.tp-grlv_g::-webkit-scrollbar-corner{background-color:rgba(0,0,0,0)}.tp-mllv_i::-webkit-scrollbar-thumb,.tp-sglv_i::-webkit-scrollbar-thumb,.tp-grlv_g::-webkit-scrollbar-thumb{background-clip:padding-box;background-color:currentColor;border:rgba(0,0,0,0) solid 2px;border-radius:4px}.tp-rotv{--font-family: var(--tp-font-family, Roboto Mono, Source Code Pro, Menlo, Courier, monospace);--bs-br: var(--tp-base-border-radius, 6px);--cnt-h-p: var(--tp-container-horizontal-padding, 4px);--cnt-v-p: var(--tp-container-vertical-padding, 4px);--elm-br: var(--tp-element-border-radius, 2px);--bld-s: var(--tp-blade-spacing, 4px);--bld-us: var(--tp-blade-unit-size, 20px);--bs-bg: var(--tp-base-background-color, hsl(230, 7%, 17%));--bs-sh: var(--tp-base-shadow-color, rgba(0, 0, 0, 0.2));--btn-bg: var(--tp-button-background-color, hsl(230, 7%, 70%));--btn-bg-a: var(--tp-button-background-color-active, #d6d7db);--btn-bg-f: var(--tp-button-background-color-focus, #c8cad0);--btn-bg-h: var(--tp-button-background-color-hover, #bbbcc4);--btn-fg: var(--tp-button-foreground-color, hsl(230, 7%, 17%));--cnt-bg: var(--tp-container-background-color, rgba(187, 188, 196, 0.1));--cnt-bg-a: var(--tp-container-background-color-active, rgba(187, 188, 196, 0.25));--cnt-bg-f: var(--tp-container-background-color-focus, rgba(187, 188, 196, 0.2));--cnt-bg-h: var(--tp-container-background-color-hover, rgba(187, 188, 196, 0.15));--cnt-fg: var(--tp-container-foreground-color, hsl(230, 7%, 75%));--in-bg: var(--tp-input-background-color, rgba(187, 188, 196, 0.1));--in-bg-a: var(--tp-input-background-color-active, rgba(187, 188, 196, 0.25));--in-bg-f: var(--tp-input-background-color-focus, rgba(187, 188, 196, 0.2));--in-bg-h: var(--tp-input-background-color-hover, rgba(187, 188, 196, 0.15));--in-fg: var(--tp-input-foreground-color, hsl(230, 7%, 75%));--lbl-fg: var(--tp-label-foreground-color, rgba(187, 188, 196, 0.7));--mo-bg: var(--tp-monitor-background-color, rgba(0, 0, 0, 0.2));--mo-fg: var(--tp-monitor-foreground-color, rgba(187, 188, 196, 0.7));--grv-fg: var(--tp-groove-foreground-color, rgba(187, 188, 196, 0.1))}.tp-rotv_c>.tp-cntv.tp-v-lst,.tp-tabv_c .tp-brkv>.tp-cntv.tp-v-lst,.tp-fldv_c>.tp-cntv.tp-v-lst{margin-bottom:calc(-1*var(--cnt-v-p))}.tp-rotv_c>.tp-fldv.tp-v-lst .tp-fldv_c,.tp-tabv_c .tp-brkv>.tp-fldv.tp-v-lst .tp-fldv_c,.tp-fldv_c>.tp-fldv.tp-v-lst .tp-fldv_c{border-bottom-left-radius:0}.tp-rotv_c>.tp-fldv.tp-v-lst .tp-fldv_b,.tp-tabv_c .tp-brkv>.tp-fldv.tp-v-lst .tp-fldv_b,.tp-fldv_c>.tp-fldv.tp-v-lst .tp-fldv_b{border-bottom-left-radius:0}.tp-rotv_c>*:not(.tp-v-fst),.tp-tabv_c .tp-brkv>*:not(.tp-v-fst),.tp-fldv_c>*:not(.tp-v-fst){margin-top:var(--bld-s)}.tp-rotv_c>.tp-sprv:not(.tp-v-fst),.tp-tabv_c .tp-brkv>.tp-sprv:not(.tp-v-fst),.tp-fldv_c>.tp-sprv:not(.tp-v-fst),.tp-rotv_c>.tp-cntv:not(.tp-v-fst),.tp-tabv_c .tp-brkv>.tp-cntv:not(.tp-v-fst),.tp-fldv_c>.tp-cntv:not(.tp-v-fst){margin-top:var(--cnt-v-p)}.tp-rotv_c>.tp-sprv+*:not(.tp-v-hidden),.tp-tabv_c .tp-brkv>.tp-sprv+*:not(.tp-v-hidden),.tp-fldv_c>.tp-sprv+*:not(.tp-v-hidden),.tp-rotv_c>.tp-cntv+*:not(.tp-v-hidden),.tp-tabv_c .tp-brkv>.tp-cntv+*:not(.tp-v-hidden),.tp-fldv_c>.tp-cntv+*:not(.tp-v-hidden){margin-top:var(--cnt-v-p)}.tp-rotv_c>.tp-sprv:not(.tp-v-hidden)+.tp-sprv,.tp-tabv_c .tp-brkv>.tp-sprv:not(.tp-v-hidden)+.tp-sprv,.tp-fldv_c>.tp-sprv:not(.tp-v-hidden)+.tp-sprv,.tp-rotv_c>.tp-cntv:not(.tp-v-hidden)+.tp-cntv,.tp-tabv_c .tp-brkv>.tp-cntv:not(.tp-v-hidden)+.tp-cntv,.tp-fldv_c>.tp-cntv:not(.tp-v-hidden)+.tp-cntv{margin-top:0}.tp-tabv_c .tp-brkv>.tp-cntv,.tp-fldv_c>.tp-cntv{margin-left:4px}.tp-tabv_c .tp-brkv>.tp-fldv>.tp-fldv_b,.tp-fldv_c>.tp-fldv>.tp-fldv_b{border-top-left-radius:var(--elm-br);border-bottom-left-radius:var(--elm-br)}.tp-tabv_c .tp-brkv>.tp-fldv.tp-fldv-expanded>.tp-fldv_b,.tp-fldv_c>.tp-fldv.tp-fldv-expanded>.tp-fldv_b{border-bottom-left-radius:0}.tp-tabv_c .tp-brkv .tp-fldv>.tp-fldv_c,.tp-fldv_c .tp-fldv>.tp-fldv_c{border-bottom-left-radius:var(--elm-br)}.tp-tabv_c .tp-brkv>.tp-cntv+.tp-fldv>.tp-fldv_b,.tp-fldv_c>.tp-cntv+.tp-fldv>.tp-fldv_b{border-top-left-radius:0}.tp-tabv_c .tp-brkv>.tp-cntv+.tp-tabv>.tp-tabv_t,.tp-fldv_c>.tp-cntv+.tp-tabv>.tp-tabv_t{border-top-left-radius:0}.tp-tabv_c .tp-brkv>.tp-tabv>.tp-tabv_t,.tp-fldv_c>.tp-tabv>.tp-tabv_t{border-top-left-radius:var(--elm-br)}.tp-tabv_c .tp-brkv .tp-tabv>.tp-tabv_c,.tp-fldv_c .tp-tabv>.tp-tabv_c{border-bottom-left-radius:var(--elm-br)}.tp-rotv_b,.tp-fldv_b{background-color:var(--cnt-bg);color:var(--cnt-fg);cursor:pointer;display:block;height:calc(var(--bld-us) + 4px);line-height:calc(var(--bld-us) + 4px);overflow:hidden;padding-left:var(--cnt-h-p);padding-right:calc(4px + var(--bld-us) + var(--cnt-h-p));position:relative;text-align:left;text-overflow:ellipsis;white-space:nowrap;width:100%;transition:border-radius .2s ease-in-out .2s}.tp-rotv_b:hover,.tp-fldv_b:hover{background-color:var(--cnt-bg-h)}.tp-rotv_b:focus,.tp-fldv_b:focus{background-color:var(--cnt-bg-f)}.tp-rotv_b:active,.tp-fldv_b:active{background-color:var(--cnt-bg-a)}.tp-rotv_b:disabled,.tp-fldv_b:disabled{opacity:.5}.tp-rotv_m,.tp-fldv_m{background:linear-gradient(to left, var(--cnt-fg), var(--cnt-fg) 2px, transparent 2px, transparent 4px, var(--cnt-fg) 4px);border-radius:2px;bottom:0;content:"";display:block;height:6px;right:calc(var(--cnt-h-p) + (var(--bld-us) + 4px - 6px)/2 - 2px);margin:auto;opacity:.5;position:absolute;top:0;transform:rotate(90deg);transition:transform .2s ease-in-out;width:6px}.tp-rotv.tp-rotv-expanded .tp-rotv_m,.tp-fldv.tp-fldv-expanded>.tp-fldv_b>.tp-fldv_m{transform:none}.tp-rotv_c,.tp-fldv_c{box-sizing:border-box;height:0;opacity:0;overflow:hidden;padding-bottom:0;padding-top:0;position:relative;transition:height .2s ease-in-out,opacity .2s linear,padding .2s ease-in-out}.tp-rotv.tp-rotv-cpl:not(.tp-rotv-expanded) .tp-rotv_c,.tp-fldv.tp-fldv-cpl:not(.tp-fldv-expanded)>.tp-fldv_c{display:none}.tp-rotv.tp-rotv-expanded .tp-rotv_c,.tp-fldv.tp-fldv-expanded>.tp-fldv_c{opacity:1;padding-bottom:var(--cnt-v-p);padding-top:var(--cnt-v-p);transform:none;overflow:visible;transition:height .2s ease-in-out,opacity .2s linear .2s,padding .2s ease-in-out}.tp-lstv,.tp-coltxtv_m{position:relative}.tp-lstv_s{padding:0 20px 0 4px;width:100%}.tp-lstv_m,.tp-coltxtv_mm{bottom:0;margin:auto;pointer-events:none;position:absolute;right:2px;top:0}.tp-lstv_m svg,.tp-coltxtv_mm svg{bottom:0;height:16px;margin:auto;position:absolute;right:0;top:0;width:16px}.tp-lstv_m svg path,.tp-coltxtv_mm svg path{fill:currentColor}.tp-pndtxtv,.tp-coltxtv_w{display:flex}.tp-pndtxtv_a,.tp-coltxtv_c{width:100%}.tp-pndtxtv_a+.tp-pndtxtv_a,.tp-coltxtv_c+.tp-pndtxtv_a,.tp-pndtxtv_a+.tp-coltxtv_c,.tp-coltxtv_c+.tp-coltxtv_c{margin-left:2px}.tp-btnv_b{width:100%}.tp-btnv_t{text-align:center}.tp-ckbv_l{display:block;position:relative}.tp-ckbv_i{left:0;opacity:0;position:absolute;top:0}.tp-ckbv_w{background-color:var(--in-bg);border-radius:var(--elm-br);cursor:pointer;display:block;height:var(--bld-us);position:relative;width:var(--bld-us)}.tp-ckbv_w svg{bottom:0;display:block;height:16px;left:0;margin:auto;opacity:0;position:absolute;right:0;top:0;width:16px}.tp-ckbv_w svg path{fill:none;stroke:var(--in-fg);stroke-width:2}.tp-ckbv_i:hover+.tp-ckbv_w{background-color:var(--in-bg-h)}.tp-ckbv_i:focus+.tp-ckbv_w{background-color:var(--in-bg-f)}.tp-ckbv_i:active+.tp-ckbv_w{background-color:var(--in-bg-a)}.tp-ckbv_i:checked+.tp-ckbv_w svg{opacity:1}.tp-ckbv.tp-v-disabled .tp-ckbv_w{opacity:.5}.tp-colv{position:relative}.tp-colv_h{display:flex}.tp-colv_s{flex-grow:0;flex-shrink:0;width:var(--bld-us)}.tp-colv_t{flex:1;margin-left:4px}.tp-colv_p{height:0;margin-top:0;opacity:0;overflow:hidden;transition:height .2s ease-in-out,opacity .2s linear,margin .2s ease-in-out}.tp-colv.tp-colv-cpl .tp-colv_p{overflow:visible}.tp-colv.tp-colv-expanded .tp-colv_p{margin-top:var(--bld-s);opacity:1}.tp-colv .tp-popv{left:calc(-1*var(--cnt-h-p));right:calc(-1*var(--cnt-h-p));top:var(--bld-us)}.tp-colpv_h,.tp-colpv_ap{margin-left:6px;margin-right:6px}.tp-colpv_h{margin-top:var(--bld-s)}.tp-colpv_rgb{display:flex;margin-top:var(--bld-s);width:100%}.tp-colpv_a{display:flex;margin-top:var(--cnt-v-p);padding-top:calc(var(--cnt-v-p) + 2px);position:relative}.tp-colpv_a::before{background-color:var(--grv-fg);content:"";height:2px;left:calc(-1*var(--cnt-h-p));position:absolute;right:calc(-1*var(--cnt-h-p));top:0}.tp-colpv.tp-v-disabled .tp-colpv_a::before{opacity:.5}.tp-colpv_ap{align-items:center;display:flex;flex:3}.tp-colpv_at{flex:1;margin-left:4px}.tp-svpv{border-radius:var(--elm-br);outline:none;overflow:hidden;position:relative}.tp-svpv.tp-v-disabled{opacity:.5}.tp-svpv_c{cursor:crosshair;display:block;height:calc(var(--bld-us)*4);width:100%}.tp-svpv_m{border-radius:100%;border:rgba(255,255,255,.75) solid 2px;box-sizing:border-box;filter:drop-shadow(0 0 1px rgba(0, 0, 0, 0.3));height:12px;margin-left:-6px;margin-top:-6px;pointer-events:none;position:absolute;width:12px}.tp-svpv:focus .tp-svpv_m{border-color:#fff}.tp-hplv{cursor:pointer;height:var(--bld-us);outline:none;position:relative}.tp-hplv.tp-v-disabled{opacity:.5}.tp-hplv_c{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAAABCAYAAABubagXAAAAQ0lEQVQoU2P8z8Dwn0GCgQEDi2OK/RBgYHjBgIpfovFh8j8YBIgzFGQxuqEgPhaDOT5gOhPkdCxOZeBg+IDFZZiGAgCaSSMYtcRHLgAAAABJRU5ErkJggg==);background-position:left top;background-repeat:no-repeat;background-size:100% 100%;border-radius:2px;display:block;height:4px;left:0;margin-top:-2px;position:absolute;top:50%;width:100%}.tp-hplv_m{border-radius:var(--elm-br);border:rgba(255,255,255,.75) solid 2px;box-shadow:0 0 2px rgba(0,0,0,.1);box-sizing:border-box;height:12px;left:50%;margin-left:-6px;margin-top:-6px;pointer-events:none;position:absolute;top:50%;width:12px}.tp-hplv:focus .tp-hplv_m{border-color:#fff}.tp-aplv{cursor:pointer;height:var(--bld-us);outline:none;position:relative;width:100%}.tp-aplv.tp-v-disabled{opacity:.5}.tp-aplv_b{background-color:#fff;background-image:linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%),linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%);background-size:4px 4px;background-position:0 0,2px 2px;border-radius:2px;display:block;height:4px;left:0;margin-top:-2px;overflow:hidden;position:absolute;top:50%;width:100%}.tp-aplv_c{bottom:0;left:0;position:absolute;right:0;top:0}.tp-aplv_m{background-color:#fff;background-image:linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%),linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%);background-size:12px 12px;background-position:0 0,6px 6px;border-radius:var(--elm-br);box-shadow:0 0 2px rgba(0,0,0,.1);height:12px;left:50%;margin-left:-6px;margin-top:-6px;overflow:hidden;pointer-events:none;position:absolute;top:50%;width:12px}.tp-aplv_p{border-radius:var(--elm-br);border:rgba(255,255,255,.75) solid 2px;box-sizing:border-box;bottom:0;left:0;position:absolute;right:0;top:0}.tp-aplv:focus .tp-aplv_p{border-color:#fff}.tp-colswv{background-color:#fff;background-image:linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%),linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%);background-size:10px 10px;background-position:0 0,5px 5px;border-radius:var(--elm-br);overflow:hidden}.tp-colswv.tp-v-disabled{opacity:.5}.tp-colswv_sw{border-radius:0}.tp-colswv_b{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:rgba(0,0,0,0);border-width:0;cursor:pointer;display:block;height:var(--bld-us);left:0;margin:0;outline:none;padding:0;position:absolute;top:0;width:var(--bld-us)}.tp-colswv_b:focus::after{border:rgba(255,255,255,.75) solid 2px;border-radius:var(--elm-br);bottom:0;content:"";display:block;left:0;position:absolute;right:0;top:0}.tp-coltxtv{display:flex;width:100%}.tp-coltxtv_m{margin-right:4px}.tp-coltxtv_ms{border-radius:var(--elm-br);color:var(--lbl-fg);cursor:pointer;height:var(--bld-us);line-height:var(--bld-us);padding:0 18px 0 4px}.tp-coltxtv_ms:hover{background-color:var(--in-bg-h)}.tp-coltxtv_ms:focus{background-color:var(--in-bg-f)}.tp-coltxtv_ms:active{background-color:var(--in-bg-a)}.tp-coltxtv_mm{color:var(--lbl-fg)}.tp-coltxtv.tp-v-disabled .tp-coltxtv_mm{opacity:.5}.tp-coltxtv_w{flex:1}.tp-dfwv{position:absolute;top:8px;right:8px;width:256px}.tp-fldv{position:relative}.tp-fldv.tp-fldv-not .tp-fldv_b{display:none}.tp-fldv_t{padding-left:4px}.tp-fldv_b:disabled .tp-fldv_m{display:none}.tp-fldv_c{padding-left:4px}.tp-fldv_i{bottom:0;color:var(--cnt-bg);left:0;overflow:hidden;position:absolute;top:calc(var(--bld-us) + 4px);width:var(--bs-br)}.tp-fldv_i::before{background-color:currentColor;bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.tp-fldv_b:hover+.tp-fldv_i{color:var(--cnt-bg-h)}.tp-fldv_b:focus+.tp-fldv_i{color:var(--cnt-bg-f)}.tp-fldv_b:active+.tp-fldv_i{color:var(--cnt-bg-a)}.tp-fldv.tp-v-disabled>.tp-fldv_i{opacity:.5}.tp-grlv{position:relative}.tp-grlv_g{display:block;height:calc(var(--bld-us)*3)}.tp-grlv_g polyline{fill:none;stroke:var(--mo-fg);stroke-linejoin:round}.tp-grlv_t{margin-top:-4px;transition:left .05s,top .05s;visibility:hidden}.tp-grlv_t.tp-grlv_t-a{visibility:visible}.tp-grlv_t.tp-grlv_t-in{transition:none}.tp-grlv.tp-v-disabled .tp-grlv_g{opacity:.5}.tp-grlv .tp-ttv{background-color:var(--mo-fg)}.tp-grlv .tp-ttv::before{border-top-color:var(--mo-fg)}.tp-lblv{align-items:center;display:flex;line-height:1.3;padding-left:var(--cnt-h-p);padding-right:var(--cnt-h-p)}.tp-lblv.tp-lblv-nol{display:block}.tp-lblv_l{color:var(--lbl-fg);flex:1;-webkit-hyphens:auto;hyphens:auto;overflow:hidden;padding-left:4px;padding-right:16px}.tp-lblv.tp-v-disabled .tp-lblv_l{opacity:.5}.tp-lblv.tp-lblv-nol .tp-lblv_l{display:none}.tp-lblv_v{align-self:flex-start;flex-grow:0;flex-shrink:0;width:160px}.tp-lblv.tp-lblv-nol .tp-lblv_v{width:100%}.tp-lstv_s{padding:0 20px 0 4px;width:100%}.tp-lstv_m{color:var(--btn-fg)}.tp-sglv_i{padding:0 4px}.tp-sglv.tp-v-disabled .tp-sglv_i{opacity:.5}.tp-mllv_i{display:block;height:calc(var(--bld-us)*3);line-height:var(--bld-us);padding:0 4px;resize:none;white-space:pre}.tp-mllv.tp-v-disabled .tp-mllv_i{opacity:.5}.tp-p2dv{position:relative}.tp-p2dv_h{display:flex}.tp-p2dv_b{height:var(--bld-us);margin-right:4px;position:relative;width:var(--bld-us)}.tp-p2dv_b svg{display:block;height:16px;left:50%;margin-left:-8px;margin-top:-8px;position:absolute;top:50%;width:16px}.tp-p2dv_b svg path{stroke:currentColor;stroke-width:2}.tp-p2dv_b svg circle{fill:currentColor}.tp-p2dv_t{flex:1}.tp-p2dv_p{height:0;margin-top:0;opacity:0;overflow:hidden;transition:height .2s ease-in-out,opacity .2s linear,margin .2s ease-in-out}.tp-p2dv.tp-p2dv-expanded .tp-p2dv_p{margin-top:var(--bld-s);opacity:1}.tp-p2dv .tp-popv{left:calc(-1*var(--cnt-h-p));right:calc(-1*var(--cnt-h-p));top:var(--bld-us)}.tp-p2dpv{padding-left:calc(var(--bld-us) + 4px)}.tp-p2dpv_p{cursor:crosshair;height:0;overflow:hidden;padding-bottom:100%;position:relative}.tp-p2dpv.tp-v-disabled .tp-p2dpv_p{opacity:.5}.tp-p2dpv_g{display:block;height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.tp-p2dpv_ax{opacity:.1;stroke:var(--in-fg);stroke-dasharray:1}.tp-p2dpv_l{opacity:.5;stroke:var(--in-fg);stroke-dasharray:1}.tp-p2dpv_m{border:var(--in-fg) solid 1px;border-radius:50%;box-sizing:border-box;height:4px;margin-left:-2px;margin-top:-2px;position:absolute;width:4px}.tp-p2dpv_p:focus .tp-p2dpv_m{background-color:var(--in-fg);border-width:0}.tp-popv{background-color:var(--bs-bg);border-radius:6px;box-shadow:0 2px 4px var(--bs-sh);display:none;max-width:168px;padding:var(--cnt-v-p) var(--cnt-h-p);position:absolute;visibility:hidden;z-index:1000}.tp-popv.tp-popv-v{display:block;visibility:visible}.tp-sprv_r{background-color:var(--grv-fg);border-width:0;display:block;height:2px;margin:0;width:100%}.tp-sprv.tp-v-disabled .tp-sprv_r{opacity:.5}.tp-sldv.tp-v-disabled{opacity:.5}.tp-sldv_t{box-sizing:border-box;cursor:pointer;height:var(--bld-us);margin:0 6px;outline:none;position:relative}.tp-sldv_t::before{background-color:var(--in-bg);border-radius:1px;bottom:0;content:"";display:block;height:2px;left:0;margin:auto;position:absolute;right:0;top:0}.tp-sldv_k{height:100%;left:0;position:absolute;top:0}.tp-sldv_k::before{background-color:var(--in-fg);border-radius:1px;bottom:0;content:"";display:block;height:2px;left:0;margin-bottom:auto;margin-top:auto;position:absolute;right:0;top:0}.tp-sldv_k::after{background-color:var(--btn-bg);border-radius:var(--elm-br);bottom:0;content:"";display:block;height:12px;margin-bottom:auto;margin-top:auto;position:absolute;right:-6px;top:0;width:12px}.tp-sldv_t:hover .tp-sldv_k::after{background-color:var(--btn-bg-h)}.tp-sldv_t:focus .tp-sldv_k::after{background-color:var(--btn-bg-f)}.tp-sldv_t:active .tp-sldv_k::after{background-color:var(--btn-bg-a)}.tp-sldtxtv{display:flex}.tp-sldtxtv_s{flex:2}.tp-sldtxtv_t{flex:1;margin-left:4px}.tp-tabv{position:relative}.tp-tabv_t{align-items:flex-end;color:var(--cnt-bg);display:flex;overflow:hidden;position:relative}.tp-tabv_t:hover{color:var(--cnt-bg-h)}.tp-tabv_t:has(*:focus){color:var(--cnt-bg-f)}.tp-tabv_t:has(*:active){color:var(--cnt-bg-a)}.tp-tabv_t::before{background-color:currentColor;bottom:0;content:"";height:2px;left:0;pointer-events:none;position:absolute;right:0}.tp-tabv.tp-v-disabled .tp-tabv_t::before{opacity:.5}.tp-tabv.tp-tabv-nop .tp-tabv_t{height:calc(var(--bld-us) + 4px);position:relative}.tp-tabv.tp-tabv-nop .tp-tabv_t::before{background-color:var(--cnt-bg);bottom:0;content:"";height:2px;left:0;position:absolute;right:0}.tp-tabv_c{padding-bottom:var(--cnt-v-p);padding-left:4px;padding-top:var(--cnt-v-p)}.tp-tabv_i{bottom:0;color:var(--cnt-bg);left:0;overflow:hidden;position:absolute;top:calc(var(--bld-us) + 4px);width:var(--bs-br)}.tp-tabv_i::before{background-color:currentColor;bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.tp-tabv_t:hover+.tp-tabv_i{color:var(--cnt-bg-h)}.tp-tabv_t:has(*:focus)+.tp-tabv_i{color:var(--cnt-bg-f)}.tp-tabv_t:has(*:active)+.tp-tabv_i{color:var(--cnt-bg-a)}.tp-tabv.tp-v-disabled>.tp-tabv_i{opacity:.5}.tp-tbiv{flex:1;min-width:0;position:relative}.tp-tbiv+.tp-tbiv{margin-left:2px}.tp-tbiv+.tp-tbiv.tp-v-disabled::before{opacity:.5}.tp-tbiv_b{display:block;padding-left:calc(var(--cnt-h-p) + 4px);padding-right:calc(var(--cnt-h-p) + 4px);position:relative;width:100%}.tp-tbiv_b:disabled{opacity:.5}.tp-tbiv_b::before{background-color:var(--cnt-bg);bottom:2px;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.tp-tbiv_b:hover::before{background-color:var(--cnt-bg-h)}.tp-tbiv_b:focus::before{background-color:var(--cnt-bg-f)}.tp-tbiv_b:active::before{background-color:var(--cnt-bg-a)}.tp-tbiv_t{color:var(--cnt-fg);height:calc(var(--bld-us) + 4px);line-height:calc(var(--bld-us) + 4px);opacity:.5;overflow:hidden;text-overflow:ellipsis}.tp-tbiv.tp-tbiv-sel .tp-tbiv_t{opacity:1}.tp-txtv{position:relative}.tp-txtv_i{padding:0 4px}.tp-txtv.tp-txtv-fst .tp-txtv_i{border-bottom-right-radius:0;border-top-right-radius:0}.tp-txtv.tp-txtv-mid .tp-txtv_i{border-radius:0}.tp-txtv.tp-txtv-lst .tp-txtv_i{border-bottom-left-radius:0;border-top-left-radius:0}.tp-txtv.tp-txtv-num .tp-txtv_i{text-align:right}.tp-txtv.tp-txtv-drg .tp-txtv_i{opacity:.3}.tp-txtv_k{cursor:pointer;height:100%;left:-3px;position:absolute;top:0;width:12px}.tp-txtv_k::before{background-color:var(--in-fg);border-radius:1px;bottom:0;content:"";height:calc(var(--bld-us) - 4px);left:50%;margin-bottom:auto;margin-left:-1px;margin-top:auto;opacity:.1;position:absolute;top:0;transition:border-radius .1s,height .1s,transform .1s,width .1s;width:2px}.tp-txtv_k:hover::before,.tp-txtv.tp-txtv-drg .tp-txtv_k::before{opacity:1}.tp-txtv.tp-txtv-drg .tp-txtv_k::before{border-radius:50%;height:4px;transform:translateX(-1px);width:4px}.tp-txtv_g{bottom:0;display:block;height:8px;left:50%;margin:auto;overflow:visible;pointer-events:none;position:absolute;top:0;visibility:hidden;width:100%}.tp-txtv.tp-txtv-drg .tp-txtv_g{visibility:visible}.tp-txtv_gb{fill:none;stroke:var(--in-fg);stroke-dasharray:1}.tp-txtv_gh{fill:none;stroke:var(--in-fg)}.tp-txtv .tp-ttv{margin-left:6px;visibility:hidden}.tp-txtv.tp-txtv-drg .tp-ttv{visibility:visible}.tp-ttv{background-color:var(--in-fg);border-radius:var(--elm-br);color:var(--bs-bg);padding:2px 4px;pointer-events:none;position:absolute;transform:translate(-50%, -100%)}.tp-ttv::before{border-color:var(--in-fg) rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0);border-style:solid;border-width:2px;box-sizing:border-box;content:"";font-size:.9em;height:4px;left:50%;margin-left:-2px;position:absolute;top:100%;width:4px}.tp-rotv{background-color:var(--bs-bg);border-radius:var(--bs-br);box-shadow:0 2px 4px var(--bs-sh);font-family:var(--font-family);font-size:11px;font-weight:500;line-height:1;text-align:left}.tp-rotv_b{border-bottom-left-radius:var(--bs-br);border-bottom-right-radius:var(--bs-br);border-top-left-radius:var(--bs-br);border-top-right-radius:var(--bs-br);padding-left:calc(4px + var(--bld-us) + var(--cnt-h-p));text-align:center}.tp-rotv.tp-rotv-expanded .tp-rotv_b{border-bottom-left-radius:0;border-bottom-right-radius:0}.tp-rotv.tp-rotv-not .tp-rotv_b{display:none}.tp-rotv_b:disabled .tp-rotv_m{display:none}.tp-rotv_c>.tp-fldv.tp-v-lst>.tp-fldv_c{border-bottom-left-radius:var(--bs-br);border-bottom-right-radius:var(--bs-br)}.tp-rotv_c>.tp-fldv.tp-v-lst>.tp-fldv_i{border-bottom-left-radius:var(--bs-br)}.tp-rotv_c>.tp-fldv.tp-v-lst:not(.tp-fldv-expanded)>.tp-fldv_b{border-bottom-left-radius:var(--bs-br);border-bottom-right-radius:var(--bs-br)}.tp-rotv_c .tp-fldv.tp-v-vlst:not(.tp-fldv-expanded)>.tp-fldv_b{border-bottom-right-radius:var(--bs-br)}.tp-rotv.tp-rotv-not .tp-rotv_c>.tp-fldv.tp-v-fst{margin-top:calc(-1*var(--cnt-v-p))}.tp-rotv.tp-rotv-not .tp-rotv_c>.tp-fldv.tp-v-fst>.tp-fldv_b{border-top-left-radius:var(--bs-br);border-top-right-radius:var(--bs-br)}.tp-rotv_c>.tp-tabv.tp-v-lst>.tp-tabv_c{border-bottom-left-radius:var(--bs-br);border-bottom-right-radius:var(--bs-br)}.tp-rotv_c>.tp-tabv.tp-v-lst>.tp-tabv_i{border-bottom-left-radius:var(--bs-br)}.tp-rotv.tp-rotv-not .tp-rotv_c>.tp-tabv.tp-v-fst{margin-top:calc(-1*var(--cnt-v-p))}.tp-rotv.tp-rotv-not .tp-rotv_c>.tp-tabv.tp-v-fst>.tp-tabv_t{border-top-left-radius:var(--bs-br);border-top-right-radius:var(--bs-br)}.tp-rotv.tp-v-disabled,.tp-rotv .tp-v-disabled{pointer-events:none}.tp-rotv.tp-v-hidden,.tp-rotv .tp-v-hidden{display:none}'),this.pool_.getAll().forEach(e=>{this.embedPluginStyle_(e)}),this.registerPlugin({plugins:[mu,cu,Hn,fu]})}}const gu=new s("3.1.7");r.BladeApi=a,r.ButtonApi=R,r.FolderApi=qn,r.InputBindingApi=Xn,r.ListApi=No,r.MonitorBindingApi=Yn,r.Pane=bu,r.SeparatorApi=Li,r.SliderApi=Fo,r.TabApi=Vi,r.TabPageApi=Jn,r.TextApi=jo,r.TpChangeEvent=u,r.VERSION=gu,Object.defineProperty(r,"__esModule",{value:!0})})})(Al,xi);var Gn={},Vl={get exports(){return Gn},set exports(g){Gn=g}};(function(g,i){(function(r,s){s(i)})(Gr,function(r){class s{constructor(o){this.controller_=o}get element(){return this.controller_.view.element}get disabled(){return this.controller_.viewProps.get("disabled")}set disabled(o){this.controller_.viewProps.set("disabled",o)}get hidden(){return this.controller_.viewProps.get("hidden")}set hidden(o){this.controller_.viewProps.set("hidden",o)}dispose(){this.controller_.viewProps.set("disposed",!0)}}class a{constructor(o){this.target=o}}class c extends a{constructor(o,p,v,C){super(o),this.value=p,this.presetKey=v,this.last=C??!0}}function u(m){return m}function h(m){return m==null}const d={alreadydisposed:()=>"View has been already disposed",invalidparams:m=>`Invalid parameters for '${m.name}'`,nomatchingcontroller:m=>`No matching controller for '${m.key}'`,nomatchingview:m=>`No matching view for '${JSON.stringify(m.params)}'`,notbindable:()=>"Value is not bindable",propertynotfound:m=>`Property '${m.name}' not found`,shouldneverhappen:()=>"This error should never happen"};class _{constructor(o){var p;this.message=(p=d[o.type](o.context))!==null&&p!==void 0?p:"Unexpected error",this.name=this.constructor.name,this.stack=new Error(this.message).stack,this.type=o.type}static alreadyDisposed(){return new _({type:"alreadydisposed"})}static notBindable(){return new _({type:"notbindable"})}static propertyNotFound(o){return new _({type:"propertynotfound",context:{name:o}})}static shouldNeverHappen(){return new _({type:"shouldneverhappen"})}}class y{constructor(){this.observers_={}}on(o,p){let v=this.observers_[o];return v||(v=this.observers_[o]=[]),v.push({handler:p}),this}off(o,p){const v=this.observers_[o];return v&&(this.observers_[o]=v.filter(C=>C.handler!==p)),this}emit(o,p){const v=this.observers_[o];v&&v.forEach(C=>{C.handler(p)})}}const w="tp";function x(m){return(p,v)=>[w,"-",m,"v",p?`_${p}`:"",v?`-${v}`:""].join("")}function M(m,o){return p=>o(m(p))}function O(m){return m.rawValue}function I(m,o){m.emitter.on("change",M(O,o)),o(m.rawValue)}function E(m,o,p){I(m.value(o),p)}function R(m,o,p){p?m.classList.add(o):m.classList.remove(o)}function z(m,o){return p=>{R(m,o,p)}}function B(m,o){I(m,p=>{o.textContent=p??""})}const N=x("btn");class Q{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(N()),p.viewProps.bindClassModifiers(this.element);const v=o.createElement("button");v.classList.add(N("b")),p.viewProps.bindDisabled(v),this.element.appendChild(v),this.buttonElement=v;const C=o.createElement("div");C.classList.add(N("t")),B(p.props.value("title"),C),this.buttonElement.appendChild(C)}}class ${constructor(o,p){this.emitter=new y,this.onClick_=this.onClick_.bind(this),this.props=p.props,this.viewProps=p.viewProps,this.view=new Q(o,{props:this.props,viewProps:this.viewProps}),this.view.buttonElement.addEventListener("click",this.onClick_)}onClick_(){this.emitter.emit("click",{sender:this})}}class j{constructor(o,p){var v;this.constraint_=p==null?void 0:p.constraint,this.equals_=(v=p==null?void 0:p.equals)!==null&&v!==void 0?v:(C,k)=>C===k,this.emitter=new y,this.rawValue_=o}get constraint(){return this.constraint_}get rawValue(){return this.rawValue_}set rawValue(o){this.setRawValue(o,{forceEmit:!1,last:!0})}setRawValue(o,p){const v=p??{forceEmit:!1,last:!0},C=this.constraint_?this.constraint_.constrain(o):o,k=this.rawValue_;this.equals_(k,C)&&!v.forceEmit||(this.emitter.emit("beforechange",{sender:this}),this.rawValue_=C,this.emitter.emit("change",{options:v,previousRawValue:k,rawValue:C,sender:this}))}}class F{constructor(o){this.emitter=new y,this.value_=o}get rawValue(){return this.value_}set rawValue(o){this.setRawValue(o,{forceEmit:!1,last:!0})}setRawValue(o,p){const v=p??{forceEmit:!1,last:!0},C=this.value_;C===o&&!v.forceEmit||(this.emitter.emit("beforechange",{sender:this}),this.value_=o,this.emitter.emit("change",{options:v,previousRawValue:C,rawValue:this.value_,sender:this}))}}function X(m,o){const p=o==null?void 0:o.constraint,v=o==null?void 0:o.equals;return!p&&!v?new F(m):new j(m,o)}class Y{constructor(o){this.emitter=new y,this.valMap_=o;for(const p in this.valMap_)this.valMap_[p].emitter.on("change",()=>{this.emitter.emit("change",{key:p,sender:this})})}static createCore(o){return Object.keys(o).reduce((v,C)=>Object.assign(v,{[C]:X(o[C])}),{})}static fromObject(o){const p=this.createCore(o);return new Y(p)}get(o){return this.valMap_[o].rawValue}set(o,p){this.valMap_[o].rawValue=p}value(o){return this.valMap_[o]}}function Z(m,o){const v=Object.keys(o).reduce((C,k)=>{if(C===void 0)return;const T=o[k],G=T(m[k]);return G.succeeded?Object.assign(Object.assign({},C),{[k]:G.value}):void 0},{});return v}function ue(m,o){return m.reduce((p,v)=>{if(p===void 0)return;const C=o(v);if(!(!C.succeeded||C.value===void 0))return[...p,C.value]},[])}function ge(m){return m===null?!1:typeof m=="object"}function pe(m){return o=>p=>{if(!o&&p===void 0)return{succeeded:!1,value:void 0};if(o&&p===void 0)return{succeeded:!0,value:void 0};const v=m(p);return v!==void 0?{succeeded:!0,value:v}:{succeeded:!1,value:void 0}}}function me(m){return{custom:o=>pe(o)(m),boolean:pe(o=>typeof o=="boolean"?o:void 0)(m),number:pe(o=>typeof o=="number"?o:void 0)(m),string:pe(o=>typeof o=="string"?o:void 0)(m),function:pe(o=>typeof o=="function"?o:void 0)(m),constant:o=>pe(p=>p===o?o:void 0)(m),raw:pe(o=>o)(m),object:o=>pe(p=>{if(ge(p))return Z(p,o)})(m),array:o=>pe(p=>{if(Array.isArray(p))return ue(p,o)})(m)}}const he={optional:me(!0),required:me(!1)};function ee(m,o){const p=he.required.object(o)(m);return p.succeeded?p.value:void 0}function q(m){console.warn([`Missing '${m.key}' of ${m.target} in ${m.place}.`,"Please rebuild plugins with the latest core package."].join(" "))}function Ce(m){return m&&m.parentElement&&m.parentElement.removeChild(m),null}class fe{constructor(o){this.value_=o}static create(o){return[new fe(o),(p,v)=>{o.setRawValue(p,v)}]}get emitter(){return this.value_.emitter}get rawValue(){return this.value_.rawValue}}const le=x("");function ne(m,o){return z(m,le(void 0,o))}class be extends Y{constructor(o){var p;super(o),this.onDisabledChange_=this.onDisabledChange_.bind(this),this.onParentChange_=this.onParentChange_.bind(this),this.onParentGlobalDisabledChange_=this.onParentGlobalDisabledChange_.bind(this),[this.globalDisabled_,this.setGlobalDisabled_]=fe.create(X(this.getGlobalDisabled_())),this.value("disabled").emitter.on("change",this.onDisabledChange_),this.value("parent").emitter.on("change",this.onParentChange_),(p=this.get("parent"))===null||p===void 0||p.globalDisabled.emitter.on("change",this.onParentGlobalDisabledChange_)}static create(o){var p,v,C;const k=o??{};return new be(Y.createCore({disabled:(p=k.disabled)!==null&&p!==void 0?p:!1,disposed:!1,hidden:(v=k.hidden)!==null&&v!==void 0?v:!1,parent:(C=k.parent)!==null&&C!==void 0?C:null}))}get globalDisabled(){return this.globalDisabled_}bindClassModifiers(o){I(this.globalDisabled_,ne(o,"disabled")),E(this,"hidden",ne(o,"hidden"))}bindDisabled(o){I(this.globalDisabled_,p=>{o.disabled=p})}bindTabIndex(o){I(this.globalDisabled_,p=>{o.tabIndex=p?-1:0})}handleDispose(o){this.value("disposed").emitter.on("change",p=>{p&&o()})}getGlobalDisabled_(){const o=this.get("parent");return(o?o.globalDisabled.rawValue:!1)||this.get("disabled")}updateGlobalDisabled_(){this.setGlobalDisabled_(this.getGlobalDisabled_())}onDisabledChange_(){this.updateGlobalDisabled_()}onParentGlobalDisabledChange_(){this.updateGlobalDisabled_()}onParentChange_(o){var p;const v=o.previousRawValue;v==null||v.globalDisabled.emitter.off("change",this.onParentGlobalDisabledChange_),(p=this.get("parent"))===null||p===void 0||p.globalDisabled.emitter.on("change",this.onParentGlobalDisabledChange_),this.updateGlobalDisabled_()}}function V(){return["veryfirst","first","last","verylast"]}const ce=x(""),Ae={veryfirst:"vfst",first:"fst",last:"lst",verylast:"vlst"};class De{constructor(o){this.parent_=null,this.blade=o.blade,this.view=o.view,this.viewProps=o.viewProps;const p=this.view.element;this.blade.value("positions").emitter.on("change",()=>{V().forEach(v=>{p.classList.remove(ce(void 0,Ae[v]))}),this.blade.get("positions").forEach(v=>{p.classList.add(ce(void 0,Ae[v]))})}),this.viewProps.handleDispose(()=>{Ce(p)})}get parent(){return this.parent_}set parent(o){if(this.parent_=o,!("parent"in this.viewProps.valMap_)){q({key:"parent",target:be.name,place:"BladeController.parent"});return}this.viewProps.set("parent",this.parent_?this.parent_.viewProps:null)}}const we="http://www.w3.org/2000/svg";function qe(m){m.offsetHeight}function fn(m,o){const p=m.style.transition;m.style.transition="none",o(),m.style.transition=p}function ze(m){return m.ontouchstart!==void 0}function vn(m){for(;m.childNodes.length>0;)m.removeChild(m.childNodes[0])}function $t(m){return m.relatedTarget?m.relatedTarget:"explicitOriginalTarget"in m?m.explicitOriginalTarget:null}const nt=x("lbl");function dt(m,o){const p=m.createDocumentFragment();return o.split(`
22
- `).map(C=>m.createTextNode(C)).forEach((C,k)=>{k>0&&p.appendChild(m.createElement("br")),p.appendChild(C)}),p}class Ee{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(nt()),p.viewProps.bindClassModifiers(this.element);const v=o.createElement("div");v.classList.add(nt("l")),E(p.props,"label",k=>{h(k)?this.element.classList.add(nt(void 0,"nol")):(this.element.classList.remove(nt(void 0,"nol")),vn(v),v.appendChild(dt(o,k)))}),this.element.appendChild(v),this.labelElement=v;const C=o.createElement("div");C.classList.add(nt("v")),this.element.appendChild(C),this.valueElement=C}}class Qe extends De{constructor(o,p){const v=p.valueController.viewProps;super(Object.assign(Object.assign({},p),{view:new Ee(o,{props:p.props,viewProps:v}),viewProps:v})),this.props=p.props,this.valueController=p.valueController,this.view.valueElement.appendChild(this.valueController.view.element)}}class Xt extends De{constructor(o){super(o),this.value=o.value}}class it extends Y{constructor(o){super(o)}static create(o){const p={completed:!0,expanded:o,expandedHeight:null,shouldFixHeight:!1,temporaryExpanded:null},v=Y.createCore(p);return new it(v)}get styleExpanded(){var o;return(o=this.get("temporaryExpanded"))!==null&&o!==void 0?o:this.get("expanded")}get styleHeight(){if(!this.styleExpanded)return"0";const o=this.get("expandedHeight");return this.get("shouldFixHeight")&&!h(o)?`${o}px`:"auto"}bindExpandedClass(o,p){const v=()=>{this.styleExpanded?o.classList.add(p):o.classList.remove(p)};E(this,"expanded",v),E(this,"temporaryExpanded",v)}cleanUpTransition(){this.set("shouldFixHeight",!1),this.set("expandedHeight",null),this.set("completed",!0)}}function bn(m){return it.create(m)}function Kn(m,o){let p=0;return fn(o,()=>{m.set("expandedHeight",null),m.set("temporaryExpanded",!0),qe(o),p=o.clientHeight,m.set("temporaryExpanded",null),qe(o)}),p}function gn(m,o){o.style.height=m.styleHeight}function _n(m,o){m.value("expanded").emitter.on("beforechange",()=>{m.set("completed",!1),h(m.get("expandedHeight"))&&m.set("expandedHeight",Kn(m,o)),m.set("shouldFixHeight",!0),qe(o)}),m.emitter.on("change",()=>{gn(m,o)}),gn(m,o),o.addEventListener("transitionend",p=>{p.propertyName==="height"&&m.cleanUpTransition()})}class at{constructor(o,p){const v=x(p.viewName);this.element=o.createElement("div"),this.element.classList.add(v()),p.viewProps.bindClassModifiers(this.element)}}class mt extends Xt{constructor(o,p){const v=p.valueController.viewProps;super(Object.assign(Object.assign({},p),{value:p.valueController.value,view:new Ee(o,{props:p.props,viewProps:v}),viewProps:v})),this.props=p.props,this.valueController=p.valueController,this.view.valueElement.appendChild(this.valueController.view.element)}}class wn{constructor(){this.disabled=!1,this.emitter=new y}dispose(){}tick(){this.disabled||this.emitter.emit("tick",{sender:this})}}class Yt{constructor(o,p){this.disabled_=!1,this.timerId_=null,this.onTick_=this.onTick_.bind(this),this.doc_=o,this.emitter=new y,this.interval_=p,this.setTimer_()}get disabled(){return this.disabled_}set disabled(o){this.disabled_=o,this.disabled_?this.clearTimer_():this.setTimer_()}dispose(){this.clearTimer_()}clearTimer_(){if(this.timerId_===null)return;const o=this.doc_.defaultView;o&&o.clearInterval(this.timerId_),this.timerId_=null}setTimer_(){if(this.clearTimer_(),this.interval_<=0)return;const o=this.doc_.defaultView;o&&(this.timerId_=o.setInterval(this.onTick_,this.interval_))}onTick_(){this.disabled_||this.emitter.emit("tick",{sender:this})}}class yn{constructor(o){this.constraints=o}constrain(o){return this.constraints.reduce((p,v)=>v.constrain(p),o)}}function lt(m,o){if(m instanceof o)return m;if(m instanceof yn){const p=m.constraints.reduce((v,C)=>v||(C instanceof o?C:null),null);if(p)return p}return null}class st{constructor(o){this.values=Y.fromObject({max:o.max,min:o.min})}constrain(o){const p=this.values.get("max"),v=this.values.get("min");return Math.min(Math.max(o,v),p)}}class ft{constructor(o){this.values=Y.fromObject({max:o.max,min:o.min})}get maxValue(){return this.values.get("max")}get minValue(){return this.values.get("min")}constrain(o){const p=this.values.get("max"),v=this.values.get("min");let C=o;return h(v)||(C=Math.max(C,v)),h(p)||(C=Math.min(C,p)),C}}class D{constructor(o,p=0){this.step=o,this.origin=p}constrain(o){const p=this.origin%this.step,v=Math.round((o-p)/this.step);return p+v*this.step}}const K=x("pop");class J{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(K()),p.viewProps.bindClassModifiers(this.element),I(p.shows,z(this.element,K(void 0,"v")))}}class ie{constructor(o,p){this.shows=X(!1),this.viewProps=p.viewProps,this.view=new J(o,{shows:this.shows,viewProps:this.viewProps})}}const ye=x("txt");class Ve{constructor(o,p){this.onChange_=this.onChange_.bind(this),this.element=o.createElement("div"),this.element.classList.add(ye()),p.viewProps.bindClassModifiers(this.element),this.props_=p.props,this.props_.emitter.on("change",this.onChange_);const v=o.createElement("input");v.classList.add(ye("i")),v.type="text",p.viewProps.bindDisabled(v),this.element.appendChild(v),this.inputElement=v,p.value.emitter.on("change",this.onChange_),this.value_=p.value,this.refresh()}refresh(){const o=this.props_.get("formatter");this.inputElement.value=o(this.value_.rawValue)}onChange_(){this.refresh()}}class St{constructor(o,p){this.onInputChange_=this.onInputChange_.bind(this),this.parser_=p.parser,this.props=p.props,this.value=p.value,this.viewProps=p.viewProps,this.view=new Ve(o,{props:p.props,value:this.value,viewProps:this.viewProps}),this.view.inputElement.addEventListener("change",this.onInputChange_)}onInputChange_(o){const v=o.currentTarget.value,C=this.parser_(v);h(C)||(this.value.rawValue=C),this.view.refresh()}}function qt(m){return m==="false"?!1:!!m}class Oe{constructor(o){this.text=o}evaluate(){return Number(this.text)}toString(){return this.text}}const Be={"**":(m,o)=>Math.pow(m,o),"*":(m,o)=>m*o,"/":(m,o)=>m/o,"%":(m,o)=>m%o,"+":(m,o)=>m+o,"-":(m,o)=>m-o,"<<":(m,o)=>m<<o,">>":(m,o)=>m>>o,">>>":(m,o)=>m>>>o,"&":(m,o)=>m&o,"^":(m,o)=>m^o,"|":(m,o)=>m|o};class fs{constructor(o,p,v){this.left=p,this.operator=o,this.right=v}evaluate(){const o=Be[this.operator];if(!o)throw new Error(`unexpected binary operator: '${this.operator}`);return o(this.left.evaluate(),this.right.evaluate())}toString(){return["b(",this.left.toString(),this.operator,this.right.toString(),")"].join(" ")}}const vs={"+":m=>m,"-":m=>-m,"~":m=>~m};class bs{constructor(o,p){this.operator=o,this.expression=p}evaluate(){const o=vs[this.operator];if(!o)throw new Error(`unexpected unary operator: '${this.operator}`);return o(this.expression.evaluate())}toString(){return["u(",this.operator,this.expression.toString(),")"].join(" ")}}function $n(m){return(o,p)=>{for(let v=0;v<m.length;v++){const C=m[v](o,p);if(C!=="")return C}return""}}function vt(m,o){var p;const v=m.substr(o).match(/^\s+/);return(p=v&&v[0])!==null&&p!==void 0?p:""}function Xn(m,o){const p=m.substr(o,1);return p.match(/^[1-9]$/)?p:""}function Te(m,o){var p;const v=m.substr(o).match(/^[0-9]+/);return(p=v&&v[0])!==null&&p!==void 0?p:""}function Yn(m,o){const p=Te(m,o);if(p!=="")return p;const v=m.substr(o,1);if(o+=1,v!=="-"&&v!=="+")return"";const C=Te(m,o);return C===""?"":v+C}function Ze(m,o){const p=m.substr(o,1);if(o+=1,p.toLowerCase()!=="e")return"";const v=Yn(m,o);return v===""?"":p+v}function Mi(m,o){const p=m.substr(o,1);if(p==="0")return p;const v=Xn(m,o);return o+=v.length,v===""?"":v+Te(m,o)}function Qt(m,o){const p=Mi(m,o);if(o+=p.length,p==="")return"";const v=m.substr(o,1);if(o+=v.length,v!==".")return"";const C=Te(m,o);return o+=C.length,p+v+C+Ze(m,o)}function ki(m,o){const p=m.substr(o,1);if(o+=p.length,p!==".")return"";const v=Te(m,o);return o+=v.length,v===""?"":p+v+Ze(m,o)}function xn(m,o){const p=Mi(m,o);return o+=p.length,p===""?"":p+Ze(m,o)}const qn=$n([Qt,ki,xn]);function Qn(m,o){var p;const v=m.substr(o).match(/^[01]+/);return(p=v&&v[0])!==null&&p!==void 0?p:""}function gs(m,o){const p=m.substr(o,2);if(o+=p.length,p.toLowerCase()!=="0b")return"";const v=Qn(m,o);return v===""?"":p+v}function _s(m,o){var p;const v=m.substr(o).match(/^[0-7]+/);return(p=v&&v[0])!==null&&p!==void 0?p:""}function ws(m,o){const p=m.substr(o,2);if(o+=p.length,p.toLowerCase()!=="0o")return"";const v=_s(m,o);return v===""?"":p+v}function ys(m,o){var p;const v=m.substr(o).match(/^[0-9a-f]+/i);return(p=v&&v[0])!==null&&p!==void 0?p:""}function Zn(m,o){const p=m.substr(o,2);if(o+=p.length,p.toLowerCase()!=="0x")return"";const v=ys(m,o);return v===""?"":p+v}const xs=$n([gs,ws,Zn]),Cs=$n([xs,qn]);function Zt(m,o){const p=Cs(m,o);return o+=p.length,p===""?null:{evaluable:new Oe(p),cursor:o}}function Si(m,o){const p=m.substr(o,1);if(o+=p.length,p!=="(")return null;const v=Wn(m,o);if(!v)return null;o=v.cursor,o+=vt(m,o).length;const C=m.substr(o,1);return o+=C.length,C!==")"?null:{evaluable:v.evaluable,cursor:o}}function Ps(m,o){var p;return(p=Zt(m,o))!==null&&p!==void 0?p:Si(m,o)}function Cn(m,o){const p=Ps(m,o);if(p)return p;const v=m.substr(o,1);if(o+=v.length,v!=="+"&&v!=="-"&&v!=="~")return null;const C=Cn(m,o);return C?(o=C.cursor,{cursor:o,evaluable:new bs(v,C.evaluable)}):null}function Ms(m,o,p){p+=vt(o,p).length;const v=m.filter(C=>o.startsWith(C,p))[0];return v?(p+=v.length,p+=vt(o,p).length,{cursor:p,operator:v}):null}function Lt(m,o){return(p,v)=>{const C=m(p,v);if(!C)return null;v=C.cursor;let k=C.evaluable;for(;;){const T=Ms(o,p,v);if(!T)break;v=T.cursor;const G=m(p,v);if(!G)return null;v=G.cursor,k=new fs(T.operator,k,G.evaluable)}return k?{cursor:v,evaluable:k}:null}}const Li=[["**"],["*","/","%"],["+","-"],["<<",">>>",">>"],["&"],["^"],["|"]].reduce((m,o)=>Lt(m,o),Cn);function Wn(m,o){return o+=vt(m,o).length,Li(m,o)}function ks(m){const o=Wn(m,0);return!o||o.cursor+vt(m,o.cursor).length!==m.length?null:o.evaluable}function Wt(m){var o;const p=ks(m);return(o=p==null?void 0:p.evaluate())!==null&&o!==void 0?o:null}function Ss(m){if(typeof m=="number")return m;if(typeof m=="string"){const o=Wt(m);if(!h(o))return o}return 0}function Se(m){return o=>o.toFixed(Math.max(Math.min(m,20),0))}const Ls=Se(0);function Pn(m){return Ls(m)+"%"}function Ai(m){return String(m)}function Jn(m,o){for(;m.length<o;)m.push(void 0)}function Vi(m){const o=[];return Jn(o,m),X(o)}function Ii(m){const o=m.indexOf(void 0);return o<0?m:m.slice(0,o)}function As(m,o){const p=[...Ii(m),o];return p.length>m.length?p.splice(0,p.length-m.length):Jn(p,m.length),p}function At({primary:m,secondary:o,forward:p,backward:v}){let C=!1;function k(T){C||(C=!0,T(),C=!1)}m.emitter.on("change",T=>{k(()=>{o.setRawValue(p(m,o),T.options)})}),o.emitter.on("change",T=>{k(()=>{m.setRawValue(v(m,o),T.options)}),k(()=>{o.setRawValue(p(m,o),T.options)})}),k(()=>{o.setRawValue(p(m,o),{forceEmit:!1,last:!0})})}function Vt(m,o){const p=m*(o.altKey?.1:1)*(o.shiftKey?10:1);return o.upKey?+p:o.downKey?-p:0}function Jt(m){return{altKey:m.altKey,downKey:m.key==="ArrowDown",shiftKey:m.shiftKey,upKey:m.key==="ArrowUp"}}function Hn(m){return{altKey:m.altKey,downKey:m.key==="ArrowLeft",shiftKey:m.shiftKey,upKey:m.key==="ArrowRight"}}function Vs(m){return m==="ArrowUp"||m==="ArrowDown"}function Di(m){return Vs(m)||m==="ArrowLeft"||m==="ArrowRight"}function ei(m,o){var p,v;const C=o.ownerDocument.defaultView,k=o.getBoundingClientRect();return{x:m.pageX-(((p=C&&C.scrollX)!==null&&p!==void 0?p:0)+k.left),y:m.pageY-(((v=C&&C.scrollY)!==null&&v!==void 0?v:0)+k.top)}}class Mn{constructor(o){this.lastTouch_=null,this.onDocumentMouseMove_=this.onDocumentMouseMove_.bind(this),this.onDocumentMouseUp_=this.onDocumentMouseUp_.bind(this),this.onMouseDown_=this.onMouseDown_.bind(this),this.onTouchEnd_=this.onTouchEnd_.bind(this),this.onTouchMove_=this.onTouchMove_.bind(this),this.onTouchStart_=this.onTouchStart_.bind(this),this.elem_=o,this.emitter=new y,o.addEventListener("touchstart",this.onTouchStart_,{passive:!1}),o.addEventListener("touchmove",this.onTouchMove_,{passive:!0}),o.addEventListener("touchend",this.onTouchEnd_),o.addEventListener("mousedown",this.onMouseDown_)}computePosition_(o){const p=this.elem_.getBoundingClientRect();return{bounds:{width:p.width,height:p.height},point:o?{x:o.x,y:o.y}:null}}onMouseDown_(o){var p;o.preventDefault(),(p=o.currentTarget)===null||p===void 0||p.focus();const v=this.elem_.ownerDocument;v.addEventListener("mousemove",this.onDocumentMouseMove_),v.addEventListener("mouseup",this.onDocumentMouseUp_),this.emitter.emit("down",{altKey:o.altKey,data:this.computePosition_(ei(o,this.elem_)),sender:this,shiftKey:o.shiftKey})}onDocumentMouseMove_(o){this.emitter.emit("move",{altKey:o.altKey,data:this.computePosition_(ei(o,this.elem_)),sender:this,shiftKey:o.shiftKey})}onDocumentMouseUp_(o){const p=this.elem_.ownerDocument;p.removeEventListener("mousemove",this.onDocumentMouseMove_),p.removeEventListener("mouseup",this.onDocumentMouseUp_),this.emitter.emit("up",{altKey:o.altKey,data:this.computePosition_(ei(o,this.elem_)),sender:this,shiftKey:o.shiftKey})}onTouchStart_(o){o.preventDefault();const p=o.targetTouches.item(0),v=this.elem_.getBoundingClientRect();this.emitter.emit("down",{altKey:o.altKey,data:this.computePosition_(p?{x:p.clientX-v.left,y:p.clientY-v.top}:void 0),sender:this,shiftKey:o.shiftKey}),this.lastTouch_=p}onTouchMove_(o){const p=o.targetTouches.item(0),v=this.elem_.getBoundingClientRect();this.emitter.emit("move",{altKey:o.altKey,data:this.computePosition_(p?{x:p.clientX-v.left,y:p.clientY-v.top}:void 0),sender:this,shiftKey:o.shiftKey}),this.lastTouch_=p}onTouchEnd_(o){var p;const v=(p=o.targetTouches.item(0))!==null&&p!==void 0?p:this.lastTouch_,C=this.elem_.getBoundingClientRect();this.emitter.emit("up",{altKey:o.altKey,data:this.computePosition_(v?{x:v.clientX-C.left,y:v.clientY-C.top}:void 0),sender:this,shiftKey:o.shiftKey})}}function Pe(m,o,p,v,C){const k=(m-o)/(p-o);return v+k*(C-v)}function Ti(m){return String(m.toFixed(10)).split(".")[1].replace(/0+$/,"").length}function It(m,o,p){return Math.min(Math.max(m,o),p)}const Ue=x("txt");class Is{constructor(o,p){this.onChange_=this.onChange_.bind(this),this.props_=p.props,this.props_.emitter.on("change",this.onChange_),this.element=o.createElement("div"),this.element.classList.add(Ue(),Ue(void 0,"num")),p.arrayPosition&&this.element.classList.add(Ue(void 0,p.arrayPosition)),p.viewProps.bindClassModifiers(this.element);const v=o.createElement("input");v.classList.add(Ue("i")),v.type="text",p.viewProps.bindDisabled(v),this.element.appendChild(v),this.inputElement=v,this.onDraggingChange_=this.onDraggingChange_.bind(this),this.dragging_=p.dragging,this.dragging_.emitter.on("change",this.onDraggingChange_),this.element.classList.add(Ue()),this.inputElement.classList.add(Ue("i"));const C=o.createElement("div");C.classList.add(Ue("k")),this.element.appendChild(C),this.knobElement=C;const k=o.createElementNS(we,"svg");k.classList.add(Ue("g")),this.knobElement.appendChild(k);const T=o.createElementNS(we,"path");T.classList.add(Ue("gb")),k.appendChild(T),this.guideBodyElem_=T;const G=o.createElementNS(we,"path");G.classList.add(Ue("gh")),k.appendChild(G),this.guideHeadElem_=G;const oe=o.createElement("div");oe.classList.add(x("tt")()),this.knobElement.appendChild(oe),this.tooltipElem_=oe,p.value.emitter.on("change",this.onChange_),this.value=p.value,this.refresh()}onDraggingChange_(o){if(o.rawValue===null){this.element.classList.remove(Ue(void 0,"drg"));return}this.element.classList.add(Ue(void 0,"drg"));const p=o.rawValue/this.props_.get("draggingScale"),v=p+(p>0?-1:p<0?1:0),C=It(-v,-4,4);this.guideHeadElem_.setAttributeNS(null,"d",[`M ${v+C},0 L${v},4 L${v+C},8`,`M ${p},-1 L${p},9`].join(" ")),this.guideBodyElem_.setAttributeNS(null,"d",`M 0,4 L${p},4`);const k=this.props_.get("formatter");this.tooltipElem_.textContent=k(this.value.rawValue),this.tooltipElem_.style.left=`${p}px`}refresh(){const o=this.props_.get("formatter");this.inputElement.value=o(this.value.rawValue)}onChange_(){this.refresh()}}class Ht{constructor(o,p){var v;this.originRawValue_=0,this.onInputChange_=this.onInputChange_.bind(this),this.onInputKeyDown_=this.onInputKeyDown_.bind(this),this.onInputKeyUp_=this.onInputKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.baseStep_=p.baseStep,this.parser_=p.parser,this.props=p.props,this.sliderProps_=(v=p.sliderProps)!==null&&v!==void 0?v:null,this.value=p.value,this.viewProps=p.viewProps,this.dragging_=X(null),this.view=new Is(o,{arrayPosition:p.arrayPosition,dragging:this.dragging_,props:this.props,value:this.value,viewProps:this.viewProps}),this.view.inputElement.addEventListener("change",this.onInputChange_),this.view.inputElement.addEventListener("keydown",this.onInputKeyDown_),this.view.inputElement.addEventListener("keyup",this.onInputKeyUp_);const C=new Mn(this.view.knobElement);C.emitter.on("down",this.onPointerDown_),C.emitter.on("move",this.onPointerMove_),C.emitter.on("up",this.onPointerUp_)}constrainValue_(o){var p,v;const C=(p=this.sliderProps_)===null||p===void 0?void 0:p.get("minValue"),k=(v=this.sliderProps_)===null||v===void 0?void 0:v.get("maxValue");let T=o;return C!==void 0&&(T=Math.max(T,C)),k!==void 0&&(T=Math.min(T,k)),T}onInputChange_(o){const v=o.currentTarget.value,C=this.parser_(v);h(C)||(this.value.rawValue=this.constrainValue_(C)),this.view.refresh()}onInputKeyDown_(o){const p=Vt(this.baseStep_,Jt(o));p!==0&&this.value.setRawValue(this.constrainValue_(this.value.rawValue+p),{forceEmit:!1,last:!1})}onInputKeyUp_(o){Vt(this.baseStep_,Jt(o))!==0&&this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}onPointerDown_(){this.originRawValue_=this.value.rawValue,this.dragging_.rawValue=0}computeDraggingValue_(o){if(!o.point)return null;const p=o.point.x-o.bounds.width/2;return this.constrainValue_(this.originRawValue_+p*this.props.get("draggingScale"))}onPointerMove_(o){const p=this.computeDraggingValue_(o.data);p!==null&&(this.value.setRawValue(p,{forceEmit:!1,last:!1}),this.dragging_.rawValue=this.value.rawValue-this.originRawValue_)}onPointerUp_(o){const p=this.computeDraggingValue_(o.data);p!==null&&(this.value.setRawValue(p,{forceEmit:!0,last:!0}),this.dragging_.rawValue=null)}}function $e(m,o){m.write(o)}function Dt(m){const o=m?lt(m,D):null;return o?o.step:null}function en(m,o){const p=m&&lt(m,D);return p?Ti(p.step):Math.max(Ti(o),2)}function ti(m){const o=Dt(m);return o??1}function kn(m,o){var p;const v=m&&lt(m,D),C=Math.abs((p=v==null?void 0:v.step)!==null&&p!==void 0?p:o);return C===0?.1:Math.pow(10,Math.floor(Math.log10(C))-1)}function Tt(m){return[m[0],m[1],m[2]]}function Ei(m){const o=It(Math.floor(m),0,255).toString(16);return o.length===1?`0${o}`:o}function tn(m,o="#"){const p=Tt(m.getComponents("rgb")).map(Ei).join("");return`${o}${p}`}function Oi(m,o="#"){const p=m.getComponents("rgb"),v=[p[0],p[1],p[2],p[3]*255].map(Ei).join("");return`${o}${v}`}function Ds(m,o){const p=Se(o==="float"?2:0);return`rgb(${Tt(m.getComponents("rgb",o)).map(C=>p(C)).join(", ")})`}function Bi(m){return o=>Ds(o,m)}function Ni(m,o){const p=Se(2),v=Se(o==="float"?2:0);return`rgba(${m.getComponents("rgb",o).map((k,T)=>(T===3?p:v)(k)).join(", ")})`}function Ts(m){return o=>Ni(o,m)}function Sn(m){const o=[Se(0),Pn,Pn];return`hsl(${Tt(m.getComponents("hsl")).map((v,C)=>o[C](v)).join(", ")})`}function Es(m){const o=[Se(0),Pn,Pn,Se(2)];return`hsla(${m.getComponents("hsl").map((v,C)=>o[C](v)).join(", ")})`}function Fi(m,o){const p=Se(o==="float"?2:0),v=["r","g","b"];return`{${Tt(m.getComponents("rgb",o)).map((k,T)=>`${v[T]}: ${p(k)}`).join(", ")}}`}function ji(m){return o=>Fi(o,m)}function Os(m,o){const p=Se(2),v=Se(o==="float"?2:0),C=["r","g","b","a"];return`{${m.getComponents("rgb",o).map((T,G)=>{const oe=G===3?p:v;return`${C[G]}: ${oe(T)}`}).join(", ")}}`}function Bs(m){return o=>Os(o,m)}[...["int","float"].reduce((m,o)=>[...m,{format:{alpha:!1,mode:"rgb",notation:"func",type:o},stringifier:Bi(o)},{format:{alpha:!0,mode:"rgb",notation:"func",type:o},stringifier:Ts(o)},{format:{alpha:!1,mode:"rgb",notation:"object",type:o},stringifier:ji(o)},{format:{alpha:!0,mode:"rgb",notation:"object",type:o},stringifier:Bs(o)}],[])];class Ns{constructor(o){this.components=o.components,this.asm_=o.assembly}constrain(o){const p=this.asm_.toComponents(o).map((v,C)=>{var k,T;return(T=(k=this.components[C])===null||k===void 0?void 0:k.constrain(v))!==null&&T!==void 0?T:v});return this.asm_.fromComponents(p)}}const zi=x("pndtxt");class Fs{constructor(o,p){this.textViews=p.textViews,this.element=o.createElement("div"),this.element.classList.add(zi()),this.textViews.forEach(v=>{const C=o.createElement("div");C.classList.add(zi("a")),C.appendChild(v.element),this.element.appendChild(C)})}}function ni(m,o,p){return new Ht(m,{arrayPosition:p===0?"fst":p===o.axes.length-1?"lst":"mid",baseStep:o.axes[p].baseStep,parser:o.parser,props:o.axes[p].textProps,value:X(0,{constraint:o.axes[p].constraint}),viewProps:o.viewProps})}class bt{constructor(o,p){this.value=p.value,this.viewProps=p.viewProps,this.acs_=p.axes.map((v,C)=>ni(o,p,C)),this.acs_.forEach((v,C)=>{At({primary:this.value,secondary:v.value,forward:k=>p.assembly.toComponents(k.rawValue)[C],backward:(k,T)=>{const G=p.assembly.toComponents(k.rawValue);return G[C]=T.rawValue,p.assembly.fromComponents(G)}})}),this.view=new Fs(o,{textViews:this.acs_.map(v=>v.view)})}}function js(m,o){return"step"in m&&!h(m.step)?new D(m.step,o):null}function nn(m){return!h(m.max)&&!h(m.min)?new st({max:m.max,min:m.min}):!h(m.max)||!h(m.min)?new ft({max:m.max,min:m.min}):null}const zs={monitor:{defaultInterval:200,defaultLineCount:3}},We=x("grl");class Ui{constructor(o,p){this.onCursorChange_=this.onCursorChange_.bind(this),this.onValueUpdate_=this.onValueUpdate_.bind(this),this.element=o.createElement("div"),this.element.classList.add(We()),p.viewProps.bindClassModifiers(this.element),this.formatter_=p.formatter,this.props_=p.props,this.cursor_=p.cursor,this.cursor_.emitter.on("change",this.onCursorChange_);const v=o.createElementNS(we,"svg");v.classList.add(We("g")),v.style.height=`calc(var(--bld-us) * ${p.lineCount})`,this.element.appendChild(v),this.svgElem_=v;const C=o.createElementNS(we,"polyline");this.svgElem_.appendChild(C),this.lineElem_=C;const k=o.createElement("div");k.classList.add(We("t"),x("tt")()),this.element.appendChild(k),this.tooltipElem_=k,p.value.emitter.on("change",this.onValueUpdate_),this.value=p.value,this.update_()}get graphElement(){return this.svgElem_}update_(){const o=this.svgElem_.getBoundingClientRect(),p=this.value.rawValue.length-1,v=this.props_.get("minValue"),C=this.props_.get("maxValue"),k=[];this.value.rawValue.forEach((Ke,te)=>{if(Ke===void 0)return;const ut=Pe(te,0,p,0,o.width),er=Pe(Ke,v,C,o.height,0);k.push([ut,er].join(","))}),this.lineElem_.setAttributeNS(null,"points",k.join(" "));const T=this.tooltipElem_,G=this.value.rawValue[this.cursor_.rawValue];if(G===void 0){T.classList.remove(We("t","a"));return}const oe=Pe(this.cursor_.rawValue,0,p,0,o.width),Ge=Pe(G,v,C,o.height,0);T.style.left=`${oe}px`,T.style.top=`${Ge}px`,T.textContent=`${this.formatter_(G)}`,T.classList.contains(We("t","a"))||(T.classList.add(We("t","a"),We("t","in")),qe(T),T.classList.remove(We("t","in")))}onValueUpdate_(){this.update_()}onCursorChange_(){this.update_()}}class Us{constructor(o,p){if(this.onGraphMouseMove_=this.onGraphMouseMove_.bind(this),this.onGraphMouseLeave_=this.onGraphMouseLeave_.bind(this),this.onGraphPointerDown_=this.onGraphPointerDown_.bind(this),this.onGraphPointerMove_=this.onGraphPointerMove_.bind(this),this.onGraphPointerUp_=this.onGraphPointerUp_.bind(this),this.props_=p.props,this.value=p.value,this.viewProps=p.viewProps,this.cursor_=X(-1),this.view=new Ui(o,{cursor:this.cursor_,formatter:p.formatter,lineCount:p.lineCount,props:this.props_,value:this.value,viewProps:this.viewProps}),!ze(o))this.view.element.addEventListener("mousemove",this.onGraphMouseMove_),this.view.element.addEventListener("mouseleave",this.onGraphMouseLeave_);else{const v=new Mn(this.view.element);v.emitter.on("down",this.onGraphPointerDown_),v.emitter.on("move",this.onGraphPointerMove_),v.emitter.on("up",this.onGraphPointerUp_)}}onGraphMouseLeave_(){this.cursor_.rawValue=-1}onGraphMouseMove_(o){const p=this.view.element.getBoundingClientRect();this.cursor_.rawValue=Math.floor(Pe(o.offsetX,0,p.width,0,this.value.rawValue.length))}onGraphPointerDown_(o){this.onGraphPointerMove_(o)}onGraphPointerMove_(o){if(!o.data.point){this.cursor_.rawValue=-1;return}this.cursor_.rawValue=Math.floor(Pe(o.data.point.x,0,o.data.bounds.width,0,this.value.rawValue.length))}onGraphPointerUp_(){this.cursor_.rawValue=-1}}class Ri{constructor(o){this.controller_=o}get disabled(){return this.controller_.viewProps.get("disabled")}set disabled(o){this.controller_.viewProps.set("disabled",o)}get title(){var o;return(o=this.controller_.props.get("title"))!==null&&o!==void 0?o:""}set title(o){this.controller_.props.set("title",o)}on(o,p){const v=p.bind(this);return this.controller_.emitter.on(o,()=>{v(new a(this))}),this}}class Rs extends a{constructor(o,p,v){super(o),this.cell=p,this.index=v}}class Gi extends s{constructor(o){super(o),this.cellToApiMap_=new Map,this.emitter_=new y;const p=this.controller_.valueController;p.cellControllers.forEach((v,C)=>{const k=new Ri(v);this.cellToApiMap_.set(v,k),v.emitter.on("click",()=>{const T=C%p.size[0],G=Math.floor(C/p.size[0]);this.emitter_.emit("click",{event:new Rs(this,k,[T,G])})})})}cell(o,p){const v=this.controller_.valueController,C=v.cellControllers[p*v.size[0]+o];return this.cellToApiMap_.get(C)}on(o,p){const v=p.bind(this);return this.emitter_.on(o,C=>{v(C.event)}),this}}class ii{constructor(o,p){this.size=p.size;const[v,C]=this.size,k=[];for(let T=0;T<C;T++)for(let G=0;G<v;G++){const oe=new $(o,{props:Y.fromObject(Object.assign({},p.cellConfig(G,T))),viewProps:be.create()});k.push(oe)}this.cellCs_=k,this.viewProps=be.create(),this.viewProps.handleDispose(()=>{this.cellCs_.forEach(T=>{T.viewProps.set("disposed",!0)})}),this.view=new at(o,{viewProps:this.viewProps,viewName:"btngrid"}),this.view.element.style.gridTemplateColumns=`repeat(${v}, 1fr)`,this.cellCs_.forEach(T=>{this.view.element.appendChild(T.view.element)})}get cellControllers(){return this.cellCs_}}const Gs={id:"buttongrid",type:"blade",css:'.tp-cbzgv,.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:rgba(0,0,0,0);border-width:0;font-family:inherit;font-size:inherit;font-weight:inherit;margin:0;outline:none;padding:0}.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{background-color:var(--btn-bg);border-radius:var(--elm-br);color:var(--btn-fg);cursor:pointer;display:block;font-weight:bold;height:var(--bld-us);line-height:var(--bld-us);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-radv_b:hover,.tp-rslv_k:hover,.tp-cbzv_b:hover{background-color:var(--btn-bg-h)}.tp-radv_b:focus,.tp-rslv_k:focus,.tp-cbzv_b:focus{background-color:var(--btn-bg-f)}.tp-radv_b:active,.tp-rslv_k:active,.tp-cbzv_b:active{background-color:var(--btn-bg-a)}.tp-radv_b:disabled,.tp-rslv_k:disabled,.tp-cbzv_b:disabled{opacity:.5}.tp-cbzgv{background-color:var(--in-bg);border-radius:var(--elm-br);box-sizing:border-box;color:var(--in-fg);font-family:inherit;height:var(--bld-us);line-height:var(--bld-us);min-width:0;width:100%}.tp-cbzgv:hover{background-color:var(--in-bg-h)}.tp-cbzgv:focus{background-color:var(--in-bg-f)}.tp-cbzgv:active{background-color:var(--in-bg-a)}.tp-cbzgv:disabled{opacity:.5}.tp-btngridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-btngridv.tp-v-disabled{opacity:.5}.tp-btngridv .tp-btnv_b:disabled{opacity:1}.tp-btngridv .tp-btnv_b:disabled .tp-btnv_t{opacity:.5}.tp-btngridv .tp-btnv_b{border-radius:0}.tp-cbzv{position:relative}.tp-cbzv_h{display:flex}.tp-cbzv_b{margin-right:4px;position:relative;width:var(--bld-us)}.tp-cbzv_b svg{display:block;height:16px;left:50%;margin-left:-8px;margin-top:-8px;position:absolute;top:50%;width:16px}.tp-cbzv_b svg path{stroke:var(--bs-bg);stroke-width:2}.tp-cbzv_t{flex:1}.tp-cbzv_p{height:0;margin-top:0;opacity:0;overflow:hidden;transition:height .2s ease-in-out,opacity .2s linear,margin .2s ease-in-out}.tp-cbzv.tp-cbzv-expanded .tp-cbzv_p{margin-top:var(--bld-s);opacity:1}.tp-cbzv.tp-cbzv-cpl .tp-cbzv_p{overflow:visible}.tp-cbzv .tp-popv{left:calc(-1*var(--cnt-h-p));position:absolute;right:calc(-1*var(--cnt-h-p));top:var(--bld-us)}.tp-cbzpv_t{margin-top:var(--bld-s)}.tp-cbzgv{height:auto;overflow:hidden;position:relative}.tp-cbzgv.tp-v-disabled{opacity:.5}.tp-cbzgv_p{left:16px;position:absolute;right:16px;top:0}.tp-cbzgv_g{cursor:pointer;display:block;height:calc(var(--bld-us)*5);width:100%}.tp-cbzgv_u{opacity:.1;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_l{fill:rgba(0,0,0,0);stroke:var(--in-fg)}.tp-cbzgv_v{opacity:.5;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_h{border:var(--in-fg) solid 1px;border-radius:50%;box-sizing:border-box;height:4px;margin-left:-2px;margin-top:-2px;pointer-events:none;position:absolute;width:4px}.tp-cbzgv:focus .tp-cbzgv_h-sel{background-color:var(--in-fg);border-width:0}.tp-cbzprvv{cursor:pointer;height:4px;padding:4px 0;position:relative}.tp-cbzprvv_g{display:block;height:100%;overflow:visible;width:100%}.tp-cbzprvv_t{opacity:.5;stroke:var(--mo-fg)}.tp-cbzprvv_m{background-color:var(--mo-fg);border-radius:50%;height:4px;margin-left:-2px;margin-top:-2px;opacity:0;position:absolute;top:50%;transition:opacity .2s ease-out;width:4px}.tp-cbzprvv_m.tp-cbzprvv_m-a{opacity:1}.tp-fpsv{position:relative}.tp-fpsv_l{bottom:4px;color:var(--mo-fg);line-height:1;right:4px;pointer-events:none;position:absolute}.tp-fpsv_u{margin-left:.2em;opacity:.7}.tp-rslv{cursor:pointer;padding-left:8px;padding-right:8px}.tp-rslv.tp-v-disabled{opacity:.5}.tp-rslv_t{height:calc(var(--bld-us));position:relative}.tp-rslv_t::before{background-color:var(--in-bg);border-radius:1px;content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:-4px;right:-4px}.tp-rslv_b{bottom:0;top:0;position:absolute}.tp-rslv_b::before{background-color:var(--in-fg);content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:0;right:0}.tp-rslv_k{height:calc(var(--bld-us) - 8px);margin-top:calc((var(--bld-us) - 8px)/-2);position:absolute;top:50%;width:8px}.tp-rslv_k.tp-rslv_k-min{margin-left:-8px}.tp-rslv_k.tp-rslv_k-max{margin-left:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-min{border-bottom-right-radius:0;border-top-right-radius:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-max{border-bottom-left-radius:0;border-top-left-radius:0}.tp-rsltxtv{display:flex}.tp-rsltxtv_s{flex:1}.tp-rsltxtv_t{flex:1;margin-left:4px}.tp-radv_l{display:block;position:relative}.tp-radv_i{left:0;opacity:0;position:absolute;top:0}.tp-radv_b{opacity:.5}.tp-radv_i:hover+.tp-radv_b{background-color:var(--btn-bg-h)}.tp-radv_i:focus+.tp-radv_b{background-color:var(--btn-bg-f)}.tp-radv_i:active+.tp-radv_b{background-color:var(--btn-bg-a)}.tp-radv_i:checked+.tp-radv_b{opacity:1}.tp-radv_t{bottom:0;color:inherit;left:0;overflow:hidden;position:absolute;right:0;text-align:center;text-overflow:ellipsis;top:0}.tp-radv_i:disabled+.tp-radv_b>.tp-radv_t{opacity:.5}.tp-radgridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-radgridv.tp-v-disabled{opacity:.5}.tp-radgridv .tp-radv_b{border-radius:0}',accept(m){const o=he,p=ee(m,{cells:o.required.function,size:o.required.array(o.required.number),view:o.required.constant("buttongrid"),label:o.optional.string});return p?{params:p}:null},controller(m){return new Qe(m.document,{blade:m.blade,props:Y.fromObject({label:m.params.label}),valueController:new ii(m.document,{cellConfig:m.params.cells,size:m.params.size})})},api(m){return!(m.controller instanceof Qe)||!(m.controller.valueController instanceof ii)?null:new Gi(m.controller)}};class Ki extends s{get label(){return this.controller_.props.get("label")}set label(o){this.controller_.props.set("label",o)}get value(){return this.controller_.valueController.value.rawValue}set value(o){this.controller_.valueController.value.rawValue=o}on(o,p){const v=p.bind(this);return this.controller_.valueController.value.emitter.on(o,C=>{v(new c(this,C.rawValue,void 0,C.options.last))}),this}}function Re(m,o,p){return m*(1-p)+o*p}const Ks=20,$s=.001,si=100;function Xs(m,o){let p=.25,v=.5,C=-1;for(let k=0;k<Ks;k++){const[T,G]=m.curve(v);if(v+=p*(T<o?1:-1),C=G,p*=.5,Math.abs(o-T)<$s)break}return C}class ct{constructor(o=0,p=0,v=1,C=1){this.cache_=[],this.comps_=[o,p,v,C]}get x1(){return this.comps_[0]}get y1(){return this.comps_[1]}get x2(){return this.comps_[2]}get y2(){return this.comps_[3]}static isObject(o){return h(o)||!Array.isArray(o)?!1:typeof o[0]=="number"&&typeof o[1]=="number"&&typeof o[2]=="number"&&typeof o[3]=="number"}static equals(o,p){return o.x1===p.x1&&o.y1===p.y1&&o.x2===p.x2&&o.y2===p.y2}curve(o){const p=Re(0,this.x1,o),v=Re(0,this.y1,o),C=Re(this.x1,this.x2,o),k=Re(this.y1,this.y2,o),T=Re(this.x2,1,o),G=Re(this.y2,1,o),oe=Re(p,C,o),Ge=Re(v,k,o),Ke=Re(C,T,o),te=Re(k,G,o);return[Re(oe,Ke,o),Re(Ge,te,o)]}y(o){if(this.cache_.length===0){const p=[];for(let v=0;v<si;v++)p.push(Xs(this,Pe(v,0,si-1,0,1)));this.cache_=p}return this.cache_[Math.round(Pe(It(o,0,1),0,1,0,si-1))]}toObject(){return[this.comps_[0],this.comps_[1],this.comps_[2],this.comps_[3]]}}const ri={toComponents:m=>m.toObject(),fromComponents:m=>new ct(...m)};function Ys(m){const o=Se(2);return`cubic-bezier(${m.toObject().map(v=>o(v)).join(", ")})`}const oi=[0,.5,.5,1];function qs(m){const o=m.match(/^cubic-bezier\s*\(\s*([0-9.]+)\s*,\s*([0-9.]+)\s*,\s*([0-9.]+)\s*,\s*([0-9.]+)\s*\)$/);if(!o)return new ct(...oi);const p=[o[1],o[2],o[3],o[4]].reduce((v,C)=>{if(!v)return null;const k=Number(C);return isNaN(k)?null:[...v,k]},[]);return new ct(...p??oi)}const gt=x("cbz");class $i{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(gt()),p.viewProps.bindClassModifiers(this.element),p.foldable.bindExpandedClass(this.element,gt(void 0,"expanded")),E(p.foldable,"completed",z(this.element,gt(void 0,"cpl")));const v=o.createElement("div");v.classList.add(gt("h")),this.element.appendChild(v);const C=o.createElement("button");C.classList.add(gt("b")),p.viewProps.bindDisabled(C);const k=o.createElementNS(we,"svg");k.innerHTML='<path d="M2 13C8 13 8 3 14 3"/>',C.appendChild(k),v.appendChild(C),this.buttonElement=C;const T=o.createElement("div");if(T.classList.add(gt("t")),v.appendChild(T),this.textElement=T,p.pickerLayout==="inline"){const G=o.createElement("div");G.classList.add(gt("p")),this.element.appendChild(G),this.pickerElement=G}else this.pickerElement=null}}const Ln=x("cbzp");class Xi{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(Ln()),p.viewProps.bindClassModifiers(this.element);const v=o.createElement("div");v.classList.add(Ln("g")),this.element.appendChild(v),this.graphElement=v;const C=o.createElement("div");C.classList.add(Ln("t")),this.element.appendChild(C),this.textElement=C}}function Je(m,o){const p=new MutationObserver(C=>{for(const k of C)k.type==="childList"&&k.addedNodes.forEach(T=>{T.contains(T)&&(o(),p.disconnect())})}),v=m.ownerDocument;p.observe(v.body,{attributes:!0,childList:!0,subtree:!0})}const rt=x("cbzg");function Qs(m,o){return p=>o(m(p))}class Le{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(rt()),p.viewProps.bindClassModifiers(this.element),p.viewProps.bindTabIndex(this.element);const v=o.createElement("div");v.classList.add(rt("p")),this.element.appendChild(v),this.previewElement=v;const C=o.createElementNS(we,"svg");C.classList.add(rt("g")),this.element.appendChild(C),this.svgElem_=C;const k=o.createElementNS(we,"path");k.classList.add(rt("u")),this.svgElem_.appendChild(k),this.guideElem_=k;const T=o.createElementNS(we,"polyline");T.classList.add(rt("l")),this.svgElem_.appendChild(T),this.lineElem_=T,this.handleElems_=[o.createElement("div"),o.createElement("div")],this.handleElems_.forEach(G=>{G.classList.add(rt("h")),this.element.appendChild(G)}),this.vectorElems_=[o.createElementNS(we,"line"),o.createElementNS(we,"line")],this.vectorElems_.forEach(G=>{G.classList.add(rt("v")),this.svgElem_.appendChild(G)}),this.value_=p.value,this.value_.emitter.on("change",this.onValueChange_.bind(this)),this.sel_=p.selection,this.handleElems_.forEach((G,oe)=>{I(this.sel_,Qs(Ge=>Ge===oe,z(G,rt("h","sel"))))}),Je(this.element,()=>{this.refresh()})}getVertMargin_(o){return o*.25}valueToPosition(o,p){const v=this.element.getBoundingClientRect(),C=v.width,k=v.height,T=this.getVertMargin_(k);return{x:Pe(o,0,1,0,C),y:Pe(p,0,1,k-T,T)}}positionToValue(o,p){const v=this.element.getBoundingClientRect(),C=v.width,k=v.height,T=this.getVertMargin_(k);return{x:It(Pe(o,0,C,0,1),0,1),y:Pe(p,k-T,T,0,1)}}refresh(){this.guideElem_.setAttributeNS(null,"d",[0,1].map(k=>{const T=this.valueToPosition(0,k),G=this.valueToPosition(1,k);return[`M ${T.x},${T.y}`,`L ${G.x},${G.y}`].join(" ")}).join(" "));const o=this.value_.rawValue,p=[];let v=0;for(;;){const k=this.valueToPosition(...o.curve(v));if(p.push([k.x,k.y].join(",")),v>=1)break;v=Math.min(v+.05,1)}this.lineElem_.setAttributeNS(null,"points",p.join(" "));const C=o.toObject();[0,1].forEach(k=>{const T=this.valueToPosition(k,k),G=this.valueToPosition(C[k*2],C[k*2+1]),oe=this.vectorElems_[k];oe.setAttributeNS(null,"x1",String(T.x)),oe.setAttributeNS(null,"y1",String(T.y)),oe.setAttributeNS(null,"x2",String(G.x)),oe.setAttributeNS(null,"y2",String(G.y));const Ge=this.handleElems_[k];Ge.style.left=`${G.x}px`,Ge.style.top=`${G.y}px`})}onValueChange_(){this.refresh()}}const Yi=24,sn=400,ai=1e3,pt=x("cbzprv");class Et{constructor(o,p){this.stopped_=!0,this.startTime_=-1,this.onDispose_=this.onDispose_.bind(this),this.onTimer_=this.onTimer_.bind(this),this.onValueChange_=this.onValueChange_.bind(this),this.element=o.createElement("div"),this.element.classList.add(pt()),p.viewProps.bindClassModifiers(this.element);const v=o.createElementNS(we,"svg");v.classList.add(pt("g")),this.element.appendChild(v),this.svgElem_=v;const C=o.createElementNS(we,"path");C.classList.add(pt("t")),this.svgElem_.appendChild(C),this.ticksElem_=C;const k=o.createElement("div");k.classList.add(pt("m")),this.element.appendChild(k),this.markerElem_=k,this.value_=p.value,this.value_.emitter.on("change",this.onValueChange_),p.viewProps.handleDispose(this.onDispose_),Je(this.element,()=>{this.refresh()})}play(){this.stop(),this.updateMarker_(0),this.markerElem_.classList.add(pt("m","a")),this.startTime_=new Date().getTime()+sn,this.stopped_=!1,requestAnimationFrame(this.onTimer_)}stop(){this.stopped_=!0,this.markerElem_.classList.remove(pt("m","a"))}onDispose_(){this.stop()}updateMarker_(o){const p=this.value_.rawValue.y(It(o,0,1));this.markerElem_.style.left=`${p*100}%`}refresh(){const o=this.svgElem_.getBoundingClientRect(),p=o.width,v=o.height,C=[],k=this.value_.rawValue;for(let T=0;T<Yi;T++){const G=Pe(T,0,Yi-1,0,1),oe=Pe(k.y(G),0,1,0,p);C.push(`M ${oe},0 v${v}`)}this.ticksElem_.setAttributeNS(null,"d",C.join(" "))}onTimer_(){if(this.startTime_===null)return;const o=new Date().getTime()-this.startTime_,p=o/ai;this.updateMarker_(p),o>ai+sn&&this.stop(),this.stopped_||requestAnimationFrame(this.onTimer_)}onValueChange_(){this.refresh(),this.play()}}function Ie(m,o,p,v){const C=p-m,k=v-o;return Math.sqrt(C*C+k*k)}function rn(m,o,p,v){const C=Ie(m,o,p,v),k=Math.atan2(v-o,p-m),T=Math.round(k/(Math.PI/4))*Math.PI/4;return{x:m+Math.cos(T)*C,y:o+Math.sin(T)*C}}class He{constructor(o,p){this.onKeyDown_=this.onKeyDown_.bind(this),this.onKeyUp_=this.onKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.baseStep_=p.baseStep,this.value=p.value,this.sel_=X(0),this.viewProps=p.viewProps,this.view=new Le(o,{selection:this.sel_,value:this.value,viewProps:this.viewProps}),this.view.element.addEventListener("keydown",this.onKeyDown_),this.view.element.addEventListener("keyup",this.onKeyUp_),this.prevView_=new Et(o,{value:this.value,viewProps:this.viewProps}),this.prevView_.element.addEventListener("mousedown",C=>{C.stopImmediatePropagation(),C.preventDefault(),this.prevView_.play()}),this.view.previewElement.appendChild(this.prevView_.element);const v=new Mn(this.view.element);v.emitter.on("down",this.onPointerDown_),v.emitter.on("move",this.onPointerMove_),v.emitter.on("up",this.onPointerUp_)}refresh(){this.view.refresh(),this.prevView_.refresh(),this.prevView_.play()}updateValue_(o,p,v){const C=this.sel_.rawValue,k=this.value.rawValue.toObject(),T=this.view.positionToValue(o.x,o.y),G=p?rn(C,C,T.x,T.y):T;k[C*2]=G.x,k[C*2+1]=G.y,this.value.setRawValue(new ct(...k),v)}onPointerDown_(o){const p=o.data;if(!p.point)return;const v=this.value.rawValue,C=this.view.valueToPosition(v.x1,v.y1),k=Ie(p.point.x,p.point.y,C.x,C.y),T=this.view.valueToPosition(v.x2,v.y2),G=Ie(p.point.x,p.point.y,T.x,T.y);this.sel_.rawValue=k<=G?0:1,this.updateValue_(p.point,o.shiftKey,{forceEmit:!1,last:!1})}onPointerMove_(o){const p=o.data;p.point&&this.updateValue_(p.point,o.shiftKey,{forceEmit:!1,last:!1})}onPointerUp_(o){const p=o.data;p.point&&this.updateValue_(p.point,o.shiftKey,{forceEmit:!0,last:!0})}onKeyDown_(o){Di(o.key)&&o.preventDefault();const p=this.sel_.rawValue,v=this.value.rawValue.toObject();v[p*2]+=Vt(this.baseStep_,Hn(o)),v[p*2+1]+=Vt(this.baseStep_,Jt(o)),this.value.setRawValue(new ct(...v),{forceEmit:!1,last:!1})}onKeyUp_(o){Di(o.key)&&o.preventDefault();const p=Vt(this.baseStep_,Hn(o)),v=Vt(this.baseStep_,Jt(o));p===0&&v===0||this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}class qi{constructor(o,p){this.value=p.value,this.viewProps=p.viewProps,this.view=new Xi(o,{viewProps:this.viewProps}),this.gc_=new He(o,{baseStep:p.axis.baseStep,value:this.value,viewProps:this.viewProps}),this.view.graphElement.appendChild(this.gc_.view.element);const v=Object.assign(Object.assign({},p.axis),{constraint:new ft({max:1,min:0})}),C=Object.assign(Object.assign({},p.axis),{constraint:void 0});this.tc_=new bt(o,{assembly:ri,axes:[v,C,v,C],parser:Wt,value:this.value,viewProps:this.viewProps}),this.view.textElement.appendChild(this.tc_.view.element)}get allFocusableElements(){return[this.gc_.view.element,...this.tc_.view.textViews.map(o=>o.inputElement)]}refresh(){this.gc_.refresh()}}class An{constructor(o,p){this.onButtonBlur_=this.onButtonBlur_.bind(this),this.onButtonClick_=this.onButtonClick_.bind(this),this.onPopupChildBlur_=this.onPopupChildBlur_.bind(this),this.onPopupChildKeydown_=this.onPopupChildKeydown_.bind(this),this.value=p.value,this.viewProps=p.viewProps,this.foldable_=bn(p.expanded),this.view=new $i(o,{foldable:this.foldable_,pickerLayout:p.pickerLayout,viewProps:this.viewProps}),this.view.buttonElement.addEventListener("blur",this.onButtonBlur_),this.view.buttonElement.addEventListener("click",this.onButtonClick_),this.tc_=new St(o,{parser:qs,props:Y.fromObject({formatter:Ys}),value:this.value,viewProps:this.viewProps}),this.view.textElement.appendChild(this.tc_.view.element),this.popC_=p.pickerLayout==="popup"?new ie(o,{viewProps:this.viewProps}):null;const v=new qi(o,{axis:p.axis,value:this.value,viewProps:this.viewProps});v.allFocusableElements.forEach(C=>{C.addEventListener("blur",this.onPopupChildBlur_),C.addEventListener("keydown",this.onPopupChildKeydown_)}),this.pickerC_=v,this.popC_?(this.view.element.appendChild(this.popC_.view.element),this.popC_.view.element.appendChild(this.pickerC_.view.element),I(this.popC_.shows,C=>{C&&v.refresh()}),At({primary:this.foldable_.value("expanded"),secondary:this.popC_.shows,forward:C=>C.rawValue,backward:(C,k)=>k.rawValue})):this.view.pickerElement&&(this.view.pickerElement.appendChild(this.pickerC_.view.element),_n(this.foldable_,this.view.pickerElement))}onButtonBlur_(o){if(!this.popC_)return;const p=o.relatedTarget;(!p||!this.popC_.view.element.contains(p))&&(this.popC_.shows.rawValue=!1)}onButtonClick_(){this.foldable_.set("expanded",!this.foldable_.get("expanded")),this.foldable_.get("expanded")&&this.pickerC_.allFocusableElements[0].focus()}onPopupChildBlur_(o){if(!this.popC_)return;const p=this.popC_.view.element,v=$t(o);v&&p.contains(v)||v&&v===this.view.buttonElement&&!ze(p.ownerDocument)||(this.popC_.shows.rawValue=!1)}onPopupChildKeydown_(o){this.popC_&&o.key==="Escape"&&(this.popC_.shows.rawValue=!1)}}function li(){return new Ns({assembly:ri,components:[0,1,2,3].map(m=>m%2===0?new ft({min:0,max:1}):void 0)})}const _t={id:"cubic-bezier",type:"blade",css:'.tp-cbzgv,.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:rgba(0,0,0,0);border-width:0;font-family:inherit;font-size:inherit;font-weight:inherit;margin:0;outline:none;padding:0}.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{background-color:var(--btn-bg);border-radius:var(--elm-br);color:var(--btn-fg);cursor:pointer;display:block;font-weight:bold;height:var(--bld-us);line-height:var(--bld-us);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-radv_b:hover,.tp-rslv_k:hover,.tp-cbzv_b:hover{background-color:var(--btn-bg-h)}.tp-radv_b:focus,.tp-rslv_k:focus,.tp-cbzv_b:focus{background-color:var(--btn-bg-f)}.tp-radv_b:active,.tp-rslv_k:active,.tp-cbzv_b:active{background-color:var(--btn-bg-a)}.tp-radv_b:disabled,.tp-rslv_k:disabled,.tp-cbzv_b:disabled{opacity:.5}.tp-cbzgv{background-color:var(--in-bg);border-radius:var(--elm-br);box-sizing:border-box;color:var(--in-fg);font-family:inherit;height:var(--bld-us);line-height:var(--bld-us);min-width:0;width:100%}.tp-cbzgv:hover{background-color:var(--in-bg-h)}.tp-cbzgv:focus{background-color:var(--in-bg-f)}.tp-cbzgv:active{background-color:var(--in-bg-a)}.tp-cbzgv:disabled{opacity:.5}.tp-btngridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-btngridv.tp-v-disabled{opacity:.5}.tp-btngridv .tp-btnv_b:disabled{opacity:1}.tp-btngridv .tp-btnv_b:disabled .tp-btnv_t{opacity:.5}.tp-btngridv .tp-btnv_b{border-radius:0}.tp-cbzv{position:relative}.tp-cbzv_h{display:flex}.tp-cbzv_b{margin-right:4px;position:relative;width:var(--bld-us)}.tp-cbzv_b svg{display:block;height:16px;left:50%;margin-left:-8px;margin-top:-8px;position:absolute;top:50%;width:16px}.tp-cbzv_b svg path{stroke:var(--bs-bg);stroke-width:2}.tp-cbzv_t{flex:1}.tp-cbzv_p{height:0;margin-top:0;opacity:0;overflow:hidden;transition:height .2s ease-in-out,opacity .2s linear,margin .2s ease-in-out}.tp-cbzv.tp-cbzv-expanded .tp-cbzv_p{margin-top:var(--bld-s);opacity:1}.tp-cbzv.tp-cbzv-cpl .tp-cbzv_p{overflow:visible}.tp-cbzv .tp-popv{left:calc(-1*var(--cnt-h-p));position:absolute;right:calc(-1*var(--cnt-h-p));top:var(--bld-us)}.tp-cbzpv_t{margin-top:var(--bld-s)}.tp-cbzgv{height:auto;overflow:hidden;position:relative}.tp-cbzgv.tp-v-disabled{opacity:.5}.tp-cbzgv_p{left:16px;position:absolute;right:16px;top:0}.tp-cbzgv_g{cursor:pointer;display:block;height:calc(var(--bld-us)*5);width:100%}.tp-cbzgv_u{opacity:.1;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_l{fill:rgba(0,0,0,0);stroke:var(--in-fg)}.tp-cbzgv_v{opacity:.5;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_h{border:var(--in-fg) solid 1px;border-radius:50%;box-sizing:border-box;height:4px;margin-left:-2px;margin-top:-2px;pointer-events:none;position:absolute;width:4px}.tp-cbzgv:focus .tp-cbzgv_h-sel{background-color:var(--in-fg);border-width:0}.tp-cbzprvv{cursor:pointer;height:4px;padding:4px 0;position:relative}.tp-cbzprvv_g{display:block;height:100%;overflow:visible;width:100%}.tp-cbzprvv_t{opacity:.5;stroke:var(--mo-fg)}.tp-cbzprvv_m{background-color:var(--mo-fg);border-radius:50%;height:4px;margin-left:-2px;margin-top:-2px;opacity:0;position:absolute;top:50%;transition:opacity .2s ease-out;width:4px}.tp-cbzprvv_m.tp-cbzprvv_m-a{opacity:1}.tp-fpsv{position:relative}.tp-fpsv_l{bottom:4px;color:var(--mo-fg);line-height:1;right:4px;pointer-events:none;position:absolute}.tp-fpsv_u{margin-left:.2em;opacity:.7}.tp-rslv{cursor:pointer;padding-left:8px;padding-right:8px}.tp-rslv.tp-v-disabled{opacity:.5}.tp-rslv_t{height:calc(var(--bld-us));position:relative}.tp-rslv_t::before{background-color:var(--in-bg);border-radius:1px;content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:-4px;right:-4px}.tp-rslv_b{bottom:0;top:0;position:absolute}.tp-rslv_b::before{background-color:var(--in-fg);content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:0;right:0}.tp-rslv_k{height:calc(var(--bld-us) - 8px);margin-top:calc((var(--bld-us) - 8px)/-2);position:absolute;top:50%;width:8px}.tp-rslv_k.tp-rslv_k-min{margin-left:-8px}.tp-rslv_k.tp-rslv_k-max{margin-left:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-min{border-bottom-right-radius:0;border-top-right-radius:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-max{border-bottom-left-radius:0;border-top-left-radius:0}.tp-rsltxtv{display:flex}.tp-rsltxtv_s{flex:1}.tp-rsltxtv_t{flex:1;margin-left:4px}.tp-radv_l{display:block;position:relative}.tp-radv_i{left:0;opacity:0;position:absolute;top:0}.tp-radv_b{opacity:.5}.tp-radv_i:hover+.tp-radv_b{background-color:var(--btn-bg-h)}.tp-radv_i:focus+.tp-radv_b{background-color:var(--btn-bg-f)}.tp-radv_i:active+.tp-radv_b{background-color:var(--btn-bg-a)}.tp-radv_i:checked+.tp-radv_b{opacity:1}.tp-radv_t{bottom:0;color:inherit;left:0;overflow:hidden;position:absolute;right:0;text-align:center;text-overflow:ellipsis;top:0}.tp-radv_i:disabled+.tp-radv_b>.tp-radv_t{opacity:.5}.tp-radgridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-radgridv.tp-v-disabled{opacity:.5}.tp-radgridv .tp-radv_b{border-radius:0}',accept(m){const o=he,p=ee(m,{value:o.required.array(o.required.number),view:o.required.constant("cubicbezier"),expanded:o.optional.boolean,label:o.optional.string,picker:o.optional.custom(v=>v==="inline"||v==="popup"?v:void 0)});return p?{params:p}:null},controller(m){var o,p;const v=new ct(...m.params.value),C=X(v,{constraint:li(),equals:ct.equals}),k=new An(m.document,{axis:{baseStep:.1,textProps:Y.fromObject({draggingScale:.01,formatter:Se(2)})},expanded:(o=m.params.expanded)!==null&&o!==void 0?o:!1,pickerLayout:(p=m.params.picker)!==null&&p!==void 0?p:"popup",value:C,viewProps:m.viewProps});return new mt(m.document,{blade:m.blade,props:Y.fromObject({label:m.params.label}),valueController:k})},api(m){return!(m.controller instanceof mt)||!(m.controller.valueController instanceof An)?null:new Ki(m.controller)}};class _e extends s{begin(){this.controller_.valueController.begin()}end(){this.controller_.valueController.end()}}const ci=20;class Me{constructor(){this.start_=null,this.duration_=0,this.fps_=null,this.frameCount_=0,this.timestamps_=[]}get duration(){return this.duration_}get fps(){return this.fps_}begin(o){this.start_=o.getTime()}calculateFps_(o){if(this.timestamps_.length===0)return null;const p=this.timestamps_[0];return 1e3*(this.frameCount_-p.frameCount)/(o-p.time)}compactTimestamps_(){if(this.timestamps_.length<=ci)return;const o=this.timestamps_.length-ci;this.timestamps_.splice(0,o);const p=this.timestamps_[0].frameCount;this.timestamps_.forEach(v=>{v.frameCount-=p}),this.frameCount_-=p}end(o){if(this.start_===null)return;const p=o.getTime();this.duration_=p-this.start_,this.start_=null,this.fps_=this.calculateFps_(p),this.timestamps_.push({frameCount:this.frameCount_,time:p}),++this.frameCount_,this.compactTimestamps_()}}const Ot=x("fps");class Ne{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(Ot()),p.viewProps.bindClassModifiers(this.element),this.graphElement=o.createElement("div"),this.graphElement.classList.add(Ot("g")),this.element.appendChild(this.graphElement);const v=o.createElement("div");v.classList.add(Ot("l")),this.element.appendChild(v);const C=o.createElement("span");C.classList.add(Ot("v")),C.textContent="--",v.appendChild(C),this.valueElement=C;const k=o.createElement("span");k.classList.add(Ot("u")),k.textContent="FPS",v.appendChild(k)}}class pi{constructor(o,p){this.stopwatch_=new Me,this.onTick_=this.onTick_.bind(this),this.ticker_=p.ticker,this.ticker_.emitter.on("tick",this.onTick_),this.value_=p.value,this.viewProps=p.viewProps,this.view=new Ne(o,{viewProps:this.viewProps}),this.graphC_=new Us(o,{formatter:Se(0),lineCount:p.lineCount,props:Y.fromObject({maxValue:p.maxValue,minValue:p.minValue}),value:this.value_,viewProps:this.viewProps}),this.view.graphElement.appendChild(this.graphC_.view.element),this.viewProps.handleDispose(()=>{this.graphC_.viewProps.set("disposed",!0),this.ticker_.dispose()})}begin(){this.stopwatch_.begin(new Date)}end(){this.stopwatch_.end(new Date)}onTick_(){const o=this.stopwatch_.fps;if(o!==null){const p=this.value_.rawValue;this.value_.rawValue=As(p,o),this.view.valueElement.textContent=o.toFixed(0)}}}function on(m,o){return o===0?new wn:new Yt(m,o??zs.monitor.defaultInterval)}const ui={id:"fpsgraph",type:"blade",accept(m){const o=he,p=ee(m,{view:o.required.constant("fpsgraph"),interval:o.optional.number,label:o.optional.string,lineCount:o.optional.number,max:o.optional.number,min:o.optional.number});return p?{params:p}:null},controller(m){var o,p,v,C;const k=(o=m.params.interval)!==null&&o!==void 0?o:500;return new Qe(m.document,{blade:m.blade,props:Y.fromObject({label:m.params.label}),valueController:new pi(m.document,{lineCount:(p=m.params.lineCount)!==null&&p!==void 0?p:2,maxValue:(v=m.params.max)!==null&&v!==void 0?v:90,minValue:(C=m.params.min)!==null&&C!==void 0?C:0,ticker:on(m.document,k),value:Vi(80),viewProps:m.viewProps})})},api(m){return!(m.controller instanceof Qe)||!(m.controller.valueController instanceof pi)?null:new _e(m.controller)}};class Fe{constructor(o,p){this.min=o,this.max=p}static isObject(o){if(typeof o!="object"||o===null)return!1;const p=o.min,v=o.max;return!(typeof p!="number"||typeof v!="number")}static equals(o,p){return o.min===p.min&&o.max===p.max}get length(){return this.max-this.min}toObject(){return{min:this.min,max:this.max}}}const hi={fromComponents:m=>new Fe(m[0],m[1]),toComponents:m=>[m.min,m.max]};class an{constructor(o){this.edge=o}constrain(o){var p,v,C,k,T,G,oe,Ge;if(o.min<=o.max)return new Fe((v=(p=this.edge)===null||p===void 0?void 0:p.constrain(o.min))!==null&&v!==void 0?v:o.min,(k=(C=this.edge)===null||C===void 0?void 0:C.constrain(o.max))!==null&&k!==void 0?k:o.max);const Ke=(o.min+o.max)/2;return new Fe((G=(T=this.edge)===null||T===void 0?void 0:T.constrain(Ke))!==null&&G!==void 0?G:Ke,(Ge=(oe=this.edge)===null||oe===void 0?void 0:oe.constrain(Ke))!==null&&Ge!==void 0?Ge:Ke)}}const di=x("rsltxt");class Vn{constructor(o,p){this.sliderView_=p.sliderView,this.textView_=p.textView,this.element=o.createElement("div"),this.element.classList.add(di());const v=o.createElement("div");v.classList.add(di("s")),v.appendChild(this.sliderView_.element),this.element.appendChild(v);const C=o.createElement("div");C.classList.add(di("t")),C.appendChild(this.textView_.element),this.element.appendChild(C)}}const Xe=x("rsl");class ln{constructor(o,p){this.onSliderPropsChange_=this.onSliderPropsChange_.bind(this),this.onValueChange_=this.onValueChange_.bind(this),this.sliderProps_=p.sliderProps,this.sliderProps_.emitter.on("change",this.onSliderPropsChange_),this.element=o.createElement("div"),this.element.classList.add(Xe()),p.viewProps.bindClassModifiers(this.element),this.value_=p.value,this.value_.emitter.on("change",this.onValueChange_);const v=o.createElement("div");v.classList.add(Xe("t")),this.element.appendChild(v),this.trackElement=v;const C=o.createElement("div");C.classList.add(Xe("b")),v.appendChild(C),this.barElement=C;const k=["min","max"].map(T=>{const G=o.createElement("div");return G.classList.add(Xe("k"),Xe("k",T)),v.appendChild(G),G});this.knobElements=[k[0],k[1]],this.update_()}valueToX_(o){const p=this.sliderProps_.get("minValue"),v=this.sliderProps_.get("maxValue");return It(Pe(o,p,v,0,1),0,1)*100}update_(){const o=this.value_.rawValue;o.length===0?this.element.classList.add(Xe(void 0,"zero")):this.element.classList.remove(Xe(void 0,"zero"));const p=[this.valueToX_(o.min),this.valueToX_(o.max)];this.barElement.style.left=`${p[0]}%`,this.barElement.style.right=`${100-p[1]}%`,this.knobElements.forEach((v,C)=>{v.style.left=`${p[C]}%`})}onSliderPropsChange_(){this.update_()}onValueChange_(){this.update_()}}class mi{constructor(o,p){this.grabbing_=null,this.grabOffset_=0,this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.sliderProps=p.sliderProps,this.viewProps=p.viewProps,this.value=p.value,this.view=new ln(o,{sliderProps:this.sliderProps,value:this.value,viewProps:p.viewProps});const v=new Mn(this.view.trackElement);v.emitter.on("down",this.onPointerDown_),v.emitter.on("move",this.onPointerMove_),v.emitter.on("up",this.onPointerUp_)}ofs_(){return this.grabbing_==="min"?this.view.knobElements[0].getBoundingClientRect().width/2:this.grabbing_==="max"?-this.view.knobElements[1].getBoundingClientRect().width/2:0}valueFromData_(o){if(!o.point)return null;const p=(o.point.x+this.ofs_())/o.bounds.width,v=this.sliderProps.get("minValue"),C=this.sliderProps.get("maxValue");return Pe(p,0,1,v,C)}onPointerDown_(o){if(!o.data.point)return;const p=o.data.point.x/o.data.bounds.width,v=this.value.rawValue,C=this.sliderProps.get("minValue"),k=this.sliderProps.get("maxValue"),T=Pe(v.min,C,k,0,1),G=Pe(v.max,C,k,0,1);Math.abs(G-p)<=.025?this.grabbing_="max":Math.abs(T-p)<=.025?this.grabbing_="min":p>=T&&p<=G?(this.grabbing_="length",this.grabOffset_=Pe(p-T,0,1,0,k-C)):p<T?(this.grabbing_="min",this.onPointerMove_(o)):p>G&&(this.grabbing_="max",this.onPointerMove_(o))}applyPointToValue_(o,p){const v=this.valueFromData_(o);if(v===null)return;const C=this.sliderProps.get("minValue"),k=this.sliderProps.get("maxValue");if(this.grabbing_==="min")this.value.setRawValue(new Fe(v,this.value.rawValue.max),p);else if(this.grabbing_==="max")this.value.setRawValue(new Fe(this.value.rawValue.min,v),p);else if(this.grabbing_==="length"){const T=this.value.rawValue.length;let G=v-this.grabOffset_,oe=G+T;G<C?(G=C,oe=C+T):oe>k&&(G=k-T,oe=k),this.value.setRawValue(new Fe(G,oe),p)}}onPointerMove_(o){this.applyPointToValue_(o.data,{forceEmit:!1,last:!1})}onPointerUp_(o){this.applyPointToValue_(o.data,{forceEmit:!0,last:!0}),this.grabbing_=null}}class ot{constructor(o,p){this.value=p.value,this.viewProps=p.viewProps,this.sc_=new mi(o,p);const v={baseStep:p.baseStep,constraint:p.constraint,textProps:Y.fromObject({draggingScale:p.draggingScale,formatter:p.formatter})};this.tc_=new bt(o,{assembly:hi,axes:[v,v],parser:p.parser,value:this.value,viewProps:p.viewProps}),this.view=new Vn(o,{sliderView:this.sc_.view,textView:this.tc_.view})}get textController(){return this.tc_}}function Qi(m){return Fe.isObject(m)?new Fe(m.min,m.max):new Fe(0,0)}function fi(m,o){m.writeProperty("max",o.max),m.writeProperty("min",o.min)}function Zs(m){const o=[],p=nn(m);p&&o.push(p);const v=js(m);return v&&o.push(v),new an(new yn(o))}const In={id:"input-interval",type:"input",css:'.tp-cbzgv,.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:rgba(0,0,0,0);border-width:0;font-family:inherit;font-size:inherit;font-weight:inherit;margin:0;outline:none;padding:0}.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{background-color:var(--btn-bg);border-radius:var(--elm-br);color:var(--btn-fg);cursor:pointer;display:block;font-weight:bold;height:var(--bld-us);line-height:var(--bld-us);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-radv_b:hover,.tp-rslv_k:hover,.tp-cbzv_b:hover{background-color:var(--btn-bg-h)}.tp-radv_b:focus,.tp-rslv_k:focus,.tp-cbzv_b:focus{background-color:var(--btn-bg-f)}.tp-radv_b:active,.tp-rslv_k:active,.tp-cbzv_b:active{background-color:var(--btn-bg-a)}.tp-radv_b:disabled,.tp-rslv_k:disabled,.tp-cbzv_b:disabled{opacity:.5}.tp-cbzgv{background-color:var(--in-bg);border-radius:var(--elm-br);box-sizing:border-box;color:var(--in-fg);font-family:inherit;height:var(--bld-us);line-height:var(--bld-us);min-width:0;width:100%}.tp-cbzgv:hover{background-color:var(--in-bg-h)}.tp-cbzgv:focus{background-color:var(--in-bg-f)}.tp-cbzgv:active{background-color:var(--in-bg-a)}.tp-cbzgv:disabled{opacity:.5}.tp-btngridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-btngridv.tp-v-disabled{opacity:.5}.tp-btngridv .tp-btnv_b:disabled{opacity:1}.tp-btngridv .tp-btnv_b:disabled .tp-btnv_t{opacity:.5}.tp-btngridv .tp-btnv_b{border-radius:0}.tp-cbzv{position:relative}.tp-cbzv_h{display:flex}.tp-cbzv_b{margin-right:4px;position:relative;width:var(--bld-us)}.tp-cbzv_b svg{display:block;height:16px;left:50%;margin-left:-8px;margin-top:-8px;position:absolute;top:50%;width:16px}.tp-cbzv_b svg path{stroke:var(--bs-bg);stroke-width:2}.tp-cbzv_t{flex:1}.tp-cbzv_p{height:0;margin-top:0;opacity:0;overflow:hidden;transition:height .2s ease-in-out,opacity .2s linear,margin .2s ease-in-out}.tp-cbzv.tp-cbzv-expanded .tp-cbzv_p{margin-top:var(--bld-s);opacity:1}.tp-cbzv.tp-cbzv-cpl .tp-cbzv_p{overflow:visible}.tp-cbzv .tp-popv{left:calc(-1*var(--cnt-h-p));position:absolute;right:calc(-1*var(--cnt-h-p));top:var(--bld-us)}.tp-cbzpv_t{margin-top:var(--bld-s)}.tp-cbzgv{height:auto;overflow:hidden;position:relative}.tp-cbzgv.tp-v-disabled{opacity:.5}.tp-cbzgv_p{left:16px;position:absolute;right:16px;top:0}.tp-cbzgv_g{cursor:pointer;display:block;height:calc(var(--bld-us)*5);width:100%}.tp-cbzgv_u{opacity:.1;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_l{fill:rgba(0,0,0,0);stroke:var(--in-fg)}.tp-cbzgv_v{opacity:.5;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_h{border:var(--in-fg) solid 1px;border-radius:50%;box-sizing:border-box;height:4px;margin-left:-2px;margin-top:-2px;pointer-events:none;position:absolute;width:4px}.tp-cbzgv:focus .tp-cbzgv_h-sel{background-color:var(--in-fg);border-width:0}.tp-cbzprvv{cursor:pointer;height:4px;padding:4px 0;position:relative}.tp-cbzprvv_g{display:block;height:100%;overflow:visible;width:100%}.tp-cbzprvv_t{opacity:.5;stroke:var(--mo-fg)}.tp-cbzprvv_m{background-color:var(--mo-fg);border-radius:50%;height:4px;margin-left:-2px;margin-top:-2px;opacity:0;position:absolute;top:50%;transition:opacity .2s ease-out;width:4px}.tp-cbzprvv_m.tp-cbzprvv_m-a{opacity:1}.tp-fpsv{position:relative}.tp-fpsv_l{bottom:4px;color:var(--mo-fg);line-height:1;right:4px;pointer-events:none;position:absolute}.tp-fpsv_u{margin-left:.2em;opacity:.7}.tp-rslv{cursor:pointer;padding-left:8px;padding-right:8px}.tp-rslv.tp-v-disabled{opacity:.5}.tp-rslv_t{height:calc(var(--bld-us));position:relative}.tp-rslv_t::before{background-color:var(--in-bg);border-radius:1px;content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:-4px;right:-4px}.tp-rslv_b{bottom:0;top:0;position:absolute}.tp-rslv_b::before{background-color:var(--in-fg);content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:0;right:0}.tp-rslv_k{height:calc(var(--bld-us) - 8px);margin-top:calc((var(--bld-us) - 8px)/-2);position:absolute;top:50%;width:8px}.tp-rslv_k.tp-rslv_k-min{margin-left:-8px}.tp-rslv_k.tp-rslv_k-max{margin-left:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-min{border-bottom-right-radius:0;border-top-right-radius:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-max{border-bottom-left-radius:0;border-top-left-radius:0}.tp-rsltxtv{display:flex}.tp-rsltxtv_s{flex:1}.tp-rsltxtv_t{flex:1;margin-left:4px}.tp-radv_l{display:block;position:relative}.tp-radv_i{left:0;opacity:0;position:absolute;top:0}.tp-radv_b{opacity:.5}.tp-radv_i:hover+.tp-radv_b{background-color:var(--btn-bg-h)}.tp-radv_i:focus+.tp-radv_b{background-color:var(--btn-bg-f)}.tp-radv_i:active+.tp-radv_b{background-color:var(--btn-bg-a)}.tp-radv_i:checked+.tp-radv_b{opacity:1}.tp-radv_t{bottom:0;color:inherit;left:0;overflow:hidden;position:absolute;right:0;text-align:center;text-overflow:ellipsis;top:0}.tp-radv_i:disabled+.tp-radv_b>.tp-radv_t{opacity:.5}.tp-radgridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-radgridv.tp-v-disabled{opacity:.5}.tp-radgridv .tp-radv_b{border-radius:0}',accept:(m,o)=>{if(!Fe.isObject(m))return null;const p=he,v=ee(o,{format:p.optional.function,max:p.optional.number,min:p.optional.number,step:p.optional.number});return v?{initialValue:new Fe(m.min,m.max),params:v}:null},binding:{reader:m=>Qi,constraint:m=>Zs(m.params),equals:Fe.equals,writer:m=>fi},controller(m){var o;const p=m.value,v=m.constraint;if(!(v instanceof an))throw _.shouldNeverHappen();const C=(p.rawValue.min+p.rawValue.max)/2,k=(o=m.params.format)!==null&&o!==void 0?o:Se(en(v.edge,C)),T=v.edge&&lt(v.edge,st);if(T)return new ot(m.document,{baseStep:ti(v.edge),constraint:v.edge,draggingScale:kn(v.edge,C),formatter:k,parser:Wt,sliderProps:new Y({maxValue:T.values.value("max"),minValue:T.values.value("min")}),value:p,viewProps:m.viewProps});const G={baseStep:ti(v.edge),constraint:v.edge,textProps:Y.fromObject({draggingScale:C,formatter:k})};return new bt(m.document,{assembly:hi,axes:[G,G],parser:Wt,value:p,viewProps:m.viewProps})}};class wt{constructor(o){this.controller_=o}get disabled(){return this.controller_.viewProps.get("disabled")}set disabled(o){this.controller_.viewProps.set("disabled",o)}get title(){var o;return(o=this.controller_.props.get("title"))!==null&&o!==void 0?o:""}set title(o){this.controller_.props.set("title",o)}}class yt extends c{constructor(o,p,v,C,k){super(o,C,k),this.cell=p,this.index=v}}class cn extends s{constructor(o){super(o),this.cellToApiMap_=new Map,this.controller_.valueController.cellControllers.forEach(v=>{const C=new wt(v);this.cellToApiMap_.set(v,C)})}get value(){return this.controller_.value}cell(o,p){const v=this.controller_.valueController,C=v.cellControllers[p*v.size[0]+o];return this.cellToApiMap_.get(C)}on(o,p){const v=p.bind(this);this.controller_.value.emitter.on(o,C=>{const k=this.controller_.valueController,T=k.findCellByValue(C.rawValue);if(!T)return;const G=this.cellToApiMap_.get(T);if(!G)return;const oe=k.cellControllers.indexOf(T);v(new yt(this,G,[oe%k.size[0],Math.floor(oe/k.size[0])],C.rawValue,void 0))})}}const pn=x("rad");class Zi{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(pn()),p.viewProps.bindClassModifiers(this.element);const v=o.createElement("label");v.classList.add(pn("l")),this.element.appendChild(v);const C=o.createElement("input");C.classList.add(pn("i")),C.name=p.name,C.type="radio",p.viewProps.bindDisabled(C),v.appendChild(C),this.inputElement=C;const k=o.createElement("div");k.classList.add(pn("b")),v.appendChild(k);const T=o.createElement("div");T.classList.add(pn("t")),k.appendChild(T),E(p.props,"title",G=>{T.textContent=G})}}class Wi{constructor(o,p){this.props=p.props,this.viewProps=p.viewProps,this.view=new Zi(o,{name:p.name,props:this.props,viewProps:this.viewProps})}}class Dn{constructor(o,p){this.cellCs_=[],this.cellValues_=[],this.onCellInputChange_=this.onCellInputChange_.bind(this),this.size=p.size;const[v,C]=this.size;for(let k=0;k<C;k++)for(let T=0;T<v;T++){const G=new Wi(o,{name:p.groupName,props:Y.fromObject(Object.assign({},p.cellConfig(T,k))),viewProps:be.create()});this.cellCs_.push(G),this.cellValues_.push(p.cellConfig(T,k).value)}this.value=p.value,I(this.value,k=>{const T=this.findCellByValue(k);T&&(T.view.inputElement.checked=!0)}),this.viewProps=be.create(),this.view=new at(o,{viewProps:this.viewProps,viewName:"radgrid"}),this.view.element.style.gridTemplateColumns=`repeat(${v}, 1fr)`,this.cellCs_.forEach(k=>{k.view.inputElement.addEventListener("change",this.onCellInputChange_),this.view.element.appendChild(k.view.element)})}get cellControllers(){return this.cellCs_}findCellByValue(o){const p=this.cellValues_.findIndex(v=>v===o);return p<0?null:this.cellCs_[p]}onCellInputChange_(o){const p=o.currentTarget,v=this.cellCs_.findIndex(C=>C.view.inputElement===p);v<0||(this.value.rawValue=this.cellValues_[v])}}const xt=function(){return{id:"radiogrid",type:"blade",accept(m){const o=he,p=ee(m,{cells:o.required.function,groupName:o.required.string,size:o.required.array(o.required.number),value:o.required.raw,view:o.required.constant("radiogrid"),label:o.optional.string});return p?{params:p}:null},controller(m){return new mt(m.document,{blade:m.blade,props:Y.fromObject({label:m.params.label}),valueController:new Dn(m.document,{groupName:m.params.groupName,cellConfig:m.params.cells,size:m.params.size,value:X(m.params.value)})})},api(m){return!(m.controller instanceof mt)||!(m.controller.valueController instanceof Dn)?null:new cn(m.controller)}}}();function vi(m){return{id:"input-radiogrid",type:"input",accept(o,p){if(!m.isType(o))return null;const v=he,C=ee(p,{cells:v.required.function,groupName:v.required.string,size:v.required.array(v.required.number),view:v.required.constant("radiogrid")});return C?{initialValue:o,params:C}:null},binding:m.binding,controller:o=>new Dn(o.document,{cellConfig:o.params.cells,groupName:o.params.groupName,size:o.params.size,value:o.value})}}const Ws=vi({isType:m=>typeof m=="number",binding:{reader:m=>Ss,writer:m=>$e}}),Js=vi({isType:m=>typeof m=="string",binding:{reader:m=>Ai,writer:m=>$e}}),Hs=vi({isType:m=>typeof m=="boolean",binding:{reader:m=>qt,writer:m=>$e}}),Ji=[Gs,_t,ui,In,xt,Hs,Ws,Js];r.ButtonCellApi=Ri,r.ButtonGridApi=Gi,r.ButtonGridController=ii,r.CubicBezier=ct,r.CubicBezierApi=Ki,r.CubicBezierAssembly=ri,r.CubicBezierController=An,r.CubicBezierGraphController=He,r.CubicBezierGraphView=Le,r.CubicBezierPickerController=qi,r.CubicBezierPickerView=Xi,r.CubicBezierPreviewView=Et,r.CubicBezierView=$i,r.FpsGraphBladeApi=_e,r.FpsGraphController=pi,r.FpsView=Ne,r.Fpswatch=Me,r.Interval=Fe,r.IntervalAssembly=hi,r.IntervalConstraint=an,r.RadioCellApi=wt,r.RadioController=Wi,r.RadioGridApi=cn,r.RadioGridController=Dn,r.RadioView=Zi,r.RangeSliderController=mi,r.RangeSliderTextController=ot,r.RangeSliderTextView=Vn,r.RangeSliderView=ln,r.TpRadioGridChangeEvent=yt,r.plugins=Ji,Object.defineProperty(r,"__esModule",{value:!0})})})(Vl,Gn);const Il=Uo({__proto__:null,default:al(Gn)},[Gn]);let Kt,Ci;const Dl=(g="tres-container")=>{Kt||(Kt=new xi.Pane({container:document.querySelector(g)||void 0}),Kt.registerPlugin(Il),Ci=Kt.addBlade({view:"fpsgraph",label:"fpsgraph"}));function i(){Kt&&Kt.dispose()}return L.onMounted(()=>{const{onBeforeLoop:r,onAfterLoop:s,resume:a}=zt.useRenderLoop();a(),r(()=>Ci.begin()),s(()=>Ci.end())}),L.onUnmounted(()=>{i()}),{pane:Kt,fpsGraph:Ci,disposeTweakPane:i}};function Tl(g,i){const r=L.ref(i),s=new f.AnimationMixer(r.value),a=L.shallowReactive({});g.forEach(u=>{const h=s.clipAction(u,r.value);a[u.name]=h});const{onLoop:c}=zt.useRenderLoop();return c(({delta:u})=>{s.update(u)}),{actions:a,mixer:s}}let Pi=null;function El(g,i){return r=>{i&&i(r),g.draco&&(Pi||(Pi=new cl),Pi.setDecoderPath(g.decoderPath||"https://www.gstatic.com/draco/versioned/decoders/1.4.3/"),r.setDRACOLoader(Pi))}}async function Hr(g,i={draco:!1},r){return await zt.useLoader(la,g,El(i,r))}const Ol=L.defineComponent({name:"GLTFModel",props:["path","draco","decoderPath"],async setup(g,{expose:i}){const{state:r}=Rt();let s;function a(){return s}i({getModel:a});const{scene:c}=await Hr(g.path,{draco:g.draco,decoderPath:g.decoderPath});return s=c,r.scene&&r.scene.add(c),()=>{}}});async function eo(g){return await zt.useLoader(Xa,g)}const Bl=L.defineComponent({name:"FBXModel",props:["path"],async setup(g,{expose:i}){const{state:r}=Rt();let s=null;function a(){return s}return i({getModel:a}),s=await eo(g.path),r.scene&&s.isObject3D&&r.scene.add(s),()=>{}}}),Nl={key:0},Fl=["args","center"],jl=L.defineComponent({__name:"Text3D",props:{font:null,text:null,size:{default:.5},height:{default:.2},curveSegments:{default:5},bevelEnabled:{type:Boolean,default:!0},bevelThickness:{default:.05},bevelSize:{default:.02},bevelOffset:{default:0},bevelSegments:{default:4},center:{type:Boolean,default:!1}},async setup(g){let i,r;const s=g,{extend:a}=Rt();a({TextGeometry:Fa});const c=new sl,u=L.useSlots(),h=L.computed(()=>{var y;return s.text?s.text:u.default?(y=u.default()[0].children)==null?void 0:y.trim():"TresJS"}),d=([i,r]=L.withAsyncContext(()=>new Promise((y,w)=>{try{typeof s.font=="string"?c.load(s.font,x=>{y(x)}):y(s.font)}catch(x){w(console.error("cientos",x))}})),i=await i,r(),i),_=L.computed(()=>({font:d,size:s.size,height:s.height,curveSegments:s.curveSegments,bevelEnabled:s.bevelEnabled,bevelThickness:s.bevelThickness,bevelSize:s.bevelSize,bevelOffset:s.bevelOffset,bevelSegments:s.bevelSegments}));return(y,w)=>L.unref(d)?(L.openBlock(),L.createElementBlock("TresMesh",Nl,[L.unref(h)?(L.openBlock(),L.createElementBlock("TresTextGeometry",{key:0,args:[L.unref(h),L.unref(_)],center:g.center},null,8,Fl)):L.createCommentVNode("",!0),L.renderSlot(y.$slots,"default")])):L.createCommentVNode("",!0)}}),zl=["rotation"],Ul=["args"],Rl=["color"],Gl=L.defineComponent({__name:"Plane",props:{args:{default:()=>[1,1]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"planeRef",ref:r,rotation:[-Math.PI/2,0,0]},s.$attrs),[L.createElementVNode("TresPlaneGeometry",{args:g.args},null,8,Ul),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,Rl)])],16,zl))}}),Kl=["args"],$l=["color"],Xl=L.defineComponent({__name:"Box",props:{args:{default:()=>[1,1,1]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"boxRef",ref:r},s.$attrs),[L.createElementVNode("TresBoxGeometry",{args:g.args},null,8,Kl),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,$l)])],16))}}),Yl=["args"],ql=["color"],Ql=L.defineComponent({__name:"Sphere",props:{args:{default:()=>[2,32,16]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"sphereRef",ref:r},s.$attrs),[L.createElementVNode("TresSphereGeometry",{args:g.args},null,8,Yl),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,ql)])],16))}}),Zl=["args"],Wl=["color"],Jl=L.defineComponent({__name:"Torus",props:{args:{default:()=>[1,1,16,80]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"torusRef",ref:r},s.$attrs),[L.createElementVNode("TresTorusGeometry",{args:g.args},null,8,Zl),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,Wl)])],16))}}),Hl=["args"],ec=["color"],tc=L.defineComponent({__name:"TorusKnot",props:{args:{default:()=>[1,.4,64,8]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"torusKnotRef",ref:r},s.$attrs),[L.createElementVNode("TresTorusKnotGeometry",{args:g.args},null,8,Hl),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,ec)])],16))}}),nc=["args"],ic=["color"],sc=L.defineComponent({__name:"Circle",props:{args:{default:()=>[1,32,0,Math.PI*2]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"circleRef",ref:r},s.$attrs),[L.createElementVNode("TresCircleGeometry",{args:g.args},null,8,nc),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,ic)])],16))}}),rc=["args"],oc=["color"],ac=L.defineComponent({__name:"Cone",props:{args:{default:()=>[1,1,12,!1,0,Math.PI*2]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"coneRef",ref:r},s.$attrs),[L.createElementVNode("TresConeGeometry",{args:g.args},null,8,rc),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,oc)])],16))}}),lc=["args"],cc=["color"],pc=L.defineComponent({__name:"Tube",props:{args:{default:()=>[new f.QuadraticBezierCurve3(new f.Vector3(-1,0,0),new f.Vector3(0,1,0),new f.Vector3(1,0,0)),20,.2,8,!1]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"tubeRef",ref:r},s.$attrs),[L.createElementVNode("TresTubeGeometry",{args:g.args},null,8,lc),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,cc)])],16))}}),uc=["args"],hc=["color"],dc=L.defineComponent({__name:"Ring",props:{args:{default:()=>[.5,1,32]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"ringRef",ref:r},s.$attrs),[L.createElementVNode("TresRingGeometry",{args:g.args},null,8,uc),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,hc)])],16))}}),mc=["rotation"],fc=["args"],vc=["color"],bc=L.defineComponent({__name:"Tetrahedron",props:{args:{default:()=>[1,0]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"tetrahedronRef",ref:r,rotation:[-Math.PI/2,0,0]},s.$attrs),[L.createElementVNode("TresTetrahedronGeometry",{args:g.args},null,8,fc),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,vc)])],16,mc))}}),gc=["args"],_c=["color"],wc=L.defineComponent({__name:"Icosahedron",props:{args:{default:()=>[1,0]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"icosahedronRef",ref:r},s.$attrs),[L.createElementVNode("TresIcosahedronGeometry",{args:g.args},null,8,gc),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,_c)])],16))}}),yc=["args"],xc=["color"],Cc=L.defineComponent({__name:"Octahedron",props:{args:{default:()=>[1,0]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"octahedronRef",ref:r},s.$attrs),[L.createElementVNode("TresOctahedronGeometry",{args:g.args},null,8,yc),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,xc)])],16))}}),Pc=["args"],Mc=["color"],kc=L.defineComponent({__name:"Dodecahedron",props:{args:{default:()=>[1,0]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=L.shallowRef();return i({value:r}),(s,a)=>(L.openBlock(),L.createElementBlock("TresMesh",L.mergeProps({ref_key:"dodecahedronRef",ref:r},s.$attrs),[L.createElementVNode("TresDodecahedronGeometry",{args:g.args},null,8,Pc),L.renderSlot(s.$slots,"default",{},()=>[L.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,Mc)])],16))}}),ms={sunset:"venice/venice_sunset_4k.hdr"};async function to({files:g=["/px.png","/nx.png","/py.png","/ny.png","/pz.png","/nz.png"],blur:i=0,background:r=!1,path:s="/",preset:a=void 0,encoding:c=void 0}){const{state:u}=Rt();if(a){if(!(a in ms))throw new Error("Preset must be one of: "+Object.keys(ms).join(", "));g=ms[a],s="https://raw.githubusercontent.com/Tresjs/assets/main/textures/hdr/"}const h=Array.isArray(g),d=h?f.CubeTextureLoader:ll,_=await zt.useLoader(d,h?[g]:g,w=>{s&&w.setPath(s),c&&(w.encoding=c)}),y=h?_[0]:_;return y&&(y.mapping=h?f.CubeReflectionMapping:f.EquirectangularReflectionMapping,y.encoding=c??h?f.sRGBEncoding:f.LinearEncoding),u.scene&&(u.scene.environment=y,r!==void 0&&(u.scene.background=y),i&&(u.scene.backgroundBlurriness=i|0)),y}const Sc=L.defineComponent({name:"Environment",props:["background","blur","files","encoding","path","preset"],async setup(g,{expose:i}){let r=null;return i({getTexture:()=>r}),r=await to(g),()=>{}}});ae.Box=Xl,ae.Circle=sc,ae.Cone=ac,ae.Dodecahedron=kc,ae.Environment=Sc,ae.FBXModel=Bl,ae.GLTFModel=Ol,ae.Icosahedron=wc,ae.Octahedron=Cc,ae.OrbitControls=hl,ae.PamCameraMouse=Ll,ae.Plane=Gl,ae.Ring=dc,ae.Sphere=Ql,ae.Tetrahedron=bc,ae.Text3D=jl,ae.Torus=Jl,ae.TorusKnot=tc,ae.TransformControls=fl,ae.Tube=pc,ae.useAnimations=Tl,ae.useEnvironment=to,ae.useFBX=eo,ae.useGLTF=Hr,ae.usePamCameraMouse=Jr,ae.useTweakPane=Dl,Object.defineProperty(ae,Symbol.toStringTag,{value:"Module"})});
19
+ `);this.workerSourceURL=URL.createObjectURL(new Blob([u]))}),this.decoderPending}_getWorker(i,r){return this._initDecoder().then(()=>{if(this.workerPool.length<this.workerLimit){const a=new Worker(this.workerSourceURL);a._callbacks={},a._taskCosts={},a._taskLoad=0,a.postMessage({type:"init",decoderConfig:this.decoderConfig}),a.onmessage=function(c){const u=c.data;switch(u.type){case"decode":a._callbacks[u.id].resolve(u);break;case"error":a._callbacks[u.id].reject(u);break;default:console.error('THREE.DRACOLoader: Unexpected message, "'+u.type+'"')}},this.workerPool.push(a)}else this.workerPool.sort(function(a,c){return a._taskLoad>c._taskLoad?-1:1});const s=this.workerPool[this.workerPool.length-1];return s._taskCosts[i]=r,s._taskLoad+=r,s})}_releaseTask(i,r){i._taskLoad-=i._taskCosts[r],delete i._callbacks[r],delete i._taskCosts[r]}debug(){console.log("Task load: ",this.workerPool.map(i=>i._taskLoad))}dispose(){for(let i=0;i<this.workerPool.length;++i)this.workerPool[i].terminate();return this.workerPool.length=0,this}}function pl(){let g,i;onmessage=function(u){const h=u.data;switch(h.type){case"init":g=h.decoderConfig,i=new Promise(function(y){g.onModuleLoaded=function(w){y({draco:w})},DracoDecoderModule(g)});break;case"decode":const d=h.buffer,_=h.taskConfig;i.then(y=>{const w=y.draco,x=new w.Decoder,M=new w.DecoderBuffer;M.Init(new Int8Array(d),d.byteLength);try{const O=r(w,x,M,_),I=O.attributes.map(E=>E.array.buffer);O.index&&I.push(O.index.array.buffer),self.postMessage({type:"decode",id:h.id,geometry:O},I)}catch(O){console.error(O),self.postMessage({type:"error",id:h.id,error:O.message})}finally{w.destroy(M),w.destroy(x)}});break}};function r(u,h,d,_){const y=_.attributeIDs,w=_.attributeTypes;let x,M;const O=h.GetEncodedGeometryType(d);if(O===u.TRIANGULAR_MESH)x=new u.Mesh,M=h.DecodeBufferToMesh(d,x);else if(O===u.POINT_CLOUD)x=new u.PointCloud,M=h.DecodeBufferToPointCloud(d,x);else throw new Error("THREE.DRACOLoader: Unexpected geometry type.");if(!M.ok()||x.ptr===0)throw new Error("THREE.DRACOLoader: Decoding failed: "+M.error_msg());const I={index:null,attributes:[]};for(const E in y){const R=self[w[E]];let z,B;if(_.useUniqueIDs)B=y[E],z=h.GetAttributeByUniqueId(x,B);else{if(B=h.GetAttributeId(x,u[y[E]]),B===-1)continue;z=h.GetAttribute(x,B)}I.attributes.push(a(u,h,x,E,R,z))}return O===u.TRIANGULAR_MESH&&(I.index=s(u,h,x)),u.destroy(x),I}function s(u,h,d){const y=d.num_faces()*3,w=y*4,x=u._malloc(w);h.GetTrianglesUInt32Array(d,w,x);const M=new Uint32Array(u.HEAPF32.buffer,x,y).slice();return u._free(x),{array:M,itemSize:1}}function a(u,h,d,_,y,w){const x=w.num_components(),O=d.num_points()*x,I=O*y.BYTES_PER_ELEMENT,E=c(u,y),R=u._malloc(I);h.GetAttributeDataArrayForAllPoints(d,w,E,I,R);const z=new y(u.HEAPF32.buffer,R,O).slice();return u._free(R),{name:_,array:z,itemSize:x}}function c(u,h){switch(h){case Float32Array:return u.DT_FLOAT32;case Int8Array:return u.DT_INT8;case Int16Array:return u.DT_INT16;case Int32Array:return u.DT_INT32;case Uint8Array:return u.DT_UINT8;case Uint16Array:return u.DT_UINT16;case Uint32Array:return u.DT_UINT32}}}function Rt(){const{state:g,setState:i}=A.inject("useTres",zt.useTres()),r=A.inject("extend")||(()=>{});return{state:g,setState:i,extend:r}}const ul=["args"],hl=A.defineComponent({__name:"OrbitControls",props:{makeDefault:{type:Boolean,default:!1},camera:null,domElement:null,target:null,enableDamping:{type:Boolean}},setup(g){const i=g,{state:r,setState:s,extend:a}=Rt(),c=A.ref(null);return a({OrbitControls:aa}),A.watch(c,u=>{u&&i.makeDefault?s("controls",u):s("controls",null)}),(u,h)=>{var d;return A.unref(r).camera&&A.unref(r).renderer?(A.openBlock(),A.createElementBlock("TresOrbitControls",{key:0,ref_key:"controls",ref:c,args:[A.unref(A.unref(r).camera)||g.camera,((d=A.unref(r).renderer)==null?void 0:d.domElement)||g.domElement]},null,8,ul)):A.createCommentVNode("",!0)}}});function dl(g,i){const r={};for(const s of i)Object.prototype.hasOwnProperty.call(g,s)&&(r[s]=g[s]);return r}function ml(g,i){const r=`set${i[0].toUpperCase()}${i.slice(1)}`;return g[r]!==void 0}const fl=A.defineComponent({__name:"TransformControls",props:{object:null,mode:null,enabled:{type:Boolean,default:!0},axis:null,translationSnap:null,rotationSnap:null,scaleSnap:null,space:null,size:null,showX:{type:Boolean},showY:{type:Boolean},showZ:{type:Boolean}},emits:["dragging","change","mouseDown","mouseUp","objectChange"],setup(g,{emit:i}){const r=g;let s=A.shallowRef();const{state:a}=Rt(),c=A.computed(()=>dl(r,["enabled","axis","mode","translationSnap","rotationSnap","scaleSnap","space","size","showX","showY","showZ"])),u=()=>i("change",s.value),h=()=>i("mouseDown",s.value),d=()=>i("mouseUp",s.value),_=()=>i("objectChange",s.value),y=x=>{a.controls&&(a.controls.enabled=!x.value),i("dragging",x.value)};function w(x){x.addEventListener("dragging-changed",y),x.addEventListener("change",u),x.addEventListener("mouseDown",h),x.addEventListener("mouseUp",d),x.addEventListener("objectChange",_)}return A.watchEffect(()=>{a.camera&&a.renderer&&a.scene&&r.object&&(s.value=new sa(a.camera,a.renderer.domElement),s.value.attach(r.object),a.scene.add(s.value),w(s.value))}),A.watch([c,s],([x,M])=>{if(x&&M)for(const O in x)if(!ml(M,O))M[O]=x[O];else{const I=`set${O[0].toUpperCase()}${O.slice(1)}`;typeof M[I]=="function"&&x[O]!==void 0&&M[I](x[O])}},{immediate:!0}),A.onUnmounted(()=>{s.value&&(s.value.removeEventListener("dragging-changed",y),s.value.removeEventListener("change",u),s.value.removeEventListener("mouseDown",h),s.value.removeEventListener("mouseUp",d),s.value.removeEventListener("objectChange",_))}),(x,M)=>A.renderSlot(x.$slots,"default")}});var Kr;const $r=typeof window<"u",vl=g=>typeof g=="string",bl=()=>{};$r&&((Kr=window==null?void 0:window.navigator)!=null&&Kr.userAgent)&&/iP(ad|hone|od)/.test(window.navigator.userAgent);function Xr(g){return typeof g=="function"?g():A.unref(g)}function gl(g){return g}function _l(g){return A.getCurrentScope()?(A.onScopeDispose(g),!0):!1}function wl(g,i=!0){A.getCurrentInstance()?A.onMounted(g):i?g():A.nextTick(g)}function yl(g){var i;const r=Xr(g);return(i=r==null?void 0:r.$el)!=null?i:r}const ds=$r?window:void 0;function Gt(...g){let i,r,s,a;if(vl(g[0])||Array.isArray(g[0])?([r,s,a]=g,i=ds):[i,r,s,a]=g,!i)return bl;Array.isArray(r)||(r=[r]),Array.isArray(s)||(s=[s]);const c=[],u=()=>{c.forEach(y=>y()),c.length=0},h=(y,w,x,M)=>(y.addEventListener(w,x,M),()=>y.removeEventListener(w,x,M)),d=A.watch(()=>[yl(i),Xr(a)],([y,w])=>{u(),y&&c.push(...r.flatMap(x=>s.map(M=>h(y,x,M,w))))},{immediate:!0,flush:"post"}),_=()=>{d(),u()};return _l(_),_}const Yr=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{},qr="__vueuse_ssr_handlers__";Yr[qr]=Yr[qr]||{};function xl(g={}){const{type:i="page",touch:r=!0,resetOnTouchEnds:s=!1,initialValue:a={x:0,y:0},window:c=ds,eventFilter:u}=g,h=A.ref(a.x),d=A.ref(a.y),_=A.ref(null),y=I=>{i==="page"?(h.value=I.pageX,d.value=I.pageY):i==="client"?(h.value=I.clientX,d.value=I.clientY):i==="movement"&&(h.value=I.movementX,d.value=I.movementY),_.value="mouse"},w=()=>{h.value=a.x,d.value=a.y},x=I=>{if(I.touches.length>0){const E=I.touches[0];i==="page"?(h.value=E.pageX,d.value=E.pageY):i==="client"&&(h.value=E.clientX,d.value=E.clientY),_.value="touch"}},M=I=>u===void 0?y(I):u(()=>y(I),{}),O=I=>u===void 0?x(I):u(()=>x(I),{});return c&&(Gt(c,"mousemove",M,{passive:!0}),Gt(c,"dragover",M,{passive:!0}),r&&i!=="movement"&&(Gt(c,"touchstart",O,{passive:!0}),Gt(c,"touchmove",O,{passive:!0}),s&&Gt(c,"touchend",w,{passive:!0}))),{x:h,y:d,sourceType:_}}var Qr;(function(g){g.UP="UP",g.RIGHT="RIGHT",g.DOWN="DOWN",g.LEFT="LEFT",g.NONE="NONE"})(Qr||(Qr={}));var Cl=Object.defineProperty,Zr=Object.getOwnPropertySymbols,Pl=Object.prototype.hasOwnProperty,Ml=Object.prototype.propertyIsEnumerable,Wr=(g,i,r)=>i in g?Cl(g,i,{enumerable:!0,configurable:!0,writable:!0,value:r}):g[i]=r,kl=(g,i)=>{for(var r in i||(i={}))Pl.call(i,r)&&Wr(g,r,i[r]);if(Zr)for(var r of Zr(i))Ml.call(i,r)&&Wr(g,r,i[r]);return g};kl({linear:gl},{easeInSine:[.12,0,.39,0],easeOutSine:[.61,1,.88,1],easeInOutSine:[.37,0,.63,1],easeInQuad:[.11,0,.5,0],easeOutQuad:[.5,1,.89,1],easeInOutQuad:[.45,0,.55,1],easeInCubic:[.32,0,.67,0],easeOutCubic:[.33,1,.68,1],easeInOutCubic:[.65,0,.35,1],easeInQuart:[.5,0,.75,0],easeOutQuart:[.25,1,.5,1],easeInOutQuart:[.76,0,.24,1],easeInQuint:[.64,0,.78,0],easeOutQuint:[.22,1,.36,1],easeInOutQuint:[.83,0,.17,1],easeInExpo:[.7,0,.84,0],easeOutExpo:[.16,1,.3,1],easeInOutExpo:[.87,0,.13,1],easeInCirc:[.55,0,1,.45],easeOutCirc:[0,.55,.45,1],easeInOutCirc:[.85,0,.15,1],easeInBack:[.36,0,.66,-.56],easeOutBack:[.34,1.56,.64,1],easeInOutBack:[.68,-.6,.32,1.6]});function Sl(g={}){const{window:i=ds,initialWidth:r=1/0,initialHeight:s=1/0,listenOrientation:a=!0,includeScrollbar:c=!0}=g,u=A.ref(r),h=A.ref(s),d=()=>{i&&(c?(u.value=i.innerWidth,h.value=i.innerHeight):(u.value=i.document.documentElement.clientWidth,h.value=i.document.documentElement.clientHeight))};return d(),wl(d),Gt("resize",d,{passive:!0}),a&&Gt("orientationchange",d,{passive:!0}),{width:u,height:h}}function Jr(g=!1,i=5,r){const{x:s,y:a}=xl(),{logWarning:c}=zt.useLogger(),{width:u,height:h}=Sl(),d=A.computed(()=>(s.value/u.value-.5)*i),_=A.computed(()=>-(a.value/h.value-.5)*i);if(r){const{x:y,y:w}=r.position;A.watchEffect(()=>{g||r&&(r.position.x=y+d.value,r.position.y=w+_.value)})}else c("Scene must contain a Camera component to use this composable")}const Ll=A.defineComponent({name:"PamCameraMouse",props:["disabled","factor"],setup(g){const{state:i}=Rt();return A.watchEffect(()=>{if(i!=null&&i.camera){const r=i==null?void 0:i.camera;Jr(g.disabled,g.factor,r)}}),()=>{}}});var xi={},Al={get exports(){return xi},set exports(g){xi=g}};/*! Tweakpane 3.1.7 (c) 2016 cocopon, licensed under the MIT license. */(function(g,i){(function(r,s){s(i)})(Gr,function(r){class s{constructor(e){const[t,l]=e.split("-"),b=t.split(".");this.major=parseInt(b[0],10),this.minor=parseInt(b[1],10),this.patch=parseInt(b[2],10),this.prerelease=l??null}toString(){const e=[this.major,this.minor,this.patch].join(".");return this.prerelease!==null?[e,this.prerelease].join("-"):e}}class a{constructor(e){this.controller_=e}get element(){return this.controller_.view.element}get disabled(){return this.controller_.viewProps.get("disabled")}set disabled(e){this.controller_.viewProps.set("disabled",e)}get hidden(){return this.controller_.viewProps.get("hidden")}set hidden(e){this.controller_.viewProps.set("hidden",e)}dispose(){this.controller_.viewProps.set("disposed",!0)}}class c{constructor(e){this.target=e}}class u extends c{constructor(e,t,l,b){super(e),this.value=t,this.presetKey=l,this.last=b??!0}}class h extends c{constructor(e,t,l){super(e),this.value=t,this.presetKey=l}}class d extends c{constructor(e,t){super(e),this.expanded=t}}class _ extends c{constructor(e,t){super(e),this.index=t}}function y(n){return n}function w(n){return n==null}function x(n,e){if(n.length!==e.length)return!1;for(let t=0;t<n.length;t++)if(n[t]!==e[t])return!1;return!0}function M(n,e){let t=n;do{const l=Object.getOwnPropertyDescriptor(t,e);if(l&&(l.set!==void 0||l.writable===!0))return!0;t=Object.getPrototypeOf(t)}while(t!==null);return!1}const O={alreadydisposed:()=>"View has been already disposed",invalidparams:n=>`Invalid parameters for '${n.name}'`,nomatchingcontroller:n=>`No matching controller for '${n.key}'`,nomatchingview:n=>`No matching view for '${JSON.stringify(n.params)}'`,notbindable:()=>"Value is not bindable",propertynotfound:n=>`Property '${n.name}' not found`,shouldneverhappen:()=>"This error should never happen"};class I{static alreadyDisposed(){return new I({type:"alreadydisposed"})}static notBindable(){return new I({type:"notbindable"})}static propertyNotFound(e){return new I({type:"propertynotfound",context:{name:e}})}static shouldNeverHappen(){return new I({type:"shouldneverhappen"})}constructor(e){var t;this.message=(t=O[e.type](e.context))!==null&&t!==void 0?t:"Unexpected error",this.name=this.constructor.name,this.stack=new Error(this.message).stack,this.type=e.type}}class E{constructor(e,t,l){this.obj_=e,this.key_=t,this.presetKey_=l??t}static isBindable(e){return!(e===null||typeof e!="object")}get key(){return this.key_}get presetKey(){return this.presetKey_}read(){return this.obj_[this.key_]}write(e){this.obj_[this.key_]=e}writeProperty(e,t){const l=this.read();if(!E.isBindable(l))throw I.notBindable();if(!(e in l))throw I.propertyNotFound(e);l[e]=t}}class R extends a{get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}get title(){var e;return(e=this.controller_.valueController.props.get("title"))!==null&&e!==void 0?e:""}set title(e){this.controller_.valueController.props.set("title",e)}on(e,t){const l=t.bind(this);return this.controller_.valueController.emitter.on(e,()=>{l(new c(this))}),this}}class z{constructor(){this.observers_={}}on(e,t){let l=this.observers_[e];return l||(l=this.observers_[e]=[]),l.push({handler:t}),this}off(e,t){const l=this.observers_[e];return l&&(this.observers_[e]=l.filter(b=>b.handler!==t)),this}emit(e,t){const l=this.observers_[e];l&&l.forEach(b=>{b.handler(t)})}}const B="tp";function N(n){return(t,l)=>[B,"-",n,"v",t?`_${t}`:"",l?`-${l}`:""].join("")}function Q(n,e){return t=>e(n(t))}function $(n){return n.rawValue}function j(n,e){n.emitter.on("change",Q($,e)),e(n.rawValue)}function F(n,e,t){j(n.value(e),t)}function X(n,e,t){t?n.classList.add(e):n.classList.remove(e)}function Y(n,e){return t=>{X(n,e,t)}}function Z(n,e){j(n,t=>{e.textContent=t??""})}const ue=N("btn");class ge{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(ue()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("button");l.classList.add(ue("b")),t.viewProps.bindDisabled(l),this.element.appendChild(l),this.buttonElement=l;const b=e.createElement("div");b.classList.add(ue("t")),Z(t.props.value("title"),b),this.buttonElement.appendChild(b)}}class pe{constructor(e,t){this.emitter=new z,this.onClick_=this.onClick_.bind(this),this.props=t.props,this.viewProps=t.viewProps,this.view=new ge(e,{props:this.props,viewProps:this.viewProps}),this.view.buttonElement.addEventListener("click",this.onClick_)}onClick_(){this.emitter.emit("click",{sender:this})}}class me{constructor(e,t){var l;this.constraint_=t==null?void 0:t.constraint,this.equals_=(l=t==null?void 0:t.equals)!==null&&l!==void 0?l:(b,P)=>b===P,this.emitter=new z,this.rawValue_=e}get constraint(){return this.constraint_}get rawValue(){return this.rawValue_}set rawValue(e){this.setRawValue(e,{forceEmit:!1,last:!0})}setRawValue(e,t){const l=t??{forceEmit:!1,last:!0},b=this.constraint_?this.constraint_.constrain(e):e,P=this.rawValue_;this.equals_(P,b)&&!l.forceEmit||(this.emitter.emit("beforechange",{sender:this}),this.rawValue_=b,this.emitter.emit("change",{options:l,previousRawValue:P,rawValue:b,sender:this}))}}class he{constructor(e){this.emitter=new z,this.value_=e}get rawValue(){return this.value_}set rawValue(e){this.setRawValue(e,{forceEmit:!1,last:!0})}setRawValue(e,t){const l=t??{forceEmit:!1,last:!0},b=this.value_;b===e&&!l.forceEmit||(this.emitter.emit("beforechange",{sender:this}),this.value_=e,this.emitter.emit("change",{options:l,previousRawValue:b,rawValue:this.value_,sender:this}))}}function ee(n,e){const t=e==null?void 0:e.constraint,l=e==null?void 0:e.equals;return!t&&!l?new he(n):new me(n,e)}class q{constructor(e){this.emitter=new z,this.valMap_=e;for(const t in this.valMap_)this.valMap_[t].emitter.on("change",()=>{this.emitter.emit("change",{key:t,sender:this})})}static createCore(e){return Object.keys(e).reduce((l,b)=>Object.assign(l,{[b]:ee(e[b])}),{})}static fromObject(e){const t=this.createCore(e);return new q(t)}get(e){return this.valMap_[e].rawValue}set(e,t){this.valMap_[e].rawValue=t}value(e){return this.valMap_[e]}}function Ce(n,e){const l=Object.keys(e).reduce((b,P)=>{if(b===void 0)return;const L=e[P],U=L(n[P]);return U.succeeded?Object.assign(Object.assign({},b),{[P]:U.value}):void 0},{});return l}function fe(n,e){return n.reduce((t,l)=>{if(t===void 0)return;const b=e(l);if(!(!b.succeeded||b.value===void 0))return[...t,b.value]},[])}function le(n){return n===null?!1:typeof n=="object"}function ne(n){return e=>t=>{if(!e&&t===void 0)return{succeeded:!1,value:void 0};if(e&&t===void 0)return{succeeded:!0,value:void 0};const l=n(t);return l!==void 0?{succeeded:!0,value:l}:{succeeded:!1,value:void 0}}}function be(n){return{custom:e=>ne(e)(n),boolean:ne(e=>typeof e=="boolean"?e:void 0)(n),number:ne(e=>typeof e=="number"?e:void 0)(n),string:ne(e=>typeof e=="string"?e:void 0)(n),function:ne(e=>typeof e=="function"?e:void 0)(n),constant:e=>ne(t=>t===e?e:void 0)(n),raw:ne(e=>e)(n),object:e=>ne(t=>{if(le(t))return Ce(t,e)})(n),array:e=>ne(t=>{if(Array.isArray(t))return fe(t,e)})(n)}}const V={optional:be(!0),required:be(!1)};function ce(n,e){const t=V.required.object(e)(n);return t.succeeded?t.value:void 0}function Ae(n){console.warn([`Missing '${n.key}' of ${n.target} in ${n.place}.`,"Please rebuild plugins with the latest core package."].join(" "))}function De(n){return n&&n.parentElement&&n.parentElement.removeChild(n),null}class we{constructor(e){this.value_=e}static create(e){return[new we(e),(t,l)=>{e.setRawValue(t,l)}]}get emitter(){return this.value_.emitter}get rawValue(){return this.value_.rawValue}}const qe=N("");function fn(n,e){return Y(n,qe(void 0,e))}class ze extends q{constructor(e){var t;super(e),this.onDisabledChange_=this.onDisabledChange_.bind(this),this.onParentChange_=this.onParentChange_.bind(this),this.onParentGlobalDisabledChange_=this.onParentGlobalDisabledChange_.bind(this),[this.globalDisabled_,this.setGlobalDisabled_]=we.create(ee(this.getGlobalDisabled_())),this.value("disabled").emitter.on("change",this.onDisabledChange_),this.value("parent").emitter.on("change",this.onParentChange_),(t=this.get("parent"))===null||t===void 0||t.globalDisabled.emitter.on("change",this.onParentGlobalDisabledChange_)}static create(e){var t,l,b;const P=e??{};return new ze(q.createCore({disabled:(t=P.disabled)!==null&&t!==void 0?t:!1,disposed:!1,hidden:(l=P.hidden)!==null&&l!==void 0?l:!1,parent:(b=P.parent)!==null&&b!==void 0?b:null}))}get globalDisabled(){return this.globalDisabled_}bindClassModifiers(e){j(this.globalDisabled_,fn(e,"disabled")),F(this,"hidden",fn(e,"hidden"))}bindDisabled(e){j(this.globalDisabled_,t=>{e.disabled=t})}bindTabIndex(e){j(this.globalDisabled_,t=>{e.tabIndex=t?-1:0})}handleDispose(e){this.value("disposed").emitter.on("change",t=>{t&&e()})}getGlobalDisabled_(){const e=this.get("parent");return(e?e.globalDisabled.rawValue:!1)||this.get("disabled")}updateGlobalDisabled_(){this.setGlobalDisabled_(this.getGlobalDisabled_())}onDisabledChange_(){this.updateGlobalDisabled_()}onParentGlobalDisabledChange_(){this.updateGlobalDisabled_()}onParentChange_(e){var t;const l=e.previousRawValue;l==null||l.globalDisabled.emitter.off("change",this.onParentGlobalDisabledChange_),(t=this.get("parent"))===null||t===void 0||t.globalDisabled.emitter.on("change",this.onParentGlobalDisabledChange_),this.updateGlobalDisabled_()}}function vn(){return["veryfirst","first","last","verylast"]}const $t=N(""),nt={veryfirst:"vfst",first:"fst",last:"lst",verylast:"vlst"};class dt{constructor(e){this.parent_=null,this.blade=e.blade,this.view=e.view,this.viewProps=e.viewProps;const t=this.view.element;this.blade.value("positions").emitter.on("change",()=>{vn().forEach(l=>{t.classList.remove($t(void 0,nt[l]))}),this.blade.get("positions").forEach(l=>{t.classList.add($t(void 0,nt[l]))})}),this.viewProps.handleDispose(()=>{De(t)})}get parent(){return this.parent_}set parent(e){if(this.parent_=e,!("parent"in this.viewProps.valMap_)){Ae({key:"parent",target:ze.name,place:"BladeController.parent"});return}this.viewProps.set("parent",this.parent_?this.parent_.viewProps:null)}}const Ee="http://www.w3.org/2000/svg";function Qe(n){n.offsetHeight}function Xt(n,e){const t=n.style.transition;n.style.transition="none",e(),n.style.transition=t}function it(n){return n.ontouchstart!==void 0}function bn(){return globalThis}function Kn(){return bn().document}function gn(n){const e=n.ownerDocument.defaultView;return e&&"document"in e?n.getContext("2d",{willReadFrequently:!0}):null}const _n={check:'<path d="M2 8l4 4l8 -8"/>',dropdown:'<path d="M5 7h6l-3 3 z"/>',p2dpad:'<path d="M8 4v8"/><path d="M4 8h8"/><circle cx="12" cy="12" r="1.2"/>'};function at(n,e){const t=n.createElementNS(Ee,"svg");return t.innerHTML=_n[e],t}function mt(n,e,t){n.insertBefore(e,n.children[t])}function wn(n){n.parentElement&&n.parentElement.removeChild(n)}function Yt(n){for(;n.children.length>0;)n.removeChild(n.children[0])}function yn(n){for(;n.childNodes.length>0;)n.removeChild(n.childNodes[0])}function lt(n){return n.relatedTarget?n.relatedTarget:"explicitOriginalTarget"in n?n.explicitOriginalTarget:null}const st=N("lbl");function ft(n,e){const t=n.createDocumentFragment();return e.split(`
20
+ `).map(b=>n.createTextNode(b)).forEach((b,P)=>{P>0&&t.appendChild(n.createElement("br")),t.appendChild(b)}),t}class D{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(st()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(st("l")),F(t.props,"label",P=>{w(P)?this.element.classList.add(st(void 0,"nol")):(this.element.classList.remove(st(void 0,"nol")),yn(l),l.appendChild(ft(e,P)))}),this.element.appendChild(l),this.labelElement=l;const b=e.createElement("div");b.classList.add(st("v")),this.element.appendChild(b),this.valueElement=b}}class K extends dt{constructor(e,t){const l=t.valueController.viewProps;super(Object.assign(Object.assign({},t),{view:new D(e,{props:t.props,viewProps:l}),viewProps:l})),this.props=t.props,this.valueController=t.valueController,this.view.valueElement.appendChild(this.valueController.view.element)}}const J={id:"button",type:"blade",accept(n){const e=V,t=ce(n,{title:e.required.string,view:e.required.constant("button"),label:e.optional.string});return t?{params:t}:null},controller(n){return new K(n.document,{blade:n.blade,props:q.fromObject({label:n.params.label}),valueController:new pe(n.document,{props:q.fromObject({title:n.params.title}),viewProps:n.viewProps})})},api(n){return!(n.controller instanceof K)||!(n.controller.valueController instanceof pe)?null:new R(n.controller)}};class ie extends dt{constructor(e){super(e),this.value=e.value}}function ye(){return new q({positions:ee([],{equals:x})})}class Ve extends q{constructor(e){super(e)}static create(e){const t={completed:!0,expanded:e,expandedHeight:null,shouldFixHeight:!1,temporaryExpanded:null},l=q.createCore(t);return new Ve(l)}get styleExpanded(){var e;return(e=this.get("temporaryExpanded"))!==null&&e!==void 0?e:this.get("expanded")}get styleHeight(){if(!this.styleExpanded)return"0";const e=this.get("expandedHeight");return this.get("shouldFixHeight")&&!w(e)?`${e}px`:"auto"}bindExpandedClass(e,t){const l=()=>{this.styleExpanded?e.classList.add(t):e.classList.remove(t)};F(this,"expanded",l),F(this,"temporaryExpanded",l)}cleanUpTransition(){this.set("shouldFixHeight",!1),this.set("expandedHeight",null),this.set("completed",!0)}}function St(n,e){let t=0;return Xt(e,()=>{n.set("expandedHeight",null),n.set("temporaryExpanded",!0),Qe(e),t=e.clientHeight,n.set("temporaryExpanded",null),Qe(e)}),t}function qt(n,e){e.style.height=n.styleHeight}function Oe(n,e){n.value("expanded").emitter.on("beforechange",()=>{if(n.set("completed",!1),w(n.get("expandedHeight"))){const t=St(n,e);t>0&&n.set("expandedHeight",t)}n.set("shouldFixHeight",!0),Qe(e)}),n.emitter.on("change",()=>{qt(n,e)}),qt(n,e),e.addEventListener("transitionend",t=>{t.propertyName==="height"&&n.cleanUpTransition()})}class Be extends a{constructor(e,t){super(e),this.rackApi_=t}}function fs(n,e){return n.addBlade(Object.assign(Object.assign({},e),{view:"button"}))}function vs(n,e){return n.addBlade(Object.assign(Object.assign({},e),{view:"folder"}))}function bs(n,e){const t=e??{};return n.addBlade(Object.assign(Object.assign({},t),{view:"separator"}))}function $n(n,e){return n.addBlade(Object.assign(Object.assign({},e),{view:"tab"}))}class vt{constructor(e){this.emitter=new z,this.items_=[],this.cache_=new Set,this.onSubListAdd_=this.onSubListAdd_.bind(this),this.onSubListRemove_=this.onSubListRemove_.bind(this),this.extract_=e}get items(){return this.items_}allItems(){return Array.from(this.cache_)}find(e){for(const t of this.allItems())if(e(t))return t;return null}includes(e){return this.cache_.has(e)}add(e,t){if(this.includes(e))throw I.shouldNeverHappen();const l=t!==void 0?t:this.items_.length;this.items_.splice(l,0,e),this.cache_.add(e);const b=this.extract_(e);b&&(b.emitter.on("add",this.onSubListAdd_),b.emitter.on("remove",this.onSubListRemove_),b.allItems().forEach(P=>{this.cache_.add(P)})),this.emitter.emit("add",{index:l,item:e,root:this,target:this})}remove(e){const t=this.items_.indexOf(e);if(t<0)return;this.items_.splice(t,1),this.cache_.delete(e);const l=this.extract_(e);l&&(l.emitter.off("add",this.onSubListAdd_),l.emitter.off("remove",this.onSubListRemove_)),this.emitter.emit("remove",{index:t,item:e,root:this,target:this})}onSubListAdd_(e){this.cache_.add(e.item),this.emitter.emit("add",{index:e.index,item:e.item,root:this,target:e.target})}onSubListRemove_(e){this.cache_.delete(e.item),this.emitter.emit("remove",{index:e.index,item:e.item,root:this,target:e.target})}}class Xn extends a{constructor(e){super(e),this.onBindingChange_=this.onBindingChange_.bind(this),this.emitter_=new z,this.controller_.binding.emitter.on("change",this.onBindingChange_)}get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}refresh(){this.controller_.binding.read()}onBindingChange_(e){const t=e.sender.target.read();this.emitter_.emit("change",{event:new u(this,t,this.controller_.binding.target.presetKey,e.options.last)})}}class Te extends K{constructor(e,t){super(e,t),this.binding=t.binding}}class Yn extends a{constructor(e){super(e),this.onBindingUpdate_=this.onBindingUpdate_.bind(this),this.emitter_=new z,this.controller_.binding.emitter.on("update",this.onBindingUpdate_)}get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}refresh(){this.controller_.binding.read()}onBindingUpdate_(e){const t=e.sender.target.read();this.emitter_.emit("update",{event:new h(this,t,this.controller_.binding.target.presetKey)})}}class Ze extends K{constructor(e,t){super(e,t),this.binding=t.binding,this.viewProps.bindDisabled(this.binding.ticker),this.viewProps.handleDispose(()=>{this.binding.dispose()})}}function Mi(n){return n instanceof xn?n.apiSet_:n instanceof Be?n.rackApi_.apiSet_:null}function Qt(n,e){const t=n.find(l=>l.controller_===e);if(!t)throw I.shouldNeverHappen();return t}function ki(n,e,t){if(!E.isBindable(n))throw I.notBindable();return new E(n,e,t)}class xn extends a{constructor(e,t){super(e),this.onRackAdd_=this.onRackAdd_.bind(this),this.onRackRemove_=this.onRackRemove_.bind(this),this.onRackInputChange_=this.onRackInputChange_.bind(this),this.onRackMonitorUpdate_=this.onRackMonitorUpdate_.bind(this),this.emitter_=new z,this.apiSet_=new vt(Mi),this.pool_=t;const l=this.controller_.rack;l.emitter.on("add",this.onRackAdd_),l.emitter.on("remove",this.onRackRemove_),l.emitter.on("inputchange",this.onRackInputChange_),l.emitter.on("monitorupdate",this.onRackMonitorUpdate_),l.children.forEach(b=>{this.setUpApi_(b)})}get children(){return this.controller_.rack.children.map(e=>Qt(this.apiSet_,e))}addInput(e,t,l){const b=l??{},P=this.controller_.view.element.ownerDocument,L=this.pool_.createInput(P,ki(e,t,b.presetKey),b),U=new Xn(L);return this.add(U,b.index)}addMonitor(e,t,l){const b=l??{},P=this.controller_.view.element.ownerDocument,L=this.pool_.createMonitor(P,ki(e,t),b),U=new Yn(L);return this.add(U,b.index)}addFolder(e){return vs(this,e)}addButton(e){return fs(this,e)}addSeparator(e){return bs(this,e)}addTab(e){return $n(this,e)}add(e,t){this.controller_.rack.add(e.controller_,t);const l=this.apiSet_.find(b=>b.controller_===e.controller_);return l&&this.apiSet_.remove(l),this.apiSet_.add(e),e}remove(e){this.controller_.rack.remove(e.controller_)}addBlade(e){const t=this.controller_.view.element.ownerDocument,l=this.pool_.createBlade(t,e),b=this.pool_.createBladeApi(l);return this.add(b,e.index)}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}setUpApi_(e){this.apiSet_.find(l=>l.controller_===e)||this.apiSet_.add(this.pool_.createBladeApi(e))}onRackAdd_(e){this.setUpApi_(e.bladeController)}onRackRemove_(e){if(e.isRoot){const t=Qt(this.apiSet_,e.bladeController);this.apiSet_.remove(t)}}onRackInputChange_(e){const t=e.bladeController;if(t instanceof Te){const l=Qt(this.apiSet_,t),b=t.binding;this.emitter_.emit("change",{event:new u(l,b.target.read(),b.target.presetKey,e.options.last)})}else if(t instanceof ie){const l=Qt(this.apiSet_,t);this.emitter_.emit("change",{event:new u(l,t.value.rawValue,void 0,e.options.last)})}}onRackMonitorUpdate_(e){if(!(e.bladeController instanceof Ze))throw I.shouldNeverHappen();const t=Qt(this.apiSet_,e.bladeController),l=e.bladeController.binding;this.emitter_.emit("update",{event:new h(t,l.target.read(),l.target.presetKey)})}}class qn extends Be{constructor(e,t){super(e,new xn(e.rackController,t)),this.emitter_=new z,this.controller_.foldable.value("expanded").emitter.on("change",l=>{this.emitter_.emit("fold",{event:new d(this,l.sender.rawValue)})}),this.rackApi_.on("change",l=>{this.emitter_.emit("change",{event:l})}),this.rackApi_.on("update",l=>{this.emitter_.emit("update",{event:l})})}get expanded(){return this.controller_.foldable.get("expanded")}set expanded(e){this.controller_.foldable.set("expanded",e)}get title(){return this.controller_.props.get("title")}set title(e){this.controller_.props.set("title",e)}get children(){return this.rackApi_.children}addInput(e,t,l){return this.rackApi_.addInput(e,t,l)}addMonitor(e,t,l){return this.rackApi_.addMonitor(e,t,l)}addFolder(e){return this.rackApi_.addFolder(e)}addButton(e){return this.rackApi_.addButton(e)}addSeparator(e){return this.rackApi_.addSeparator(e)}addTab(e){return this.rackApi_.addTab(e)}add(e,t){return this.rackApi_.add(e,t)}remove(e){this.rackApi_.remove(e)}addBlade(e){return this.rackApi_.addBlade(e)}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}}class Qn extends dt{constructor(e){super({blade:e.blade,view:e.view,viewProps:e.rackController.viewProps}),this.rackController=e.rackController}}class gs{constructor(e,t){const l=N(t.viewName);this.element=e.createElement("div"),this.element.classList.add(l()),t.viewProps.bindClassModifiers(this.element)}}function _s(n,e){for(let t=0;t<n.length;t++){const l=n[t];if(l instanceof Te&&l.binding===e)return l}return null}function ws(n,e){for(let t=0;t<n.length;t++){const l=n[t];if(l instanceof Ze&&l.binding===e)return l}return null}function ys(n,e){for(let t=0;t<n.length;t++){const l=n[t];if(l instanceof ie&&l.value===e)return l}return null}function Zn(n){return n instanceof Zt?n.rack:n instanceof Qn?n.rackController.rack:null}function xs(n){const e=Zn(n);return e?e.bcSet_:null}class Cs{constructor(e){var t,l;this.onBladePositionsChange_=this.onBladePositionsChange_.bind(this),this.onSetAdd_=this.onSetAdd_.bind(this),this.onSetRemove_=this.onSetRemove_.bind(this),this.onChildDispose_=this.onChildDispose_.bind(this),this.onChildPositionsChange_=this.onChildPositionsChange_.bind(this),this.onChildInputChange_=this.onChildInputChange_.bind(this),this.onChildMonitorUpdate_=this.onChildMonitorUpdate_.bind(this),this.onChildValueChange_=this.onChildValueChange_.bind(this),this.onChildViewPropsChange_=this.onChildViewPropsChange_.bind(this),this.onDescendantLayout_=this.onDescendantLayout_.bind(this),this.onDescendantInputChange_=this.onDescendantInputChange_.bind(this),this.onDescendantMonitorUpdate_=this.onDescendantMonitorUpdate_.bind(this),this.emitter=new z,this.blade_=(t=e.blade)!==null&&t!==void 0?t:null,(l=this.blade_)===null||l===void 0||l.value("positions").emitter.on("change",this.onBladePositionsChange_),this.viewProps=e.viewProps,this.bcSet_=new vt(xs),this.bcSet_.emitter.on("add",this.onSetAdd_),this.bcSet_.emitter.on("remove",this.onSetRemove_)}get children(){return this.bcSet_.items}add(e,t){var l;(l=e.parent)===null||l===void 0||l.remove(e),M(e,"parent")?e.parent=this:(e.parent_=this,Ae({key:"parent",target:"BladeController",place:"BladeRack.add"})),this.bcSet_.add(e,t)}remove(e){M(e,"parent")?e.parent=null:(e.parent_=null,Ae({key:"parent",target:"BladeController",place:"BladeRack.remove"})),this.bcSet_.remove(e)}find(e){return this.bcSet_.allItems().filter(t=>t instanceof e)}onSetAdd_(e){this.updatePositions_();const t=e.target===e.root;if(this.emitter.emit("add",{bladeController:e.item,index:e.index,isRoot:t,sender:this}),!t)return;const l=e.item;if(l.viewProps.emitter.on("change",this.onChildViewPropsChange_),l.blade.value("positions").emitter.on("change",this.onChildPositionsChange_),l.viewProps.handleDispose(this.onChildDispose_),l instanceof Te)l.binding.emitter.on("change",this.onChildInputChange_);else if(l instanceof Ze)l.binding.emitter.on("update",this.onChildMonitorUpdate_);else if(l instanceof ie)l.value.emitter.on("change",this.onChildValueChange_);else{const b=Zn(l);if(b){const P=b.emitter;P.on("layout",this.onDescendantLayout_),P.on("inputchange",this.onDescendantInputChange_),P.on("monitorupdate",this.onDescendantMonitorUpdate_)}}}onSetRemove_(e){this.updatePositions_();const t=e.target===e.root;if(this.emitter.emit("remove",{bladeController:e.item,isRoot:t,sender:this}),!t)return;const l=e.item;if(l instanceof Te)l.binding.emitter.off("change",this.onChildInputChange_);else if(l instanceof Ze)l.binding.emitter.off("update",this.onChildMonitorUpdate_);else if(l instanceof ie)l.value.emitter.off("change",this.onChildValueChange_);else{const b=Zn(l);if(b){const P=b.emitter;P.off("layout",this.onDescendantLayout_),P.off("inputchange",this.onDescendantInputChange_),P.off("monitorupdate",this.onDescendantMonitorUpdate_)}}}updatePositions_(){const e=this.bcSet_.items.filter(b=>!b.viewProps.get("hidden")),t=e[0],l=e[e.length-1];this.bcSet_.items.forEach(b=>{const P=[];b===t&&(P.push("first"),(!this.blade_||this.blade_.get("positions").includes("veryfirst"))&&P.push("veryfirst")),b===l&&(P.push("last"),(!this.blade_||this.blade_.get("positions").includes("verylast"))&&P.push("verylast")),b.blade.set("positions",P)})}onChildPositionsChange_(){this.updatePositions_(),this.emitter.emit("layout",{sender:this})}onChildViewPropsChange_(e){this.updatePositions_(),this.emitter.emit("layout",{sender:this})}onChildDispose_(){this.bcSet_.items.filter(t=>t.viewProps.get("disposed")).forEach(t=>{this.bcSet_.remove(t)})}onChildInputChange_(e){const t=_s(this.find(Te),e.sender);if(!t)throw I.alreadyDisposed();this.emitter.emit("inputchange",{bladeController:t,options:e.options,sender:this})}onChildMonitorUpdate_(e){const t=ws(this.find(Ze),e.sender);if(!t)throw I.alreadyDisposed();this.emitter.emit("monitorupdate",{bladeController:t,sender:this})}onChildValueChange_(e){const t=ys(this.find(ie),e.sender);if(!t)throw I.alreadyDisposed();this.emitter.emit("inputchange",{bladeController:t,options:e.options,sender:this})}onDescendantLayout_(e){this.updatePositions_(),this.emitter.emit("layout",{sender:this})}onDescendantInputChange_(e){this.emitter.emit("inputchange",{bladeController:e.bladeController,options:e.options,sender:this})}onDescendantMonitorUpdate_(e){this.emitter.emit("monitorupdate",{bladeController:e.bladeController,sender:this})}onBladePositionsChange_(){this.updatePositions_()}}class Zt extends dt{constructor(e,t){super(Object.assign(Object.assign({},t),{view:new gs(e,{viewName:"brk",viewProps:t.viewProps})})),this.onRackAdd_=this.onRackAdd_.bind(this),this.onRackRemove_=this.onRackRemove_.bind(this);const l=new Cs({blade:t.root?void 0:t.blade,viewProps:t.viewProps});l.emitter.on("add",this.onRackAdd_),l.emitter.on("remove",this.onRackRemove_),this.rack=l,this.viewProps.handleDispose(()=>{for(let b=this.rack.children.length-1;b>=0;b--)this.rack.children[b].viewProps.set("disposed",!0)})}onRackAdd_(e){e.isRoot&&mt(this.view.element,e.bladeController.view.element,e.index)}onRackRemove_(e){e.isRoot&&wn(e.bladeController.view.element)}}const Si=N("cnt");class Ps{constructor(e,t){var l;this.className_=N((l=t.viewName)!==null&&l!==void 0?l:"fld"),this.element=e.createElement("div"),this.element.classList.add(this.className_(),Si()),t.viewProps.bindClassModifiers(this.element),this.foldable_=t.foldable,this.foldable_.bindExpandedClass(this.element,this.className_(void 0,"expanded")),F(this.foldable_,"completed",Y(this.element,this.className_(void 0,"cpl")));const b=e.createElement("button");b.classList.add(this.className_("b")),F(t.props,"title",H=>{w(H)?this.element.classList.add(this.className_(void 0,"not")):this.element.classList.remove(this.className_(void 0,"not"))}),t.viewProps.bindDisabled(b),this.element.appendChild(b),this.buttonElement=b;const P=e.createElement("div");P.classList.add(this.className_("i")),this.element.appendChild(P);const L=e.createElement("div");L.classList.add(this.className_("t")),Z(t.props.value("title"),L),this.buttonElement.appendChild(L),this.titleElement=L;const U=e.createElement("div");U.classList.add(this.className_("m")),this.buttonElement.appendChild(U);const W=t.containerElement;W.classList.add(this.className_("c")),this.element.appendChild(W),this.containerElement=W}}class Cn extends Qn{constructor(e,t){var l;const b=Ve.create((l=t.expanded)!==null&&l!==void 0?l:!0),P=new Zt(e,{blade:t.blade,root:t.root,viewProps:t.viewProps});super(Object.assign(Object.assign({},t),{rackController:P,view:new Ps(e,{containerElement:P.view.element,foldable:b,props:t.props,viewName:t.root?"rot":void 0,viewProps:t.viewProps})})),this.onTitleClick_=this.onTitleClick_.bind(this),this.props=t.props,this.foldable=b,Oe(this.foldable,this.view.containerElement),this.rackController.rack.emitter.on("add",()=>{this.foldable.cleanUpTransition()}),this.rackController.rack.emitter.on("remove",()=>{this.foldable.cleanUpTransition()}),this.view.buttonElement.addEventListener("click",this.onTitleClick_)}get document(){return this.view.element.ownerDocument}onTitleClick_(){this.foldable.set("expanded",!this.foldable.get("expanded"))}}const Ms={id:"folder",type:"blade",accept(n){const e=V,t=ce(n,{title:e.required.string,view:e.required.constant("folder"),expanded:e.optional.boolean});return t?{params:t}:null},controller(n){return new Cn(n.document,{blade:n.blade,expanded:n.params.expanded,props:q.fromObject({title:n.params.title}),viewProps:n.viewProps})},api(n){return n.controller instanceof Cn?new qn(n.controller,n.pool):null}};class Lt extends ie{constructor(e,t){const l=t.valueController.viewProps;super(Object.assign(Object.assign({},t),{value:t.valueController.value,view:new D(e,{props:t.props,viewProps:l}),viewProps:l})),this.props=t.props,this.valueController=t.valueController,this.view.valueElement.appendChild(this.valueController.view.element)}}class Li extends a{}const Wn=N("spr");class ks{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(Wn()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("hr");l.classList.add(Wn("r")),this.element.appendChild(l)}}class Wt extends dt{constructor(e,t){super(Object.assign(Object.assign({},t),{view:new ks(e,{viewProps:t.viewProps})}))}}const Ss={id:"separator",type:"blade",accept(n){const t=ce(n,{view:V.required.constant("separator")});return t?{params:t}:null},controller(n){return new Wt(n.document,{blade:n.blade,viewProps:n.viewProps})},api(n){return n.controller instanceof Wt?new Li(n.controller):null}},Se=N("tbi");class Ls{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(Se()),t.viewProps.bindClassModifiers(this.element),F(t.props,"selected",P=>{P?this.element.classList.add(Se(void 0,"sel")):this.element.classList.remove(Se(void 0,"sel"))});const l=e.createElement("button");l.classList.add(Se("b")),t.viewProps.bindDisabled(l),this.element.appendChild(l),this.buttonElement=l;const b=e.createElement("div");b.classList.add(Se("t")),Z(t.props.value("title"),b),this.buttonElement.appendChild(b),this.titleElement=b}}class Pn{constructor(e,t){this.emitter=new z,this.onClick_=this.onClick_.bind(this),this.props=t.props,this.viewProps=t.viewProps,this.view=new Ls(e,{props:t.props,viewProps:t.viewProps}),this.view.buttonElement.addEventListener("click",this.onClick_)}onClick_(){this.emitter.emit("click",{sender:this})}}class Ai{constructor(e,t){this.onItemClick_=this.onItemClick_.bind(this),this.ic_=new Pn(e,{props:t.itemProps,viewProps:ze.create()}),this.ic_.emitter.on("click",this.onItemClick_),this.cc_=new Zt(e,{blade:ye(),viewProps:ze.create()}),this.props=t.props,F(this.props,"selected",l=>{this.itemController.props.set("selected",l),this.contentController.viewProps.set("hidden",!l)})}get itemController(){return this.ic_}get contentController(){return this.cc_}onItemClick_(){this.props.set("selected",!0)}}class Jn{constructor(e,t){this.controller_=e,this.rackApi_=t}get title(){var e;return(e=this.controller_.itemController.props.get("title"))!==null&&e!==void 0?e:""}set title(e){this.controller_.itemController.props.set("title",e)}get selected(){return this.controller_.props.get("selected")}set selected(e){this.controller_.props.set("selected",e)}get children(){return this.rackApi_.children}addButton(e){return this.rackApi_.addButton(e)}addFolder(e){return this.rackApi_.addFolder(e)}addSeparator(e){return this.rackApi_.addSeparator(e)}addTab(e){return this.rackApi_.addTab(e)}add(e,t){this.rackApi_.add(e,t)}remove(e){this.rackApi_.remove(e)}addInput(e,t,l){return this.rackApi_.addInput(e,t,l)}addMonitor(e,t,l){return this.rackApi_.addMonitor(e,t,l)}addBlade(e){return this.rackApi_.addBlade(e)}}class Vi extends Be{constructor(e,t){super(e,new xn(e.rackController,t)),this.onPageAdd_=this.onPageAdd_.bind(this),this.onPageRemove_=this.onPageRemove_.bind(this),this.onSelect_=this.onSelect_.bind(this),this.emitter_=new z,this.pageApiMap_=new Map,this.rackApi_.on("change",l=>{this.emitter_.emit("change",{event:l})}),this.rackApi_.on("update",l=>{this.emitter_.emit("update",{event:l})}),this.controller_.tab.selectedIndex.emitter.on("change",this.onSelect_),this.controller_.pageSet.emitter.on("add",this.onPageAdd_),this.controller_.pageSet.emitter.on("remove",this.onPageRemove_),this.controller_.pageSet.items.forEach(l=>{this.setUpPageApi_(l)})}get pages(){return this.controller_.pageSet.items.map(e=>{const t=this.pageApiMap_.get(e);if(!t)throw I.shouldNeverHappen();return t})}addPage(e){const t=this.controller_.view.element.ownerDocument,l=new Ai(t,{itemProps:q.fromObject({selected:!1,title:e.title}),props:q.fromObject({selected:!1})});this.controller_.add(l,e.index);const b=this.pageApiMap_.get(l);if(!b)throw I.shouldNeverHappen();return b}removePage(e){this.controller_.remove(e)}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}setUpPageApi_(e){const t=this.rackApi_.apiSet_.find(b=>b.controller_===e.contentController);if(!t)throw I.shouldNeverHappen();const l=new Jn(e,t);this.pageApiMap_.set(e,l)}onPageAdd_(e){this.setUpPageApi_(e.item)}onPageRemove_(e){if(!this.pageApiMap_.get(e.item))throw I.shouldNeverHappen();this.pageApiMap_.delete(e.item)}onSelect_(e){this.emitter_.emit("select",{event:new _(this,e.rawValue)})}}const Ii=-1;class As{constructor(){this.onItemSelectedChange_=this.onItemSelectedChange_.bind(this),this.empty=ee(!0),this.selectedIndex=ee(Ii),this.items_=[]}add(e,t){const l=t??this.items_.length;this.items_.splice(l,0,e),e.emitter.on("change",this.onItemSelectedChange_),this.keepSelection_()}remove(e){const t=this.items_.indexOf(e);t<0||(this.items_.splice(t,1),e.emitter.off("change",this.onItemSelectedChange_),this.keepSelection_())}keepSelection_(){if(this.items_.length===0){this.selectedIndex.rawValue=Ii,this.empty.rawValue=!0;return}const e=this.items_.findIndex(t=>t.rawValue);e<0?(this.items_.forEach((t,l)=>{t.rawValue=l===0}),this.selectedIndex.rawValue=0):(this.items_.forEach((t,l)=>{t.rawValue=l===e}),this.selectedIndex.rawValue=e),this.empty.rawValue=!1}onItemSelectedChange_(e){if(e.rawValue){const t=this.items_.findIndex(l=>l===e.sender);this.items_.forEach((l,b)=>{l.rawValue=b===t}),this.selectedIndex.rawValue=t}else this.keepSelection_()}}const At=N("tab");class Vt{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(At(),Si()),t.viewProps.bindClassModifiers(this.element),j(t.empty,Y(this.element,At(void 0,"nop")));const l=e.createElement("div");l.classList.add(At("t")),this.element.appendChild(l),this.itemsElement=l;const b=e.createElement("div");b.classList.add(At("i")),this.element.appendChild(b);const P=t.contentsElement;P.classList.add(At("c")),this.element.appendChild(P),this.contentsElement=P}}class Jt extends Qn{constructor(e,t){const l=new Zt(e,{blade:t.blade,viewProps:t.viewProps}),b=new As;super({blade:t.blade,rackController:l,view:new Vt(e,{contentsElement:l.view.element,empty:b.empty,viewProps:t.viewProps})}),this.onPageAdd_=this.onPageAdd_.bind(this),this.onPageRemove_=this.onPageRemove_.bind(this),this.pageSet_=new vt(()=>null),this.pageSet_.emitter.on("add",this.onPageAdd_),this.pageSet_.emitter.on("remove",this.onPageRemove_),this.tab=b}get pageSet(){return this.pageSet_}add(e,t){this.pageSet_.add(e,t)}remove(e){this.pageSet_.remove(this.pageSet_.items[e])}onPageAdd_(e){const t=e.item;mt(this.view.itemsElement,t.itemController.view.element,e.index),t.itemController.viewProps.set("parent",this.viewProps),this.rackController.rack.add(t.contentController,e.index),this.tab.add(t.props.value("selected"))}onPageRemove_(e){const t=e.item;wn(t.itemController.view.element),t.itemController.viewProps.set("parent",null),this.rackController.rack.remove(t.contentController),this.tab.remove(t.props.value("selected"))}}const Hn={id:"tab",type:"blade",accept(n){const e=V,t=ce(n,{pages:e.required.array(e.required.object({title:e.required.string})),view:e.required.constant("tab")});return!t||t.pages.length===0?null:{params:t}},controller(n){const e=new Jt(n.document,{blade:n.blade,viewProps:n.viewProps});return n.params.pages.forEach(t=>{const l=new Ai(n.document,{itemProps:q.fromObject({selected:!1,title:t.title}),props:q.fromObject({selected:!1})});e.add(l)}),e},api(n){return n.controller instanceof Jt?new Vi(n.controller,n.pool):null}};function Vs(n,e){const t=n.accept(e.params);if(!t)return null;const l=V.optional.boolean(e.params.disabled).value,b=V.optional.boolean(e.params.hidden).value;return n.controller({blade:ye(),document:e.document,params:Object.assign(Object.assign({},t.params),{disabled:l,hidden:b}),viewProps:ze.create({disabled:l,hidden:b})})}class Di{constructor(){this.disabled=!1,this.emitter=new z}dispose(){}tick(){this.disabled||this.emitter.emit("tick",{sender:this})}}class ei{constructor(e,t){this.disabled_=!1,this.timerId_=null,this.onTick_=this.onTick_.bind(this),this.doc_=e,this.emitter=new z,this.interval_=t,this.setTimer_()}get disabled(){return this.disabled_}set disabled(e){this.disabled_=e,this.disabled_?this.clearTimer_():this.setTimer_()}dispose(){this.clearTimer_()}clearTimer_(){if(this.timerId_===null)return;const e=this.doc_.defaultView;e&&e.clearInterval(this.timerId_),this.timerId_=null}setTimer_(){if(this.clearTimer_(),this.interval_<=0)return;const e=this.doc_.defaultView;e&&(this.timerId_=e.setInterval(this.onTick_,this.interval_))}onTick_(){this.disabled_||this.emitter.emit("tick",{sender:this})}}class Mn{constructor(e){this.onValueChange_=this.onValueChange_.bind(this),this.reader=e.reader,this.writer=e.writer,this.emitter=new z,this.value=e.value,this.value.emitter.on("change",this.onValueChange_),this.target=e.target,this.read()}read(){const e=this.target.read();e!==void 0&&(this.value.rawValue=this.reader(e))}write_(e){this.writer(this.target,e)}onValueChange_(e){this.write_(e.rawValue),this.emitter.emit("change",{options:e.options,rawValue:e.rawValue,sender:this})}}function Pe(n,e){for(;n.length<e;)n.push(void 0)}function Ti(n){const e=[];return Pe(e,n),ee(e)}function It(n){const e=n.indexOf(void 0);return e<0?n:n.slice(0,e)}function Ue(n,e){const t=[...It(n),e];return t.length>n.length?t.splice(0,t.length-n.length):Pe(t,n.length),t}class Is{constructor(e){this.onTick_=this.onTick_.bind(this),this.reader_=e.reader,this.target=e.target,this.emitter=new z,this.value=e.value,this.ticker=e.ticker,this.ticker.emitter.on("tick",this.onTick_),this.read()}dispose(){this.ticker.dispose()}read(){const e=this.target.read();if(e===void 0)return;const t=this.value.rawValue,l=this.reader_(e);this.value.rawValue=Ue(t,l),this.emitter.emit("update",{rawValue:l,sender:this})}onTick_(e){this.read()}}class Ht{constructor(e){this.constraints=e}constrain(e){return this.constraints.reduce((t,l)=>l.constrain(t),e)}}function $e(n,e){if(n instanceof e)return n;if(n instanceof Ht){const t=n.constraints.reduce((l,b)=>l||(b instanceof e?b:null),null);if(t)return t}return null}class Dt{constructor(e){this.values=q.fromObject({max:e.max,min:e.min})}constrain(e){const t=this.values.get("max"),l=this.values.get("min");return Math.min(Math.max(e,l),t)}}class en{constructor(e){this.values=q.fromObject({options:e})}get options(){return this.values.get("options")}constrain(e){const t=this.values.get("options");return t.length===0||t.filter(b=>b.value===e).length>0?e:t[0].value}}class ti{constructor(e){this.values=q.fromObject({max:e.max,min:e.min})}get maxValue(){return this.values.get("max")}get minValue(){return this.values.get("min")}constrain(e){const t=this.values.get("max"),l=this.values.get("min");let b=e;return w(l)||(b=Math.max(b,l)),w(t)||(b=Math.min(b,t)),b}}class kn{constructor(e,t=0){this.step=e,this.origin=t}constrain(e){const t=this.origin%this.step,l=Math.round((e-t)/this.step);return t+l*this.step}}const Tt=N("lst");class Ei{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),this.props_=t.props,this.element=e.createElement("div"),this.element.classList.add(Tt()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("select");l.classList.add(Tt("s")),F(this.props_,"options",P=>{Yt(l),P.forEach((L,U)=>{const W=e.createElement("option");W.dataset.index=String(U),W.textContent=L.text,W.value=String(L.value),l.appendChild(W)})}),t.viewProps.bindDisabled(l),this.element.appendChild(l),this.selectElement=l;const b=e.createElement("div");b.classList.add(Tt("m")),b.appendChild(at(e,"dropdown")),this.element.appendChild(b),t.value.emitter.on("change",this.onValueChange_),this.value_=t.value,this.update_()}update_(){this.selectElement.value=String(this.value_.rawValue)}onValueChange_(){this.update_()}}class tn{constructor(e,t){this.onSelectChange_=this.onSelectChange_.bind(this),this.props=t.props,this.value=t.value,this.viewProps=t.viewProps,this.view=new Ei(e,{props:this.props,value:this.value,viewProps:this.viewProps}),this.view.selectElement.addEventListener("change",this.onSelectChange_)}onSelectChange_(e){const l=e.currentTarget.selectedOptions.item(0);if(!l)return;const b=Number(l.dataset.index);this.value.rawValue=this.props.get("options")[b].value}}const Oi=N("pop");class Ds{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(Oi()),t.viewProps.bindClassModifiers(this.element),j(t.shows,Y(this.element,Oi(void 0,"v")))}}class Bi{constructor(e,t){this.shows=ee(!1),this.viewProps=t.viewProps,this.view=new Ds(e,{shows:this.shows,viewProps:this.viewProps})}}const Ni=N("txt");class Ts{constructor(e,t){this.onChange_=this.onChange_.bind(this),this.element=e.createElement("div"),this.element.classList.add(Ni()),t.viewProps.bindClassModifiers(this.element),this.props_=t.props,this.props_.emitter.on("change",this.onChange_);const l=e.createElement("input");l.classList.add(Ni("i")),l.type="text",t.viewProps.bindDisabled(l),this.element.appendChild(l),this.inputElement=l,t.value.emitter.on("change",this.onChange_),this.value_=t.value,this.refresh()}refresh(){const e=this.props_.get("formatter");this.inputElement.value=e(this.value_.rawValue)}onChange_(){this.refresh()}}class Sn{constructor(e,t){this.onInputChange_=this.onInputChange_.bind(this),this.parser_=t.parser,this.props=t.props,this.value=t.value,this.viewProps=t.viewProps,this.view=new Ts(e,{props:t.props,value:this.value,viewProps:this.viewProps}),this.view.inputElement.addEventListener("change",this.onInputChange_)}onInputChange_(e){const l=e.currentTarget.value,b=this.parser_(l);w(b)||(this.value.rawValue=b),this.view.refresh()}}function Es(n){return String(n)}function Fi(n){return n==="false"?!1:!!n}function ji(n){return Es(n)}class Os{constructor(e){this.text=e}evaluate(){return Number(this.text)}toString(){return this.text}}const Bs={"**":(n,e)=>Math.pow(n,e),"*":(n,e)=>n*e,"/":(n,e)=>n/e,"%":(n,e)=>n%e,"+":(n,e)=>n+e,"-":(n,e)=>n-e,"<<":(n,e)=>n<<e,">>":(n,e)=>n>>e,">>>":(n,e)=>n>>>e,"&":(n,e)=>n&e,"^":(n,e)=>n^e,"|":(n,e)=>n|e};class Ns{constructor(e,t,l){this.left=t,this.operator=e,this.right=l}evaluate(){const e=Bs[this.operator];if(!e)throw new Error(`unexpected binary operator: '${this.operator}`);return e(this.left.evaluate(),this.right.evaluate())}toString(){return["b(",this.left.toString(),this.operator,this.right.toString(),")"].join(" ")}}const zi={"+":n=>n,"-":n=>-n,"~":n=>~n};class Fs{constructor(e,t){this.operator=e,this.expression=t}evaluate(){const e=zi[this.operator];if(!e)throw new Error(`unexpected unary operator: '${this.operator}`);return e(this.expression.evaluate())}toString(){return["u(",this.operator,this.expression.toString(),")"].join(" ")}}function ni(n){return(e,t)=>{for(let l=0;l<n.length;l++){const b=n[l](e,t);if(b!=="")return b}return""}}function bt(n,e){var t;const l=n.substr(e).match(/^\s+/);return(t=l&&l[0])!==null&&t!==void 0?t:""}function js(n,e){const t=n.substr(e,1);return t.match(/^[1-9]$/)?t:""}function nn(n,e){var t;const l=n.substr(e).match(/^[0-9]+/);return(t=l&&l[0])!==null&&t!==void 0?t:""}function zs(n,e){const t=nn(n,e);if(t!=="")return t;const l=n.substr(e,1);if(e+=1,l!=="-"&&l!=="+")return"";const b=nn(n,e);return b===""?"":l+b}function We(n,e){const t=n.substr(e,1);if(e+=1,t.toLowerCase()!=="e")return"";const l=zs(n,e);return l===""?"":t+l}function Ui(n,e){const t=n.substr(e,1);if(t==="0")return t;const l=js(n,e);return e+=l.length,l===""?"":l+nn(n,e)}function Us(n,e){const t=Ui(n,e);if(e+=t.length,t==="")return"";const l=n.substr(e,1);if(e+=l.length,l!==".")return"";const b=nn(n,e);return e+=b.length,t+l+b+We(n,e)}function Ri(n,e){const t=n.substr(e,1);if(e+=t.length,t!==".")return"";const l=nn(n,e);return e+=l.length,l===""?"":t+l+We(n,e)}function Rs(n,e){const t=Ui(n,e);return e+=t.length,t===""?"":t+We(n,e)}const Gi=ni([Us,Ri,Rs]);function ii(n,e){var t;const l=n.substr(e).match(/^[01]+/);return(t=l&&l[0])!==null&&t!==void 0?t:""}function Gs(n,e){const t=n.substr(e,2);if(e+=t.length,t.toLowerCase()!=="0b")return"";const l=ii(n,e);return l===""?"":t+l}function Ki(n,e){var t;const l=n.substr(e).match(/^[0-7]+/);return(t=l&&l[0])!==null&&t!==void 0?t:""}function Re(n,e){const t=n.substr(e,2);if(e+=t.length,t.toLowerCase()!=="0o")return"";const l=Ki(n,e);return l===""?"":t+l}function Ks(n,e){var t;const l=n.substr(e).match(/^[0-9a-f]+/i);return(t=l&&l[0])!==null&&t!==void 0?t:""}function $s(n,e){const t=n.substr(e,2);if(e+=t.length,t.toLowerCase()!=="0x")return"";const l=Ks(n,e);return l===""?"":t+l}const si=ni([Gs,Re,$s]),Xs=ni([si,Gi]);function ct(n,e){const t=Xs(n,e);return e+=t.length,t===""?null:{evaluable:new Os(t),cursor:e}}function ri(n,e){const t=n.substr(e,1);if(e+=t.length,t!=="(")return null;const l=Ln(n,e);if(!l)return null;e=l.cursor,e+=bt(n,e).length;const b=n.substr(e,1);return e+=b.length,b!==")"?null:{evaluable:l.evaluable,cursor:e}}function Ys(n,e){var t;return(t=ct(n,e))!==null&&t!==void 0?t:ri(n,e)}function oi(n,e){const t=Ys(n,e);if(t)return t;const l=n.substr(e,1);if(e+=l.length,l!=="+"&&l!=="-"&&l!=="~")return null;const b=oi(n,e);return b?(e=b.cursor,{cursor:e,evaluable:new Fs(l,b.evaluable)}):null}function qs(n,e,t){t+=bt(e,t).length;const l=n.filter(b=>e.startsWith(b,t))[0];return l?(t+=l.length,t+=bt(e,t).length,{cursor:t,operator:l}):null}function gt(n,e){return(t,l)=>{const b=n(t,l);if(!b)return null;l=b.cursor;let P=b.evaluable;for(;;){const L=qs(e,t,l);if(!L)break;l=L.cursor;const U=n(t,l);if(!U)return null;l=U.cursor,P=new Ns(L.operator,P,U.evaluable)}return P?{cursor:l,evaluable:P}:null}}const $i=[["**"],["*","/","%"],["+","-"],["<<",">>>",">>"],["&"],["^"],["|"]].reduce((n,e)=>gt(n,e),oi);function Ln(n,e){return e+=bt(n,e).length,$i(n,e)}function Xi(n){const e=Ln(n,0);return!e||e.cursor+bt(n,e.cursor).length!==n.length?null:e.evaluable}function Je(n){var e;const t=Xi(n);return(e=t==null?void 0:t.evaluate())!==null&&e!==void 0?e:null}function rt(n){if(typeof n=="number")return n;if(typeof n=="string"){const e=Je(n);if(!w(e))return e}return 0}function Qs(n){return String(n)}function Le(n){return e=>e.toFixed(Math.max(Math.min(n,20),0))}const Yi=Le(0);function sn(n){return Yi(n)+"%"}function ai(n){return String(n)}function pt(n){return n}function Et({primary:n,secondary:e,forward:t,backward:l}){let b=!1;function P(L){b||(b=!0,L(),b=!1)}n.emitter.on("change",L=>{P(()=>{e.setRawValue(t(n,e),L.options)})}),e.emitter.on("change",L=>{P(()=>{n.setRawValue(l(n,e),L.options)}),P(()=>{e.setRawValue(t(n,e),L.options)})}),P(()=>{e.setRawValue(t(n,e),{forceEmit:!1,last:!0})})}function Ie(n,e){const t=n*(e.altKey?.1:1)*(e.shiftKey?10:1);return e.upKey?+t:e.downKey?-t:0}function rn(n){return{altKey:n.altKey,downKey:n.key==="ArrowDown",shiftKey:n.shiftKey,upKey:n.key==="ArrowUp"}}function He(n){return{altKey:n.altKey,downKey:n.key==="ArrowLeft",shiftKey:n.shiftKey,upKey:n.key==="ArrowRight"}}function qi(n){return n==="ArrowUp"||n==="ArrowDown"}function An(n){return qi(n)||n==="ArrowLeft"||n==="ArrowRight"}function li(n,e){var t,l;const b=e.ownerDocument.defaultView,P=e.getBoundingClientRect();return{x:n.pageX-(((t=b&&b.scrollX)!==null&&t!==void 0?t:0)+P.left),y:n.pageY-(((l=b&&b.scrollY)!==null&&l!==void 0?l:0)+P.top)}}class _t{constructor(e){this.lastTouch_=null,this.onDocumentMouseMove_=this.onDocumentMouseMove_.bind(this),this.onDocumentMouseUp_=this.onDocumentMouseUp_.bind(this),this.onMouseDown_=this.onMouseDown_.bind(this),this.onTouchEnd_=this.onTouchEnd_.bind(this),this.onTouchMove_=this.onTouchMove_.bind(this),this.onTouchStart_=this.onTouchStart_.bind(this),this.elem_=e,this.emitter=new z,e.addEventListener("touchstart",this.onTouchStart_,{passive:!1}),e.addEventListener("touchmove",this.onTouchMove_,{passive:!0}),e.addEventListener("touchend",this.onTouchEnd_),e.addEventListener("mousedown",this.onMouseDown_)}computePosition_(e){const t=this.elem_.getBoundingClientRect();return{bounds:{width:t.width,height:t.height},point:e?{x:e.x,y:e.y}:null}}onMouseDown_(e){var t;e.preventDefault(),(t=e.currentTarget)===null||t===void 0||t.focus();const l=this.elem_.ownerDocument;l.addEventListener("mousemove",this.onDocumentMouseMove_),l.addEventListener("mouseup",this.onDocumentMouseUp_),this.emitter.emit("down",{altKey:e.altKey,data:this.computePosition_(li(e,this.elem_)),sender:this,shiftKey:e.shiftKey})}onDocumentMouseMove_(e){this.emitter.emit("move",{altKey:e.altKey,data:this.computePosition_(li(e,this.elem_)),sender:this,shiftKey:e.shiftKey})}onDocumentMouseUp_(e){const t=this.elem_.ownerDocument;t.removeEventListener("mousemove",this.onDocumentMouseMove_),t.removeEventListener("mouseup",this.onDocumentMouseUp_),this.emitter.emit("up",{altKey:e.altKey,data:this.computePosition_(li(e,this.elem_)),sender:this,shiftKey:e.shiftKey})}onTouchStart_(e){e.preventDefault();const t=e.targetTouches.item(0),l=this.elem_.getBoundingClientRect();this.emitter.emit("down",{altKey:e.altKey,data:this.computePosition_(t?{x:t.clientX-l.left,y:t.clientY-l.top}:void 0),sender:this,shiftKey:e.shiftKey}),this.lastTouch_=t}onTouchMove_(e){const t=e.targetTouches.item(0),l=this.elem_.getBoundingClientRect();this.emitter.emit("move",{altKey:e.altKey,data:this.computePosition_(t?{x:t.clientX-l.left,y:t.clientY-l.top}:void 0),sender:this,shiftKey:e.shiftKey}),this.lastTouch_=t}onTouchEnd_(e){var t;const l=(t=e.targetTouches.item(0))!==null&&t!==void 0?t:this.lastTouch_,b=this.elem_.getBoundingClientRect();this.emitter.emit("up",{altKey:e.altKey,data:this.computePosition_(l?{x:l.clientX-b.left,y:l.clientY-b.top}:void 0),sender:this,shiftKey:e.shiftKey})}}function _e(n,e,t,l,b){const P=(n-e)/(t-e);return l+P*(b-l)}function ci(n){return String(n.toFixed(10)).split(".")[1].replace(/0+$/,"").length}function Me(n,e,t){return Math.min(Math.max(n,e),t)}function Ot(n,e){return(n%e+e)%e}const Ne=N("txt");class pi{constructor(e,t){this.onChange_=this.onChange_.bind(this),this.props_=t.props,this.props_.emitter.on("change",this.onChange_),this.element=e.createElement("div"),this.element.classList.add(Ne(),Ne(void 0,"num")),t.arrayPosition&&this.element.classList.add(Ne(void 0,t.arrayPosition)),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("input");l.classList.add(Ne("i")),l.type="text",t.viewProps.bindDisabled(l),this.element.appendChild(l),this.inputElement=l,this.onDraggingChange_=this.onDraggingChange_.bind(this),this.dragging_=t.dragging,this.dragging_.emitter.on("change",this.onDraggingChange_),this.element.classList.add(Ne()),this.inputElement.classList.add(Ne("i"));const b=e.createElement("div");b.classList.add(Ne("k")),this.element.appendChild(b),this.knobElement=b;const P=e.createElementNS(Ee,"svg");P.classList.add(Ne("g")),this.knobElement.appendChild(P);const L=e.createElementNS(Ee,"path");L.classList.add(Ne("gb")),P.appendChild(L),this.guideBodyElem_=L;const U=e.createElementNS(Ee,"path");U.classList.add(Ne("gh")),P.appendChild(U),this.guideHeadElem_=U;const W=e.createElement("div");W.classList.add(N("tt")()),this.knobElement.appendChild(W),this.tooltipElem_=W,t.value.emitter.on("change",this.onChange_),this.value=t.value,this.refresh()}onDraggingChange_(e){if(e.rawValue===null){this.element.classList.remove(Ne(void 0,"drg"));return}this.element.classList.add(Ne(void 0,"drg"));const t=e.rawValue/this.props_.get("draggingScale"),l=t+(t>0?-1:t<0?1:0),b=Me(-l,-4,4);this.guideHeadElem_.setAttributeNS(null,"d",[`M ${l+b},0 L${l},4 L${l+b},8`,`M ${t},-1 L${t},9`].join(" ")),this.guideBodyElem_.setAttributeNS(null,"d",`M 0,4 L${t},4`);const P=this.props_.get("formatter");this.tooltipElem_.textContent=P(this.value.rawValue),this.tooltipElem_.style.left=`${t}px`}refresh(){const e=this.props_.get("formatter");this.inputElement.value=e(this.value.rawValue)}onChange_(){this.refresh()}}class on{constructor(e,t){var l;this.originRawValue_=0,this.onInputChange_=this.onInputChange_.bind(this),this.onInputKeyDown_=this.onInputKeyDown_.bind(this),this.onInputKeyUp_=this.onInputKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.baseStep_=t.baseStep,this.parser_=t.parser,this.props=t.props,this.sliderProps_=(l=t.sliderProps)!==null&&l!==void 0?l:null,this.value=t.value,this.viewProps=t.viewProps,this.dragging_=ee(null),this.view=new pi(e,{arrayPosition:t.arrayPosition,dragging:this.dragging_,props:this.props,value:this.value,viewProps:this.viewProps}),this.view.inputElement.addEventListener("change",this.onInputChange_),this.view.inputElement.addEventListener("keydown",this.onInputKeyDown_),this.view.inputElement.addEventListener("keyup",this.onInputKeyUp_);const b=new _t(this.view.knobElement);b.emitter.on("down",this.onPointerDown_),b.emitter.on("move",this.onPointerMove_),b.emitter.on("up",this.onPointerUp_)}constrainValue_(e){var t,l;const b=(t=this.sliderProps_)===null||t===void 0?void 0:t.get("minValue"),P=(l=this.sliderProps_)===null||l===void 0?void 0:l.get("maxValue");let L=e;return b!==void 0&&(L=Math.max(L,b)),P!==void 0&&(L=Math.min(L,P)),L}onInputChange_(e){const l=e.currentTarget.value,b=this.parser_(l);w(b)||(this.value.rawValue=this.constrainValue_(b)),this.view.refresh()}onInputKeyDown_(e){const t=Ie(this.baseStep_,rn(e));t!==0&&this.value.setRawValue(this.constrainValue_(this.value.rawValue+t),{forceEmit:!1,last:!1})}onInputKeyUp_(e){Ie(this.baseStep_,rn(e))!==0&&this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}onPointerDown_(){this.originRawValue_=this.value.rawValue,this.dragging_.rawValue=0}computeDraggingValue_(e){if(!e.point)return null;const t=e.point.x-e.bounds.width/2;return this.constrainValue_(this.originRawValue_+t*this.props.get("draggingScale"))}onPointerMove_(e){const t=this.computeDraggingValue_(e.data);t!==null&&(this.value.setRawValue(t,{forceEmit:!1,last:!1}),this.dragging_.rawValue=this.value.rawValue-this.originRawValue_)}onPointerUp_(e){const t=this.computeDraggingValue_(e.data);t!==null&&(this.value.setRawValue(t,{forceEmit:!0,last:!0}),this.dragging_.rawValue=null)}}const ui=N("sld");class Fe{constructor(e,t){this.onChange_=this.onChange_.bind(this),this.props_=t.props,this.props_.emitter.on("change",this.onChange_),this.element=e.createElement("div"),this.element.classList.add(ui()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(ui("t")),t.viewProps.bindTabIndex(l),this.element.appendChild(l),this.trackElement=l;const b=e.createElement("div");b.classList.add(ui("k")),this.trackElement.appendChild(b),this.knobElement=b,t.value.emitter.on("change",this.onChange_),this.value=t.value,this.update_()}update_(){const e=Me(_e(this.value.rawValue,this.props_.get("minValue"),this.props_.get("maxValue"),0,100),0,100);this.knobElement.style.width=`${e}%`}onChange_(){this.update_()}}class hi{constructor(e,t){this.onKeyDown_=this.onKeyDown_.bind(this),this.onKeyUp_=this.onKeyUp_.bind(this),this.onPointerDownOrMove_=this.onPointerDownOrMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.baseStep_=t.baseStep,this.value=t.value,this.viewProps=t.viewProps,this.props=t.props,this.view=new Fe(e,{props:this.props,value:this.value,viewProps:this.viewProps}),this.ptHandler_=new _t(this.view.trackElement),this.ptHandler_.emitter.on("down",this.onPointerDownOrMove_),this.ptHandler_.emitter.on("move",this.onPointerDownOrMove_),this.ptHandler_.emitter.on("up",this.onPointerUp_),this.view.trackElement.addEventListener("keydown",this.onKeyDown_),this.view.trackElement.addEventListener("keyup",this.onKeyUp_)}handlePointerEvent_(e,t){e.point&&this.value.setRawValue(_e(Me(e.point.x,0,e.bounds.width),0,e.bounds.width,this.props.get("minValue"),this.props.get("maxValue")),t)}onPointerDownOrMove_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerUp_(e){this.handlePointerEvent_(e.data,{forceEmit:!0,last:!0})}onKeyDown_(e){const t=Ie(this.baseStep_,He(e));t!==0&&this.value.setRawValue(this.value.rawValue+t,{forceEmit:!1,last:!1})}onKeyUp_(e){Ie(this.baseStep_,He(e))!==0&&this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}const an=N("sldtxt");class di{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(an());const l=e.createElement("div");l.classList.add(an("s")),this.sliderView_=t.sliderView,l.appendChild(this.sliderView_.element),this.element.appendChild(l);const b=e.createElement("div");b.classList.add(an("t")),this.textView_=t.textView,b.appendChild(this.textView_.element),this.element.appendChild(b)}}class Vn{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.sliderC_=new hi(e,{baseStep:t.baseStep,props:t.sliderProps,value:t.value,viewProps:this.viewProps}),this.textC_=new on(e,{baseStep:t.baseStep,parser:t.parser,props:t.textProps,sliderProps:t.sliderProps,value:t.value,viewProps:t.viewProps}),this.view=new di(e,{sliderView:this.sliderC_.view,textView:this.textC_.view})}get sliderController(){return this.sliderC_}get textController(){return this.textC_}}function Xe(n,e){n.write(e)}function ln(n){const e=V;if(Array.isArray(n))return e.required.array(e.required.object({text:e.required.string,value:e.required.raw}))(n).value;if(typeof n=="object")return e.required.raw(n).value}function mi(n){if(n==="inline"||n==="popup")return n}function ot(n){const e=V;return e.required.object({max:e.optional.number,min:e.optional.number,step:e.optional.number})(n).value}function Qi(n){if(Array.isArray(n))return n;const e=[];return Object.keys(n).forEach(t=>{e.push({text:t,value:n[t]})}),e}function fi(n){return w(n)?null:new en(Qi(n))}function Zs(n){const e=n?$e(n,kn):null;return e?e.step:null}function In(n,e){const t=n&&$e(n,kn);return t?ci(t.step):Math.max(ci(e),2)}function wt(n){const e=Zs(n);return e??1}function yt(n,e){var t;const l=n&&$e(n,kn),b=Math.abs((t=l==null?void 0:l.step)!==null&&t!==void 0?t:e);return b===0?.1:Math.pow(10,Math.floor(Math.log10(b))-1)}const cn=N("ckb");class pn{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),this.element=e.createElement("div"),this.element.classList.add(cn()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("label");l.classList.add(cn("l")),this.element.appendChild(l);const b=e.createElement("input");b.classList.add(cn("i")),b.type="checkbox",l.appendChild(b),this.inputElement=b,t.viewProps.bindDisabled(this.inputElement);const P=e.createElement("div");P.classList.add(cn("w")),l.appendChild(P);const L=at(e,"check");P.appendChild(L),t.value.emitter.on("change",this.onValueChange_),this.value=t.value,this.update_()}update_(){this.inputElement.checked=this.value.rawValue}onValueChange_(){this.update_()}}class Zi{constructor(e,t){this.onInputChange_=this.onInputChange_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.view=new pn(e,{value:this.value,viewProps:this.viewProps}),this.view.inputElement.addEventListener("change",this.onInputChange_)}onInputChange_(e){const t=e.currentTarget;this.value.rawValue=t.checked}}function Wi(n){const e=[],t=fi(n.options);return t&&e.push(t),new Ht(e)}const Dn={id:"input-bool",type:"input",accept:(n,e)=>{if(typeof n!="boolean")return null;const l=ce(e,{options:V.optional.custom(ln)});return l?{initialValue:n,params:l}:null},binding:{reader:n=>Fi,constraint:n=>Wi(n.params),writer:n=>Xe},controller:n=>{const e=n.document,t=n.value,l=n.constraint,b=l&&$e(l,en);return b?new tn(e,{props:new q({options:b.values.value("options")}),value:t,viewProps:n.viewProps}):new Zi(e,{value:t,viewProps:n.viewProps})}},xt=N("col");class vi{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(xt()),t.foldable.bindExpandedClass(this.element,xt(void 0,"expanded")),F(t.foldable,"completed",Y(this.element,xt(void 0,"cpl")));const l=e.createElement("div");l.classList.add(xt("h")),this.element.appendChild(l);const b=e.createElement("div");b.classList.add(xt("s")),l.appendChild(b),this.swatchElement=b;const P=e.createElement("div");if(P.classList.add(xt("t")),l.appendChild(P),this.textElement=P,t.pickerLayout==="inline"){const L=e.createElement("div");L.classList.add(xt("p")),this.element.appendChild(L),this.pickerElement=L}else this.pickerElement=null}}function Ws(n,e,t){const l=Me(n/255,0,1),b=Me(e/255,0,1),P=Me(t/255,0,1),L=Math.max(l,b,P),U=Math.min(l,b,P),W=L-U;let H=0,de=0;const ve=(U+L)/2;return W!==0&&(de=W/(1-Math.abs(L+U-1)),l===L?H=(b-P)/W:b===L?H=2+(P-l)/W:H=4+(l-b)/W,H=H/6+(H<0?1:0)),[H*360,de*100,ve*100]}function Js(n,e,t){const l=(n%360+360)%360,b=Me(e/100,0,1),P=Me(t/100,0,1),L=(1-Math.abs(2*P-1))*b,U=L*(1-Math.abs(l/60%2-1)),W=P-L/2;let H,de,ve;return l>=0&&l<60?[H,de,ve]=[L,U,0]:l>=60&&l<120?[H,de,ve]=[U,L,0]:l>=120&&l<180?[H,de,ve]=[0,L,U]:l>=180&&l<240?[H,de,ve]=[0,U,L]:l>=240&&l<300?[H,de,ve]=[U,0,L]:[H,de,ve]=[L,0,U],[(H+W)*255,(de+W)*255,(ve+W)*255]}function Hs(n,e,t){const l=Me(n/255,0,1),b=Me(e/255,0,1),P=Me(t/255,0,1),L=Math.max(l,b,P),U=Math.min(l,b,P),W=L-U;let H;W===0?H=0:L===l?H=60*(((b-P)/W%6+6)%6):L===b?H=60*((P-l)/W+2):H=60*((l-b)/W+4);const de=L===0?0:W/L,ve=L;return[H,de*100,ve*100]}function Ji(n,e,t){const l=Ot(n,360),b=Me(e/100,0,1),P=Me(t/100,0,1),L=P*b,U=L*(1-Math.abs(l/60%2-1)),W=P-L;let H,de,ve;return l>=0&&l<60?[H,de,ve]=[L,U,0]:l>=60&&l<120?[H,de,ve]=[U,L,0]:l>=120&&l<180?[H,de,ve]=[0,L,U]:l>=180&&l<240?[H,de,ve]=[0,U,L]:l>=240&&l<300?[H,de,ve]=[U,0,L]:[H,de,ve]=[L,0,U],[(H+W)*255,(de+W)*255,(ve+W)*255]}function m(n,e,t){const l=t+e*(100-Math.abs(2*t-100))/200;return[n,l!==0?e*(100-Math.abs(2*t-100))/l:0,t+e*(100-Math.abs(2*t-100))/(2*100)]}function o(n,e,t){const l=100-Math.abs(t*(200-e)/100-100);return[n,l!==0?e*t/l:0,t*(200-e)/(2*100)]}function p(n){return[n[0],n[1],n[2]]}function v(n,e){return[n[0],n[1],n[2],e]}const C={hsl:{hsl:(n,e,t)=>[n,e,t],hsv:m,rgb:Js},hsv:{hsl:o,hsv:(n,e,t)=>[n,e,t],rgb:Ji},rgb:{hsl:Ws,hsv:Hs,rgb:(n,e,t)=>[n,e,t]}};function k(n,e){return[e==="float"?1:n==="rgb"?255:360,e==="float"?1:n==="rgb"?255:100,e==="float"?1:n==="rgb"?255:100]}function T(n,e){return n===e?e:Ot(n,e)}function G(n,e,t){var l;const b=k(e,t);return[e==="rgb"?Me(n[0],0,b[0]):T(n[0],b[0]),Me(n[1],0,b[1]),Me(n[2],0,b[2]),Me((l=n[3])!==null&&l!==void 0?l:1,0,1)]}function oe(n,e,t,l){const b=k(e,t),P=k(e,l);return n.map((L,U)=>L/b[U]*P[U])}function Ge(n,e,t){const l=oe(n,e.mode,e.type,"int"),b=C[e.mode][t.mode](...l);return oe(b,t.mode,"int",t.type)}function Ke(n,e){return typeof n!="object"||w(n)?!1:e in n&&typeof n[e]=="number"}class te{static black(e="int"){return new te([0,0,0],"rgb",e)}static fromObject(e,t="int"){const l="a"in e?[e.r,e.g,e.b,e.a]:[e.r,e.g,e.b];return new te(l,"rgb",t)}static toRgbaObject(e,t="int"){return e.toRgbaObject(t)}static isRgbColorObject(e){return Ke(e,"r")&&Ke(e,"g")&&Ke(e,"b")}static isRgbaColorObject(e){return this.isRgbColorObject(e)&&Ke(e,"a")}static isColorObject(e){return this.isRgbColorObject(e)}static equals(e,t){if(e.mode!==t.mode)return!1;const l=e.comps_,b=t.comps_;for(let P=0;P<l.length;P++)if(l[P]!==b[P])return!1;return!0}constructor(e,t,l="int"){this.mode=t,this.type=l,this.comps_=G(e,t,l)}getComponents(e,t="int"){return v(Ge(p(this.comps_),{mode:this.mode,type:this.type},{mode:e??this.mode,type:t}),this.comps_[3])}toRgbaObject(e="int"){const t=this.getComponents("rgb",e);return{r:t[0],g:t[1],b:t[2],a:t[3]}}}const ut=N("colp");class er{constructor(e,t){this.alphaViews_=null,this.element=e.createElement("div"),this.element.classList.add(ut()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(ut("hsv"));const b=e.createElement("div");b.classList.add(ut("sv")),this.svPaletteView_=t.svPaletteView,b.appendChild(this.svPaletteView_.element),l.appendChild(b);const P=e.createElement("div");P.classList.add(ut("h")),this.hPaletteView_=t.hPaletteView,P.appendChild(this.hPaletteView_.element),l.appendChild(P),this.element.appendChild(l);const L=e.createElement("div");if(L.classList.add(ut("rgb")),this.textView_=t.textView,L.appendChild(this.textView_.element),this.element.appendChild(L),t.alphaViews){this.alphaViews_={palette:t.alphaViews.palette,text:t.alphaViews.text};const U=e.createElement("div");U.classList.add(ut("a"));const W=e.createElement("div");W.classList.add(ut("ap")),W.appendChild(this.alphaViews_.palette.element),U.appendChild(W);const H=e.createElement("div");H.classList.add(ut("at")),H.appendChild(this.alphaViews_.text.element),U.appendChild(H),this.element.appendChild(U)}}get allFocusableElements(){const e=[this.svPaletteView_.element,this.hPaletteView_.element,this.textView_.modeSelectElement,...this.textView_.textViews.map(t=>t.inputElement)];return this.alphaViews_&&e.push(this.alphaViews_.palette.element,this.alphaViews_.text.inputElement),e}}function Lc(n){return n==="int"?"int":n==="float"?"float":void 0}function tr(n){const e=V;return ce(n,{alpha:e.optional.boolean,color:e.optional.object({alpha:e.optional.boolean,type:e.optional.custom(Lc)}),expanded:e.optional.boolean,picker:e.optional.custom(mi)})}function un(n){return n?.1:1}function hn(n){var e;return(e=n.color)===null||e===void 0?void 0:e.type}function Ac(n,e){return n.alpha===e.alpha&&n.mode===e.mode&&n.notation===e.notation&&n.type===e.type}function et(n,e){const t=n.match(/^(.+)%$/);return Math.min(t?parseFloat(t[1])*.01*e:parseFloat(n),e)}const Vc={deg:n=>n,grad:n=>n*360/400,rad:n=>n*360/(2*Math.PI),turn:n=>n*360};function no(n){const e=n.match(/^([0-9.]+?)(deg|grad|rad|turn)$/);if(!e)return parseFloat(n);const t=parseFloat(e[1]),l=e[2];return Vc[l](t)}function io(n){const e=n.match(/^rgb\(\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*\)$/);if(!e)return null;const t=[et(e[1],255),et(e[2],255),et(e[3],255)];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])?null:t}function so(n){return e=>{const t=io(e);return t?new te(t,"rgb",n):null}}function ro(n){const e=n.match(/^rgba\(\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*\)$/);if(!e)return null;const t=[et(e[1],255),et(e[2],255),et(e[3],255),et(e[4],1)];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])||isNaN(t[3])?null:t}function oo(n){return e=>{const t=ro(e);return t?new te(t,"rgb",n):null}}function ao(n){const e=n.match(/^hsl\(\s*([0-9A-Fa-f.]+(?:deg|grad|rad|turn)?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*\)$/);if(!e)return null;const t=[no(e[1]),et(e[2],100),et(e[3],100)];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])?null:t}function lo(n){return e=>{const t=ao(e);return t?new te(t,"hsl",n):null}}function co(n){const e=n.match(/^hsla\(\s*([0-9A-Fa-f.]+(?:deg|grad|rad|turn)?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*,\s*([0-9A-Fa-f.]+%?)\s*\)$/);if(!e)return null;const t=[no(e[1]),et(e[2],100),et(e[3],100),et(e[4],1)];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])||isNaN(t[3])?null:t}function po(n){return e=>{const t=co(e);return t?new te(t,"hsl",n):null}}function uo(n){const e=n.match(/^#([0-9A-Fa-f])([0-9A-Fa-f])([0-9A-Fa-f])$/);if(e)return[parseInt(e[1]+e[1],16),parseInt(e[2]+e[2],16),parseInt(e[3]+e[3],16)];const t=n.match(/^(?:#|0x)([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})$/);return t?[parseInt(t[1],16),parseInt(t[2],16),parseInt(t[3],16)]:null}function Ic(n){const e=uo(n);return e?new te(e,"rgb","int"):null}function ho(n){const e=n.match(/^#?([0-9A-Fa-f])([0-9A-Fa-f])([0-9A-Fa-f])([0-9A-Fa-f])$/);if(e)return[parseInt(e[1]+e[1],16),parseInt(e[2]+e[2],16),parseInt(e[3]+e[3],16),_e(parseInt(e[4]+e[4],16),0,255,0,1)];const t=n.match(/^(?:#|0x)?([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})$/);return t?[parseInt(t[1],16),parseInt(t[2],16),parseInt(t[3],16),_e(parseInt(t[4],16),0,255,0,1)]:null}function Dc(n){const e=ho(n);return e?new te(e,"rgb","int"):null}function mo(n){const e=n.match(/^\{\s*r\s*:\s*([0-9A-Fa-f.]+%?)\s*,\s*g\s*:\s*([0-9A-Fa-f.]+%?)\s*,\s*b\s*:\s*([0-9A-Fa-f.]+%?)\s*\}$/);if(!e)return null;const t=[parseFloat(e[1]),parseFloat(e[2]),parseFloat(e[3])];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])?null:t}function fo(n){return e=>{const t=mo(e);return t?new te(t,"rgb",n):null}}function vo(n){const e=n.match(/^\{\s*r\s*:\s*([0-9A-Fa-f.]+%?)\s*,\s*g\s*:\s*([0-9A-Fa-f.]+%?)\s*,\s*b\s*:\s*([0-9A-Fa-f.]+%?)\s*,\s*a\s*:\s*([0-9A-Fa-f.]+%?)\s*\}$/);if(!e)return null;const t=[parseFloat(e[1]),parseFloat(e[2]),parseFloat(e[3]),parseFloat(e[4])];return isNaN(t[0])||isNaN(t[1])||isNaN(t[2])||isNaN(t[3])?null:t}function bo(n){return e=>{const t=vo(e);return t?new te(t,"rgb",n):null}}const Tc=[{parser:uo,result:{alpha:!1,mode:"rgb",notation:"hex"}},{parser:ho,result:{alpha:!0,mode:"rgb",notation:"hex"}},{parser:io,result:{alpha:!1,mode:"rgb",notation:"func"}},{parser:ro,result:{alpha:!0,mode:"rgb",notation:"func"}},{parser:ao,result:{alpha:!1,mode:"hsl",notation:"func"}},{parser:co,result:{alpha:!0,mode:"hsl",notation:"func"}},{parser:mo,result:{alpha:!1,mode:"rgb",notation:"object"}},{parser:vo,result:{alpha:!0,mode:"rgb",notation:"object"}}];function Ec(n){return Tc.reduce((e,{parser:t,result:l})=>e||(t(n)?l:null),null)}function nr(n,e="int"){const t=Ec(n);return t?t.notation==="hex"&&e!=="float"?Object.assign(Object.assign({},t),{type:"int"}):t.notation==="func"?Object.assign(Object.assign({},t),{type:e}):null:null}const go={int:[Ic,Dc,so("int"),oo("int"),lo("int"),po("int"),fo("int"),bo("int")],float:[so("float"),oo("float"),lo("float"),po("float"),fo("float"),bo("float")]};function Oc(n){const e=go[n];return t=>{if(typeof t!="string")return te.black(n);const l=e.reduce((b,P)=>b||P(t),null);return l??te.black(n)}}function ir(n){const e=go[n];return t=>e.reduce((l,b)=>l||b(t),null)}function _o(n){const e=Me(Math.floor(n),0,255).toString(16);return e.length===1?`0${e}`:e}function wo(n,e="#"){const t=p(n.getComponents("rgb")).map(_o).join("");return`${e}${t}`}function sr(n,e="#"){const t=n.getComponents("rgb"),l=[t[0],t[1],t[2],t[3]*255].map(_o).join("");return`${e}${l}`}function yo(n,e){const t=Le(e==="float"?2:0);return`rgb(${p(n.getComponents("rgb",e)).map(b=>t(b)).join(", ")})`}function Bc(n){return e=>yo(e,n)}function Hi(n,e){const t=Le(2),l=Le(e==="float"?2:0);return`rgba(${n.getComponents("rgb",e).map((P,L)=>(L===3?t:l)(P)).join(", ")})`}function Nc(n){return e=>Hi(e,n)}function Fc(n){const e=[Le(0),sn,sn];return`hsl(${p(n.getComponents("hsl")).map((l,b)=>e[b](l)).join(", ")})`}function jc(n){const e=[Le(0),sn,sn,Le(2)];return`hsla(${n.getComponents("hsl").map((l,b)=>e[b](l)).join(", ")})`}function xo(n,e){const t=Le(e==="float"?2:0),l=["r","g","b"];return`{${p(n.getComponents("rgb",e)).map((P,L)=>`${l[L]}: ${t(P)}`).join(", ")}}`}function zc(n){return e=>xo(e,n)}function Co(n,e){const t=Le(2),l=Le(e==="float"?2:0),b=["r","g","b","a"];return`{${n.getComponents("rgb",e).map((L,U)=>{const W=U===3?t:l;return`${b[U]}: ${W(L)}`}).join(", ")}}`}function Uc(n){return e=>Co(e,n)}const Rc=[{format:{alpha:!1,mode:"rgb",notation:"hex",type:"int"},stringifier:wo},{format:{alpha:!0,mode:"rgb",notation:"hex",type:"int"},stringifier:sr},{format:{alpha:!1,mode:"hsl",notation:"func",type:"int"},stringifier:Fc},{format:{alpha:!0,mode:"hsl",notation:"func",type:"int"},stringifier:jc},...["int","float"].reduce((n,e)=>[...n,{format:{alpha:!1,mode:"rgb",notation:"func",type:e},stringifier:Bc(e)},{format:{alpha:!0,mode:"rgb",notation:"func",type:e},stringifier:Nc(e)},{format:{alpha:!1,mode:"rgb",notation:"object",type:e},stringifier:zc(e)},{format:{alpha:!0,mode:"rgb",notation:"object",type:e},stringifier:Uc(e)}],[])];function rr(n){return Rc.reduce((e,t)=>e||(Ac(t.format,n)?t.stringifier:null),null)}const bi=N("apl");class Gc{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),this.value=t.value,this.value.emitter.on("change",this.onValueChange_),this.element=e.createElement("div"),this.element.classList.add(bi()),t.viewProps.bindClassModifiers(this.element),t.viewProps.bindTabIndex(this.element);const l=e.createElement("div");l.classList.add(bi("b")),this.element.appendChild(l);const b=e.createElement("div");b.classList.add(bi("c")),l.appendChild(b),this.colorElem_=b;const P=e.createElement("div");P.classList.add(bi("m")),this.element.appendChild(P),this.markerElem_=P;const L=e.createElement("div");L.classList.add(bi("p")),this.markerElem_.appendChild(L),this.previewElem_=L,this.update_()}update_(){const e=this.value.rawValue,t=e.getComponents("rgb"),l=new te([t[0],t[1],t[2],0],"rgb"),b=new te([t[0],t[1],t[2],255],"rgb"),P=["to right",Hi(l),Hi(b)];this.colorElem_.style.background=`linear-gradient(${P.join(",")})`,this.previewElem_.style.backgroundColor=Hi(e);const L=_e(t[3],0,1,0,100);this.markerElem_.style.left=`${L}%`}onValueChange_(){this.update_()}}class Kc{constructor(e,t){this.onKeyDown_=this.onKeyDown_.bind(this),this.onKeyUp_=this.onKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.view=new Gc(e,{value:this.value,viewProps:this.viewProps}),this.ptHandler_=new _t(this.view.element),this.ptHandler_.emitter.on("down",this.onPointerDown_),this.ptHandler_.emitter.on("move",this.onPointerMove_),this.ptHandler_.emitter.on("up",this.onPointerUp_),this.view.element.addEventListener("keydown",this.onKeyDown_),this.view.element.addEventListener("keyup",this.onKeyUp_)}handlePointerEvent_(e,t){if(!e.point)return;const l=e.point.x/e.bounds.width,b=this.value.rawValue,[P,L,U]=b.getComponents("hsv");this.value.setRawValue(new te([P,L,U,l],"hsv"),t)}onPointerDown_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerMove_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerUp_(e){this.handlePointerEvent_(e.data,{forceEmit:!0,last:!0})}onKeyDown_(e){const t=Ie(un(!0),He(e));if(t===0)return;const l=this.value.rawValue,[b,P,L,U]=l.getComponents("hsv");this.value.setRawValue(new te([b,P,L,U+t],"hsv"),{forceEmit:!1,last:!1})}onKeyUp_(e){Ie(un(!0),He(e))!==0&&this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}const Tn=N("coltxt");function $c(n){const e=n.createElement("select"),t=[{text:"RGB",value:"rgb"},{text:"HSL",value:"hsl"},{text:"HSV",value:"hsv"}];return e.appendChild(t.reduce((l,b)=>{const P=n.createElement("option");return P.textContent=b.text,P.value=b.value,l.appendChild(P),l},n.createDocumentFragment())),e}class Xc{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(Tn()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(Tn("m")),this.modeElem_=$c(e),this.modeElem_.classList.add(Tn("ms")),l.appendChild(this.modeSelectElement),t.viewProps.bindDisabled(this.modeElem_);const b=e.createElement("div");b.classList.add(Tn("mm")),b.appendChild(at(e,"dropdown")),l.appendChild(b),this.element.appendChild(l);const P=e.createElement("div");P.classList.add(Tn("w")),this.element.appendChild(P),this.textsElem_=P,this.textViews_=t.textViews,this.applyTextViews_(),j(t.colorMode,L=>{this.modeElem_.value=L})}get modeSelectElement(){return this.modeElem_}get textViews(){return this.textViews_}set textViews(e){this.textViews_=e,this.applyTextViews_()}applyTextViews_(){Yt(this.textsElem_);const e=this.element.ownerDocument;this.textViews_.forEach(t=>{const l=e.createElement("div");l.classList.add(Tn("c")),l.appendChild(t.element),this.textsElem_.appendChild(l)})}}function Yc(n){return Le(n==="float"?2:0)}function qc(n,e,t){const l=k(n,e)[t];return new Dt({min:0,max:l})}function or(n,e,t){return new on(n,{arrayPosition:t===0?"fst":t===3-1?"lst":"mid",baseStep:un(!1),parser:e.parser,props:q.fromObject({draggingScale:e.colorType==="float"?.01:1,formatter:Yc(e.colorType)}),value:ee(0,{constraint:qc(e.colorMode,e.colorType,t)}),viewProps:e.viewProps})}class Qc{constructor(e,t){this.onModeSelectChange_=this.onModeSelectChange_.bind(this),this.colorType_=t.colorType,this.parser_=t.parser,this.value=t.value,this.viewProps=t.viewProps,this.colorMode=ee(this.value.rawValue.mode),this.ccs_=this.createComponentControllers_(e),this.view=new Xc(e,{colorMode:this.colorMode,textViews:[this.ccs_[0].view,this.ccs_[1].view,this.ccs_[2].view],viewProps:this.viewProps}),this.view.modeSelectElement.addEventListener("change",this.onModeSelectChange_)}createComponentControllers_(e){const t={colorMode:this.colorMode.rawValue,colorType:this.colorType_,parser:this.parser_,viewProps:this.viewProps},l=[or(e,t,0),or(e,t,1),or(e,t,2)];return l.forEach((b,P)=>{Et({primary:this.value,secondary:b.value,forward:L=>L.rawValue.getComponents(this.colorMode.rawValue,this.colorType_)[P],backward:(L,U)=>{const W=this.colorMode.rawValue,H=L.rawValue.getComponents(W,this.colorType_);return H[P]=U.rawValue,new te(v(p(H),H[3]),W,this.colorType_)}})}),l}onModeSelectChange_(e){const t=e.currentTarget;this.colorMode.rawValue=t.value,this.ccs_=this.createComponentControllers_(this.view.element.ownerDocument),this.view.textViews=[this.ccs_[0].view,this.ccs_[1].view,this.ccs_[2].view]}}const ar=N("hpl");class Zc{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),this.value=t.value,this.value.emitter.on("change",this.onValueChange_),this.element=e.createElement("div"),this.element.classList.add(ar()),t.viewProps.bindClassModifiers(this.element),t.viewProps.bindTabIndex(this.element);const l=e.createElement("div");l.classList.add(ar("c")),this.element.appendChild(l);const b=e.createElement("div");b.classList.add(ar("m")),this.element.appendChild(b),this.markerElem_=b,this.update_()}update_(){const e=this.value.rawValue,[t]=e.getComponents("hsv");this.markerElem_.style.backgroundColor=yo(new te([t,100,100],"hsv"));const l=_e(t,0,360,0,100);this.markerElem_.style.left=`${l}%`}onValueChange_(){this.update_()}}class Wc{constructor(e,t){this.onKeyDown_=this.onKeyDown_.bind(this),this.onKeyUp_=this.onKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.view=new Zc(e,{value:this.value,viewProps:this.viewProps}),this.ptHandler_=new _t(this.view.element),this.ptHandler_.emitter.on("down",this.onPointerDown_),this.ptHandler_.emitter.on("move",this.onPointerMove_),this.ptHandler_.emitter.on("up",this.onPointerUp_),this.view.element.addEventListener("keydown",this.onKeyDown_),this.view.element.addEventListener("keyup",this.onKeyUp_)}handlePointerEvent_(e,t){if(!e.point)return;const l=_e(Me(e.point.x,0,e.bounds.width),0,e.bounds.width,0,360),b=this.value.rawValue,[,P,L,U]=b.getComponents("hsv");this.value.setRawValue(new te([l,P,L,U],"hsv"),t)}onPointerDown_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerMove_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerUp_(e){this.handlePointerEvent_(e.data,{forceEmit:!0,last:!0})}onKeyDown_(e){const t=Ie(un(!1),He(e));if(t===0)return;const l=this.value.rawValue,[b,P,L,U]=l.getComponents("hsv");this.value.setRawValue(new te([b+t,P,L,U],"hsv"),{forceEmit:!1,last:!1})}onKeyUp_(e){Ie(un(!1),He(e))!==0&&this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}const lr=N("svp"),Po=64;class Jc{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),this.value=t.value,this.value.emitter.on("change",this.onValueChange_),this.element=e.createElement("div"),this.element.classList.add(lr()),t.viewProps.bindClassModifiers(this.element),t.viewProps.bindTabIndex(this.element);const l=e.createElement("canvas");l.height=Po,l.width=Po,l.classList.add(lr("c")),this.element.appendChild(l),this.canvasElement=l;const b=e.createElement("div");b.classList.add(lr("m")),this.element.appendChild(b),this.markerElem_=b,this.update_()}update_(){const e=gn(this.canvasElement);if(!e)return;const l=this.value.rawValue.getComponents("hsv"),b=this.canvasElement.width,P=this.canvasElement.height,L=e.getImageData(0,0,b,P),U=L.data;for(let de=0;de<P;de++)for(let ve=0;ve<b;ve++){const dn=_e(ve,0,b,0,100),_i=_e(de,0,P,100,0),wi=Ji(l[0],dn,_i),es=(de*b+ve)*4;U[es]=wi[0],U[es+1]=wi[1],U[es+2]=wi[2],U[es+3]=255}e.putImageData(L,0,0);const W=_e(l[1],0,100,0,100);this.markerElem_.style.left=`${W}%`;const H=_e(l[2],0,100,100,0);this.markerElem_.style.top=`${H}%`}onValueChange_(){this.update_()}}class Hc{constructor(e,t){this.onKeyDown_=this.onKeyDown_.bind(this),this.onKeyUp_=this.onKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.view=new Jc(e,{value:this.value,viewProps:this.viewProps}),this.ptHandler_=new _t(this.view.element),this.ptHandler_.emitter.on("down",this.onPointerDown_),this.ptHandler_.emitter.on("move",this.onPointerMove_),this.ptHandler_.emitter.on("up",this.onPointerUp_),this.view.element.addEventListener("keydown",this.onKeyDown_),this.view.element.addEventListener("keyup",this.onKeyUp_)}handlePointerEvent_(e,t){if(!e.point)return;const l=_e(e.point.x,0,e.bounds.width,0,100),b=_e(e.point.y,0,e.bounds.height,100,0),[P,,,L]=this.value.rawValue.getComponents("hsv");this.value.setRawValue(new te([P,l,b,L],"hsv"),t)}onPointerDown_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerMove_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerUp_(e){this.handlePointerEvent_(e.data,{forceEmit:!0,last:!0})}onKeyDown_(e){An(e.key)&&e.preventDefault();const[t,l,b,P]=this.value.rawValue.getComponents("hsv"),L=un(!1),U=Ie(L,He(e)),W=Ie(L,rn(e));U===0&&W===0||this.value.setRawValue(new te([t,l+U,b+W,P],"hsv"),{forceEmit:!1,last:!1})}onKeyUp_(e){const t=un(!1),l=Ie(t,He(e)),b=Ie(t,rn(e));l===0&&b===0||this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}class ep{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.hPaletteC_=new Wc(e,{value:this.value,viewProps:this.viewProps}),this.svPaletteC_=new Hc(e,{value:this.value,viewProps:this.viewProps}),this.alphaIcs_=t.supportsAlpha?{palette:new Kc(e,{value:this.value,viewProps:this.viewProps}),text:new on(e,{parser:Je,baseStep:.1,props:q.fromObject({draggingScale:.01,formatter:Le(2)}),value:ee(0,{constraint:new Dt({min:0,max:1})}),viewProps:this.viewProps})}:null,this.alphaIcs_&&Et({primary:this.value,secondary:this.alphaIcs_.text.value,forward:l=>l.rawValue.getComponents()[3],backward:(l,b)=>{const P=l.rawValue.getComponents();return P[3]=b.rawValue,new te(P,l.rawValue.mode)}}),this.textC_=new Qc(e,{colorType:t.colorType,parser:Je,value:this.value,viewProps:this.viewProps}),this.view=new er(e,{alphaViews:this.alphaIcs_?{palette:this.alphaIcs_.palette.view,text:this.alphaIcs_.text.view}:null,hPaletteView:this.hPaletteC_.view,supportsAlpha:t.supportsAlpha,svPaletteView:this.svPaletteC_.view,textView:this.textC_.view,viewProps:this.viewProps})}get textController(){return this.textC_}}const cr=N("colsw");class tp{constructor(e,t){this.onValueChange_=this.onValueChange_.bind(this),t.value.emitter.on("change",this.onValueChange_),this.value=t.value,this.element=e.createElement("div"),this.element.classList.add(cr()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(cr("sw")),this.element.appendChild(l),this.swatchElem_=l;const b=e.createElement("button");b.classList.add(cr("b")),t.viewProps.bindDisabled(b),this.element.appendChild(b),this.buttonElement=b,this.update_()}update_(){const e=this.value.rawValue;this.swatchElem_.style.backgroundColor=sr(e)}onValueChange_(){this.update_()}}class np{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.view=new tp(e,{value:this.value,viewProps:this.viewProps})}}class pr{constructor(e,t){this.onButtonBlur_=this.onButtonBlur_.bind(this),this.onButtonClick_=this.onButtonClick_.bind(this),this.onPopupChildBlur_=this.onPopupChildBlur_.bind(this),this.onPopupChildKeydown_=this.onPopupChildKeydown_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.foldable_=Ve.create(t.expanded),this.swatchC_=new np(e,{value:this.value,viewProps:this.viewProps});const l=this.swatchC_.view.buttonElement;l.addEventListener("blur",this.onButtonBlur_),l.addEventListener("click",this.onButtonClick_),this.textC_=new Sn(e,{parser:t.parser,props:q.fromObject({formatter:t.formatter}),value:this.value,viewProps:this.viewProps}),this.view=new vi(e,{foldable:this.foldable_,pickerLayout:t.pickerLayout}),this.view.swatchElement.appendChild(this.swatchC_.view.element),this.view.textElement.appendChild(this.textC_.view.element),this.popC_=t.pickerLayout==="popup"?new Bi(e,{viewProps:this.viewProps}):null;const b=new ep(e,{colorType:t.colorType,supportsAlpha:t.supportsAlpha,value:this.value,viewProps:this.viewProps});b.view.allFocusableElements.forEach(P=>{P.addEventListener("blur",this.onPopupChildBlur_),P.addEventListener("keydown",this.onPopupChildKeydown_)}),this.pickerC_=b,this.popC_?(this.view.element.appendChild(this.popC_.view.element),this.popC_.view.element.appendChild(b.view.element),Et({primary:this.foldable_.value("expanded"),secondary:this.popC_.shows,forward:P=>P.rawValue,backward:(P,L)=>L.rawValue})):this.view.pickerElement&&(this.view.pickerElement.appendChild(this.pickerC_.view.element),Oe(this.foldable_,this.view.pickerElement))}get textController(){return this.textC_}onButtonBlur_(e){if(!this.popC_)return;const t=this.view.element,l=e.relatedTarget;(!l||!t.contains(l))&&(this.popC_.shows.rawValue=!1)}onButtonClick_(){this.foldable_.set("expanded",!this.foldable_.get("expanded")),this.foldable_.get("expanded")&&this.pickerC_.view.allFocusableElements[0].focus()}onPopupChildBlur_(e){if(!this.popC_)return;const t=this.popC_.view.element,l=lt(e);l&&t.contains(l)||l&&l===this.swatchC_.view.buttonElement&&!it(t.ownerDocument)||(this.popC_.shows.rawValue=!1)}onPopupChildKeydown_(e){this.popC_?e.key==="Escape"&&(this.popC_.shows.rawValue=!1):this.view.pickerElement&&e.key==="Escape"&&this.swatchC_.view.buttonElement.focus()}}function ip(n,e){return te.isColorObject(n)?te.fromObject(n,e):te.black(e)}function sp(n){return p(n.getComponents("rgb")).reduce((e,t)=>e<<8|Math.floor(t)&255,0)}function rp(n){return n.getComponents("rgb").reduce((e,t,l)=>{const b=Math.floor(l===3?t*255:t)&255;return e<<8|b},0)>>>0}function op(n){return new te([n>>16&255,n>>8&255,n&255],"rgb")}function ap(n){return new te([n>>24&255,n>>16&255,n>>8&255,_e(n&255,0,255,0,1)],"rgb")}function lp(n){return typeof n!="number"?te.black():op(n)}function cp(n){return typeof n!="number"?te.black():ap(n)}function pp(n){const e=rr(n);return e?(t,l)=>{Xe(t,e(l))}:null}function up(n){const e=n?rp:sp;return(t,l)=>{Xe(t,e(l))}}function hp(n,e,t){const l=e.toRgbaObject(t);n.writeProperty("r",l.r),n.writeProperty("g",l.g),n.writeProperty("b",l.b),n.writeProperty("a",l.a)}function dp(n,e,t){const l=e.toRgbaObject(t);n.writeProperty("r",l.r),n.writeProperty("g",l.g),n.writeProperty("b",l.b)}function mp(n,e){return(t,l)=>{n?hp(t,l,e):dp(t,l,e)}}function ur(n){var e;return!!(n!=null&&n.alpha||!((e=n==null?void 0:n.color)===null||e===void 0)&&e.alpha)}function fp(n){return n?e=>sr(e,"0x"):e=>wo(e,"0x")}function vp(n){return"color"in n||"view"in n&&n.view==="color"}const bp={id:"input-color-number",type:"input",accept:(n,e)=>{if(typeof n!="number"||!vp(e))return null;const t=tr(e);return t?{initialValue:n,params:t}:null},binding:{reader:n=>ur(n.params)?cp:lp,equals:te.equals,writer:n=>up(ur(n.params))},controller:n=>{const e=ur(n.params),t="expanded"in n.params?n.params.expanded:void 0,l="picker"in n.params?n.params.picker:void 0;return new pr(n.document,{colorType:"int",expanded:t??!1,formatter:fp(e),parser:ir("int"),pickerLayout:l??"popup",supportsAlpha:e,value:n.value,viewProps:n.viewProps})}};function gp(n){return te.isRgbaColorObject(n)}function _p(n){return e=>ip(e,n)}function wp(n,e){return t=>n?Co(t,e):xo(t,e)}const yp={id:"input-color-object",type:"input",accept:(n,e)=>{if(!te.isColorObject(n))return null;const t=tr(e);return t?{initialValue:n,params:t}:null},binding:{reader:n=>_p(hn(n.params)),equals:te.equals,writer:n=>mp(gp(n.initialValue),hn(n.params))},controller:n=>{var e;const t=te.isRgbaColorObject(n.initialValue),l="expanded"in n.params?n.params.expanded:void 0,b="picker"in n.params?n.params.picker:void 0,P=(e=hn(n.params))!==null&&e!==void 0?e:"int";return new pr(n.document,{colorType:P,expanded:l??!1,formatter:wp(t,P),parser:ir(P),pickerLayout:b??"popup",supportsAlpha:t,value:n.value,viewProps:n.viewProps})}},xp={id:"input-color-string",type:"input",accept:(n,e)=>{if(typeof n!="string"||"view"in e&&e.view==="text")return null;const t=nr(n,hn(e));if(!t||!rr(t))return null;const b=tr(e);return b?{initialValue:n,params:b}:null},binding:{reader:n=>{var e;return Oc((e=hn(n.params))!==null&&e!==void 0?e:"int")},equals:te.equals,writer:n=>{const e=nr(n.initialValue,hn(n.params));if(!e)throw I.shouldNeverHappen();const t=pp(e);if(!t)throw I.notBindable();return t}},controller:n=>{const e=nr(n.initialValue,hn(n.params));if(!e)throw I.shouldNeverHappen();const t=rr(e);if(!t)throw I.shouldNeverHappen();const l="expanded"in n.params?n.params.expanded:void 0,b="picker"in n.params?n.params.picker:void 0;return new pr(n.document,{colorType:e.type,expanded:l??!1,formatter:t,parser:ir(e.type),pickerLayout:b??"popup",supportsAlpha:e.alpha,value:n.value,viewProps:n.viewProps})}};class Bt{constructor(e){this.components=e.components,this.asm_=e.assembly}constrain(e){const t=this.asm_.toComponents(e).map((l,b)=>{var P,L;return(L=(P=this.components[b])===null||P===void 0?void 0:P.constrain(l))!==null&&L!==void 0?L:l});return this.asm_.fromComponents(t)}}const Mo=N("pndtxt");class Cp{constructor(e,t){this.textViews=t.textViews,this.element=e.createElement("div"),this.element.classList.add(Mo()),this.textViews.forEach(l=>{const b=e.createElement("div");b.classList.add(Mo("a")),b.appendChild(l.element),this.element.appendChild(b)})}}function Pp(n,e,t){return new on(n,{arrayPosition:t===0?"fst":t===e.axes.length-1?"lst":"mid",baseStep:e.axes[t].baseStep,parser:e.parser,props:e.axes[t].textProps,value:ee(0,{constraint:e.axes[t].constraint}),viewProps:e.viewProps})}class hr{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.acs_=t.axes.map((l,b)=>Pp(e,t,b)),this.acs_.forEach((l,b)=>{Et({primary:this.value,secondary:l.value,forward:P=>t.assembly.toComponents(P.rawValue)[b],backward:(P,L)=>{const U=t.assembly.toComponents(P.rawValue);return U[b]=L.rawValue,t.assembly.fromComponents(U)}})}),this.view=new Cp(e,{textViews:this.acs_.map(l=>l.view)})}}function ko(n,e){return"step"in n&&!w(n.step)?new kn(n.step,e):null}function So(n){return!w(n.max)&&!w(n.min)?new Dt({max:n.max,min:n.min}):!w(n.max)||!w(n.min)?new ti({max:n.max,min:n.min}):null}function Mp(n){const e=$e(n,Dt);if(e)return[e.values.get("min"),e.values.get("max")];const t=$e(n,ti);return t?[t.minValue,t.maxValue]:[void 0,void 0]}function kp(n,e){const t=[],l=ko(n,e);l&&t.push(l);const b=So(n);b&&t.push(b);const P=fi(n.options);return P&&t.push(P),new Ht(t)}const Sp={id:"input-number",type:"input",accept:(n,e)=>{if(typeof n!="number")return null;const t=V,l=ce(e,{format:t.optional.function,max:t.optional.number,min:t.optional.number,options:t.optional.custom(ln),step:t.optional.number});return l?{initialValue:n,params:l}:null},binding:{reader:n=>rt,constraint:n=>kp(n.params,n.initialValue),writer:n=>Xe},controller:n=>{var e;const t=n.value,l=n.constraint,b=l&&$e(l,en);if(b)return new tn(n.document,{props:new q({options:b.values.value("options")}),value:t,viewProps:n.viewProps});const P=(e="format"in n.params?n.params.format:void 0)!==null&&e!==void 0?e:Le(In(l,t.rawValue)),L=l&&$e(l,Dt);return L?new Vn(n.document,{baseStep:wt(l),parser:Je,sliderProps:new q({maxValue:L.values.value("max"),minValue:L.values.value("min")}),textProps:q.fromObject({draggingScale:yt(l,t.rawValue),formatter:P}),value:t,viewProps:n.viewProps}):new on(n.document,{baseStep:wt(l),parser:Je,props:q.fromObject({draggingScale:yt(l,t.rawValue),formatter:P}),value:t,viewProps:n.viewProps})}};class Nt{constructor(e=0,t=0){this.x=e,this.y=t}getComponents(){return[this.x,this.y]}static isObject(e){if(w(e))return!1;const t=e.x,l=e.y;return!(typeof t!="number"||typeof l!="number")}static equals(e,t){return e.x===t.x&&e.y===t.y}toObject(){return{x:this.x,y:this.y}}}const Lo={toComponents:n=>n.getComponents(),fromComponents:n=>new Nt(...n)},En=N("p2d");class Lp{constructor(e,t){this.element=e.createElement("div"),this.element.classList.add(En()),t.viewProps.bindClassModifiers(this.element),j(t.expanded,Y(this.element,En(void 0,"expanded")));const l=e.createElement("div");l.classList.add(En("h")),this.element.appendChild(l);const b=e.createElement("button");b.classList.add(En("b")),b.appendChild(at(e,"p2dpad")),t.viewProps.bindDisabled(b),l.appendChild(b),this.buttonElement=b;const P=e.createElement("div");if(P.classList.add(En("t")),l.appendChild(P),this.textElement=P,t.pickerLayout==="inline"){const L=e.createElement("div");L.classList.add(En("p")),this.element.appendChild(L),this.pickerElement=L}else this.pickerElement=null}}const Ft=N("p2dp");class Ap{constructor(e,t){this.onFoldableChange_=this.onFoldableChange_.bind(this),this.onValueChange_=this.onValueChange_.bind(this),this.invertsY_=t.invertsY,this.maxValue_=t.maxValue,this.element=e.createElement("div"),this.element.classList.add(Ft()),t.layout==="popup"&&this.element.classList.add(Ft(void 0,"p")),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("div");l.classList.add(Ft("p")),t.viewProps.bindTabIndex(l),this.element.appendChild(l),this.padElement=l;const b=e.createElementNS(Ee,"svg");b.classList.add(Ft("g")),this.padElement.appendChild(b),this.svgElem_=b;const P=e.createElementNS(Ee,"line");P.classList.add(Ft("ax")),P.setAttributeNS(null,"x1","0"),P.setAttributeNS(null,"y1","50%"),P.setAttributeNS(null,"x2","100%"),P.setAttributeNS(null,"y2","50%"),this.svgElem_.appendChild(P);const L=e.createElementNS(Ee,"line");L.classList.add(Ft("ax")),L.setAttributeNS(null,"x1","50%"),L.setAttributeNS(null,"y1","0"),L.setAttributeNS(null,"x2","50%"),L.setAttributeNS(null,"y2","100%"),this.svgElem_.appendChild(L);const U=e.createElementNS(Ee,"line");U.classList.add(Ft("l")),U.setAttributeNS(null,"x1","50%"),U.setAttributeNS(null,"y1","50%"),this.svgElem_.appendChild(U),this.lineElem_=U;const W=e.createElement("div");W.classList.add(Ft("m")),this.padElement.appendChild(W),this.markerElem_=W,t.value.emitter.on("change",this.onValueChange_),this.value=t.value,this.update_()}get allFocusableElements(){return[this.padElement]}update_(){const[e,t]=this.value.rawValue.getComponents(),l=this.maxValue_,b=_e(e,-l,+l,0,100),P=_e(t,-l,+l,0,100),L=this.invertsY_?100-P:P;this.lineElem_.setAttributeNS(null,"x2",`${b}%`),this.lineElem_.setAttributeNS(null,"y2",`${L}%`),this.markerElem_.style.left=`${b}%`,this.markerElem_.style.top=`${L}%`}onValueChange_(){this.update_()}onFoldableChange_(){this.update_()}}function Ao(n,e,t){return[Ie(e[0],He(n)),Ie(e[1],rn(n))*(t?1:-1)]}class Vp{constructor(e,t){this.onPadKeyDown_=this.onPadKeyDown_.bind(this),this.onPadKeyUp_=this.onPadKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.baseSteps_=t.baseSteps,this.maxValue_=t.maxValue,this.invertsY_=t.invertsY,this.view=new Ap(e,{invertsY:this.invertsY_,layout:t.layout,maxValue:this.maxValue_,value:this.value,viewProps:this.viewProps}),this.ptHandler_=new _t(this.view.padElement),this.ptHandler_.emitter.on("down",this.onPointerDown_),this.ptHandler_.emitter.on("move",this.onPointerMove_),this.ptHandler_.emitter.on("up",this.onPointerUp_),this.view.padElement.addEventListener("keydown",this.onPadKeyDown_),this.view.padElement.addEventListener("keyup",this.onPadKeyUp_)}handlePointerEvent_(e,t){if(!e.point)return;const l=this.maxValue_,b=_e(e.point.x,0,e.bounds.width,-l,+l),P=_e(this.invertsY_?e.bounds.height-e.point.y:e.point.y,0,e.bounds.height,-l,+l);this.value.setRawValue(new Nt(b,P),t)}onPointerDown_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerMove_(e){this.handlePointerEvent_(e.data,{forceEmit:!1,last:!1})}onPointerUp_(e){this.handlePointerEvent_(e.data,{forceEmit:!0,last:!0})}onPadKeyDown_(e){An(e.key)&&e.preventDefault();const[t,l]=Ao(e,this.baseSteps_,this.invertsY_);t===0&&l===0||this.value.setRawValue(new Nt(this.value.rawValue.x+t,this.value.rawValue.y+l),{forceEmit:!1,last:!1})}onPadKeyUp_(e){const[t,l]=Ao(e,this.baseSteps_,this.invertsY_);t===0&&l===0||this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}class Ip{constructor(e,t){var l,b;this.onPopupChildBlur_=this.onPopupChildBlur_.bind(this),this.onPopupChildKeydown_=this.onPopupChildKeydown_.bind(this),this.onPadButtonBlur_=this.onPadButtonBlur_.bind(this),this.onPadButtonClick_=this.onPadButtonClick_.bind(this),this.value=t.value,this.viewProps=t.viewProps,this.foldable_=Ve.create(t.expanded),this.popC_=t.pickerLayout==="popup"?new Bi(e,{viewProps:this.viewProps}):null;const P=new Vp(e,{baseSteps:[t.axes[0].baseStep,t.axes[1].baseStep],invertsY:t.invertsY,layout:t.pickerLayout,maxValue:t.maxValue,value:this.value,viewProps:this.viewProps});P.view.allFocusableElements.forEach(L=>{L.addEventListener("blur",this.onPopupChildBlur_),L.addEventListener("keydown",this.onPopupChildKeydown_)}),this.pickerC_=P,this.textC_=new hr(e,{assembly:Lo,axes:t.axes,parser:t.parser,value:this.value,viewProps:this.viewProps}),this.view=new Lp(e,{expanded:this.foldable_.value("expanded"),pickerLayout:t.pickerLayout,viewProps:this.viewProps}),this.view.textElement.appendChild(this.textC_.view.element),(l=this.view.buttonElement)===null||l===void 0||l.addEventListener("blur",this.onPadButtonBlur_),(b=this.view.buttonElement)===null||b===void 0||b.addEventListener("click",this.onPadButtonClick_),this.popC_?(this.view.element.appendChild(this.popC_.view.element),this.popC_.view.element.appendChild(this.pickerC_.view.element),Et({primary:this.foldable_.value("expanded"),secondary:this.popC_.shows,forward:L=>L.rawValue,backward:(L,U)=>U.rawValue})):this.view.pickerElement&&(this.view.pickerElement.appendChild(this.pickerC_.view.element),Oe(this.foldable_,this.view.pickerElement))}onPadButtonBlur_(e){if(!this.popC_)return;const t=this.view.element,l=e.relatedTarget;(!l||!t.contains(l))&&(this.popC_.shows.rawValue=!1)}onPadButtonClick_(){this.foldable_.set("expanded",!this.foldable_.get("expanded")),this.foldable_.get("expanded")&&this.pickerC_.view.allFocusableElements[0].focus()}onPopupChildBlur_(e){if(!this.popC_)return;const t=this.popC_.view.element,l=lt(e);l&&t.contains(l)||l&&l===this.view.buttonElement&&!it(t.ownerDocument)||(this.popC_.shows.rawValue=!1)}onPopupChildKeydown_(e){this.popC_?e.key==="Escape"&&(this.popC_.shows.rawValue=!1):this.view.pickerElement&&e.key==="Escape"&&this.view.buttonElement.focus()}}class On{constructor(e=0,t=0,l=0){this.x=e,this.y=t,this.z=l}getComponents(){return[this.x,this.y,this.z]}static isObject(e){if(w(e))return!1;const t=e.x,l=e.y,b=e.z;return!(typeof t!="number"||typeof l!="number"||typeof b!="number")}static equals(e,t){return e.x===t.x&&e.y===t.y&&e.z===t.z}toObject(){return{x:this.x,y:this.y,z:this.z}}}const Vo={toComponents:n=>n.getComponents(),fromComponents:n=>new On(...n)};function Dp(n){return On.isObject(n)?new On(n.x,n.y,n.z):new On}function Tp(n,e){n.writeProperty("x",e.x),n.writeProperty("y",e.y),n.writeProperty("z",e.z)}function Ep(n,e){return new Bt({assembly:Vo,components:[Ct("x"in n?n.x:void 0,e.x),Ct("y"in n?n.y:void 0,e.y),Ct("z"in n?n.z:void 0,e.z)]})}function dr(n,e){return{baseStep:wt(e),constraint:e,textProps:q.fromObject({draggingScale:yt(e,n),formatter:Le(In(e,n))})}}const Op={id:"input-point3d",type:"input",accept:(n,e)=>{if(!On.isObject(n))return null;const t=V,l=ce(e,{x:t.optional.custom(ot),y:t.optional.custom(ot),z:t.optional.custom(ot)});return l?{initialValue:n,params:l}:null},binding:{reader:n=>Dp,constraint:n=>Ep(n.params,n.initialValue),equals:On.equals,writer:n=>Tp},controller:n=>{const e=n.value,t=n.constraint;if(!(t instanceof Bt))throw I.shouldNeverHappen();return new hr(n.document,{assembly:Vo,axes:[dr(e.rawValue.x,t.components[0]),dr(e.rawValue.y,t.components[1]),dr(e.rawValue.z,t.components[2])],parser:Je,value:e,viewProps:n.viewProps})}};class Bn{constructor(e=0,t=0,l=0,b=0){this.x=e,this.y=t,this.z=l,this.w=b}getComponents(){return[this.x,this.y,this.z,this.w]}static isObject(e){if(w(e))return!1;const t=e.x,l=e.y,b=e.z,P=e.w;return!(typeof t!="number"||typeof l!="number"||typeof b!="number"||typeof P!="number")}static equals(e,t){return e.x===t.x&&e.y===t.y&&e.z===t.z&&e.w===t.w}toObject(){return{x:this.x,y:this.y,z:this.z,w:this.w}}}const Io={toComponents:n=>n.getComponents(),fromComponents:n=>new Bn(...n)};function Bp(n){return Bn.isObject(n)?new Bn(n.x,n.y,n.z,n.w):new Bn}function Np(n,e){n.writeProperty("x",e.x),n.writeProperty("y",e.y),n.writeProperty("z",e.z),n.writeProperty("w",e.w)}function Fp(n,e){return new Bt({assembly:Io,components:[Ct("x"in n?n.x:void 0,e.x),Ct("y"in n?n.y:void 0,e.y),Ct("z"in n?n.z:void 0,e.z),Ct("w"in n?n.w:void 0,e.w)]})}function jp(n,e){return{baseStep:wt(e),constraint:e,textProps:q.fromObject({draggingScale:yt(e,n),formatter:Le(In(e,n))})}}const zp={id:"input-point4d",type:"input",accept:(n,e)=>{if(!Bn.isObject(n))return null;const t=V,l=ce(e,{x:t.optional.custom(ot),y:t.optional.custom(ot),z:t.optional.custom(ot),w:t.optional.custom(ot)});return l?{initialValue:n,params:l}:null},binding:{reader:n=>Bp,constraint:n=>Fp(n.params,n.initialValue),equals:Bn.equals,writer:n=>Np},controller:n=>{const e=n.value,t=n.constraint;if(!(t instanceof Bt))throw I.shouldNeverHappen();return new hr(n.document,{assembly:Io,axes:e.rawValue.getComponents().map((l,b)=>jp(l,t.components[b])),parser:Je,value:e,viewProps:n.viewProps})}};function Up(n){const e=[],t=fi(n.options);return t&&e.push(t),new Ht(e)}const Rp={id:"input-string",type:"input",accept:(n,e)=>{if(typeof n!="string")return null;const l=ce(e,{options:V.optional.custom(ln)});return l?{initialValue:n,params:l}:null},binding:{reader:n=>ai,constraint:n=>Up(n.params),writer:n=>Xe},controller:n=>{const e=n.document,t=n.value,l=n.constraint,b=l&&$e(l,en);return b?new tn(e,{props:new q({options:b.values.value("options")}),value:t,viewProps:n.viewProps}):new Sn(e,{parser:P=>P,props:q.fromObject({formatter:pt}),value:t,viewProps:n.viewProps})}},gi={monitor:{defaultInterval:200,defaultLineCount:3}},Do=N("mll");class Gp{constructor(e,t){this.onValueUpdate_=this.onValueUpdate_.bind(this),this.formatter_=t.formatter,this.element=e.createElement("div"),this.element.classList.add(Do()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("textarea");l.classList.add(Do("i")),l.style.height=`calc(var(--bld-us) * ${t.lineCount})`,l.readOnly=!0,t.viewProps.bindDisabled(l),this.element.appendChild(l),this.textareaElem_=l,t.value.emitter.on("change",this.onValueUpdate_),this.value=t.value,this.update_()}update_(){const e=this.textareaElem_,t=e.scrollTop===e.scrollHeight-e.clientHeight,l=[];this.value.rawValue.forEach(b=>{b!==void 0&&l.push(this.formatter_(b))}),e.textContent=l.join(`
21
+ `),t&&(e.scrollTop=e.scrollHeight)}onValueUpdate_(){this.update_()}}class mr{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.view=new Gp(e,{formatter:t.formatter,lineCount:t.lineCount,value:this.value,viewProps:this.viewProps})}}const To=N("sgl");class Kp{constructor(e,t){this.onValueUpdate_=this.onValueUpdate_.bind(this),this.formatter_=t.formatter,this.element=e.createElement("div"),this.element.classList.add(To()),t.viewProps.bindClassModifiers(this.element);const l=e.createElement("input");l.classList.add(To("i")),l.readOnly=!0,l.type="text",t.viewProps.bindDisabled(l),this.element.appendChild(l),this.inputElement=l,t.value.emitter.on("change",this.onValueUpdate_),this.value=t.value,this.update_()}update_(){const e=this.value.rawValue,t=e[e.length-1];this.inputElement.value=t!==void 0?this.formatter_(t):""}onValueUpdate_(){this.update_()}}class fr{constructor(e,t){this.value=t.value,this.viewProps=t.viewProps,this.view=new Kp(e,{formatter:t.formatter,value:this.value,viewProps:this.viewProps})}}const $p={id:"monitor-bool",type:"monitor",accept:(n,e)=>{if(typeof n!="boolean")return null;const l=ce(e,{lineCount:V.optional.number});return l?{initialValue:n,params:l}:null},binding:{reader:n=>Fi},controller:n=>{var e;return n.value.rawValue.length===1?new fr(n.document,{formatter:ji,value:n.value,viewProps:n.viewProps}):new mr(n.document,{formatter:ji,lineCount:(e=n.params.lineCount)!==null&&e!==void 0?e:gi.monitor.defaultLineCount,value:n.value,viewProps:n.viewProps})}},jt=N("grl");class Xp{constructor(e,t){this.onCursorChange_=this.onCursorChange_.bind(this),this.onValueUpdate_=this.onValueUpdate_.bind(this),this.element=e.createElement("div"),this.element.classList.add(jt()),t.viewProps.bindClassModifiers(this.element),this.formatter_=t.formatter,this.props_=t.props,this.cursor_=t.cursor,this.cursor_.emitter.on("change",this.onCursorChange_);const l=e.createElementNS(Ee,"svg");l.classList.add(jt("g")),l.style.height=`calc(var(--bld-us) * ${t.lineCount})`,this.element.appendChild(l),this.svgElem_=l;const b=e.createElementNS(Ee,"polyline");this.svgElem_.appendChild(b),this.lineElem_=b;const P=e.createElement("div");P.classList.add(jt("t"),N("tt")()),this.element.appendChild(P),this.tooltipElem_=P,t.value.emitter.on("change",this.onValueUpdate_),this.value=t.value,this.update_()}get graphElement(){return this.svgElem_}update_(){const e=this.svgElem_.getBoundingClientRect(),t=this.value.rawValue.length-1,l=this.props_.get("minValue"),b=this.props_.get("maxValue"),P=[];this.value.rawValue.forEach((de,ve)=>{if(de===void 0)return;const dn=_e(ve,0,t,0,e.width),_i=_e(de,l,b,e.height,0);P.push([dn,_i].join(","))}),this.lineElem_.setAttributeNS(null,"points",P.join(" "));const L=this.tooltipElem_,U=this.value.rawValue[this.cursor_.rawValue];if(U===void 0){L.classList.remove(jt("t","a"));return}const W=_e(this.cursor_.rawValue,0,t,0,e.width),H=_e(U,l,b,e.height,0);L.style.left=`${W}px`,L.style.top=`${H}px`,L.textContent=`${this.formatter_(U)}`,L.classList.contains(jt("t","a"))||(L.classList.add(jt("t","a"),jt("t","in")),Qe(L),L.classList.remove(jt("t","in")))}onValueUpdate_(){this.update_()}onCursorChange_(){this.update_()}}class Yp{constructor(e,t){if(this.onGraphMouseMove_=this.onGraphMouseMove_.bind(this),this.onGraphMouseLeave_=this.onGraphMouseLeave_.bind(this),this.onGraphPointerDown_=this.onGraphPointerDown_.bind(this),this.onGraphPointerMove_=this.onGraphPointerMove_.bind(this),this.onGraphPointerUp_=this.onGraphPointerUp_.bind(this),this.props_=t.props,this.value=t.value,this.viewProps=t.viewProps,this.cursor_=ee(-1),this.view=new Xp(e,{cursor:this.cursor_,formatter:t.formatter,lineCount:t.lineCount,props:this.props_,value:this.value,viewProps:this.viewProps}),!it(e))this.view.element.addEventListener("mousemove",this.onGraphMouseMove_),this.view.element.addEventListener("mouseleave",this.onGraphMouseLeave_);else{const l=new _t(this.view.element);l.emitter.on("down",this.onGraphPointerDown_),l.emitter.on("move",this.onGraphPointerMove_),l.emitter.on("up",this.onGraphPointerUp_)}}onGraphMouseLeave_(){this.cursor_.rawValue=-1}onGraphMouseMove_(e){const t=this.view.element.getBoundingClientRect();this.cursor_.rawValue=Math.floor(_e(e.offsetX,0,t.width,0,this.value.rawValue.length))}onGraphPointerDown_(e){this.onGraphPointerMove_(e)}onGraphPointerMove_(e){if(!e.data.point){this.cursor_.rawValue=-1;return}this.cursor_.rawValue=Math.floor(_e(e.data.point.x,0,e.data.bounds.width,0,this.value.rawValue.length))}onGraphPointerUp_(){this.cursor_.rawValue=-1}}function vr(n){return"format"in n&&!w(n.format)?n.format:Le(2)}function qp(n){var e;return n.value.rawValue.length===1?new fr(n.document,{formatter:vr(n.params),value:n.value,viewProps:n.viewProps}):new mr(n.document,{formatter:vr(n.params),lineCount:(e=n.params.lineCount)!==null&&e!==void 0?e:gi.monitor.defaultLineCount,value:n.value,viewProps:n.viewProps})}function Qp(n){var e,t,l;return new Yp(n.document,{formatter:vr(n.params),lineCount:(e=n.params.lineCount)!==null&&e!==void 0?e:gi.monitor.defaultLineCount,props:q.fromObject({maxValue:(t="max"in n.params?n.params.max:null)!==null&&t!==void 0?t:100,minValue:(l="min"in n.params?n.params.min:null)!==null&&l!==void 0?l:0}),value:n.value,viewProps:n.viewProps})}function Eo(n){return"view"in n&&n.view==="graph"}const Zp={id:"monitor-number",type:"monitor",accept:(n,e)=>{if(typeof n!="number")return null;const t=V,l=ce(e,{format:t.optional.function,lineCount:t.optional.number,max:t.optional.number,min:t.optional.number,view:t.optional.string});return l?{initialValue:n,params:l}:null},binding:{defaultBufferSize:n=>Eo(n)?64:1,reader:n=>rt},controller:n=>Eo(n.params)?Qp(n):qp(n)},Wp={id:"monitor-string",type:"monitor",accept:(n,e)=>{if(typeof n!="string")return null;const t=V,l=ce(e,{lineCount:t.optional.number,multiline:t.optional.boolean});return l?{initialValue:n,params:l}:null},binding:{reader:n=>ai},controller:n=>{var e;const t=n.value;return t.rawValue.length>1||"multiline"in n.params&&n.params.multiline?new mr(n.document,{formatter:pt,lineCount:(e=n.params.lineCount)!==null&&e!==void 0?e:gi.monitor.defaultLineCount,value:t,viewProps:n.viewProps}):new fr(n.document,{formatter:pt,value:t,viewProps:n.viewProps})}};function Jp(n,e){var t;const l=n.accept(e.target.read(),e.params);if(w(l))return null;const b=V,P={target:e.target,initialValue:l.initialValue,params:l.params},L=n.binding.reader(P),U=n.binding.constraint?n.binding.constraint(P):void 0,W=ee(L(l.initialValue),{constraint:U,equals:n.binding.equals}),H=new Mn({reader:L,target:e.target,value:W,writer:n.binding.writer(P)}),de=b.optional.boolean(e.params.disabled).value,ve=b.optional.boolean(e.params.hidden).value,dn=n.controller({constraint:U,document:e.document,initialValue:l.initialValue,params:l.params,value:H.value,viewProps:ze.create({disabled:de,hidden:ve})});return new Te(e.document,{binding:H,blade:ye(),props:q.fromObject({label:"label"in e.params?(t=b.optional.string(e.params.label).value)!==null&&t!==void 0?t:null:e.target.key}),valueController:dn})}function Hp(n,e){return e===0?new Di:new ei(n,e??gi.monitor.defaultInterval)}function eu(n,e){var t,l,b;const P=V,L=n.accept(e.target.read(),e.params);if(w(L))return null;const U={target:e.target,initialValue:L.initialValue,params:L.params},W=n.binding.reader(U),H=(l=(t=P.optional.number(e.params.bufferSize).value)!==null&&t!==void 0?t:n.binding.defaultBufferSize&&n.binding.defaultBufferSize(L.params))!==null&&l!==void 0?l:1,de=P.optional.number(e.params.interval).value,ve=new Is({reader:W,target:e.target,ticker:Hp(e.document,de),value:Ti(H)}),dn=P.optional.boolean(e.params.disabled).value,_i=P.optional.boolean(e.params.hidden).value,wi=n.controller({document:e.document,params:L.params,value:ve.value,viewProps:ze.create({disabled:dn,hidden:_i})});return new Ze(e.document,{binding:ve,blade:ye(),props:q.fromObject({label:"label"in e.params?(b=P.optional.string(e.params.label).value)!==null&&b!==void 0?b:null:e.target.key}),valueController:wi})}class tu{constructor(){this.pluginsMap_={blades:[],inputs:[],monitors:[]}}getAll(){return[...this.pluginsMap_.blades,...this.pluginsMap_.inputs,...this.pluginsMap_.monitors]}register(e){e.type==="blade"?this.pluginsMap_.blades.unshift(e):e.type==="input"?this.pluginsMap_.inputs.unshift(e):e.type==="monitor"&&this.pluginsMap_.monitors.unshift(e)}createInput(e,t,l){const b=t.read();if(w(b))throw new I({context:{key:t.key},type:"nomatchingcontroller"});const P=this.pluginsMap_.inputs.reduce((L,U)=>L??Jp(U,{document:e,target:t,params:l}),null);if(P)return P;throw new I({context:{key:t.key},type:"nomatchingcontroller"})}createMonitor(e,t,l){const b=this.pluginsMap_.monitors.reduce((P,L)=>P??eu(L,{document:e,params:l,target:t}),null);if(b)return b;throw new I({context:{key:t.key},type:"nomatchingcontroller"})}createBlade(e,t){const l=this.pluginsMap_.blades.reduce((b,P)=>b??Vs(P,{document:e,params:t}),null);if(!l)throw new I({type:"nomatchingview",context:{params:t}});return l}createBladeApi(e){if(e instanceof Te)return new Xn(e);if(e instanceof Ze)return new Yn(e);if(e instanceof Zt)return new xn(e,this);const t=this.pluginsMap_.blades.reduce((l,b)=>l??b.api({controller:e,pool:this}),null);if(!t)throw I.shouldNeverHappen();return t}}function nu(){const n=new tu;return[lu,Op,zp,Rp,Sp,xp,yp,bp,Dn,$p,Wp,Zp,J,Ms,Ss,Hn].forEach(e=>{n.register(e)}),n}function iu(n){return Nt.isObject(n)?new Nt(n.x,n.y):new Nt}function su(n,e){n.writeProperty("x",e.x),n.writeProperty("y",e.y)}function Ct(n,e){if(!n)return;const t=[],l=ko(n,e);l&&t.push(l);const b=So(n);return b&&t.push(b),new Ht(t)}function ru(n,e){return new Bt({assembly:Lo,components:[Ct("x"in n?n.x:void 0,e.x),Ct("y"in n?n.y:void 0,e.y)]})}function Oo(n,e){const[t,l]=n?Mp(n):[];if(!w(t)||!w(l))return Math.max(Math.abs(t??0),Math.abs(l??0));const b=wt(n);return Math.max(Math.abs(b)*10,Math.abs(e)*10)}function ou(n,e){const t=e instanceof Bt?e.components[0]:void 0,l=e instanceof Bt?e.components[1]:void 0,b=Oo(t,n.x),P=Oo(l,n.y);return Math.max(b,P)}function Bo(n,e){return{baseStep:wt(e),constraint:e,textProps:q.fromObject({draggingScale:yt(e,n),formatter:Le(In(e,n))})}}function au(n){if(!("y"in n))return!1;const e=n.y;return e&&"inverted"in e?!!e.inverted:!1}const lu={id:"input-point2d",type:"input",accept:(n,e)=>{if(!Nt.isObject(n))return null;const t=V,l=ce(e,{expanded:t.optional.boolean,picker:t.optional.custom(mi),x:t.optional.custom(ot),y:t.optional.object({inverted:t.optional.boolean,max:t.optional.number,min:t.optional.number,step:t.optional.number})});return l?{initialValue:n,params:l}:null},binding:{reader:n=>iu,constraint:n=>ru(n.params,n.initialValue),equals:Nt.equals,writer:n=>su},controller:n=>{const e=n.document,t=n.value,l=n.constraint;if(!(l instanceof Bt))throw I.shouldNeverHappen();const b="expanded"in n.params?n.params.expanded:void 0,P="picker"in n.params?n.params.picker:void 0;return new Ip(e,{axes:[Bo(t.rawValue.x,l.components[0]),Bo(t.rawValue.y,l.components[1])],expanded:b??!1,invertsY:au(n.params),maxValue:ou(t.rawValue,l),parser:Je,pickerLayout:P??"popup",value:t,viewProps:n.viewProps})}};class No extends a{constructor(e){super(e),this.emitter_=new z,this.controller_.valueController.value.emitter.on("change",t=>{this.emitter_.emit("change",{event:new u(this,t.rawValue)})})}get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}get options(){return this.controller_.valueController.props.get("options")}set options(e){this.controller_.valueController.props.set("options",e)}get value(){return this.controller_.valueController.value.rawValue}set value(e){this.controller_.valueController.value.rawValue=e}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}}class Fo extends a{constructor(e){super(e),this.emitter_=new z,this.controller_.valueController.value.emitter.on("change",t=>{this.emitter_.emit("change",{event:new u(this,t.rawValue)})})}get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}get maxValue(){return this.controller_.valueController.sliderController.props.get("maxValue")}set maxValue(e){this.controller_.valueController.sliderController.props.set("maxValue",e)}get minValue(){return this.controller_.valueController.sliderController.props.get("minValue")}set minValue(e){this.controller_.valueController.sliderController.props.set("minValue",e)}get value(){return this.controller_.valueController.value.rawValue}set value(e){this.controller_.valueController.value.rawValue=e}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}}class jo extends a{constructor(e){super(e),this.emitter_=new z,this.controller_.valueController.value.emitter.on("change",t=>{this.emitter_.emit("change",{event:new u(this,t.rawValue)})})}get label(){return this.controller_.props.get("label")}set label(e){this.controller_.props.set("label",e)}get formatter(){return this.controller_.valueController.props.get("formatter")}set formatter(e){this.controller_.valueController.props.set("formatter",e)}get value(){return this.controller_.valueController.value.rawValue}set value(e){this.controller_.valueController.value.rawValue=e}on(e,t){const l=t.bind(this);return this.emitter_.on(e,b=>{l(b.event)}),this}}const cu=function(){return{id:"list",type:"blade",accept(n){const e=V,t=ce(n,{options:e.required.custom(ln),value:e.required.raw,view:e.required.constant("list"),label:e.optional.string});return t?{params:t}:null},controller(n){const e=new en(Qi(n.params.options)),t=ee(n.params.value,{constraint:e}),l=new tn(n.document,{props:new q({options:e.values.value("options")}),value:t,viewProps:n.viewProps});return new Lt(n.document,{blade:n.blade,props:q.fromObject({label:n.params.label}),valueController:l})},api(n){return!(n.controller instanceof Lt)||!(n.controller.valueController instanceof tn)?null:new No(n.controller)}}}();function pu(n){return n.reduce((e,t)=>Object.assign(e,{[t.presetKey]:t.read()}),{})}function uu(n,e){n.forEach(t=>{const l=e[t.target.presetKey];l!==void 0&&t.writer(t.target,t.reader(l))})}class hu extends qn{constructor(e,t){super(e,t)}get element(){return this.controller_.view.element}importPreset(e){const t=this.controller_.rackController.rack.find(Te).map(l=>l.binding);uu(t,e),this.refresh()}exportPreset(){const e=this.controller_.rackController.rack.find(Te).map(t=>t.binding.target);return pu(e)}refresh(){this.controller_.rackController.rack.find(Te).forEach(e=>{e.binding.read()}),this.controller_.rackController.rack.find(Ze).forEach(e=>{e.binding.read()})}}class du extends Cn{constructor(e,t){super(e,{expanded:t.expanded,blade:t.blade,props:t.props,root:!0,viewProps:t.viewProps})}}const mu={id:"slider",type:"blade",accept(n){const e=V,t=ce(n,{max:e.required.number,min:e.required.number,view:e.required.constant("slider"),format:e.optional.function,label:e.optional.string,value:e.optional.number});return t?{params:t}:null},controller(n){var e,t;const l=(e=n.params.value)!==null&&e!==void 0?e:0,b=new Dt({max:n.params.max,min:n.params.min}),P=new Vn(n.document,{baseStep:1,parser:Je,sliderProps:new q({maxValue:b.values.value("max"),minValue:b.values.value("min")}),textProps:q.fromObject({draggingScale:yt(void 0,l),formatter:(t=n.params.format)!==null&&t!==void 0?t:Qs}),value:ee(l,{constraint:b}),viewProps:n.viewProps});return new Lt(n.document,{blade:n.blade,props:q.fromObject({label:n.params.label}),valueController:P})},api(n){return!(n.controller instanceof Lt)||!(n.controller.valueController instanceof Vn)?null:new Fo(n.controller)}},fu=function(){return{id:"text",type:"blade",accept(n){const e=V,t=ce(n,{parse:e.required.function,value:e.required.raw,view:e.required.constant("text"),format:e.optional.function,label:e.optional.string});return t?{params:t}:null},controller(n){var e;const t=new Sn(n.document,{parser:n.params.parse,props:q.fromObject({formatter:(e=n.params.format)!==null&&e!==void 0?e:l=>String(l)}),value:ee(n.params.value),viewProps:n.viewProps});return new Lt(n.document,{blade:n.blade,props:q.fromObject({label:n.params.label}),valueController:t})},api(n){return!(n.controller instanceof Lt)||!(n.controller.valueController instanceof Sn)?null:new jo(n.controller)}}}();function vu(n){const e=n.createElement("div");return e.classList.add(N("dfw")()),n.body&&n.body.appendChild(e),e}function zo(n,e,t){if(n.querySelector(`style[data-tp-style=${e}]`))return;const l=n.createElement("style");l.dataset.tpStyle=e,l.textContent=t,n.head.appendChild(l)}class bu extends hu{constructor(e){var t,l;const b=e??{},P=(t=b.document)!==null&&t!==void 0?t:Kn(),L=nu(),U=new du(P,{expanded:b.expanded,blade:ye(),props:q.fromObject({title:b.title}),viewProps:ze.create()});super(U,L),this.pool_=L,this.containerElem_=(l=b.container)!==null&&l!==void 0?l:vu(P),this.containerElem_.appendChild(this.element),this.doc_=P,this.usesDefaultWrapper_=!b.container,this.setUpDefaultPlugins_()}get document(){if(!this.doc_)throw I.alreadyDisposed();return this.doc_}dispose(){const e=this.containerElem_;if(!e)throw I.alreadyDisposed();if(this.usesDefaultWrapper_){const t=e.parentElement;t&&t.removeChild(e)}this.containerElem_=null,this.doc_=null,super.dispose()}registerPlugin(e){("plugin"in e?[e.plugin]:"plugins"in e?e.plugins:[]).forEach(l=>{this.pool_.register(l),this.embedPluginStyle_(l)})}embedPluginStyle_(e){e.css&&zo(this.document,`plugin-${e.id}`,e.css)}setUpDefaultPlugins_(){zo(this.document,"default",'.tp-tbiv_b,.tp-coltxtv_ms,.tp-ckbv_i,.tp-rotv_b,.tp-fldv_b,.tp-mllv_i,.tp-sglv_i,.tp-grlv_g,.tp-txtv_i,.tp-p2dpv_p,.tp-colswv_sw,.tp-p2dv_b,.tp-btnv_b,.tp-lstv_s{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:rgba(0,0,0,0);border-width:0;font-family:inherit;font-size:inherit;font-weight:inherit;margin:0;outline:none;padding:0}.tp-p2dv_b,.tp-btnv_b,.tp-lstv_s{background-color:var(--btn-bg);border-radius:var(--elm-br);color:var(--btn-fg);cursor:pointer;display:block;font-weight:bold;height:var(--bld-us);line-height:var(--bld-us);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-p2dv_b:hover,.tp-btnv_b:hover,.tp-lstv_s:hover{background-color:var(--btn-bg-h)}.tp-p2dv_b:focus,.tp-btnv_b:focus,.tp-lstv_s:focus{background-color:var(--btn-bg-f)}.tp-p2dv_b:active,.tp-btnv_b:active,.tp-lstv_s:active{background-color:var(--btn-bg-a)}.tp-p2dv_b:disabled,.tp-btnv_b:disabled,.tp-lstv_s:disabled{opacity:.5}.tp-txtv_i,.tp-p2dpv_p,.tp-colswv_sw{background-color:var(--in-bg);border-radius:var(--elm-br);box-sizing:border-box;color:var(--in-fg);font-family:inherit;height:var(--bld-us);line-height:var(--bld-us);min-width:0;width:100%}.tp-txtv_i:hover,.tp-p2dpv_p:hover,.tp-colswv_sw:hover{background-color:var(--in-bg-h)}.tp-txtv_i:focus,.tp-p2dpv_p:focus,.tp-colswv_sw:focus{background-color:var(--in-bg-f)}.tp-txtv_i:active,.tp-p2dpv_p:active,.tp-colswv_sw:active{background-color:var(--in-bg-a)}.tp-txtv_i:disabled,.tp-p2dpv_p:disabled,.tp-colswv_sw:disabled{opacity:.5}.tp-mllv_i,.tp-sglv_i,.tp-grlv_g{background-color:var(--mo-bg);border-radius:var(--elm-br);box-sizing:border-box;color:var(--mo-fg);height:var(--bld-us);scrollbar-color:currentColor rgba(0,0,0,0);scrollbar-width:thin;width:100%}.tp-mllv_i::-webkit-scrollbar,.tp-sglv_i::-webkit-scrollbar,.tp-grlv_g::-webkit-scrollbar{height:8px;width:8px}.tp-mllv_i::-webkit-scrollbar-corner,.tp-sglv_i::-webkit-scrollbar-corner,.tp-grlv_g::-webkit-scrollbar-corner{background-color:rgba(0,0,0,0)}.tp-mllv_i::-webkit-scrollbar-thumb,.tp-sglv_i::-webkit-scrollbar-thumb,.tp-grlv_g::-webkit-scrollbar-thumb{background-clip:padding-box;background-color:currentColor;border:rgba(0,0,0,0) solid 2px;border-radius:4px}.tp-rotv{--font-family: var(--tp-font-family, Roboto Mono, Source Code Pro, Menlo, Courier, monospace);--bs-br: var(--tp-base-border-radius, 6px);--cnt-h-p: var(--tp-container-horizontal-padding, 4px);--cnt-v-p: var(--tp-container-vertical-padding, 4px);--elm-br: var(--tp-element-border-radius, 2px);--bld-s: var(--tp-blade-spacing, 4px);--bld-us: var(--tp-blade-unit-size, 20px);--bs-bg: var(--tp-base-background-color, hsl(230, 7%, 17%));--bs-sh: var(--tp-base-shadow-color, rgba(0, 0, 0, 0.2));--btn-bg: var(--tp-button-background-color, hsl(230, 7%, 70%));--btn-bg-a: var(--tp-button-background-color-active, #d6d7db);--btn-bg-f: var(--tp-button-background-color-focus, #c8cad0);--btn-bg-h: var(--tp-button-background-color-hover, #bbbcc4);--btn-fg: var(--tp-button-foreground-color, hsl(230, 7%, 17%));--cnt-bg: var(--tp-container-background-color, rgba(187, 188, 196, 0.1));--cnt-bg-a: var(--tp-container-background-color-active, rgba(187, 188, 196, 0.25));--cnt-bg-f: var(--tp-container-background-color-focus, rgba(187, 188, 196, 0.2));--cnt-bg-h: var(--tp-container-background-color-hover, rgba(187, 188, 196, 0.15));--cnt-fg: var(--tp-container-foreground-color, hsl(230, 7%, 75%));--in-bg: var(--tp-input-background-color, rgba(187, 188, 196, 0.1));--in-bg-a: var(--tp-input-background-color-active, rgba(187, 188, 196, 0.25));--in-bg-f: var(--tp-input-background-color-focus, rgba(187, 188, 196, 0.2));--in-bg-h: var(--tp-input-background-color-hover, rgba(187, 188, 196, 0.15));--in-fg: var(--tp-input-foreground-color, hsl(230, 7%, 75%));--lbl-fg: var(--tp-label-foreground-color, rgba(187, 188, 196, 0.7));--mo-bg: var(--tp-monitor-background-color, rgba(0, 0, 0, 0.2));--mo-fg: var(--tp-monitor-foreground-color, rgba(187, 188, 196, 0.7));--grv-fg: var(--tp-groove-foreground-color, rgba(187, 188, 196, 0.1))}.tp-rotv_c>.tp-cntv.tp-v-lst,.tp-tabv_c .tp-brkv>.tp-cntv.tp-v-lst,.tp-fldv_c>.tp-cntv.tp-v-lst{margin-bottom:calc(-1*var(--cnt-v-p))}.tp-rotv_c>.tp-fldv.tp-v-lst .tp-fldv_c,.tp-tabv_c .tp-brkv>.tp-fldv.tp-v-lst .tp-fldv_c,.tp-fldv_c>.tp-fldv.tp-v-lst .tp-fldv_c{border-bottom-left-radius:0}.tp-rotv_c>.tp-fldv.tp-v-lst .tp-fldv_b,.tp-tabv_c .tp-brkv>.tp-fldv.tp-v-lst .tp-fldv_b,.tp-fldv_c>.tp-fldv.tp-v-lst .tp-fldv_b{border-bottom-left-radius:0}.tp-rotv_c>*:not(.tp-v-fst),.tp-tabv_c .tp-brkv>*:not(.tp-v-fst),.tp-fldv_c>*:not(.tp-v-fst){margin-top:var(--bld-s)}.tp-rotv_c>.tp-sprv:not(.tp-v-fst),.tp-tabv_c .tp-brkv>.tp-sprv:not(.tp-v-fst),.tp-fldv_c>.tp-sprv:not(.tp-v-fst),.tp-rotv_c>.tp-cntv:not(.tp-v-fst),.tp-tabv_c .tp-brkv>.tp-cntv:not(.tp-v-fst),.tp-fldv_c>.tp-cntv:not(.tp-v-fst){margin-top:var(--cnt-v-p)}.tp-rotv_c>.tp-sprv+*:not(.tp-v-hidden),.tp-tabv_c .tp-brkv>.tp-sprv+*:not(.tp-v-hidden),.tp-fldv_c>.tp-sprv+*:not(.tp-v-hidden),.tp-rotv_c>.tp-cntv+*:not(.tp-v-hidden),.tp-tabv_c .tp-brkv>.tp-cntv+*:not(.tp-v-hidden),.tp-fldv_c>.tp-cntv+*:not(.tp-v-hidden){margin-top:var(--cnt-v-p)}.tp-rotv_c>.tp-sprv:not(.tp-v-hidden)+.tp-sprv,.tp-tabv_c .tp-brkv>.tp-sprv:not(.tp-v-hidden)+.tp-sprv,.tp-fldv_c>.tp-sprv:not(.tp-v-hidden)+.tp-sprv,.tp-rotv_c>.tp-cntv:not(.tp-v-hidden)+.tp-cntv,.tp-tabv_c .tp-brkv>.tp-cntv:not(.tp-v-hidden)+.tp-cntv,.tp-fldv_c>.tp-cntv:not(.tp-v-hidden)+.tp-cntv{margin-top:0}.tp-tabv_c .tp-brkv>.tp-cntv,.tp-fldv_c>.tp-cntv{margin-left:4px}.tp-tabv_c .tp-brkv>.tp-fldv>.tp-fldv_b,.tp-fldv_c>.tp-fldv>.tp-fldv_b{border-top-left-radius:var(--elm-br);border-bottom-left-radius:var(--elm-br)}.tp-tabv_c .tp-brkv>.tp-fldv.tp-fldv-expanded>.tp-fldv_b,.tp-fldv_c>.tp-fldv.tp-fldv-expanded>.tp-fldv_b{border-bottom-left-radius:0}.tp-tabv_c .tp-brkv .tp-fldv>.tp-fldv_c,.tp-fldv_c .tp-fldv>.tp-fldv_c{border-bottom-left-radius:var(--elm-br)}.tp-tabv_c .tp-brkv>.tp-cntv+.tp-fldv>.tp-fldv_b,.tp-fldv_c>.tp-cntv+.tp-fldv>.tp-fldv_b{border-top-left-radius:0}.tp-tabv_c .tp-brkv>.tp-cntv+.tp-tabv>.tp-tabv_t,.tp-fldv_c>.tp-cntv+.tp-tabv>.tp-tabv_t{border-top-left-radius:0}.tp-tabv_c .tp-brkv>.tp-tabv>.tp-tabv_t,.tp-fldv_c>.tp-tabv>.tp-tabv_t{border-top-left-radius:var(--elm-br)}.tp-tabv_c .tp-brkv .tp-tabv>.tp-tabv_c,.tp-fldv_c .tp-tabv>.tp-tabv_c{border-bottom-left-radius:var(--elm-br)}.tp-rotv_b,.tp-fldv_b{background-color:var(--cnt-bg);color:var(--cnt-fg);cursor:pointer;display:block;height:calc(var(--bld-us) + 4px);line-height:calc(var(--bld-us) + 4px);overflow:hidden;padding-left:var(--cnt-h-p);padding-right:calc(4px + var(--bld-us) + var(--cnt-h-p));position:relative;text-align:left;text-overflow:ellipsis;white-space:nowrap;width:100%;transition:border-radius .2s ease-in-out .2s}.tp-rotv_b:hover,.tp-fldv_b:hover{background-color:var(--cnt-bg-h)}.tp-rotv_b:focus,.tp-fldv_b:focus{background-color:var(--cnt-bg-f)}.tp-rotv_b:active,.tp-fldv_b:active{background-color:var(--cnt-bg-a)}.tp-rotv_b:disabled,.tp-fldv_b:disabled{opacity:.5}.tp-rotv_m,.tp-fldv_m{background:linear-gradient(to left, var(--cnt-fg), var(--cnt-fg) 2px, transparent 2px, transparent 4px, var(--cnt-fg) 4px);border-radius:2px;bottom:0;content:"";display:block;height:6px;right:calc(var(--cnt-h-p) + (var(--bld-us) + 4px - 6px)/2 - 2px);margin:auto;opacity:.5;position:absolute;top:0;transform:rotate(90deg);transition:transform .2s ease-in-out;width:6px}.tp-rotv.tp-rotv-expanded .tp-rotv_m,.tp-fldv.tp-fldv-expanded>.tp-fldv_b>.tp-fldv_m{transform:none}.tp-rotv_c,.tp-fldv_c{box-sizing:border-box;height:0;opacity:0;overflow:hidden;padding-bottom:0;padding-top:0;position:relative;transition:height .2s ease-in-out,opacity .2s linear,padding .2s ease-in-out}.tp-rotv.tp-rotv-cpl:not(.tp-rotv-expanded) .tp-rotv_c,.tp-fldv.tp-fldv-cpl:not(.tp-fldv-expanded)>.tp-fldv_c{display:none}.tp-rotv.tp-rotv-expanded .tp-rotv_c,.tp-fldv.tp-fldv-expanded>.tp-fldv_c{opacity:1;padding-bottom:var(--cnt-v-p);padding-top:var(--cnt-v-p);transform:none;overflow:visible;transition:height .2s ease-in-out,opacity .2s linear .2s,padding .2s ease-in-out}.tp-lstv,.tp-coltxtv_m{position:relative}.tp-lstv_s{padding:0 20px 0 4px;width:100%}.tp-lstv_m,.tp-coltxtv_mm{bottom:0;margin:auto;pointer-events:none;position:absolute;right:2px;top:0}.tp-lstv_m svg,.tp-coltxtv_mm svg{bottom:0;height:16px;margin:auto;position:absolute;right:0;top:0;width:16px}.tp-lstv_m svg path,.tp-coltxtv_mm svg path{fill:currentColor}.tp-pndtxtv,.tp-coltxtv_w{display:flex}.tp-pndtxtv_a,.tp-coltxtv_c{width:100%}.tp-pndtxtv_a+.tp-pndtxtv_a,.tp-coltxtv_c+.tp-pndtxtv_a,.tp-pndtxtv_a+.tp-coltxtv_c,.tp-coltxtv_c+.tp-coltxtv_c{margin-left:2px}.tp-btnv_b{width:100%}.tp-btnv_t{text-align:center}.tp-ckbv_l{display:block;position:relative}.tp-ckbv_i{left:0;opacity:0;position:absolute;top:0}.tp-ckbv_w{background-color:var(--in-bg);border-radius:var(--elm-br);cursor:pointer;display:block;height:var(--bld-us);position:relative;width:var(--bld-us)}.tp-ckbv_w svg{bottom:0;display:block;height:16px;left:0;margin:auto;opacity:0;position:absolute;right:0;top:0;width:16px}.tp-ckbv_w svg path{fill:none;stroke:var(--in-fg);stroke-width:2}.tp-ckbv_i:hover+.tp-ckbv_w{background-color:var(--in-bg-h)}.tp-ckbv_i:focus+.tp-ckbv_w{background-color:var(--in-bg-f)}.tp-ckbv_i:active+.tp-ckbv_w{background-color:var(--in-bg-a)}.tp-ckbv_i:checked+.tp-ckbv_w svg{opacity:1}.tp-ckbv.tp-v-disabled .tp-ckbv_w{opacity:.5}.tp-colv{position:relative}.tp-colv_h{display:flex}.tp-colv_s{flex-grow:0;flex-shrink:0;width:var(--bld-us)}.tp-colv_t{flex:1;margin-left:4px}.tp-colv_p{height:0;margin-top:0;opacity:0;overflow:hidden;transition:height .2s ease-in-out,opacity .2s linear,margin .2s ease-in-out}.tp-colv.tp-colv-cpl .tp-colv_p{overflow:visible}.tp-colv.tp-colv-expanded .tp-colv_p{margin-top:var(--bld-s);opacity:1}.tp-colv .tp-popv{left:calc(-1*var(--cnt-h-p));right:calc(-1*var(--cnt-h-p));top:var(--bld-us)}.tp-colpv_h,.tp-colpv_ap{margin-left:6px;margin-right:6px}.tp-colpv_h{margin-top:var(--bld-s)}.tp-colpv_rgb{display:flex;margin-top:var(--bld-s);width:100%}.tp-colpv_a{display:flex;margin-top:var(--cnt-v-p);padding-top:calc(var(--cnt-v-p) + 2px);position:relative}.tp-colpv_a::before{background-color:var(--grv-fg);content:"";height:2px;left:calc(-1*var(--cnt-h-p));position:absolute;right:calc(-1*var(--cnt-h-p));top:0}.tp-colpv.tp-v-disabled .tp-colpv_a::before{opacity:.5}.tp-colpv_ap{align-items:center;display:flex;flex:3}.tp-colpv_at{flex:1;margin-left:4px}.tp-svpv{border-radius:var(--elm-br);outline:none;overflow:hidden;position:relative}.tp-svpv.tp-v-disabled{opacity:.5}.tp-svpv_c{cursor:crosshair;display:block;height:calc(var(--bld-us)*4);width:100%}.tp-svpv_m{border-radius:100%;border:rgba(255,255,255,.75) solid 2px;box-sizing:border-box;filter:drop-shadow(0 0 1px rgba(0, 0, 0, 0.3));height:12px;margin-left:-6px;margin-top:-6px;pointer-events:none;position:absolute;width:12px}.tp-svpv:focus .tp-svpv_m{border-color:#fff}.tp-hplv{cursor:pointer;height:var(--bld-us);outline:none;position:relative}.tp-hplv.tp-v-disabled{opacity:.5}.tp-hplv_c{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAAABCAYAAABubagXAAAAQ0lEQVQoU2P8z8Dwn0GCgQEDi2OK/RBgYHjBgIpfovFh8j8YBIgzFGQxuqEgPhaDOT5gOhPkdCxOZeBg+IDFZZiGAgCaSSMYtcRHLgAAAABJRU5ErkJggg==);background-position:left top;background-repeat:no-repeat;background-size:100% 100%;border-radius:2px;display:block;height:4px;left:0;margin-top:-2px;position:absolute;top:50%;width:100%}.tp-hplv_m{border-radius:var(--elm-br);border:rgba(255,255,255,.75) solid 2px;box-shadow:0 0 2px rgba(0,0,0,.1);box-sizing:border-box;height:12px;left:50%;margin-left:-6px;margin-top:-6px;pointer-events:none;position:absolute;top:50%;width:12px}.tp-hplv:focus .tp-hplv_m{border-color:#fff}.tp-aplv{cursor:pointer;height:var(--bld-us);outline:none;position:relative;width:100%}.tp-aplv.tp-v-disabled{opacity:.5}.tp-aplv_b{background-color:#fff;background-image:linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%),linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%);background-size:4px 4px;background-position:0 0,2px 2px;border-radius:2px;display:block;height:4px;left:0;margin-top:-2px;overflow:hidden;position:absolute;top:50%;width:100%}.tp-aplv_c{bottom:0;left:0;position:absolute;right:0;top:0}.tp-aplv_m{background-color:#fff;background-image:linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%),linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%);background-size:12px 12px;background-position:0 0,6px 6px;border-radius:var(--elm-br);box-shadow:0 0 2px rgba(0,0,0,.1);height:12px;left:50%;margin-left:-6px;margin-top:-6px;overflow:hidden;pointer-events:none;position:absolute;top:50%;width:12px}.tp-aplv_p{border-radius:var(--elm-br);border:rgba(255,255,255,.75) solid 2px;box-sizing:border-box;bottom:0;left:0;position:absolute;right:0;top:0}.tp-aplv:focus .tp-aplv_p{border-color:#fff}.tp-colswv{background-color:#fff;background-image:linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%),linear-gradient(to top right, #ddd 25%, transparent 25%, transparent 75%, #ddd 75%);background-size:10px 10px;background-position:0 0,5px 5px;border-radius:var(--elm-br);overflow:hidden}.tp-colswv.tp-v-disabled{opacity:.5}.tp-colswv_sw{border-radius:0}.tp-colswv_b{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:rgba(0,0,0,0);border-width:0;cursor:pointer;display:block;height:var(--bld-us);left:0;margin:0;outline:none;padding:0;position:absolute;top:0;width:var(--bld-us)}.tp-colswv_b:focus::after{border:rgba(255,255,255,.75) solid 2px;border-radius:var(--elm-br);bottom:0;content:"";display:block;left:0;position:absolute;right:0;top:0}.tp-coltxtv{display:flex;width:100%}.tp-coltxtv_m{margin-right:4px}.tp-coltxtv_ms{border-radius:var(--elm-br);color:var(--lbl-fg);cursor:pointer;height:var(--bld-us);line-height:var(--bld-us);padding:0 18px 0 4px}.tp-coltxtv_ms:hover{background-color:var(--in-bg-h)}.tp-coltxtv_ms:focus{background-color:var(--in-bg-f)}.tp-coltxtv_ms:active{background-color:var(--in-bg-a)}.tp-coltxtv_mm{color:var(--lbl-fg)}.tp-coltxtv.tp-v-disabled .tp-coltxtv_mm{opacity:.5}.tp-coltxtv_w{flex:1}.tp-dfwv{position:absolute;top:8px;right:8px;width:256px}.tp-fldv{position:relative}.tp-fldv.tp-fldv-not .tp-fldv_b{display:none}.tp-fldv_t{padding-left:4px}.tp-fldv_b:disabled .tp-fldv_m{display:none}.tp-fldv_c{padding-left:4px}.tp-fldv_i{bottom:0;color:var(--cnt-bg);left:0;overflow:hidden;position:absolute;top:calc(var(--bld-us) + 4px);width:var(--bs-br)}.tp-fldv_i::before{background-color:currentColor;bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.tp-fldv_b:hover+.tp-fldv_i{color:var(--cnt-bg-h)}.tp-fldv_b:focus+.tp-fldv_i{color:var(--cnt-bg-f)}.tp-fldv_b:active+.tp-fldv_i{color:var(--cnt-bg-a)}.tp-fldv.tp-v-disabled>.tp-fldv_i{opacity:.5}.tp-grlv{position:relative}.tp-grlv_g{display:block;height:calc(var(--bld-us)*3)}.tp-grlv_g polyline{fill:none;stroke:var(--mo-fg);stroke-linejoin:round}.tp-grlv_t{margin-top:-4px;transition:left .05s,top .05s;visibility:hidden}.tp-grlv_t.tp-grlv_t-a{visibility:visible}.tp-grlv_t.tp-grlv_t-in{transition:none}.tp-grlv.tp-v-disabled .tp-grlv_g{opacity:.5}.tp-grlv .tp-ttv{background-color:var(--mo-fg)}.tp-grlv .tp-ttv::before{border-top-color:var(--mo-fg)}.tp-lblv{align-items:center;display:flex;line-height:1.3;padding-left:var(--cnt-h-p);padding-right:var(--cnt-h-p)}.tp-lblv.tp-lblv-nol{display:block}.tp-lblv_l{color:var(--lbl-fg);flex:1;-webkit-hyphens:auto;hyphens:auto;overflow:hidden;padding-left:4px;padding-right:16px}.tp-lblv.tp-v-disabled .tp-lblv_l{opacity:.5}.tp-lblv.tp-lblv-nol .tp-lblv_l{display:none}.tp-lblv_v{align-self:flex-start;flex-grow:0;flex-shrink:0;width:160px}.tp-lblv.tp-lblv-nol .tp-lblv_v{width:100%}.tp-lstv_s{padding:0 20px 0 4px;width:100%}.tp-lstv_m{color:var(--btn-fg)}.tp-sglv_i{padding:0 4px}.tp-sglv.tp-v-disabled .tp-sglv_i{opacity:.5}.tp-mllv_i{display:block;height:calc(var(--bld-us)*3);line-height:var(--bld-us);padding:0 4px;resize:none;white-space:pre}.tp-mllv.tp-v-disabled .tp-mllv_i{opacity:.5}.tp-p2dv{position:relative}.tp-p2dv_h{display:flex}.tp-p2dv_b{height:var(--bld-us);margin-right:4px;position:relative;width:var(--bld-us)}.tp-p2dv_b svg{display:block;height:16px;left:50%;margin-left:-8px;margin-top:-8px;position:absolute;top:50%;width:16px}.tp-p2dv_b svg path{stroke:currentColor;stroke-width:2}.tp-p2dv_b svg circle{fill:currentColor}.tp-p2dv_t{flex:1}.tp-p2dv_p{height:0;margin-top:0;opacity:0;overflow:hidden;transition:height .2s ease-in-out,opacity .2s linear,margin .2s ease-in-out}.tp-p2dv.tp-p2dv-expanded .tp-p2dv_p{margin-top:var(--bld-s);opacity:1}.tp-p2dv .tp-popv{left:calc(-1*var(--cnt-h-p));right:calc(-1*var(--cnt-h-p));top:var(--bld-us)}.tp-p2dpv{padding-left:calc(var(--bld-us) + 4px)}.tp-p2dpv_p{cursor:crosshair;height:0;overflow:hidden;padding-bottom:100%;position:relative}.tp-p2dpv.tp-v-disabled .tp-p2dpv_p{opacity:.5}.tp-p2dpv_g{display:block;height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.tp-p2dpv_ax{opacity:.1;stroke:var(--in-fg);stroke-dasharray:1}.tp-p2dpv_l{opacity:.5;stroke:var(--in-fg);stroke-dasharray:1}.tp-p2dpv_m{border:var(--in-fg) solid 1px;border-radius:50%;box-sizing:border-box;height:4px;margin-left:-2px;margin-top:-2px;position:absolute;width:4px}.tp-p2dpv_p:focus .tp-p2dpv_m{background-color:var(--in-fg);border-width:0}.tp-popv{background-color:var(--bs-bg);border-radius:6px;box-shadow:0 2px 4px var(--bs-sh);display:none;max-width:168px;padding:var(--cnt-v-p) var(--cnt-h-p);position:absolute;visibility:hidden;z-index:1000}.tp-popv.tp-popv-v{display:block;visibility:visible}.tp-sprv_r{background-color:var(--grv-fg);border-width:0;display:block;height:2px;margin:0;width:100%}.tp-sprv.tp-v-disabled .tp-sprv_r{opacity:.5}.tp-sldv.tp-v-disabled{opacity:.5}.tp-sldv_t{box-sizing:border-box;cursor:pointer;height:var(--bld-us);margin:0 6px;outline:none;position:relative}.tp-sldv_t::before{background-color:var(--in-bg);border-radius:1px;bottom:0;content:"";display:block;height:2px;left:0;margin:auto;position:absolute;right:0;top:0}.tp-sldv_k{height:100%;left:0;position:absolute;top:0}.tp-sldv_k::before{background-color:var(--in-fg);border-radius:1px;bottom:0;content:"";display:block;height:2px;left:0;margin-bottom:auto;margin-top:auto;position:absolute;right:0;top:0}.tp-sldv_k::after{background-color:var(--btn-bg);border-radius:var(--elm-br);bottom:0;content:"";display:block;height:12px;margin-bottom:auto;margin-top:auto;position:absolute;right:-6px;top:0;width:12px}.tp-sldv_t:hover .tp-sldv_k::after{background-color:var(--btn-bg-h)}.tp-sldv_t:focus .tp-sldv_k::after{background-color:var(--btn-bg-f)}.tp-sldv_t:active .tp-sldv_k::after{background-color:var(--btn-bg-a)}.tp-sldtxtv{display:flex}.tp-sldtxtv_s{flex:2}.tp-sldtxtv_t{flex:1;margin-left:4px}.tp-tabv{position:relative}.tp-tabv_t{align-items:flex-end;color:var(--cnt-bg);display:flex;overflow:hidden;position:relative}.tp-tabv_t:hover{color:var(--cnt-bg-h)}.tp-tabv_t:has(*:focus){color:var(--cnt-bg-f)}.tp-tabv_t:has(*:active){color:var(--cnt-bg-a)}.tp-tabv_t::before{background-color:currentColor;bottom:0;content:"";height:2px;left:0;pointer-events:none;position:absolute;right:0}.tp-tabv.tp-v-disabled .tp-tabv_t::before{opacity:.5}.tp-tabv.tp-tabv-nop .tp-tabv_t{height:calc(var(--bld-us) + 4px);position:relative}.tp-tabv.tp-tabv-nop .tp-tabv_t::before{background-color:var(--cnt-bg);bottom:0;content:"";height:2px;left:0;position:absolute;right:0}.tp-tabv_c{padding-bottom:var(--cnt-v-p);padding-left:4px;padding-top:var(--cnt-v-p)}.tp-tabv_i{bottom:0;color:var(--cnt-bg);left:0;overflow:hidden;position:absolute;top:calc(var(--bld-us) + 4px);width:var(--bs-br)}.tp-tabv_i::before{background-color:currentColor;bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.tp-tabv_t:hover+.tp-tabv_i{color:var(--cnt-bg-h)}.tp-tabv_t:has(*:focus)+.tp-tabv_i{color:var(--cnt-bg-f)}.tp-tabv_t:has(*:active)+.tp-tabv_i{color:var(--cnt-bg-a)}.tp-tabv.tp-v-disabled>.tp-tabv_i{opacity:.5}.tp-tbiv{flex:1;min-width:0;position:relative}.tp-tbiv+.tp-tbiv{margin-left:2px}.tp-tbiv+.tp-tbiv.tp-v-disabled::before{opacity:.5}.tp-tbiv_b{display:block;padding-left:calc(var(--cnt-h-p) + 4px);padding-right:calc(var(--cnt-h-p) + 4px);position:relative;width:100%}.tp-tbiv_b:disabled{opacity:.5}.tp-tbiv_b::before{background-color:var(--cnt-bg);bottom:2px;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.tp-tbiv_b:hover::before{background-color:var(--cnt-bg-h)}.tp-tbiv_b:focus::before{background-color:var(--cnt-bg-f)}.tp-tbiv_b:active::before{background-color:var(--cnt-bg-a)}.tp-tbiv_t{color:var(--cnt-fg);height:calc(var(--bld-us) + 4px);line-height:calc(var(--bld-us) + 4px);opacity:.5;overflow:hidden;text-overflow:ellipsis}.tp-tbiv.tp-tbiv-sel .tp-tbiv_t{opacity:1}.tp-txtv{position:relative}.tp-txtv_i{padding:0 4px}.tp-txtv.tp-txtv-fst .tp-txtv_i{border-bottom-right-radius:0;border-top-right-radius:0}.tp-txtv.tp-txtv-mid .tp-txtv_i{border-radius:0}.tp-txtv.tp-txtv-lst .tp-txtv_i{border-bottom-left-radius:0;border-top-left-radius:0}.tp-txtv.tp-txtv-num .tp-txtv_i{text-align:right}.tp-txtv.tp-txtv-drg .tp-txtv_i{opacity:.3}.tp-txtv_k{cursor:pointer;height:100%;left:-3px;position:absolute;top:0;width:12px}.tp-txtv_k::before{background-color:var(--in-fg);border-radius:1px;bottom:0;content:"";height:calc(var(--bld-us) - 4px);left:50%;margin-bottom:auto;margin-left:-1px;margin-top:auto;opacity:.1;position:absolute;top:0;transition:border-radius .1s,height .1s,transform .1s,width .1s;width:2px}.tp-txtv_k:hover::before,.tp-txtv.tp-txtv-drg .tp-txtv_k::before{opacity:1}.tp-txtv.tp-txtv-drg .tp-txtv_k::before{border-radius:50%;height:4px;transform:translateX(-1px);width:4px}.tp-txtv_g{bottom:0;display:block;height:8px;left:50%;margin:auto;overflow:visible;pointer-events:none;position:absolute;top:0;visibility:hidden;width:100%}.tp-txtv.tp-txtv-drg .tp-txtv_g{visibility:visible}.tp-txtv_gb{fill:none;stroke:var(--in-fg);stroke-dasharray:1}.tp-txtv_gh{fill:none;stroke:var(--in-fg)}.tp-txtv .tp-ttv{margin-left:6px;visibility:hidden}.tp-txtv.tp-txtv-drg .tp-ttv{visibility:visible}.tp-ttv{background-color:var(--in-fg);border-radius:var(--elm-br);color:var(--bs-bg);padding:2px 4px;pointer-events:none;position:absolute;transform:translate(-50%, -100%)}.tp-ttv::before{border-color:var(--in-fg) rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0);border-style:solid;border-width:2px;box-sizing:border-box;content:"";font-size:.9em;height:4px;left:50%;margin-left:-2px;position:absolute;top:100%;width:4px}.tp-rotv{background-color:var(--bs-bg);border-radius:var(--bs-br);box-shadow:0 2px 4px var(--bs-sh);font-family:var(--font-family);font-size:11px;font-weight:500;line-height:1;text-align:left}.tp-rotv_b{border-bottom-left-radius:var(--bs-br);border-bottom-right-radius:var(--bs-br);border-top-left-radius:var(--bs-br);border-top-right-radius:var(--bs-br);padding-left:calc(4px + var(--bld-us) + var(--cnt-h-p));text-align:center}.tp-rotv.tp-rotv-expanded .tp-rotv_b{border-bottom-left-radius:0;border-bottom-right-radius:0}.tp-rotv.tp-rotv-not .tp-rotv_b{display:none}.tp-rotv_b:disabled .tp-rotv_m{display:none}.tp-rotv_c>.tp-fldv.tp-v-lst>.tp-fldv_c{border-bottom-left-radius:var(--bs-br);border-bottom-right-radius:var(--bs-br)}.tp-rotv_c>.tp-fldv.tp-v-lst>.tp-fldv_i{border-bottom-left-radius:var(--bs-br)}.tp-rotv_c>.tp-fldv.tp-v-lst:not(.tp-fldv-expanded)>.tp-fldv_b{border-bottom-left-radius:var(--bs-br);border-bottom-right-radius:var(--bs-br)}.tp-rotv_c .tp-fldv.tp-v-vlst:not(.tp-fldv-expanded)>.tp-fldv_b{border-bottom-right-radius:var(--bs-br)}.tp-rotv.tp-rotv-not .tp-rotv_c>.tp-fldv.tp-v-fst{margin-top:calc(-1*var(--cnt-v-p))}.tp-rotv.tp-rotv-not .tp-rotv_c>.tp-fldv.tp-v-fst>.tp-fldv_b{border-top-left-radius:var(--bs-br);border-top-right-radius:var(--bs-br)}.tp-rotv_c>.tp-tabv.tp-v-lst>.tp-tabv_c{border-bottom-left-radius:var(--bs-br);border-bottom-right-radius:var(--bs-br)}.tp-rotv_c>.tp-tabv.tp-v-lst>.tp-tabv_i{border-bottom-left-radius:var(--bs-br)}.tp-rotv.tp-rotv-not .tp-rotv_c>.tp-tabv.tp-v-fst{margin-top:calc(-1*var(--cnt-v-p))}.tp-rotv.tp-rotv-not .tp-rotv_c>.tp-tabv.tp-v-fst>.tp-tabv_t{border-top-left-radius:var(--bs-br);border-top-right-radius:var(--bs-br)}.tp-rotv.tp-v-disabled,.tp-rotv .tp-v-disabled{pointer-events:none}.tp-rotv.tp-v-hidden,.tp-rotv .tp-v-hidden{display:none}'),this.pool_.getAll().forEach(e=>{this.embedPluginStyle_(e)}),this.registerPlugin({plugins:[mu,cu,Hn,fu]})}}const gu=new s("3.1.7");r.BladeApi=a,r.ButtonApi=R,r.FolderApi=qn,r.InputBindingApi=Xn,r.ListApi=No,r.MonitorBindingApi=Yn,r.Pane=bu,r.SeparatorApi=Li,r.SliderApi=Fo,r.TabApi=Vi,r.TabPageApi=Jn,r.TextApi=jo,r.TpChangeEvent=u,r.VERSION=gu,Object.defineProperty(r,"__esModule",{value:!0})})})(Al,xi);var Gn={},Vl={get exports(){return Gn},set exports(g){Gn=g}};(function(g,i){(function(r,s){s(i)})(Gr,function(r){class s{constructor(o){this.controller_=o}get element(){return this.controller_.view.element}get disabled(){return this.controller_.viewProps.get("disabled")}set disabled(o){this.controller_.viewProps.set("disabled",o)}get hidden(){return this.controller_.viewProps.get("hidden")}set hidden(o){this.controller_.viewProps.set("hidden",o)}dispose(){this.controller_.viewProps.set("disposed",!0)}}class a{constructor(o){this.target=o}}class c extends a{constructor(o,p,v,C){super(o),this.value=p,this.presetKey=v,this.last=C??!0}}function u(m){return m}function h(m){return m==null}const d={alreadydisposed:()=>"View has been already disposed",invalidparams:m=>`Invalid parameters for '${m.name}'`,nomatchingcontroller:m=>`No matching controller for '${m.key}'`,nomatchingview:m=>`No matching view for '${JSON.stringify(m.params)}'`,notbindable:()=>"Value is not bindable",propertynotfound:m=>`Property '${m.name}' not found`,shouldneverhappen:()=>"This error should never happen"};class _{constructor(o){var p;this.message=(p=d[o.type](o.context))!==null&&p!==void 0?p:"Unexpected error",this.name=this.constructor.name,this.stack=new Error(this.message).stack,this.type=o.type}static alreadyDisposed(){return new _({type:"alreadydisposed"})}static notBindable(){return new _({type:"notbindable"})}static propertyNotFound(o){return new _({type:"propertynotfound",context:{name:o}})}static shouldNeverHappen(){return new _({type:"shouldneverhappen"})}}class y{constructor(){this.observers_={}}on(o,p){let v=this.observers_[o];return v||(v=this.observers_[o]=[]),v.push({handler:p}),this}off(o,p){const v=this.observers_[o];return v&&(this.observers_[o]=v.filter(C=>C.handler!==p)),this}emit(o,p){const v=this.observers_[o];v&&v.forEach(C=>{C.handler(p)})}}const w="tp";function x(m){return(p,v)=>[w,"-",m,"v",p?`_${p}`:"",v?`-${v}`:""].join("")}function M(m,o){return p=>o(m(p))}function O(m){return m.rawValue}function I(m,o){m.emitter.on("change",M(O,o)),o(m.rawValue)}function E(m,o,p){I(m.value(o),p)}function R(m,o,p){p?m.classList.add(o):m.classList.remove(o)}function z(m,o){return p=>{R(m,o,p)}}function B(m,o){I(m,p=>{o.textContent=p??""})}const N=x("btn");class Q{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(N()),p.viewProps.bindClassModifiers(this.element);const v=o.createElement("button");v.classList.add(N("b")),p.viewProps.bindDisabled(v),this.element.appendChild(v),this.buttonElement=v;const C=o.createElement("div");C.classList.add(N("t")),B(p.props.value("title"),C),this.buttonElement.appendChild(C)}}class ${constructor(o,p){this.emitter=new y,this.onClick_=this.onClick_.bind(this),this.props=p.props,this.viewProps=p.viewProps,this.view=new Q(o,{props:this.props,viewProps:this.viewProps}),this.view.buttonElement.addEventListener("click",this.onClick_)}onClick_(){this.emitter.emit("click",{sender:this})}}class j{constructor(o,p){var v;this.constraint_=p==null?void 0:p.constraint,this.equals_=(v=p==null?void 0:p.equals)!==null&&v!==void 0?v:(C,k)=>C===k,this.emitter=new y,this.rawValue_=o}get constraint(){return this.constraint_}get rawValue(){return this.rawValue_}set rawValue(o){this.setRawValue(o,{forceEmit:!1,last:!0})}setRawValue(o,p){const v=p??{forceEmit:!1,last:!0},C=this.constraint_?this.constraint_.constrain(o):o,k=this.rawValue_;this.equals_(k,C)&&!v.forceEmit||(this.emitter.emit("beforechange",{sender:this}),this.rawValue_=C,this.emitter.emit("change",{options:v,previousRawValue:k,rawValue:C,sender:this}))}}class F{constructor(o){this.emitter=new y,this.value_=o}get rawValue(){return this.value_}set rawValue(o){this.setRawValue(o,{forceEmit:!1,last:!0})}setRawValue(o,p){const v=p??{forceEmit:!1,last:!0},C=this.value_;C===o&&!v.forceEmit||(this.emitter.emit("beforechange",{sender:this}),this.value_=o,this.emitter.emit("change",{options:v,previousRawValue:C,rawValue:this.value_,sender:this}))}}function X(m,o){const p=o==null?void 0:o.constraint,v=o==null?void 0:o.equals;return!p&&!v?new F(m):new j(m,o)}class Y{constructor(o){this.emitter=new y,this.valMap_=o;for(const p in this.valMap_)this.valMap_[p].emitter.on("change",()=>{this.emitter.emit("change",{key:p,sender:this})})}static createCore(o){return Object.keys(o).reduce((v,C)=>Object.assign(v,{[C]:X(o[C])}),{})}static fromObject(o){const p=this.createCore(o);return new Y(p)}get(o){return this.valMap_[o].rawValue}set(o,p){this.valMap_[o].rawValue=p}value(o){return this.valMap_[o]}}function Z(m,o){const v=Object.keys(o).reduce((C,k)=>{if(C===void 0)return;const T=o[k],G=T(m[k]);return G.succeeded?Object.assign(Object.assign({},C),{[k]:G.value}):void 0},{});return v}function ue(m,o){return m.reduce((p,v)=>{if(p===void 0)return;const C=o(v);if(!(!C.succeeded||C.value===void 0))return[...p,C.value]},[])}function ge(m){return m===null?!1:typeof m=="object"}function pe(m){return o=>p=>{if(!o&&p===void 0)return{succeeded:!1,value:void 0};if(o&&p===void 0)return{succeeded:!0,value:void 0};const v=m(p);return v!==void 0?{succeeded:!0,value:v}:{succeeded:!1,value:void 0}}}function me(m){return{custom:o=>pe(o)(m),boolean:pe(o=>typeof o=="boolean"?o:void 0)(m),number:pe(o=>typeof o=="number"?o:void 0)(m),string:pe(o=>typeof o=="string"?o:void 0)(m),function:pe(o=>typeof o=="function"?o:void 0)(m),constant:o=>pe(p=>p===o?o:void 0)(m),raw:pe(o=>o)(m),object:o=>pe(p=>{if(ge(p))return Z(p,o)})(m),array:o=>pe(p=>{if(Array.isArray(p))return ue(p,o)})(m)}}const he={optional:me(!0),required:me(!1)};function ee(m,o){const p=he.required.object(o)(m);return p.succeeded?p.value:void 0}function q(m){console.warn([`Missing '${m.key}' of ${m.target} in ${m.place}.`,"Please rebuild plugins with the latest core package."].join(" "))}function Ce(m){return m&&m.parentElement&&m.parentElement.removeChild(m),null}class fe{constructor(o){this.value_=o}static create(o){return[new fe(o),(p,v)=>{o.setRawValue(p,v)}]}get emitter(){return this.value_.emitter}get rawValue(){return this.value_.rawValue}}const le=x("");function ne(m,o){return z(m,le(void 0,o))}class be extends Y{constructor(o){var p;super(o),this.onDisabledChange_=this.onDisabledChange_.bind(this),this.onParentChange_=this.onParentChange_.bind(this),this.onParentGlobalDisabledChange_=this.onParentGlobalDisabledChange_.bind(this),[this.globalDisabled_,this.setGlobalDisabled_]=fe.create(X(this.getGlobalDisabled_())),this.value("disabled").emitter.on("change",this.onDisabledChange_),this.value("parent").emitter.on("change",this.onParentChange_),(p=this.get("parent"))===null||p===void 0||p.globalDisabled.emitter.on("change",this.onParentGlobalDisabledChange_)}static create(o){var p,v,C;const k=o??{};return new be(Y.createCore({disabled:(p=k.disabled)!==null&&p!==void 0?p:!1,disposed:!1,hidden:(v=k.hidden)!==null&&v!==void 0?v:!1,parent:(C=k.parent)!==null&&C!==void 0?C:null}))}get globalDisabled(){return this.globalDisabled_}bindClassModifiers(o){I(this.globalDisabled_,ne(o,"disabled")),E(this,"hidden",ne(o,"hidden"))}bindDisabled(o){I(this.globalDisabled_,p=>{o.disabled=p})}bindTabIndex(o){I(this.globalDisabled_,p=>{o.tabIndex=p?-1:0})}handleDispose(o){this.value("disposed").emitter.on("change",p=>{p&&o()})}getGlobalDisabled_(){const o=this.get("parent");return(o?o.globalDisabled.rawValue:!1)||this.get("disabled")}updateGlobalDisabled_(){this.setGlobalDisabled_(this.getGlobalDisabled_())}onDisabledChange_(){this.updateGlobalDisabled_()}onParentGlobalDisabledChange_(){this.updateGlobalDisabled_()}onParentChange_(o){var p;const v=o.previousRawValue;v==null||v.globalDisabled.emitter.off("change",this.onParentGlobalDisabledChange_),(p=this.get("parent"))===null||p===void 0||p.globalDisabled.emitter.on("change",this.onParentGlobalDisabledChange_),this.updateGlobalDisabled_()}}function V(){return["veryfirst","first","last","verylast"]}const ce=x(""),Ae={veryfirst:"vfst",first:"fst",last:"lst",verylast:"vlst"};class De{constructor(o){this.parent_=null,this.blade=o.blade,this.view=o.view,this.viewProps=o.viewProps;const p=this.view.element;this.blade.value("positions").emitter.on("change",()=>{V().forEach(v=>{p.classList.remove(ce(void 0,Ae[v]))}),this.blade.get("positions").forEach(v=>{p.classList.add(ce(void 0,Ae[v]))})}),this.viewProps.handleDispose(()=>{Ce(p)})}get parent(){return this.parent_}set parent(o){if(this.parent_=o,!("parent"in this.viewProps.valMap_)){q({key:"parent",target:be.name,place:"BladeController.parent"});return}this.viewProps.set("parent",this.parent_?this.parent_.viewProps:null)}}const we="http://www.w3.org/2000/svg";function qe(m){m.offsetHeight}function fn(m,o){const p=m.style.transition;m.style.transition="none",o(),m.style.transition=p}function ze(m){return m.ontouchstart!==void 0}function vn(m){for(;m.childNodes.length>0;)m.removeChild(m.childNodes[0])}function $t(m){return m.relatedTarget?m.relatedTarget:"explicitOriginalTarget"in m?m.explicitOriginalTarget:null}const nt=x("lbl");function dt(m,o){const p=m.createDocumentFragment();return o.split(`
22
+ `).map(C=>m.createTextNode(C)).forEach((C,k)=>{k>0&&p.appendChild(m.createElement("br")),p.appendChild(C)}),p}class Ee{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(nt()),p.viewProps.bindClassModifiers(this.element);const v=o.createElement("div");v.classList.add(nt("l")),E(p.props,"label",k=>{h(k)?this.element.classList.add(nt(void 0,"nol")):(this.element.classList.remove(nt(void 0,"nol")),vn(v),v.appendChild(dt(o,k)))}),this.element.appendChild(v),this.labelElement=v;const C=o.createElement("div");C.classList.add(nt("v")),this.element.appendChild(C),this.valueElement=C}}class Qe extends De{constructor(o,p){const v=p.valueController.viewProps;super(Object.assign(Object.assign({},p),{view:new Ee(o,{props:p.props,viewProps:v}),viewProps:v})),this.props=p.props,this.valueController=p.valueController,this.view.valueElement.appendChild(this.valueController.view.element)}}class Xt extends De{constructor(o){super(o),this.value=o.value}}class it extends Y{constructor(o){super(o)}static create(o){const p={completed:!0,expanded:o,expandedHeight:null,shouldFixHeight:!1,temporaryExpanded:null},v=Y.createCore(p);return new it(v)}get styleExpanded(){var o;return(o=this.get("temporaryExpanded"))!==null&&o!==void 0?o:this.get("expanded")}get styleHeight(){if(!this.styleExpanded)return"0";const o=this.get("expandedHeight");return this.get("shouldFixHeight")&&!h(o)?`${o}px`:"auto"}bindExpandedClass(o,p){const v=()=>{this.styleExpanded?o.classList.add(p):o.classList.remove(p)};E(this,"expanded",v),E(this,"temporaryExpanded",v)}cleanUpTransition(){this.set("shouldFixHeight",!1),this.set("expandedHeight",null),this.set("completed",!0)}}function bn(m){return it.create(m)}function Kn(m,o){let p=0;return fn(o,()=>{m.set("expandedHeight",null),m.set("temporaryExpanded",!0),qe(o),p=o.clientHeight,m.set("temporaryExpanded",null),qe(o)}),p}function gn(m,o){o.style.height=m.styleHeight}function _n(m,o){m.value("expanded").emitter.on("beforechange",()=>{m.set("completed",!1),h(m.get("expandedHeight"))&&m.set("expandedHeight",Kn(m,o)),m.set("shouldFixHeight",!0),qe(o)}),m.emitter.on("change",()=>{gn(m,o)}),gn(m,o),o.addEventListener("transitionend",p=>{p.propertyName==="height"&&m.cleanUpTransition()})}class at{constructor(o,p){const v=x(p.viewName);this.element=o.createElement("div"),this.element.classList.add(v()),p.viewProps.bindClassModifiers(this.element)}}class mt extends Xt{constructor(o,p){const v=p.valueController.viewProps;super(Object.assign(Object.assign({},p),{value:p.valueController.value,view:new Ee(o,{props:p.props,viewProps:v}),viewProps:v})),this.props=p.props,this.valueController=p.valueController,this.view.valueElement.appendChild(this.valueController.view.element)}}class wn{constructor(){this.disabled=!1,this.emitter=new y}dispose(){}tick(){this.disabled||this.emitter.emit("tick",{sender:this})}}class Yt{constructor(o,p){this.disabled_=!1,this.timerId_=null,this.onTick_=this.onTick_.bind(this),this.doc_=o,this.emitter=new y,this.interval_=p,this.setTimer_()}get disabled(){return this.disabled_}set disabled(o){this.disabled_=o,this.disabled_?this.clearTimer_():this.setTimer_()}dispose(){this.clearTimer_()}clearTimer_(){if(this.timerId_===null)return;const o=this.doc_.defaultView;o&&o.clearInterval(this.timerId_),this.timerId_=null}setTimer_(){if(this.clearTimer_(),this.interval_<=0)return;const o=this.doc_.defaultView;o&&(this.timerId_=o.setInterval(this.onTick_,this.interval_))}onTick_(){this.disabled_||this.emitter.emit("tick",{sender:this})}}class yn{constructor(o){this.constraints=o}constrain(o){return this.constraints.reduce((p,v)=>v.constrain(p),o)}}function lt(m,o){if(m instanceof o)return m;if(m instanceof yn){const p=m.constraints.reduce((v,C)=>v||(C instanceof o?C:null),null);if(p)return p}return null}class st{constructor(o){this.values=Y.fromObject({max:o.max,min:o.min})}constrain(o){const p=this.values.get("max"),v=this.values.get("min");return Math.min(Math.max(o,v),p)}}class ft{constructor(o){this.values=Y.fromObject({max:o.max,min:o.min})}get maxValue(){return this.values.get("max")}get minValue(){return this.values.get("min")}constrain(o){const p=this.values.get("max"),v=this.values.get("min");let C=o;return h(v)||(C=Math.max(C,v)),h(p)||(C=Math.min(C,p)),C}}class D{constructor(o,p=0){this.step=o,this.origin=p}constrain(o){const p=this.origin%this.step,v=Math.round((o-p)/this.step);return p+v*this.step}}const K=x("pop");class J{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(K()),p.viewProps.bindClassModifiers(this.element),I(p.shows,z(this.element,K(void 0,"v")))}}class ie{constructor(o,p){this.shows=X(!1),this.viewProps=p.viewProps,this.view=new J(o,{shows:this.shows,viewProps:this.viewProps})}}const ye=x("txt");class Ve{constructor(o,p){this.onChange_=this.onChange_.bind(this),this.element=o.createElement("div"),this.element.classList.add(ye()),p.viewProps.bindClassModifiers(this.element),this.props_=p.props,this.props_.emitter.on("change",this.onChange_);const v=o.createElement("input");v.classList.add(ye("i")),v.type="text",p.viewProps.bindDisabled(v),this.element.appendChild(v),this.inputElement=v,p.value.emitter.on("change",this.onChange_),this.value_=p.value,this.refresh()}refresh(){const o=this.props_.get("formatter");this.inputElement.value=o(this.value_.rawValue)}onChange_(){this.refresh()}}class St{constructor(o,p){this.onInputChange_=this.onInputChange_.bind(this),this.parser_=p.parser,this.props=p.props,this.value=p.value,this.viewProps=p.viewProps,this.view=new Ve(o,{props:p.props,value:this.value,viewProps:this.viewProps}),this.view.inputElement.addEventListener("change",this.onInputChange_)}onInputChange_(o){const v=o.currentTarget.value,C=this.parser_(v);h(C)||(this.value.rawValue=C),this.view.refresh()}}function qt(m){return m==="false"?!1:!!m}class Oe{constructor(o){this.text=o}evaluate(){return Number(this.text)}toString(){return this.text}}const Be={"**":(m,o)=>Math.pow(m,o),"*":(m,o)=>m*o,"/":(m,o)=>m/o,"%":(m,o)=>m%o,"+":(m,o)=>m+o,"-":(m,o)=>m-o,"<<":(m,o)=>m<<o,">>":(m,o)=>m>>o,">>>":(m,o)=>m>>>o,"&":(m,o)=>m&o,"^":(m,o)=>m^o,"|":(m,o)=>m|o};class fs{constructor(o,p,v){this.left=p,this.operator=o,this.right=v}evaluate(){const o=Be[this.operator];if(!o)throw new Error(`unexpected binary operator: '${this.operator}`);return o(this.left.evaluate(),this.right.evaluate())}toString(){return["b(",this.left.toString(),this.operator,this.right.toString(),")"].join(" ")}}const vs={"+":m=>m,"-":m=>-m,"~":m=>~m};class bs{constructor(o,p){this.operator=o,this.expression=p}evaluate(){const o=vs[this.operator];if(!o)throw new Error(`unexpected unary operator: '${this.operator}`);return o(this.expression.evaluate())}toString(){return["u(",this.operator,this.expression.toString(),")"].join(" ")}}function $n(m){return(o,p)=>{for(let v=0;v<m.length;v++){const C=m[v](o,p);if(C!=="")return C}return""}}function vt(m,o){var p;const v=m.substr(o).match(/^\s+/);return(p=v&&v[0])!==null&&p!==void 0?p:""}function Xn(m,o){const p=m.substr(o,1);return p.match(/^[1-9]$/)?p:""}function Te(m,o){var p;const v=m.substr(o).match(/^[0-9]+/);return(p=v&&v[0])!==null&&p!==void 0?p:""}function Yn(m,o){const p=Te(m,o);if(p!=="")return p;const v=m.substr(o,1);if(o+=1,v!=="-"&&v!=="+")return"";const C=Te(m,o);return C===""?"":v+C}function Ze(m,o){const p=m.substr(o,1);if(o+=1,p.toLowerCase()!=="e")return"";const v=Yn(m,o);return v===""?"":p+v}function Mi(m,o){const p=m.substr(o,1);if(p==="0")return p;const v=Xn(m,o);return o+=v.length,v===""?"":v+Te(m,o)}function Qt(m,o){const p=Mi(m,o);if(o+=p.length,p==="")return"";const v=m.substr(o,1);if(o+=v.length,v!==".")return"";const C=Te(m,o);return o+=C.length,p+v+C+Ze(m,o)}function ki(m,o){const p=m.substr(o,1);if(o+=p.length,p!==".")return"";const v=Te(m,o);return o+=v.length,v===""?"":p+v+Ze(m,o)}function xn(m,o){const p=Mi(m,o);return o+=p.length,p===""?"":p+Ze(m,o)}const qn=$n([Qt,ki,xn]);function Qn(m,o){var p;const v=m.substr(o).match(/^[01]+/);return(p=v&&v[0])!==null&&p!==void 0?p:""}function gs(m,o){const p=m.substr(o,2);if(o+=p.length,p.toLowerCase()!=="0b")return"";const v=Qn(m,o);return v===""?"":p+v}function _s(m,o){var p;const v=m.substr(o).match(/^[0-7]+/);return(p=v&&v[0])!==null&&p!==void 0?p:""}function ws(m,o){const p=m.substr(o,2);if(o+=p.length,p.toLowerCase()!=="0o")return"";const v=_s(m,o);return v===""?"":p+v}function ys(m,o){var p;const v=m.substr(o).match(/^[0-9a-f]+/i);return(p=v&&v[0])!==null&&p!==void 0?p:""}function Zn(m,o){const p=m.substr(o,2);if(o+=p.length,p.toLowerCase()!=="0x")return"";const v=ys(m,o);return v===""?"":p+v}const xs=$n([gs,ws,Zn]),Cs=$n([xs,qn]);function Zt(m,o){const p=Cs(m,o);return o+=p.length,p===""?null:{evaluable:new Oe(p),cursor:o}}function Si(m,o){const p=m.substr(o,1);if(o+=p.length,p!=="(")return null;const v=Wn(m,o);if(!v)return null;o=v.cursor,o+=vt(m,o).length;const C=m.substr(o,1);return o+=C.length,C!==")"?null:{evaluable:v.evaluable,cursor:o}}function Ps(m,o){var p;return(p=Zt(m,o))!==null&&p!==void 0?p:Si(m,o)}function Cn(m,o){const p=Ps(m,o);if(p)return p;const v=m.substr(o,1);if(o+=v.length,v!=="+"&&v!=="-"&&v!=="~")return null;const C=Cn(m,o);return C?(o=C.cursor,{cursor:o,evaluable:new bs(v,C.evaluable)}):null}function Ms(m,o,p){p+=vt(o,p).length;const v=m.filter(C=>o.startsWith(C,p))[0];return v?(p+=v.length,p+=vt(o,p).length,{cursor:p,operator:v}):null}function Lt(m,o){return(p,v)=>{const C=m(p,v);if(!C)return null;v=C.cursor;let k=C.evaluable;for(;;){const T=Ms(o,p,v);if(!T)break;v=T.cursor;const G=m(p,v);if(!G)return null;v=G.cursor,k=new fs(T.operator,k,G.evaluable)}return k?{cursor:v,evaluable:k}:null}}const Li=[["**"],["*","/","%"],["+","-"],["<<",">>>",">>"],["&"],["^"],["|"]].reduce((m,o)=>Lt(m,o),Cn);function Wn(m,o){return o+=vt(m,o).length,Li(m,o)}function ks(m){const o=Wn(m,0);return!o||o.cursor+vt(m,o.cursor).length!==m.length?null:o.evaluable}function Wt(m){var o;const p=ks(m);return(o=p==null?void 0:p.evaluate())!==null&&o!==void 0?o:null}function Ss(m){if(typeof m=="number")return m;if(typeof m=="string"){const o=Wt(m);if(!h(o))return o}return 0}function Se(m){return o=>o.toFixed(Math.max(Math.min(m,20),0))}const Ls=Se(0);function Pn(m){return Ls(m)+"%"}function Ai(m){return String(m)}function Jn(m,o){for(;m.length<o;)m.push(void 0)}function Vi(m){const o=[];return Jn(o,m),X(o)}function Ii(m){const o=m.indexOf(void 0);return o<0?m:m.slice(0,o)}function As(m,o){const p=[...Ii(m),o];return p.length>m.length?p.splice(0,p.length-m.length):Jn(p,m.length),p}function At({primary:m,secondary:o,forward:p,backward:v}){let C=!1;function k(T){C||(C=!0,T(),C=!1)}m.emitter.on("change",T=>{k(()=>{o.setRawValue(p(m,o),T.options)})}),o.emitter.on("change",T=>{k(()=>{m.setRawValue(v(m,o),T.options)}),k(()=>{o.setRawValue(p(m,o),T.options)})}),k(()=>{o.setRawValue(p(m,o),{forceEmit:!1,last:!0})})}function Vt(m,o){const p=m*(o.altKey?.1:1)*(o.shiftKey?10:1);return o.upKey?+p:o.downKey?-p:0}function Jt(m){return{altKey:m.altKey,downKey:m.key==="ArrowDown",shiftKey:m.shiftKey,upKey:m.key==="ArrowUp"}}function Hn(m){return{altKey:m.altKey,downKey:m.key==="ArrowLeft",shiftKey:m.shiftKey,upKey:m.key==="ArrowRight"}}function Vs(m){return m==="ArrowUp"||m==="ArrowDown"}function Di(m){return Vs(m)||m==="ArrowLeft"||m==="ArrowRight"}function ei(m,o){var p,v;const C=o.ownerDocument.defaultView,k=o.getBoundingClientRect();return{x:m.pageX-(((p=C&&C.scrollX)!==null&&p!==void 0?p:0)+k.left),y:m.pageY-(((v=C&&C.scrollY)!==null&&v!==void 0?v:0)+k.top)}}class Mn{constructor(o){this.lastTouch_=null,this.onDocumentMouseMove_=this.onDocumentMouseMove_.bind(this),this.onDocumentMouseUp_=this.onDocumentMouseUp_.bind(this),this.onMouseDown_=this.onMouseDown_.bind(this),this.onTouchEnd_=this.onTouchEnd_.bind(this),this.onTouchMove_=this.onTouchMove_.bind(this),this.onTouchStart_=this.onTouchStart_.bind(this),this.elem_=o,this.emitter=new y,o.addEventListener("touchstart",this.onTouchStart_,{passive:!1}),o.addEventListener("touchmove",this.onTouchMove_,{passive:!0}),o.addEventListener("touchend",this.onTouchEnd_),o.addEventListener("mousedown",this.onMouseDown_)}computePosition_(o){const p=this.elem_.getBoundingClientRect();return{bounds:{width:p.width,height:p.height},point:o?{x:o.x,y:o.y}:null}}onMouseDown_(o){var p;o.preventDefault(),(p=o.currentTarget)===null||p===void 0||p.focus();const v=this.elem_.ownerDocument;v.addEventListener("mousemove",this.onDocumentMouseMove_),v.addEventListener("mouseup",this.onDocumentMouseUp_),this.emitter.emit("down",{altKey:o.altKey,data:this.computePosition_(ei(o,this.elem_)),sender:this,shiftKey:o.shiftKey})}onDocumentMouseMove_(o){this.emitter.emit("move",{altKey:o.altKey,data:this.computePosition_(ei(o,this.elem_)),sender:this,shiftKey:o.shiftKey})}onDocumentMouseUp_(o){const p=this.elem_.ownerDocument;p.removeEventListener("mousemove",this.onDocumentMouseMove_),p.removeEventListener("mouseup",this.onDocumentMouseUp_),this.emitter.emit("up",{altKey:o.altKey,data:this.computePosition_(ei(o,this.elem_)),sender:this,shiftKey:o.shiftKey})}onTouchStart_(o){o.preventDefault();const p=o.targetTouches.item(0),v=this.elem_.getBoundingClientRect();this.emitter.emit("down",{altKey:o.altKey,data:this.computePosition_(p?{x:p.clientX-v.left,y:p.clientY-v.top}:void 0),sender:this,shiftKey:o.shiftKey}),this.lastTouch_=p}onTouchMove_(o){const p=o.targetTouches.item(0),v=this.elem_.getBoundingClientRect();this.emitter.emit("move",{altKey:o.altKey,data:this.computePosition_(p?{x:p.clientX-v.left,y:p.clientY-v.top}:void 0),sender:this,shiftKey:o.shiftKey}),this.lastTouch_=p}onTouchEnd_(o){var p;const v=(p=o.targetTouches.item(0))!==null&&p!==void 0?p:this.lastTouch_,C=this.elem_.getBoundingClientRect();this.emitter.emit("up",{altKey:o.altKey,data:this.computePosition_(v?{x:v.clientX-C.left,y:v.clientY-C.top}:void 0),sender:this,shiftKey:o.shiftKey})}}function Pe(m,o,p,v,C){const k=(m-o)/(p-o);return v+k*(C-v)}function Ti(m){return String(m.toFixed(10)).split(".")[1].replace(/0+$/,"").length}function It(m,o,p){return Math.min(Math.max(m,o),p)}const Ue=x("txt");class Is{constructor(o,p){this.onChange_=this.onChange_.bind(this),this.props_=p.props,this.props_.emitter.on("change",this.onChange_),this.element=o.createElement("div"),this.element.classList.add(Ue(),Ue(void 0,"num")),p.arrayPosition&&this.element.classList.add(Ue(void 0,p.arrayPosition)),p.viewProps.bindClassModifiers(this.element);const v=o.createElement("input");v.classList.add(Ue("i")),v.type="text",p.viewProps.bindDisabled(v),this.element.appendChild(v),this.inputElement=v,this.onDraggingChange_=this.onDraggingChange_.bind(this),this.dragging_=p.dragging,this.dragging_.emitter.on("change",this.onDraggingChange_),this.element.classList.add(Ue()),this.inputElement.classList.add(Ue("i"));const C=o.createElement("div");C.classList.add(Ue("k")),this.element.appendChild(C),this.knobElement=C;const k=o.createElementNS(we,"svg");k.classList.add(Ue("g")),this.knobElement.appendChild(k);const T=o.createElementNS(we,"path");T.classList.add(Ue("gb")),k.appendChild(T),this.guideBodyElem_=T;const G=o.createElementNS(we,"path");G.classList.add(Ue("gh")),k.appendChild(G),this.guideHeadElem_=G;const oe=o.createElement("div");oe.classList.add(x("tt")()),this.knobElement.appendChild(oe),this.tooltipElem_=oe,p.value.emitter.on("change",this.onChange_),this.value=p.value,this.refresh()}onDraggingChange_(o){if(o.rawValue===null){this.element.classList.remove(Ue(void 0,"drg"));return}this.element.classList.add(Ue(void 0,"drg"));const p=o.rawValue/this.props_.get("draggingScale"),v=p+(p>0?-1:p<0?1:0),C=It(-v,-4,4);this.guideHeadElem_.setAttributeNS(null,"d",[`M ${v+C},0 L${v},4 L${v+C},8`,`M ${p},-1 L${p},9`].join(" ")),this.guideBodyElem_.setAttributeNS(null,"d",`M 0,4 L${p},4`);const k=this.props_.get("formatter");this.tooltipElem_.textContent=k(this.value.rawValue),this.tooltipElem_.style.left=`${p}px`}refresh(){const o=this.props_.get("formatter");this.inputElement.value=o(this.value.rawValue)}onChange_(){this.refresh()}}class Ht{constructor(o,p){var v;this.originRawValue_=0,this.onInputChange_=this.onInputChange_.bind(this),this.onInputKeyDown_=this.onInputKeyDown_.bind(this),this.onInputKeyUp_=this.onInputKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.baseStep_=p.baseStep,this.parser_=p.parser,this.props=p.props,this.sliderProps_=(v=p.sliderProps)!==null&&v!==void 0?v:null,this.value=p.value,this.viewProps=p.viewProps,this.dragging_=X(null),this.view=new Is(o,{arrayPosition:p.arrayPosition,dragging:this.dragging_,props:this.props,value:this.value,viewProps:this.viewProps}),this.view.inputElement.addEventListener("change",this.onInputChange_),this.view.inputElement.addEventListener("keydown",this.onInputKeyDown_),this.view.inputElement.addEventListener("keyup",this.onInputKeyUp_);const C=new Mn(this.view.knobElement);C.emitter.on("down",this.onPointerDown_),C.emitter.on("move",this.onPointerMove_),C.emitter.on("up",this.onPointerUp_)}constrainValue_(o){var p,v;const C=(p=this.sliderProps_)===null||p===void 0?void 0:p.get("minValue"),k=(v=this.sliderProps_)===null||v===void 0?void 0:v.get("maxValue");let T=o;return C!==void 0&&(T=Math.max(T,C)),k!==void 0&&(T=Math.min(T,k)),T}onInputChange_(o){const v=o.currentTarget.value,C=this.parser_(v);h(C)||(this.value.rawValue=this.constrainValue_(C)),this.view.refresh()}onInputKeyDown_(o){const p=Vt(this.baseStep_,Jt(o));p!==0&&this.value.setRawValue(this.constrainValue_(this.value.rawValue+p),{forceEmit:!1,last:!1})}onInputKeyUp_(o){Vt(this.baseStep_,Jt(o))!==0&&this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}onPointerDown_(){this.originRawValue_=this.value.rawValue,this.dragging_.rawValue=0}computeDraggingValue_(o){if(!o.point)return null;const p=o.point.x-o.bounds.width/2;return this.constrainValue_(this.originRawValue_+p*this.props.get("draggingScale"))}onPointerMove_(o){const p=this.computeDraggingValue_(o.data);p!==null&&(this.value.setRawValue(p,{forceEmit:!1,last:!1}),this.dragging_.rawValue=this.value.rawValue-this.originRawValue_)}onPointerUp_(o){const p=this.computeDraggingValue_(o.data);p!==null&&(this.value.setRawValue(p,{forceEmit:!0,last:!0}),this.dragging_.rawValue=null)}}function $e(m,o){m.write(o)}function Dt(m){const o=m?lt(m,D):null;return o?o.step:null}function en(m,o){const p=m&&lt(m,D);return p?Ti(p.step):Math.max(Ti(o),2)}function ti(m){const o=Dt(m);return o??1}function kn(m,o){var p;const v=m&&lt(m,D),C=Math.abs((p=v==null?void 0:v.step)!==null&&p!==void 0?p:o);return C===0?.1:Math.pow(10,Math.floor(Math.log10(C))-1)}function Tt(m){return[m[0],m[1],m[2]]}function Ei(m){const o=It(Math.floor(m),0,255).toString(16);return o.length===1?`0${o}`:o}function tn(m,o="#"){const p=Tt(m.getComponents("rgb")).map(Ei).join("");return`${o}${p}`}function Oi(m,o="#"){const p=m.getComponents("rgb"),v=[p[0],p[1],p[2],p[3]*255].map(Ei).join("");return`${o}${v}`}function Ds(m,o){const p=Se(o==="float"?2:0);return`rgb(${Tt(m.getComponents("rgb",o)).map(C=>p(C)).join(", ")})`}function Bi(m){return o=>Ds(o,m)}function Ni(m,o){const p=Se(2),v=Se(o==="float"?2:0);return`rgba(${m.getComponents("rgb",o).map((k,T)=>(T===3?p:v)(k)).join(", ")})`}function Ts(m){return o=>Ni(o,m)}function Sn(m){const o=[Se(0),Pn,Pn];return`hsl(${Tt(m.getComponents("hsl")).map((v,C)=>o[C](v)).join(", ")})`}function Es(m){const o=[Se(0),Pn,Pn,Se(2)];return`hsla(${m.getComponents("hsl").map((v,C)=>o[C](v)).join(", ")})`}function Fi(m,o){const p=Se(o==="float"?2:0),v=["r","g","b"];return`{${Tt(m.getComponents("rgb",o)).map((k,T)=>`${v[T]}: ${p(k)}`).join(", ")}}`}function ji(m){return o=>Fi(o,m)}function Os(m,o){const p=Se(2),v=Se(o==="float"?2:0),C=["r","g","b","a"];return`{${m.getComponents("rgb",o).map((T,G)=>{const oe=G===3?p:v;return`${C[G]}: ${oe(T)}`}).join(", ")}}`}function Bs(m){return o=>Os(o,m)}[...["int","float"].reduce((m,o)=>[...m,{format:{alpha:!1,mode:"rgb",notation:"func",type:o},stringifier:Bi(o)},{format:{alpha:!0,mode:"rgb",notation:"func",type:o},stringifier:Ts(o)},{format:{alpha:!1,mode:"rgb",notation:"object",type:o},stringifier:ji(o)},{format:{alpha:!0,mode:"rgb",notation:"object",type:o},stringifier:Bs(o)}],[])];class Ns{constructor(o){this.components=o.components,this.asm_=o.assembly}constrain(o){const p=this.asm_.toComponents(o).map((v,C)=>{var k,T;return(T=(k=this.components[C])===null||k===void 0?void 0:k.constrain(v))!==null&&T!==void 0?T:v});return this.asm_.fromComponents(p)}}const zi=x("pndtxt");class Fs{constructor(o,p){this.textViews=p.textViews,this.element=o.createElement("div"),this.element.classList.add(zi()),this.textViews.forEach(v=>{const C=o.createElement("div");C.classList.add(zi("a")),C.appendChild(v.element),this.element.appendChild(C)})}}function ni(m,o,p){return new Ht(m,{arrayPosition:p===0?"fst":p===o.axes.length-1?"lst":"mid",baseStep:o.axes[p].baseStep,parser:o.parser,props:o.axes[p].textProps,value:X(0,{constraint:o.axes[p].constraint}),viewProps:o.viewProps})}class bt{constructor(o,p){this.value=p.value,this.viewProps=p.viewProps,this.acs_=p.axes.map((v,C)=>ni(o,p,C)),this.acs_.forEach((v,C)=>{At({primary:this.value,secondary:v.value,forward:k=>p.assembly.toComponents(k.rawValue)[C],backward:(k,T)=>{const G=p.assembly.toComponents(k.rawValue);return G[C]=T.rawValue,p.assembly.fromComponents(G)}})}),this.view=new Fs(o,{textViews:this.acs_.map(v=>v.view)})}}function js(m,o){return"step"in m&&!h(m.step)?new D(m.step,o):null}function nn(m){return!h(m.max)&&!h(m.min)?new st({max:m.max,min:m.min}):!h(m.max)||!h(m.min)?new ft({max:m.max,min:m.min}):null}const zs={monitor:{defaultInterval:200,defaultLineCount:3}},We=x("grl");class Ui{constructor(o,p){this.onCursorChange_=this.onCursorChange_.bind(this),this.onValueUpdate_=this.onValueUpdate_.bind(this),this.element=o.createElement("div"),this.element.classList.add(We()),p.viewProps.bindClassModifiers(this.element),this.formatter_=p.formatter,this.props_=p.props,this.cursor_=p.cursor,this.cursor_.emitter.on("change",this.onCursorChange_);const v=o.createElementNS(we,"svg");v.classList.add(We("g")),v.style.height=`calc(var(--bld-us) * ${p.lineCount})`,this.element.appendChild(v),this.svgElem_=v;const C=o.createElementNS(we,"polyline");this.svgElem_.appendChild(C),this.lineElem_=C;const k=o.createElement("div");k.classList.add(We("t"),x("tt")()),this.element.appendChild(k),this.tooltipElem_=k,p.value.emitter.on("change",this.onValueUpdate_),this.value=p.value,this.update_()}get graphElement(){return this.svgElem_}update_(){const o=this.svgElem_.getBoundingClientRect(),p=this.value.rawValue.length-1,v=this.props_.get("minValue"),C=this.props_.get("maxValue"),k=[];this.value.rawValue.forEach((Ke,te)=>{if(Ke===void 0)return;const ut=Pe(te,0,p,0,o.width),er=Pe(Ke,v,C,o.height,0);k.push([ut,er].join(","))}),this.lineElem_.setAttributeNS(null,"points",k.join(" "));const T=this.tooltipElem_,G=this.value.rawValue[this.cursor_.rawValue];if(G===void 0){T.classList.remove(We("t","a"));return}const oe=Pe(this.cursor_.rawValue,0,p,0,o.width),Ge=Pe(G,v,C,o.height,0);T.style.left=`${oe}px`,T.style.top=`${Ge}px`,T.textContent=`${this.formatter_(G)}`,T.classList.contains(We("t","a"))||(T.classList.add(We("t","a"),We("t","in")),qe(T),T.classList.remove(We("t","in")))}onValueUpdate_(){this.update_()}onCursorChange_(){this.update_()}}class Us{constructor(o,p){if(this.onGraphMouseMove_=this.onGraphMouseMove_.bind(this),this.onGraphMouseLeave_=this.onGraphMouseLeave_.bind(this),this.onGraphPointerDown_=this.onGraphPointerDown_.bind(this),this.onGraphPointerMove_=this.onGraphPointerMove_.bind(this),this.onGraphPointerUp_=this.onGraphPointerUp_.bind(this),this.props_=p.props,this.value=p.value,this.viewProps=p.viewProps,this.cursor_=X(-1),this.view=new Ui(o,{cursor:this.cursor_,formatter:p.formatter,lineCount:p.lineCount,props:this.props_,value:this.value,viewProps:this.viewProps}),!ze(o))this.view.element.addEventListener("mousemove",this.onGraphMouseMove_),this.view.element.addEventListener("mouseleave",this.onGraphMouseLeave_);else{const v=new Mn(this.view.element);v.emitter.on("down",this.onGraphPointerDown_),v.emitter.on("move",this.onGraphPointerMove_),v.emitter.on("up",this.onGraphPointerUp_)}}onGraphMouseLeave_(){this.cursor_.rawValue=-1}onGraphMouseMove_(o){const p=this.view.element.getBoundingClientRect();this.cursor_.rawValue=Math.floor(Pe(o.offsetX,0,p.width,0,this.value.rawValue.length))}onGraphPointerDown_(o){this.onGraphPointerMove_(o)}onGraphPointerMove_(o){if(!o.data.point){this.cursor_.rawValue=-1;return}this.cursor_.rawValue=Math.floor(Pe(o.data.point.x,0,o.data.bounds.width,0,this.value.rawValue.length))}onGraphPointerUp_(){this.cursor_.rawValue=-1}}class Ri{constructor(o){this.controller_=o}get disabled(){return this.controller_.viewProps.get("disabled")}set disabled(o){this.controller_.viewProps.set("disabled",o)}get title(){var o;return(o=this.controller_.props.get("title"))!==null&&o!==void 0?o:""}set title(o){this.controller_.props.set("title",o)}on(o,p){const v=p.bind(this);return this.controller_.emitter.on(o,()=>{v(new a(this))}),this}}class Rs extends a{constructor(o,p,v){super(o),this.cell=p,this.index=v}}class Gi extends s{constructor(o){super(o),this.cellToApiMap_=new Map,this.emitter_=new y;const p=this.controller_.valueController;p.cellControllers.forEach((v,C)=>{const k=new Ri(v);this.cellToApiMap_.set(v,k),v.emitter.on("click",()=>{const T=C%p.size[0],G=Math.floor(C/p.size[0]);this.emitter_.emit("click",{event:new Rs(this,k,[T,G])})})})}cell(o,p){const v=this.controller_.valueController,C=v.cellControllers[p*v.size[0]+o];return this.cellToApiMap_.get(C)}on(o,p){const v=p.bind(this);return this.emitter_.on(o,C=>{v(C.event)}),this}}class ii{constructor(o,p){this.size=p.size;const[v,C]=this.size,k=[];for(let T=0;T<C;T++)for(let G=0;G<v;G++){const oe=new $(o,{props:Y.fromObject(Object.assign({},p.cellConfig(G,T))),viewProps:be.create()});k.push(oe)}this.cellCs_=k,this.viewProps=be.create(),this.viewProps.handleDispose(()=>{this.cellCs_.forEach(T=>{T.viewProps.set("disposed",!0)})}),this.view=new at(o,{viewProps:this.viewProps,viewName:"btngrid"}),this.view.element.style.gridTemplateColumns=`repeat(${v}, 1fr)`,this.cellCs_.forEach(T=>{this.view.element.appendChild(T.view.element)})}get cellControllers(){return this.cellCs_}}const Gs={id:"buttongrid",type:"blade",css:'.tp-cbzgv,.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:rgba(0,0,0,0);border-width:0;font-family:inherit;font-size:inherit;font-weight:inherit;margin:0;outline:none;padding:0}.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{background-color:var(--btn-bg);border-radius:var(--elm-br);color:var(--btn-fg);cursor:pointer;display:block;font-weight:bold;height:var(--bld-us);line-height:var(--bld-us);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-radv_b:hover,.tp-rslv_k:hover,.tp-cbzv_b:hover{background-color:var(--btn-bg-h)}.tp-radv_b:focus,.tp-rslv_k:focus,.tp-cbzv_b:focus{background-color:var(--btn-bg-f)}.tp-radv_b:active,.tp-rslv_k:active,.tp-cbzv_b:active{background-color:var(--btn-bg-a)}.tp-radv_b:disabled,.tp-rslv_k:disabled,.tp-cbzv_b:disabled{opacity:.5}.tp-cbzgv{background-color:var(--in-bg);border-radius:var(--elm-br);box-sizing:border-box;color:var(--in-fg);font-family:inherit;height:var(--bld-us);line-height:var(--bld-us);min-width:0;width:100%}.tp-cbzgv:hover{background-color:var(--in-bg-h)}.tp-cbzgv:focus{background-color:var(--in-bg-f)}.tp-cbzgv:active{background-color:var(--in-bg-a)}.tp-cbzgv:disabled{opacity:.5}.tp-btngridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-btngridv.tp-v-disabled{opacity:.5}.tp-btngridv .tp-btnv_b:disabled{opacity:1}.tp-btngridv .tp-btnv_b:disabled .tp-btnv_t{opacity:.5}.tp-btngridv .tp-btnv_b{border-radius:0}.tp-cbzv{position:relative}.tp-cbzv_h{display:flex}.tp-cbzv_b{margin-right:4px;position:relative;width:var(--bld-us)}.tp-cbzv_b svg{display:block;height:16px;left:50%;margin-left:-8px;margin-top:-8px;position:absolute;top:50%;width:16px}.tp-cbzv_b svg path{stroke:var(--bs-bg);stroke-width:2}.tp-cbzv_t{flex:1}.tp-cbzv_p{height:0;margin-top:0;opacity:0;overflow:hidden;transition:height .2s ease-in-out,opacity .2s linear,margin .2s ease-in-out}.tp-cbzv.tp-cbzv-expanded .tp-cbzv_p{margin-top:var(--bld-s);opacity:1}.tp-cbzv.tp-cbzv-cpl .tp-cbzv_p{overflow:visible}.tp-cbzv .tp-popv{left:calc(-1*var(--cnt-h-p));position:absolute;right:calc(-1*var(--cnt-h-p));top:var(--bld-us)}.tp-cbzpv_t{margin-top:var(--bld-s)}.tp-cbzgv{height:auto;overflow:hidden;position:relative}.tp-cbzgv.tp-v-disabled{opacity:.5}.tp-cbzgv_p{left:16px;position:absolute;right:16px;top:0}.tp-cbzgv_g{cursor:pointer;display:block;height:calc(var(--bld-us)*5);width:100%}.tp-cbzgv_u{opacity:.1;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_l{fill:rgba(0,0,0,0);stroke:var(--in-fg)}.tp-cbzgv_v{opacity:.5;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_h{border:var(--in-fg) solid 1px;border-radius:50%;box-sizing:border-box;height:4px;margin-left:-2px;margin-top:-2px;pointer-events:none;position:absolute;width:4px}.tp-cbzgv:focus .tp-cbzgv_h-sel{background-color:var(--in-fg);border-width:0}.tp-cbzprvv{cursor:pointer;height:4px;padding:4px 0;position:relative}.tp-cbzprvv_g{display:block;height:100%;overflow:visible;width:100%}.tp-cbzprvv_t{opacity:.5;stroke:var(--mo-fg)}.tp-cbzprvv_m{background-color:var(--mo-fg);border-radius:50%;height:4px;margin-left:-2px;margin-top:-2px;opacity:0;position:absolute;top:50%;transition:opacity .2s ease-out;width:4px}.tp-cbzprvv_m.tp-cbzprvv_m-a{opacity:1}.tp-fpsv{position:relative}.tp-fpsv_l{bottom:4px;color:var(--mo-fg);line-height:1;right:4px;pointer-events:none;position:absolute}.tp-fpsv_u{margin-left:.2em;opacity:.7}.tp-rslv{cursor:pointer;padding-left:8px;padding-right:8px}.tp-rslv.tp-v-disabled{opacity:.5}.tp-rslv_t{height:calc(var(--bld-us));position:relative}.tp-rslv_t::before{background-color:var(--in-bg);border-radius:1px;content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:-4px;right:-4px}.tp-rslv_b{bottom:0;top:0;position:absolute}.tp-rslv_b::before{background-color:var(--in-fg);content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:0;right:0}.tp-rslv_k{height:calc(var(--bld-us) - 8px);margin-top:calc((var(--bld-us) - 8px)/-2);position:absolute;top:50%;width:8px}.tp-rslv_k.tp-rslv_k-min{margin-left:-8px}.tp-rslv_k.tp-rslv_k-max{margin-left:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-min{border-bottom-right-radius:0;border-top-right-radius:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-max{border-bottom-left-radius:0;border-top-left-radius:0}.tp-rsltxtv{display:flex}.tp-rsltxtv_s{flex:1}.tp-rsltxtv_t{flex:1;margin-left:4px}.tp-radv_l{display:block;position:relative}.tp-radv_i{left:0;opacity:0;position:absolute;top:0}.tp-radv_b{opacity:.5}.tp-radv_i:hover+.tp-radv_b{background-color:var(--btn-bg-h)}.tp-radv_i:focus+.tp-radv_b{background-color:var(--btn-bg-f)}.tp-radv_i:active+.tp-radv_b{background-color:var(--btn-bg-a)}.tp-radv_i:checked+.tp-radv_b{opacity:1}.tp-radv_t{bottom:0;color:inherit;left:0;overflow:hidden;position:absolute;right:0;text-align:center;text-overflow:ellipsis;top:0}.tp-radv_i:disabled+.tp-radv_b>.tp-radv_t{opacity:.5}.tp-radgridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-radgridv.tp-v-disabled{opacity:.5}.tp-radgridv .tp-radv_b{border-radius:0}',accept(m){const o=he,p=ee(m,{cells:o.required.function,size:o.required.array(o.required.number),view:o.required.constant("buttongrid"),label:o.optional.string});return p?{params:p}:null},controller(m){return new Qe(m.document,{blade:m.blade,props:Y.fromObject({label:m.params.label}),valueController:new ii(m.document,{cellConfig:m.params.cells,size:m.params.size})})},api(m){return!(m.controller instanceof Qe)||!(m.controller.valueController instanceof ii)?null:new Gi(m.controller)}};class Ki extends s{get label(){return this.controller_.props.get("label")}set label(o){this.controller_.props.set("label",o)}get value(){return this.controller_.valueController.value.rawValue}set value(o){this.controller_.valueController.value.rawValue=o}on(o,p){const v=p.bind(this);return this.controller_.valueController.value.emitter.on(o,C=>{v(new c(this,C.rawValue,void 0,C.options.last))}),this}}function Re(m,o,p){return m*(1-p)+o*p}const Ks=20,$s=.001,si=100;function Xs(m,o){let p=.25,v=.5,C=-1;for(let k=0;k<Ks;k++){const[T,G]=m.curve(v);if(v+=p*(T<o?1:-1),C=G,p*=.5,Math.abs(o-T)<$s)break}return C}class ct{constructor(o=0,p=0,v=1,C=1){this.cache_=[],this.comps_=[o,p,v,C]}get x1(){return this.comps_[0]}get y1(){return this.comps_[1]}get x2(){return this.comps_[2]}get y2(){return this.comps_[3]}static isObject(o){return h(o)||!Array.isArray(o)?!1:typeof o[0]=="number"&&typeof o[1]=="number"&&typeof o[2]=="number"&&typeof o[3]=="number"}static equals(o,p){return o.x1===p.x1&&o.y1===p.y1&&o.x2===p.x2&&o.y2===p.y2}curve(o){const p=Re(0,this.x1,o),v=Re(0,this.y1,o),C=Re(this.x1,this.x2,o),k=Re(this.y1,this.y2,o),T=Re(this.x2,1,o),G=Re(this.y2,1,o),oe=Re(p,C,o),Ge=Re(v,k,o),Ke=Re(C,T,o),te=Re(k,G,o);return[Re(oe,Ke,o),Re(Ge,te,o)]}y(o){if(this.cache_.length===0){const p=[];for(let v=0;v<si;v++)p.push(Xs(this,Pe(v,0,si-1,0,1)));this.cache_=p}return this.cache_[Math.round(Pe(It(o,0,1),0,1,0,si-1))]}toObject(){return[this.comps_[0],this.comps_[1],this.comps_[2],this.comps_[3]]}}const ri={toComponents:m=>m.toObject(),fromComponents:m=>new ct(...m)};function Ys(m){const o=Se(2);return`cubic-bezier(${m.toObject().map(v=>o(v)).join(", ")})`}const oi=[0,.5,.5,1];function qs(m){const o=m.match(/^cubic-bezier\s*\(\s*([0-9.]+)\s*,\s*([0-9.]+)\s*,\s*([0-9.]+)\s*,\s*([0-9.]+)\s*\)$/);if(!o)return new ct(...oi);const p=[o[1],o[2],o[3],o[4]].reduce((v,C)=>{if(!v)return null;const k=Number(C);return isNaN(k)?null:[...v,k]},[]);return new ct(...p??oi)}const gt=x("cbz");class $i{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(gt()),p.viewProps.bindClassModifiers(this.element),p.foldable.bindExpandedClass(this.element,gt(void 0,"expanded")),E(p.foldable,"completed",z(this.element,gt(void 0,"cpl")));const v=o.createElement("div");v.classList.add(gt("h")),this.element.appendChild(v);const C=o.createElement("button");C.classList.add(gt("b")),p.viewProps.bindDisabled(C);const k=o.createElementNS(we,"svg");k.innerHTML='<path d="M2 13C8 13 8 3 14 3"/>',C.appendChild(k),v.appendChild(C),this.buttonElement=C;const T=o.createElement("div");if(T.classList.add(gt("t")),v.appendChild(T),this.textElement=T,p.pickerLayout==="inline"){const G=o.createElement("div");G.classList.add(gt("p")),this.element.appendChild(G),this.pickerElement=G}else this.pickerElement=null}}const Ln=x("cbzp");class Xi{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(Ln()),p.viewProps.bindClassModifiers(this.element);const v=o.createElement("div");v.classList.add(Ln("g")),this.element.appendChild(v),this.graphElement=v;const C=o.createElement("div");C.classList.add(Ln("t")),this.element.appendChild(C),this.textElement=C}}function Je(m,o){const p=new MutationObserver(C=>{for(const k of C)k.type==="childList"&&k.addedNodes.forEach(T=>{T.contains(T)&&(o(),p.disconnect())})}),v=m.ownerDocument;p.observe(v.body,{attributes:!0,childList:!0,subtree:!0})}const rt=x("cbzg");function Qs(m,o){return p=>o(m(p))}class Le{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(rt()),p.viewProps.bindClassModifiers(this.element),p.viewProps.bindTabIndex(this.element);const v=o.createElement("div");v.classList.add(rt("p")),this.element.appendChild(v),this.previewElement=v;const C=o.createElementNS(we,"svg");C.classList.add(rt("g")),this.element.appendChild(C),this.svgElem_=C;const k=o.createElementNS(we,"path");k.classList.add(rt("u")),this.svgElem_.appendChild(k),this.guideElem_=k;const T=o.createElementNS(we,"polyline");T.classList.add(rt("l")),this.svgElem_.appendChild(T),this.lineElem_=T,this.handleElems_=[o.createElement("div"),o.createElement("div")],this.handleElems_.forEach(G=>{G.classList.add(rt("h")),this.element.appendChild(G)}),this.vectorElems_=[o.createElementNS(we,"line"),o.createElementNS(we,"line")],this.vectorElems_.forEach(G=>{G.classList.add(rt("v")),this.svgElem_.appendChild(G)}),this.value_=p.value,this.value_.emitter.on("change",this.onValueChange_.bind(this)),this.sel_=p.selection,this.handleElems_.forEach((G,oe)=>{I(this.sel_,Qs(Ge=>Ge===oe,z(G,rt("h","sel"))))}),Je(this.element,()=>{this.refresh()})}getVertMargin_(o){return o*.25}valueToPosition(o,p){const v=this.element.getBoundingClientRect(),C=v.width,k=v.height,T=this.getVertMargin_(k);return{x:Pe(o,0,1,0,C),y:Pe(p,0,1,k-T,T)}}positionToValue(o,p){const v=this.element.getBoundingClientRect(),C=v.width,k=v.height,T=this.getVertMargin_(k);return{x:It(Pe(o,0,C,0,1),0,1),y:Pe(p,k-T,T,0,1)}}refresh(){this.guideElem_.setAttributeNS(null,"d",[0,1].map(k=>{const T=this.valueToPosition(0,k),G=this.valueToPosition(1,k);return[`M ${T.x},${T.y}`,`L ${G.x},${G.y}`].join(" ")}).join(" "));const o=this.value_.rawValue,p=[];let v=0;for(;;){const k=this.valueToPosition(...o.curve(v));if(p.push([k.x,k.y].join(",")),v>=1)break;v=Math.min(v+.05,1)}this.lineElem_.setAttributeNS(null,"points",p.join(" "));const C=o.toObject();[0,1].forEach(k=>{const T=this.valueToPosition(k,k),G=this.valueToPosition(C[k*2],C[k*2+1]),oe=this.vectorElems_[k];oe.setAttributeNS(null,"x1",String(T.x)),oe.setAttributeNS(null,"y1",String(T.y)),oe.setAttributeNS(null,"x2",String(G.x)),oe.setAttributeNS(null,"y2",String(G.y));const Ge=this.handleElems_[k];Ge.style.left=`${G.x}px`,Ge.style.top=`${G.y}px`})}onValueChange_(){this.refresh()}}const Yi=24,sn=400,ai=1e3,pt=x("cbzprv");class Et{constructor(o,p){this.stopped_=!0,this.startTime_=-1,this.onDispose_=this.onDispose_.bind(this),this.onTimer_=this.onTimer_.bind(this),this.onValueChange_=this.onValueChange_.bind(this),this.element=o.createElement("div"),this.element.classList.add(pt()),p.viewProps.bindClassModifiers(this.element);const v=o.createElementNS(we,"svg");v.classList.add(pt("g")),this.element.appendChild(v),this.svgElem_=v;const C=o.createElementNS(we,"path");C.classList.add(pt("t")),this.svgElem_.appendChild(C),this.ticksElem_=C;const k=o.createElement("div");k.classList.add(pt("m")),this.element.appendChild(k),this.markerElem_=k,this.value_=p.value,this.value_.emitter.on("change",this.onValueChange_),p.viewProps.handleDispose(this.onDispose_),Je(this.element,()=>{this.refresh()})}play(){this.stop(),this.updateMarker_(0),this.markerElem_.classList.add(pt("m","a")),this.startTime_=new Date().getTime()+sn,this.stopped_=!1,requestAnimationFrame(this.onTimer_)}stop(){this.stopped_=!0,this.markerElem_.classList.remove(pt("m","a"))}onDispose_(){this.stop()}updateMarker_(o){const p=this.value_.rawValue.y(It(o,0,1));this.markerElem_.style.left=`${p*100}%`}refresh(){const o=this.svgElem_.getBoundingClientRect(),p=o.width,v=o.height,C=[],k=this.value_.rawValue;for(let T=0;T<Yi;T++){const G=Pe(T,0,Yi-1,0,1),oe=Pe(k.y(G),0,1,0,p);C.push(`M ${oe},0 v${v}`)}this.ticksElem_.setAttributeNS(null,"d",C.join(" "))}onTimer_(){if(this.startTime_===null)return;const o=new Date().getTime()-this.startTime_,p=o/ai;this.updateMarker_(p),o>ai+sn&&this.stop(),this.stopped_||requestAnimationFrame(this.onTimer_)}onValueChange_(){this.refresh(),this.play()}}function Ie(m,o,p,v){const C=p-m,k=v-o;return Math.sqrt(C*C+k*k)}function rn(m,o,p,v){const C=Ie(m,o,p,v),k=Math.atan2(v-o,p-m),T=Math.round(k/(Math.PI/4))*Math.PI/4;return{x:m+Math.cos(T)*C,y:o+Math.sin(T)*C}}class He{constructor(o,p){this.onKeyDown_=this.onKeyDown_.bind(this),this.onKeyUp_=this.onKeyUp_.bind(this),this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.baseStep_=p.baseStep,this.value=p.value,this.sel_=X(0),this.viewProps=p.viewProps,this.view=new Le(o,{selection:this.sel_,value:this.value,viewProps:this.viewProps}),this.view.element.addEventListener("keydown",this.onKeyDown_),this.view.element.addEventListener("keyup",this.onKeyUp_),this.prevView_=new Et(o,{value:this.value,viewProps:this.viewProps}),this.prevView_.element.addEventListener("mousedown",C=>{C.stopImmediatePropagation(),C.preventDefault(),this.prevView_.play()}),this.view.previewElement.appendChild(this.prevView_.element);const v=new Mn(this.view.element);v.emitter.on("down",this.onPointerDown_),v.emitter.on("move",this.onPointerMove_),v.emitter.on("up",this.onPointerUp_)}refresh(){this.view.refresh(),this.prevView_.refresh(),this.prevView_.play()}updateValue_(o,p,v){const C=this.sel_.rawValue,k=this.value.rawValue.toObject(),T=this.view.positionToValue(o.x,o.y),G=p?rn(C,C,T.x,T.y):T;k[C*2]=G.x,k[C*2+1]=G.y,this.value.setRawValue(new ct(...k),v)}onPointerDown_(o){const p=o.data;if(!p.point)return;const v=this.value.rawValue,C=this.view.valueToPosition(v.x1,v.y1),k=Ie(p.point.x,p.point.y,C.x,C.y),T=this.view.valueToPosition(v.x2,v.y2),G=Ie(p.point.x,p.point.y,T.x,T.y);this.sel_.rawValue=k<=G?0:1,this.updateValue_(p.point,o.shiftKey,{forceEmit:!1,last:!1})}onPointerMove_(o){const p=o.data;p.point&&this.updateValue_(p.point,o.shiftKey,{forceEmit:!1,last:!1})}onPointerUp_(o){const p=o.data;p.point&&this.updateValue_(p.point,o.shiftKey,{forceEmit:!0,last:!0})}onKeyDown_(o){Di(o.key)&&o.preventDefault();const p=this.sel_.rawValue,v=this.value.rawValue.toObject();v[p*2]+=Vt(this.baseStep_,Hn(o)),v[p*2+1]+=Vt(this.baseStep_,Jt(o)),this.value.setRawValue(new ct(...v),{forceEmit:!1,last:!1})}onKeyUp_(o){Di(o.key)&&o.preventDefault();const p=Vt(this.baseStep_,Hn(o)),v=Vt(this.baseStep_,Jt(o));p===0&&v===0||this.value.setRawValue(this.value.rawValue,{forceEmit:!0,last:!0})}}class qi{constructor(o,p){this.value=p.value,this.viewProps=p.viewProps,this.view=new Xi(o,{viewProps:this.viewProps}),this.gc_=new He(o,{baseStep:p.axis.baseStep,value:this.value,viewProps:this.viewProps}),this.view.graphElement.appendChild(this.gc_.view.element);const v=Object.assign(Object.assign({},p.axis),{constraint:new ft({max:1,min:0})}),C=Object.assign(Object.assign({},p.axis),{constraint:void 0});this.tc_=new bt(o,{assembly:ri,axes:[v,C,v,C],parser:Wt,value:this.value,viewProps:this.viewProps}),this.view.textElement.appendChild(this.tc_.view.element)}get allFocusableElements(){return[this.gc_.view.element,...this.tc_.view.textViews.map(o=>o.inputElement)]}refresh(){this.gc_.refresh()}}class An{constructor(o,p){this.onButtonBlur_=this.onButtonBlur_.bind(this),this.onButtonClick_=this.onButtonClick_.bind(this),this.onPopupChildBlur_=this.onPopupChildBlur_.bind(this),this.onPopupChildKeydown_=this.onPopupChildKeydown_.bind(this),this.value=p.value,this.viewProps=p.viewProps,this.foldable_=bn(p.expanded),this.view=new $i(o,{foldable:this.foldable_,pickerLayout:p.pickerLayout,viewProps:this.viewProps}),this.view.buttonElement.addEventListener("blur",this.onButtonBlur_),this.view.buttonElement.addEventListener("click",this.onButtonClick_),this.tc_=new St(o,{parser:qs,props:Y.fromObject({formatter:Ys}),value:this.value,viewProps:this.viewProps}),this.view.textElement.appendChild(this.tc_.view.element),this.popC_=p.pickerLayout==="popup"?new ie(o,{viewProps:this.viewProps}):null;const v=new qi(o,{axis:p.axis,value:this.value,viewProps:this.viewProps});v.allFocusableElements.forEach(C=>{C.addEventListener("blur",this.onPopupChildBlur_),C.addEventListener("keydown",this.onPopupChildKeydown_)}),this.pickerC_=v,this.popC_?(this.view.element.appendChild(this.popC_.view.element),this.popC_.view.element.appendChild(this.pickerC_.view.element),I(this.popC_.shows,C=>{C&&v.refresh()}),At({primary:this.foldable_.value("expanded"),secondary:this.popC_.shows,forward:C=>C.rawValue,backward:(C,k)=>k.rawValue})):this.view.pickerElement&&(this.view.pickerElement.appendChild(this.pickerC_.view.element),_n(this.foldable_,this.view.pickerElement))}onButtonBlur_(o){if(!this.popC_)return;const p=o.relatedTarget;(!p||!this.popC_.view.element.contains(p))&&(this.popC_.shows.rawValue=!1)}onButtonClick_(){this.foldable_.set("expanded",!this.foldable_.get("expanded")),this.foldable_.get("expanded")&&this.pickerC_.allFocusableElements[0].focus()}onPopupChildBlur_(o){if(!this.popC_)return;const p=this.popC_.view.element,v=$t(o);v&&p.contains(v)||v&&v===this.view.buttonElement&&!ze(p.ownerDocument)||(this.popC_.shows.rawValue=!1)}onPopupChildKeydown_(o){this.popC_&&o.key==="Escape"&&(this.popC_.shows.rawValue=!1)}}function li(){return new Ns({assembly:ri,components:[0,1,2,3].map(m=>m%2===0?new ft({min:0,max:1}):void 0)})}const _t={id:"cubic-bezier",type:"blade",css:'.tp-cbzgv,.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:rgba(0,0,0,0);border-width:0;font-family:inherit;font-size:inherit;font-weight:inherit;margin:0;outline:none;padding:0}.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{background-color:var(--btn-bg);border-radius:var(--elm-br);color:var(--btn-fg);cursor:pointer;display:block;font-weight:bold;height:var(--bld-us);line-height:var(--bld-us);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-radv_b:hover,.tp-rslv_k:hover,.tp-cbzv_b:hover{background-color:var(--btn-bg-h)}.tp-radv_b:focus,.tp-rslv_k:focus,.tp-cbzv_b:focus{background-color:var(--btn-bg-f)}.tp-radv_b:active,.tp-rslv_k:active,.tp-cbzv_b:active{background-color:var(--btn-bg-a)}.tp-radv_b:disabled,.tp-rslv_k:disabled,.tp-cbzv_b:disabled{opacity:.5}.tp-cbzgv{background-color:var(--in-bg);border-radius:var(--elm-br);box-sizing:border-box;color:var(--in-fg);font-family:inherit;height:var(--bld-us);line-height:var(--bld-us);min-width:0;width:100%}.tp-cbzgv:hover{background-color:var(--in-bg-h)}.tp-cbzgv:focus{background-color:var(--in-bg-f)}.tp-cbzgv:active{background-color:var(--in-bg-a)}.tp-cbzgv:disabled{opacity:.5}.tp-btngridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-btngridv.tp-v-disabled{opacity:.5}.tp-btngridv .tp-btnv_b:disabled{opacity:1}.tp-btngridv .tp-btnv_b:disabled .tp-btnv_t{opacity:.5}.tp-btngridv .tp-btnv_b{border-radius:0}.tp-cbzv{position:relative}.tp-cbzv_h{display:flex}.tp-cbzv_b{margin-right:4px;position:relative;width:var(--bld-us)}.tp-cbzv_b svg{display:block;height:16px;left:50%;margin-left:-8px;margin-top:-8px;position:absolute;top:50%;width:16px}.tp-cbzv_b svg path{stroke:var(--bs-bg);stroke-width:2}.tp-cbzv_t{flex:1}.tp-cbzv_p{height:0;margin-top:0;opacity:0;overflow:hidden;transition:height .2s ease-in-out,opacity .2s linear,margin .2s ease-in-out}.tp-cbzv.tp-cbzv-expanded .tp-cbzv_p{margin-top:var(--bld-s);opacity:1}.tp-cbzv.tp-cbzv-cpl .tp-cbzv_p{overflow:visible}.tp-cbzv .tp-popv{left:calc(-1*var(--cnt-h-p));position:absolute;right:calc(-1*var(--cnt-h-p));top:var(--bld-us)}.tp-cbzpv_t{margin-top:var(--bld-s)}.tp-cbzgv{height:auto;overflow:hidden;position:relative}.tp-cbzgv.tp-v-disabled{opacity:.5}.tp-cbzgv_p{left:16px;position:absolute;right:16px;top:0}.tp-cbzgv_g{cursor:pointer;display:block;height:calc(var(--bld-us)*5);width:100%}.tp-cbzgv_u{opacity:.1;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_l{fill:rgba(0,0,0,0);stroke:var(--in-fg)}.tp-cbzgv_v{opacity:.5;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_h{border:var(--in-fg) solid 1px;border-radius:50%;box-sizing:border-box;height:4px;margin-left:-2px;margin-top:-2px;pointer-events:none;position:absolute;width:4px}.tp-cbzgv:focus .tp-cbzgv_h-sel{background-color:var(--in-fg);border-width:0}.tp-cbzprvv{cursor:pointer;height:4px;padding:4px 0;position:relative}.tp-cbzprvv_g{display:block;height:100%;overflow:visible;width:100%}.tp-cbzprvv_t{opacity:.5;stroke:var(--mo-fg)}.tp-cbzprvv_m{background-color:var(--mo-fg);border-radius:50%;height:4px;margin-left:-2px;margin-top:-2px;opacity:0;position:absolute;top:50%;transition:opacity .2s ease-out;width:4px}.tp-cbzprvv_m.tp-cbzprvv_m-a{opacity:1}.tp-fpsv{position:relative}.tp-fpsv_l{bottom:4px;color:var(--mo-fg);line-height:1;right:4px;pointer-events:none;position:absolute}.tp-fpsv_u{margin-left:.2em;opacity:.7}.tp-rslv{cursor:pointer;padding-left:8px;padding-right:8px}.tp-rslv.tp-v-disabled{opacity:.5}.tp-rslv_t{height:calc(var(--bld-us));position:relative}.tp-rslv_t::before{background-color:var(--in-bg);border-radius:1px;content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:-4px;right:-4px}.tp-rslv_b{bottom:0;top:0;position:absolute}.tp-rslv_b::before{background-color:var(--in-fg);content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:0;right:0}.tp-rslv_k{height:calc(var(--bld-us) - 8px);margin-top:calc((var(--bld-us) - 8px)/-2);position:absolute;top:50%;width:8px}.tp-rslv_k.tp-rslv_k-min{margin-left:-8px}.tp-rslv_k.tp-rslv_k-max{margin-left:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-min{border-bottom-right-radius:0;border-top-right-radius:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-max{border-bottom-left-radius:0;border-top-left-radius:0}.tp-rsltxtv{display:flex}.tp-rsltxtv_s{flex:1}.tp-rsltxtv_t{flex:1;margin-left:4px}.tp-radv_l{display:block;position:relative}.tp-radv_i{left:0;opacity:0;position:absolute;top:0}.tp-radv_b{opacity:.5}.tp-radv_i:hover+.tp-radv_b{background-color:var(--btn-bg-h)}.tp-radv_i:focus+.tp-radv_b{background-color:var(--btn-bg-f)}.tp-radv_i:active+.tp-radv_b{background-color:var(--btn-bg-a)}.tp-radv_i:checked+.tp-radv_b{opacity:1}.tp-radv_t{bottom:0;color:inherit;left:0;overflow:hidden;position:absolute;right:0;text-align:center;text-overflow:ellipsis;top:0}.tp-radv_i:disabled+.tp-radv_b>.tp-radv_t{opacity:.5}.tp-radgridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-radgridv.tp-v-disabled{opacity:.5}.tp-radgridv .tp-radv_b{border-radius:0}',accept(m){const o=he,p=ee(m,{value:o.required.array(o.required.number),view:o.required.constant("cubicbezier"),expanded:o.optional.boolean,label:o.optional.string,picker:o.optional.custom(v=>v==="inline"||v==="popup"?v:void 0)});return p?{params:p}:null},controller(m){var o,p;const v=new ct(...m.params.value),C=X(v,{constraint:li(),equals:ct.equals}),k=new An(m.document,{axis:{baseStep:.1,textProps:Y.fromObject({draggingScale:.01,formatter:Se(2)})},expanded:(o=m.params.expanded)!==null&&o!==void 0?o:!1,pickerLayout:(p=m.params.picker)!==null&&p!==void 0?p:"popup",value:C,viewProps:m.viewProps});return new mt(m.document,{blade:m.blade,props:Y.fromObject({label:m.params.label}),valueController:k})},api(m){return!(m.controller instanceof mt)||!(m.controller.valueController instanceof An)?null:new Ki(m.controller)}};class _e extends s{begin(){this.controller_.valueController.begin()}end(){this.controller_.valueController.end()}}const ci=20;class Me{constructor(){this.start_=null,this.duration_=0,this.fps_=null,this.frameCount_=0,this.timestamps_=[]}get duration(){return this.duration_}get fps(){return this.fps_}begin(o){this.start_=o.getTime()}calculateFps_(o){if(this.timestamps_.length===0)return null;const p=this.timestamps_[0];return 1e3*(this.frameCount_-p.frameCount)/(o-p.time)}compactTimestamps_(){if(this.timestamps_.length<=ci)return;const o=this.timestamps_.length-ci;this.timestamps_.splice(0,o);const p=this.timestamps_[0].frameCount;this.timestamps_.forEach(v=>{v.frameCount-=p}),this.frameCount_-=p}end(o){if(this.start_===null)return;const p=o.getTime();this.duration_=p-this.start_,this.start_=null,this.fps_=this.calculateFps_(p),this.timestamps_.push({frameCount:this.frameCount_,time:p}),++this.frameCount_,this.compactTimestamps_()}}const Ot=x("fps");class Ne{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(Ot()),p.viewProps.bindClassModifiers(this.element),this.graphElement=o.createElement("div"),this.graphElement.classList.add(Ot("g")),this.element.appendChild(this.graphElement);const v=o.createElement("div");v.classList.add(Ot("l")),this.element.appendChild(v);const C=o.createElement("span");C.classList.add(Ot("v")),C.textContent="--",v.appendChild(C),this.valueElement=C;const k=o.createElement("span");k.classList.add(Ot("u")),k.textContent="FPS",v.appendChild(k)}}class pi{constructor(o,p){this.stopwatch_=new Me,this.onTick_=this.onTick_.bind(this),this.ticker_=p.ticker,this.ticker_.emitter.on("tick",this.onTick_),this.value_=p.value,this.viewProps=p.viewProps,this.view=new Ne(o,{viewProps:this.viewProps}),this.graphC_=new Us(o,{formatter:Se(0),lineCount:p.lineCount,props:Y.fromObject({maxValue:p.maxValue,minValue:p.minValue}),value:this.value_,viewProps:this.viewProps}),this.view.graphElement.appendChild(this.graphC_.view.element),this.viewProps.handleDispose(()=>{this.graphC_.viewProps.set("disposed",!0),this.ticker_.dispose()})}begin(){this.stopwatch_.begin(new Date)}end(){this.stopwatch_.end(new Date)}onTick_(){const o=this.stopwatch_.fps;if(o!==null){const p=this.value_.rawValue;this.value_.rawValue=As(p,o),this.view.valueElement.textContent=o.toFixed(0)}}}function on(m,o){return o===0?new wn:new Yt(m,o??zs.monitor.defaultInterval)}const ui={id:"fpsgraph",type:"blade",accept(m){const o=he,p=ee(m,{view:o.required.constant("fpsgraph"),interval:o.optional.number,label:o.optional.string,lineCount:o.optional.number,max:o.optional.number,min:o.optional.number});return p?{params:p}:null},controller(m){var o,p,v,C;const k=(o=m.params.interval)!==null&&o!==void 0?o:500;return new Qe(m.document,{blade:m.blade,props:Y.fromObject({label:m.params.label}),valueController:new pi(m.document,{lineCount:(p=m.params.lineCount)!==null&&p!==void 0?p:2,maxValue:(v=m.params.max)!==null&&v!==void 0?v:90,minValue:(C=m.params.min)!==null&&C!==void 0?C:0,ticker:on(m.document,k),value:Vi(80),viewProps:m.viewProps})})},api(m){return!(m.controller instanceof Qe)||!(m.controller.valueController instanceof pi)?null:new _e(m.controller)}};class Fe{constructor(o,p){this.min=o,this.max=p}static isObject(o){if(typeof o!="object"||o===null)return!1;const p=o.min,v=o.max;return!(typeof p!="number"||typeof v!="number")}static equals(o,p){return o.min===p.min&&o.max===p.max}get length(){return this.max-this.min}toObject(){return{min:this.min,max:this.max}}}const hi={fromComponents:m=>new Fe(m[0],m[1]),toComponents:m=>[m.min,m.max]};class an{constructor(o){this.edge=o}constrain(o){var p,v,C,k,T,G,oe,Ge;if(o.min<=o.max)return new Fe((v=(p=this.edge)===null||p===void 0?void 0:p.constrain(o.min))!==null&&v!==void 0?v:o.min,(k=(C=this.edge)===null||C===void 0?void 0:C.constrain(o.max))!==null&&k!==void 0?k:o.max);const Ke=(o.min+o.max)/2;return new Fe((G=(T=this.edge)===null||T===void 0?void 0:T.constrain(Ke))!==null&&G!==void 0?G:Ke,(Ge=(oe=this.edge)===null||oe===void 0?void 0:oe.constrain(Ke))!==null&&Ge!==void 0?Ge:Ke)}}const di=x("rsltxt");class Vn{constructor(o,p){this.sliderView_=p.sliderView,this.textView_=p.textView,this.element=o.createElement("div"),this.element.classList.add(di());const v=o.createElement("div");v.classList.add(di("s")),v.appendChild(this.sliderView_.element),this.element.appendChild(v);const C=o.createElement("div");C.classList.add(di("t")),C.appendChild(this.textView_.element),this.element.appendChild(C)}}const Xe=x("rsl");class ln{constructor(o,p){this.onSliderPropsChange_=this.onSliderPropsChange_.bind(this),this.onValueChange_=this.onValueChange_.bind(this),this.sliderProps_=p.sliderProps,this.sliderProps_.emitter.on("change",this.onSliderPropsChange_),this.element=o.createElement("div"),this.element.classList.add(Xe()),p.viewProps.bindClassModifiers(this.element),this.value_=p.value,this.value_.emitter.on("change",this.onValueChange_);const v=o.createElement("div");v.classList.add(Xe("t")),this.element.appendChild(v),this.trackElement=v;const C=o.createElement("div");C.classList.add(Xe("b")),v.appendChild(C),this.barElement=C;const k=["min","max"].map(T=>{const G=o.createElement("div");return G.classList.add(Xe("k"),Xe("k",T)),v.appendChild(G),G});this.knobElements=[k[0],k[1]],this.update_()}valueToX_(o){const p=this.sliderProps_.get("minValue"),v=this.sliderProps_.get("maxValue");return It(Pe(o,p,v,0,1),0,1)*100}update_(){const o=this.value_.rawValue;o.length===0?this.element.classList.add(Xe(void 0,"zero")):this.element.classList.remove(Xe(void 0,"zero"));const p=[this.valueToX_(o.min),this.valueToX_(o.max)];this.barElement.style.left=`${p[0]}%`,this.barElement.style.right=`${100-p[1]}%`,this.knobElements.forEach((v,C)=>{v.style.left=`${p[C]}%`})}onSliderPropsChange_(){this.update_()}onValueChange_(){this.update_()}}class mi{constructor(o,p){this.grabbing_=null,this.grabOffset_=0,this.onPointerDown_=this.onPointerDown_.bind(this),this.onPointerMove_=this.onPointerMove_.bind(this),this.onPointerUp_=this.onPointerUp_.bind(this),this.sliderProps=p.sliderProps,this.viewProps=p.viewProps,this.value=p.value,this.view=new ln(o,{sliderProps:this.sliderProps,value:this.value,viewProps:p.viewProps});const v=new Mn(this.view.trackElement);v.emitter.on("down",this.onPointerDown_),v.emitter.on("move",this.onPointerMove_),v.emitter.on("up",this.onPointerUp_)}ofs_(){return this.grabbing_==="min"?this.view.knobElements[0].getBoundingClientRect().width/2:this.grabbing_==="max"?-this.view.knobElements[1].getBoundingClientRect().width/2:0}valueFromData_(o){if(!o.point)return null;const p=(o.point.x+this.ofs_())/o.bounds.width,v=this.sliderProps.get("minValue"),C=this.sliderProps.get("maxValue");return Pe(p,0,1,v,C)}onPointerDown_(o){if(!o.data.point)return;const p=o.data.point.x/o.data.bounds.width,v=this.value.rawValue,C=this.sliderProps.get("minValue"),k=this.sliderProps.get("maxValue"),T=Pe(v.min,C,k,0,1),G=Pe(v.max,C,k,0,1);Math.abs(G-p)<=.025?this.grabbing_="max":Math.abs(T-p)<=.025?this.grabbing_="min":p>=T&&p<=G?(this.grabbing_="length",this.grabOffset_=Pe(p-T,0,1,0,k-C)):p<T?(this.grabbing_="min",this.onPointerMove_(o)):p>G&&(this.grabbing_="max",this.onPointerMove_(o))}applyPointToValue_(o,p){const v=this.valueFromData_(o);if(v===null)return;const C=this.sliderProps.get("minValue"),k=this.sliderProps.get("maxValue");if(this.grabbing_==="min")this.value.setRawValue(new Fe(v,this.value.rawValue.max),p);else if(this.grabbing_==="max")this.value.setRawValue(new Fe(this.value.rawValue.min,v),p);else if(this.grabbing_==="length"){const T=this.value.rawValue.length;let G=v-this.grabOffset_,oe=G+T;G<C?(G=C,oe=C+T):oe>k&&(G=k-T,oe=k),this.value.setRawValue(new Fe(G,oe),p)}}onPointerMove_(o){this.applyPointToValue_(o.data,{forceEmit:!1,last:!1})}onPointerUp_(o){this.applyPointToValue_(o.data,{forceEmit:!0,last:!0}),this.grabbing_=null}}class ot{constructor(o,p){this.value=p.value,this.viewProps=p.viewProps,this.sc_=new mi(o,p);const v={baseStep:p.baseStep,constraint:p.constraint,textProps:Y.fromObject({draggingScale:p.draggingScale,formatter:p.formatter})};this.tc_=new bt(o,{assembly:hi,axes:[v,v],parser:p.parser,value:this.value,viewProps:p.viewProps}),this.view=new Vn(o,{sliderView:this.sc_.view,textView:this.tc_.view})}get textController(){return this.tc_}}function Qi(m){return Fe.isObject(m)?new Fe(m.min,m.max):new Fe(0,0)}function fi(m,o){m.writeProperty("max",o.max),m.writeProperty("min",o.min)}function Zs(m){const o=[],p=nn(m);p&&o.push(p);const v=js(m);return v&&o.push(v),new an(new yn(o))}const In={id:"input-interval",type:"input",css:'.tp-cbzgv,.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:rgba(0,0,0,0);border-width:0;font-family:inherit;font-size:inherit;font-weight:inherit;margin:0;outline:none;padding:0}.tp-radv_b,.tp-rslv_k,.tp-cbzv_b{background-color:var(--btn-bg);border-radius:var(--elm-br);color:var(--btn-fg);cursor:pointer;display:block;font-weight:bold;height:var(--bld-us);line-height:var(--bld-us);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-radv_b:hover,.tp-rslv_k:hover,.tp-cbzv_b:hover{background-color:var(--btn-bg-h)}.tp-radv_b:focus,.tp-rslv_k:focus,.tp-cbzv_b:focus{background-color:var(--btn-bg-f)}.tp-radv_b:active,.tp-rslv_k:active,.tp-cbzv_b:active{background-color:var(--btn-bg-a)}.tp-radv_b:disabled,.tp-rslv_k:disabled,.tp-cbzv_b:disabled{opacity:.5}.tp-cbzgv{background-color:var(--in-bg);border-radius:var(--elm-br);box-sizing:border-box;color:var(--in-fg);font-family:inherit;height:var(--bld-us);line-height:var(--bld-us);min-width:0;width:100%}.tp-cbzgv:hover{background-color:var(--in-bg-h)}.tp-cbzgv:focus{background-color:var(--in-bg-f)}.tp-cbzgv:active{background-color:var(--in-bg-a)}.tp-cbzgv:disabled{opacity:.5}.tp-btngridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-btngridv.tp-v-disabled{opacity:.5}.tp-btngridv .tp-btnv_b:disabled{opacity:1}.tp-btngridv .tp-btnv_b:disabled .tp-btnv_t{opacity:.5}.tp-btngridv .tp-btnv_b{border-radius:0}.tp-cbzv{position:relative}.tp-cbzv_h{display:flex}.tp-cbzv_b{margin-right:4px;position:relative;width:var(--bld-us)}.tp-cbzv_b svg{display:block;height:16px;left:50%;margin-left:-8px;margin-top:-8px;position:absolute;top:50%;width:16px}.tp-cbzv_b svg path{stroke:var(--bs-bg);stroke-width:2}.tp-cbzv_t{flex:1}.tp-cbzv_p{height:0;margin-top:0;opacity:0;overflow:hidden;transition:height .2s ease-in-out,opacity .2s linear,margin .2s ease-in-out}.tp-cbzv.tp-cbzv-expanded .tp-cbzv_p{margin-top:var(--bld-s);opacity:1}.tp-cbzv.tp-cbzv-cpl .tp-cbzv_p{overflow:visible}.tp-cbzv .tp-popv{left:calc(-1*var(--cnt-h-p));position:absolute;right:calc(-1*var(--cnt-h-p));top:var(--bld-us)}.tp-cbzpv_t{margin-top:var(--bld-s)}.tp-cbzgv{height:auto;overflow:hidden;position:relative}.tp-cbzgv.tp-v-disabled{opacity:.5}.tp-cbzgv_p{left:16px;position:absolute;right:16px;top:0}.tp-cbzgv_g{cursor:pointer;display:block;height:calc(var(--bld-us)*5);width:100%}.tp-cbzgv_u{opacity:.1;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_l{fill:rgba(0,0,0,0);stroke:var(--in-fg)}.tp-cbzgv_v{opacity:.5;stroke:var(--in-fg);stroke-dasharray:1}.tp-cbzgv_h{border:var(--in-fg) solid 1px;border-radius:50%;box-sizing:border-box;height:4px;margin-left:-2px;margin-top:-2px;pointer-events:none;position:absolute;width:4px}.tp-cbzgv:focus .tp-cbzgv_h-sel{background-color:var(--in-fg);border-width:0}.tp-cbzprvv{cursor:pointer;height:4px;padding:4px 0;position:relative}.tp-cbzprvv_g{display:block;height:100%;overflow:visible;width:100%}.tp-cbzprvv_t{opacity:.5;stroke:var(--mo-fg)}.tp-cbzprvv_m{background-color:var(--mo-fg);border-radius:50%;height:4px;margin-left:-2px;margin-top:-2px;opacity:0;position:absolute;top:50%;transition:opacity .2s ease-out;width:4px}.tp-cbzprvv_m.tp-cbzprvv_m-a{opacity:1}.tp-fpsv{position:relative}.tp-fpsv_l{bottom:4px;color:var(--mo-fg);line-height:1;right:4px;pointer-events:none;position:absolute}.tp-fpsv_u{margin-left:.2em;opacity:.7}.tp-rslv{cursor:pointer;padding-left:8px;padding-right:8px}.tp-rslv.tp-v-disabled{opacity:.5}.tp-rslv_t{height:calc(var(--bld-us));position:relative}.tp-rslv_t::before{background-color:var(--in-bg);border-radius:1px;content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:-4px;right:-4px}.tp-rslv_b{bottom:0;top:0;position:absolute}.tp-rslv_b::before{background-color:var(--in-fg);content:"";height:2px;margin-top:-1px;position:absolute;top:50%;left:0;right:0}.tp-rslv_k{height:calc(var(--bld-us) - 8px);margin-top:calc((var(--bld-us) - 8px)/-2);position:absolute;top:50%;width:8px}.tp-rslv_k.tp-rslv_k-min{margin-left:-8px}.tp-rslv_k.tp-rslv_k-max{margin-left:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-min{border-bottom-right-radius:0;border-top-right-radius:0}.tp-rslv.tp-rslv-zero .tp-rslv_k.tp-rslv_k-max{border-bottom-left-radius:0;border-top-left-radius:0}.tp-rsltxtv{display:flex}.tp-rsltxtv_s{flex:1}.tp-rsltxtv_t{flex:1;margin-left:4px}.tp-radv_l{display:block;position:relative}.tp-radv_i{left:0;opacity:0;position:absolute;top:0}.tp-radv_b{opacity:.5}.tp-radv_i:hover+.tp-radv_b{background-color:var(--btn-bg-h)}.tp-radv_i:focus+.tp-radv_b{background-color:var(--btn-bg-f)}.tp-radv_i:active+.tp-radv_b{background-color:var(--btn-bg-a)}.tp-radv_i:checked+.tp-radv_b{opacity:1}.tp-radv_t{bottom:0;color:inherit;left:0;overflow:hidden;position:absolute;right:0;text-align:center;text-overflow:ellipsis;top:0}.tp-radv_i:disabled+.tp-radv_b>.tp-radv_t{opacity:.5}.tp-radgridv{border-radius:var(--elm-br);display:grid;overflow:hidden;gap:2px}.tp-radgridv.tp-v-disabled{opacity:.5}.tp-radgridv .tp-radv_b{border-radius:0}',accept:(m,o)=>{if(!Fe.isObject(m))return null;const p=he,v=ee(o,{format:p.optional.function,max:p.optional.number,min:p.optional.number,step:p.optional.number});return v?{initialValue:new Fe(m.min,m.max),params:v}:null},binding:{reader:m=>Qi,constraint:m=>Zs(m.params),equals:Fe.equals,writer:m=>fi},controller(m){var o;const p=m.value,v=m.constraint;if(!(v instanceof an))throw _.shouldNeverHappen();const C=(p.rawValue.min+p.rawValue.max)/2,k=(o=m.params.format)!==null&&o!==void 0?o:Se(en(v.edge,C)),T=v.edge&&lt(v.edge,st);if(T)return new ot(m.document,{baseStep:ti(v.edge),constraint:v.edge,draggingScale:kn(v.edge,C),formatter:k,parser:Wt,sliderProps:new Y({maxValue:T.values.value("max"),minValue:T.values.value("min")}),value:p,viewProps:m.viewProps});const G={baseStep:ti(v.edge),constraint:v.edge,textProps:Y.fromObject({draggingScale:C,formatter:k})};return new bt(m.document,{assembly:hi,axes:[G,G],parser:Wt,value:p,viewProps:m.viewProps})}};class wt{constructor(o){this.controller_=o}get disabled(){return this.controller_.viewProps.get("disabled")}set disabled(o){this.controller_.viewProps.set("disabled",o)}get title(){var o;return(o=this.controller_.props.get("title"))!==null&&o!==void 0?o:""}set title(o){this.controller_.props.set("title",o)}}class yt extends c{constructor(o,p,v,C,k){super(o,C,k),this.cell=p,this.index=v}}class cn extends s{constructor(o){super(o),this.cellToApiMap_=new Map,this.controller_.valueController.cellControllers.forEach(v=>{const C=new wt(v);this.cellToApiMap_.set(v,C)})}get value(){return this.controller_.value}cell(o,p){const v=this.controller_.valueController,C=v.cellControllers[p*v.size[0]+o];return this.cellToApiMap_.get(C)}on(o,p){const v=p.bind(this);this.controller_.value.emitter.on(o,C=>{const k=this.controller_.valueController,T=k.findCellByValue(C.rawValue);if(!T)return;const G=this.cellToApiMap_.get(T);if(!G)return;const oe=k.cellControllers.indexOf(T);v(new yt(this,G,[oe%k.size[0],Math.floor(oe/k.size[0])],C.rawValue,void 0))})}}const pn=x("rad");class Zi{constructor(o,p){this.element=o.createElement("div"),this.element.classList.add(pn()),p.viewProps.bindClassModifiers(this.element);const v=o.createElement("label");v.classList.add(pn("l")),this.element.appendChild(v);const C=o.createElement("input");C.classList.add(pn("i")),C.name=p.name,C.type="radio",p.viewProps.bindDisabled(C),v.appendChild(C),this.inputElement=C;const k=o.createElement("div");k.classList.add(pn("b")),v.appendChild(k);const T=o.createElement("div");T.classList.add(pn("t")),k.appendChild(T),E(p.props,"title",G=>{T.textContent=G})}}class Wi{constructor(o,p){this.props=p.props,this.viewProps=p.viewProps,this.view=new Zi(o,{name:p.name,props:this.props,viewProps:this.viewProps})}}class Dn{constructor(o,p){this.cellCs_=[],this.cellValues_=[],this.onCellInputChange_=this.onCellInputChange_.bind(this),this.size=p.size;const[v,C]=this.size;for(let k=0;k<C;k++)for(let T=0;T<v;T++){const G=new Wi(o,{name:p.groupName,props:Y.fromObject(Object.assign({},p.cellConfig(T,k))),viewProps:be.create()});this.cellCs_.push(G),this.cellValues_.push(p.cellConfig(T,k).value)}this.value=p.value,I(this.value,k=>{const T=this.findCellByValue(k);T&&(T.view.inputElement.checked=!0)}),this.viewProps=be.create(),this.view=new at(o,{viewProps:this.viewProps,viewName:"radgrid"}),this.view.element.style.gridTemplateColumns=`repeat(${v}, 1fr)`,this.cellCs_.forEach(k=>{k.view.inputElement.addEventListener("change",this.onCellInputChange_),this.view.element.appendChild(k.view.element)})}get cellControllers(){return this.cellCs_}findCellByValue(o){const p=this.cellValues_.findIndex(v=>v===o);return p<0?null:this.cellCs_[p]}onCellInputChange_(o){const p=o.currentTarget,v=this.cellCs_.findIndex(C=>C.view.inputElement===p);v<0||(this.value.rawValue=this.cellValues_[v])}}const xt=function(){return{id:"radiogrid",type:"blade",accept(m){const o=he,p=ee(m,{cells:o.required.function,groupName:o.required.string,size:o.required.array(o.required.number),value:o.required.raw,view:o.required.constant("radiogrid"),label:o.optional.string});return p?{params:p}:null},controller(m){return new mt(m.document,{blade:m.blade,props:Y.fromObject({label:m.params.label}),valueController:new Dn(m.document,{groupName:m.params.groupName,cellConfig:m.params.cells,size:m.params.size,value:X(m.params.value)})})},api(m){return!(m.controller instanceof mt)||!(m.controller.valueController instanceof Dn)?null:new cn(m.controller)}}}();function vi(m){return{id:"input-radiogrid",type:"input",accept(o,p){if(!m.isType(o))return null;const v=he,C=ee(p,{cells:v.required.function,groupName:v.required.string,size:v.required.array(v.required.number),view:v.required.constant("radiogrid")});return C?{initialValue:o,params:C}:null},binding:m.binding,controller:o=>new Dn(o.document,{cellConfig:o.params.cells,groupName:o.params.groupName,size:o.params.size,value:o.value})}}const Ws=vi({isType:m=>typeof m=="number",binding:{reader:m=>Ss,writer:m=>$e}}),Js=vi({isType:m=>typeof m=="string",binding:{reader:m=>Ai,writer:m=>$e}}),Hs=vi({isType:m=>typeof m=="boolean",binding:{reader:m=>qt,writer:m=>$e}}),Ji=[Gs,_t,ui,In,xt,Hs,Ws,Js];r.ButtonCellApi=Ri,r.ButtonGridApi=Gi,r.ButtonGridController=ii,r.CubicBezier=ct,r.CubicBezierApi=Ki,r.CubicBezierAssembly=ri,r.CubicBezierController=An,r.CubicBezierGraphController=He,r.CubicBezierGraphView=Le,r.CubicBezierPickerController=qi,r.CubicBezierPickerView=Xi,r.CubicBezierPreviewView=Et,r.CubicBezierView=$i,r.FpsGraphBladeApi=_e,r.FpsGraphController=pi,r.FpsView=Ne,r.Fpswatch=Me,r.Interval=Fe,r.IntervalAssembly=hi,r.IntervalConstraint=an,r.RadioCellApi=wt,r.RadioController=Wi,r.RadioGridApi=cn,r.RadioGridController=Dn,r.RadioView=Zi,r.RangeSliderController=mi,r.RangeSliderTextController=ot,r.RangeSliderTextView=Vn,r.RangeSliderView=ln,r.TpRadioGridChangeEvent=yt,r.plugins=Ji,Object.defineProperty(r,"__esModule",{value:!0})})})(Vl,Gn);const Il=Uo({__proto__:null,default:al(Gn)},[Gn]);let Kt,Ci;const Dl=(g="tres-container")=>{Kt||(Kt=new xi.Pane({container:document.querySelector(g)||void 0}),Kt.registerPlugin(Il),Ci=Kt.addBlade({view:"fpsgraph",label:"fpsgraph"}));function i(){Kt&&Kt.dispose()}return A.onMounted(()=>{const{onBeforeLoop:r,onAfterLoop:s,resume:a}=zt.useRenderLoop();a(),r(()=>Ci.begin()),s(()=>Ci.end())}),A.onUnmounted(()=>{i()}),{pane:Kt,fpsGraph:Ci,disposeTweakPane:i}};function Tl(g,i){const r=A.ref(i),s=new f.AnimationMixer(r.value),a=A.shallowReactive({});g.forEach(u=>{const h=s.clipAction(u,r.value);a[u.name]=h});const{onLoop:c}=zt.useRenderLoop();return c(({delta:u})=>{s.update(u)}),{actions:a,mixer:s}}let Pi=null;function El(g,i){return r=>{i&&i(r),g.draco&&(Pi||(Pi=new cl),Pi.setDecoderPath(g.decoderPath||"https://www.gstatic.com/draco/versioned/decoders/1.4.3/"),r.setDRACOLoader(Pi))}}async function Hr(g,i={draco:!1},r){return await zt.useLoader(la,g,El(i,r))}const Ol=A.defineComponent({name:"GLTFModel",props:["path","draco","decoderPath"],async setup(g,{expose:i}){const{state:r}=Rt(),s=A.ref();i({model:s});const{scene:a}=await Hr(g.path,{draco:g.draco,decoderPath:g.decoderPath});return s.value=a,r.scene&&r.scene.add(a),()=>{}}});async function eo(g){return await zt.useLoader(Xa,g)}const Bl=A.defineComponent({name:"FBXModel",props:["path"],async setup(g,{expose:i}){const{state:r}=Rt();let s=null;function a(){return s}return i({getModel:a}),s=await eo(g.path),r.scene&&s.isObject3D&&r.scene.add(s),()=>{}}}),Nl={key:0},Fl=["args","center"],jl=A.defineComponent({__name:"Text3D",props:{font:null,text:null,size:{default:.5},height:{default:.2},curveSegments:{default:5},bevelEnabled:{type:Boolean,default:!0},bevelThickness:{default:.05},bevelSize:{default:.02},bevelOffset:{default:0},bevelSegments:{default:4},center:{type:Boolean,default:!1}},async setup(g){let i,r;const s=g,{extend:a}=Rt();a({TextGeometry:Fa});const c=new sl,u=A.useSlots(),h=A.computed(()=>{var y;return s.text?s.text:u.default?(y=u.default()[0].children)==null?void 0:y.trim():"TresJS"}),d=([i,r]=A.withAsyncContext(()=>new Promise((y,w)=>{try{typeof s.font=="string"?c.load(s.font,x=>{y(x)}):y(s.font)}catch(x){w(console.error("cientos",x))}})),i=await i,r(),i),_=A.computed(()=>({font:d,size:s.size,height:s.height,curveSegments:s.curveSegments,bevelEnabled:s.bevelEnabled,bevelThickness:s.bevelThickness,bevelSize:s.bevelSize,bevelOffset:s.bevelOffset,bevelSegments:s.bevelSegments}));return(y,w)=>A.unref(d)?(A.openBlock(),A.createElementBlock("TresMesh",Nl,[A.unref(h)?(A.openBlock(),A.createElementBlock("TresTextGeometry",{key:0,args:[A.unref(h),A.unref(_)],center:g.center},null,8,Fl)):A.createCommentVNode("",!0),A.renderSlot(y.$slots,"default")])):A.createCommentVNode("",!0)}}),zl=["rotation"],Ul=["args"],Rl=["color"],Gl=A.defineComponent({__name:"Plane",props:{args:{default:()=>[1,1]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"planeRef",ref:r,rotation:[-Math.PI/2,0,0]},s.$attrs),[A.createElementVNode("TresPlaneGeometry",{args:g.args},null,8,Ul),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,Rl)])],16,zl))}}),Kl=["args"],$l=["color"],Xl=A.defineComponent({__name:"Box",props:{args:{default:()=>[1,1,1]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"boxRef",ref:r},s.$attrs),[A.createElementVNode("TresBoxGeometry",{args:g.args},null,8,Kl),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,$l)])],16))}}),Yl=["args"],ql=["color"],Ql=A.defineComponent({__name:"Sphere",props:{args:{default:()=>[2,32,16]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"sphereRef",ref:r},s.$attrs),[A.createElementVNode("TresSphereGeometry",{args:g.args},null,8,Yl),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,ql)])],16))}}),Zl=["args"],Wl=["color"],Jl=A.defineComponent({__name:"Torus",props:{args:{default:()=>[1,1,16,80]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"torusRef",ref:r},s.$attrs),[A.createElementVNode("TresTorusGeometry",{args:g.args},null,8,Zl),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,Wl)])],16))}}),Hl=["args"],ec=["color"],tc=A.defineComponent({__name:"TorusKnot",props:{args:{default:()=>[1,.4,64,8]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"torusKnotRef",ref:r},s.$attrs),[A.createElementVNode("TresTorusKnotGeometry",{args:g.args},null,8,Hl),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,ec)])],16))}}),nc=["args"],ic=["color"],sc=A.defineComponent({__name:"Circle",props:{args:{default:()=>[1,32,0,Math.PI*2]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"circleRef",ref:r},s.$attrs),[A.createElementVNode("TresCircleGeometry",{args:g.args},null,8,nc),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,ic)])],16))}}),rc=["args"],oc=["color"],ac=A.defineComponent({__name:"Cone",props:{args:{default:()=>[1,1,12,!1,0,Math.PI*2]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"coneRef",ref:r},s.$attrs),[A.createElementVNode("TresConeGeometry",{args:g.args},null,8,rc),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,oc)])],16))}}),lc=["args"],cc=["color"],pc=A.defineComponent({__name:"Tube",props:{args:{default:()=>[new f.QuadraticBezierCurve3(new f.Vector3(-1,0,0),new f.Vector3(0,1,0),new f.Vector3(1,0,0)),20,.2,8,!1]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"tubeRef",ref:r},s.$attrs),[A.createElementVNode("TresTubeGeometry",{args:g.args},null,8,lc),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,cc)])],16))}}),uc=["args"],hc=["color"],dc=A.defineComponent({__name:"Ring",props:{args:{default:()=>[.5,1,32]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"ringRef",ref:r},s.$attrs),[A.createElementVNode("TresRingGeometry",{args:g.args},null,8,uc),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,hc)])],16))}}),mc=["rotation"],fc=["args"],vc=["color"],bc=A.defineComponent({__name:"Tetrahedron",props:{args:{default:()=>[1,0]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"tetrahedronRef",ref:r,rotation:[-Math.PI/2,0,0]},s.$attrs),[A.createElementVNode("TresTetrahedronGeometry",{args:g.args},null,8,fc),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,vc)])],16,mc))}}),gc=["args"],_c=["color"],wc=A.defineComponent({__name:"Icosahedron",props:{args:{default:()=>[1,0]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"icosahedronRef",ref:r},s.$attrs),[A.createElementVNode("TresIcosahedronGeometry",{args:g.args},null,8,gc),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,_c)])],16))}}),yc=["args"],xc=["color"],Cc=A.defineComponent({__name:"Octahedron",props:{args:{default:()=>[1,0]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"octahedronRef",ref:r},s.$attrs),[A.createElementVNode("TresOctahedronGeometry",{args:g.args},null,8,yc),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,xc)])],16))}}),Pc=["args"],Mc=["color"],kc=A.defineComponent({__name:"Dodecahedron",props:{args:{default:()=>[1,0]},color:{default:"0xffffff"}},setup(g,{expose:i}){const r=A.shallowRef();return i({value:r}),(s,a)=>(A.openBlock(),A.createElementBlock("TresMesh",A.mergeProps({ref_key:"dodecahedronRef",ref:r},s.$attrs),[A.createElementVNode("TresDodecahedronGeometry",{args:g.args},null,8,Pc),A.renderSlot(s.$slots,"default",{},()=>[A.createElementVNode("TresMeshBasicMaterial",{color:g.color},null,8,Mc)])],16))}}),ms={sunset:"venice/venice_sunset_4k.hdr"};async function to({files:g=["/px.png","/nx.png","/py.png","/ny.png","/pz.png","/nz.png"],blur:i=0,background:r=!1,path:s="/",preset:a=void 0,encoding:c=void 0}){const{state:u}=Rt();if(a){if(!(a in ms))throw new Error("Preset must be one of: "+Object.keys(ms).join(", "));g=ms[a],s="https://raw.githubusercontent.com/Tresjs/assets/main/textures/hdr/"}const h=Array.isArray(g),d=h?f.CubeTextureLoader:ll,_=await zt.useLoader(d,h?[g]:g,w=>{s&&w.setPath(s),c&&(w.encoding=c)}),y=h?_[0]:_;return y&&(y.mapping=h?f.CubeReflectionMapping:f.EquirectangularReflectionMapping,y.encoding=c??h?f.sRGBEncoding:f.LinearEncoding),u.scene&&(u.scene.environment=y,r!==void 0&&(u.scene.background=y),i&&(u.scene.backgroundBlurriness=i|0)),y}const Sc=A.defineComponent({name:"Environment",props:["background","blur","files","encoding","path","preset"],async setup(g,{expose:i}){let r=null;return i({getTexture:()=>r}),r=await to(g),()=>{}}});ae.Box=Xl,ae.Circle=sc,ae.Cone=ac,ae.Dodecahedron=kc,ae.Environment=Sc,ae.FBXModel=Bl,ae.GLTFModel=Ol,ae.Icosahedron=wc,ae.Octahedron=Cc,ae.OrbitControls=hl,ae.PamCameraMouse=Ll,ae.Plane=Gl,ae.Ring=dc,ae.Sphere=Ql,ae.Tetrahedron=bc,ae.Text3D=jl,ae.Torus=Jl,ae.TorusKnot=tc,ae.TransformControls=fl,ae.Tube=pc,ae.useAnimations=Tl,ae.useEnvironment=to,ae.useFBX=eo,ae.useGLTF=Hr,ae.usePamCameraMouse=Jr,ae.useTweakPane=Dl,Object.defineProperty(ae,Symbol.toStringTag,{value:"Module"})});