@tresjs/leches
Version:
Tasty GUI for Vue controls 🍰
9 lines (8 loc) • 22.4 kB
JavaScript
/**
* name: @tresjs/leches
* version: v0.14.1
* (c) 2025
* description: Tasty GUI for Vue controls 🍰
* author: Alvaro Saburido <hola@alvarosaburido.dev> (https://github.com/alvarosabu/)
*/
(function(V,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue"),require("@vueuse/core")):typeof define=="function"&&define.amd?define(["exports","vue","@vueuse/core"],e):(V=typeof globalThis<"u"?globalThis:V||self,e(V.tresleches={},V.Vue,V.VueUseCore))})(this,function(V,e,w){"use strict";const U=typeof window<"u"&&typeof document<"u";typeof WorkerGlobalScope<"u"&&globalThis instanceof WorkerGlobalScope;function G(l,r={}){if(!e.isRef(l))return e.toRefs(l);const n=Array.isArray(l.value)?Array.from({length:l.value.length}):{};for(const o in l.value)n[o]=e.customRef(()=>({get(){return l.value[o]},set(t){var u;if((u=e.toValue(r.replaceRef))!=null?u:!0)if(Array.isArray(l.value)){const i=[...l.value];i[o]=t,l.value=i}else{const i={...l.value,[o]:t};Object.setPrototypeOf(i,Object.getPrototypeOf(l.value)),l.value=i}else l.value[o]=t}}));return n}const N=e.toValue,H=U?window:void 0;function J(l,r={}){const{pointerTypes:n,preventDefault:o,stopPropagation:t,exact:u,onMove:s,onEnd:i,onStart:d,initialValue:y,axis:g="both",draggingElement:c=H,handle:a=l}=r,{width:b}=w.useWindowSize();let B=b.value;const p=e.ref(N(y)??{x:0,y:0});e.watch(b,()=>{const m=b.value-B;p.value.x+=m,B=b.value});const C=e.ref(),$=m=>n?n.includes(m.pointerType):!0,_=m=>{N(o)&&m.preventDefault(),N(t)&&m.stopPropagation()},E=m=>{if(!$(m)||N(u)&&m.target!==N(l))return;const f=N(l).getBoundingClientRect(),k={x:m.clientX-f.left,y:m.clientY-f.top};(d==null?void 0:d(k,m))!==!1&&(C.value=k,_(m))},S=m=>{if(!$(m)||!C.value)return;let{x:f,y:k}=p.value;(g==="x"||g==="both")&&(f=m.clientX-C.value.x),(g==="y"||g==="both")&&(k=m.clientY-C.value.y),p.value={x:f,y:k},s==null||s(p.value,m),_(m)},F=m=>{$(m)&&C.value&&(C.value=void 0,i==null||i(p.value,m),_(m))};if(U){const m={capture:r.capture??!0};w.useEventListener(a,"pointerdown",E,m),w.useEventListener(c,"pointermove",S,m),w.useEventListener(c,"pointerup",F,m)}return{...G(p),position:p,isDragging:e.computed(()=>!!C.value),style:e.computed(()=>`left:${p.value.x}px;top:${p.value.y}px;`)}}const Q=e.defineComponent({name:"UseDraggable",props:["storageKey","storageType","initialValue","exact","preventDefault","stopPropagation","pointerTypes","as","handle","axis","onStart","onMove","onEnd"],setup(l,{slots:r}){const n=e.ref(),o=e.computed(()=>l.handle??n.value),t=l.storageKey&&w.useStorage(l.storageKey,N(l.initialValue)||{x:0,y:0},w.isClient?l.storageType==="session"?sessionStorage:localStorage:void 0),u=t||l.initialValue||{x:0,y:0},s=(d,y)=>{var g;(g=l.onEnd)==null||g.call(l,d,y),t&&(t.value.x=d.x,t.value.y=d.y)},i=e.reactive(J(n,{...l,handle:o,initialValue:u,onEnd:s}));return()=>{if(r.default)return e.h(l.as||"div",{ref:n,style:`touch-action:none;${i.style}`},r.default(i))}}}),Z=Symbol("CONTROLS_CONTEXT_KEY"),O="default",D=e.reactive({});function R(l=O){return e.provide(Z,D),D[l]}const I=l=>{const r=/^#(?:[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$|^0x(?:[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/;return typeof l=="boolean"?"boolean":typeof l=="number"?"number":typeof l=="string"&&r.test(l)?"color":typeof l=="string"?"string":l.isVector3||l.isVector2||l.isEuler||Array.isArray(l.value)||l.value.isVector3||l.value.isVector2||l.value.isEuler||Array.isArray(l.value.value)?"vector":l.min!==void 0||l.max!==void 0||l.step!==void 0?"range":l.options&&Array.isArray(l.options)?"select":"unknown"},A=(l,r,n,o)=>{const t={key:e.ref(l),label:e.ref(l),name:e.ref(l),type:e.ref(n),value:e.ref(r),visible:e.ref(!0),icon:e.ref(),uniqueKey:e.ref(l),[l]:e.ref(r)};return o&&(t.folder=e.ref(o)),t},v=(l,r,n)=>{const o={},t=typeof l=="string"?l:null,u=t?r:l,s=t&&t!=="fpsgraph"?n:r,i=(s==null?void 0:s.uuid)||O;if(D[i]||(D[i]=e.reactive({})),l==="fpsgraph"){const c=A("fpsgraph",null,"fpsgraph",null);return D[i].fpsgraph=c,o.fpsgraph=c,e.toRefs(e.reactive(o))}const d=D[i],y=e.isReactive(u),g=y?e.toRefs(u):{};for(const c in u){let a=u[c],b=c;if(y&&g[c]&&(a=g[c]),t&&(b=`${t}${c.charAt(0).toUpperCase()+c.slice(1)}`),typeof a=="object"&&!e.isRef(a)&&!Array.isArray(a)&&a.value!==void 0){const p=a,C=e.isRef(p.value)?p.value:e.ref(p.value),$=p.type||I(p),_=A(c,C,$,t);$==="select"&&(_.options=e.ref(p.options.map(E=>typeof E=="object"&&E.text&&E.value?E:{text:E,value:E}))),$==="range"&&(_.min=e.ref(p.min||0),_.max=e.ref(p.max||1),_.step=e.ref(p.step||.1)),_.label.value=p.label||c,_.icon.value=p.icon,_.visible.value=p.visible!==void 0?p.visible:!0,_.uniqueKey.value=b,d[b]=_,o[b]=_;continue}if(e.isRef(a)){const p=A(c,a,a.value.type||I(a.value),t);d[b]=p,o[b]=p;continue}else if(typeof a=="object"&&!Array.isArray(a)){const p=e.toRefs(a);p[c]&&(a=p[c])}const B=A(c,a,a.type||I(a),t);d[b]=B,o[b]=B,B.uniqueKey.value=b}return Object.keys(o).length>1?e.toRefs(e.reactive(o)):Object.values(o)[0]},ee=["for","title"],T=e.defineComponent({__name:"ControlLabel",props:{label:{},control:{}},setup(l){return(r,n)=>(e.openBlock(),e.createElementBlock("label",{for:r.control.uniqueKey,title:r.label,class:"tl-text-gray-500 tl-w-1/3 tl-truncate"},[r.control.icon?(e.openBlock(),e.createElementBlock("i",{key:0,class:e.normalizeClass(r.control.icon)},null,2)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(r.label),1)],64))],8,ee))}}),te={class:"tl-flex tl-px-4 tl-justify-between tl-gap-4 tl-items-center tl-mb-2"},le=["id","value","min","max","step"],ne=e.defineComponent({__name:"NumberControl",props:{label:{},control:{}},emits:["change"],setup(l,{emit:r}){const n=l,o=r;function t(c){const{target:a}=c;o("change",a.valueAsNumber)}const u=w.useMouse(),s=e.ref(0),i=e.ref(!1),d=c=>{s.value=c.clientX,i.value=!0},y=()=>{i.value=!1},g=c=>Math.floor(Math.abs(c)/10);return e.watch(u.x,c=>{if(i.value){const a=c-s.value,b=g(a);a>0?o("change",n.control.value+1+b):a<0&&o("change",n.control.value-1+b),n.control.min!==void 0&&n.control.value<n.control.min&&o("change",n.control.min),n.control.max!==void 0&&n.control.value>n.control.max&&o("change",n.control.max),s.value=c}}),(c,a)=>(e.openBlock(),e.createElementBlock("div",te,[e.createVNode(T,{label:c.label,control:c.control},null,8,["label","control"]),e.createElementVNode("input",{id:c.control.uniqueKey,value:c.control.value,class:e.normalizeClass(["tl-p-2 tl-w-1/3 tl-rounded tl-text-right tl-text-xs tl-text-gray-400 tl-bg-gray-100 tl-focus:border-gray-200 tl-outline-none tl-border-none tl-font-sans",{"tl-cursor-ew-resize":i.value}]),type:"number",min:c.control.min,max:c.control.max,step:c.control.step,onInput:t,onMousedown:d,onMouseup:y},null,42,le)]))}}),oe={class:"tl-flex tl-px-4 tl-justify-between tl-gap-4 tl-items-center tl-mb-2 tl-min-h-32px"},re=["id","value","aria-label"],ae=e.defineComponent({__name:"TextControl",props:{label:{},control:{}},emits:["change"],setup(l,{emit:r}){const n=r;function o(t){const{target:u}=t;n("change",u.value)}return(t,u)=>(e.openBlock(),e.createElementBlock("div",oe,[e.createVNode(T,{label:t.label,control:t.control},null,8,["label","control"]),e.createElementVNode("input",{id:t.control.uniqueKey,value:t.control.value,type:"text",tabindex:"0",class:"tl-p-2 tl-w-2/3 tl-rounded tl-text-right tl-text-xs tl-text-gray-400 tl-bg-gray-100 focus:tl-border-gray-200 tl-border-none tl-font-sans","aria-label":t.label,placeholder:"Enter value here...",onChange:o},null,40,re)]))}}),se={class:"tl-flex tl-px-4 tl-justify-start tl-gap-2 tl-items-center tl-mb-2 tl-min-h-32px"},ce={class:"tl-text-gray-500 tl-w-1/3"},ie=["id","checked"],ue=["for"],de=["aria-checked"],pe={class:"i-ic:baseline-check tl-text-light"},fe=e.defineComponent({__name:"BooleanControl",props:{label:{},control:{}},emits:["change"],setup(l,{emit:r}){const n=l,o=r;function t(s){const{target:i}=s;o("change",i.checked)}function u(s){(s.code==="Space"||s.code==="Enter")&&(s.preventDefault(),o("change",!n.control.value))}return(s,i)=>(e.openBlock(),e.createElementBlock("div",se,[e.createElementVNode("label",ce,e.toDisplayString(s.label),1),e.createElementVNode("input",{id:s.control.uniqueKey,checked:s.control.value,class:"tl-hidden",type:"checkbox",onInput:t},null,40,ie),e.createElementVNode("label",{for:s.control.uniqueKey,class:"tl-inline-flex tl-items-center tl-cursor-pointer"},[e.createElementVNode("span",{tabindex:"0",role:"checkbox","aria-checked":s.control.value.toString(),class:e.normalizeClass([{"tl-bg-dark-500":s.control.value,"tl-bg-gray-200":!s.control.value},"tl-w-4 tl-h-4 tl-flex tl-justify-center tl-items-center tl-rounded tl-border tl-border-gray-300 tl-mr-2 tl-transition-colors tl-duration-200"]),onKeydown:u},[e.withDirectives(e.createElementVNode("i",pe,null,512),[[e.vShow,s.control.value]])],42,de)],8,ue)]))}}),me={class:"tl-px-4 tl-relative tl-flex tl-justify-between tl-gap-4 tl-items-center tl-mb-2"},be=["value","min","max","step"],ge=["value","min","max","step"],ye=e.defineComponent({__name:"SliderControl",props:{label:{},control:{}},emits:["change"],setup(l,{emit:r}){const n=l,o=r;function t(a){const{target:b}=a;o("change",b.valueAsNumber)}const u=e.computed(()=>({backgroundImage:`linear-gradient(to right, #333 0% ${100*(n.control.value-(n.control.min||0))/((n.control.max||100)-(n.control.min||0))}%, #e2e2e2 0%)`})),s=w.useMouse(),i=e.ref(0),d=e.ref(!1),y=a=>{i.value=a.clientX,d.value=!0},g=()=>{d.value=!1},c=a=>Math.floor(Math.abs(a)/10);return e.watch(s.x,a=>{if(d.value){const b=a-i.value,B=c(b);b>0?o("change",n.control.value+1+B):b<0&&o("change",n.control.value-1+B),n.control.min!==void 0&&n.control.value<n.control.min&&o("change",n.control.min),n.control.max!==void 0&&n.control.value>n.control.max&&o("change",n.control.max),i.value=a}}),(a,b)=>(e.openBlock(),e.createElementBlock("div",me,[e.createVNode(T,{label:a.label,control:a.control},null,8,["label","control"]),e.createElementVNode("input",{value:a.control.value,class:"tl-w-1/2 tl-h-0.75 tl-bg-dark-200 tl-rounded-full tl-appearance-none",style:e.normalizeStyle(u.value),type:"range",min:a.control.min,max:a.control.max,step:a.control.step,onInput:t},null,44,be),e.createElementVNode("input",{value:a.control.value,class:e.normalizeClass(["tl-p-2 tl-w-1/4 tl-rounded tl-text-right tl-text-xs tl-text-gray-400 tl-bg-gray-100 tl-focus:border-gray-200 tl-outline-none tl-border-none tl-font-sans",{"tl-cursor-ew-resize":d.value}]),type:"number",min:a.control.min,max:a.control.max,step:a.control.step,onInput:t,onMousedown:y,onMouseup:g},null,42,ge)]))}}),P=(l,r)=>{const n=l.__vccOpts||l;for(const[o,t]of r)n[o]=t;return n},he=P(ye,[["__scopeId","data-v-207d19a7"]]),ke={class:"tl-flex tl-px-4 tl-justify-between tl-gap-4 tl-items-center tl-mb-2"},_e={class:"tl-text-gray-500 tl-w-1/3"},we=["id","value","aria-label"],Be=["id","aria-label","value"],Ce=e.defineComponent({__name:"ColorControl",props:{label:{},control:{}},emits:["change"],setup(l,{emit:r}){const n=r;function o(t){const{target:u}=t;n("change",u.value)}return(t,u)=>(e.openBlock(),e.createElementBlock("div",ke,[e.createElementVNode("label",_e,e.toDisplayString(t.label),1),e.createElementVNode("input",{id:t.control.uniqueKey,tabindex:"0",value:t.control.value,"aria-label":t.label,class:e.normalizeClass(["focus:tl-outline-none focus:tl-ring-2 focus:tl-ring-blue-600",{"important-tl-outline-gray-200":t.control.value==="#ffffff"}]),type:"color",onInput:o},null,42,we),e.createElementVNode("input",{id:t.control.uniqueKey,tabindex:"0","aria-label":t.label,value:t.control.value,class:"tl-p-2 tl-w-2/3 tl-rounded tl-text-right tl-text-xs tl-text-gray-400 tl-bg-gray-100 tl-border-none tl-font-sans",type:"text",onInput:o},null,40,Be)]))}});function K(l){return l&&typeof l.x=="number"&&typeof l.y=="number"}function q(l){return l&&typeof l.x=="number"&&typeof l.y=="number"&&typeof l.z=="number"}function Ee(l){if(typeof l=="number")return[l,l,l];if(q(l)){const{x:r,y:n,z:o}=l;return[r,n,o]}if(K(l)){const{x:r,y:n}=l;return[r,n]}return l}const xe={class:"tl-relative tl-w-2/3 tl-flex tl-justify-between tl-gap-0.5"},Ve={key:0,class:"tl-font-bold tl-px-1 tl-py-1 tl-text-0.65rem tl-text-gray-300"},$e=["id","step","value","onInput","onMousedown","onMouseup","onFocus"],Ne=e.defineComponent({__name:"VectorControl",props:{label:{},control:{}},emits:["change"],setup(l,{emit:r}){const n=l,o=r,t=w.useMouse(),{pressed:u}=w.useMousePressed(),s=e.ref(0),i=e.ref(!1),d=e.ref(0),y=e.ref(null),g=e.ref(1),c=w.useKeyModifier("Shift"),a=w.useKeyModifier("Alt");e.watch(c,f=>{g.value=f?10:1}),e.watch(a,f=>{g.value=f?.1:1});const b=f=>{y.value=f},B=()=>{y.value=null},p=(f,k)=>{d.value=k,s.value=f.clientX,i.value=!0},C=(f,k)=>{d.value=k,i.value=!1},$=()=>{i.value=!1};e.watch(u,f=>{f||(i.value=!1)});const _=f=>Math.floor(Math.abs(f)/10),E=e.computed(()=>Ee(n.control.value)),S=e.ref(["x","y","z"]),F=e.computed(()=>K(n.control.value)||q(n.control.value));function m(f,k){const{value:M}=n.control,{target:h}=f;d.value=k,M[F.value?S.value[d.value]:d.value]=Number.parseFloat(h.value),o("change",M)}return e.watch(t.x,f=>{if(i.value){const k=f-s.value,M=_(k),{value:h}=n.control,x=F.value?S.value[d.value]:d.value;k>0?h[x]+=g.value+M:k<0&&(h[x]-=g.value+M),n.control.min!==void 0&&h<n.control.min&&(h[x]=n.control.min),n.control.max!==void 0&&h>n.control.max&&(h[x]=n.control.max),o("change",h),s.value=f}}),(f,k)=>(e.openBlock(),e.createElementBlock("div",{class:"tl-flex tl-px-4 tl-justify-between tl-gap-1 tl-items-center tl-mb-2",onMouseup:k[0]||(k[0]=M=>$())},[e.createVNode(T,{label:f.label,control:f.control},null,8,["label","control"]),e.createElementVNode("div",xe,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(E.value,(M,h)=>(e.openBlock(),e.createElementBlock("div",{key:f.label+h,class:e.normalizeClass(["tl-flex tl-items-center tl-bg-gray-100 tl-rounded",{"tl-w-2/5":y.value===h,"tl-w-1/3":e.unref(q)(f.control.value),"tl-w-1/2":e.unref(K)(f.control.value)}])},[S.value[h]&&F.value?(e.openBlock(),e.createElementBlock("span",Ve,e.toDisplayString(S.value[h]),1)):e.createCommentVNode("",!0),e.createElementVNode("input",{id:`${f.control.uniqueKey}-${S.value[h]}`,type:"number",step:g.value,class:e.normalizeClass(["tl-w-full tl-px-0 tl-p-1 tl-text-right tl-text-0.65rem tl-text-gray-400 tl-bg-transparent focus:tl-border-gray-200 tl-outline-none tl-border-none tl-font-sans tl-appearence-none",{"tl-cursor-ew-resize":i.value}]),value:E.value[h].toFixed(2),onInput:x=>m(x,h),onMousedown:x=>p(x,h),onMouseup:x=>C(x,h),onFocus:x=>b(h),onBlur:B},null,42,$e)],2))),128))])],32))}}),Se={class:"tl-flex tl-px-4 tl-justify-between tl-gap-4 tl-items-center tl-mb-2"},Me={class:"tl-text-gray-500 tl-w-1/3"},De={class:"tl-relative tl-w-2/3 tl-p-1 tl-rounded tl-text-right tl-text-xs tl-text-gray-400 tl-bg-gray-100 tl-focus:border-gray-200 tl-outline-none tl-border-none tl-font-sans"},Te={class:"tl-absolute tl-bottom-0.5 tl-right-0.5 tl-font-sans tl-text-xs"},ze=["points"],X=160,L=40,z=2,W=100,j=20,Fe=e.defineComponent({__name:"FPSGraph",props:{label:{},control:{}},setup(l){const r=w.useFps({every:W}),n=e.ref(""),o=e.ref([]),t=e.ref(X/z);let u=performance.now();return w.useRafFn(({timestamp:s})=>{s-u>=W&&(u=s,o.value.push(r.value),o.value.length>t.value&&o.value.shift(),n.value=o.value.map((i,d)=>`${d*z},${L+j-z/2-i*(L+j-z)/120}`).join(" "))}),(s,i)=>(e.openBlock(),e.createElementBlock("div",Se,[e.createElementVNode("label",Me,e.toDisplayString(s.label),1),e.createElementVNode("div",De,[e.createElementVNode("div",Te,e.toDisplayString(Math.round(e.unref(r)))+" FPS ",1),(e.openBlock(),e.createElementBlock("svg",{width:X,height:L,xmlns:"http://www.w3.org/2000/svg",class:"tl-bg-gray-100"},[e.createElementVNode("polyline",{points:n.value,fill:"none",stroke:"lightgray","stroke-width":z,"stroke-linecap":"round","stroke-linejoin":"round"},null,8,ze)]))])]))}}),Ae={class:"tl-flex tl-px-4 tl-justify-between tl-gap-4 tl-items-center tl-mb-2 tl-min-h-32px"},Ie=["id","value"],Ke=["value"],qe=e.defineComponent({__name:"SelectControl",props:{label:{},control:{}},emits:["change"],setup(l,{emit:r}){const n=r;function o(t){n("change",t.target.value)}return(t,u)=>(e.openBlock(),e.createElementBlock("div",Ae,[e.createVNode(T,{label:t.label,control:t.control},null,8,["label","control"]),e.createElementVNode("select",{id:t.control.uniqueKey,value:t.control.value,class:"tl-p-2 tl-w-2/3 tl-rounded tl-text-left tl-text-xs tl-text-gray-400 tl-bg-gray-100 focus:tl-border-gray-200 tl-outline-none tl-border-none tl-font-sans",onChange:o},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.control.options,s=>(e.openBlock(),e.createElementBlock("option",{key:s.value,value:s.value},e.toDisplayString(s.text),9,Ke))),128))],40,Ie)]))}}),Le=P(e.defineComponent({__name:"ButtonControl",props:{label:{},control:{}},setup(l){const r=l,n=e.computed(()=>{const o="leches-btn",t=`leches-btn-${r.control.value.variant||"primary"}`,u=`leches-btn-${r.control.value.size||"sm"}`;return[o,t,u]});return(o,t)=>(e.openBlock(),e.createElementBlock("button",{class:e.normalizeClass(n.value),onClick:t[0]||(t[0]=(...u)=>o.control.value.onClick&&o.control.value.onClick(...u))},[e.createElementVNode("i",{class:e.normalizeClass([o.control.value.icon,o.control.value.label?"mr-1":""])},null,2),e.createTextVNode(" "+e.toDisplayString(o.control.value.label),1)],2))}}),[["__scopeId","data-v-926dfadc"]]),Ue={key:0},Y=e.defineComponent({__name:"ControlInput",props:{control:{}},emits:["change"],setup(l,{emit:r}){const n=r;function o(t){n("change",t)}return(t,u)=>t.control.visible?(e.openBlock(),e.createElementBlock("div",Ue,[t.control.type==="color"?(e.openBlock(),e.createBlock(Ce,{key:0,label:t.control.label,control:t.control,onChange:o},null,8,["label","control"])):t.control.type==="select"?(e.openBlock(),e.createBlock(qe,{key:1,label:t.control.label,control:t.control,onChange:o},null,8,["label","control"])):t.control.type==="vector"?(e.openBlock(),e.createBlock(Ne,{key:2,label:t.control.label,control:t.control,onChange:o},null,8,["label","control"])):t.control.type==="boolean"?(e.openBlock(),e.createBlock(fe,{key:3,label:t.control.label,control:t.control,onChange:o},null,8,["label","control"])):t.control.type==="fpsgraph"?(e.openBlock(),e.createBlock(Fe,{key:4,label:t.control.label,control:t.control},null,8,["label","control"])):t.control.type==="number"?(e.openBlock(),e.createBlock(ne,{key:5,label:t.control.label,control:t.control,onChange:o},null,8,["label","control"])):t.control.type==="range"?(e.openBlock(),e.createBlock(he,{key:6,label:t.control.label,control:t.control,onChange:o},null,8,["label","control"])):t.control.type==="button"?(e.openBlock(),e.createElementBlock("div",{key:7,class:e.normalizeClass(["tl-p-2",t.control.value.size==="tl-block"?"tl-flex":"tl-inline-flex"])},[e.createVNode(Le,{label:t.control.label,control:t.control},null,8,["label","control"])],2)):(e.openBlock(),e.createBlock(ae,{key:8,label:t.control.label,control:t.control,onChange:o},null,8,["label","control"]))])):e.createCommentVNode("",!0)}}),Oe={class:"tl-mb-4"},Re=["aria-expanded","data-folder"],Pe={class:"tl-bg-white tl-rounded-b tl-pt-4",role:"menu"},Xe=e.defineComponent({__name:"Folder",props:{controls:{},label:{}},setup(l){function r(t,u){u.value=t}const n=e.ref(!1),o=()=>{n.value=!n.value};return(t,u)=>(e.openBlock(),e.createElementBlock("div",Oe,[e.createElementVNode("button",{class:"tl-flex tl-items-center tl-justify-between tl-w-full tl-py-2 tl-px-4 tl-bg-gray-100 tl-border-none tl-text-gray-400 tl-font-bold tl-text-xs tl-font-sans tl-cursor-pointer","aria-expanded":n.value,"aria-haspopup":"true",role:"button","data-folder":t.label,tabindex:"0",onClick:o},[e.createElementVNode("span",null,e.toDisplayString(t.label),1),e.createElementVNode("i",{class:e.normalizeClass(n.value?"i-ic:baseline-keyboard-arrow-up":"i-ic:baseline-keyboard-arrow-down")},null,2)],8,Re),e.createVNode(e.Transition,{name:"slide","enter-active-class":"tl-animate-fade-in tl-animate-duration-200 tl-animate-ease-in-out","leave-active-class":"tl-animate-fade-out tl-animate-duration-200 tl-animate-ease-in-out"},{default:e.withCtx(()=>[e.withDirectives(e.createElementVNode("div",Pe,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.controls,s=>(e.openBlock(),e.createBlock(Y,{key:s.label,control:s,role:"menuitem",onChange:i=>r(i,s)},null,8,["control","onChange"]))),128))],512),[[e.vShow,n.value]])]),_:1})]))}}),We={tabindex:"0",class:"tl-bg-white tl-shadow-xl tl-rounded tl-border-4 tl-border-solid tl-border-black"},je=280,Ye=e.defineComponent({__name:"TresLeches",props:{uuid:{}},setup(l){const r=l,{uuid:n}=e.toRefs(r),{width:o}=w.useWindowSize(),t=e.ref(null),u=R(n==null?void 0:n.value);function s(d,y){u[e.unref(d)].value=y,u[e.unref(d)][e.unref(d)]=y}const i=e.computed(()=>{const d={};for(const y in u){const g=u[y],c=g.folder||"default";d[c]||(d[c]=[]),d[c].push(g)}return d});return(d,y)=>(e.openBlock(),e.createBlock(e.unref(Q),{id:e.unref(n),"initial-value":{x:e.unref(o)-je-40,y:10},class:e.normalizeClass(["tl-absolute tl-select-none tl-z-24 tl-w-280px tl-font-sans tl-text-xs",d.$attrs.class]),handle:t.value},{default:e.withCtx(()=>[e.createElementVNode("div",We,[e.createElementVNode("header",{ref_key:"handle",ref:t,class:"tl-relative tl-cursor-grabbing tl-p-4 tl-flex tl-justify-between tl-text-gray-200 tl-relative"},y[0]||(y[0]=[e.createElementVNode("i",{class:"tl-h-4 tl-w-4 tl-p-1.5 tl-flex tl-items-center tl-line-height-0 tl-rounded-full tl-bg-gray-100 tl-text-xs"},"🍰",-1),e.createElementVNode("div",null,[e.createElementVNode("i",{class:"i-ic-baseline-drag-indicator"}),e.createElementVNode("i",{class:"i-ic-baseline-drag-indicator"}),e.createElementVNode("i",{class:"i-ic-baseline-drag-indicator"})],-1),e.createElementVNode("div",null,null,-1)]),512),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.value,(g,c)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:c},[c!=="default"?(e.openBlock(),e.createBlock(Xe,{key:0,label:c,controls:g},null,8,["label","controls"])):e.createCommentVNode("",!0),c==="default"?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(g,a=>(e.openBlock(),e.createBlock(Y,{key:a.label,control:a,onChange:b=>s(a.key,b)},null,8,["control","onChange"]))),128)):e.createCommentVNode("",!0)],64))),128))])]),_:1},8,["id","initial-value","class","handle"]))}});V.TresLeches=Ye,V.useControls=v,V.useControlsProvider=R,Object.defineProperty(V,Symbol.toStringTag,{value:"Module"})});