vx-vue 1.4.1 → 1.4.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/style.css +1 -1
- package/dist/vxvue.es.js +792 -766
- package/dist/vxvue.umd.js +1 -1
- package/package.json +9 -8
package/dist/vxvue.umd.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(v,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],e):(v=typeof globalThis<"u"?globalThis:v||self,e(v.vxVue={},v.Vue))})(this,function(v,e){"use strict";const le={__name:"Accordion",props:{activeIndex:{type:[Number,Array],default:null}},emits:["update:activeIndex"],setup(t,{emit:c}){const l=t,o=c,a=e.useSlots(),n=e.ref([]),u=m=>n.value.push(m),i=e.computed(()=>a.default().reduce((m,g)=>((g.type.__name||g.type.name)==="AccordionPanel"&&m.push(g),m),[])),s=m=>{if(Array.isArray(l.activeIndex)){let g=[].concat(l.activeIndex),y=g.findIndex(h=>h===m);y===-1?o("update:activeIndex",[...g,m]):(g.splice(y,1),o("update:activeIndex",g))}else o("update:activeIndex",m===l.activeIndex?-1:m)},r=m=>{if(m=++m%i.value.length,!n.value[m].disabled){s(m),n.value[m].focus();return}r(m)},d=m=>{if(m=(m||i.value.length)-1,!n.value[m].disabled){s(m),n.value[m].focus();return}d(m)};return e.onBeforeUpdate(()=>n.value=[]),(m,g)=>(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.value,(y,h)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(y),{key:h,ref_for:!0,ref:u,show:Array.isArray(t.activeIndex)?t.activeIndex?.includes(h):t.activeIndex===h,onSelect:B=>s(h),onKeydown:B=>r(h),onKeyup:B=>d(h)},null,40,["show","onSelect","onKeydown","onKeyup"]))),128))}};function ae(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M6.75 2.25A.75.75 0 0 1 7.5 3v1.5h9V3A.75.75 0 0 1 18 3v1.5h.75a3 3 0 0 1 3 3v11.25a3 3 0 0 1-3 3H5.25a3 3 0 0 1-3-3V7.5a3 3 0 0 1 3-3H6V3a.75.75 0 0 1 .75-.75Zm13.5 9a1.5 1.5 0 0 0-1.5-1.5H5.25a1.5 1.5 0 0 0-1.5 1.5v7.5a1.5 1.5 0 0 0 1.5 1.5h13.5a1.5 1.5 0 0 0 1.5-1.5v-7.5Z","clip-rule":"evenodd"})])}function oe(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M12.53 16.28a.75.75 0 0 1-1.06 0l-7.5-7.5a.75.75 0 0 1 1.06-1.06L12 14.69l6.97-6.97a.75.75 0 1 1 1.06 1.06l-7.5 7.5Z","clip-rule":"evenodd"})])}function Y(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M7.72 12.53a.75.75 0 0 1 0-1.06l7.5-7.5a.75.75 0 1 1 1.06 1.06L9.31 12l6.97 6.97a.75.75 0 1 1-1.06 1.06l-7.5-7.5Z","clip-rule":"evenodd"})])}function I(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M16.28 11.47a.75.75 0 0 1 0 1.06l-7.5 7.5a.75.75 0 0 1-1.06-1.06L14.69 12 7.72 5.03a.75.75 0 0 1 1.06-1.06l7.5 7.5Z","clip-rule":"evenodd"})])}function ne(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M11.47 4.72a.75.75 0 0 1 1.06 0l3.75 3.75a.75.75 0 0 1-1.06 1.06L12 6.31 8.78 9.53a.75.75 0 0 1-1.06-1.06l3.75-3.75Zm-3.75 9.75a.75.75 0 0 1 1.06 0L12 17.69l3.22-3.22a.75.75 0 1 1 1.06 1.06l-3.75 3.75a.75.75 0 0 1-1.06 0l-3.75-3.75a.75.75 0 0 1 0-1.06Z","clip-rule":"evenodd"})])}function re(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M11.47 7.72a.75.75 0 0 1 1.06 0l7.5 7.5a.75.75 0 1 1-1.06 1.06L12 9.31l-6.97 6.97a.75.75 0 0 1-1.06-1.06l7.5-7.5Z","clip-rule":"evenodd"})])}function se(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M4.25 12a.75.75 0 0 1 .75-.75h14a.75.75 0 0 1 0 1.5H5a.75.75 0 0 1-.75-.75Z","clip-rule":"evenodd"})])}function ie(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M12 3.75a.75.75 0 0 1 .75.75v6.75h6.75a.75.75 0 0 1 0 1.5h-6.75v6.75a.75.75 0 0 1-1.5 0v-6.75H4.5a.75.75 0 0 1 0-1.5h6.75V4.5a.75.75 0 0 1 .75-.75Z","clip-rule":"evenodd"})])}function R(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M5.47 5.47a.75.75 0 0 1 1.06 0L12 10.94l5.47-5.47a.75.75 0 1 1 1.06 1.06L13.06 12l5.47 5.47a.75.75 0 1 1-1.06 1.06L12 13.06l-5.47 5.47a.75.75 0 0 1-1.06-1.06L10.94 12 5.47 6.53a.75.75 0 0 1 0-1.06Z","clip-rule":"evenodd"})])}const ce=["id","disabled","aria-expanded","aria-controls"],de=["id","aria-labelledby"],ue={class:"overflow-hidden rounded-b"},me=Object.assign({inheritAttrs:!1},{__name:"AccordionPanel",props:{show:Boolean,disabled:Boolean},emits:["select","keyup","keydown"],setup(t,{expose:c,emit:l}){const o=l,a=t,n=e.useAttrs(),u=e.ref(null),i=Math.random().toString(20).substring(2,8),s=d=>{if(!a.disabled){const m=new Map([[40,"keydown"],[38,"keyup"]]).get(d.keyCode);m&&(o(m),d.preventDefault())}};return c({focus:()=>u.value.focus(),disabled:a.disabled}),(d,m)=>(e.openBlock(),e.createElementBlock("div",null,[e.createElementVNode("button",{id:"ap-control-"+e.unref(i),ref_key:"btn",ref:u,class:e.normalizeClass(["flex items-center w-full space-x-2 px-4 py-2 ring-vxvue",t.show?"rounded-t":"rounded-sm",t.disabled?"bg-slate-300 text-slate-700":"bg-vxvue hover:bg-vxvue-600 text-white",e.unref(n).class]),disabled:t.disabled,"aria-expanded":t.show,"aria-controls":"ap-"+e.unref(i),tabindex:"0",onClick:m[0]||(m[0]=g=>o("select")),onKeydown:s},[t.disabled?(e.openBlock(),e.createBlock(e.unref(R),{key:0,class:"size-5"})):(e.openBlock(),e.createBlock(e.unref(I),{key:1,class:e.normalizeClass(["size-5 transform-gpu transition-transform duration-300",{"rotate-90":t.show}])},null,8,["class"])),e.createElementVNode("span",null,[e.renderSlot(d.$slots,"header")])],42,ce),e.createElementVNode("div",{id:"ap-"+e.unref(i),class:e.normalizeClass(["grid transition-[grid-template-rows] duration-300 ease-in-out",t.show&&!t.disabled?"grid-rows-1":"grid-rows-[repeat(1,minmax(0,0fr))]"]),"aria-labelledby":"ap-control-"+e.unref(i)},[e.createElementVNode("div",ue,[e.renderSlot(d.$slots,"default")])],10,de)]))}}),fe=["viewBox"],pe=["cx","cy","r","stroke-width"],he=["cx","cy","r","stroke-width","stroke-dasharray"],H={__name:"Spinner",props:{radius:{type:Number,default:10},strokeWidth:{type:Number,default:4}},setup(t){const c=t,l=e.computed(()=>c.radius+c.strokeWidth/2),o=e.computed(()=>c.radius*2+c.strokeWidth),a=e.computed(()=>c.radius*Math.PI/1.5);return(n,u)=>(e.openBlock(),e.createElementBlock("svg",{class:"animate-spin",xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 "+o.value+" "+o.value,role:"progressbar"},[e.createElementVNode("circle",{class:"opacity-35",cx:l.value,cy:l.value,r:t.radius,stroke:"currentColor","stroke-width":t.strokeWidth},null,8,pe),e.createElementVNode("circle",{cx:l.value,cy:l.value,r:t.radius,stroke:"currentColor","stroke-width":t.strokeWidth,"stroke-dasharray":a.value+" "+t.radius*100,"stroke-linecap":"round"},null,8,he)],8,fe))}},K=(t,c)=>{const l=t.__vccOpts||t;for(const[o,a]of c)l[o]=a;return l},O=K({__name:"VxVueTransition",props:{name:{type:String,required:!0,validator:t=>["appear","vert-fade","fade"].includes(t)}},setup(t){return(c,l)=>(e.openBlock(),e.createBlock(e.Transition,{name:t.name},{default:e.withCtx(()=>[e.renderSlot(c.$slots,"default",{},void 0,!0)]),_:3},8,["name"]))}},[["__scopeId","data-v-f6b1631e"]]);function ge(t){return e.getCurrentScope()?(e.onScopeDispose(t),!0):!1}const X=typeof window<"u"&&typeof document<"u";typeof WorkerGlobalScope<"u"&&globalThis instanceof WorkerGlobalScope;const be=Object.prototype.toString,ke=t=>be.call(t)==="[object Object]",F=()=>{},ye=xe();function xe(){var t,c;return X&&((t=window?.navigator)==null?void 0:t.userAgent)&&(/iP(?:ad|hone|od)/.test(window.navigator.userAgent)||((c=window?.navigator)==null?void 0:c.maxTouchPoints)>2&&/iPad|Macintosh/.test(window?.navigator.userAgent))}function Z(t){return Array.isArray(t)?t:[t]}const we=/[YMDHhms]o|\[([^\]]+)\]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a{1,2}|A{1,2}|m{1,2}|s{1,2}|Z{1,2}|z{1,4}|SSS/g;function Be(t,c,l,o){let a=t<12?"AM":"PM";return o&&(a=a.split("").reduce((n,u)=>n+=`${u}.`,"")),l?a.toLowerCase():a}function T(t){const c=["th","st","nd","rd"],l=t%100;return t+(c[(l-20)%10]||c[l]||c[0])}function G(t,c,l={}){var o;const a=t.getFullYear(),n=t.getMonth(),u=t.getDate(),i=t.getHours(),s=t.getMinutes(),r=t.getSeconds(),d=t.getMilliseconds(),m=t.getDay(),g=(o=l.customMeridiem)!=null?o:Be,y=B=>{var k;return(k=B.split(" ")[1])!=null?k:""},h={Yo:()=>T(a),YY:()=>String(a).slice(-2),YYYY:()=>a,M:()=>n+1,Mo:()=>T(n+1),MM:()=>`${n+1}`.padStart(2,"0"),MMM:()=>t.toLocaleDateString(e.toValue(l.locales),{month:"short"}),MMMM:()=>t.toLocaleDateString(e.toValue(l.locales),{month:"long"}),D:()=>String(u),Do:()=>T(u),DD:()=>`${u}`.padStart(2,"0"),H:()=>String(i),Ho:()=>T(i),HH:()=>`${i}`.padStart(2,"0"),h:()=>`${i%12||12}`.padStart(1,"0"),ho:()=>T(i%12||12),hh:()=>`${i%12||12}`.padStart(2,"0"),m:()=>String(s),mo:()=>T(s),mm:()=>`${s}`.padStart(2,"0"),s:()=>String(r),so:()=>T(r),ss:()=>`${r}`.padStart(2,"0"),SSS:()=>`${d}`.padStart(3,"0"),d:()=>m,dd:()=>t.toLocaleDateString(e.toValue(l.locales),{weekday:"narrow"}),ddd:()=>t.toLocaleDateString(e.toValue(l.locales),{weekday:"short"}),dddd:()=>t.toLocaleDateString(e.toValue(l.locales),{weekday:"long"}),A:()=>g(i,s),AA:()=>g(i,s,!1,!0),a:()=>g(i,s,!0),aa:()=>g(i,s,!0,!0),z:()=>y(t.toLocaleDateString(e.toValue(l.locales),{timeZoneName:"shortOffset"})),zz:()=>y(t.toLocaleDateString(e.toValue(l.locales),{timeZoneName:"shortOffset"})),zzz:()=>y(t.toLocaleDateString(e.toValue(l.locales),{timeZoneName:"shortOffset"})),zzzz:()=>y(t.toLocaleDateString(e.toValue(l.locales),{timeZoneName:"longOffset"}))};return c.replace(we,(B,k)=>{var w,S;return(S=k??((w=h[B])==null?void 0:w.call(h)))!=null?S:B})}function Ve(t,c,l){return e.watch(t,c,{...l,immediate:!0})}const J=X?window:void 0;function _(t){var c;const l=e.toValue(t);return(c=l?.$el)!=null?c:l}function q(...t){const c=[],l=()=>{c.forEach(i=>i()),c.length=0},o=(i,s,r,d)=>(i.addEventListener(s,r,d),()=>i.removeEventListener(s,r,d)),a=e.computed(()=>{const i=Z(e.toValue(t[0])).filter(s=>s!=null);return i.every(s=>typeof s!="string")?i:void 0}),n=Ve(()=>{var i,s;return[(s=(i=a.value)==null?void 0:i.map(r=>_(r)))!=null?s:[J].filter(r=>r!=null),Z(e.toValue(a.value?t[1]:t[0])),Z(e.unref(a.value?t[2]:t[1])),e.toValue(a.value?t[3]:t[2])]},([i,s,r,d])=>{if(l(),!i?.length||!s?.length||!r?.length)return;const m=ke(d)?{...d}:d;c.push(...i.flatMap(g=>s.flatMap(y=>r.map(h=>o(g,y,h,m)))))},{flush:"post"}),u=()=>{n(),l()};return ge(l),u}let Q=!1;function U(t,c,l={}){const{window:o=J,ignore:a=[],capture:n=!0,detectIframe:u=!1,controls:i=!1}=l;if(!o)return i?{stop:F,cancel:F,trigger:F}:F;if(ye&&!Q){Q=!0;const k={passive:!0};Array.from(o.document.body.children).forEach(w=>w.addEventListener("click",F,k)),o.document.documentElement.addEventListener("click",F,k)}let s=!0;const r=k=>e.toValue(a).some(w=>{if(typeof w=="string")return Array.from(o.document.querySelectorAll(w)).some(S=>S===k.target||k.composedPath().includes(S));{const S=_(w);return S&&(k.target===S||k.composedPath().includes(S))}});function d(k){const w=e.toValue(k);return w&&w.$.subTree.shapeFlag===16}function m(k,w){const S=e.toValue(k),$=S.$.subTree&&S.$.subTree.children;return $==null||!Array.isArray($)?!1:$.some(A=>A.el===w.target||w.composedPath().includes(A.el))}const g=k=>{const w=_(t);if(k.target!=null&&!(!(w instanceof Element)&&d(t)&&m(t,k))&&!(!w||w===k.target||k.composedPath().includes(w))){if("detail"in k&&k.detail===0&&(s=!r(k)),!s){s=!0;return}c(k)}};let y=!1;const h=[q(o,"click",k=>{y||(y=!0,setTimeout(()=>{y=!1},0),g(k))},{passive:!0,capture:n}),q(o,"pointerdown",k=>{const w=_(t);s=!r(k)&&!!(w&&!k.composedPath().includes(w))},{passive:!0}),u&&q(o,"blur",k=>{setTimeout(()=>{var w;const S=_(t);((w=o.document.activeElement)==null?void 0:w.tagName)==="IFRAME"&&!S?.contains(o.document.activeElement)&&c(k)},0)},{passive:!0})].filter(Boolean),B=()=>h.forEach(k=>k());return i?{stop:B,cancel:()=>{s=!1},trigger:k=>{s=!0,g(k),s=!1}}:B}const Ee=["value","onKeydown"],ve={class:"flex absolute inset-y-0 right-0 items-center pr-3 text-vxvue-700"},Se=["data-result-index"],Ce=Object.assign({inheritAttrs:!1},{__name:"Autocomplete",props:e.mergeModels({search:{type:Function,required:!0},resultListClass:{type:String,default:"result-list"},resultItemClass:{type:String,default:"result-list-item"},getResultValue:{type:Function,default:t=>t},autoSelect:Boolean},{modelValue:{type:String,default:""},modelModifiers:{}}),emits:e.mergeModels(["blur-sm","submit"],["update:modelValue"]),setup(t,{emit:c}){const l=c,o=t,a=e.useModel(t,"modelValue"),n=e.useAttrs(),i=(()=>{let E=0;return C=>(C||"")+ ++E})()((n.id||"autocomplete")+"-"),s=e.ref([]),r=e.ref(-1),d=e.ref(0),m=e.ref(!1),g=e.ref(!1),y=e.ref("top-0 translate-y-12"),h=e.ref(!0),B=e.ref(null),k=e.ref(null),w=e.ref(null),S=e.computed(()=>s.value.map((E,C)=>({id:(n.id||"autocomplete")+"-item-"+C,class:[o.resultItemClass,{"bg-vxvue-700 text-white":r.value===C}],role:"option",...r.value===C?{"aria-selected":"true"}:{}}))),$=e.computed(()=>({role:"combobox",autocomplete:"off",autocapitalize:"off",autocorrect:"off",spellcheck:"false","aria-autocomplete":"list","aria-haspopup":"listbox","aria-owns":i,"aria-expanded":m.value?"true":"false","aria-activedescendant":r.value>-1?S.value[r.value].id:"",...n})),A=e.computed(()=>({id:i,class:["absolute min-w-full transform z-[var(--zIndex-dropdown)]",o.resultListClass,y.value],role:"listbox"})),z=()=>{r.value=-1,s.value=[],m.value=!1,h.value=!0},x=E=>{const C=o.search(E);if(C instanceof Promise){const L=++d.value;g.value=!0,C.then(D=>{L===d.value&&(s.value=D,g.value=!1,s.value.length?(r.value=o.autoSelect?0:-1,m.value=!0):z())})}else s.value=C,s.value.length===0?z():(r.value=o.autoSelect?0:-1,m.value=!0)},V=()=>{const E=s.value[r.value];return E&&(a.value=o.getResultValue(E)),z(),E},p=E=>{a.value=E,x(E)},f=E=>x(E.target.value),b=()=>{z(),l("blur-sm")},N=()=>{const E=s.value.length;r.value=((r.value-1)%E+E)%E},M=E=>{m.value||f(E);const C=s.value.length;r.value=((r.value+1)%C+C)%C},j=()=>{z(),a.value=""},P=()=>l("submit",V()),W=E=>{const C=E.target.closest("[data-result-index]");C&&(r.value=parseInt(C.dataset.resultIndex,10),l("submit",V()))};return U(w,z),e.onUpdated(()=>{if(B.value){const E=k.value.getBoundingClientRect(),C=B.value.getBoundingClientRect();h.value&&s.value.length&&(h.value=!1,y.value=E.bottom+C.height>window.innerHeight&&window.innerHeight-E.bottom<E.top&&window.pageYOffset+E.top-C.height>0?"bottom-0 -translate-y-12":"top-0 translate-y-12");const L=B.value.querySelector('[data-result-index="'+r.value+'"]');if(L){let D=L.getBoundingClientRect();D.top<C.top?B.value.scrollTop-=C.top-D.top:D.bottom>C.bottom&&(B.value.scrollTop+=D.bottom-C.bottom)}}}),(E,C)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"container",ref:w,class:e.normalizeClass(["inline-block relative",E.$attrs.class])},[e.createElementVNode("input",e.mergeProps({ref_key:"input",ref:k,class:"block pr-10 w-full form-input focus:border-vxvue",value:a.value},$.value,{onInput:C[0]||(C[0]=L=>p(L.target.value)),onKeydown:[e.withKeys(P,["enter"]),e.withKeys(j,["esc"]),e.withKeys(V,["tab"]),e.withKeys(e.withModifiers(N,["prevent"]),["up"]),e.withKeys(e.withModifiers(M,["prevent"]),["down"])],onFocus:f,onBlur:b}),null,16,Ee),e.createElementVNode("span",ve,[g.value?(e.openBlock(),e.createBlock(H,{key:0,class:"size-5"})):e.createCommentVNode("",!0)]),e.createVNode(O,{name:"fade"},{default:e.withCtx(()=>[s.value.length?(e.openBlock(),e.createElementBlock("div",e.mergeProps({key:0,ref_key:"resultList",ref:B},A.value,{onClick:W,onMousedown:C[1]||(C[1]=e.withModifiers(()=>{},["prevent"]))}),[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.value,(L,D)=>(e.openBlock(),e.createElementBlock("div",{"data-result-index":D},[e.renderSlot(E.$slots,"result",{result:L,props:S.value[D]},()=>[(e.openBlock(),e.createElementBlock("div",e.mergeProps({key:S.value[D].id},{ref_for:!0},S.value[D]),e.toDisplayString(t.getResultValue(L)),17))])],8,Se))),256))],16)):e.createCommentVNode("",!0)]),_:3})],2))}}),Ne={key:0,class:"fixed inset-0 z-[calc(var(--zIndex-confirm)-1)] bg-black/50 backdrop-blur-xs","aria-hidden":"true"},$e={key:0,class:"overflow-y-auto fixed inset-0 z-[var(--zIndex-confirm)]"},Me={class:"flex justify-center items-center min-h-screen text-center sm:block sm:p-0"},De={key:0},ze={class:"inline-block text-left align-bottom bg-white rounded-sm shadow-xl transition-all transform sm:my-8 sm:w-full sm:max-w-sm sm:align-middle lg:max-w-lg"},Ae={class:"px-4 pb-4 mt-4 sm:px-6 sm:pb-6 sm:mt-5"},Le={class:"flex flex-row items-center"},Te={class:"shrink-0"},Pe={class:"grow text-center"},Fe=["onClick"],Ie={__name:"Confirm",props:{buttons:{type:[Object,Array],default:()=>({label:"Ok"}),validator:t=>Array.isArray(t)&&t.length<=2&&t.filter(c=>c.label!=="undefined"&&c.value!=="undefined").length===t.length||t.label!==void 0&&t.value!==void 0},headerClass:{type:String,default:"text-vxvue-alt-900 bg-vxvue-alt-300"},buttonClass:{type:String,default:"button"}},setup(t,{expose:c}){const l=t,o=e.ref(""),a=e.ref(""),n=e.ref(!1);let u=null,i=null;const s=e.computed(()=>Array.isArray(l.buttons)?l.buttons:[l.buttons]),r=e.ref(null),d=(g,y)=>{n.value=!1,g.value!==void 0?g.value?u():i():y?i():u()};return c({open:(g,y)=>(o.value=g,a.value=y,n.value=!0,e.nextTick(()=>r.value.firstElementChild.focus()),new Promise((h,B)=>{u=h,i=B}))}),(g,y)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[n.value?(e.openBlock(),e.createElementBlock("div",Ne)):e.createCommentVNode("",!0),e.createVNode(O,{name:"appear"},{default:e.withCtx(()=>[n.value?(e.openBlock(),e.createElementBlock("div",$e,[e.createElementVNode("div",Me,[n.value?(e.openBlock(),e.createElementBlock("div",De,[y[0]||(y[0]=e.createElementVNode("span",{class:"hidden sm:inline-block sm:h-screen sm:align-middle","aria-hidden":"true"},"",-1)),e.createElementVNode("div",ze,[o.value||g.$slots.title?(e.openBlock(),e.createElementBlock("h3",{key:0,class:e.normalizeClass(["py-4 pt-4 rounded-t-sm text-lg font-medium text-center sm:py-6",t.headerClass])},[e.renderSlot(g.$slots,"title",{title:o.value},()=>[e.createTextVNode(e.toDisplayString(o.value),1)])],2)):e.createCommentVNode("",!0),e.createElementVNode("div",Ae,[e.createElementVNode("div",Le,[e.createElementVNode("div",Te,[e.renderSlot(g.$slots,"icon")]),e.createElementVNode("p",Pe,[e.renderSlot(g.$slots,"default",{message:a.value},()=>[e.createTextVNode(e.toDisplayString(a.value),1)])])]),e.createElementVNode("div",{ref_key:"buttonsContainer",ref:r,class:"flex justify-center mt-5 space-x-2 sm:mt-6"},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.value,(h,B)=>(e.openBlock(),e.createElementBlock("button",{key:h.label,class:e.normalizeClass([t.buttonClass,h.class]),onClick:e.withModifiers(k=>d(h,B),["prevent"])},e.toDisplayString(h.label),11,Fe))),128))],512)])])])):e.createCommentVNode("",!0)])])):e.createCommentVNode("",!0)]),_:3})],64))}};function Oe(t,c){const l=e.ref(!1),o=e.toValue(c);let a,n=o.toLowerCase().replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),u=[];if((a=o.match(/\bd\b/gi))&&a.length===1)n=n.replace("d","(\\d{1,2})");else if((a=o.match(/\bdd\b/gi))&&a.length===1)n=n.replace("dd","(\\d{2})");else return{date:l};if(u.push({srcPos:o.toLowerCase().indexOf("d"),destPos:2}),(a=o.match(/\bm\b/gi))&&a.length===1)n=n.replace("m","(\\d{1,2})");else if((a=o.match(/\bmm\b/gi))&&a.length===1)n=n.replace("mm","(\\d{2})");else return{date:l};if(u.push({srcPos:o.toLowerCase().indexOf("m"),destPos:1}),(a=o.match(/\byyyy\b/gi))&&a.length===1)n=n.replace("yyyy","(\\d{4})");else return{date:l};if(u.push({srcPos:o.toLowerCase().indexOf("y"),destPos:0}),!(a=e.toValue(t).match(n)))return{date:l};a.shift(),u.sort((d,m)=>d.srcPos<m.srcPos?-1:1);let i=[],s,r;for(;s=a.shift();)r=u.shift(),i[r.destPos]=s;return i=Date.parse(i.join("-")),i&&(i=new Date(i),l.value=new Date(i.getFullYear(),i.getMonth(),i.getDate(),0,0,0)),{date:l}}const _e={class:"text-vxvue-700"},je=["disabled"],ee=Object.assign({inheritAttrs:!1},{__name:"DateInput",props:e.mergeModels({outputFormat:{type:String,default:"YYYY-MM-DD"},inputFormat:{type:String,default:"YYYY-MM-DD"},showToggle:{type:Boolean,default:!1}},{modelValue:{type:Date,default:null},modelModifiers:{}}),emits:e.mergeModels(["toggle-datepicker"],["update:modelValue"]),setup(t,{emit:c}){const l=c,o=t,a=e.useModel(t,"modelValue"),n=e.ref(""),u=e.computed(()=>a.value?G(a.value,o.outputFormat):""),i=e.computed(()=>{let s=Object.assign({},e.useAttrs());return delete s.class,s});return e.watch(a,s=>n.value===s?G(s,o.outputFormat):""),(s,r)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["inline-block relative",s.$attrs.class])},[e.withDirectives(e.createElementVNode("div",null,[e.createElementVNode("div",{class:e.normalizeClass(["block flex items-center w-full form-input bg-vxvue-50",{"pr-10":t.showToggle}])},[e.createElementVNode("span",_e,e.toDisplayString(u.value),1),i.value.disabled?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("button",{key:0,class:"inline-flex shrink-0 justify-center items-center ml-2 rounded-full focus:text-white focus:outline-hidden size-4 text-vxvue hover:bg-vxvue-100 hover:text-vue-700 focus:bg-vxvue-700",onClick:r[0]||(r[0]=d=>a.value=null)},[e.createVNode(e.unref(R),{class:"size-4"})]))],2)],512),[[e.vShow,u.value]]),e.withDirectives(e.createElementVNode("div",null,[e.withDirectives(e.createElementVNode("input",e.mergeProps({"onUpdate:modelValue":r[1]||(r[1]=d=>n.value=d),type:"text",class:["block w-full form-input peer focus:border-vxvue",{"pr-10":t.showToggle}]},i.value,{onBlur:r[2]||(r[2]=d=>a.value=e.unref(Oe)(n.value,o.inputFormat).date?.value||null),onInput:r[3]||(r[3]=e.withModifiers(()=>{},["prevent"]))}),null,16),[[e.vModelText,n.value]])],512),[[e.vShow,!u.value]]),t.showToggle?(e.openBlock(),e.createElementBlock("button",{key:0,ref:"toggleButton",class:e.normalizeClass(["flex absolute inset-y-0 right-0 items-center px-2 text-vxvue-700",i.value.disabled?"cursor-not-allowed":"hover:text-vxvue"]),disabled:i.value.disabled,"aria-label":"datepicker-toggle",onClick:r[4]||(r[4]=e.withModifiers(d=>l("toggle-datepicker"),["stop"]))},[e.createVNode(e.unref(ae),{class:"size-6"})],10,je)):e.createCommentVNode("",!0),e.renderSlot(s.$slots,"default")],2))}}),Ye={class:"flex items-center py-2 px-3 text-white bg-vxvue-700"},Re={class:"flex justify-between w-1/2"},He={class:"flex justify-between w-1/2"},Ze={class:"grid grid-cols-7 gap-0.5 p-0.5"},qe=["disabled","onClick"],Ue={class:"flex justify-between items-center py-2 px-3 text-white bg-vxvue-700"},We={class:"grid grid-cols-2 gap-0.5 p-0.5"},Ke=["onClick"],Xe=Object.assign({inheritAttrs:!1},{__name:"Datepicker",props:e.mergeModels({shownMonth:Date,maxNumberOfValues:{type:Number,default:1},validFrom:Date,validUntil:Date,dayNames:{type:Array,default:()=>"S M T W T F S".split(" ")},highlightRange:Boolean,locale:{type:String,default:"default"},startOfWeekIndex:{type:Number,default:0,validator:t=>t===0||t===1},hasInput:{type:Boolean,default:!0}},{modelValue:{type:[Date,Array],default:null,validator:(t,c)=>t instanceof Date&&c.maxNumberOfValues===1||t.every(l=>l instanceof Date||l===null)&&t.length<=c.maxNumberOfValues},modelModifiers:{}}),emits:e.mergeModels(["month-change","year-change"],["update:modelValue"]),setup(t,{emit:c}){const l=t,o=e.useModel(t,"modelValue"),a=c,n=(()=>{const p=new Date;return new Date(p.getFullYear(),p.getMonth(),p.getDate())})(),u=e.ref(null),i=e.ref([]),s=e.ref(!1),r=e.ref("days"),d=e.ref(0),m=e.ref({horiz:"left-0",vert:"top-0"}),g=e.ref(null),y=e.ref(null),h=e.ref(null),B=e.computed(()=>l.hasInput&&l.maxNumberOfValues===1),k=e.computed(()=>{const p=[],f=u.value.getFullYear(),b=u.value.getMonth(),N=new Date(f,b+1,0),M=new Date(f,b,0).getDay()+1-l.startOfWeekIndex,j=(6+l.startOfWeekIndex-N.getDay())%7;for(let P=-M,W=N.getDate()+j;P<W;++P)p.push(new Date(f,b,P+1));return p}),w=e.computed(()=>l.startOfWeekIndex?l.dayNames.slice(1).concat(l.dayNames[0]):l.dayNames),S=p=>{u.value=new Date(u.value.getFullYear(),p,1),a("month-change",u.value)},$=p=>{u.value=new Date(p,u.value.getMonth(),1),a("year-change",u.value)},A=p=>o.value=p,z=p=>{if(s.value=!1,l.maxNumberOfValues===1)o.value=p;else{const f=i.value;let b=f.findIndex(N=>N.getTime()===p.getTime());b!==-1?f.splice(b,1):f.length<l.maxNumberOfValues&&f.push(p),o.value=f}},x=p=>i.value.find(f=>f?.getTime()===p.getTime()),V=p=>{const f=p.getMonth()!==u.value.getMonth(),b=x(p),N=p.getTime()===n.getTime(),M=l.validFrom&&l.validFrom>p||l.validUntil&&l.validUntil<p,j=!b&&l.maxNumberOfValues>1&&i.value.length===l.maxNumberOfValues,P=l.highlightRange&&p>Math.min(...i.value)&&p<Math.max(...i.value);return{"cursor-not-allowed":M||j,"text-vxvue-700":!M&&!f&&!N&&!b,"text-error":M&&!f,"text-gray-400":f&&!N&&!b,"bg-vxvue-alt-300 font-bold":N&&!b,"bg-vxvue-700 text-white":b,"hover:ring-2 hover:ring-vxvue":!M,"bg-vxvue-100/50":P&&!N&&!b}};return U(y,()=>{s.value=!1,r.value="days"},{ignore:[h]}),e.onMounted(()=>h.value=g.value?.$refs.toggleButton),e.watch(s,p=>{p&&B.value&&e.nextTick(()=>{const f=g.value.$el.getBoundingClientRect(),b=y.value.getBoundingClientRect();m.value.horiz=f.right-b.width<0?"left-0":"right-0",m.value.vert=f.bottom+b.height>window.innerHeight?"bottom-0 -translate-y-12":"top-0 translate-y-12"})}),e.watch(o,p=>{if(p)if(Array.isArray(p)){const f=[],b=i.value;p.forEach(N=>{N&&f.push(new Date(N.getFullYear(),N.getMonth(),N.getDate()))}),(f.length!==b.length||![...new Set([...f,...b])].every(N=>f.filter(M=>M.getTime()===N.getTime()).length===b.filter(M=>M.getTime()===N.getTime()).length))&&(i.value=f,u.value=new Date((f[0]||n).getTime()),u.value.setDate(1))}else i.value=[new Date(p.getFullYear(),p.getMonth(),p.getDate())],u.value=new Date(p.getFullYear(),p.getMonth(),1);else i.value=[],u.value=new Date(n.getFullYear(),n.getMonth(),1)},{immediate:!0}),e.watch(()=>l.shownMonth,p=>{u.value=new Date((p||n).getTime()),u.value.setDate(1)},{immediate:!0}),(p,f)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["relative",p.$attrs.class])},[B.value?(e.openBlock(),e.createBlock(ee,e.mergeProps({key:0},p.$attrs,{ref_key:"input",ref:g,"model-value":i.value[0],"show-toggle":!0,class:"w-full",onToggleDatepicker:f[0]||(f[0]=b=>s.value=!s.value),"onUpdate:modelValue":A}),{default:e.withCtx(()=>[e.renderSlot(p.$slots,"default")]),_:3},16,["model-value"])):e.createCommentVNode("",!0),e.createVNode(O,{name:"fade"},{default:e.withCtx(()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"calendar",ref:y,class:e.normalizeClass(["overflow-hidden z-[var(--zIndex-dropdown)] bg-white rounded-sm shadow-md min-w-72 sm:min-w-80",m.value.horiz,m.value.vert,{absolute:B.value}])},[r.value==="days"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createElementVNode("div",Ye,[e.createElementVNode("div",Re,[e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:f[1]||(f[1]=e.withModifiers(b=>S(u.value.getMonth()-1),["stop"]))},[e.createVNode(e.unref(Y),{class:"size-6"})]),e.createElementVNode("span",null,e.toDisplayString(u.value.toLocaleString(t.locale,{month:"long"})),1),e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:f[2]||(f[2]=e.withModifiers(b=>S(u.value.getMonth()+1),["stop"]))},[e.createVNode(e.unref(I),{class:"size-6"})])]),e.createElementVNode("div",He,[e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:f[3]||(f[3]=e.withModifiers(b=>$(u.value.getFullYear()-1),["stop"]))},[e.createVNode(e.unref(Y),{class:"size-6"})]),e.createElementVNode("button",{class:"text-vxvue-100 hover:text-vxvue-50",onClick:f[4]||(f[4]=b=>{r.value="years",d.value=u.value.getFullYear()})},e.toDisplayString(u.value.getFullYear()),1),e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:f[5]||(f[5]=e.withModifiers(b=>$(u.value.getFullYear()+1),["stop"]))},[e.createVNode(e.unref(I),{class:"size-6"})])])]),e.createElementVNode("div",Ze,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(w.value,(b,N)=>(e.openBlock(),e.createElementBlock("div",{key:N,class:"py-2 text-center bg-gray-200"},e.toDisplayString(b),1))),128)),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(k.value,b=>(e.openBlock(),e.createElementBlock("button",{key:b,class:e.normalizeClass(["py-2 rounded-xs block text-center",V(b)]),disabled:t.validFrom&&t.validFrom>b||t.validUntil&&t.validUntil<b||t.maxNumberOfValues>1&&i.value.length===t.maxNumberOfValues&&!x(b),onClick:e.withModifiers(N=>z(b),["stop"])},e.toDisplayString(b.getDate()),11,qe))),128))])],64)):e.createCommentVNode("",!0),r.value==="years"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createElementVNode("div",Ue,[e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:f[6]||(f[6]=e.withModifiers(b=>d.value-=10,["stop"]))},[e.createVNode(e.unref(Y),{class:"size-6"})]),e.createElementVNode("span",null,e.toDisplayString(d.value)+" - "+e.toDisplayString(d.value+9),1),e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:f[7]||(f[7]=e.withModifiers(b=>d.value+=10,["stop"]))},[e.createVNode(e.unref(I),{class:"size-6"})])]),e.createElementVNode("div",We,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(10,b=>e.createElementVNode("div",{key:b,class:"text-center hover:ring-2 text-vxvue-700 hover:ring-vxvue"},[e.createElementVNode("button",{class:"py-2 px-3",onClick:e.withModifiers(N=>{$(d.value+b-1),r.value="days"},["stop"])},e.toDisplayString(d.value+b-1),9,Ke)])),64))])],64)):e.createCommentVNode("",!0)],2),[[e.vShow,s.value]])]),_:1})],2))}}),Ge=["for"],Je=["id","multiple","accept"],Qe={__name:"FormFileButton",props:e.mergeModels({accept:{type:String,default:"*"},multiple:{type:Boolean,default:!1},name:{type:String,default:"file"},id:{type:String,default:"form-file-button-"+Math.ceil(Math.random()*1e3)}},{modelValue:{type:Array,default:()=>[]},modelModifiers:{}}),emits:e.mergeModels(["form-data"],["update:modelValue"]),setup(t,{emit:c}){const l=c,o=t,a=e.useModel(t,"modelValue"),n=i=>{const s=new FormData;for(let r of i)s.append(o.name,r,r.name);return s},u=i=>{const s=i.target.files||i.dataTransfer.files;if(s){const r=Array.from(s);a.value=r,l("form-data",n(r))}};return(i,s)=>(e.openBlock(),e.createElementBlock("label",{for:t.id},[e.renderSlot(i.$slots,"default",{},()=>[s[0]||(s[0]=e.createTextVNode("Upload",-1))]),e.createElementVNode("input",{id:t.id,type:"file",multiple:t.multiple,accept:t.accept,class:"hidden",onChange:u},null,40,Je)],8,Ge))}},et={key:0,value:null,disabled:"",hidden:""},tt=["selected","value"],te={__name:"FormSelect",props:e.mergeModels({options:{type:Array,default:()=>[]},placeholder:{type:String,default:null}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(t){const c=e.useModel(t,"modelValue");return(l,o)=>e.withDirectives((e.openBlock(),e.createElementBlock("select",e.mergeProps(l.$attrs,{"onUpdate:modelValue":o[0]||(o[0]=a=>c.value=a),class:"form-select"}),[t.placeholder?(e.openBlock(),e.createElementBlock("option",et,e.toDisplayString(t.placeholder),1)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,a=>(e.openBlock(),e.createElementBlock("option",{key:a.key!==void 0?a.key:a.label||a,selected:(a.key!==void 0?a.key:a.label||a)===c.value,value:a.key!==void 0?a.key:a.label||a},e.toDisplayString(a.label||a),9,tt))),128))],16)),[[e.vModelSelect,c.value]])}},lt=["aria-checked","aria-label"],at=["d"],ot={__name:"FormSwitch",props:{modelValue:{},modelModifiers:{}},emits:["update:modelValue"],setup(t){const c=e.useModel(t,"modelValue"),l=e.computed(()=>{let a=Object.assign({},e.useAttrs());return delete a.class,a}),o=e.computed(()=>e.useAttrs().disabled||e.useAttrs().disabled==="");return(a,n)=>(e.openBlock(),e.createElementBlock("label",{class:e.normalizeClass(a.$attrs.class),tabindex:"0"},[e.createElementVNode("span",{role:"switch",class:e.normalizeClass(["inline-flex relative shrink-0 w-11 p-[2px] rounded-full transition-colors duration-200 ease-in-out cursor-pointer focus:ring-2 focus:ring-offset-2 focus:outline-hidden focus:ring-vxvue",o.value?"bg-slate-200":c.value?"bg-vxvue":"bg-slate-300"]),"aria-checked":c.value,"aria-label":a.$attrs["aria-label"]},[e.createElementVNode("span",{"aria-hidden":"true",class:e.normalizeClass(["block relative size-5 rounded-full transition duration-200 ease-in-out transform pointer-events-none",c.value?"translate-x-5":"translate-x-0",o.value?"bg-slate-100":"bg-white"])},[e.renderSlot(a.$slots,"handle",{},()=>[(e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"6",stroke:"currentColor",class:e.normalizeClass(["absolute top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2 size-3",c.value&&!o.value?"text-vxvue":"text-slate-300"])},[e.createElementVNode("path",{"stroke-linecap":"round",d:c.value?"M12 18 V6":"m18.5 12 c0 3.5 -3 6.5 -6.5 6.5 -3.5 0 -6.5 -3 -6.5 -6.5 0 -3.5 3 -6.5 6.5 -6.5 3.5 0 6.5 3 6.5 6.5z"},null,8,at)],2))])],2),e.withDirectives(e.createElementVNode("input",e.mergeProps({"onUpdate:modelValue":n[0]||(n[0]=u=>c.value=u)},l.value,{class:"hidden",value:"1",type:"checkbox"}),null,16),[[e.vModelCheckbox,c.value]])],10,lt),e.renderSlot(a.$slots,"default")],2))}},nt={"aria-live":"assertive",class:"flex fixed inset-0 z-[var(--zIndex-toast)] items-start py-6 px-4 pointer-events-none sm:p-6"},rt={class:"flex flex-col items-center space-y-4 w-full"},st={class:"p-4"},it={class:"flex items-start"},ct={class:"shrink-0"},dt={class:"flex-1 pt-0.5 ml-3 w-0"},ut={class:"font-bold"},mt={class:"mt-1"},ft={class:"flex shrink-0 ml-4"},pt=Object.assign({inheritAttrs:!1},{__name:"MessageToast",props:{title:{type:String,default:""},message:{type:[String,Array],default:null},timeout:{type:Number,default:5e3},active:{type:Boolean,default:!1},showTimeoutProgress:{type:Boolean,default:!1}},emits:["timeout","close"],setup(t,{emit:c}){const l=t,o=c,a=e.computed(()=>typeof l.message=="string"?[l.message]:l.message),n=e.ref(0);let u=null;const i=()=>{window.clearTimeout(u),n.value=100,l.active&&l.timeout&&(u=window.setTimeout(()=>{o("timeout")},l.timeout),window.setTimeout(()=>n.value=0,0))};return e.watch(()=>l.active,i),e.onMounted(i),(s,r)=>(e.openBlock(),e.createElementBlock("div",nt,[e.createElementVNode("div",rt,[e.createVNode(O,{name:"vert-fade"},{default:e.withCtx(()=>[t.active?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["overflow-hidden w-full max-w-sm rounded-md ring-1 ring-black/5 shadow-lg pointer-events-auto",s.$attrs.class])},[e.createElementVNode("div",st,[e.createElementVNode("div",it,[e.createElementVNode("div",ct,[e.renderSlot(s.$slots,"icon")]),e.createElementVNode("div",dt,[e.renderSlot(s.$slots,"title",{},()=>[e.createElementVNode("div",ut,e.toDisplayString(t.title),1)]),e.renderSlot(s.$slots,"default",{},()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(a.value,d=>(e.openBlock(),e.createElementBlock("p",mt,e.toDisplayString(d),1))),256))])]),e.createElementVNode("div",ft,[e.createElementVNode("button",{class:"inline-flex text-white bg-black/20 rounded-xs focus:ring-2 focus:outline-hidden hover:text-stone-200 focus:ring-stone-200",onClick:r[0]||(r[0]=d=>o("close"))},[r[1]||(r[1]=e.createElementVNode("span",{class:"sr-only"},"Close",-1)),e.createVNode(e.unref(R),{class:"size-5"})])])])]),t.showTimeoutProgress&&t.timeout?(e.openBlock(),e.createElementBlock("div",{key:0,class:"h-1 transition-all ease-linear bg-vxvue-alt",style:e.normalizeStyle({width:n.value+"%","transition-duration":t.timeout+"ms"}),role:"progressbar","aria-hidden":"false","aria-label":"notification timer"},null,4)):e.createCommentVNode("",!0)],2)):e.createCommentVNode("",!0)]),_:3})])]))}}),ht={key:0,class:"fixed inset-0 z-[calc(var(--zIndex-modal)-1)] bg-white/50 backdrop-blur-xs","aria-hidden":"true"},gt={key:0,class:"fixed inset-0 z-[var(--zIndex-modal)]"},bt={class:"flex justify-center items-center h-screen"},kt={__name:"Modal",props:{show:Boolean,containerClass:{type:String,default:"mx-4 w-full lg:w-1/2 xl:w-1/4 max-h-[90vh]"},headerClass:{type:String,default:""},contentClass:{type:String,default:""}},emits:["clicked-outside"],setup(t,{emit:c}){const l=c,o=e.ref(null);return U(o,()=>l("clicked-outside")),(a,n)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[t.show?(e.openBlock(),e.createElementBlock("div",ht)):e.createCommentVNode("",!0),e.createVNode(O,{name:"appear"},{default:e.withCtx(()=>[t.show?(e.openBlock(),e.createElementBlock("div",gt,[e.createElementVNode("div",bt,[e.createElementVNode("div",{ref_key:"container",ref:o,class:e.normalizeClass(["flex flex-col overflow-hidden max-w-full bg-white rounded-sm ring-1 ring-black/10 shadow-xl transition-all transform xl:max-w-(--breakpoint-xl)",t.containerClass])},[e.createElementVNode("div",{class:e.normalizeClass(["grow-0",t.headerClass])},[e.renderSlot(a.$slots,"title")],2),e.createElementVNode("div",{class:e.normalizeClass(["overflow-y-auto h-full",t.contentClass])},[e.renderSlot(a.$slots,"default")],2)],2)])])):e.createCommentVNode("",!0)]),_:3})],64))}},yt={class:"flex justify-between items-center px-4 sm:px-0"},xt={class:"flex flex-1 -mt-px w-0"},wt=["disabled"],Bt={class:"hidden md:flex md:-mt-px"},Vt={class:"flex flex-1 justify-end -mt-px w-0"},Et=["disabled"],vt={__name:"Pagination",props:{page:{type:Number,default:1},total:{type:Number,default:1},perPage:{type:Number,default:20,validator:t=>t>=1},showNavButtons:{type:Boolean,default:!0},prevText:{type:String,default:"Previous"},nextText:{type:String,default:"Next"},showAllPages:{type:Boolean,default:!1},markerPosition:{type:String,default:"above",validator:t=>["above","below"].includes(t)}},emits:["update:page"],setup(t,{emit:c}){const l=c,o=t,a=e.ref(Math.ceil(o.total/o.perPage)),n=e.ref(null),u=e.computed(()=>(o.markerPosition==="above"?"border-t-4 -mt-[4px]":"border-b-4 -mb-[4px]")+" py-4"),i=e.computed(()=>{let d=[1];if(o.showAllPages||a.value<=7){for(let m=2;m<=a.value;++m)d.push(m);return d}return n.value>=a.value?d.push("dots",n.value-2,n.value-1):n.value-1&&n.value-1>1&&(n.value>1&&d.push("dots"),d.push(n.value-1)),n.value>1&&d.push(n.value),n.value+1<a.value&&(d.push(n.value+1),n.value<=1&&d.push(n.value+2),n.value+2<a.value&&d.push("dots")),n.value<a.value&&d.push(a.value),d}),s=()=>{n.value>1&&l("update:page",n.value-1)},r=()=>{n.value<a.value&&l("update:page",n.value+1)};return e.watch(()=>o.page,d=>n.value=Math.min(Math.max(d,1),a.value),{immediate:!0}),e.watch(()=>o.perPage,d=>{a.value=Math.ceil(o.total/o.perPage),l("update:page",1)}),e.watch(()=>o.total,d=>{a.value=Math.ceil(o.total/o.perPage),n.value>a.value&&l("update:page",a.value)}),(d,m)=>(e.openBlock(),e.createElementBlock("nav",yt,[e.createElementVNode("div",xt,[t.showNavButtons?(e.openBlock(),e.createElementBlock("button",{key:0,disabled:n.value<=1,class:e.normalizeClass([n.value<=1?"pointer-events-none text-gray-500":"text-vxvue-700","inline-flex items-center pr-1 text-sm border-transparent hover:text-vxvue"]),onClick:s},[e.createVNode(e.unref(Y),{class:"size-5"}),e.createTextVNode(" "+e.toDisplayString(t.prevText),1)],10,wt)):e.createCommentVNode("",!0)]),e.createElementVNode("div",Bt,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.value,(g,y)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(t.page!=="dots"?"button":"span"),{key:y,class:e.normalizeClass([{"pointer-events-none":g==="dots"},g===n.value?"border-vxvue text-vxvue font-bold":"border-transparent text-gray-500 hover:border-gray-300",u.value,"inline-flex items-center px-4 text-sm"]),onClick:h=>g!=="dots"?l("update:page",g):null},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(g!=="dots"?g:"…"),1)]),_:2},1032,["class","onClick"]))),128))]),e.createElementVNode("div",Vt,[t.showNavButtons?(e.openBlock(),e.createElementBlock("button",{key:0,disabled:n.value>=a.value,class:e.normalizeClass([n.value>=a.value?"pointer-events-none text-gray-500":"text-vxvue-700","inline-flex items-center pr-1 text-sm border-transparent hover:text-vxvue"]),onClick:r},[e.createTextVNode(e.toDisplayString(t.nextText)+" ",1),e.createVNode(e.unref(I),{class:"size-5"})],10,Et)):e.createCommentVNode("",!0)])]))}};function St(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M3.98 8.223A10.477 10.477 0 0 0 1.934 12C3.226 16.338 7.244 19.5 12 19.5c.993 0 1.953-.138 2.863-.395M6.228 6.228A10.451 10.451 0 0 1 12 4.5c4.756 0 8.773 3.162 10.065 7.498a10.522 10.522 0 0 1-4.293 5.774M6.228 6.228 3 3m3.228 3.228 3.65 3.65m7.894 7.894L21 21m-3.228-3.228-3.65-3.65m0 0a3 3 0 1 0-4.243-4.243m4.242 4.242L9.88 9.88"})])}function Ct(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M2.036 12.322a1.012 1.012 0 0 1 0-.639C3.423 7.51 7.36 4.5 12 4.5c4.638 0 8.573 3.007 9.963 7.178.07.207.07.431 0 .639C20.577 16.49 16.64 19.5 12 19.5c-4.638 0-8.573-3.007-9.963-7.178Z"}),e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M15 12a3 3 0 1 1-6 0 3 3 0 0 1 6 0Z"})])}const Nt=["type"],$t=["disabled"],Mt=Object.assign({inheritAttrs:!1},{__name:"PasswordInput",props:{modelValue:{},modelModifiers:{}},emits:["update:modelValue"],setup(t){const c=e.useModel(t,"modelValue"),l=e.ref(!1),o=e.computed(()=>{let a=Object.assign({},e.useAttrs());return delete a.class,a});return(a,n)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass("inline-block relative "+e.useAttrs().class)},[e.withDirectives(e.createElementVNode("input",e.mergeProps({"onUpdate:modelValue":n[0]||(n[0]=u=>c.value=u),type:l.value?"text":"password"},o.value,{class:"block pr-12 w-full form-input peer"}),null,16,Nt),[[e.vModelDynamic,c.value]]),e.createElementVNode("button",{class:"flex absolute inset-y-0 right-0 items-center px-3 text-brand-700 hover:text-brand","aria-label":"show-password-toggle",disabled:e.useAttrs().disabled??!1,onClick:n[1]||(n[1]=e.withModifiers(u=>l.value=!l.value,["stop"]))},[l.value?(e.openBlock(),e.createBlock(e.unref(St),{key:0,class:"size-5"})):(e.openBlock(),e.createBlock(e.unref(Ct),{key:1,class:"size-5"}))],8,$t)],2))}}),Dt={class:"flex items-center pb-1"},zt={key:0,class:"ml-6"},At=Object.assign({inheritAttrs:!1},{__name:"SimpleTree",props:e.mergeModels({branch:{type:Object,default:()=>({})}},{modelValue:{type:Object,default:null},modelModifiers:{}}),emits:e.mergeModels(["expand"],["update:modelValue"]),setup(t,{emit:c}){const l=t,o=c,a=e.useModel(t,"modelValue"),n=e.ref(!1);return e.onMounted(()=>{l.branch===a.value&&o("expand",!0)}),(u,i)=>{const s=e.resolveComponent("simple-tree",!0);return e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([!t.branch.branches||!t.branch.branches.length?"terminates":"",u.$attrs.class])},[e.createElementVNode("div",Dt,[t.branch.branches&&t.branch.branches.length?(e.openBlock(),e.createElementBlock("button",{key:0,class:"mr-2",onClick:i[0]||(i[0]=r=>n.value=!n.value)},[e.renderSlot(u.$slots,"toggle",{branch:t.branch,expanded:n.value},()=>[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(n.value?e.unref(se):e.unref(ie)),{class:"p-0.5 text-white rounded size-5 bg-vxvue-700 hover:bg-vxvue"}))])])):e.createCommentVNode("",!0),t.branch===a.value?e.renderSlot(u.$slots,"label-selected",{key:1,branch:t.branch},()=>[e.createElementVNode("strong",null,e.toDisplayString(t.branch.label),1)]):(e.openBlock(),e.createElementBlock("button",{key:2,onClick:i[1]||(i[1]=r=>a.value=t.branch)},[e.renderSlot(u.$slots,"label",{branch:t.branch},()=>[e.createTextVNode(e.toDisplayString(t.branch.label),1)])]))]),t.branch.branches&&t.branch.branches.length?e.withDirectives((e.openBlock(),e.createElementBlock("div",zt,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.branch.branches,r=>(e.openBlock(),e.createBlock(s,{key:r.id||r.key||null,branch:r,modelValue:a.value,"onUpdate:modelValue":i[2]||(i[2]=d=>a.value=d),onExpand:i[3]||(i[3]=d=>{n.value=d,o("expand",d)})},e.createSlots({_:2},[e.renderList(u.$slots,(d,m)=>({name:m,fn:e.withCtx(g=>[e.renderSlot(u.$slots,m,e.mergeProps({ref_for:!0},g))])}))]),1032,["branch","modelValue"]))),128))],512)),[[e.vShow,n.value]]):e.createCommentVNode("",!0)],2)}}}),Lt={__name:"Sizable",props:{vertical:Boolean},emits:["dragStart","dragStop"],setup(t,{emit:c}){const l=t,o=c,a=e.ref(null),n=e.ref(null);let u=!1,i={},s=null,r=null,d=null;const m=h=>{if(u){h.preventDefault();const{pageX:B,pageY:k}=h.touches?.[0]??h;l.vertical?a.value.style.height=Math.min(r.height-d.height-(s.y-r.y),Math.max(0,s.height+k-i.y))+"px":a.value.style.width=Math.min(r.width-d.width-(s.x-r.x),Math.max(0,s.width+B-i.x))+"px"}},g=h=>{h.preventDefault(),h.currentTarget.focus(),u=!0;const{pageX:B,pageY:k}=h.touches?.[0]??h;i={x:B,y:k},d=n.value.getBoundingClientRect(),s=a.value.getBoundingClientRect(),r=a.value.parentElement.getBoundingClientRect(),h.type==="mousedown"?(document.addEventListener("mousemove",m),document.addEventListener("mouseup",y)):(document.addEventListener("touchmove",m),document.addEventListener("touchend",y)),o("dragStart")},y=h=>{u&&(u=!1,h.type==="mouseup"?(document.removeEventListener("mousemove",m),document.removeEventListener("mouseup",y)):(document.removeEventListener("touchmove",m),document.removeEventListener("touchend",y)),setTimeout(()=>o("dragStop"),0))};return(h,B)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"box",ref:a,class:"relative"},[e.renderSlot(h.$slots,"default"),e.createElementVNode("div",e.mergeProps({ref_key:"handle",ref:n,class:["absolute flex",l.vertical?"inset-x-0 top-full justify-center py-1 cursor-ns-resize":"inset-y-0 left-full items-center px-1 cursor-ew-resize"]},e.toHandlers({touchstart:g,mousedown:g,touchend:y,mouseup:y},!0)),[e.renderSlot(h.$slots,"handle",{},()=>[e.createElementVNode("div",{class:e.normalizeClass(["rounded-full bg-vxvue",l.vertical?"h-1.5 w-8":"h-8 w-1.5"])},null,2)])],16)],512))}},Tt=["aria-valuemin","aria-valuemax","aria-valuenow","aria-valuetext"],Pt=["id"],Ft=["id","aria-label"],It=Object.assign({inheritAttrs:!1},{__name:"Slider",props:e.mergeModels({min:{type:Number,default:0},max:{type:Number,default:100},vertical:Boolean,disabled:Boolean},{modelValue:{type:[Number,Array],default:null,validator(t){return typeof t=="number"||t.every(c=>typeof c=="number")}},modelModifiers:{}}),emits:e.mergeModels(["dragStart","dragStop"],["update:modelValue"]),setup(t,{emit:c}){const l=t,o=e.useModel(t,"modelValue"),a=c,n=e.useAttrs(),u={x:null,y:null},i={w:null,h:null};let s=!1;const r=e.ref(null),d=e.ref(0),m=e.computed(()=>{const x=l.max,V=l.min;return o.value instanceof Array?o.value.map(p=>(Math.max(Math.min(p,x),V)-V)*100/(x-V)):(Math.max(Math.min(o.value,x),V)-V)*100/(x-V)}),g=e.computed(()=>{if(o.value instanceof Array){const x=Math.min(...m.value)+"%",V=Math.max(...m.value)-Math.min(...m.value)+"%";return l.vertical?{bottom:x,height:V}:{left:x,width:V}}return l.vertical?{bottom:0,height:m.value+"%"}:{width:m.value+"%"}}),y=e.ref({class:(l.vertical?"left-0 -translate-x-1.5 translate-y-2.5":"top-0 -translate-x-2.5 -translate-y-1.5")+" touch-none absolute size-5 rounded-full border-2 bg-white transition-colors duration-200 "+(l.disabled?"":" focus:ring-4 focus:outline-hidden border-vxvue cursor-grab hover:bg-vxvue focus:ring-vxvue/50"),tabindex:0}),h=x=>{let V=parseFloat(x.toFixed(10));V=Math.min(l.max,Math.max(l.min,V)),o.value instanceof Array?o.value[d.value]=V:o.value=V},B=x=>{const{pageX:V,pageY:p}=x.touches?x.touches[0]:x,f=l.vertical?(-p+u.y)/i.h:(V-u.x)/i.w;h(Math.floor((l.max-l.min)*f+l.min))},k=()=>{const{clientLeft:x,clientTop:V,scrollLeft:p,scrollTop:f}=document.documentElement,b=r.value.getBoundingClientRect();u.x=b.left+p-x,u.y=b.bottom+f-V,i.w=r.value.offsetWidth,i.h=r.value.offsetHeight},w=x=>{s&&(x.preventDefault(),B(x))},S=x=>{x.preventDefault(),x.currentTarget.focus(),k(),s=!0,x.type==="mousedown"?(document.addEventListener("mousemove",w),document.addEventListener("mouseup",$)):(document.addEventListener("touchmove",w),document.addEventListener("touchend",$)),a("dragStart")},$=x=>{s&&(s=!1,x.type==="mouseup"?(document.removeEventListener("mousemove",w),document.removeEventListener("mouseup",$)):(document.removeEventListener("touchmove",w),document.removeEventListener("touchend",$)),setTimeout(()=>a("dragStop"),0))},A=x=>{x.keyCode>=33&&x.keyCode<=40&&x.preventDefault();const V=o.value[d.value]??o.value;switch(x.keyCode){case 37:case 40:h(V-1);break;case 39:case 38:h(V+1);break;case 33:h(V+(l.max-l.min)/10);break;case 34:h(V-(l.max-l.min)/10);break;case 36:h(l.min);break;case 35:h(l.max)}},z=x=>{k(),B(x)};return(x,V)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({ref_key:"track",ref:r,class:["relative bg-slate-300",t.vertical?"h-full w-2 rounded-t-full rounded-b-full":"w-full h-2 rounded-r-full rounded-l-full"],role:"slider","aria-label":"slider-thumb","aria-valuemin":t.min,"aria-valuemax":t.max,"aria-valuenow":o.value[0]??o.value,"aria-valuetext":o.value},e.toHandlers(t.disabled?{}:{click:z},!0)),[t.disabled?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["absolute bg-vxvue",t.vertical?"w-full rounded-t-full rounded-b-full":"h-full rounded-r-full rounded-l-full"]),style:e.normalizeStyle(g.value)},null,6)),o.value.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:2},e.renderList(o.value,(p,f)=>(e.openBlock(),e.createElementBlock("button",e.mergeProps({id:f?null:e.unref(n).id,style:t.vertical?{bottom:m.value[f]+"%"}:{left:m.value[f]+"%"},"aria-label":"slider-thumb-"+(f+1)},{ref_for:!0},y.value,e.toHandlers(t.disabled?{}:{focus:()=>d.value=f,keydown:A,touchstart:b=>{d.value=f,S(b)},mousedown:b=>{d.value=f,S(b)},touchend:$,mouseup:$},!0)),null,16,Ft))),256)):(e.openBlock(),e.createElementBlock("button",e.mergeProps({key:1,id:e.unref(n).id,style:t.vertical?{bottom:m.value+"%"}:{left:m.value+"%"},"aria-label":"slider-thumb"},y.value,e.toHandlers(t.disabled?{}:{focus:()=>d.value=0,keydown:A,touchstart:p=>{d.value=0,S(p)},mousedown:p=>{d.value=0,S(p)},touchend:$,mouseup:$},!0)),null,16,Pt))],16,Tt))}}),Ot=["data-active","onClick"],_t={class:"flex items-center space-x-1"},jt=["data-active"],Yt={__name:"Sortable",props:{columns:{type:Array,required:!0,validator:t=>{for(const c of t)if(c.label===void 0||c.prop===void 0)return!1;return!0}},rows:{type:Array,required:!0},offset:{type:Number,default:null},count:{type:Number,default:null},sortProp:{type:String,default:null},sortDirection:{type:String,default:null,validator:t=>!t||["asc","desc"].includes(t)},keyProperty:{type:String,default:"key"},headerClass:{type:String,default:"text-white bg-vxvue-700 [&_*[data-active]]:bg-vxvue-alt-800"},bodyClass:{type:String,default:"[&>*:nth-child(even)]:bg-vxvue-50 [&>*:nth-child(even)_*[data-active]]:bg-vxvue-alt-100 [&>*:nth-child(odd)_*[data-active]]:bg-vxvue-alt-50"}},emits:["before-sort","after-sort"],setup(t,{emit:c}){const l=t,o=c,a=e.ref(l.sortProp),n=e.ref(l.sortDirection),u=e.computed(()=>{let s=l.rows.slice();const r=l.columns.find(({prop:d})=>d===a.value);return r&&(n.value==="asc"&&r.sortAscFunction?s.sort(r.sortAscFunction):n.value==="desc"&&r.sortDescFunction?s.sort(r.sortDescFunction):s.sort((d,m)=>d[a.value]<m[a.value]?n.value==="asc"?-1:1:d[a.value]>m[a.value]?n.value==="asc"?1:-1:0)),s.slice(l.offset||0,(l.offset||0)+(l.count||s.length))}),i=s=>{o("before-sort",{prop:a.value,dir:n.value}),a.value===s?n.value=n.value==="asc"?"desc":"asc":(a.value=s,n.value=n.value||"asc"),e.nextTick(()=>o("after-sort",{prop:a.value,dir:n.value}))};return(s,r)=>(e.openBlock(),e.createElementBlock("table",{class:e.normalizeClass(s.$attrs.class||"w-full divide-y divide-y-slate-900 table-fixed")},[e.createElementVNode("thead",{class:e.normalizeClass(t.headerClass)},[e.createElementVNode("tr",null,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.columns,d=>(e.openBlock(),e.createElementBlock("th",{key:d.prop,scope:"col","data-active":a.value===d.prop?"active":null,class:e.normalizeClass(["py-3 px-6 text-left",{"cursor-pointer":d.sortable},d.cssClass]),onClick:m=>d.sortable?i(d.prop):null},[e.renderSlot(s.$slots,d.prop+"-header",{column:d,sortDir:n.value,sortProp:a.value},()=>[e.createElementVNode("div",_t,[e.createElementVNode("span",null,e.toDisplayString(d.label),1),d.sortable?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(a.value!==d.prop?e.unref(ne):n.value==="asc"?e.unref(oe):e.unref(re)),{key:0,class:"size-4"})):e.createCommentVNode("",!0)])])],10,Ot))),128))])],2),e.createElementVNode("tbody",{class:e.normalizeClass(t.bodyClass)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(u.value,d=>(e.openBlock(),e.createElementBlock("tr",{key:d[t.keyProperty],class:e.normalizeClass(d.cssClass)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.columns,m=>(e.openBlock(),e.createElementBlock("td",{key:m.prop,"data-active":a.value===m.prop?"active":null,class:"overflow-hidden py-3 px-6 whitespace-nowrap text-ellipsis"},[e.renderSlot(s.$slots,m.prop,{row:d},()=>[e.createTextVNode(e.toDisplayString(d[m.prop]),1)])],8,jt))),128))],2))),128))],2)],2))}},Rt={class:"flex items-center space-x-2"},Ht=["disabled"],Zt=K(Object.assign({inheritAttrs:!1},{__name:"SubmitButton",props:{busy:Boolean,spinnerClass:{type:String,default:null},theme:{type:String,default:null}},emits:["submit"],setup(t,{emit:c}){const l=c;return(o,a)=>(e.openBlock(),e.createElementBlock("div",Rt,[e.createElementVNode("button",{class:e.normalizeClass([o.$attrs.class,t.theme]),disabled:o.$attrs.disabled||t.busy,type:"button",onClick:a[0]||(a[0]=n=>l("submit"))},[e.renderSlot(o.$slots,"default",{},void 0,!0)],10,Ht),t.busy?(e.openBlock(),e.createBlock(H,{key:0,class:e.normalizeClass(t.spinnerClass||["size-5",{error:"text-error",success:"text-success",default:"text-vxvue"}[t.theme||"default"]])},null,8,["class"])):e.createCommentVNode("",!0)]))}}),[["__scopeId","data-v-646b7a90"]]),qt={class:"sm:hidden"},Ut={class:"hidden sm:block"},Wt={class:"border-b border-gray-200"},Kt={class:"flex -mb-px space-x-8","aria-label":"Tabs"},Xt=["aria-current","onClick"],Gt={__name:"Tabs",props:{items:{type:Array,default:()=>[]},activeIndex:{type:Number,default:0}},emits:["update:activeIndex"],setup(t,{emit:c}){const l=t,o=c,a=e.ref(l.items[l.activeIndex]||{}),n=e.computed(()=>{let i=[];return l.items.forEach((s,r)=>{s.disabled||i.push({label:s.name,key:r})}),i});e.watch(()=>l.activeIndex,i=>{a.value=l.items[i]||{}});const u=i=>{i.disabled||(a.value=i,o("update:activeIndex",l.items.indexOf(i)))};return(i,s)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",qt,[e.createVNode(te,{options:n.value,"model-value":t.activeIndex,class:"w-full","onUpdate:modelValue":s[0]||(s[0]=r=>o("update:activeIndex",r))},null,8,["options","model-value"])]),e.createElementVNode("div",Ut,[e.createElementVNode("div",Wt,[e.createElementVNode("nav",Kt,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.items,r=>(e.openBlock(),e.createElementBlock("a",{key:r.name,href:"#",class:e.normalizeClass(["group inline-flex items-center py-4 px-1 border-b-4 font-medium no-underline! border-transparent",{"border-vxvue text-vxvue":a.value===r,"cursor-not-allowed text-gray-400":r.disabled,"text-gray-900 hover:text-vxvue-600 hover:border-vxvue-600":a.value!==r&&!r.disabled}]),"aria-current":a.value===r?"page":void 0,onClick:e.withModifiers(d=>u(r),["prevent"])},[e.renderSlot(i.$slots,"icon",{tab:r}),e.createElementVNode("span",null,[e.renderSlot(i.$slots,"default",{tab:r},()=>[e.createTextVNode(e.toDisplayString(r.name),1)])]),e.renderSlot(i.$slots,"badge",{tab:r},()=>[r.badge?(e.openBlock(),e.createElementBlock("span",{key:0,class:e.normalizeClass(["hidden ml-3 py-0.5 px-2.5 rounded-full text-xs font-medium md:inline-block text-current",{"bg-gray-100":r.disabled,"bg-vxvue-50":a.value===r,"bg-gray-200":a.value!==r&&!r.disabled}])},e.toDisplayString(r.badge),3)):e.createCommentVNode("",!0)])],10,Xt))),128))])])])],64))}},Jt={mounted:t=>t.focus()},Qt={mounted:(t,c)=>{if(!["INPUT","TEXTAREA"].includes(t.nodeName)){let l=t.querySelector('input:not([type]),input[type="text"],input[type="search"],input[type="email"],input[type="password"],input[type="url"],input[type="tel"]');l||(l=t.querySelector("textarea")),t=l}if(t){if(t.querySelector("label"))throw new Error("VFloatingLabel directive: LABEL element found.");const l=Math.random().toString(36).substring(2),o=document.createElement("div");o.classList.add("relative","isolate");const a=document.createElement("label");a.classList.add(..."absolute px-2 left-1 top-2 scale-90 text-sm z-[var(--zIndex-label)] origin-[0] bg-white -translate-y-4 transform-gpu duration-200".split(" "),..."peer-focus:top-2 peer-focus:scale-90 peer-focus:-translate-y-full".split(" "),..."peer-placeholder-shown:scale-100 peer-placeholder-shown:-translate-y-1/2".split(" "),t.nodeName==="TEXTAREA"?"peer-placeholder-shown:top-4":"peer-placeholder-shown:top-1/2"),c.value?.invalid?a.classList.add("text-error","peer-focus:text-error"):a.classList.add("peer-focus:text-blue-600"),t.getAttribute("required")!==null&&a.classList.add("required"),a.setAttribute("for",t.getAttribute("id")||l+"-element"),a.innerHTML=c.value?.label||t.getAttribute("placeholder")||l+"-label",t.classList.add("peer"),t.setAttribute("placeholder"," "),t.setAttribute("id",t.getAttribute("id")||l+"-element"),t.parentElement.replaceChild(o,t),o.appendChild(t),o.appendChild(a)}},updated:(t,c)=>{const l=t.parentNode.querySelector("label");if(!l)return;const o=t.getAttribute("placeholder")?.trim();l.innerHTML=c.value?.label||o||l.innerHTML,o&&t.setAttribute("placeholder"," "),c.value?.invalid?(l.classList.add("text-error","peer-focus:text-error"),l.classList.remove("peer-focus:text-blue-600")):(l.classList.remove("text-error","peer-focus:text-error"),l.classList.add("peer-focus:text-blue-600")),l.classList[t.getAttribute("required")!==null?"add":"remove"]("required")}};v.Accordion=le,v.AccordionPanel=me,v.Autocomplete=Ce,v.Confirm=Ie,v.DateInput=ee,v.Datepicker=Xe,v.FormFileButton=Qe,v.FormSelect=te,v.FormSwitch=ot,v.MessageToast=pt,v.Modal=kt,v.Pagination=vt,v.PasswordInput=Mt,v.SimpleTree=At,v.Sizable=Lt,v.Slider=It,v.Sortable=Yt,v.Spinner=H,v.SubmitButton=Zt,v.Tabs=Gt,v.VFloatingLabel=Qt,v.VFocus=Jt,Object.defineProperty(v,Symbol.toStringTag,{value:"Module"})});
|
|
1
|
+
(function(E,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],e):(E=typeof globalThis<"u"?globalThis:E||self,e(E.vxVue={},E.Vue))})(this,function(E,e){"use strict";const ee={__name:"Accordion",props:{activeIndex:{type:[Number,Array],default:null}},emits:["update:activeIndex"],setup(t,{emit:c}){const l=t,o=c,a=e.useSlots(),n=e.ref([]),u=f=>n.value.push(f),i=e.computed(()=>a.default().reduce((f,h)=>((h.type.__name||h.type.name)==="AccordionPanel"&&f.push(h),f),[])),r=f=>{if(Array.isArray(l.activeIndex)){let h=[].concat(l.activeIndex),y=h.findIndex(g=>g===f);y===-1?o("update:activeIndex",[...h,f]):(h.splice(y,1),o("update:activeIndex",h))}else o("update:activeIndex",f===l.activeIndex?-1:f)},s=f=>{if(f=++f%i.value.length,!n.value[f].disabled){r(f),n.value[f].focus();return}s(f)},d=f=>{if(f=(f||i.value.length)-1,!n.value[f].disabled){r(f),n.value[f].focus();return}d(f)};return e.onBeforeUpdate(()=>n.value=[]),(f,h)=>(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.value,(y,g)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(y),{key:g,ref_for:!0,ref:u,show:Array.isArray(t.activeIndex)?t.activeIndex?.includes(g):t.activeIndex===g,onSelect:B=>r(g),onKeydown:B=>s(g),onKeyup:B=>d(g)},null,40,["show","onSelect","onKeydown","onKeyup"]))),128))}};function te(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M6.75 2.25A.75.75 0 0 1 7.5 3v1.5h9V3A.75.75 0 0 1 18 3v1.5h.75a3 3 0 0 1 3 3v11.25a3 3 0 0 1-3 3H5.25a3 3 0 0 1-3-3V7.5a3 3 0 0 1 3-3H6V3a.75.75 0 0 1 .75-.75Zm13.5 9a1.5 1.5 0 0 0-1.5-1.5H5.25a1.5 1.5 0 0 0-1.5 1.5v7.5a1.5 1.5 0 0 0 1.5 1.5h13.5a1.5 1.5 0 0 0 1.5-1.5v-7.5Z","clip-rule":"evenodd"})])}function le(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M12.53 16.28a.75.75 0 0 1-1.06 0l-7.5-7.5a.75.75 0 0 1 1.06-1.06L12 14.69l6.97-6.97a.75.75 0 1 1 1.06 1.06l-7.5 7.5Z","clip-rule":"evenodd"})])}function j(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M7.72 12.53a.75.75 0 0 1 0-1.06l7.5-7.5a.75.75 0 1 1 1.06 1.06L9.31 12l6.97 6.97a.75.75 0 1 1-1.06 1.06l-7.5-7.5Z","clip-rule":"evenodd"})])}function I(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M16.28 11.47a.75.75 0 0 1 0 1.06l-7.5 7.5a.75.75 0 0 1-1.06-1.06L14.69 12 7.72 5.03a.75.75 0 0 1 1.06-1.06l7.5 7.5Z","clip-rule":"evenodd"})])}function ae(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M11.47 4.72a.75.75 0 0 1 1.06 0l3.75 3.75a.75.75 0 0 1-1.06 1.06L12 6.31 8.78 9.53a.75.75 0 0 1-1.06-1.06l3.75-3.75Zm-3.75 9.75a.75.75 0 0 1 1.06 0L12 17.69l3.22-3.22a.75.75 0 1 1 1.06 1.06l-3.75 3.75a.75.75 0 0 1-1.06 0l-3.75-3.75a.75.75 0 0 1 0-1.06Z","clip-rule":"evenodd"})])}function oe(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M11.47 7.72a.75.75 0 0 1 1.06 0l7.5 7.5a.75.75 0 1 1-1.06 1.06L12 9.31l-6.97 6.97a.75.75 0 0 1-1.06-1.06l7.5-7.5Z","clip-rule":"evenodd"})])}function ne(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M4.25 12a.75.75 0 0 1 .75-.75h14a.75.75 0 0 1 0 1.5H5a.75.75 0 0 1-.75-.75Z","clip-rule":"evenodd"})])}function re(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M12 3.75a.75.75 0 0 1 .75.75v6.75h6.75a.75.75 0 0 1 0 1.5h-6.75v6.75a.75.75 0 0 1-1.5 0v-6.75H4.5a.75.75 0 0 1 0-1.5h6.75V4.5a.75.75 0 0 1 .75-.75Z","clip-rule":"evenodd"})])}function R(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"fill-rule":"evenodd",d:"M5.47 5.47a.75.75 0 0 1 1.06 0L12 10.94l5.47-5.47a.75.75 0 1 1 1.06 1.06L13.06 12l5.47 5.47a.75.75 0 1 1-1.06 1.06L12 13.06l-5.47 5.47a.75.75 0 0 1-1.06-1.06L10.94 12 5.47 6.53a.75.75 0 0 1 0-1.06Z","clip-rule":"evenodd"})])}const se=["id","disabled","aria-expanded","aria-controls"],ie=["id","aria-labelledby"],ce={class:"overflow-hidden rounded-b"},de=Object.assign({inheritAttrs:!1},{__name:"AccordionPanel",props:{show:Boolean,disabled:Boolean},emits:["select","keyup","keydown"],setup(t,{expose:c,emit:l}){const o=l,a=t,n=e.useAttrs(),u=e.ref(null),i=Math.random().toString(20).substring(2,8),r=d=>{if(!a.disabled){const f=new Map([[40,"keydown"],[38,"keyup"]]).get(d.keyCode);f&&(o(f),d.preventDefault())}};return c({focus:()=>u.value.focus(),disabled:a.disabled}),(d,f)=>(e.openBlock(),e.createElementBlock("div",null,[e.createElementVNode("button",{id:"ap-control-"+e.unref(i),ref_key:"btn",ref:u,class:e.normalizeClass(["flex items-center w-full space-x-2 px-4 py-2 ring-vxvue",t.show?"rounded-t":"rounded-sm",t.disabled?"bg-slate-300 text-slate-700":"bg-vxvue hover:bg-vxvue-600 text-white",e.unref(n).class]),disabled:t.disabled,"aria-expanded":t.show,"aria-controls":"ap-"+e.unref(i),tabindex:"0",onClick:f[0]||(f[0]=h=>o("select")),onKeydown:r},[t.disabled?(e.openBlock(),e.createBlock(e.unref(R),{key:0,class:"size-5"})):(e.openBlock(),e.createBlock(e.unref(I),{key:1,class:e.normalizeClass(["size-5 transform-gpu transition-transform duration-300",{"rotate-90":t.show}])},null,8,["class"])),e.createElementVNode("span",null,[e.renderSlot(d.$slots,"header")])],42,se),e.createElementVNode("div",{id:"ap-"+e.unref(i),class:e.normalizeClass(["grid transition-[grid-template-rows] duration-300 ease-in-out",t.show&&!t.disabled?"grid-rows-1":"grid-rows-[repeat(1,minmax(0,0fr))]"]),"aria-labelledby":"ap-control-"+e.unref(i)},[e.createElementVNode("div",ce,[e.renderSlot(d.$slots,"default")])],10,ie)]))}}),ue=["viewBox"],me=["cx","cy","r","stroke-width"],fe=["cx","cy","r","stroke-width","stroke-dasharray"],H={__name:"Spinner",props:{radius:{type:Number,default:10},strokeWidth:{type:Number,default:4}},setup(t){const c=t,l=e.computed(()=>c.radius+c.strokeWidth/2),o=e.computed(()=>c.radius*2+c.strokeWidth),a=e.computed(()=>c.radius*Math.PI/1.5);return(n,u)=>(e.openBlock(),e.createElementBlock("svg",{class:"animate-spin",xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 "+o.value+" "+o.value,role:"progressbar"},[e.createElementVNode("circle",{class:"opacity-35",cx:l.value,cy:l.value,r:t.radius,stroke:"currentColor","stroke-width":t.strokeWidth},null,8,me),e.createElementVNode("circle",{cx:l.value,cy:l.value,r:t.radius,stroke:"currentColor","stroke-width":t.strokeWidth,"stroke-dasharray":a.value+" "+t.radius*100,"stroke-linecap":"round"},null,8,fe)],8,ue))}},Z=(t,c)=>{const l=t.__vccOpts||t;for(const[o,a]of c)l[o]=a;return l},O=Z({__name:"VxVueTransition",props:{name:{type:String,required:!0,validator:t=>["appear","vert-fade","fade"].includes(t)}},setup(t){return(c,l)=>(e.openBlock(),e.createBlock(e.Transition,{name:t.name},{default:e.withCtx(()=>[e.renderSlot(c.$slots,"default",{},void 0,!0)]),_:3},8,["name"]))}},[["__scopeId","data-v-f6b1631e"]]);function pe(t,c){return e.getCurrentScope()?(e.onScopeDispose(t,c),!0):!1}const he=typeof window<"u"&&typeof document<"u";typeof WorkerGlobalScope<"u"&&globalThis instanceof WorkerGlobalScope;const ge=Object.prototype.toString,be=t=>ge.call(t)==="[object Object]",Y=()=>{};function U(t){return Array.isArray(t)?t:[t]}const ke=/[YMDHhms]o|\[([^\]]+)\]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a{1,2}|A{1,2}|m{1,2}|s{1,2}|Z{1,2}|z{1,4}|SSS/g;function ye(t,c,l,o){let a=t<12?"AM":"PM";return o&&(a=a.split("").reduce((n,u)=>n+=`${u}.`,"")),l?a.toLowerCase():a}function P(t){const c=["th","st","nd","rd"],l=t%100;return t+(c[(l-20)%10]||c[l]||c[0])}function X(t,c,l={}){var o;const a=t.getFullYear(),n=t.getMonth(),u=t.getDate(),i=t.getHours(),r=t.getMinutes(),s=t.getSeconds(),d=t.getMilliseconds(),f=t.getDay(),h=(o=l.customMeridiem)!==null&&o!==void 0?o:ye,y=B=>{var b;return(b=B.split(" ")[1])!==null&&b!==void 0?b:""},g={Yo:()=>P(a),YY:()=>String(a).slice(-2),YYYY:()=>a,M:()=>n+1,Mo:()=>P(n+1),MM:()=>`${n+1}`.padStart(2,"0"),MMM:()=>t.toLocaleDateString(e.toValue(l.locales),{month:"short"}),MMMM:()=>t.toLocaleDateString(e.toValue(l.locales),{month:"long"}),D:()=>String(u),Do:()=>P(u),DD:()=>`${u}`.padStart(2,"0"),H:()=>String(i),Ho:()=>P(i),HH:()=>`${i}`.padStart(2,"0"),h:()=>`${i%12||12}`.padStart(1,"0"),ho:()=>P(i%12||12),hh:()=>`${i%12||12}`.padStart(2,"0"),m:()=>String(r),mo:()=>P(r),mm:()=>`${r}`.padStart(2,"0"),s:()=>String(s),so:()=>P(s),ss:()=>`${s}`.padStart(2,"0"),SSS:()=>`${d}`.padStart(3,"0"),d:()=>f,dd:()=>t.toLocaleDateString(e.toValue(l.locales),{weekday:"narrow"}),ddd:()=>t.toLocaleDateString(e.toValue(l.locales),{weekday:"short"}),dddd:()=>t.toLocaleDateString(e.toValue(l.locales),{weekday:"long"}),A:()=>h(i,r),AA:()=>h(i,r,!1,!0),a:()=>h(i,r,!0),aa:()=>h(i,r,!0,!0),z:()=>y(t.toLocaleDateString(e.toValue(l.locales),{timeZoneName:"shortOffset"})),zz:()=>y(t.toLocaleDateString(e.toValue(l.locales),{timeZoneName:"shortOffset"})),zzz:()=>y(t.toLocaleDateString(e.toValue(l.locales),{timeZoneName:"shortOffset"})),zzzz:()=>y(t.toLocaleDateString(e.toValue(l.locales),{timeZoneName:"longOffset"}))};return c.replace(ke,(B,b)=>{var w,S;return(w=b??((S=g[B])===null||S===void 0?void 0:S.call(g)))!==null&&w!==void 0?w:B})}function xe(t,c,l){return e.watch(t,c,{...l,immediate:!0})}const G=he?window:void 0;function _(t){var c;const l=e.toValue(t);return(c=l?.$el)!==null&&c!==void 0?c:l}function q(...t){const c=[],l=()=>{c.forEach(i=>i()),c.length=0},o=(i,r,s,d)=>(i.addEventListener(r,s,d),()=>i.removeEventListener(r,s,d)),a=e.computed(()=>{const i=U(e.toValue(t[0])).filter(r=>r!=null);return i.every(r=>typeof r!="string")?i:void 0}),n=xe(()=>{var i,r;return[(i=(r=a.value)===null||r===void 0?void 0:r.map(s=>_(s)))!==null&&i!==void 0?i:[G].filter(s=>s!=null),U(e.toValue(a.value?t[1]:t[0])),U(e.unref(a.value?t[2]:t[1])),e.toValue(a.value?t[3]:t[2])]},([i,r,s,d])=>{if(l(),!i?.length||!r?.length||!s?.length)return;const f=be(d)?{...d}:d;c.push(...i.flatMap(h=>r.flatMap(y=>s.map(g=>o(h,y,g,f)))))},{flush:"post"}),u=()=>{n(),l()};return pe(l),u}function W(t,c,l={}){const{window:o=G,ignore:a=[],capture:n=!0,detectIframe:u=!1,controls:i=!1}=l;if(!o)return i?{stop:Y,cancel:Y,trigger:Y}:Y;let r=!0;const s=b=>e.toValue(a).some(w=>{if(typeof w=="string")return Array.from(o.document.querySelectorAll(w)).some(S=>S===b.target||b.composedPath().includes(S));{const S=_(w);return S&&(b.target===S||b.composedPath().includes(S))}});function d(b){const w=e.toValue(b);return w&&w.$.subTree.shapeFlag===16}function f(b,w){const S=e.toValue(b),D=S.$.subTree&&S.$.subTree.children;return D==null||!Array.isArray(D)?!1:D.some(z=>z.el===w.target||w.composedPath().includes(z.el))}const h=b=>{const w=_(t);if(b.target!=null&&!(!(w instanceof Element)&&d(t)&&f(t,b))&&!(!w||w===b.target||b.composedPath().includes(w))){if("detail"in b&&b.detail===0&&(r=!s(b)),!r){r=!0;return}c(b)}};let y=!1;const g=[q(o,"click",b=>{y||(y=!0,setTimeout(()=>{y=!1},0),h(b))},{passive:!0,capture:n}),q(o,"pointerdown",b=>{const w=_(t);r=!s(b)&&!!(w&&!b.composedPath().includes(w))},{passive:!0}),u&&q(o,"blur",b=>{setTimeout(()=>{var w;const S=_(t);((w=o.document.activeElement)===null||w===void 0?void 0:w.tagName)==="IFRAME"&&!S?.contains(o.document.activeElement)&&c(b)},0)},{passive:!0})].filter(Boolean),B=()=>g.forEach(b=>b());return i?{stop:B,cancel:()=>{r=!1},trigger:b=>{r=!0,h(b),r=!1}}:B}const we=["value","onKeydown"],Be={class:"flex absolute inset-y-0 right-0 items-center pr-3 text-vxvue-700"},Ve=["data-result-index"],ve=Object.assign({inheritAttrs:!1},{__name:"Autocomplete",props:e.mergeModels({search:{type:Function,required:!0},resultListClass:{type:String,default:"result-list"},resultItemClass:{type:String,default:"result-list-item"},getResultValue:{type:Function,default:t=>t},autoSelect:Boolean},{modelValue:{type:String,default:""},modelModifiers:{}}),emits:e.mergeModels(["blur-sm","submit"],["update:modelValue"]),setup(t,{emit:c}){const l=c,o=t,a=e.useModel(t,"modelValue"),n=e.useAttrs(),i=(()=>{let v=0;return C=>(C||"")+ ++v})()((n.id||"autocomplete")+"-"),r=e.ref([]),s=e.ref(-1),d=e.ref(0),f=e.ref(!1),h=e.ref(!1),y=e.ref("top-0 translate-y-12"),g=e.ref(!0),B=e.ref(null),b=e.ref(null),w=e.ref(null),S=e.computed(()=>r.value.map((v,C)=>({id:(n.id||"autocomplete")+"-item-"+C,class:[o.resultItemClass,{"bg-vxvue-700 text-white":s.value===C}],role:"option",...s.value===C?{"aria-selected":"true"}:{}}))),D=e.computed(()=>({role:"combobox",autocomplete:"off",autocapitalize:"off",autocorrect:"off",spellcheck:"false","aria-autocomplete":"list","aria-haspopup":"listbox","aria-owns":i,"aria-expanded":f.value?"true":"false","aria-activedescendant":s.value>-1?S.value[s.value].id:"",...n})),z=e.computed(()=>({id:i,class:["absolute min-w-full transform z-[var(--zIndex-dropdown)]",o.resultListClass,y.value],role:"listbox"})),M=()=>{s.value=-1,r.value=[],f.value=!1,g.value=!0},$=v=>{const C=o.search(v);if(C instanceof Promise){const A=++d.value;h.value=!0,C.then(T=>{A===d.value&&(r.value=T,h.value=!1,r.value.length?(s.value=o.autoSelect?0:-1,f.value=!0):M())})}else r.value=C,r.value.length===0?M():(s.value=o.autoSelect?0:-1,f.value=!0)},L=()=>{const v=r.value[s.value];return v&&(a.value=o.getResultValue(v)),M(),v},k=v=>{a.value=v,$(v)},m=v=>$(v.target.value),p=()=>{M(),l("blur-sm")},x=()=>{const v=r.value.length;s.value=((s.value-1)%v+v)%v},V=v=>{f.value||m(v);const C=r.value.length;s.value=((s.value+1)%C+C)%C},N=()=>{M(),a.value=""},F=()=>l("submit",L()),K=v=>{const C=v.target.closest("[data-result-index]");C&&(s.value=parseInt(C.dataset.resultIndex,10),l("submit",L()))};return W(w,M),e.onUpdated(()=>{if(B.value){const v=b.value.getBoundingClientRect(),C=B.value.getBoundingClientRect();g.value&&r.value.length&&(g.value=!1,y.value=v.bottom+C.height>window.innerHeight&&window.innerHeight-v.bottom<v.top&&window.pageYOffset+v.top-C.height>0?"bottom-0 -translate-y-12":"top-0 translate-y-12");const A=B.value.querySelector('[data-result-index="'+s.value+'"]');if(A){let T=A.getBoundingClientRect();T.top<C.top?B.value.scrollTop-=C.top-T.top:T.bottom>C.bottom&&(B.value.scrollTop+=T.bottom-C.bottom)}}}),(v,C)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"container",ref:w,class:e.normalizeClass(["inline-block relative",v.$attrs.class])},[e.createElementVNode("input",e.mergeProps({ref_key:"input",ref:b,class:"block pr-10 w-full form-input focus:border-vxvue",value:a.value},D.value,{onInput:C[0]||(C[0]=A=>k(A.target.value)),onKeydown:[e.withKeys(F,["enter"]),e.withKeys(N,["esc"]),e.withKeys(L,["tab"]),e.withKeys(e.withModifiers(x,["prevent"]),["up"]),e.withKeys(e.withModifiers(V,["prevent"]),["down"])],onFocus:m,onBlur:p}),null,16,we),e.createElementVNode("span",Be,[h.value?(e.openBlock(),e.createBlock(H,{key:0,class:"size-5"})):e.createCommentVNode("",!0)]),e.createVNode(O,{name:"fade"},{default:e.withCtx(()=>[r.value.length?(e.openBlock(),e.createElementBlock("div",e.mergeProps({key:0,ref_key:"resultList",ref:B},z.value,{onClick:K,onMousedown:C[1]||(C[1]=e.withModifiers(()=>{},["prevent"]))}),[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(r.value,(A,T)=>(e.openBlock(),e.createElementBlock("div",{"data-result-index":T},[e.renderSlot(v.$slots,"result",{result:A,props:S.value[T]},()=>[(e.openBlock(),e.createElementBlock("div",e.mergeProps({key:S.value[T].id},{ref_for:!0},S.value[T]),e.toDisplayString(t.getResultValue(A)),17))])],8,Ve))),256))],16)):e.createCommentVNode("",!0)]),_:3})],2))}}),Ee={key:0,class:"fixed inset-0 z-[calc(var(--zIndex-confirm)-1)] bg-black/50 backdrop-blur-xs","aria-hidden":"true"},Se={key:0,class:"overflow-y-auto fixed inset-0 z-[var(--zIndex-confirm)]"},Ce={class:"flex justify-center items-center min-h-screen text-center sm:block sm:p-0"},Ne={key:0},$e={class:"inline-block text-left align-bottom bg-white rounded-sm shadow-xl transition-all transform sm:my-8 sm:w-full sm:max-w-sm sm:align-middle lg:max-w-lg"},Me={class:"px-4 pb-4 mt-4 sm:px-6 sm:pb-6 sm:mt-5"},De={class:"flex flex-row items-center"},ze={class:"shrink-0"},Te={class:"text-center grow"},Ae=["onClick"],Le={__name:"Confirm",props:{buttons:{type:[Object,Array],default:()=>({label:"Ok"}),validator:t=>Array.isArray(t)&&t.length<=2&&t.filter(c=>c.label!=="undefined"&&c.value!=="undefined").length===t.length||t.label!==void 0&&t.value!==void 0},headerClass:{type:String,default:"text-vxvue-alt-900 bg-vxvue-alt-300"},buttonClass:{type:String,default:"button"}},setup(t,{expose:c}){const l=t,o=e.ref(""),a=e.ref(""),n=e.ref(!1);let u=null,i=null;const r=e.computed(()=>Array.isArray(l.buttons)?l.buttons:[l.buttons]),s=e.ref(null),d=(h,y)=>{n.value=!1,h.value!==void 0?h.value?u():i():y?i():u()};return c({open:(h,y)=>(o.value=h,a.value=y,n.value=!0,e.nextTick(()=>s.value.firstElementChild.focus()),new Promise((g,B)=>{u=g,i=B}))}),(h,y)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[n.value?(e.openBlock(),e.createElementBlock("div",Ee)):e.createCommentVNode("",!0),e.createVNode(O,{name:"appear"},{default:e.withCtx(()=>[n.value?(e.openBlock(),e.createElementBlock("div",Se,[e.createElementVNode("div",Ce,[n.value?(e.openBlock(),e.createElementBlock("div",Ne,[y[0]||(y[0]=e.createElementVNode("span",{class:"hidden sm:inline-block sm:h-screen sm:align-middle","aria-hidden":"true"},"",-1)),e.createElementVNode("div",$e,[o.value||h.$slots.title?(e.openBlock(),e.createElementBlock("h3",{key:0,class:e.normalizeClass(["py-4 pt-4 text-lg font-medium text-center rounded-t-sm sm:py-6",t.headerClass])},[e.renderSlot(h.$slots,"title",{title:o.value},()=>[e.createTextVNode(e.toDisplayString(o.value),1)])],2)):e.createCommentVNode("",!0),e.createElementVNode("div",Me,[e.createElementVNode("div",De,[e.createElementVNode("div",ze,[e.renderSlot(h.$slots,"icon")]),e.createElementVNode("p",Te,[e.renderSlot(h.$slots,"default",{message:a.value},()=>[e.createTextVNode(e.toDisplayString(a.value),1)])])]),e.createElementVNode("div",{ref_key:"buttonsContainer",ref:s,class:"flex justify-center mt-5 space-x-2 sm:mt-6"},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(r.value,(g,B)=>(e.openBlock(),e.createElementBlock("button",{key:g.label,class:e.normalizeClass([t.buttonClass,g.class]),onClick:e.withModifiers(b=>d(g,B),["prevent"])},e.toDisplayString(g.label),11,Ae))),128))],512)])])])):e.createCommentVNode("",!0)])])):e.createCommentVNode("",!0)]),_:3})],64))}};function Pe(t,c){const l=e.ref(!1),o=e.toValue(c);let a,n=o.toLowerCase().replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),u=[];if((a=o.match(/\bd\b/gi))&&a.length===1)n=n.replace("d","(\\d{1,2})");else if((a=o.match(/\bdd\b/gi))&&a.length===1)n=n.replace("dd","(\\d{2})");else return{date:l};if(u.push({srcPos:o.toLowerCase().indexOf("d"),destPos:2}),(a=o.match(/\bm\b/gi))&&a.length===1)n=n.replace("m","(\\d{1,2})");else if((a=o.match(/\bmm\b/gi))&&a.length===1)n=n.replace("mm","(\\d{2})");else return{date:l};if(u.push({srcPos:o.toLowerCase().indexOf("m"),destPos:1}),(a=o.match(/\byyyy\b/gi))&&a.length===1)n=n.replace("yyyy","(\\d{4})");else return{date:l};if(u.push({srcPos:o.toLowerCase().indexOf("y"),destPos:0}),!(a=e.toValue(t).match(n)))return{date:l};a.shift(),u.sort((d,f)=>d.srcPos<f.srcPos?-1:1);let i=[],r,s;for(;r=a.shift();)s=u.shift(),i[s.destPos]=r;return i=Date.parse(i.join("-")),i&&(i=new Date(i),l.value=new Date(i.getFullYear(),i.getMonth(),i.getDate(),0,0,0)),{date:l}}const Fe={class:"text-vxvue-700"},Ie=["disabled"],J=Object.assign({inheritAttrs:!1},{__name:"DateInput",props:e.mergeModels({outputFormat:{type:String,default:"YYYY-MM-DD"},inputFormat:{type:String,default:"YYYY-MM-DD"},showToggle:{type:Boolean,default:!1}},{modelValue:{type:Date,default:null},modelModifiers:{}}),emits:e.mergeModels(["toggle-datepicker"],["update:modelValue"]),setup(t,{emit:c}){const l=c,o=t,a=e.useModel(t,"modelValue"),n=e.ref(""),u=e.computed(()=>a.value?X(a.value,o.outputFormat):""),i=e.computed(()=>{let r=Object.assign({},e.useAttrs());return delete r.class,r});return e.watch(a,r=>n.value===r?X(r,o.outputFormat):""),(r,s)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["inline-block relative",r.$attrs.class])},[e.withDirectives(e.createElementVNode("div",null,[e.createElementVNode("div",{class:e.normalizeClass(["block flex items-center w-full form-input bg-vxvue-50",{"pr-10":t.showToggle}])},[e.createElementVNode("span",Fe,e.toDisplayString(u.value),1),i.value.disabled?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("button",{key:0,class:"inline-flex justify-center items-center ml-2 rounded-full focus:text-white shrink-0 size-4 text-vxvue hover:bg-vxvue-100 hover:text-vue-700 focus:outline-hidden focus:bg-vxvue-700",onClick:s[0]||(s[0]=d=>a.value=null)},[e.createVNode(e.unref(R),{class:"size-4"})]))],2)],512),[[e.vShow,u.value]]),e.withDirectives(e.createElementVNode("div",null,[e.withDirectives(e.createElementVNode("input",e.mergeProps({"onUpdate:modelValue":s[1]||(s[1]=d=>n.value=d),type:"text",class:["block w-full form-input peer focus:border-vxvue",{"pr-10":t.showToggle}]},i.value,{onBlur:s[2]||(s[2]=d=>a.value=e.unref(Pe)(n.value,o.inputFormat).date?.value||null),onInput:s[3]||(s[3]=e.withModifiers(()=>{},["prevent"]))}),null,16),[[e.vModelText,n.value]])],512),[[e.vShow,!u.value]]),t.showToggle?(e.openBlock(),e.createElementBlock("button",{key:0,ref:"toggleButton",class:e.normalizeClass(["flex absolute inset-y-0 right-0 items-center px-2 text-vxvue-700",i.value.disabled?"cursor-not-allowed":"hover:text-vxvue"]),disabled:i.value.disabled,"aria-label":"datepicker-toggle",onClick:s[4]||(s[4]=e.withModifiers(d=>l("toggle-datepicker"),["stop"]))},[e.createVNode(e.unref(te),{class:"size-6"})],10,Ie)):e.createCommentVNode("",!0),e.renderSlot(r.$slots,"default")],2))}}),Oe={class:"flex items-center py-2 px-3 text-white bg-vxvue-700"},_e={class:"flex justify-between w-1/2"},je={class:"flex justify-between w-1/2"},Ye={class:"grid grid-cols-7 gap-0.5 p-0.5"},Re=["disabled","onClick"],He={class:"flex justify-between items-center py-2 px-3 text-white bg-vxvue-700"},Ze={class:"grid grid-cols-2 gap-0.5 p-0.5"},Ue=["onClick"],qe=Object.assign({inheritAttrs:!1},{__name:"Datepicker",props:e.mergeModels({shownMonth:Date,maxNumberOfValues:{type:Number,default:1},validFrom:Date,validUntil:Date,dayNames:{type:Array,default:()=>"S M T W T F S".split(" ")},highlightRange:Boolean,locale:{type:String,default:"default"},startOfWeekIndex:{type:Number,default:0,validator:t=>t===0||t===1},hasInput:{type:Boolean,default:!0}},{modelValue:{type:[Date,Array],default:null,validator:(t,c)=>t instanceof Date&&c.maxNumberOfValues===1||t.every(l=>l instanceof Date||l===null)&&t.length<=c.maxNumberOfValues},modelModifiers:{}}),emits:e.mergeModels(["month-change","year-change"],["update:modelValue"]),setup(t,{emit:c}){const l=t,o=e.useModel(t,"modelValue"),a=c,n=(()=>{const k=new Date;return new Date(k.getFullYear(),k.getMonth(),k.getDate())})(),u=e.ref(null),i=e.ref([]),r=e.ref(!1),s=e.ref("days"),d=e.ref(0),f=e.ref({horiz:"left-0",vert:"top-0"}),h=e.ref(null),y=e.ref(null),g=e.ref(null),B=e.computed(()=>l.hasInput&&l.maxNumberOfValues===1),b=e.computed(()=>{const k=[],m=u.value.getFullYear(),p=u.value.getMonth(),x=new Date(m,p+1,0),V=new Date(m,p,0).getDay()+1-l.startOfWeekIndex,N=(6+l.startOfWeekIndex-x.getDay())%7;for(let F=-V,K=x.getDate()+N;F<K;++F)k.push(new Date(m,p,F+1));return k}),w=e.computed(()=>l.startOfWeekIndex?l.dayNames.slice(1).concat(l.dayNames[0]):l.dayNames),S=k=>{u.value=new Date(u.value.getFullYear(),k,1),a("month-change",u.value)},D=k=>{u.value=new Date(k,u.value.getMonth(),1),a("year-change",u.value)},z=k=>o.value=k,M=k=>{if(r.value=!1,l.maxNumberOfValues===1)o.value=k;else{const m=i.value;let p=m.findIndex(x=>x.getTime()===k.getTime());p!==-1?m.splice(p,1):m.length<l.maxNumberOfValues&&m.push(k),o.value=m}},$=k=>i.value.find(m=>m?.getTime()===k.getTime()),L=k=>{const m=k.getMonth()!==u.value.getMonth(),p=$(k),x=k.getTime()===n.getTime(),V=l.validFrom&&l.validFrom>k||l.validUntil&&l.validUntil<k,N=!p&&l.maxNumberOfValues>1&&i.value.length===l.maxNumberOfValues,F=l.highlightRange&&k>Math.min(...i.value)&&k<Math.max(...i.value);return{"cursor-not-allowed":V||N,"text-vxvue-700":!V&&!m&&!x&&!p,"text-error":V&&!m,"text-gray-400":m&&!x&&!p,"bg-vxvue-alt-300 font-bold":x&&!p,"bg-vxvue-700 text-white":p,"hover:ring-2 hover:ring-vxvue":!V,"bg-vxvue-100/50":F&&!x&&!p}};return W(y,()=>{r.value=!1,s.value="days"},{ignore:[g]}),e.onMounted(()=>g.value=h.value?.$refs.toggleButton),e.watch(r,k=>{k&&B.value&&e.nextTick(()=>{const m=h.value.$el.getBoundingClientRect(),p=y.value.getBoundingClientRect();f.value.horiz=m.right-p.width<0?"left-0":"right-0",f.value.vert=m.bottom+p.height>window.innerHeight?"bottom-0 -translate-y-12":"top-0 translate-y-12"})}),e.watch(o,k=>{if(k)if(Array.isArray(k)){const m=[],p=i.value;k.forEach(x=>{x&&m.push(new Date(x.getFullYear(),x.getMonth(),x.getDate()))}),(m.length!==p.length||![...new Set([...m,...p])].every(x=>m.filter(V=>V.getTime()===x.getTime()).length===p.filter(V=>V.getTime()===x.getTime()).length))&&(i.value=m,u.value=new Date((m[0]||n).getTime()),u.value.setDate(1))}else i.value=[new Date(k.getFullYear(),k.getMonth(),k.getDate())],u.value=new Date(k.getFullYear(),k.getMonth(),1);else i.value=[],u.value=new Date(n.getFullYear(),n.getMonth(),1)},{immediate:!0}),e.watch(()=>l.shownMonth,k=>{u.value=new Date((k||n).getTime()),u.value.setDate(1)},{immediate:!0}),(k,m)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["relative",k.$attrs.class])},[B.value?(e.openBlock(),e.createBlock(J,e.mergeProps({key:0},k.$attrs,{ref_key:"input",ref:h,"model-value":i.value[0],"show-toggle":!0,class:"w-full",onToggleDatepicker:m[0]||(m[0]=p=>r.value=!r.value),"onUpdate:modelValue":z}),{default:e.withCtx(()=>[e.renderSlot(k.$slots,"default")]),_:3},16,["model-value"])):e.createCommentVNode("",!0),e.createVNode(O,{name:"fade"},{default:e.withCtx(()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"calendar",ref:y,class:e.normalizeClass(["overflow-hidden z-[var(--zIndex-dropdown)] bg-white rounded-sm shadow-md min-w-72 sm:min-w-80",f.value.horiz,f.value.vert,{absolute:B.value}])},[s.value==="days"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createElementVNode("div",Oe,[e.createElementVNode("div",_e,[e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:m[1]||(m[1]=e.withModifiers(p=>S(u.value.getMonth()-1),["stop"]))},[e.createVNode(e.unref(j),{class:"size-6"})]),e.createElementVNode("span",null,e.toDisplayString(u.value.toLocaleString(t.locale,{month:"long"})),1),e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:m[2]||(m[2]=e.withModifiers(p=>S(u.value.getMonth()+1),["stop"]))},[e.createVNode(e.unref(I),{class:"size-6"})])]),e.createElementVNode("div",je,[e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:m[3]||(m[3]=e.withModifiers(p=>D(u.value.getFullYear()-1),["stop"]))},[e.createVNode(e.unref(j),{class:"size-6"})]),e.createElementVNode("button",{class:"text-vxvue-100 hover:text-vxvue-50",onClick:m[4]||(m[4]=p=>{s.value="years",d.value=u.value.getFullYear()})},e.toDisplayString(u.value.getFullYear()),1),e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:m[5]||(m[5]=e.withModifiers(p=>D(u.value.getFullYear()+1),["stop"]))},[e.createVNode(e.unref(I),{class:"size-6"})])])]),e.createElementVNode("div",Ye,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(w.value,(p,x)=>(e.openBlock(),e.createElementBlock("div",{key:x,class:"py-2 text-center bg-gray-200"},e.toDisplayString(p),1))),128)),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(b.value,p=>(e.openBlock(),e.createElementBlock("button",{key:p,class:e.normalizeClass(["py-2 rounded-xs block text-center",L(p)]),disabled:t.validFrom&&t.validFrom>p||t.validUntil&&t.validUntil<p||t.maxNumberOfValues>1&&i.value.length===t.maxNumberOfValues&&!$(p),onClick:e.withModifiers(x=>M(p),["stop"])},e.toDisplayString(p.getDate()),11,Re))),128))])],64)):e.createCommentVNode("",!0),s.value==="years"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createElementVNode("div",He,[e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:m[6]||(m[6]=e.withModifiers(p=>d.value-=10,["stop"]))},[e.createVNode(e.unref(j),{class:"size-6"})]),e.createElementVNode("span",null,e.toDisplayString(d.value)+" - "+e.toDisplayString(d.value+9),1),e.createElementVNode("button",{class:"shrink-0 text-vxvue-100 hover:text-vxvue-50",onClick:m[7]||(m[7]=e.withModifiers(p=>d.value+=10,["stop"]))},[e.createVNode(e.unref(I),{class:"size-6"})])]),e.createElementVNode("div",Ze,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(10,p=>e.createElementVNode("div",{key:p,class:"text-center hover:ring-2 text-vxvue-700 hover:ring-vxvue"},[e.createElementVNode("button",{class:"py-2 px-3",onClick:e.withModifiers(x=>{D(d.value+p-1),s.value="days"},["stop"])},e.toDisplayString(d.value+p-1),9,Ue)])),64))])],64)):e.createCommentVNode("",!0)],2),[[e.vShow,r.value]])]),_:1})],2))}}),We=["for"],Ke=["id","multiple","accept"],Xe={__name:"FormFileButton",props:e.mergeModels({accept:{type:String,default:"*"},multiple:{type:Boolean,default:!1},name:{type:String,default:"file"},id:{type:String,default:"form-file-button-"+Math.ceil(Math.random()*1e3)}},{modelValue:{type:Array,default:()=>[]},modelModifiers:{}}),emits:e.mergeModels(["form-data"],["update:modelValue"]),setup(t,{emit:c}){const l=c,o=t,a=e.useModel(t,"modelValue"),n=i=>{const r=new FormData;for(let s of i)r.append(o.name,s,s.name);return r},u=i=>{const r=i.target.files||i.dataTransfer.files;if(r){const s=Array.from(r);a.value=s,l("form-data",n(s))}};return(i,r)=>(e.openBlock(),e.createElementBlock("label",{for:t.id},[e.renderSlot(i.$slots,"default",{},()=>[r[0]||(r[0]=e.createTextVNode("Upload",-1))]),e.createElementVNode("input",{id:t.id,type:"file",multiple:t.multiple,accept:t.accept,class:"hidden",onChange:u},null,40,Ke)],8,We))}},Ge={key:0,value:null,disabled:"",hidden:""},Je=["selected","value"],Q={__name:"FormSelect",props:e.mergeModels({options:{type:Array,default:()=>[]},placeholder:{type:String,default:null}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(t){const c=e.useModel(t,"modelValue");return(l,o)=>e.withDirectives((e.openBlock(),e.createElementBlock("select",e.mergeProps(l.$attrs,{"onUpdate:modelValue":o[0]||(o[0]=a=>c.value=a),class:"form-select"}),[t.placeholder?(e.openBlock(),e.createElementBlock("option",Ge,e.toDisplayString(t.placeholder),1)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,a=>(e.openBlock(),e.createElementBlock("option",{key:a.key!==void 0?a.key:a.label||a,selected:(a.key!==void 0?a.key:a.label||a)===c.value,value:a.key!==void 0?a.key:a.label||a},e.toDisplayString(a.label||a),9,Je))),128))],16)),[[e.vModelSelect,c.value]])}},Qe=["aria-checked","aria-label"],et=["d"],tt={__name:"FormSwitch",props:{modelValue:{},modelModifiers:{}},emits:["update:modelValue"],setup(t){const c=e.useModel(t,"modelValue"),l=e.computed(()=>{let a=Object.assign({},e.useAttrs());return delete a.class,a}),o=e.computed(()=>e.useAttrs().disabled||e.useAttrs().disabled==="");return(a,n)=>(e.openBlock(),e.createElementBlock("label",{class:e.normalizeClass(a.$attrs.class),tabindex:"0"},[e.createElementVNode("span",{role:"switch",class:e.normalizeClass(["inline-flex relative shrink-0 w-11 p-[2px] rounded-full transition-colors duration-200 ease-in-out cursor-pointer focus:ring-2 focus:ring-offset-2 focus:outline-hidden focus:ring-vxvue",o.value?"bg-slate-200":c.value?"bg-vxvue":"bg-slate-300"]),"aria-checked":c.value,"aria-label":a.$attrs["aria-label"]},[e.createElementVNode("span",{"aria-hidden":"true",class:e.normalizeClass(["block relative size-5 rounded-full transition duration-200 ease-in-out transform pointer-events-none",c.value?"translate-x-5":"translate-x-0",o.value?"bg-slate-100":"bg-white"])},[e.renderSlot(a.$slots,"handle",{},()=>[(e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"6",stroke:"currentColor",class:e.normalizeClass(["absolute top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2 size-3",c.value&&!o.value?"text-vxvue":"text-slate-300"])},[e.createElementVNode("path",{"stroke-linecap":"round",d:c.value?"M12 18 V6":"m18.5 12 c0 3.5 -3 6.5 -6.5 6.5 -3.5 0 -6.5 -3 -6.5 -6.5 0 -3.5 3 -6.5 6.5 -6.5 3.5 0 6.5 3 6.5 6.5z"},null,8,et)],2))])],2),e.withDirectives(e.createElementVNode("input",e.mergeProps({"onUpdate:modelValue":n[0]||(n[0]=u=>c.value=u)},l.value,{class:"hidden",value:"1",type:"checkbox"}),null,16),[[e.vModelCheckbox,c.value]])],10,Qe),e.renderSlot(a.$slots,"default")],2))}},lt={"aria-live":"assertive",class:"flex fixed inset-0 items-start py-6 px-4 pointer-events-none sm:p-6 z-[var(--zIndex-toast)]"},at={class:"flex flex-col items-center space-y-4 w-full"},ot={class:"p-4"},nt={class:"flex items-start"},rt={class:"shrink-0"},st={class:"flex-1 pt-0.5 ml-3 w-0"},it={class:"font-bold"},ct={class:"mt-1"},dt={class:"flex ml-4 shrink-0"},ut=Object.assign({inheritAttrs:!1},{__name:"MessageToast",props:{title:{type:String,default:""},message:{type:[String,Array],default:null},timeout:{type:Number,default:5e3},active:{type:Boolean,default:!1},showTimeoutProgress:{type:Boolean,default:!1}},emits:["timeout","close"],setup(t,{emit:c}){const l=t,o=c,a=e.computed(()=>typeof l.message=="string"?[l.message]:l.message),n=e.ref(0);let u=null;const i=()=>{window.clearTimeout(u),n.value=100,l.active&&l.timeout&&(u=window.setTimeout(()=>{o("timeout")},l.timeout),window.setTimeout(()=>n.value=0,0))};return e.watch(()=>l.active,i),e.onMounted(i),(r,s)=>(e.openBlock(),e.createElementBlock("div",lt,[e.createElementVNode("div",at,[e.createVNode(O,{name:"vert-fade"},{default:e.withCtx(()=>[t.active?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["overflow-hidden w-full max-w-sm rounded-md ring-1 shadow-lg pointer-events-auto ring-black/5",r.$attrs.class])},[e.createElementVNode("div",ot,[e.createElementVNode("div",nt,[e.createElementVNode("div",rt,[e.renderSlot(r.$slots,"icon")]),e.createElementVNode("div",st,[e.renderSlot(r.$slots,"title",{},()=>[e.createElementVNode("div",it,e.toDisplayString(t.title),1)]),e.renderSlot(r.$slots,"default",{},()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(a.value,d=>(e.openBlock(),e.createElementBlock("p",ct,e.toDisplayString(d),1))),256))])]),e.createElementVNode("div",dt,[e.createElementVNode("button",{class:"inline-flex text-white focus:ring-2 bg-black/20 rounded-xs hover:text-stone-200 focus:outline-hidden focus:ring-stone-200",onClick:s[0]||(s[0]=d=>o("close"))},[s[1]||(s[1]=e.createElementVNode("span",{class:"sr-only"},"Close",-1)),e.createVNode(e.unref(R),{class:"size-5"})])])])]),t.showTimeoutProgress&&t.timeout?(e.openBlock(),e.createElementBlock("div",{key:0,class:"h-1 transition-all ease-linear bg-vxvue-alt",style:e.normalizeStyle({width:n.value+"%","transition-duration":t.timeout+"ms"}),role:"progressbar","aria-hidden":"false","aria-label":"notification timer"},null,4)):e.createCommentVNode("",!0)],2)):e.createCommentVNode("",!0)]),_:3})])]))}}),mt={key:0,class:"fixed inset-0 z-[calc(var(--zIndex-modal)-1)] bg-white/50 backdrop-blur-xs","aria-hidden":"true"},ft={key:0,class:"fixed inset-0 z-[var(--zIndex-modal)]"},pt={class:"flex justify-center items-center h-screen"},ht={__name:"Modal",props:{show:Boolean,containerClass:{type:String,default:"mx-4 w-full lg:w-1/2 xl:w-1/4 max-h-[90vh]"},headerClass:{type:String,default:""},contentClass:{type:String,default:""}},emits:["clicked-outside"],setup(t,{emit:c}){const l=c,o=e.ref(null);return W(o,()=>l("clicked-outside")),(a,n)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[t.show?(e.openBlock(),e.createElementBlock("div",mt)):e.createCommentVNode("",!0),e.createVNode(O,{name:"appear"},{default:e.withCtx(()=>[t.show?(e.openBlock(),e.createElementBlock("div",ft,[e.createElementVNode("div",pt,[e.createElementVNode("div",{ref_key:"container",ref:o,class:e.normalizeClass(["flex flex-col overflow-hidden max-w-full bg-white rounded-sm ring-1 ring-black/10 shadow-xl transition-all transform xl:max-w-(--breakpoint-xl)",t.containerClass])},[e.createElementVNode("div",{class:e.normalizeClass(["grow-0",t.headerClass])},[e.renderSlot(a.$slots,"title")],2),e.createElementVNode("div",{class:e.normalizeClass(["overflow-y-auto h-full",t.contentClass])},[e.renderSlot(a.$slots,"default")],2)],2)])])):e.createCommentVNode("",!0)]),_:3})],64))}},gt={class:"flex justify-between items-center px-4 sm:px-0"},bt={class:"flex flex-1 -mt-px w-0"},kt=["disabled"],yt={class:"hidden md:flex md:-mt-px"},xt={class:"flex flex-1 justify-end -mt-px w-0"},wt=["disabled"],Bt={__name:"Pagination",props:{page:{type:Number,default:1},total:{type:Number,default:1},perPage:{type:Number,default:20,validator:t=>t>=1},showNavButtons:{type:Boolean,default:!0},prevText:{type:String,default:"Previous"},nextText:{type:String,default:"Next"},showAllPages:{type:Boolean,default:!1},markerPosition:{type:String,default:"above",validator:t=>["above","below"].includes(t)}},emits:["update:page"],setup(t,{emit:c}){const l=c,o=t,a=e.ref(Math.ceil(o.total/o.perPage)),n=e.ref(null),u=e.computed(()=>(o.markerPosition==="above"?"border-t-4 -mt-[4px]":"border-b-4 -mb-[4px]")+" py-4"),i=e.computed(()=>{let d=[1];if(o.showAllPages||a.value<=7){for(let f=2;f<=a.value;++f)d.push(f);return d}return n.value>=a.value?d.push("dots",n.value-2,n.value-1):n.value-1&&n.value-1>1&&(n.value>1&&d.push("dots"),d.push(n.value-1)),n.value>1&&d.push(n.value),n.value+1<a.value&&(d.push(n.value+1),n.value<=1&&d.push(n.value+2),n.value+2<a.value&&d.push("dots")),n.value<a.value&&d.push(a.value),d}),r=()=>{n.value>1&&l("update:page",n.value-1)},s=()=>{n.value<a.value&&l("update:page",n.value+1)};return e.watch(()=>o.page,d=>n.value=Math.min(Math.max(d,1),a.value),{immediate:!0}),e.watch(()=>o.perPage,d=>{a.value=Math.ceil(o.total/o.perPage),l("update:page",1)}),e.watch(()=>o.total,d=>{a.value=Math.ceil(o.total/o.perPage),n.value>a.value&&l("update:page",a.value)}),(d,f)=>(e.openBlock(),e.createElementBlock("nav",gt,[e.createElementVNode("div",bt,[t.showNavButtons?(e.openBlock(),e.createElementBlock("button",{key:0,disabled:n.value<=1,class:e.normalizeClass([n.value<=1?"pointer-events-none text-gray-500":"text-vxvue-700","inline-flex items-center pr-1 text-sm border-transparent hover:text-vxvue"]),onClick:r},[e.createVNode(e.unref(j),{class:"size-5"}),e.createTextVNode(" "+e.toDisplayString(t.prevText),1)],10,kt)):e.createCommentVNode("",!0)]),e.createElementVNode("div",yt,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.value,(h,y)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(t.page!=="dots"?"button":"span"),{key:y,class:e.normalizeClass([{"pointer-events-none":h==="dots"},h===n.value?"border-vxvue text-vxvue font-bold":"border-transparent text-gray-500 hover:border-gray-300",u.value,"inline-flex items-center px-4 text-sm"]),onClick:g=>h!=="dots"?l("update:page",h):null},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(h!=="dots"?h:"…"),1)]),_:2},1032,["class","onClick"]))),128))]),e.createElementVNode("div",xt,[t.showNavButtons?(e.openBlock(),e.createElementBlock("button",{key:0,disabled:n.value>=a.value,class:e.normalizeClass([n.value>=a.value?"pointer-events-none text-gray-500":"text-vxvue-700","inline-flex items-center pr-1 text-sm border-transparent hover:text-vxvue"]),onClick:s},[e.createTextVNode(e.toDisplayString(t.nextText)+" ",1),e.createVNode(e.unref(I),{class:"size-5"})],10,wt)):e.createCommentVNode("",!0)])]))}};function Vt(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M3.98 8.223A10.477 10.477 0 0 0 1.934 12C3.226 16.338 7.244 19.5 12 19.5c.993 0 1.953-.138 2.863-.395M6.228 6.228A10.451 10.451 0 0 1 12 4.5c4.756 0 8.773 3.162 10.065 7.498a10.522 10.522 0 0 1-4.293 5.774M6.228 6.228 3 3m3.228 3.228 3.65 3.65m7.894 7.894L21 21m-3.228-3.228-3.65-3.65m0 0a3 3 0 1 0-4.243-4.243m4.242 4.242L9.88 9.88"})])}function vt(t,c){return e.openBlock(),e.createElementBlock("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"currentColor","aria-hidden":"true","data-slot":"icon"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M2.036 12.322a1.012 1.012 0 0 1 0-.639C3.423 7.51 7.36 4.5 12 4.5c4.638 0 8.573 3.007 9.963 7.178.07.207.07.431 0 .639C20.577 16.49 16.64 19.5 12 19.5c-4.638 0-8.573-3.007-9.963-7.178Z"}),e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M15 12a3 3 0 1 1-6 0 3 3 0 0 1 6 0Z"})])}const Et=["type"],St=["disabled"],Ct=Object.assign({inheritAttrs:!1},{__name:"PasswordInput",props:{modelValue:{},modelModifiers:{}},emits:["update:modelValue"],setup(t){const c=e.useModel(t,"modelValue"),l=e.ref(!1),o=e.computed(()=>{let a=Object.assign({},e.useAttrs());return delete a.class,a});return(a,n)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass("inline-block relative "+e.useAttrs().class)},[e.withDirectives(e.createElementVNode("input",e.mergeProps({"onUpdate:modelValue":n[0]||(n[0]=u=>c.value=u),type:l.value?"text":"password"},o.value,{class:"block pr-12 w-full form-input peer"}),null,16,Et),[[e.vModelDynamic,c.value]]),e.createElementVNode("button",{class:"flex absolute inset-y-0 right-0 items-center px-3 text-brand-700 hover:text-brand","aria-label":"show-password-toggle",disabled:e.useAttrs().disabled??!1,onClick:n[1]||(n[1]=e.withModifiers(u=>l.value=!l.value,["stop"]))},[l.value?(e.openBlock(),e.createBlock(e.unref(Vt),{key:0,class:"size-5"})):(e.openBlock(),e.createBlock(e.unref(vt),{key:1,class:"size-5"}))],8,St)],2))}}),Nt={class:"flex items-center pb-1"},$t={key:0,class:"ml-6"},Mt=Object.assign({inheritAttrs:!1},{__name:"SimpleTree",props:e.mergeModels({branch:{type:Object,default:()=>({})}},{modelValue:{type:Object,default:null},modelModifiers:{}}),emits:e.mergeModels(["expand"],["update:modelValue"]),setup(t,{emit:c}){const l=t,o=c,a=e.useModel(t,"modelValue"),n=e.ref(!1);return e.onMounted(()=>{l.branch===a.value&&o("expand",!0)}),(u,i)=>{const r=e.resolveComponent("simple-tree",!0);return e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([!t.branch.branches||!t.branch.branches.length?"terminates":"",u.$attrs.class])},[e.createElementVNode("div",Nt,[t.branch.branches&&t.branch.branches.length?(e.openBlock(),e.createElementBlock("button",{key:0,class:"mr-2",onClick:i[0]||(i[0]=s=>n.value=!n.value)},[e.renderSlot(u.$slots,"toggle",{branch:t.branch,expanded:n.value},()=>[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(n.value?e.unref(ne):e.unref(re)),{class:"p-0.5 text-white rounded size-5 bg-vxvue-700 hover:bg-vxvue"}))])])):e.createCommentVNode("",!0),t.branch===a.value?e.renderSlot(u.$slots,"label-selected",{key:1,branch:t.branch},()=>[e.createElementVNode("strong",null,e.toDisplayString(t.branch.label),1)]):(e.openBlock(),e.createElementBlock("button",{key:2,onClick:i[1]||(i[1]=s=>a.value=t.branch)},[e.renderSlot(u.$slots,"label",{branch:t.branch},()=>[e.createTextVNode(e.toDisplayString(t.branch.label),1)])]))]),t.branch.branches&&t.branch.branches.length?e.withDirectives((e.openBlock(),e.createElementBlock("div",$t,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.branch.branches,s=>(e.openBlock(),e.createBlock(r,{key:s.id||s.key||null,branch:s,modelValue:a.value,"onUpdate:modelValue":i[2]||(i[2]=d=>a.value=d),onExpand:i[3]||(i[3]=d=>{n.value=d,o("expand",d)})},e.createSlots({_:2},[e.renderList(u.$slots,(d,f)=>({name:f,fn:e.withCtx(h=>[e.renderSlot(u.$slots,f,e.mergeProps({ref_for:!0},h))])}))]),1032,["branch","modelValue"]))),128))],512)),[[e.vShow,n.value]]):e.createCommentVNode("",!0)],2)}}}),Dt={__name:"Sizable",props:{vertical:Boolean},emits:["dragStart","dragStop"],setup(t,{emit:c}){const l=t,o=c,a=e.ref(null),n=e.ref(null);let u=!1,i={},r=null,s=null,d=null;const f=g=>{if(u){g.preventDefault();const{pageX:B,pageY:b}=g.touches?.[0]??g;l.vertical?a.value.style.height=Math.min(s.height-d.height-(r.y-s.y),Math.max(0,r.height+b-i.y))+"px":a.value.style.width=Math.min(s.width-d.width-(r.x-s.x),Math.max(0,r.width+B-i.x))+"px"}},h=g=>{g.preventDefault(),g.currentTarget.focus(),u=!0;const{pageX:B,pageY:b}=g.touches?.[0]??g;i={x:B,y:b},d=n.value.getBoundingClientRect(),r=a.value.getBoundingClientRect(),s=a.value.parentElement.getBoundingClientRect(),g.type==="mousedown"?(document.addEventListener("mousemove",f),document.addEventListener("mouseup",y)):(document.addEventListener("touchmove",f),document.addEventListener("touchend",y)),o("dragStart")},y=g=>{u&&(u=!1,g.type==="mouseup"?(document.removeEventListener("mousemove",f),document.removeEventListener("mouseup",y)):(document.removeEventListener("touchmove",f),document.removeEventListener("touchend",y)),setTimeout(()=>o("dragStop"),0))};return(g,B)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"box",ref:a,class:"relative"},[e.renderSlot(g.$slots,"default"),e.createElementVNode("div",e.mergeProps({ref_key:"handle",ref:n,class:["absolute flex",l.vertical?"inset-x-0 top-full justify-center py-1 cursor-ns-resize":"inset-y-0 left-full items-center px-1 cursor-ew-resize"]},e.toHandlers({touchstart:h,mousedown:h,touchend:y,mouseup:y},!0)),[e.renderSlot(g.$slots,"handle",{},()=>[e.createElementVNode("div",{class:e.normalizeClass(["rounded-full bg-vxvue",l.vertical?"h-1.5 w-8":"h-8 w-1.5"])},null,2)])],16)],512))}},zt=["aria-valuemin","aria-valuemax","aria-valuenow","aria-valuetext"],Tt=["id"],At=["id","aria-label"],Lt=Z(Object.assign({inheritAttrs:!1},{__name:"Slider",props:e.mergeModels({min:{type:Number,default:0},max:{type:Number,default:100},vertical:Boolean,disabled:Boolean,showTooltip:{type:String,default:"never",validator:t=>["always","focus","never"].includes(t)},formatTooltip:{type:Function,default:t=>String(t)}},{modelValue:{type:[Number,Array],default:null,validator(t){return typeof t=="number"||t.every(c=>typeof c=="number")}},modelModifiers:{}}),emits:e.mergeModels(["dragStart","dragStop"],["update:modelValue"]),setup(t,{emit:c}){const l=t,o=e.useModel(t,"modelValue"),a=c,n=e.useAttrs(),u={x:null,y:null},i={w:null,h:null};let r=!1;const s=e.ref(null),d=e.ref(0),f=e.ref({class:(l.vertical?"left-0 -translate-x-1.5 translate-y-2.5":"top-0 -translate-x-2.5 -translate-y-1.5")+" group touch-none absolute size-5 rounded-full border-2 bg-white transition-colors duration-200 "+(l.disabled?"":" focus:ring-4 focus:outline-hidden border-vxvue cursor-grab hover:bg-vxvue focus:ring-vxvue/50"),tabindex:0}),h=e.ref(null),y=e.ref(null),g=e.computed(()=>{const m=l.max,p=l.min;return o.value instanceof Array?o.value.map(x=>(Math.max(Math.min(x,m),p)-p)*100/(m-p)):(Math.max(Math.min(o.value,m),p)-p)*100/(m-p)}),B=e.computed(()=>{if(o.value instanceof Array){const m=Math.min(...g.value)+"%",p=Math.max(...g.value)-Math.min(...g.value)+"%";return l.vertical?{bottom:m,height:p}:{left:m,width:p}}return l.vertical?{bottom:0,height:g.value+"%"}:{width:g.value+"%"}}),b=m=>{if(l.showTooltip!=="never"&&h.value){let p=(y.value.length?y.value[0]:y.value).getBoundingClientRect()[l.vertical?"left":"top"],x=0;h.value.length?h.value.forEach(N=>x=Math.max(N.getBoundingClientRect()[l.vertical?"width":"height"],x)):x=h.value.getBoundingClientRect()[l.vertical?"height":"width"];let V="tooltip "+(l.showTooltip==="focus"?"tooltip-focused ":"");l.vertical?V+=p<x+10?"tooltip-right":"tooltip-left":V+=p<x+10?"tooltip-bottom":"tooltip-top",o.value.length?h.value.forEach(N=>N.className=V):h.value.className=V}},w=m=>{let p=parseFloat(m.toFixed(10));p=Math.min(l.max,Math.max(l.min,p)),o.value instanceof Array?o.value[d.value]=p:o.value=p},S=m=>{const{pageX:p,pageY:x}=m.touches?m.touches[0]:m,V=l.vertical?(-x+u.y)/i.h:(p-u.x)/i.w;w(Math.floor((l.max-l.min)*V+l.min))},D=()=>{const{clientLeft:m,clientTop:p,scrollLeft:x,scrollTop:V}=document.documentElement,N=s.value.getBoundingClientRect();u.x=N.left+x-m,u.y=N.bottom+V-p,i.w=s.value.offsetWidth,i.h=s.value.offsetHeight},z=m=>{r&&(m.preventDefault(),S(m))},M=m=>{m.preventDefault(),m.currentTarget.focus(),D(),r=!0,m.type==="mousedown"?(document.addEventListener("mousemove",z),document.addEventListener("mouseup",$)):(document.addEventListener("touchmove",z),document.addEventListener("touchend",$)),a("dragStart")},$=m=>{r&&(r=!1,m.type==="mouseup"?(document.removeEventListener("mousemove",z),document.removeEventListener("mouseup",$)):(document.removeEventListener("touchmove",z),document.removeEventListener("touchend",$)),setTimeout(()=>a("dragStop"),0))},L=m=>{m.keyCode>=33&&m.keyCode<=40&&m.preventDefault();const p=o.value[d.value]??o.value;switch(m.keyCode){case 37:case 40:w(p-1);break;case 39:case 38:w(p+1);break;case 33:w(p+(l.max-l.min)/10);break;case 34:w(p-(l.max-l.min)/10);break;case 36:w(l.min);break;case 35:w(l.max)}},k=m=>{D(),S(m)};return e.onUpdated(b),e.onMounted(b),(m,p)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({ref_key:"track",ref:s,class:["relative bg-slate-300",t.vertical?"h-full w-2 rounded-t-full rounded-b-full":"w-full h-2 rounded-r-full rounded-l-full"],role:"slider","aria-label":"slider-thumb","aria-valuemin":t.min,"aria-valuemax":t.max,"aria-valuenow":o.value[0]??o.value,"aria-valuetext":o.value},e.toHandlers(t.disabled?{}:{click:k},!0)),[t.disabled?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["absolute bg-vxvue",t.vertical?"w-full rounded-t-full rounded-b-full":"h-full rounded-r-full rounded-l-full"]),style:e.normalizeStyle(B.value)},null,6)),o.value.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:2},e.renderList(o.value,(x,V)=>(e.openBlock(),e.createElementBlock("button",e.mergeProps({id:V?null:e.unref(n).id,style:t.vertical?{bottom:g.value[V]+"%"}:{left:g.value[V]+"%"},"aria-label":"slider-thumb-"+(V+1)},{ref_for:!0},f.value,e.toHandlers(t.disabled?{}:{focus:()=>d.value=V,keydown:L,touchstart:N=>{d.value=V,M(N)},mousedown:N=>{d.value=V,M(N)},touchend:$,mouseup:$},!0),{ref_for:!0,ref_key:"handle",ref:y}),[t.showTooltip!=="never"?(e.openBlock(),e.createElementBlock("span",{key:0,class:e.normalizeClass(["tooltip",{"tooltip-focused":t.showTooltip==="focus"},t.vertical?"tooltip-left":"tooltip-top"]),ref_for:!0,ref_key:"tooltip",ref:h},[e.renderSlot(m.$slots,"tooltip",{value:x,ndx:V},()=>[e.createTextVNode(e.toDisplayString(t.formatTooltip(x)),1)],!0)],2)):e.createCommentVNode("",!0)],16,At))),256)):(e.openBlock(),e.createElementBlock("button",e.mergeProps({key:1,id:e.unref(n).id,style:t.vertical?{bottom:g.value+"%"}:{left:g.value+"%"},"aria-label":"slider-thumb"},f.value,e.toHandlers(t.disabled?{}:{focus:()=>d.value=0,keydown:L,touchstart:x=>{d.value=0,M(x)},mousedown:x=>{d.value=0,M(x)},touchend:$,mouseup:$},!0),{ref_key:"handle",ref:y}),[t.showTooltip!=="never"?(e.openBlock(),e.createElementBlock("span",{key:0,class:e.normalizeClass(["tooltip",{"tooltip-focused":t.showTooltip==="focus"},t.vertical?"tooltip-left":"tooltip-top"]),ref_key:"tooltip",ref:h},[e.renderSlot(m.$slots,"tooltip",{value:o.value},()=>[e.createTextVNode(e.toDisplayString(t.formatTooltip(o.value)),1)],!0)],2)):e.createCommentVNode("",!0)],16,Tt))],16,zt))}}),[["__scopeId","data-v-995282a3"]]),Pt=["data-active","onClick"],Ft={class:"flex items-center space-x-1"},It=["data-active"],Ot={__name:"Sortable",props:{columns:{type:Array,required:!0,validator:t=>{for(const c of t)if(c.label===void 0||c.prop===void 0)return!1;return!0}},rows:{type:Array,required:!0},offset:{type:Number,default:null},count:{type:Number,default:null},sortProp:{type:String,default:null},sortDirection:{type:String,default:null,validator:t=>!t||["asc","desc"].includes(t)},keyProperty:{type:String,default:"key"},headerClass:{type:String,default:"text-white bg-vxvue-700 [&_*[data-active]]:bg-vxvue-alt-800"},bodyClass:{type:String,default:"[&>*:nth-child(even)]:bg-vxvue-50 [&>*:nth-child(even)_*[data-active]]:bg-vxvue-alt-100 [&>*:nth-child(odd)_*[data-active]]:bg-vxvue-alt-50"}},emits:["before-sort","after-sort"],setup(t,{emit:c}){const l=t,o=c,a=e.ref(l.sortProp),n=e.ref(l.sortDirection),u=e.computed(()=>{let r=l.rows.slice();const s=l.columns.find(({prop:d})=>d===a.value);return s&&(n.value==="asc"&&s.sortAscFunction?r.sort(s.sortAscFunction):n.value==="desc"&&s.sortDescFunction?r.sort(s.sortDescFunction):r.sort((d,f)=>d[a.value]<f[a.value]?n.value==="asc"?-1:1:d[a.value]>f[a.value]?n.value==="asc"?1:-1:0)),r.slice(l.offset||0,(l.offset||0)+(l.count||r.length))}),i=r=>{o("before-sort",{prop:a.value,dir:n.value}),a.value===r?n.value=n.value==="asc"?"desc":"asc":(a.value=r,n.value=n.value||"asc"),e.nextTick(()=>o("after-sort",{prop:a.value,dir:n.value}))};return(r,s)=>(e.openBlock(),e.createElementBlock("table",{class:e.normalizeClass(r.$attrs.class||"w-full divide-y divide-y-slate-900 table-fixed")},[e.createElementVNode("thead",{class:e.normalizeClass(t.headerClass)},[e.createElementVNode("tr",null,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.columns,d=>(e.openBlock(),e.createElementBlock("th",{key:d.prop,scope:"col","data-active":a.value===d.prop?"active":null,class:e.normalizeClass(["py-3 px-6 text-left",{"cursor-pointer":d.sortable},d.cssClass]),onClick:f=>d.sortable?i(d.prop):null},[e.renderSlot(r.$slots,d.prop+"-header",{column:d,sortDir:n.value,sortProp:a.value},()=>[e.createElementVNode("div",Ft,[e.createElementVNode("span",null,e.toDisplayString(d.label),1),d.sortable?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(a.value!==d.prop?e.unref(ae):n.value==="asc"?e.unref(le):e.unref(oe)),{key:0,class:"size-4"})):e.createCommentVNode("",!0)])])],10,Pt))),128))])],2),e.createElementVNode("tbody",{class:e.normalizeClass(t.bodyClass)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(u.value,d=>(e.openBlock(),e.createElementBlock("tr",{key:d[t.keyProperty],class:e.normalizeClass(d.cssClass)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.columns,f=>(e.openBlock(),e.createElementBlock("td",{key:f.prop,"data-active":a.value===f.prop?"active":null,class:"overflow-hidden py-3 px-6 whitespace-nowrap text-ellipsis"},[e.renderSlot(r.$slots,f.prop,{row:d},()=>[e.createTextVNode(e.toDisplayString(d[f.prop]),1)])],8,It))),128))],2))),128))],2)],2))}},_t={class:"flex items-center space-x-2"},jt=["disabled"],Yt=Z(Object.assign({inheritAttrs:!1},{__name:"SubmitButton",props:{busy:Boolean,spinnerClass:{type:String,default:null},theme:{type:String,default:null}},emits:["submit"],setup(t,{emit:c}){const l=c;return(o,a)=>(e.openBlock(),e.createElementBlock("div",_t,[e.createElementVNode("button",{class:e.normalizeClass([o.$attrs.class,t.theme]),disabled:o.$attrs.disabled||t.busy,type:"button",onClick:a[0]||(a[0]=n=>l("submit"))},[e.renderSlot(o.$slots,"default",{},void 0,!0)],10,jt),t.busy?(e.openBlock(),e.createBlock(H,{key:0,class:e.normalizeClass(t.spinnerClass||["size-5",{error:"text-error",success:"text-success",default:"text-vxvue"}[t.theme||"default"]])},null,8,["class"])):e.createCommentVNode("",!0)]))}}),[["__scopeId","data-v-646b7a90"]]),Rt={class:"sm:hidden"},Ht={class:"hidden sm:block"},Zt={class:"border-b border-gray-200"},Ut={class:"flex -mb-px space-x-8","aria-label":"Tabs"},qt=["aria-current","onClick"],Wt={__name:"Tabs",props:{items:{type:Array,default:()=>[]},activeIndex:{type:Number,default:0}},emits:["update:activeIndex"],setup(t,{emit:c}){const l=t,o=c,a=e.ref(l.items[l.activeIndex]||{}),n=e.computed(()=>{let i=[];return l.items.forEach((r,s)=>{r.disabled||i.push({label:r.name,key:s})}),i});e.watch(()=>l.activeIndex,i=>{a.value=l.items[i]||{}});const u=i=>{i.disabled||(a.value=i,o("update:activeIndex",l.items.indexOf(i)))};return(i,r)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",Rt,[e.createVNode(Q,{options:n.value,"model-value":t.activeIndex,class:"w-full","onUpdate:modelValue":r[0]||(r[0]=s=>o("update:activeIndex",s))},null,8,["options","model-value"])]),e.createElementVNode("div",Ht,[e.createElementVNode("div",Zt,[e.createElementVNode("nav",Ut,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.items,s=>(e.openBlock(),e.createElementBlock("a",{key:s.name,href:"#",class:e.normalizeClass(["group inline-flex items-center py-4 px-1 border-b-4 font-medium no-underline! border-transparent",{"border-vxvue text-vxvue":a.value===s,"cursor-not-allowed text-gray-400":s.disabled,"text-gray-900 hover:text-vxvue-600 hover:border-vxvue-600":a.value!==s&&!s.disabled}]),"aria-current":a.value===s?"page":void 0,onClick:e.withModifiers(d=>u(s),["prevent"])},[e.renderSlot(i.$slots,"icon",{tab:s}),e.createElementVNode("span",null,[e.renderSlot(i.$slots,"default",{tab:s},()=>[e.createTextVNode(e.toDisplayString(s.name),1)])]),e.renderSlot(i.$slots,"badge",{tab:s},()=>[s.badge?(e.openBlock(),e.createElementBlock("span",{key:0,class:e.normalizeClass(["hidden ml-3 py-0.5 px-2.5 rounded-full text-xs font-medium md:inline-block text-current",{"bg-gray-100":s.disabled,"bg-vxvue-50":a.value===s,"bg-gray-200":a.value!==s&&!s.disabled}])},e.toDisplayString(s.badge),3)):e.createCommentVNode("",!0)])],10,qt))),128))])])])],64))}},Kt={mounted:t=>t.focus()},Xt={mounted:(t,c)=>{if(!["INPUT","TEXTAREA"].includes(t.nodeName)){let l=t.querySelector('input:not([type]),input[type="text"],input[type="search"],input[type="email"],input[type="password"],input[type="url"],input[type="tel"]');l||(l=t.querySelector("textarea")),t=l}if(t){if(t.querySelector("label"))throw new Error("VFloatingLabel directive: LABEL element found.");const l=Math.random().toString(36).substring(2),o=document.createElement("div");o.classList.add("relative","isolate");const a=document.createElement("label");a.classList.add(..."absolute px-2 left-1 top-2 scale-90 text-sm z-[var(--zIndex-label)] origin-[0] bg-white -translate-y-4 transform-gpu duration-200".split(" "),..."peer-focus:top-2 peer-focus:scale-90 peer-focus:-translate-y-full".split(" "),..."peer-placeholder-shown:scale-100 peer-placeholder-shown:-translate-y-1/2".split(" "),t.nodeName==="TEXTAREA"?"peer-placeholder-shown:top-4":"peer-placeholder-shown:top-1/2"),c.value?.invalid?a.classList.add("text-error","peer-focus:text-error"):a.classList.add("peer-focus:text-blue-600"),t.getAttribute("required")!==null&&a.classList.add("required"),a.setAttribute("for",t.getAttribute("id")||l+"-element"),a.innerHTML=c.value?.label||t.getAttribute("placeholder")||l+"-label",t.classList.add("peer"),t.setAttribute("placeholder"," "),t.setAttribute("id",t.getAttribute("id")||l+"-element"),t.parentElement.replaceChild(o,t),o.appendChild(t),o.appendChild(a)}},updated:(t,c)=>{const l=t.parentNode.querySelector("label");if(!l)return;const o=t.getAttribute("placeholder")?.trim();l.innerHTML=c.value?.label||o||l.innerHTML,o&&t.setAttribute("placeholder"," "),c.value?.invalid?(l.classList.add("text-error","peer-focus:text-error"),l.classList.remove("peer-focus:text-blue-600")):(l.classList.remove("text-error","peer-focus:text-error"),l.classList.add("peer-focus:text-blue-600")),l.classList[t.getAttribute("required")!==null?"add":"remove"]("required")}};E.Accordion=ee,E.AccordionPanel=de,E.Autocomplete=ve,E.Confirm=Le,E.DateInput=J,E.Datepicker=qe,E.FormFileButton=Xe,E.FormSelect=Q,E.FormSwitch=tt,E.MessageToast=ut,E.Modal=ht,E.Pagination=Bt,E.PasswordInput=Ct,E.SimpleTree=Mt,E.Sizable=Dt,E.Slider=Lt,E.Sortable=Ot,E.Spinner=H,E.SubmitButton=Yt,E.Tabs=Wt,E.VFloatingLabel=Xt,E.VFocus=Kt,Object.defineProperty(E,Symbol.toStringTag,{value:"Module"})});
|
package/package.json
CHANGED
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
"./vx-vue.css": "./dist/style.css",
|
|
15
15
|
"./dist/*": "./dist/*"
|
|
16
16
|
},
|
|
17
|
-
"version": "1.4.
|
|
17
|
+
"version": "1.4.2",
|
|
18
18
|
"license": "MIT",
|
|
19
19
|
"homepage": "https://vectrex.github.io/vxVue",
|
|
20
20
|
"repository": {
|
|
@@ -26,32 +26,33 @@
|
|
|
26
26
|
"build": "vite build",
|
|
27
27
|
"preview": "vite preview",
|
|
28
28
|
"test": "vitest",
|
|
29
|
+
"test:ui": "vitest --ui",
|
|
29
30
|
"format": "prettier --write src/",
|
|
30
|
-
"tailwind-cleanup": "rustywind --write src/**/*.{vue,css,js}",
|
|
31
31
|
"docs:dev": "vitepress dev docs",
|
|
32
32
|
"docs:build": "vitepress build docs",
|
|
33
33
|
"docs:preview": "vitepress preview docs"
|
|
34
34
|
},
|
|
35
35
|
"devDependencies": {
|
|
36
36
|
"@heroicons/vue": "^2.2.0",
|
|
37
|
-
"tailwindcss": "^4.1.
|
|
37
|
+
"tailwindcss": "^4.1.16",
|
|
38
38
|
"@tailwindcss/forms": "^0.5.10",
|
|
39
|
-
"@tailwindcss/postcss": "^4.1.
|
|
39
|
+
"@tailwindcss/postcss": "^4.1.16",
|
|
40
40
|
"vue": "^3.5.22",
|
|
41
|
-
"@vueuse/core": "^
|
|
41
|
+
"@vueuse/core": "^14.0.0",
|
|
42
42
|
"postcss": "^8.5.6",
|
|
43
43
|
"@vue/test-utils": "^2.4.6",
|
|
44
44
|
"jsdom": "^27.0.1",
|
|
45
|
-
"vite": "^7.1.
|
|
45
|
+
"vite": "^7.1.12",
|
|
46
46
|
"eslint": "^9.38.0",
|
|
47
47
|
"eslint-plugin-vue": "^9.33.0",
|
|
48
48
|
"@eslint/js": "^9.38.0",
|
|
49
49
|
"@stylistic/eslint-plugin": "^5.5.0",
|
|
50
|
-
"@vitest/eslint-plugin": "^1.3.
|
|
50
|
+
"@vitest/eslint-plugin": "^1.3.24",
|
|
51
51
|
"@vitejs/plugin-vue": "^6.0.1",
|
|
52
52
|
"vite-plugin-vue-devtools": "^8.0.3",
|
|
53
53
|
"vitepress": "^1.6.4",
|
|
54
|
-
"vitest": "^
|
|
54
|
+
"vitest": "^4.0.3",
|
|
55
|
+
"@vitest/ui": "^4.0.3",
|
|
55
56
|
"prettier": "^3.6.2",
|
|
56
57
|
"rustywind": "^0.24.3"
|
|
57
58
|
}
|