@volverjs/ui-vue 0.0.10-beta.54 → 0.0.10-beta.55
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/components/VvCombobox/VvCombobox.es.js +357 -357
- package/dist/components/VvCombobox/VvCombobox.umd.js +1 -1
- package/dist/components/VvInputText/VvInputText.es.js +17 -19
- package/dist/components/VvInputText/VvInputText.umd.js +1 -1
- package/dist/components/VvTextarea/VvTextarea.es.js +966 -67
- package/dist/components/VvTextarea/VvTextarea.umd.js +1 -1
- package/dist/components/VvTextarea/VvTextarea.vue.d.ts +52 -0
- package/dist/components/VvTextarea/index.d.ts +37 -1
- package/dist/components/index.es.js +445 -295
- package/dist/components/index.umd.js +1 -1
- package/dist/icons.es.js +3 -3
- package/dist/icons.umd.js +1 -1
- package/package.json +22 -22
- package/src/assets/icons/detailed.json +1 -1
- package/src/assets/icons/normal.json +1 -1
- package/src/assets/icons/simple.json +1 -1
- package/src/components/VvCombobox/VvCombobox.vue +3 -3
- package/src/components/VvInputText/VvInputText.vue +18 -20
- package/src/components/VvTextarea/VvTextarea.vue +108 -5
- package/src/components/VvTextarea/index.ts +32 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("@iconify/vue"),require("@floating-ui/vue"),require("@vueuse/core"),require("mitt"),require("ts-dot-prop")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","@floating-ui/vue","@vueuse/core","mitt","ts-dot-prop"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvCombobox=t(e.vue,e.vue$1,e.vue$2,e.core,e.mitt,e.tsDotProp)}(this,(function(e,t,l,o,a,n){"use strict";var r=(e=>(e.local="local",e.session="session",e))(r||{}),i=(e=>(e.absolute="absolute",e.fixed="fixed",e))(i||{}),u=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(u||{}),s=(e=>(e.topStart="top-start",e.topEnd="top-end",e.bottomStart="bottom-start",e.bottomEnd="bottom-end",e.leftStart="left-start",e.leftEnd="left-end",e.rightStart="right-start",e.rightEnd="right-end",e))(s||{}),d=(e=>(e.before="before",e.after="after",e))(d||{}),c=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(c||{}),v=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(v||{}),f=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(f||{}),p=(e=>(e.listbox="listbox",e.menu="menu",e))(p||{}),m=(e=>(e.option="option",e.presentation="presentation",e))(m||{});const b=Symbol.for("volver"),g=Symbol.for("buttonGroup"),y=Symbol.for("dropdownTrigger"),h=Symbol.for("dropdownItem"),k=Symbol.for("dropdownAction");function S(e,t,l){return B(e,t)}function B(e,t){if(e===t)return!0;if(e&&t&&"object"==typeof e&&"object"==typeof t){const l=Array.isArray(e),o=Array.isArray(t);let a,n,r;if(l&&o){if(n=e.length,n!==t.length)return!1;for(a=n;0!=a--;)if(!B(e[a],t[a]))return!1;return!0}if(l!==o)return!1;const i=e instanceof Date,u=t instanceof Date;if(i!==u)return!1;if(i&&u)return e.getTime()===t.getTime();const s=e instanceof RegExp,d=t instanceof RegExp;if(s!==d)return!1;if(s&&d)return e.toString()===t.toString();const c=Object.keys(e);if(n=c.length,n!==Object.keys(t).length)return!1;for(a=n;0!=a--;)if(!Object.prototype.hasOwnProperty.call(t,c[a]))return!1;for(a=n;0!=a--;)if(r=c[a],!B(e[r],t[r]))return!1;return!0}return Number.isNaN(e)&&Number.isNaN(t)}function x(e,t){if(null!=e&&t&&t.length)for(const l of t)if(S(e,l))return!0;return!1}function w(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}function V(t,l){const o=e.computed((()=>e.isRef(t)?t.value:t)),a=e.computed((()=>w(o.value.invalidLabel))),n=e.computed((()=>w(o.value.validLabel))),r=e.computed((()=>o.value.loadingLabel)),i=e.computed((()=>o.value.hintLabel)),u=e.computed((()=>Boolean(o.value.loading&&(l.loading||r.value)))),s=e.computed((()=>!u.value&&Boolean(o.value.invalid&&(l.invalid||a.value)))),d=e.computed((()=>!u.value&&!s.value&&Boolean(o.value.valid&&(l.valid||n.value)))),c=e.computed((()=>!u.value&&!s.value&&!d.value&&Boolean(l.hint||i.value))),v=e.computed((()=>s.value||d.value||u.value||c.value)),f=e.computed((()=>({modelValue:o.value.modelValue,valid:o.value.valid,invalid:o.value.invalid,loading:o.value.loading}))),p=e.defineComponent({name:"HintSlot",props:{tag:{type:String,default:"small"}},setup:()=>({isVisible:v,invalidLabel:a,validLabel:n,loadingLabel:r,hintLabel:i,hasInvalidLabelOrSlot:s,hasValidLabelOrSlot:d,hasLoadingLabelOrSlot:u,hasHintLabelOrSlot:c}),render(){var t,l,o,a,n,r,i,u;if(this.isVisible){let s;return this.hasInvalidLabelOrSlot&&(s="alert"),this.hasValidLabelOrSlot&&(s="status"),this.hasLoadingLabelOrSlot?e.h(this.tag,{role:s},(null==(l=(t=this.$slots).loading)?void 0:l.call(t))??this.loadingLabel):this.hasInvalidLabelOrSlot?e.h(this.tag,{role:s},(null==(a=(o=this.$slots).invalid)?void 0:a.call(o))??this.$slots.invalid??this.invalidLabel):this.hasValidLabelOrSlot?e.h(this.tag,{role:s},(null==(r=(n=this.$slots).valid)?void 0:r.call(n))??this.validLabel):e.h(this.tag,{role:s},(null==(u=(i=this.$slots).hint)?void 0:u.call(i))??this.$slots.hint??this.hintLabel)}return null}});return{hasInvalidLabelOrSlot:s,hasHintLabelOrSlot:c,hasValidLabelOrSlot:d,hasLoadingLabelOrSlot:u,hintSlotScope:f,HintSlot:p}}const L={to:{type:[String,Object]},href:String,target:String,rel:{type:String,default:"noopener noreferrer"}},P={valid:{type:Boolean,default:!1},validLabel:{type:[String,Array],default:void 0}},$={invalid:{type:Boolean,default:!1},invalidLabel:{type:[String,Array],default:void 0}},C={loading:{type:Boolean,default:!1},loadingLabel:{type:String,default:"Loading..."}},O={disabled:{type:Boolean,default:!1}},N={required:{type:Boolean,default:!1}},E={selected:{type:Boolean,default:!1}},_={active:{type:Boolean,default:!1}},A={current:{type:Boolean,default:!1}},F={pressed:{type:Boolean,default:!1}},D={label:{type:[String,Number],default:void 0}},R={readonly:{type:Boolean,default:!1}},j={modifiers:{type:[String,Array],default:void 0}},H={hintLabel:{type:String,default:""}},z={options:{type:Array,default:()=>[]},labelKey:{type:[String,Function],default:"label"},valueKey:{type:[String,Function],default:"value"},disabledKey:{type:[String,Function],default:"disabled"}},I={icon:{type:[String,Object],default:void 0},iconPosition:{type:String,default:d.before,validation:e=>Object.values(d).includes(e)}},T={tabindex:{type:[String,Number],default:0}},M={floating:{type:Boolean,default:!1}},q={unselectable:{type:Boolean,default:!0}},K={id:[String,Number]},W={placement:{type:String,default:u.bottom,validator:e=>Object.values(u).includes(e)||Object.values(s).includes(e)},strategy:{type:String,default:void 0,validator:e=>Object.values(i).includes(e)},transitionName:{type:String,default:void 0},offset:{type:[Number,String,Object],default:0},shift:{type:[Boolean,Object],default:!1},flip:{type:[Boolean,Object],default:!0},size:{type:[Boolean,Object],default:()=>({padding:10})},autoPlacement:{type:[Boolean,Object],default:!1},arrow:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean,default:!1}},G={...K,name:{type:String,required:!0}},J={autofocus:{type:Boolean,default:!1}},U={autocomplete:{type:String,default:"off"}},Q={...O,...D,...F,..._,...A,...L,type:{type:String,default:c.button,validator:e=>Object.values(c).includes(e)},ariaLabel:{type:String,default:void 0},defaultTag:{type:String,default:v.button}};r.local;const X={...j,value:[String,Number]};function Y(t,l,o){return e.computed((()=>{const a={[t]:!0},n="string"==typeof(null==l?void 0:l.value)?l.value.split(" "):null==l?void 0:l.value;return n&&Array.isArray(n)&&n.forEach((e=>{e&&(a[`${t}--${e}`]=!0)})),o&&Object.keys(o.value).forEach((l=>{a[`${t}--${l}`]=e.unref(o.value[l])})),a}))}const Z=e.defineComponent({name:"VvBadge",props:X,setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=Y("vv-badge",o);return(t,l)=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass(e.unref(a))},[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.value),1)]))],2))}});const ee={...Q,...K,...j,...q,...C,...I,iconPosition:{type:String,default:u.left,validator:e=>Object.values(u).includes(e)},loadingIcon:{type:String,default:"eos-icons:bubble-loading"},toggle:{type:Boolean,default:!1},value:{type:[String,Number,Boolean],default:void 0},uncheckedValue:{type:[String,Number,Boolean],default:void 0},modelValue:{type:[String,Number,Boolean],default:void 0}};function te(t,l){const{group:o,isInGroup:a,getGroupOrLocalRef:n}=function(t){const l=e.inject(t,void 0),o=e.computed((()=>void 0!==l));return{group:l,isInGroup:o,getGroupOrLocalRef:function(t,o,a){const n=null==l?void 0:l[t];if(n)return e.computed({get:()=>n.value,set(e){n.value=e}});const r=e.toRef(o,t);return e.computed({get:()=>r.value,set(e){a&&a(`update:${t}`,e)}})}}}(g),{id:r,iconPosition:i,icon:u,label:s,pressed:d}=e.toRefs(t),c=n("modelValue",t,l),v=n("toggle",t),f=n("unselectable",t),p=e.computed((()=>(null==o?void 0:o.multiple.value)??!1)),m=e.computed((()=>{let e=t.modifiers,l=null==o?void 0:o.modifiers.value;const a=new Set;return e&&(Array.isArray(e)||(e=e.split(" ")),e.forEach((e=>a.add(e)))),l&&(Array.isArray(l)||(l=l.split(" ")),l.forEach((e=>a.add(e)))),Array.from(a)})),b=e.computed((()=>Boolean(t.disabled||(null==o?void 0:o.disabled.value))));return{group:o,isInGroup:a,modelValue:c,toggle:v,unselectable:f,multiple:p,modifiers:m,disabled:b,id:r,pressed:d,iconPosition:i,icon:u,label:s}}const le=Q;function oe(){return e.inject(b)}const ae=e.defineComponent({name:"VvAction",props:le,emits:["click","mouseover","mouseleave"],setup(t,{expose:l,emit:o}){const a=t,n=o,r=e.getCurrentInstance(),i=oe(),u=e.ref(null);l({$el:u});const{reference:s,bus:d,aria:c,expanded:f}=e.inject(y,{});e.watch((()=>u.value),(e=>{s&&(s.value=e)}));const p=e.computed((()=>a.pressed||(null==f?void 0:f.value))),{role:m}=e.inject(k,{}),b=e.computed((()=>{switch(!0){case a.disabled:return v.button;case void 0!==a.to:return(null==i?void 0:i.nuxt)?v.nuxtLink:v.routerLink;case void 0!==a.href:return v.a;default:return a.defaultTag}})),g=e.computed((()=>{const e={...null==c?void 0:c.value,ariaPressed:!!p.value||void 0,ariaLabel:a.ariaLabel,role:null==m?void 0:m.value};switch(b.value){case v.a:return{...e,href:a.href,target:a.target,rel:a.rel};case v.routerLink:case v.nuxtLink:return{...e,to:a.to,target:a.target};case v.button:return{...e,type:a.type,disabled:a.disabled};default:return e}}));function h(e){var t;a.disabled?e.preventDefault():(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onClick)?n("click",e):null==d||d.emit("click",e)}function S(e){var t;(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onMouseover)?n("mouseover",e):null==d||d.emit("mouseover",e)}function B(e){var t;(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onMouseleave)?n("mouseleave",e):null==d||d.emit("mouseleave",e)}return(t,l)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(b)),e.mergeProps(e.unref(g),{ref_key:"element",ref:u,class:{active:t.active,pressed:e.unref(p),disabled:t.disabled,current:t.current},onClickPassive:h,onMouseoverPassive:S,onMouseleavePassive:B}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.label),1)]))])),_:3},16,["class"]))}}),ne={prefix:"normal"},re=e.defineComponent({name:"VvIcon",props:e.mergeDefaults({name:{},color:{},width:{},height:{},provider:{},prefix:{},src:{},horizontalFlip:{type:Boolean},verticalFlip:{type:Boolean},flip:{},mode:{},inline:{type:Boolean},rotate:{},onLoad:{type:Function},svg:{},modifiers:{}},ne),setup(l){const o=l,a=e.computed((()=>"string"==typeof o.rotate?Number.parseFloat(o.rotate):o.rotate)),n=e.ref(!0),r=oe(),{modifiers:i}=e.toRefs(o),u=Y("vv-icon",i),s=e.computed((()=>o.provider||(null==r?void 0:r.iconsProvider))),d=e.computed((()=>{const e=o.name??"",l=`@${s.value}:${o.prefix}:${e}`;if(t.iconExists(l))return l;const a=null==r?void 0:r.iconsCollections.find((l=>{const o=`@${s.value}:${l.prefix}:${e}`;return t.iconExists(o)}));return a?`@${s.value}:${a.prefix}:${e}`:e}));function c(e){const l=function(e){let t;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");t=(new e).window}return(t?new t.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),a=(null==l?void 0:l.innerHTML.trim())||"";l&&a&&t.addIcon(`@${s.value}:${o.prefix}:${o.name}`,{body:a,height:l.viewBox.baseVal.height,width:l.viewBox.baseVal.width})}return r&&o.src&&!t.iconExists(`@${s.value}:${o.prefix}:${o.name}`)&&(n.value=!1,r.fetchIcon(o.src).then((e=>{e&&(c(e),n.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),o.svg&&c(o.svg),(l,o)=>e.unref(n)?(e.openBlock(),e.createBlock(e.unref(t.Icon),e.mergeProps({key:0,class:e.unref(u)},{inline:l.inline,width:l.width,height:l.height,horizontalFlip:l.horizontalFlip,verticalFlip:l.verticalFlip,flip:l.flip,rotate:e.unref(a),color:l.color,onLoad:l.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}});function ie(t){return e.computed((()=>String((null==t?void 0:t.value)||e.useId())))}function ue(t,l){const o=e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),a=e.computed((()=>(null==l?void 0:l.value)===d.before?o.value:void 0)),n=e.computed((()=>(null==l?void 0:l.value)===d.after?o.value:void 0)),r=e.computed((()=>(null==l?void 0:l.value)===u.left?o.value:void 0)),i=e.computed((()=>(null==l?void 0:l.value)===u.right?o.value:void 0)),s=e.computed((()=>(null==l?void 0:l.value)===u.top?o.value:void 0)),c=e.computed((()=>(null==l?void 0:l.value)===u.bottom?o.value:void 0));return{hasIcon:o,hasIconLeft:r,hasIconRight:i,hasIconTop:s,hasIconBottom:c,hasIconBefore:a,hasIconAfter:n}}const se={key:1,class:"vv-button__label"},de={key:1,class:"vv-button__label"},ce=e.defineComponent({name:"VvButton",inheritAttrs:!1,props:ee,emits:["update:modelValue"],setup(t,{expose:l,emit:o}){const a=t,n=o,r=e.useAttrs(),i=e.useSlots(),{id:s,modifiers:d,iconPosition:c,icon:v,label:f,modelValue:p,disabled:m,toggle:b,unselectable:g}=te(a,n),y=ie(s),h=e.computed((()=>(null==r?void 0:r.name)||y.value)),k=e.ref(null);l({$el:e.computed((()=>{var e;return null==(e=k.value)?void 0:e.$el}))});const B=e.computed((()=>b.value?Array.isArray(p.value)?x(h.value,p.value):S(h.value,p.value):a.pressed)),w=Y("vv-button",d,e.computed((()=>({reverse:[u.right,u.bottom].includes(c.value),column:[u.top,u.bottom].includes(c.value),"icon-only":Boolean((null==v?void 0:v.value)&&!(null==f?void 0:f.value)&&!i.default)})))),{hasIcon:V}=ue(v),L=e.computed((()=>void 0!==a.value?a.value:h.value)),P=e.computed((()=>{if(b.value)return{onClick:$}}));function $(){if(b.value){if(Array.isArray(p.value))return x(L.value,p.value)?void(g.value&&(p.value=p.value.filter((e=>e!==L.value)))):void p.value.push(L.value);if(L.value===p.value&&g.value)return void(p.value=a.uncheckedValue);p.value=L.value}}return(t,l)=>(e.openBlock(),e.createBlock(ae,e.mergeProps({...e.unref(r),...e.unref(P),disabled:e.unref(m),pressed:e.unref(B),active:t.active,type:t.type,to:t.to,href:t.href,target:t.target,rel:t.rel,ariaLabel:t.ariaLabel},{id:e.unref(y),ref_key:"element",ref:k,class:e.unref(w)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[t.loading?e.renderSlot(t.$slots,"loading",{key:0},(()=>[t.loadingIcon?(e.openBlock(),e.createBlock(re,{key:0,class:"vv-button__loading-icon",name:t.loadingIcon},null,8,["name"])):e.createCommentVNode("v-if",!0),t.loadingLabel?(e.openBlock(),e.createElementBlock("span",se,e.toDisplayString(t.loadingLabel),1)):e.createCommentVNode("v-if",!0)])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.renderSlot(t.$slots,"before"),e.unref(V)?(e.openBlock(),e.createBlock(re,e.mergeProps({key:0},e.unref(V),{class:"vv-button__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.unref(f)?(e.openBlock(),e.createElementBlock("span",de,[e.renderSlot(t.$slots,"label",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(f)),1)]))])):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"after")],64))]))])),_:3},16,["id","class"]))}}),ve={...K,...W,...j,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:p.menu,validator:e=>Object.values(p).includes(e)}},fe={focusOnHover:{type:Boolean,default:!1}},pe={...O,...E,...q,...j,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String},focusOnHover:{type:Boolean,default:!1}};const me=["id","tabindex","role","aria-labelledby"],be=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:ve,emits:["update:modelValue","beforeEnter","afterLeave","beforeExpand","beforeCollapse","afterExpand","afterCollapse","before-enter","after-leave","enter","afterEnter","enterCancelled","beforeLeave","leave","leaveCancelled"],setup(t,{expose:n,emit:r}){const s=t,d=r,{id:c}=e.toRefs(s),v=ie(c),f=e.useAttrs(),b=e.ref("auto"),g=e.ref("auto"),k=e.ref(),S=e.ref(),B=e.ref(),x=e.ref(),w=e.computed({get:()=>s.reference??k.value,set:e=>{k.value=e}}),V=e.ref(!1);e.onMounted((()=>{o.useMutationObserver(S.value,(()=>{var e;V.value="true"===(null==(e=window.getComputedStyle(S.value).getPropertyValue("--dropdown-custom-position"))?void 0:e.trim())}),{attributeFilter:["style"],window:window})}));const L=e.computed((()=>{const e=[];if(s.autoPlacement?"boolean"==typeof s.autoPlacement?e.push(l.autoPlacement()):e.push(l.autoPlacement(s.autoPlacement)):s.flip&&("boolean"==typeof s.flip?e.push(l.flip({fallbackStrategy:"initialPlacement"})):e.push(l.flip(s.flip))),s.shift&&("boolean"==typeof s.shift?e.push(l.shift()):e.push(l.shift(s.shift))),s.size){const t=({availableWidth:e,availableHeight:t})=>{b.value=`${e}px`,g.value=`${t}px`};"boolean"==typeof s.size?e.push(l.size({apply:t})):e.push(l.size({...s.size,apply:t}))}return s.offset&&(e.push(l.offset(Number(s.offset))),["string","number"].includes(typeof s.offset)?e.push(l.offset(Number(s.offset))):e.push(l.offset(s.offset))),s.arrow&&e.push(l.arrow({element:B})),e})),{x:P,y:$,middlewareData:C,placement:O,strategy:N}=l.useFloating(w,S,{whileElementsMounted:(...e)=>l.autoUpdate(...e,{animationFrame:s.strategy===i.fixed}),placement:e.computed((()=>s.placement)),strategy:e.computed((()=>s.strategy)),middleware:L}),E=e.computed((()=>{var e;if(V.value)return;const t=s.triggerWidth&&w.value?`${null==(e=w.value)?void 0:e.offsetWidth}px`:void 0;return{position:N.value,top:`${$.value??0}px`,left:`${P.value??0}px`,maxWidth:t?void 0:b.value,maxHeight:g.value,width:t}})),_=e.computed((()=>O.value.split("-")[0])),A=e.computed((()=>{var e,t,l,o,a;if(V.value)return;const n={[u.top]:u.bottom,[u.right]:u.left,[u.bottom]:u.top,[u.left]:u.right}[_.value];return{left:void 0!==(null==(e=C.value.arrow)?void 0:e.x)?`${null==(t=C.value.arrow)?void 0:t.x}px`:void 0,top:void 0!==(null==(l=C.value.arrow)?void 0:l.y)?`${null==(o=C.value.arrow)?void 0:o.y}px`:void 0,[n]:-((null==(a=B.value)?void 0:a.offsetWidth)??0)/2+"px"}})),F=o.useVModel(s,"modelValue",d),D=e.ref(!1),R=e.computed({get:()=>F.value??D.value,set:e=>{void 0!==F.value?F.value=e:D.value=e}});function j(){R.value=!0}function H(){R.value=!1}function z(){R.value=!R.value}function I(e){w.value=e}n({toggle:z,show:j,hide:H,init:I,customPosition:V}),e.watch(R,(t=>{t&&s.autofocusFirst&&e.nextTick((()=>{const e=Q(S.value);e.length>0&&e[0].focus({preventScroll:!0})}))})),o.onClickOutside(S,(()=>{!s.keepOpen&&R.value&&(R.value=!1)}),{ignore:[w]});const T=e.computed((()=>{var e,t;return(null==(t=null==(e=w.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),M=e.computed((()=>({"aria-controls":v.value,"aria-haspopup":!0,"aria-expanded":R.value}))),{component:q,bus:K}=function({reference:t,id:l,expanded:o,aria:n}){const r=a(),i=e.defineComponent({name:"VvDropdownTriggerProvider",setup(){e.provide(y,{reference:t,id:l,expanded:o,aria:n,bus:r})},render(){var t,l;return e.h(e.Fragment,{},null==(l=(t=this.$slots).default)?void 0:l.call(t))}});return{bus:r,component:i}}({reference:w,id:v,expanded:R,aria:M});K.on("click",z);const{role:W,modifiers:G}=e.toRefs(s),J=Y("vv-dropdown",G,e.computed((()=>({arrow:s.arrow})))),{focused:U}=o.useFocusWithin(S);function Q(e){return e?[...e.querySelectorAll('a[href], button, input, textarea, select, details, [tabindex]:not([tabindex="-1"])')].filter((e=>!e.hasAttribute("disabled")&&!e.getAttribute("aria-hidden"))):[]}const X=o.useElementHover(S),{itemRole:Z}=function({role:t,...l}){const o=e.computed((()=>t.value===p.listbox?m.option:m.presentation));return e.provide(h,{role:o,...l}),{itemRole:o}}({role:W,expanded:R,focused:U,hovered:X});o.onKeyStroke("Escape",(e=>{R.value&&(e.preventDefault(),H())})),o.onKeyStroke("ArrowDown",(t=>{R.value&&U.value&&(t.preventDefault(),e.nextTick((()=>{if(U.value){const e=Q(S.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus({preventScroll:!0}):e[0].focus({preventScroll:!0})}})))})),o.onKeyStroke("ArrowUp",(t=>{R.value&&U.value&&(t.preventDefault(),e.nextTick((()=>{if(U.value){const e=Q(S.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus({preventScroll:!0}):e[e.length-1].focus({preventScroll:!0})}})))})),o.onKeyStroke([" ","Enter"],(e=>{const t=e.target;R.value&&U.value&&t&&(null==t||t.click())}));const ee={"before-enter":()=>{d(R.value?"beforeExpand":"beforeCollapse"),d("beforeEnter")},"after-leave":()=>{d(R.value?"afterExpand":"afterCollapse"),d("afterLeave")},enter:()=>{d("enter")},"after-enter":()=>{d("afterEnter")},"enter-cancelled":()=>{d("enterCancelled")},"before-leave":()=>{d("beforeLeave")},leave:()=>{d("leave")},"leave-cancelled":()=>{d("leaveCancelled")}};return(t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(q),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:I,show:j,hide:H,toggle:z,expanded:e.unref(R),aria:e.unref(M)})))])),_:3}),e.createVNode(e.Transition,e.mergeProps({name:t.transitionName},e.toHandlers(ee),{persisted:""}),{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:S,style:e.normalizeStyle(e.unref(E)),class:e.normalizeClass(e.unref(J))},[s.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:B,style:e.normalizeStyle(e.unref(A)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(R)}))),e.createElementVNode("div",e.mergeProps(e.unref(f),{id:e.unref(v),ref_key:"listEl",ref:x,tabindex:e.unref(R)?void 0:-1,role:e.unref(W),"aria-labelledby":e.unref(T),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(Z)})))],16,me),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(R)})))],6),[[e.vShow,e.unref(R)]])])),_:3},16,["name"])],64))}}),ge={class:"vv-dropdown-optgroup",role:"presentation",tabindex:"-1"},ye=e.defineComponent({name:"VvDropdownOptgroup",props:{...D},setup(t){const l=t;return(t,o)=>(e.openBlock(),e.createElementBlock("li",ge,e.toDisplayString(l.label),1))}}),he=e.defineComponent({name:"VvDropdownItem",props:fe,setup(t){const l=t,{role:a,expanded:n}=e.inject(h,{}),r=e.ref(null);!function({expanded:t}){e.provide(k,{role:e.ref(f.menuitem),expanded:t})}({expanded:n});const i=o.useElementHover(r),{focused:u}=o.useFocus(r),{focused:s}=o.useFocusWithin(r);return e.watch(i,(e=>{e&&l.focusOnHover&&(u.value=!0)})),(t,l)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({role:e.unref(a)},{ref_key:"element",ref:r,class:["vv-dropdown__item",{"focus-visible":e.unref(u)||e.unref(s)}]}),[e.renderSlot(t.$slots,"default")],16))}}),ke=["title"],Se=e.defineComponent({name:"VvDropdownOption",props:pe,setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=Y("vv-dropdown-option",o,e.computed((()=>({disabled:l.disabled,selected:l.selected,unselectable:l.unselectable&&l.selected})))),n=e.computed((()=>l.selected?l.unselectable?l.deselectHintLabel:l.selectedHintLabel:l.disabled?"":l.selectHintLabel));return(t,l)=>(e.openBlock(),e.createBlock(he,{class:e.normalizeClass(e.unref(a)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled,"focus-on-hover":t.focusOnHover},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default"),e.createElementVNode("span",{class:"vv-dropdown-option__hint",title:e.unref(n)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(n)),1)]))],8,ke)])),_:3},8,["class","tabindex","aria-selected","aria-disabled","focus-on-hover"]))}}),Be={...G,...J,...U,...T,...P,...$,...H,...C,...O,...R,...j,...z,...I,...M,...q,...D,multiple:Boolean,required:Boolean,size:[String,Number],modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},autoselectFirst:{type:Boolean,default:!1},placeholder:String};function xe(){return{...Be,options:{...Be.options,type:Array,default:()=>[]}}}function we(t,l,o){const a=oe(),n=e.computed((()=>{var e;if(a&&(null==(e=a.defaults.value)?void 0:e[t]))return a.defaults.value[t]}));return e.computed((()=>{if(void 0===n.value)return o;const e=n.value,t=l,a=o;return Object.keys(t).reduce(((l,o)=>{const n=a[o];if(l[o]=n,o in e){if(Array.isArray(t[o])){const a=t[o];if(a.length){a[0]===n&&(l[o]=e[o])}}if("function"==typeof t[o]){(0,t[o])()===n&&(l[o]=e[o])}if("object"==typeof t[o]){let a=t[o].default;"function"==typeof a&&(a=a()),"object"==typeof a?JSON.stringify(a)===JSON.stringify(n)&&(l[o]=e[o]):a===n&&(l[o]=e[o])}}return l}),{})}))}function Ve(t,l){const{focused:a}=o.useFocus(t);return e.watch(a,(o=>{l(o?"focus":"blur",e.unref(t))})),{focused:a}}function Le(t){const{options:l,labelKey:o,valueKey:a,disabledKey:r}=e.toRefs(t);return{options:l,getOptionLabel:e=>"string"==typeof e?e:"function"==typeof o.value?o.value(e):String(o.value?n.get(e,o.value):e),getOptionValue:e=>"string"==typeof e?e:"function"==typeof a.value?a.value(e):a.value?n.get(e,a.value):e,isOptionDisabled:e=>"string"!=typeof e&&("function"==typeof r.value?r.value(e):!!r.value&&n.get(e,r.value)),getOptionGrouped:e=>"string"==typeof e?[]:"object"==typeof e&&e&&"options"in e?e.options:[]}}const Pe=["for"],$e={class:"vv-select__wrapper"},Ce={key:0,class:"vv-select__input-before"},Oe={class:"vv-select__inner"},Ne=["id"],Ee=["disabled","hidden"],_e=["disabled","value"],Ae=["disabled","label"],Fe=["disabled","value"],De={key:1,class:"vv-select__input-after"},Re=e.defineComponent({name:"VvSelect",props:xe(),emits:["update:modelValue","focus","blur"],setup(t,{emit:l}){const a=t,n=l,r=e.useSlots(),i=we("VvSelect",xe(),a),u=e.ref(),{HintSlot:s,hasHintLabelOrSlot:d,hasInvalidLabelOrSlot:c,hintSlotScope:v}=V(i,r),{focused:f}=Ve(u,n);function p(e){var t;return"string"!=typeof e&&(null==(t=e.options)?void 0:t.length)}const{id:m,modifiers:b,disabled:g,readonly:y,loading:h,icon:k,iconPosition:S,invalid:B,valid:x,floating:w,multiple:L}=e.toRefs(a),P=ie(m),$=e.computed((()=>`${P.value}-hint`)),C=e.computed((()=>a.disabled||a.readonly)),O=e.computed((()=>C.value?-1:a.tabindex)),N=e.computed({get:()=>a.modelValue,set:e=>{Array.isArray(e)&&0===(e=e.filter((e=>void 0!==e))).length&&!a.unselectable&&u.value?u.value.value=String(a.modelValue):n("update:modelValue",e)}}),E=e.computed((()=>Array.isArray(N.value)?N.value.length>0:void 0!==N.value&&null!==N.value)),_=o.useElementVisibility(u);e.watch(_,(e=>{e&&a.autofocus&&(f.value=!0)}));const{hasIconBefore:A,hasIconAfter:F}=ue(k,S),D=e.computed((()=>!0===a.invalid||!0!==a.valid&&void 0)),R=Y("vv-select",b,e.computed((()=>({valid:x.value,invalid:B.value,loading:h.value,disabled:g.value,readonly:y.value,"icon-before":void 0!==A.value,"icon-after":void 0!==F.value,dirty:E.value,focus:f.value,floating:w.value,multiple:L.value})))),{getOptionLabel:j,getOptionValue:H,isOptionDisabled:z,getOptionGrouped:I}=Le(a);e.watch((()=>a.options),(e=>{if((null==e?void 0:e.length)&&a.autoselectFirst&&!E.value){const t=H(e[0]);N.value=a.multiple?[t]:t}}),{immediate:!0});const T=e.computed((()=>({name:a.name,tabindex:O.value,disabled:C.value,required:a.required,size:a.size,autocomplete:a.autocomplete,multiple:a.multiple,"aria-invalid":D.value,"aria-describedby":d.value?$.value:void 0,"aria-errormessage":c.value?$.value:void 0}))),M=e.computed((()=>({valid:a.valid,invalid:a.invalid,modelValue:a.modelValue})));return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref(R))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(P)},e.toDisplayString(t.label),9,Pe)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",$e,[t.$slots.before?(e.openBlock(),e.createElementBlock("div",Ce,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(M))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",Oe,[e.unref(A)?(e.openBlock(),e.createBlock(re,e.mergeProps({key:0},e.unref(A),{class:"vv-select__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.withDirectives(e.createElementVNode("select",e.mergeProps({id:e.unref(P),ref_key:"selectEl",ref:u},e.unref(T),{"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(N)?N.value=t:null)}),[t.placeholder?(e.openBlock(),e.createElementBlock("option",{key:0,value:void 0,disabled:!t.unselectable,hidden:!t.unselectable},e.toDisplayString(t.placeholder),9,Ee)):e.createCommentVNode("v-if",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,((t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[p(t)?(e.openBlock(),e.createElementBlock("optgroup",{key:`group-${l}`,disabled:e.unref(z)(t),label:e.unref(j)(t)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(I)(t),((t,o)=>(e.openBlock(),e.createElementBlock("option",{key:`group-${l}-item-${o}`,disabled:e.unref(z)(t),value:e.unref(H)(t)},e.toDisplayString(e.unref(j)(t)),9,Fe)))),128))],8,Ae)):(e.openBlock(),e.createElementBlock("option",{key:l,disabled:e.unref(z)(t),value:e.unref(H)(t)},e.toDisplayString(e.unref(j)(t)),9,_e))],64)))),256))],16,Ne),[[e.vModelSelect,e.unref(N)]]),e.unref(F)?(e.openBlock(),e.createBlock(re,e.mergeProps({key:1},e.unref(F),{class:"vv-select__icon vv-select__icon-after"}),null,16)):e.createCommentVNode("v-if",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",De,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(M))))])):e.createCommentVNode("v-if",!0)]),e.createVNode(e.unref(s),{id:e.unref($),class:"vv-select__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"3"}:void 0]),1032,["id"])],2))}}),je={...G,...T,...P,...$,...H,...C,...O,...R,...j,...z,...I,...M,...W,...D,...N,transitionName:{type:String,default:"vv-dropdown--mobile-fade-block"},modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},noResultsLabel:{type:String,default:"No results"},noOptionsLabel:{type:String,default:"No options available"},selectedHintLabel:{type:String,default:"Selected"},deselectActionLabel:{type:String,default:"Deselect"},selectHintLabel:{type:String,default:"Press enter to select"},deselectHintLabel:{type:String,default:"Press enter to remove"},closeLabel:{type:String,default:"Close"},placeholder:String,searchable:Boolean,searchFunction:{type:Function,default:void 0},searchPlaceholder:{type:String,default:"Search..."},debounceSearch:{type:[Number,String],default:0},multiple:Boolean,minValues:{type:[Number,String],default:0},maxValues:[Number,String],unselectable:{type:Boolean,default:!0},separator:{type:String,default:", "},native:Boolean,badges:Boolean,badgeModifiers:{type:[String,Array],default:"action sm"},triggerWidth:{...W.triggerWidth,default:!0},dropdownModifiers:{type:[String,Array],default:"mobile"},autoOpen:{type:Boolean,default:!1},autoselectFirst:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1}};function He(){return{...je,options:{...je.options,type:Array},searchFunction:{...je.searchFunction,type:Function}}}const ze=["id"],Ie=["id","for"],Te=["id","aria-controls","placeholder"],Me={key:0,class:"vv-select__input-before"},qe={class:"vv-select__inner"},Ke=["aria-controls","aria-expanded","aria-labelledby","aria-describedby","aria-errormessage","tabindex"],We={key:0,class:"vv-select__value"},Ge=["aria-label","onClick"],Je={key:1,class:"vv-select__input-after"},Ue={name:"VvCombobox",components:{VvDropdown:be,VvDropdownOption:Se,VvDropdownOptgroup:ye,VvButton:ce}};return e.defineComponent({...Ue,props:He(),emits:["update:modelValue","update:search","change:search","focus","blur"],setup(t,{emit:l}){const a=t,n=l,r=e.useSlots(),i=we("VvCombobox",He(),a),u=e.ref(null),s=e.ref(null),d=e.ref(null),c=e.ref(),{HintSlot:v,hasHintLabelOrSlot:f,hasInvalidLabelOrSlot:m,hintSlotScope:b}=V(i,r),{focused:g}=Ve(u,n),{focused:y}=o.useFocusWithin(d);e.watch(g,(e=>{a.autoOpen&&(!e||S.value?e||!S.value||y.value||w():x())})),e.watch(y,(e=>{g.value||e||!S.value||w()}));const h=e.ref(""),k=o.refDebounced(h,e.computed((()=>Number(a.debounceSearch))));e.watch(k,(()=>{n("update:search",k.value),n("change:search",k.value)}));const S=e.ref(!1);function B(){K.value||(S.value=!S.value)}function x(){K.value||S.value||(S.value=!0)}function w(){!K.value&&S.value&&(S.value=!1)}function L(){i.value.searchable&&s.value&&s.value.focus({preventScroll:!0})}function P(){i.value.searchable&&(h.value="")}function $(e){var t;return"string"!=typeof e&&(null==(t=e.options)?void 0:t.length)}const{id:C,icon:O,iconPosition:N,modifiers:E,disabled:_,required:A,readonly:F,loading:D,valid:R,invalid:j,floating:H}=e.toRefs(a),z=ie(C),I=e.computed((()=>`${z.value}-hint`)),T=e.computed((()=>`${z.value}-dropdown`)),M=e.computed((()=>`${z.value}-search`)),q=e.computed((()=>`${z.value}-label`)),K=e.computed((()=>a.disabled||a.readonly)),W=e.computed((()=>K.value?-1:a.tabindex)),G=e.computed({get:()=>Array.isArray(a.modelValue)?a.modelValue:void 0!==a.modelValue&&null!==a.modelValue?[a.modelValue]:[],set:e=>{n("update:modelValue",a.multiple||Array.isArray(a.modelValue)?e:e.pop())}}),J=e.computed((()=>G.value.length)),U=e.computed((()=>J.value>0)),Q=e.computed((()=>a.multiple?void 0===a.maxValues?1/0:Number(a.maxValues):1)),X=e.computed((()=>!K.value&&(!!a.unselectable&&(0===Number(a.minValues)||J.value>Number(a.minValues))))),ee=e.computed((()=>!K.value&&(!a.multiple||J.value<Q.value))),te=e.ref(!1),le=e.computed((()=>te.value||D.value)),{hasIconBefore:oe,hasIconAfter:ae}=ue(O,N),ne=Y("vv-select",E,e.computed((()=>({disabled:_.value,required:A.value,loading:le.value,readonly:F.value,"icon-before":void 0!==oe.value,"icon-after":void 0!==ae.value,valid:R.value,invalid:j.value,dirty:U.value,focus:g.value||y.value||S.value,floating:H.value,badges:a.badges})))),{getOptionLabel:se,getOptionValue:de,getOptionGrouped:ve,isOptionDisabled:fe}=Le(a);function pe(e){return fe(e)||!ee.value&&!ge(e)}const me=o.computedAsync((async()=>{var e;if(i.value.searchFunction){te.value=!0;const e=await Promise.resolve(i.value.searchFunction(k.value,a.options));return te.value=!1,e}return null==(e=a.options)?void 0:e.filter((e=>se(e).toLowerCase().includes(k.value.toLowerCase().trim())))}));function ge(e){const t=de(e);return"object"==typeof t?G.value.some((e=>"object"==typeof e&&JSON.stringify(e)===JSON.stringify(t))):G.value.includes(t)}const he=e.computed((()=>a.options.reduce(((e,t)=>$(t)?[...e,...ve(t)]:[...e,t]),[]).filter((e=>ge(e))))),ke=e.computed((()=>he.value.map((e=>se(e))).join(a.separator)));function Be(){a.autoOpen?x():B()}function xe(e){const t=ge(e),l=de(e);t&&X.value?G.value=G.value.filter((e=>"object"==typeof l&&"object"==typeof e?JSON.stringify(e)!==JSON.stringify(l):e!==l)):!t&&ee.value&&(a.multiple||(G.value=[]),G.value=[...G.value,l]),a.multiple||a.keepOpen||w()}e.watch((()=>a.options),(e=>{(null==e?void 0:e.length)&&a.autoselectFirst&&!U.value&&xe(e[0])}),{immediate:!0});const Pe=e.computed((()=>({id:z.value,name:a.name,tabindex:W.value,valid:R.value,validLabel:i.value.validLabel,invalid:j.value,invalidLabel:i.value.invalidLabel,hintLabel:i.value.hintLabel,loading:le.value,loadingLabel:i.value.loadingLabel,disabled:_.value,readonly:F.value,modifiers:i.value.modifiers,options:i.value.options,labelKey:i.value.labelKey,valueKey:i.value.valueKey,icon:i.value.icon,iconPosition:i.value.iconPosition,floating:i.value.floating,unselectable:X.value,autoselectFirst:i.value.autoselectFirst,multiple:i.value.multiple,label:i.value.label,placeholder:i.value.placeholder,modelValue:a.modelValue}))),$e=e.computed((()=>({id:T.value,reference:d.value,placement:i.value.placement,strategy:i.value.strategy,transitionName:i.value.transitionName,offset:i.value.offset,shift:i.value.shift,flip:i.value.flip,autoPlacement:i.value.autoPlacement,arrow:i.value.arrow,autofocusFirst:!!i.value.searchable||i.value.autofocusFirst,triggerWidth:i.value.triggerWidth,modifiers:i.value.dropdownModifiers}))),Ce=e.computed((()=>({valid:a.valid,invalid:a.invalid,modelValue:a.modelValue})));return o.onKeyStroke([" ","Enter"],(e=>{a.autoOpen||!S.value&&g.value&&(e.preventDefault(),e.stopImmediatePropagation(),B())}),{target:u}),(t,l)=>t.native?(e.openBlock(),e.createBlock(Re,e.mergeProps({key:1},e.unref(Pe),{"onUpdate:modelValue":l[3]||(l[3]=e=>n("update:modelValue",e))}),null,16)):(e.openBlock(),e.createElementBlock("div",{key:0,id:e.unref(z),class:e.normalizeClass(e.unref(ne))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,id:e.unref(q),for:e.unref(i).searchable?e.unref(M):void 0},e.toDisplayString(t.label),9,Ie)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:d,class:"vv-select__wrapper"},[e.createVNode(be,e.mergeProps({ref_key:"dropdownEl",ref:c,modelValue:e.unref(S),"onUpdate:modelValue":l[2]||(l[2]=t=>e.isRef(S)?S.value=t:null)},e.unref($e),{role:e.unref(p).listbox,onAfterExpand:L,onAfterCollapse:P}),e.createSlots({default:e.withCtx((({aria:l})=>[t.$slots.before?(e.openBlock(),e.createElementBlock("div",Me,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(Ce))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",qe,[e.unref(oe)?(e.openBlock(),e.createBlock(re,e.mergeProps({key:0},e.unref(oe),{class:"vv-select__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",e.mergeProps({ref_key:"inputEl",ref:u},l,{class:"vv-select__input",role:"combobox","aria-controls":e.unref(T),"aria-expanded":e.unref(S),"aria-labelledby":e.unref(q),"aria-describedby":e.unref(f)?e.unref(I):void 0,"aria-errormessage":e.unref(m)?e.unref(I):void 0,tabindex:e.unref(W),onClickPassive:Be}),[e.renderSlot(t.$slots,"value",e.normalizeProps(e.guardReactiveProps({selectedOptions:e.unref(he),onInput:xe})),(()=>[e.unref(ke)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.badges?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(e.unref(he),((l,o)=>(e.openBlock(),e.createBlock(Z,{key:o,modifiers:t.badgeModifiers,class:"vv-select__badge"},{default:e.withCtx((()=>[e.createTextVNode(e.toDisplayString(e.unref(se)(l))+" ",1),e.unref(X)?(e.openBlock(),e.createElementBlock("button",{key:0,"aria-label":e.unref(i).deselectActionLabel,type:"button",onClick:e.withModifiers((e=>xe(l)),["stop"])},[e.createVNode(re,{name:"close"})],8,Ge)):e.createCommentVNode("v-if",!0)])),_:2},1032,["modifiers"])))),128)):(e.openBlock(),e.createElementBlock("div",We,e.toDisplayString(e.unref(ke)),1))],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(t.placeholder),1)],64))]))],16,Ke),e.unref(ae)?(e.openBlock(),e.createBlock(re,e.mergeProps({key:1},e.unref(ae),{class:"vv-select__icon vv-select__icon-after"}),null,16)):e.createCommentVNode("v-if",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Je,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(Ce))))])):e.createCommentVNode("v-if",!0)])),items:e.withCtx((()=>{var l;return[!e.unref(_)&&(null==(l=e.unref(me))?void 0:l.length)?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(e.unref(me),((l,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:o},[$(l)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createVNode(ye,{label:e.unref(se)(l)},null,8,["label"]),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(ve)(l),((o,a)=>(e.openBlock(),e.createBlock(Se,e.mergeProps({ref_for:!0},{selected:ge(o),disabled:pe(o),unselectable:e.unref(X),deselectHintLabel:e.unref(i).deselectHintLabel,selectHintLabel:e.unref(i).selectHintLabel,selectedHintLabel:e.unref(i).selectedHintLabel},{key:a,class:"vv-dropdown-option","focus-on-hover":"",onClickPassive:e=>xe(o)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.mergeProps({ref_for:!0},{option:l,selectedOptions:e.unref(he),selected:ge(o),disabled:pe(o)}),(()=>[e.createTextVNode(e.toDisplayString(e.unref(se)(o)),1)]))])),_:2},1040,["onClickPassive"])))),128))],64)):(e.openBlock(),e.createBlock(Se,e.mergeProps({key:1,ref_for:!0},{selected:ge(l),disabled:pe(l),unselectable:e.unref(X),deselectHintLabel:e.unref(i).deselectHintLabel,selectHintLabel:e.unref(i).selectHintLabel,selectedHintLabel:e.unref(i).selectedHintLabel},{class:"vv-dropdown-option","focus-on-hover":"",onClickPassive:e=>xe(l)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.mergeProps({ref_for:!0},{option:l,selectedOptions:e.unref(he),selected:ge(l),disabled:pe(l)}),(()=>[e.createTextVNode(e.toDisplayString(e.unref(se)(l)),1)]))])),_:2},1040,["onClickPassive"]))],64)))),128)):t.options.length?e.unref(_)?e.createCommentVNode("v-if",!0):(e.openBlock(),e.createBlock(Se,{key:2,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-results",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(i).noResultsLabel),1)]))])),_:3})):(e.openBlock(),e.createBlock(Se,{key:1,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-options",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(i).noOptionsLabel),1)]))])),_:3}))]})),after:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::after",{},(()=>{var t;return[(null==(t=e.unref(c))?void 0:t.customPosition)?(e.openBlock(),e.createBlock(ce,{key:0,label:e.unref(i).closeLabel,modifiers:"secondary",onClick:l[1]||(l[1]=t=>e.unref(c).hide())},null,8,["label"])):e.createCommentVNode("v-if",!0)]}))])),_:2},[e.unref(i).searchable||t.$slots["dropdown::before"]?{name:"before",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::before"),e.unref(i).searchable&&!e.unref(_)?e.withDirectives((e.openBlock(),e.createElementBlock("input",{key:0,id:e.unref(M),ref_key:"inputSearchEl",ref:s,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(h)?h.value=t:null),"aria-autocomplete":"list","aria-controls":e.unref(T),autocomplete:"off",spellcheck:"false",type:"search",class:"vv-dropdown__search",placeholder:e.unref(i).searchPlaceholder},null,8,Te)),[[e.vModelText,e.unref(h)]]):e.createCommentVNode("v-if",!0)])),key:"0"}:void 0]),1040,["modelValue","role"])],512),e.createVNode(e.unref(v),{id:e.unref(I),class:"vv-select__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(b))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(b))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(b))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(b))))])),key:"3"}:void 0]),1032,["id"])],10,ze))}})}));
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("@iconify/vue"),require("@floating-ui/vue"),require("@vueuse/core"),require("mitt"),require("ts-dot-prop")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","@floating-ui/vue","@vueuse/core","mitt","ts-dot-prop"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvCombobox=t(e.vue,e.vue$1,e.vue$2,e.core,e.mitt,e.tsDotProp)}(this,(function(e,t,l,o,a,n){"use strict";var r=(e=>(e.local="local",e.session="session",e))(r||{}),i=(e=>(e.absolute="absolute",e.fixed="fixed",e))(i||{}),u=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(u||{}),s=(e=>(e.topStart="top-start",e.topEnd="top-end",e.bottomStart="bottom-start",e.bottomEnd="bottom-end",e.leftStart="left-start",e.leftEnd="left-end",e.rightStart="right-start",e.rightEnd="right-end",e))(s||{}),d=(e=>(e.before="before",e.after="after",e))(d||{}),c=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(c||{}),v=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(v||{}),f=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(f||{}),p=(e=>(e.listbox="listbox",e.menu="menu",e))(p||{}),m=(e=>(e.option="option",e.presentation="presentation",e))(m||{});const b=Symbol.for("volver"),g=Symbol.for("buttonGroup"),y=Symbol.for("dropdownTrigger"),h=Symbol.for("dropdownItem"),k=Symbol.for("dropdownAction"),S={to:{type:[String,Object]},href:String,target:String,rel:{type:String,default:"noopener noreferrer"}},B={valid:{type:Boolean,default:!1},validLabel:{type:[String,Array],default:void 0}},x={invalid:{type:Boolean,default:!1},invalidLabel:{type:[String,Array],default:void 0}},w={loading:{type:Boolean,default:!1},loadingLabel:{type:String,default:"Loading..."}},V={disabled:{type:Boolean,default:!1}},L={required:{type:Boolean,default:!1}},P={selected:{type:Boolean,default:!1}},$={active:{type:Boolean,default:!1}},C={current:{type:Boolean,default:!1}},O={pressed:{type:Boolean,default:!1}},N={label:{type:[String,Number],default:void 0}},E={readonly:{type:Boolean,default:!1}},_={modifiers:{type:[String,Array],default:void 0}},A={hintLabel:{type:String,default:""}},F={options:{type:Array,default:()=>[]},labelKey:{type:[String,Function],default:"label"},valueKey:{type:[String,Function],default:"value"},disabledKey:{type:[String,Function],default:"disabled"}},D={icon:{type:[String,Object],default:void 0},iconPosition:{type:String,default:d.before,validation:e=>Object.values(d).includes(e)}},R={tabindex:{type:[String,Number],default:0}},j={floating:{type:Boolean,default:!1}},H={unselectable:{type:Boolean,default:!0}},z={id:[String,Number]},I={placement:{type:String,default:u.bottom,validator:e=>Object.values(u).includes(e)||Object.values(s).includes(e)},strategy:{type:String,default:void 0,validator:e=>Object.values(i).includes(e)},transitionName:{type:String,default:void 0},offset:{type:[Number,String,Object],default:0},shift:{type:[Boolean,Object],default:!1},flip:{type:[Boolean,Object],default:!0},size:{type:[Boolean,Object],default:()=>({padding:10})},autoPlacement:{type:[Boolean,Object],default:!1},arrow:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean,default:!1}},T={...z,name:{type:String,required:!0}},M={autofocus:{type:Boolean,default:!1}},q={autocomplete:{type:String,default:"off"}},K={...V,...N,...O,...$,...C,...S,type:{type:String,default:c.button,validator:e=>Object.values(c).includes(e)},ariaLabel:{type:String,default:void 0},defaultTag:{type:String,default:v.button}};r.local;const W={...T,...R,...B,...x,...A,...w,...V,...E,..._,...F,...D,...j,...I,...N,...L,transitionName:{type:String,default:"vv-dropdown--mobile-fade-block"},modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},noResultsLabel:{type:String,default:"No results"},noOptionsLabel:{type:String,default:"No options available"},selectedHintLabel:{type:String,default:"Selected"},deselectActionLabel:{type:String,default:"Deselect"},selectHintLabel:{type:String,default:"Press enter to select"},deselectHintLabel:{type:String,default:"Press enter to remove"},closeLabel:{type:String,default:"Close"},placeholder:String,searchable:Boolean,searchFunction:{type:Function,default:void 0},searchPlaceholder:{type:String,default:"Search..."},debounceSearch:{type:[Number,String],default:0},multiple:Boolean,minValues:{type:[Number,String],default:0},maxValues:[Number,String],unselectable:{type:Boolean,default:!0},separator:{type:String,default:", "},native:Boolean,badges:Boolean,badgeModifiers:{type:[String,Array],default:"action sm"},triggerWidth:{...I.triggerWidth,default:!0},dropdownModifiers:{type:[String,Array],default:"mobile"},autoOpen:{type:Boolean,default:!1},autoselectFirst:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1}};function G(){return{...W,options:{...W.options,type:Array},searchFunction:{...W.searchFunction,type:Function}}}function J(e,t,l){return U(e,t)}function U(e,t){if(e===t)return!0;if(e&&t&&"object"==typeof e&&"object"==typeof t){const l=Array.isArray(e),o=Array.isArray(t);let a,n,r;if(l&&o){if(n=e.length,n!==t.length)return!1;for(a=n;0!=a--;)if(!U(e[a],t[a]))return!1;return!0}if(l!==o)return!1;const i=e instanceof Date,u=t instanceof Date;if(i!==u)return!1;if(i&&u)return e.getTime()===t.getTime();const s=e instanceof RegExp,d=t instanceof RegExp;if(s!==d)return!1;if(s&&d)return e.toString()===t.toString();const c=Object.keys(e);if(n=c.length,n!==Object.keys(t).length)return!1;for(a=n;0!=a--;)if(!Object.prototype.hasOwnProperty.call(t,c[a]))return!1;for(a=n;0!=a--;)if(r=c[a],!U(e[r],t[r]))return!1;return!0}return Number.isNaN(e)&&Number.isNaN(t)}function Q(e,t){if(null!=e&&t&&t.length)for(const l of t)if(J(e,l))return!0;return!1}function X(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}function Y(t,l){const o=e.computed((()=>e.isRef(t)?t.value:t)),a=e.computed((()=>X(o.value.invalidLabel))),n=e.computed((()=>X(o.value.validLabel))),r=e.computed((()=>o.value.loadingLabel)),i=e.computed((()=>o.value.hintLabel)),u=e.computed((()=>Boolean(o.value.loading&&(l.loading||r.value)))),s=e.computed((()=>!u.value&&Boolean(o.value.invalid&&(l.invalid||a.value)))),d=e.computed((()=>!u.value&&!s.value&&Boolean(o.value.valid&&(l.valid||n.value)))),c=e.computed((()=>!u.value&&!s.value&&!d.value&&Boolean(l.hint||i.value))),v=e.computed((()=>s.value||d.value||u.value||c.value)),f=e.computed((()=>({modelValue:o.value.modelValue,valid:o.value.valid,invalid:o.value.invalid,loading:o.value.loading}))),p=e.defineComponent({name:"HintSlot",props:{tag:{type:String,default:"small"}},setup:()=>({isVisible:v,invalidLabel:a,validLabel:n,loadingLabel:r,hintLabel:i,hasInvalidLabelOrSlot:s,hasValidLabelOrSlot:d,hasLoadingLabelOrSlot:u,hasHintLabelOrSlot:c}),render(){var t,l,o,a,n,r,i,u;if(this.isVisible){let s;return this.hasInvalidLabelOrSlot&&(s="alert"),this.hasValidLabelOrSlot&&(s="status"),this.hasLoadingLabelOrSlot?e.h(this.tag,{role:s},(null==(l=(t=this.$slots).loading)?void 0:l.call(t))??this.loadingLabel):this.hasInvalidLabelOrSlot?e.h(this.tag,{role:s},(null==(a=(o=this.$slots).invalid)?void 0:a.call(o))??this.$slots.invalid??this.invalidLabel):this.hasValidLabelOrSlot?e.h(this.tag,{role:s},(null==(r=(n=this.$slots).valid)?void 0:r.call(n))??this.validLabel):e.h(this.tag,{role:s},(null==(u=(i=this.$slots).hint)?void 0:u.call(i))??this.$slots.hint??this.hintLabel)}return null}});return{hasInvalidLabelOrSlot:s,hasHintLabelOrSlot:c,hasValidLabelOrSlot:d,hasLoadingLabelOrSlot:u,hintSlotScope:f,HintSlot:p}}const Z={..._,value:[String,Number]};function ee(t,l,o){return e.computed((()=>{const a={[t]:!0},n="string"==typeof(null==l?void 0:l.value)?l.value.split(" "):null==l?void 0:l.value;return n&&Array.isArray(n)&&n.forEach((e=>{e&&(a[`${t}--${e}`]=!0)})),o&&Object.keys(o.value).forEach((l=>{a[`${t}--${l}`]=e.unref(o.value[l])})),a}))}const te=e.defineComponent({name:"VvBadge",props:Z,setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=ee("vv-badge",o);return(t,l)=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass(e.unref(a))},[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.value),1)]))],2))}});const le={...K,...z,..._,...H,...w,...D,iconPosition:{type:String,default:u.left,validator:e=>Object.values(u).includes(e)},loadingIcon:{type:String,default:"eos-icons:bubble-loading"},toggle:{type:Boolean,default:!1},value:{type:[String,Number,Boolean],default:void 0},uncheckedValue:{type:[String,Number,Boolean],default:void 0},modelValue:{type:[String,Number,Boolean],default:void 0}};function oe(t,l){const{group:o,isInGroup:a,getGroupOrLocalRef:n}=function(t){const l=e.inject(t,void 0),o=e.computed((()=>void 0!==l));return{group:l,isInGroup:o,getGroupOrLocalRef:function(t,o,a){const n=null==l?void 0:l[t];if(n)return e.computed({get:()=>n.value,set(e){n.value=e}});const r=e.toRef(o,t);return e.computed({get:()=>r.value,set(e){a&&a(`update:${t}`,e)}})}}}(g),{id:r,iconPosition:i,icon:u,label:s,pressed:d}=e.toRefs(t),c=n("modelValue",t,l),v=n("toggle",t),f=n("unselectable",t),p=e.computed((()=>(null==o?void 0:o.multiple.value)??!1)),m=e.computed((()=>{let e=t.modifiers,l=null==o?void 0:o.modifiers.value;const a=new Set;return e&&(Array.isArray(e)||(e=e.split(" ")),e.forEach((e=>a.add(e)))),l&&(Array.isArray(l)||(l=l.split(" ")),l.forEach((e=>a.add(e)))),Array.from(a)})),b=e.computed((()=>Boolean(t.disabled||(null==o?void 0:o.disabled.value))));return{group:o,isInGroup:a,modelValue:c,toggle:v,unselectable:f,multiple:p,modifiers:m,disabled:b,id:r,pressed:d,iconPosition:i,icon:u,label:s}}const ae=K;function ne(){return e.inject(b)}const re=e.defineComponent({name:"VvAction",props:ae,emits:["click","mouseover","mouseleave"],setup(t,{expose:l,emit:o}){const a=t,n=o,r=e.getCurrentInstance(),i=ne(),u=e.ref(null);l({$el:u});const{reference:s,bus:d,aria:c,expanded:f}=e.inject(y,{});e.watch((()=>u.value),(e=>{s&&(s.value=e)}));const p=e.computed((()=>a.pressed||(null==f?void 0:f.value))),{role:m}=e.inject(k,{}),b=e.computed((()=>{switch(!0){case a.disabled:return v.button;case void 0!==a.to:return(null==i?void 0:i.nuxt)?v.nuxtLink:v.routerLink;case void 0!==a.href:return v.a;default:return a.defaultTag}})),g=e.computed((()=>{const e={...null==c?void 0:c.value,ariaPressed:!!p.value||void 0,ariaLabel:a.ariaLabel,role:null==m?void 0:m.value};switch(b.value){case v.a:return{...e,href:a.href,target:a.target,rel:a.rel};case v.routerLink:case v.nuxtLink:return{...e,to:a.to,target:a.target};case v.button:return{...e,type:a.type,disabled:a.disabled};default:return e}}));function h(e){var t;a.disabled?e.preventDefault():(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onClick)?n("click",e):null==d||d.emit("click",e)}function S(e){var t;(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onMouseover)?n("mouseover",e):null==d||d.emit("mouseover",e)}function B(e){var t;(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onMouseleave)?n("mouseleave",e):null==d||d.emit("mouseleave",e)}return(t,l)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(b)),e.mergeProps(e.unref(g),{ref_key:"element",ref:u,class:{active:t.active,pressed:e.unref(p),disabled:t.disabled,current:t.current},onClickPassive:h,onMouseoverPassive:S,onMouseleavePassive:B}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.label),1)]))])),_:3},16,["class"]))}}),ie={prefix:"normal"},ue=e.defineComponent({name:"VvIcon",props:e.mergeDefaults({name:{},color:{},width:{},height:{},provider:{},prefix:{},src:{},horizontalFlip:{type:Boolean},verticalFlip:{type:Boolean},flip:{},mode:{},inline:{type:Boolean},rotate:{},onLoad:{type:Function},svg:{},modifiers:{}},ie),setup(l){const o=l,a=e.computed((()=>"string"==typeof o.rotate?Number.parseFloat(o.rotate):o.rotate)),n=e.ref(!0),r=ne(),{modifiers:i}=e.toRefs(o),u=ee("vv-icon",i),s=e.computed((()=>o.provider||(null==r?void 0:r.iconsProvider))),d=e.computed((()=>{const e=o.name??"",l=`@${s.value}:${o.prefix}:${e}`;if(t.iconExists(l))return l;const a=null==r?void 0:r.iconsCollections.find((l=>{const o=`@${s.value}:${l.prefix}:${e}`;return t.iconExists(o)}));return a?`@${s.value}:${a.prefix}:${e}`:e}));function c(e){const l=function(e){let t;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");t=(new e).window}return(t?new t.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),a=(null==l?void 0:l.innerHTML.trim())||"";l&&a&&t.addIcon(`@${s.value}:${o.prefix}:${o.name}`,{body:a,height:l.viewBox.baseVal.height,width:l.viewBox.baseVal.width})}return r&&o.src&&!t.iconExists(`@${s.value}:${o.prefix}:${o.name}`)&&(n.value=!1,r.fetchIcon(o.src).then((e=>{e&&(c(e),n.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),o.svg&&c(o.svg),(l,o)=>e.unref(n)?(e.openBlock(),e.createBlock(e.unref(t.Icon),e.mergeProps({key:0,class:e.unref(u)},{inline:l.inline,width:l.width,height:l.height,horizontalFlip:l.horizontalFlip,verticalFlip:l.verticalFlip,flip:l.flip,rotate:e.unref(a),color:l.color,onLoad:l.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}});function se(t){return e.computed((()=>String((null==t?void 0:t.value)||e.useId())))}function de(t,l){const o=e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),a=e.computed((()=>(null==l?void 0:l.value)===d.before?o.value:void 0)),n=e.computed((()=>(null==l?void 0:l.value)===d.after?o.value:void 0)),r=e.computed((()=>(null==l?void 0:l.value)===u.left?o.value:void 0)),i=e.computed((()=>(null==l?void 0:l.value)===u.right?o.value:void 0)),s=e.computed((()=>(null==l?void 0:l.value)===u.top?o.value:void 0)),c=e.computed((()=>(null==l?void 0:l.value)===u.bottom?o.value:void 0));return{hasIcon:o,hasIconLeft:r,hasIconRight:i,hasIconTop:s,hasIconBottom:c,hasIconBefore:a,hasIconAfter:n}}const ce={key:1,class:"vv-button__label"},ve={key:1,class:"vv-button__label"},fe=e.defineComponent({name:"VvButton",inheritAttrs:!1,props:le,emits:["update:modelValue"],setup(t,{expose:l,emit:o}){const a=t,n=o,r=e.useAttrs(),i=e.useSlots(),{id:s,modifiers:d,iconPosition:c,icon:v,label:f,modelValue:p,disabled:m,toggle:b,unselectable:g}=oe(a,n),y=se(s),h=e.computed((()=>(null==r?void 0:r.name)||y.value)),k=e.ref(null);l({$el:e.computed((()=>{var e;return null==(e=k.value)?void 0:e.$el}))});const S=e.computed((()=>b.value?Array.isArray(p.value)?Q(h.value,p.value):J(h.value,p.value):a.pressed)),B=ee("vv-button",d,e.computed((()=>({reverse:[u.right,u.bottom].includes(c.value),column:[u.top,u.bottom].includes(c.value),"icon-only":Boolean((null==v?void 0:v.value)&&!(null==f?void 0:f.value)&&!i.default)})))),{hasIcon:x}=de(v),w=e.computed((()=>void 0!==a.value?a.value:h.value)),V=e.computed((()=>{if(b.value)return{onClick:L}}));function L(){if(b.value){if(Array.isArray(p.value))return Q(w.value,p.value)?void(g.value&&(p.value=p.value.filter((e=>e!==w.value)))):void p.value.push(w.value);if(w.value===p.value&&g.value)return void(p.value=a.uncheckedValue);p.value=w.value}}return(t,l)=>(e.openBlock(),e.createBlock(re,e.mergeProps({...e.unref(r),...e.unref(V),disabled:e.unref(m),pressed:e.unref(S),active:t.active,type:t.type,to:t.to,href:t.href,target:t.target,rel:t.rel,ariaLabel:t.ariaLabel},{id:e.unref(y),ref_key:"element",ref:k,class:e.unref(B)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[t.loading?e.renderSlot(t.$slots,"loading",{key:0},(()=>[t.loadingIcon?(e.openBlock(),e.createBlock(ue,{key:0,class:"vv-button__loading-icon",name:t.loadingIcon},null,8,["name"])):e.createCommentVNode("v-if",!0),t.loadingLabel?(e.openBlock(),e.createElementBlock("span",ce,e.toDisplayString(t.loadingLabel),1)):e.createCommentVNode("v-if",!0)])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.renderSlot(t.$slots,"before"),e.unref(x)?(e.openBlock(),e.createBlock(ue,e.mergeProps({key:0},e.unref(x),{class:"vv-button__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.unref(f)?(e.openBlock(),e.createElementBlock("span",ve,[e.renderSlot(t.$slots,"label",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(f)),1)]))])):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"after")],64))]))])),_:3},16,["id","class"]))}}),pe={...z,...I,..._,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:p.menu,validator:e=>Object.values(p).includes(e)}},me={focusOnHover:{type:Boolean,default:!1}},be={...V,...P,...H,..._,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String},focusOnHover:{type:Boolean,default:!1}};const ge=["id","tabindex","role","aria-labelledby"],ye=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:pe,emits:["update:modelValue","beforeEnter","afterLeave","beforeExpand","beforeCollapse","afterExpand","afterCollapse","before-enter","after-leave","enter","afterEnter","enterCancelled","beforeLeave","leave","leaveCancelled"],setup(t,{expose:n,emit:r}){const s=t,d=r,{id:c}=e.toRefs(s),v=se(c),f=e.useAttrs(),b=e.ref("auto"),g=e.ref("auto"),k=e.ref(),S=e.ref(),B=e.ref(),x=e.ref(),w=e.computed({get:()=>s.reference??k.value,set:e=>{k.value=e}}),V=e.ref(!1);e.onMounted((()=>{o.useMutationObserver(S.value,(()=>{var e;V.value="true"===(null==(e=window.getComputedStyle(S.value).getPropertyValue("--dropdown-custom-position"))?void 0:e.trim())}),{attributeFilter:["style"],window:window})}));const L=e.computed((()=>{const e=[];if(s.autoPlacement?"boolean"==typeof s.autoPlacement?e.push(l.autoPlacement()):e.push(l.autoPlacement(s.autoPlacement)):s.flip&&("boolean"==typeof s.flip?e.push(l.flip({fallbackStrategy:"initialPlacement"})):e.push(l.flip(s.flip))),s.shift&&("boolean"==typeof s.shift?e.push(l.shift()):e.push(l.shift(s.shift))),s.size){const t=({availableWidth:e,availableHeight:t})=>{b.value=`${e}px`,g.value=`${t}px`};"boolean"==typeof s.size?e.push(l.size({apply:t})):e.push(l.size({...s.size,apply:t}))}return s.offset&&(e.push(l.offset(Number(s.offset))),["string","number"].includes(typeof s.offset)?e.push(l.offset(Number(s.offset))):e.push(l.offset(s.offset))),s.arrow&&e.push(l.arrow({element:B})),e})),{x:P,y:$,middlewareData:C,placement:O,strategy:N}=l.useFloating(w,S,{whileElementsMounted:(...e)=>l.autoUpdate(...e,{animationFrame:s.strategy===i.fixed}),placement:e.computed((()=>s.placement)),strategy:e.computed((()=>s.strategy)),middleware:L}),E=e.computed((()=>{var e;if(V.value)return;const t=s.triggerWidth&&w.value?`${null==(e=w.value)?void 0:e.offsetWidth}px`:void 0;return{position:N.value,top:`${$.value??0}px`,left:`${P.value??0}px`,maxWidth:t?void 0:b.value,maxHeight:g.value,width:t}})),_=e.computed((()=>O.value.split("-")[0])),A=e.computed((()=>{var e,t,l,o,a;if(V.value)return;const n={[u.top]:u.bottom,[u.right]:u.left,[u.bottom]:u.top,[u.left]:u.right}[_.value];return{left:void 0!==(null==(e=C.value.arrow)?void 0:e.x)?`${null==(t=C.value.arrow)?void 0:t.x}px`:void 0,top:void 0!==(null==(l=C.value.arrow)?void 0:l.y)?`${null==(o=C.value.arrow)?void 0:o.y}px`:void 0,[n]:-((null==(a=B.value)?void 0:a.offsetWidth)??0)/2+"px"}})),F=o.useVModel(s,"modelValue",d),D=e.ref(!1),R=e.computed({get:()=>F.value??D.value,set:e=>{void 0!==F.value?F.value=e:D.value=e}});function j(){R.value=!0}function H(){R.value=!1}function z(){R.value=!R.value}function I(e){w.value=e}n({toggle:z,show:j,hide:H,init:I,customPosition:V}),e.watch(R,(t=>{t&&s.autofocusFirst&&e.nextTick((()=>{const e=Q(S.value);e.length>0&&e[0].focus({preventScroll:!0})}))})),o.onClickOutside(S,(()=>{!s.keepOpen&&R.value&&(R.value=!1)}),{ignore:[w]});const T=e.computed((()=>{var e,t;return(null==(t=null==(e=w.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),M=e.computed((()=>({"aria-controls":v.value,"aria-haspopup":!0,"aria-expanded":R.value}))),{component:q,bus:K}=function({reference:t,id:l,expanded:o,aria:n}){const r=a(),i=e.defineComponent({name:"VvDropdownTriggerProvider",setup(){e.provide(y,{reference:t,id:l,expanded:o,aria:n,bus:r})},render(){var t,l;return e.h(e.Fragment,{},null==(l=(t=this.$slots).default)?void 0:l.call(t))}});return{bus:r,component:i}}({reference:w,id:v,expanded:R,aria:M});K.on("click",z);const{role:W,modifiers:G}=e.toRefs(s),J=ee("vv-dropdown",G,e.computed((()=>({arrow:s.arrow})))),{focused:U}=o.useFocusWithin(S);function Q(e){return e?[...e.querySelectorAll('a[href], button, input, textarea, select, details, [tabindex]:not([tabindex="-1"])')].filter((e=>!e.hasAttribute("disabled")&&!e.getAttribute("aria-hidden"))):[]}const X=o.useElementHover(S),{itemRole:Y}=function({role:t,...l}){const o=e.computed((()=>t.value===p.listbox?m.option:m.presentation));return e.provide(h,{role:o,...l}),{itemRole:o}}({role:W,expanded:R,focused:U,hovered:X});o.onKeyStroke("Escape",(e=>{R.value&&(e.preventDefault(),H())})),o.onKeyStroke("ArrowDown",(t=>{R.value&&U.value&&(t.preventDefault(),e.nextTick((()=>{if(U.value){const e=Q(S.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus({preventScroll:!0}):e[0].focus({preventScroll:!0})}})))})),o.onKeyStroke("ArrowUp",(t=>{R.value&&U.value&&(t.preventDefault(),e.nextTick((()=>{if(U.value){const e=Q(S.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus({preventScroll:!0}):e[e.length-1].focus({preventScroll:!0})}})))})),o.onKeyStroke([" ","Enter"],(e=>{const t=e.target;R.value&&U.value&&t&&(null==t||t.click())}));const Z={"before-enter":()=>{d(R.value?"beforeExpand":"beforeCollapse"),d("beforeEnter")},"after-leave":()=>{d(R.value?"afterExpand":"afterCollapse"),d("afterLeave")},enter:()=>{d("enter")},"after-enter":()=>{d("afterEnter")},"enter-cancelled":()=>{d("enterCancelled")},"before-leave":()=>{d("beforeLeave")},leave:()=>{d("leave")},"leave-cancelled":()=>{d("leaveCancelled")}};return(t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(q),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:I,show:j,hide:H,toggle:z,expanded:e.unref(R),aria:e.unref(M)})))])),_:3}),e.createVNode(e.Transition,e.mergeProps({name:t.transitionName},e.toHandlers(Z),{persisted:""}),{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:S,style:e.normalizeStyle(e.unref(E)),class:e.normalizeClass(e.unref(J))},[s.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:B,style:e.normalizeStyle(e.unref(A)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(R)}))),e.createElementVNode("div",e.mergeProps(e.unref(f),{id:e.unref(v),ref_key:"listEl",ref:x,tabindex:e.unref(R)?void 0:-1,role:e.unref(W),"aria-labelledby":e.unref(T),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(Y)})))],16,ge),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(R)})))],6),[[e.vShow,e.unref(R)]])])),_:3},16,["name"])],64))}}),he={class:"vv-dropdown-optgroup",role:"presentation",tabindex:"-1"},ke=e.defineComponent({name:"VvDropdownOptgroup",props:{...N},setup(t){const l=t;return(t,o)=>(e.openBlock(),e.createElementBlock("li",he,e.toDisplayString(l.label),1))}}),Se=e.defineComponent({name:"VvDropdownItem",props:me,setup(t){const l=t,{role:a,expanded:n}=e.inject(h,{}),r=e.ref(null);!function({expanded:t}){e.provide(k,{role:e.ref(f.menuitem),expanded:t})}({expanded:n});const i=o.useElementHover(r),{focused:u}=o.useFocus(r),{focused:s}=o.useFocusWithin(r);return e.watch(i,(e=>{e&&l.focusOnHover&&(u.value=!0)})),(t,l)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({role:e.unref(a)},{ref_key:"element",ref:r,class:["vv-dropdown__item",{"focus-visible":e.unref(u)||e.unref(s)}]}),[e.renderSlot(t.$slots,"default")],16))}}),Be=["title"],xe=e.defineComponent({name:"VvDropdownOption",props:be,setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=ee("vv-dropdown-option",o,e.computed((()=>({disabled:l.disabled,selected:l.selected,unselectable:l.unselectable&&l.selected})))),n=e.computed((()=>l.selected?l.unselectable?l.deselectHintLabel:l.selectedHintLabel:l.disabled?"":l.selectHintLabel));return(t,l)=>(e.openBlock(),e.createBlock(Se,{class:e.normalizeClass(e.unref(a)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled,"focus-on-hover":t.focusOnHover},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default"),e.createElementVNode("span",{class:"vv-dropdown-option__hint",title:e.unref(n)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(n)),1)]))],8,Be)])),_:3},8,["class","tabindex","aria-selected","aria-disabled","focus-on-hover"]))}}),we={...T,...M,...q,...R,...B,...x,...A,...w,...V,...E,..._,...F,...D,...j,...H,...N,multiple:Boolean,required:Boolean,size:[String,Number],modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},autoselectFirst:{type:Boolean,default:!1},placeholder:String};function Ve(){return{...we,options:{...we.options,type:Array,default:()=>[]}}}function Le(t,l,o){const a=ne(),n=e.computed((()=>{var e;if(a&&(null==(e=a.defaults.value)?void 0:e[t]))return a.defaults.value[t]}));return e.computed((()=>{if(void 0===n.value)return o;const e=n.value,t=l,a=o;return Object.keys(t).reduce(((l,o)=>{const n=a[o];if(l[o]=n,o in e){if(Array.isArray(t[o])){const a=t[o];if(a.length){a[0]===n&&(l[o]=e[o])}}if("function"==typeof t[o]){(0,t[o])()===n&&(l[o]=e[o])}if("object"==typeof t[o]){let a=t[o].default;"function"==typeof a&&(a=a()),"object"==typeof a?JSON.stringify(a)===JSON.stringify(n)&&(l[o]=e[o]):a===n&&(l[o]=e[o])}}return l}),{})}))}function Pe(t,l){const{focused:a}=o.useFocus(t);return e.watch(a,(o=>{l(o?"focus":"blur",e.unref(t))})),{focused:a}}function $e(t){const{options:l,labelKey:o,valueKey:a,disabledKey:r}=e.toRefs(t);return{options:l,getOptionLabel:e=>"string"==typeof e?e:"function"==typeof o.value?o.value(e):String(o.value?n.get(e,o.value):e),getOptionValue:e=>"string"==typeof e?e:"function"==typeof a.value?a.value(e):a.value?n.get(e,a.value):e,isOptionDisabled:e=>"string"!=typeof e&&("function"==typeof r.value?r.value(e):!!r.value&&n.get(e,r.value)),getOptionGrouped:e=>"string"==typeof e?[]:"object"==typeof e&&e&&"options"in e?e.options:[]}}const Ce=["for"],Oe={class:"vv-select__wrapper"},Ne={key:0,class:"vv-select__input-before"},Ee={class:"vv-select__inner"},_e=["id"],Ae=["disabled","hidden"],Fe=["disabled","value"],De=["disabled","label"],Re=["disabled","value"],je={key:1,class:"vv-select__input-after"},He=e.defineComponent({name:"VvSelect",props:Ve(),emits:["update:modelValue","focus","blur"],setup(t,{emit:l}){const a=t,n=l,r=e.useSlots(),i=Le("VvSelect",Ve(),a),u=e.ref(),{HintSlot:s,hasHintLabelOrSlot:d,hasInvalidLabelOrSlot:c,hintSlotScope:v}=Y(i,r),{focused:f}=Pe(u,n);function p(e){var t;return"string"!=typeof e&&(null==(t=e.options)?void 0:t.length)}const{id:m,modifiers:b,disabled:g,readonly:y,loading:h,icon:k,iconPosition:S,invalid:B,valid:x,floating:w,multiple:V}=e.toRefs(a),L=se(m),P=e.computed((()=>`${L.value}-hint`)),$=e.computed((()=>a.disabled||a.readonly)),C=e.computed((()=>$.value?-1:a.tabindex)),O=e.computed({get:()=>a.modelValue,set:e=>{Array.isArray(e)&&0===(e=e.filter((e=>void 0!==e))).length&&!a.unselectable&&u.value?u.value.value=String(a.modelValue):n("update:modelValue",e)}}),N=e.computed((()=>Array.isArray(O.value)?O.value.length>0:void 0!==O.value&&null!==O.value)),E=o.useElementVisibility(u);e.watch(E,(e=>{e&&a.autofocus&&(f.value=!0)}));const{hasIconBefore:_,hasIconAfter:A}=de(k,S),F=e.computed((()=>!0===a.invalid||!0!==a.valid&&void 0)),D=ee("vv-select",b,e.computed((()=>({valid:x.value,invalid:B.value,loading:h.value,disabled:g.value,readonly:y.value,"icon-before":void 0!==_.value,"icon-after":void 0!==A.value,dirty:N.value,focus:f.value,floating:w.value,multiple:V.value})))),{getOptionLabel:R,getOptionValue:j,isOptionDisabled:H,getOptionGrouped:z}=$e(a);e.watch((()=>a.options),(e=>{if((null==e?void 0:e.length)&&a.autoselectFirst&&!N.value){const t=j(e[0]);O.value=a.multiple?[t]:t}}),{immediate:!0});const I=e.computed((()=>({name:a.name,tabindex:C.value,disabled:$.value,required:a.required,size:a.size,autocomplete:a.autocomplete,multiple:a.multiple,"aria-invalid":F.value,"aria-describedby":d.value?P.value:void 0,"aria-errormessage":c.value?P.value:void 0}))),T=e.computed((()=>({valid:a.valid,invalid:a.invalid,modelValue:a.modelValue})));return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref(D))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(L)},e.toDisplayString(t.label),9,Ce)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",Oe,[t.$slots.before?(e.openBlock(),e.createElementBlock("div",Ne,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(T))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",Ee,[e.unref(_)?(e.openBlock(),e.createBlock(ue,e.mergeProps({key:0},e.unref(_),{class:"vv-select__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.withDirectives(e.createElementVNode("select",e.mergeProps({id:e.unref(L),ref_key:"selectEl",ref:u},e.unref(I),{"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(O)?O.value=t:null)}),[t.placeholder?(e.openBlock(),e.createElementBlock("option",{key:0,value:void 0,disabled:!t.unselectable,hidden:!t.unselectable},e.toDisplayString(t.placeholder),9,Ae)):e.createCommentVNode("v-if",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,((t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[p(t)?(e.openBlock(),e.createElementBlock("optgroup",{key:`group-${l}`,disabled:e.unref(H)(t),label:e.unref(R)(t)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(z)(t),((t,o)=>(e.openBlock(),e.createElementBlock("option",{key:`group-${l}-item-${o}`,disabled:e.unref(H)(t),value:e.unref(j)(t)},e.toDisplayString(e.unref(R)(t)),9,Re)))),128))],8,De)):(e.openBlock(),e.createElementBlock("option",{key:l,disabled:e.unref(H)(t),value:e.unref(j)(t)},e.toDisplayString(e.unref(R)(t)),9,Fe))],64)))),256))],16,_e),[[e.vModelSelect,e.unref(O)]]),e.unref(A)?(e.openBlock(),e.createBlock(ue,e.mergeProps({key:1},e.unref(A),{class:"vv-select__icon vv-select__icon-after"}),null,16)):e.createCommentVNode("v-if",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",je,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(T))))])):e.createCommentVNode("v-if",!0)]),e.createVNode(e.unref(s),{id:e.unref(P),class:"vv-select__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"3"}:void 0]),1032,["id"])],2))}}),ze=["id"],Ie=["id","for"],Te=["id","aria-controls","placeholder"],Me={key:0,class:"vv-select__input-before"},qe={class:"vv-select__inner"},Ke=["aria-controls","aria-expanded","aria-labelledby","aria-describedby","aria-errormessage","tabindex"],We={key:0,class:"vv-select__value"},Ge=["aria-label","onClick"],Je={key:1,class:"vv-select__input-after"},Ue={name:"VvCombobox",components:{VvDropdown:ye,VvDropdownOption:xe,VvDropdownOptgroup:ke,VvButton:fe}};return e.defineComponent({...Ue,props:G(),emits:["update:modelValue","update:search","change:search","focus","blur"],setup(t,{emit:l}){const a=t,n=l,r=e.useSlots(),i=Le("VvCombobox",G(),a),u=e.ref(null),s=e.ref(null),d=e.ref(null),c=e.ref(),{HintSlot:v,hasHintLabelOrSlot:f,hasInvalidLabelOrSlot:m,hintSlotScope:b}=Y(i,r),{focused:g}=Pe(u,n),{focused:y}=o.useFocusWithin(d);e.watch(g,(e=>{a.autoOpen&&(!e||S.value?e||!S.value||y.value||w():x())})),e.watch(y,(e=>{g.value||e||!S.value||w()}));const h=e.ref(""),k=o.refDebounced(h,e.computed((()=>Number(a.debounceSearch))));e.watch(k,(()=>{n("update:search",k.value),n("change:search",k.value)}));const S=e.ref(!1);function B(){q.value||(S.value=!S.value)}function x(){q.value||S.value||(S.value=!0)}function w(){!q.value&&S.value&&(S.value=!1)}function V(){i.value.searchable&&s.value&&s.value.focus({preventScroll:!0})}function L(){i.value.searchable&&(h.value="")}function P(e){var t;return"string"!=typeof e&&(null==(t=e.options)?void 0:t.length)}const{id:$,icon:C,iconPosition:O,modifiers:N,disabled:E,required:_,readonly:A,loading:F,valid:D,invalid:R,floating:j}=e.toRefs(a),H=se($),z=e.computed((()=>`${H.value}-hint`)),I=e.computed((()=>`${H.value}-dropdown`)),T=e.computed((()=>`${H.value}-search`)),M=e.computed((()=>`${H.value}-label`)),q=e.computed((()=>a.disabled||a.readonly)),K=e.computed((()=>q.value?-1:a.tabindex)),W=e.computed({get:()=>Array.isArray(a.modelValue)?a.modelValue:void 0!==a.modelValue&&null!==a.modelValue?[a.modelValue]:[],set:e=>{n("update:modelValue",a.multiple||Array.isArray(a.modelValue)?e:e.pop())}}),J=e.computed((()=>W.value.length)),U=e.computed((()=>J.value>0)),Q=e.computed((()=>a.multiple?void 0===a.maxValues?1/0:Number(a.maxValues):1)),X=e.computed((()=>!q.value&&(!!a.unselectable&&(0===Number(a.minValues)||J.value>Number(a.minValues))))),Z=e.computed((()=>!q.value&&(!a.multiple||J.value<Q.value))),le=e.ref(!1),oe=e.computed((()=>le.value||F.value)),{hasIconBefore:ae,hasIconAfter:ne}=de(C,O),re=ee("vv-select",N,e.computed((()=>({disabled:E.value,required:_.value,loading:oe.value,readonly:A.value,"icon-before":void 0!==ae.value,"icon-after":void 0!==ne.value,valid:D.value,invalid:R.value,dirty:U.value,focus:g.value||y.value||S.value,floating:j.value,badges:a.badges})))),{getOptionLabel:ie,getOptionValue:ce,getOptionGrouped:ve,isOptionDisabled:pe}=$e(a);function me(e){return pe(e)||!Z.value&&!ge(e)}const be=o.computedAsync((async()=>{var e;if(i.value.searchFunction){le.value=!0;const e=await Promise.resolve(i.value.searchFunction(k.value,a.options));return le.value=!1,e}return null==(e=a.options)?void 0:e.filter((e=>ie(e).toLowerCase().includes(k.value.toLowerCase().trim())))}));function ge(e){const t=ce(e);return"object"==typeof t?W.value.some((e=>"object"==typeof e&&JSON.stringify(e)===JSON.stringify(t))):W.value.includes(t)}const he=e.computed((()=>a.options.reduce(((e,t)=>P(t)?[...e,...ve(t)]:[...e,t]),[]).filter((e=>ge(e))))),Se=e.computed((()=>he.value.map((e=>ie(e))).join(a.separator)));function Be(){a.autoOpen?x():B()}function we(e){const t=ge(e),l=ce(e);t&&X.value?W.value=W.value.filter((e=>"object"==typeof l&&"object"==typeof e?JSON.stringify(e)!==JSON.stringify(l):e!==l)):!t&&Z.value&&(a.multiple||(W.value=[]),W.value=[...W.value,l]),a.multiple||a.keepOpen||w()}e.watch((()=>a.options),(e=>{(null==e?void 0:e.length)&&a.autoselectFirst&&!U.value&&we(e[0])}),{immediate:!0});const Ve=e.computed((()=>({id:H.value,name:a.name,tabindex:K.value,valid:D.value,validLabel:i.value.validLabel,invalid:R.value,invalidLabel:i.value.invalidLabel,hintLabel:i.value.hintLabel,loading:oe.value,loadingLabel:i.value.loadingLabel,disabled:E.value,readonly:A.value,modifiers:i.value.modifiers,options:i.value.options,labelKey:i.value.labelKey,valueKey:i.value.valueKey,icon:i.value.icon,iconPosition:i.value.iconPosition,floating:i.value.floating,unselectable:X.value,autoselectFirst:i.value.autoselectFirst,multiple:i.value.multiple,label:i.value.label,placeholder:i.value.placeholder,modelValue:a.modelValue}))),Ce=e.computed((()=>({id:I.value,reference:d.value,placement:i.value.placement,strategy:i.value.strategy,transitionName:i.value.transitionName,offset:i.value.offset,shift:i.value.shift,flip:i.value.flip,autoPlacement:i.value.autoPlacement,arrow:i.value.arrow,autofocusFirst:!!i.value.searchable||i.value.autofocusFirst,triggerWidth:i.value.triggerWidth,modifiers:i.value.dropdownModifiers}))),Oe=e.computed((()=>({valid:a.valid,invalid:a.invalid,modelValue:a.modelValue})));return o.onKeyStroke([" ","Enter"],(e=>{a.autoOpen||!S.value&&g.value&&(e.preventDefault(),e.stopImmediatePropagation(),B())}),{target:u}),(t,l)=>t.native?(e.openBlock(),e.createBlock(He,e.mergeProps({key:1},e.unref(Ve),{"onUpdate:modelValue":l[3]||(l[3]=e=>n("update:modelValue",e))}),null,16)):(e.openBlock(),e.createElementBlock("div",{key:0,id:e.unref(H),class:e.normalizeClass(e.unref(re))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,id:e.unref(M),for:e.unref(i).searchable?e.unref(T):void 0},e.toDisplayString(t.label),9,Ie)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:d,class:"vv-select__wrapper"},[e.createVNode(ye,e.mergeProps({ref_key:"dropdownEl",ref:c,modelValue:e.unref(S),"onUpdate:modelValue":l[2]||(l[2]=t=>e.isRef(S)?S.value=t:null)},e.unref(Ce),{role:e.unref(p).listbox,onAfterExpand:V,onAfterCollapse:L}),e.createSlots({default:e.withCtx((({aria:l})=>[t.$slots.before?(e.openBlock(),e.createElementBlock("div",Me,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(Oe))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",qe,[e.unref(ae)?(e.openBlock(),e.createBlock(ue,e.mergeProps({key:0},e.unref(ae),{class:"vv-select__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",e.mergeProps({ref_key:"inputEl",ref:u},l,{class:"vv-select__input",role:"combobox","aria-controls":e.unref(I),"aria-expanded":e.unref(S),"aria-labelledby":e.unref(M),"aria-describedby":e.unref(f)?e.unref(z):void 0,"aria-errormessage":e.unref(m)?e.unref(z):void 0,tabindex:e.unref(K),onClickPassive:Be}),[e.renderSlot(t.$slots,"value",e.normalizeProps(e.guardReactiveProps({selectedOptions:e.unref(he),onInput:we})),(()=>[e.unref(Se)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.badges?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(e.unref(he),((l,o)=>(e.openBlock(),e.createBlock(te,{key:o,modifiers:t.badgeModifiers,class:"vv-select__badge"},{default:e.withCtx((()=>[e.createTextVNode(e.toDisplayString(e.unref(ie)(l))+" ",1),e.unref(X)?(e.openBlock(),e.createElementBlock("button",{key:0,"aria-label":e.unref(i).deselectActionLabel,type:"button",onClick:e.withModifiers((e=>we(l)),["stop"])},[e.createVNode(ue,{name:"close"})],8,Ge)):e.createCommentVNode("v-if",!0)])),_:2},1032,["modifiers"])))),128)):(e.openBlock(),e.createElementBlock("div",We,e.toDisplayString(e.unref(Se)),1))],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(t.placeholder),1)],64))]))],16,Ke),e.unref(ne)?(e.openBlock(),e.createBlock(ue,e.mergeProps({key:1},e.unref(ne),{class:"vv-select__icon vv-select__icon-after"}),null,16)):e.createCommentVNode("v-if",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Je,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(Oe))))])):e.createCommentVNode("v-if",!0)])),items:e.withCtx((()=>{var l;return[!e.unref(E)&&(null==(l=e.unref(be))?void 0:l.length)?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(e.unref(be),((l,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:o},[P(l)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createVNode(ke,{label:e.unref(ie)(l)},null,8,["label"]),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(ve)(l),((o,a)=>(e.openBlock(),e.createBlock(xe,e.mergeProps({ref_for:!0},{selected:ge(o),disabled:me(o),unselectable:e.unref(X),deselectHintLabel:e.unref(i).deselectHintLabel,selectHintLabel:e.unref(i).selectHintLabel,selectedHintLabel:e.unref(i).selectedHintLabel},{key:a,class:"vv-dropdown-option","focus-on-hover":"",onClickPassive:e=>we(o)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.mergeProps({ref_for:!0},{option:l,selectedOptions:e.unref(he),selected:ge(o),disabled:me(o)}),(()=>[e.createTextVNode(e.toDisplayString(e.unref(ie)(o)),1)]))])),_:2},1040,["onClickPassive"])))),128))],64)):(e.openBlock(),e.createBlock(xe,e.mergeProps({key:1,ref_for:!0},{selected:ge(l),disabled:me(l),unselectable:e.unref(X),deselectHintLabel:e.unref(i).deselectHintLabel,selectHintLabel:e.unref(i).selectHintLabel,selectedHintLabel:e.unref(i).selectedHintLabel},{class:"vv-dropdown-option","focus-on-hover":"",onClickPassive:e=>we(l)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.mergeProps({ref_for:!0},{option:l,selectedOptions:e.unref(he),selected:ge(l),disabled:me(l)}),(()=>[e.createTextVNode(e.toDisplayString(e.unref(ie)(l)),1)]))])),_:2},1040,["onClickPassive"]))],64)))),128)):t.options.length?e.unref(E)?e.createCommentVNode("v-if",!0):(e.openBlock(),e.createBlock(xe,{key:2,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-results",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(i).noResultsLabel),1)]))])),_:3})):(e.openBlock(),e.createBlock(xe,{key:1,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-options",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(i).noOptionsLabel),1)]))])),_:3}))]})),after:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::after",{},(()=>{var t;return[(null==(t=e.unref(c))?void 0:t.customPosition)?(e.openBlock(),e.createBlock(fe,{key:0,label:e.unref(i).closeLabel,modifiers:"secondary",onClick:l[1]||(l[1]=t=>e.unref(c).hide())},null,8,["label"])):e.createCommentVNode("v-if",!0)]}))])),_:2},[e.unref(i).searchable||t.$slots["dropdown::before"]?{name:"before",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::before"),e.unref(i).searchable&&!e.unref(E)?e.withDirectives((e.openBlock(),e.createElementBlock("input",{key:0,id:e.unref(T),ref_key:"inputSearchEl",ref:s,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(h)?h.value=t:null),"aria-autocomplete":"list","aria-controls":e.unref(I),autocomplete:"off",spellcheck:"false",type:"search",class:"vv-dropdown__search",placeholder:e.unref(i).searchPlaceholder},null,8,Te)),[[e.vModelText,e.unref(h)]]):e.createCommentVNode("v-if",!0)])),key:"0"}:void 0]),1040,["modelValue","role"])],512),e.createVNode(e.unref(v),{id:e.unref(z),class:"vv-select__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(b))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(b))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(b))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(b))))])),key:"3"}:void 0]),1032,["id"])],10,ze))}})}));
|
|
@@ -2261,34 +2261,32 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
2261
2261
|
const inputEl = el;
|
|
2262
2262
|
const innerEl = ref();
|
|
2263
2263
|
const wrapperEl = ref();
|
|
2264
|
-
const
|
|
2264
|
+
const suggestionsDropdownEl = ref();
|
|
2265
2265
|
__expose({ $inner: innerEl });
|
|
2266
2266
|
const { focused } = useComponentFocus(inputEl, emit);
|
|
2267
2267
|
const isFocused = computed(
|
|
2268
2268
|
() => focused.value && !props.disabled && !props.readonly
|
|
2269
2269
|
);
|
|
2270
2270
|
watch(isFocused, (newValue) => {
|
|
2271
|
-
var _a;
|
|
2271
|
+
var _a, _b;
|
|
2272
2272
|
if (newValue && propsDefaults.value.selectOnFocus && inputEl.value) {
|
|
2273
2273
|
inputEl.value.select();
|
|
2274
2274
|
}
|
|
2275
|
-
if (newValue) {
|
|
2276
|
-
(
|
|
2275
|
+
if (newValue && ((_a = suggestions.value) == null ? void 0 : _a.size)) {
|
|
2276
|
+
(_b = suggestionsDropdownEl.value) == null ? void 0 : _b.show();
|
|
2277
2277
|
return;
|
|
2278
2278
|
}
|
|
2279
|
-
|
|
2280
|
-
|
|
2281
|
-
|
|
2282
|
-
|
|
2283
|
-
suggestions.value
|
|
2284
|
-
|
|
2285
|
-
|
|
2286
|
-
|
|
2287
|
-
);
|
|
2288
|
-
}
|
|
2289
|
-
suggestions.value.add(localModelValue.value);
|
|
2279
|
+
if (isDirty.value && suggestions.value) {
|
|
2280
|
+
const suggestionsLimit = props.maxSuggestions;
|
|
2281
|
+
if (suggestions.value.size >= suggestionsLimit && !suggestions.value.has(localModelValue.value)) {
|
|
2282
|
+
suggestions.value = new Set(
|
|
2283
|
+
[...suggestions.value].slice(
|
|
2284
|
+
suggestions.value.size - suggestionsLimit + 1
|
|
2285
|
+
)
|
|
2286
|
+
);
|
|
2290
2287
|
}
|
|
2291
|
-
|
|
2288
|
+
suggestions.value.add(localModelValue.value);
|
|
2289
|
+
}
|
|
2292
2290
|
});
|
|
2293
2291
|
const isVisible = useElementVisibility(inputEl);
|
|
2294
2292
|
watch(isVisible, (newValue) => {
|
|
@@ -2386,7 +2384,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
2386
2384
|
function onSuggestionSelect(suggestion) {
|
|
2387
2385
|
var _a;
|
|
2388
2386
|
localModelValue.value = suggestion;
|
|
2389
|
-
(_a =
|
|
2387
|
+
(_a = suggestionsDropdownEl.value) == null ? void 0 : _a.hide();
|
|
2390
2388
|
}
|
|
2391
2389
|
function onSuggestionRemove(suggestion) {
|
|
2392
2390
|
var _a;
|
|
@@ -2648,8 +2646,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
2648
2646
|
]), 1032, ["id"]),
|
|
2649
2647
|
unref(hasSuggestions) ? (openBlock(), createBlock(_sfc_main$4, {
|
|
2650
2648
|
key: 1,
|
|
2651
|
-
ref_key: "
|
|
2652
|
-
ref:
|
|
2649
|
+
ref_key: "suggestionsDropdownEl",
|
|
2650
|
+
ref: suggestionsDropdownEl,
|
|
2653
2651
|
reference: unref(wrapperEl),
|
|
2654
2652
|
"autofocus-first": false,
|
|
2655
2653
|
"trigger-width": true
|
|
@@ -1 +1 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("vue-imask"),require("@floating-ui/vue"),require("@vueuse/core"),require("mitt"),require("@iconify/vue")):"function"==typeof define&&define.amd?define(["vue","vue-imask","@floating-ui/vue","@vueuse/core","mitt","@iconify/vue"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvInputText=t(e.vue,e.vueImask,e.vue$1,e.core,e.mitt,e.vue$2)}(this,(function(e,t,o,l,a,n){"use strict";function i(t){return null==(o=e.unref(t))||""===o||Array.isArray(o)&&0===o.length||!(o instanceof Date)&&"object"==typeof o&&0===Object.keys(o).length;var o}function r(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}var u=(e=>(e.local="local",e.session="session",e))(u||{}),s=(e=>(e.absolute="absolute",e.fixed="fixed",e))(s||{}),d=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(d||{}),c=(e=>(e.topStart="top-start",e.topEnd="top-end",e.bottomStart="bottom-start",e.bottomEnd="bottom-end",e.leftStart="left-start",e.leftEnd="left-end",e.rightStart="right-start",e.rightEnd="right-end",e))(c||{}),v=(e=>(e.before="before",e.after="after",e))(v||{}),p=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(p||{}),f=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(f||{}),m=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(m||{}),b=(e=>(e.listbox="listbox",e.menu="menu",e))(b||{}),h=(e=>(e.option="option",e.presentation="presentation",e))(h||{});const g=Symbol.for("volver"),y=Symbol.for("dropdownTrigger"),S=Symbol.for("dropdownItem"),w=Symbol.for("dropdownAction"),k={valid:{type:Boolean,default:!1},validLabel:{type:[String,Array],default:void 0}},x={invalid:{type:Boolean,default:!1},invalidLabel:{type:[String,Array],default:void 0}},E={loading:{type:Boolean,default:!1},loadingLabel:{type:String,default:"Loading..."}},L={disabled:{type:Boolean,default:!1}},B={required:{type:Boolean,default:!1}},$={selected:{type:Boolean,default:!1}},C=(Boolean,Boolean,Boolean,{label:{type:[String,Number],default:void 0}}),P={readonly:{type:Boolean,default:!1}},O={modifiers:{type:[String,Array],default:void 0}},N={hintLabel:{type:String,default:""}},T={count:{type:[Boolean,String],default:!1,validator:e=>[!0,!1,"limit","countdown"].includes(e)}},V={debounce:{type:[Number,String],default:void 0}},A={icon:{type:[String,Object],default:void 0},iconPosition:{type:String,default:v.before,validation:e=>Object.values(v).includes(e)}},_={tabindex:{type:[String,Number],default:0}},D={floating:{type:Boolean,default:!1}},I={unselectable:{type:Boolean,default:!0}},R={id:[String,Number]},M={placement:{type:String,default:d.bottom,validator:e=>Object.values(d).includes(e)||Object.values(c).includes(e)},strategy:{type:String,default:void 0,validator:e=>Object.values(s).includes(e)},transitionName:{type:String,default:void 0},offset:{type:[Number,String,Object],default:0},shift:{type:[Boolean,Object],default:!1},flip:{type:[Boolean,Object],default:!0},size:{type:[Boolean,Object],default:()=>({padding:10})},autoPlacement:{type:[Boolean,Object],default:!1},arrow:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean,default:!1}},H={...{...R,name:{type:String,required:!0}},...{autofocus:{type:Boolean,default:!1}},...{autocomplete:{type:String,default:"off"}},..._,...L,...P,...k,...x,...N,...E,...O,...T,...V,...A,...D,...C,minlength:{type:[String,Number],default:void 0},maxlength:{type:[String,Number],default:void 0},placeholder:{type:String,default:void 0},...B};p.button,f.button;const j={storageType:{type:String,default:u.local,validator:e=>Object.values(u).includes(e)},storageKey:String},z={...R,...M,...O,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:b.menu,validator:e=>Object.values(b).includes(e)}},U={focusOnHover:{type:Boolean,default:!1}},F={...L,...$,...I,...O,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String},focusOnHover:{type:Boolean,default:!1}};function W(t){return e.computed((()=>String((null==t?void 0:t.value)||e.useId())))}function q(t,o,l){return e.computed((()=>{const a={[t]:!0},n="string"==typeof(null==o?void 0:o.value)?o.value.split(" "):null==o?void 0:o.value;return n&&Array.isArray(n)&&n.forEach((e=>{e&&(a[`${t}--${e}`]=!0)})),l&&Object.keys(l.value).forEach((o=>{a[`${t}--${o}`]=e.unref(l.value[o])})),a}))}const K=["id","tabindex","role","aria-labelledby"],X=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:z,emits:["update:modelValue","beforeEnter","afterLeave","beforeExpand","beforeCollapse","afterExpand","afterCollapse","before-enter","after-leave","enter","afterEnter","enterCancelled","beforeLeave","leave","leaveCancelled"],setup(t,{expose:n,emit:i}){const r=t,u=i,{id:c}=e.toRefs(r),v=W(c),p=e.useAttrs(),f=e.ref("auto"),m=e.ref("auto"),g=e.ref(),w=e.ref(),k=e.ref(),x=e.ref(),E=e.computed({get:()=>r.reference??g.value,set:e=>{g.value=e}}),L=e.ref(!1);e.onMounted((()=>{l.useMutationObserver(w.value,(()=>{var e;L.value="true"===(null==(e=window.getComputedStyle(w.value).getPropertyValue("--dropdown-custom-position"))?void 0:e.trim())}),{attributeFilter:["style"],window:window})}));const B=e.computed((()=>{const e=[];if(r.autoPlacement?"boolean"==typeof r.autoPlacement?e.push(o.autoPlacement()):e.push(o.autoPlacement(r.autoPlacement)):r.flip&&("boolean"==typeof r.flip?e.push(o.flip({fallbackStrategy:"initialPlacement"})):e.push(o.flip(r.flip))),r.shift&&("boolean"==typeof r.shift?e.push(o.shift()):e.push(o.shift(r.shift))),r.size){const t=({availableWidth:e,availableHeight:t})=>{f.value=`${e}px`,m.value=`${t}px`};"boolean"==typeof r.size?e.push(o.size({apply:t})):e.push(o.size({...r.size,apply:t}))}return r.offset&&(e.push(o.offset(Number(r.offset))),["string","number"].includes(typeof r.offset)?e.push(o.offset(Number(r.offset))):e.push(o.offset(r.offset))),r.arrow&&e.push(o.arrow({element:k})),e})),{x:$,y:C,middlewareData:P,placement:O,strategy:N}=o.useFloating(E,w,{whileElementsMounted:(...e)=>o.autoUpdate(...e,{animationFrame:r.strategy===s.fixed}),placement:e.computed((()=>r.placement)),strategy:e.computed((()=>r.strategy)),middleware:B}),T=e.computed((()=>{var e;if(L.value)return;const t=r.triggerWidth&&E.value?`${null==(e=E.value)?void 0:e.offsetWidth}px`:void 0;return{position:N.value,top:`${C.value??0}px`,left:`${$.value??0}px`,maxWidth:t?void 0:f.value,maxHeight:m.value,width:t}})),V=e.computed((()=>O.value.split("-")[0])),A=e.computed((()=>{var e,t,o,l,a;if(L.value)return;const n={[d.top]:d.bottom,[d.right]:d.left,[d.bottom]:d.top,[d.left]:d.right}[V.value];return{left:void 0!==(null==(e=P.value.arrow)?void 0:e.x)?`${null==(t=P.value.arrow)?void 0:t.x}px`:void 0,top:void 0!==(null==(o=P.value.arrow)?void 0:o.y)?`${null==(l=P.value.arrow)?void 0:l.y}px`:void 0,[n]:-((null==(a=k.value)?void 0:a.offsetWidth)??0)/2+"px"}})),_=l.useVModel(r,"modelValue",u),D=e.ref(!1),I=e.computed({get:()=>_.value??D.value,set:e=>{void 0!==_.value?_.value=e:D.value=e}});function R(){I.value=!0}function M(){I.value=!1}function H(){I.value=!I.value}function j(e){E.value=e}n({toggle:H,show:R,hide:M,init:j,customPosition:L}),e.watch(I,(t=>{t&&r.autofocusFirst&&e.nextTick((()=>{const e=Z(w.value);e.length>0&&e[0].focus({preventScroll:!0})}))})),l.onClickOutside(w,(()=>{!r.keepOpen&&I.value&&(I.value=!1)}),{ignore:[E]});const z=e.computed((()=>{var e,t;return(null==(t=null==(e=E.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),U=e.computed((()=>({"aria-controls":v.value,"aria-haspopup":!0,"aria-expanded":I.value}))),{component:F,bus:X}=function({reference:t,id:o,expanded:l,aria:n}){const i=a(),r=e.defineComponent({name:"VvDropdownTriggerProvider",setup(){e.provide(y,{reference:t,id:o,expanded:l,aria:n,bus:i})},render(){var t,o;return e.h(e.Fragment,{},null==(o=(t=this.$slots).default)?void 0:o.call(t))}});return{bus:i,component:r}}({reference:E,id:v,expanded:I,aria:U});X.on("click",H);const{role:J,modifiers:Y}=e.toRefs(r),G=q("vv-dropdown",Y,e.computed((()=>({arrow:r.arrow})))),{focused:Q}=l.useFocusWithin(w);function Z(e){return e?[...e.querySelectorAll('a[href], button, input, textarea, select, details, [tabindex]:not([tabindex="-1"])')].filter((e=>!e.hasAttribute("disabled")&&!e.getAttribute("aria-hidden"))):[]}const ee=l.useElementHover(w),{itemRole:te}=function({role:t,...o}){const l=e.computed((()=>t.value===b.listbox?h.option:h.presentation));return e.provide(S,{role:l,...o}),{itemRole:l}}({role:J,expanded:I,focused:Q,hovered:ee});l.onKeyStroke("Escape",(e=>{I.value&&(e.preventDefault(),M())})),l.onKeyStroke("ArrowDown",(t=>{I.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=Z(w.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus({preventScroll:!0}):e[0].focus({preventScroll:!0})}})))})),l.onKeyStroke("ArrowUp",(t=>{I.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=Z(w.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus({preventScroll:!0}):e[e.length-1].focus({preventScroll:!0})}})))})),l.onKeyStroke([" ","Enter"],(e=>{const t=e.target;I.value&&Q.value&&t&&(null==t||t.click())}));const oe={"before-enter":()=>{u(I.value?"beforeExpand":"beforeCollapse"),u("beforeEnter")},"after-leave":()=>{u(I.value?"afterExpand":"afterCollapse"),u("afterLeave")},enter:()=>{u("enter")},"after-enter":()=>{u("afterEnter")},"enter-cancelled":()=>{u("enterCancelled")},"before-leave":()=>{u("beforeLeave")},leave:()=>{u("leave")},"leave-cancelled":()=>{u("leaveCancelled")}};return(t,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(F),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:j,show:R,hide:M,toggle:H,expanded:e.unref(I),aria:e.unref(U)})))])),_:3}),e.createVNode(e.Transition,e.mergeProps({name:t.transitionName},e.toHandlers(oe),{persisted:""}),{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:w,style:e.normalizeStyle(e.unref(T)),class:e.normalizeClass(e.unref(G))},[r.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:k,style:e.normalizeStyle(e.unref(A)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(I)}))),e.createElementVNode("div",e.mergeProps(e.unref(p),{id:e.unref(v),ref_key:"listEl",ref:x,tabindex:e.unref(I)?void 0:-1,role:e.unref(J),"aria-labelledby":e.unref(z),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(te)})))],16,K),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(I)})))],6),[[e.vShow,e.unref(I)]])])),_:3},16,["name"])],64))}});const J=e.defineComponent({name:"VvDropdownItem",props:U,setup(t){const o=t,{role:a,expanded:n}=e.inject(S,{}),i=e.ref(null);!function({expanded:t}){e.provide(w,{role:e.ref(m.menuitem),expanded:t})}({expanded:n});const r=l.useElementHover(i),{focused:u}=l.useFocus(i),{focused:s}=l.useFocusWithin(i);return e.watch(r,(e=>{e&&o.focusOnHover&&(u.value=!0)})),(t,o)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({role:e.unref(a)},{ref_key:"element",ref:i,class:["vv-dropdown__item",{"focus-visible":e.unref(u)||e.unref(s)}]}),[e.renderSlot(t.$slots,"default")],16))}}),Y=["title"],G=e.defineComponent({name:"VvDropdownOption",props:F,setup(t){const o=t,{modifiers:l}=e.toRefs(o),a=q("vv-dropdown-option",l,e.computed((()=>({disabled:o.disabled,selected:o.selected,unselectable:o.unselectable&&o.selected})))),n=e.computed((()=>o.selected?o.unselectable?o.deselectHintLabel:o.selectedHintLabel:o.disabled?"":o.selectHintLabel));return(t,o)=>(e.openBlock(),e.createBlock(J,{class:e.normalizeClass(e.unref(a)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled,"focus-on-hover":t.focusOnHover},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default"),e.createElementVNode("span",{class:"vv-dropdown-option__hint",title:e.unref(n)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(n)),1)]))],8,Y)])),_:3},8,["class","tabindex","aria-selected","aria-disabled","focus-on-hover"]))}}),Q="eye-on",Z="eye-off",ee="calendar",te="time",oe="color",le="close",ae="trash",ne={prefix:"normal"};function ie(){return e.inject(g)}const re=e.defineComponent({name:"VvIcon",props:e.mergeDefaults({name:{},color:{},width:{},height:{},provider:{},prefix:{},src:{},horizontalFlip:{type:Boolean},verticalFlip:{type:Boolean},flip:{},mode:{},inline:{type:Boolean},rotate:{},onLoad:{type:Function},svg:{},modifiers:{}},ne),setup(t){const o=t,l=e.computed((()=>"string"==typeof o.rotate?Number.parseFloat(o.rotate):o.rotate)),a=e.ref(!0),i=ie(),{modifiers:r}=e.toRefs(o),u=q("vv-icon",r),s=e.computed((()=>o.provider||(null==i?void 0:i.iconsProvider))),d=e.computed((()=>{const e=o.name??"",t=`@${s.value}:${o.prefix}:${e}`;if(n.iconExists(t))return t;const l=null==i?void 0:i.iconsCollections.find((t=>{const o=`@${s.value}:${t.prefix}:${e}`;return n.iconExists(o)}));return l?`@${s.value}:${l.prefix}:${e}`:e}));function c(e){const t=function(e){let t;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");t=(new e).window}return(t?new t.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),l=(null==t?void 0:t.innerHTML.trim())||"";t&&l&&n.addIcon(`@${s.value}:${o.prefix}:${o.name}`,{body:l,height:t.viewBox.baseVal.height,width:t.viewBox.baseVal.width})}return i&&o.src&&!n.iconExists(`@${s.value}:${o.prefix}:${o.name}`)&&(a.value=!1,i.fetchIcon(o.src).then((e=>{e&&(c(e),a.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),o.svg&&c(o.svg),(t,o)=>e.unref(a)?(e.openBlock(),e.createBlock(e.unref(n.Icon),e.mergeProps({key:0,class:e.unref(u)},{inline:t.inline,width:t.width,height:t.height,horizontalFlip:t.horizontalFlip,verticalFlip:t.verticalFlip,flip:t.flip,rotate:e.unref(l),color:t.color,onLoad:t.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}}),ue={TEXT:"text",PASSWORD:"password",NUMBER:"number",EMAIL:"email",TEL:"tel",URL:"url",COLOR:"color",SEARCH:"search",DATE:"date",TIME:"time",DATETIME_LOCAL:"datetime-local",MONTH:"month",WEEK:"week"},se={...H,...j,modelValue:[String,Number],type:{type:String,default:ue.TEXT,validator:e=>Object.values(ue).includes(e)},min:[Number,Date,String],max:[Number,Date,String],step:{type:[String,Number],default:1},pattern:String,multiple:Boolean,iconShowPassword:{type:[String,Object],default:Q},iconHidePassword:{type:[String,Object],default:Z},iconClear:{type:[String,Object],default:le},iconRemoveSuggestion:{type:[String,Object],default:ae},labelStepUp:{type:String,default:"Increase value"},labelStepDown:{type:String,default:"Decrease value"},labelShowPassword:{type:String,default:"Show password"},labelHidePassword:{type:String,default:"Hide password"},labelClear:{type:String,default:"Clear"},labelRemoveSuggestion:{type:String,default:"Remove suggestion"},iMask:{type:Object,default:void 0},masked:{type:String,default:void 0},autoWidth:{type:Boolean,default:!1},hideActions:{type:Boolean,default:!1},unit:{type:String},selectOnFocus:{type:Boolean,default:!1},maxSuggestions:{type:Number,default:5}};function de(t,o){const l=e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),a=e.computed((()=>(null==o?void 0:o.value)===v.before?l.value:void 0)),n=e.computed((()=>(null==o?void 0:o.value)===v.after?l.value:void 0)),i=e.computed((()=>(null==o?void 0:o.value)===d.left?l.value:void 0)),r=e.computed((()=>(null==o?void 0:o.value)===d.right?l.value:void 0)),u=e.computed((()=>(null==o?void 0:o.value)===d.top?l.value:void 0)),s=e.computed((()=>(null==o?void 0:o.value)===d.bottom?l.value:void 0));return{hasIcon:l,hasIconLeft:i,hasIconRight:r,hasIconTop:u,hasIconBottom:s,hasIconBefore:a,hasIconAfter:n}}const ce=e.defineComponent({components:{VvIcon:re},props:{disabled:{type:Boolean,default:!1},label:{type:String,default:"Clear"},icon:{type:[String,Object],default:"close"}},emits:["clear"],setup(t,{emit:o}){const{hasIcon:l}=de(e.computed((()=>t.icon)));return{hasIcon:l,onClick:function(e){null==e||e.stopPropagation(),t.disabled||o("clear")}}},render(){const t=this.hasIcon?e.h(re,{...this.hasIcon,class:"vv-input-text__icon"}):void 0;return e.h("button",{disabled:this.disabled,class:"vv-input-text__action",ariaLabel:this.label,type:"button",onClick:this.onClick},t)}}),ve=e.defineComponent({components:{VvIcon:re},props:{disabled:{type:Boolean,default:!1},labelShow:{type:String,default:"Show password"},labelHide:{type:String,default:"Hide password"},iconShow:{type:[String,Object],default:Q},iconHide:{type:[String,Object],default:Z}},emits:["toggle-password"],setup(t,{emit:o}){const l=e.ref(!1),a=e.computed((()=>l.value?t.iconHide:t.iconShow)),{hasIcon:n}=de(a);return{active:l,activeIcon:a,hasIcon:n,onClick:function(e){null==e||e.stopPropagation(),t.disabled||(l.value=!l.value,o("toggle-password",l.value))}}},render(){const t=this.hasIcon?e.h(re,{...this.hasIcon,class:"vv-input-text__icon"}):void 0;return e.h("button",{disabled:this.disabled,class:"vv-input-text__action",ariaLabel:this.active?this.labelHide:this.labelShow,type:"button",onClick:this.onClick},t)}}),pe=e.defineComponent({components:{VvIcon:re},props:{disabled:{type:Boolean,default:!1},label:{type:String},mode:{type:String,validator:e=>["up","down"].includes(e),default:"up"}},emits:["step-up","step-down"],setup(t,{emit:o}){const l=e.computed((()=>"up"===t.mode));return{isUp:l,onClick:e=>{null==e||e.stopPropagation(),t.disabled||o(l.value?"step-up":"step-down")}}},render(){return e.h("button",{class:["vv-input-text__action vv-input-text__action-chevron",this.isUp&&"vv-input-text__action-chevron-up"],disabled:this.disabled,ariaLabel:this.label,type:"button",onClick:this.onClick})}});function fe(t,o){return{name:"VvInputTextActions",components:{VvIcon:re,VvInputPasswordAction:ve,VvInputStepAction:pe,VvInputClearAction:ce},setup:()=>({isDisabled:e.computed((()=>o.disabled||o.readonly)),labelStepUp:o.labelStepUp,labelStepDown:o.labelStepDown,labelShowPassword:o.labelShowPassword,labelHidePassword:o.labelHidePassword,labelClear:o.labelClear,iconShowPassword:o.iconShowPassword,iconHidePassword:o.iconHidePassword}),render(){let l=null;switch(t){case ue.SEARCH:{const{onClear:t}=this.$attrs;l=[e.h(ce,{disabled:this.isDisabled,label:this.labelShowPassword,onClear:t})];break}case ue.PASSWORD:{const{onTogglePassword:t}=this.$attrs;l=[e.h(ve,{disabled:this.isDisabled,onTogglePassword:t,labelShow:this.labelShowPassword,labelHide:this.labelHidePassword,iconShow:this.iconShowPassword,iconHide:this.iconHidePassword})];break}case ue.NUMBER:{const{onStepUp:t,onStepDown:a}=this.$attrs;l=[e.h(pe,{mode:"up",disabled:this.isDisabled||void 0!==o.max&&o.modelValue===o.max,label:this.labelStepUp,onStepUp:t,onStepDown:a}),e.h(pe,{mode:"down",disabled:this.isDisabled||void 0!==o.min&&o.modelValue===o.min,label:this.labelStepDown,onStepUp:t,onStepDown:a})];break}}return Array.isArray(l)?e.h("div",{class:"vv-input-text__actions-group"},l):l}}}const me=["for"],be={key:0,class:"vv-input-text__input-before"},he=["id"],ge={key:1,class:"vv-input-text__unit"},ye={key:5,class:"vv-input-text__input-after"},Se={key:6,class:"vv-input-text__limit"},we={class:"flex-1"},ke=["title","onClick"];return e.defineComponent({name:"VvInputText",props:se,emits:["update:modelValue","update:masked","accept","accept:typed","accept:masked","accept:unmasked","complete","complete:typed","complete:masked","complete:unmasked","focus","blur","keyup","keydown","keypress"],setup(o,{expose:a,emit:n}){const s=o,d=n,c=e.useSlots(),v=function(t,o,l){const a=ie(),n=e.computed((()=>{var e;if(a&&(null==(e=a.defaults.value)?void 0:e[t]))return a.defaults.value[t]}));return e.computed((()=>{if(void 0===n.value)return l;const e=n.value,t=o,a=l;return Object.keys(t).reduce(((o,l)=>{const n=a[l];if(o[l]=n,l in e){if(Array.isArray(t[l])){const a=t[l];a.length&&a[0]===n&&(o[l]=e[l])}if("function"==typeof t[l]&&(0,t[l])()===n&&(o[l]=e[l]),"object"==typeof t[l]){let a=t[l].default;"function"==typeof a&&(a=a()),"object"==typeof a?JSON.stringify(a)===JSON.stringify(n)&&(o[l]=e[l]):a===n&&(o[l]=e[l])}}return o}),{})}))}("VvInputText",se,s),{count:p,debounce:f,icon:m,iconPosition:b,iconRemoveSuggestion:h,id:g,invalid:y,label:S,loading:w,maxlength:k,minlength:x,modelValue:E,step:L,storageKey:B,storageType:$,type:C,valid:P}=e.toRefs(s),O=W(g),N=e.computed((()=>`${O.value}-hint`)),T=e.computed((()=>s.floating&&i(s.placeholder)?" ":s.placeholder)),V=function(t,o,l=0,{getter:a=e=>e,setter:n=e=>e}={}){let i;return"string"==typeof l&&(l=Number.parseInt(l)),e.computed({get:()=>a(null==t?void 0:t.value),set:e=>{i&&clearTimeout(i),i=setTimeout((()=>{o("update:modelValue",n(e))}),l)}})}(E,d,(null==f?void 0:f.value)??0),A=/^-0?[.,]?[0*]?$/,_=e.ref(!1),{el:D,mask:I,typed:R,masked:M,unmasked:H}=t.useIMask(e.computed((()=>{if(!s.iMask)return{mask:/./};if(s.iMask.mask===Number){const e={...s.iMask};return s.min&&(e.min=Number(s.min)),s.max&&(e.max=Number(s.max)),e}return s.iMask})),{emit:d,onAccept:()=>{if(_.value){if(d("update:masked",M.value),C.value===ue.NUMBER){if(/^-$|^$/.test(H.value)){if(null===V.value||void 0===V.value)return;return void(V.value=void 0)}return A.test(H.value)?void(V.value=0):"number"!=typeof R.value?void(V.value=Number(R.value)):void(V.value=R.value)}if(C.value===ue.DATE){if(D.value instanceof HTMLInputElement&&"date"===D.value.type)return void(V.value=D.value.value);let e=R.value;if(null===e||""===e){if(!V.value)return;return void(V.value="")}return e instanceof Date||(e=new Date(e)),void(V.value=`${e.getFullYear()}-${`0${e.getMonth()+1}`.slice(-2)}-${`0${e.getDate()}`.slice(-2)}`)}if(C.value===ue.DATETIME_LOCAL){if(D.value instanceof HTMLInputElement&&"datetime-local"===D.value.type)return void(V.value=D.value.value);let e=R.value;if(null===e||""===e){if(!V.value)return;return void(V.value="")}return R.value instanceof Date||(e=new Date(e)),void(V.value=`${e.getFullYear()}-${`0${e.getMonth()+1}`.slice(-2)}-${`0${e.getDate()}`.slice(-2)}T${`0${e.getHours()}`.slice(-2)}:${`0${e.getMinutes()}`.slice(-2)}`)}(V.value||H.value)&&(V.value=H.value)}}});function j(e){var t;if(null==e)return R.value="",void(H.value="");(null==(t=s.iMask)?void 0:t.mask)!==Date?C.value===ue.NUMBER&&A.test(H.value)&&0===e||(R.value=e,H.value=`${R.value}`):R.value=new Date(e)}e.onMounted((()=>{I.value&&(_.value=!0,j(s.modelValue))})),e.watch((()=>s.modelValue),(e=>{I.value&&j(e)})),e.watch((()=>s.masked),(e=>{M.value=e??""}));const z=D,U=e.ref(),F=e.ref(),K=e.ref();a({$inner:U});const{focused:J}=function(t,o){const{focused:a}=l.useFocus(t);return e.watch(a,(l=>{o(l?"focus":"blur",e.unref(t))})),{focused:a}}(z,d),Y=e.computed((()=>J.value&&!s.disabled&&!s.readonly));e.watch(Y,(e=>{var t;e&&v.value.selectOnFocus&&z.value&&z.value.select(),e?null==(t=K.value)||t.show():setTimeout((()=>{if(Te.value&&Ae.value){const e=s.maxSuggestions-1;Ae.value.size>e&&!Ae.value.has(V.value)&&(Ae.value=new Set([...Ae.value].slice(Ae.value.size-e))),Ae.value.add(V.value)}}),300)}));const Q=l.useElementVisibility(z);e.watch(Q,(e=>{e&&s.autofocus&&!s.disabled&&!s.readonly&&(J.value=!0)}));const Z=e.ref(!1),le=e.computed((()=>s.type===ue.PASSWORD));function ae(){Z.value=!Z.value}const ne=e.computed((()=>s.type===ue.TIME||s.type===ue.DATETIME_LOCAL||s.type===ue.DATE||s.type===ue.WEEK||s.type===ue.MONTH)),ce=e.computed((()=>s.type===ue.NUMBER));function ve(){if(Oe.value){if(s.iMask)return void(R.value=Number(R.value)+Number((null==L?void 0:L.value)??1));z.value.stepUp(),V.value=Number(e.unref(z).value)}}function pe(){if(Oe.value){if(s.iMask)return void(R.value=Number(R.value)-Number((null==L?void 0:L.value)??1));z.value.stepDown(),V.value=Number(e.unref(z).value)}}const xe=e.computed((()=>s.type===ue.SEARCH));function Ee(){V.value=""}const{hasIconBefore:Le,hasIconAfter:Be}=de(m,b),$e=e.computed((()=>{if(void 0!==Be.value)return Be.value;switch(s.type){case ue.COLOR:return{name:oe};case ue.DATE:case ue.DATETIME_LOCAL:case ue.WEEK:case ue.MONTH:return{name:ee};case ue.TIME:return{name:te}}})),{hasIcon:Ce}=de(h),{formatted:Pe}=function(t,o){const l=e.computed((()=>(e.unref(t)??"").length)),a=e.computed((()=>void 0!==(null==o?void 0:o.lowerLimit)&&l.value<(null==o?void 0:o.lowerLimit)?l.value-o.lowerLimit:void 0!==(null==o?void 0:o.upperLimit)&&l.value<(null==o?void 0:o.upperLimit)?o.upperLimit-l.value:0)),n=e.computed((()=>{if(!1===(null==o?void 0:o.mode))return"";if("limit"===(null==o?void 0:o.mode)&&(null==o?void 0:o.upperLimit))return`${l.value} / ${o.lowerLimit?`${o.lowerLimit}-`:""}${o.upperLimit}`;if("countdown"===(null==o?void 0:o.mode)){if(0===a.value)return;return a}return l.value}));return{length:l,gap:a,formatted:n}}(V,{mode:p.value,upperLimit:Number(null==k?void 0:k.value),lowerLimit:Number(null==x?void 0:x.value)}),Oe=e.computed((()=>!s.disabled&&!s.readonly)),Ne=e.computed((()=>Oe.value?s.tabindex:-1)),Te=e.computed((()=>!i(E))),Ve=e.computed((()=>!0===y.value||!0!==P.value&&void 0)),Ae=function(t,o=u.local,a){const n=e.ref();let i;return a&&(n.value=a),t&&e.watch(t,((t,a)=>{const r=e.unref(o)===u.session?sessionStorage:localStorage;a&&a!==t&&r.removeItem(a),i=t?l.useStorage(t,(null==i?void 0:i.value)??n.value,r):void 0}),{immediate:!0}),e.isRef(o)&&e.watch(o,((e,o)=>{if(null==t?void 0:t.value){if(e){const o=e===u.session?sessionStorage:localStorage;i=l.useStorage(t.value,(null==i?void 0:i.value)??n.value,o)}o&&o!==e&&(o===u.session?sessionStorage:localStorage).removeItem(t.value)}})),e.computed({get:()=>(null==i?void 0:i.value)??n.value,set:e=>{i?i.value=e:n.value=e}})}(B,$,new Set),_e=e.computed((()=>Ae.value?[...Ae.value].filter((e=>i(V.value)||`${e}`.toLowerCase().includes(`${V.value}`.toLowerCase())&&e!==V.value)).reverse():[])),De=e.computed((()=>(null==B?void 0:B.value)&&Ae.value&&Ae.value.size>0));const{modifiers:Ie}=e.toRefs(s),Re=q("vv-input-text",Ie,e.computed((()=>({valid:P.value,invalid:y.value,loading:w.value,disabled:s.disabled,required:s.required,readonly:s.readonly,"icon-before":!!Le.value,"icon-after":!!$e.value,floating:s.floating&&!i(s.label),dirty:Te.value,focus:Y.value,"auto-width":s.autoWidth})))),Me=e.computed((()=>{const e=le.value&&Z.value?ue.TEXT:!ne.value||Te.value||J.value?s.iMask?ue.TEXT:s.type:ue.TEXT,t={type:e,name:s.name,tabindex:Ne.value,disabled:s.disabled,readonly:s.readonly,required:s.required,autocomplete:s.autocomplete,"aria-invalid":Ve.value,"aria-describedby":ze.value?N.value:void 0,"aria-errormessage":Ue.value?N.value:void 0};if(e===ue.DATE||e===ue.MONTH||e===ue.WEEK||e===ue.TIME||e===ue.DATETIME_LOCAL||e===ue.NUMBER){let o=s.max;e!==ue.DATE||o||(o="9999-12-31"),t.step=s.step,t.max=void 0!==o?String(o):void 0,t.min=void 0!==s.min?String(s.min):void 0}return e!==ue.TEXT&&e!==ue.SEARCH&&e!==ue.URL&&e!==ue.TEL&&e!==ue.EMAIL&&e!==ue.PASSWORD&&e!==ue.NUMBER||(t.placeholder=T.value),e!==ue.TEXT&&e!==ue.SEARCH&&e!==ue.URL&&e!==ue.TEL&&e!==ue.EMAIL&&e!==ue.PASSWORD||(t.minlength=s.minlength,t.maxlength=s.maxlength,t.pattern=s.pattern),e===ue.EMAIL&&(t.multiple=s.multiple),t})),He=e.computed((()=>({valid:s.valid,invalid:s.invalid,modelValue:s.modelValue,togglePassword:ae,stepUp:ve,stepDown:pe,clear:Ee}))),{HintSlot:je,hasHintLabelOrSlot:ze,hasInvalidLabelOrSlot:Ue,hintSlotScope:Fe}=function(t,o){const l=e.computed((()=>e.isRef(t)?t.value:t)),a=e.computed((()=>r(l.value.invalidLabel))),n=e.computed((()=>r(l.value.validLabel))),i=e.computed((()=>l.value.loadingLabel)),u=e.computed((()=>l.value.hintLabel)),s=e.computed((()=>Boolean(l.value.loading&&(o.loading||i.value)))),d=e.computed((()=>!s.value&&Boolean(l.value.invalid&&(o.invalid||a.value)))),c=e.computed((()=>!s.value&&!d.value&&Boolean(l.value.valid&&(o.valid||n.value)))),v=e.computed((()=>!s.value&&!d.value&&!c.value&&Boolean(o.hint||u.value))),p=e.computed((()=>d.value||c.value||s.value||v.value)),f=e.computed((()=>({modelValue:l.value.modelValue,valid:l.value.valid,invalid:l.value.invalid,loading:l.value.loading}))),m=e.defineComponent({name:"HintSlot",props:{tag:{type:String,default:"small"}},setup:()=>({isVisible:p,invalidLabel:a,validLabel:n,loadingLabel:i,hintLabel:u,hasInvalidLabelOrSlot:d,hasValidLabelOrSlot:c,hasLoadingLabelOrSlot:s,hasHintLabelOrSlot:v}),render(){var t,o,l,a,n,i,r,u;if(this.isVisible){let s;return this.hasInvalidLabelOrSlot&&(s="alert"),this.hasValidLabelOrSlot&&(s="status"),this.hasLoadingLabelOrSlot?e.h(this.tag,{role:s},(null==(o=(t=this.$slots).loading)?void 0:o.call(t))??this.loadingLabel):this.hasInvalidLabelOrSlot?e.h(this.tag,{role:s},(null==(a=(l=this.$slots).invalid)?void 0:a.call(l))??this.$slots.invalid??this.invalidLabel):this.hasValidLabelOrSlot?e.h(this.tag,{role:s},(null==(i=(n=this.$slots).valid)?void 0:i.call(n))??this.validLabel):e.h(this.tag,{role:s},(null==(u=(r=this.$slots).hint)?void 0:u.call(r))??this.$slots.hint??this.hintLabel)}return null}});return{hasInvalidLabelOrSlot:d,hasHintLabelOrSlot:v,hasValidLabelOrSlot:c,hasLoadingLabelOrSlot:s,hintSlotScope:f,HintSlot:m}}(v,c),We=fe(ue.PASSWORD,s),qe=fe(ue.NUMBER,s),Ke=fe(ue.SEARCH,s);function Xe(){Oe.value&&(J.value=!0)}const Je=e.computed((()=>{if(s.autoWidth)return{width:void 0!==V.value?`${String(V.value).length+1}ch`:void 0}}));function Ye(e){switch(e.code){case"ArrowUp":ce.value&&(ve(),e.preventDefault());break;case"ArrowDown":ce.value&&(pe(),e.preventDefault())}d("keydown",e)}return(t,o)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref(Re))},[e.unref(S)?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(O),class:"vv-input-text__label"},e.toDisplayString(e.unref(S)),9,me)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:F,class:"vv-input-text__wrapper"},[t.$slots.before?(e.openBlock(),e.createElementBlock("div",be,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(He))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"innerEl",ref:U,class:"vv-input-text__inner",onClick:e.withModifiers(Xe,["stop"])},[e.unref(Le)?(e.openBlock(),e.createBlock(re,e.mergeProps({key:0},e.unref(Le),{class:"vv-input-text__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.createElementVNode("input",e.mergeProps({id:e.unref(O),ref_key:"inputEl",ref:z},e.unref(Me),{style:e.unref(Je),onKeyup:o[0]||(o[0]=e=>d("keyup",e)),onKeydown:Ye,onKeypress:o[1]||(o[1]=e=>d("keypress",e))}),null,16,he),(t.unit||t.$slots.unit)&&e.unref(Te)?(e.openBlock(),e.createElementBlock("div",ge,[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps(e.unref(He))),(()=>[e.createTextVNode(e.toDisplayString(t.unit),1)]))])):e.createCommentVNode("v-if",!0)],512),e.unref($e)?(e.openBlock(),e.createBlock(re,e.mergeProps({key:1},e.unref($e),{class:"vv-input-text__icon vv-input-text__icon-after"}),null,16)):e.unref(le)&&!t.hideActions&&e.unref(Oe)?(e.openBlock(),e.createBlock(e.unref(We),{key:2,onTogglePassword:ae})):e.unref(ce)&&!t.hideActions&&e.unref(Oe)?(e.openBlock(),e.createBlock(e.unref(qe),{key:3,onStepUp:ve,onStepDown:pe})):e.unref(xe)&&!t.hideActions&&e.unref(Oe)?(e.openBlock(),e.createBlock(e.unref(Ke),{key:4,onClear:Ee})):e.createCommentVNode("v-if",!0),t.$slots.after?(e.openBlock(),e.createElementBlock("div",ye,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(He))))])):e.createCommentVNode("v-if",!0),e.unref(p)?(e.openBlock(),e.createElementBlock("span",Se,[e.renderSlot(t.$slots,"count",e.normalizeProps(e.guardReactiveProps(e.unref(He))),(()=>[e.createTextVNode(e.toDisplayString(e.unref(Pe)),1)]))])):e.createCommentVNode("v-if",!0)],512),e.createVNode(e.unref(je),{id:e.unref(N),class:"vv-input-text__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"3"}:void 0]),1032,["id"]),e.unref(De)?(e.openBlock(),e.createBlock(X,{key:1,ref_key:"dropdownEl",ref:K,reference:e.unref(F),"autofocus-first":!1,"trigger-width":!0},{items:e.withCtx((()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(_e),(o=>(e.openBlock(),e.createBlock(G,{key:o,onClick:e.withModifiers((e=>{return t=o,V.value=t,void(null==(l=K.value)||l.hide());var t,l}),["stop"])},{default:e.withCtx((()=>[e.createElementVNode("div",we,[e.renderSlot(t.$slots,"suggestion",e.mergeProps({ref_for:!0},{value:o}),(()=>[e.createTextVNode(e.toDisplayString(o),1)]))]),e.unref(Ae)&&e.unref(Ce)?(e.openBlock(),e.createElementBlock("button",{key:0,type:"button",tabindex:"-1",class:"cursor-pointer",title:t.labelRemoveSuggestion,onClick:e.withModifiers((e=>{return t=o,void(null==(l=Ae.value)||l.delete(t));var t,l}),["stop"])},[e.createVNode(re,e.mergeProps({ref_for:!0},e.unref(Ce)),null,16)],8,ke)):e.createCommentVNode("v-if",!0)])),_:2},1032,["onClick"])))),128))])),_:3},8,["reference"])):e.createCommentVNode("v-if",!0)],2))}})}));
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("vue-imask"),require("@floating-ui/vue"),require("@vueuse/core"),require("mitt"),require("@iconify/vue")):"function"==typeof define&&define.amd?define(["vue","vue-imask","@floating-ui/vue","@vueuse/core","mitt","@iconify/vue"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvInputText=t(e.vue,e.vueImask,e.vue$1,e.core,e.mitt,e.vue$2)}(this,(function(e,t,o,l,a,n){"use strict";function i(t){return null==(o=e.unref(t))||""===o||Array.isArray(o)&&0===o.length||!(o instanceof Date)&&"object"==typeof o&&0===Object.keys(o).length;var o}function r(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}var u=(e=>(e.local="local",e.session="session",e))(u||{}),s=(e=>(e.absolute="absolute",e.fixed="fixed",e))(s||{}),d=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(d||{}),c=(e=>(e.topStart="top-start",e.topEnd="top-end",e.bottomStart="bottom-start",e.bottomEnd="bottom-end",e.leftStart="left-start",e.leftEnd="left-end",e.rightStart="right-start",e.rightEnd="right-end",e))(c||{}),v=(e=>(e.before="before",e.after="after",e))(v||{}),p=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(p||{}),f=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(f||{}),m=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(m||{}),b=(e=>(e.listbox="listbox",e.menu="menu",e))(b||{}),h=(e=>(e.option="option",e.presentation="presentation",e))(h||{});const g=Symbol.for("volver"),y=Symbol.for("dropdownTrigger"),S=Symbol.for("dropdownItem"),w=Symbol.for("dropdownAction"),k={valid:{type:Boolean,default:!1},validLabel:{type:[String,Array],default:void 0}},x={invalid:{type:Boolean,default:!1},invalidLabel:{type:[String,Array],default:void 0}},E={loading:{type:Boolean,default:!1},loadingLabel:{type:String,default:"Loading..."}},L={disabled:{type:Boolean,default:!1}},B={required:{type:Boolean,default:!1}},$={selected:{type:Boolean,default:!1}},C=(Boolean,Boolean,Boolean,{label:{type:[String,Number],default:void 0}}),P={readonly:{type:Boolean,default:!1}},O={modifiers:{type:[String,Array],default:void 0}},N={hintLabel:{type:String,default:""}},T={count:{type:[Boolean,String],default:!1,validator:e=>[!0,!1,"limit","countdown"].includes(e)}},V={debounce:{type:[Number,String],default:void 0}},A={icon:{type:[String,Object],default:void 0},iconPosition:{type:String,default:v.before,validation:e=>Object.values(v).includes(e)}},D={tabindex:{type:[String,Number],default:0}},_={floating:{type:Boolean,default:!1}},I={unselectable:{type:Boolean,default:!0}},R={id:[String,Number]},M={placement:{type:String,default:d.bottom,validator:e=>Object.values(d).includes(e)||Object.values(c).includes(e)},strategy:{type:String,default:void 0,validator:e=>Object.values(s).includes(e)},transitionName:{type:String,default:void 0},offset:{type:[Number,String,Object],default:0},shift:{type:[Boolean,Object],default:!1},flip:{type:[Boolean,Object],default:!0},size:{type:[Boolean,Object],default:()=>({padding:10})},autoPlacement:{type:[Boolean,Object],default:!1},arrow:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean,default:!1}},H={...{...R,name:{type:String,required:!0}},...{autofocus:{type:Boolean,default:!1}},...{autocomplete:{type:String,default:"off"}},...D,...L,...P,...k,...x,...N,...E,...O,...T,...V,...A,..._,...C,minlength:{type:[String,Number],default:void 0},maxlength:{type:[String,Number],default:void 0},placeholder:{type:String,default:void 0},...B};p.button,f.button;const j={storageType:{type:String,default:u.local,validator:e=>Object.values(u).includes(e)},storageKey:String},z={...R,...M,...O,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:b.menu,validator:e=>Object.values(b).includes(e)}},U={focusOnHover:{type:Boolean,default:!1}},F={...L,...$,...I,...O,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String},focusOnHover:{type:Boolean,default:!1}};function W(t){return e.computed((()=>String((null==t?void 0:t.value)||e.useId())))}function q(t,o,l){return e.computed((()=>{const a={[t]:!0},n="string"==typeof(null==o?void 0:o.value)?o.value.split(" "):null==o?void 0:o.value;return n&&Array.isArray(n)&&n.forEach((e=>{e&&(a[`${t}--${e}`]=!0)})),l&&Object.keys(l.value).forEach((o=>{a[`${t}--${o}`]=e.unref(l.value[o])})),a}))}const K=["id","tabindex","role","aria-labelledby"],X=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:z,emits:["update:modelValue","beforeEnter","afterLeave","beforeExpand","beforeCollapse","afterExpand","afterCollapse","before-enter","after-leave","enter","afterEnter","enterCancelled","beforeLeave","leave","leaveCancelled"],setup(t,{expose:n,emit:i}){const r=t,u=i,{id:c}=e.toRefs(r),v=W(c),p=e.useAttrs(),f=e.ref("auto"),m=e.ref("auto"),g=e.ref(),w=e.ref(),k=e.ref(),x=e.ref(),E=e.computed({get:()=>r.reference??g.value,set:e=>{g.value=e}}),L=e.ref(!1);e.onMounted((()=>{l.useMutationObserver(w.value,(()=>{var e;L.value="true"===(null==(e=window.getComputedStyle(w.value).getPropertyValue("--dropdown-custom-position"))?void 0:e.trim())}),{attributeFilter:["style"],window:window})}));const B=e.computed((()=>{const e=[];if(r.autoPlacement?"boolean"==typeof r.autoPlacement?e.push(o.autoPlacement()):e.push(o.autoPlacement(r.autoPlacement)):r.flip&&("boolean"==typeof r.flip?e.push(o.flip({fallbackStrategy:"initialPlacement"})):e.push(o.flip(r.flip))),r.shift&&("boolean"==typeof r.shift?e.push(o.shift()):e.push(o.shift(r.shift))),r.size){const t=({availableWidth:e,availableHeight:t})=>{f.value=`${e}px`,m.value=`${t}px`};"boolean"==typeof r.size?e.push(o.size({apply:t})):e.push(o.size({...r.size,apply:t}))}return r.offset&&(e.push(o.offset(Number(r.offset))),["string","number"].includes(typeof r.offset)?e.push(o.offset(Number(r.offset))):e.push(o.offset(r.offset))),r.arrow&&e.push(o.arrow({element:k})),e})),{x:$,y:C,middlewareData:P,placement:O,strategy:N}=o.useFloating(E,w,{whileElementsMounted:(...e)=>o.autoUpdate(...e,{animationFrame:r.strategy===s.fixed}),placement:e.computed((()=>r.placement)),strategy:e.computed((()=>r.strategy)),middleware:B}),T=e.computed((()=>{var e;if(L.value)return;const t=r.triggerWidth&&E.value?`${null==(e=E.value)?void 0:e.offsetWidth}px`:void 0;return{position:N.value,top:`${C.value??0}px`,left:`${$.value??0}px`,maxWidth:t?void 0:f.value,maxHeight:m.value,width:t}})),V=e.computed((()=>O.value.split("-")[0])),A=e.computed((()=>{var e,t,o,l,a;if(L.value)return;const n={[d.top]:d.bottom,[d.right]:d.left,[d.bottom]:d.top,[d.left]:d.right}[V.value];return{left:void 0!==(null==(e=P.value.arrow)?void 0:e.x)?`${null==(t=P.value.arrow)?void 0:t.x}px`:void 0,top:void 0!==(null==(o=P.value.arrow)?void 0:o.y)?`${null==(l=P.value.arrow)?void 0:l.y}px`:void 0,[n]:-((null==(a=k.value)?void 0:a.offsetWidth)??0)/2+"px"}})),D=l.useVModel(r,"modelValue",u),_=e.ref(!1),I=e.computed({get:()=>D.value??_.value,set:e=>{void 0!==D.value?D.value=e:_.value=e}});function R(){I.value=!0}function M(){I.value=!1}function H(){I.value=!I.value}function j(e){E.value=e}n({toggle:H,show:R,hide:M,init:j,customPosition:L}),e.watch(I,(t=>{t&&r.autofocusFirst&&e.nextTick((()=>{const e=Z(w.value);e.length>0&&e[0].focus({preventScroll:!0})}))})),l.onClickOutside(w,(()=>{!r.keepOpen&&I.value&&(I.value=!1)}),{ignore:[E]});const z=e.computed((()=>{var e,t;return(null==(t=null==(e=E.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),U=e.computed((()=>({"aria-controls":v.value,"aria-haspopup":!0,"aria-expanded":I.value}))),{component:F,bus:X}=function({reference:t,id:o,expanded:l,aria:n}){const i=a(),r=e.defineComponent({name:"VvDropdownTriggerProvider",setup(){e.provide(y,{reference:t,id:o,expanded:l,aria:n,bus:i})},render(){var t,o;return e.h(e.Fragment,{},null==(o=(t=this.$slots).default)?void 0:o.call(t))}});return{bus:i,component:r}}({reference:E,id:v,expanded:I,aria:U});X.on("click",H);const{role:J,modifiers:Y}=e.toRefs(r),G=q("vv-dropdown",Y,e.computed((()=>({arrow:r.arrow})))),{focused:Q}=l.useFocusWithin(w);function Z(e){return e?[...e.querySelectorAll('a[href], button, input, textarea, select, details, [tabindex]:not([tabindex="-1"])')].filter((e=>!e.hasAttribute("disabled")&&!e.getAttribute("aria-hidden"))):[]}const ee=l.useElementHover(w),{itemRole:te}=function({role:t,...o}){const l=e.computed((()=>t.value===b.listbox?h.option:h.presentation));return e.provide(S,{role:l,...o}),{itemRole:l}}({role:J,expanded:I,focused:Q,hovered:ee});l.onKeyStroke("Escape",(e=>{I.value&&(e.preventDefault(),M())})),l.onKeyStroke("ArrowDown",(t=>{I.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=Z(w.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus({preventScroll:!0}):e[0].focus({preventScroll:!0})}})))})),l.onKeyStroke("ArrowUp",(t=>{I.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=Z(w.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus({preventScroll:!0}):e[e.length-1].focus({preventScroll:!0})}})))})),l.onKeyStroke([" ","Enter"],(e=>{const t=e.target;I.value&&Q.value&&t&&(null==t||t.click())}));const oe={"before-enter":()=>{u(I.value?"beforeExpand":"beforeCollapse"),u("beforeEnter")},"after-leave":()=>{u(I.value?"afterExpand":"afterCollapse"),u("afterLeave")},enter:()=>{u("enter")},"after-enter":()=>{u("afterEnter")},"enter-cancelled":()=>{u("enterCancelled")},"before-leave":()=>{u("beforeLeave")},leave:()=>{u("leave")},"leave-cancelled":()=>{u("leaveCancelled")}};return(t,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(F),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:j,show:R,hide:M,toggle:H,expanded:e.unref(I),aria:e.unref(U)})))])),_:3}),e.createVNode(e.Transition,e.mergeProps({name:t.transitionName},e.toHandlers(oe),{persisted:""}),{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:w,style:e.normalizeStyle(e.unref(T)),class:e.normalizeClass(e.unref(G))},[r.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:k,style:e.normalizeStyle(e.unref(A)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(I)}))),e.createElementVNode("div",e.mergeProps(e.unref(p),{id:e.unref(v),ref_key:"listEl",ref:x,tabindex:e.unref(I)?void 0:-1,role:e.unref(J),"aria-labelledby":e.unref(z),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(te)})))],16,K),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(I)})))],6),[[e.vShow,e.unref(I)]])])),_:3},16,["name"])],64))}});const J=e.defineComponent({name:"VvDropdownItem",props:U,setup(t){const o=t,{role:a,expanded:n}=e.inject(S,{}),i=e.ref(null);!function({expanded:t}){e.provide(w,{role:e.ref(m.menuitem),expanded:t})}({expanded:n});const r=l.useElementHover(i),{focused:u}=l.useFocus(i),{focused:s}=l.useFocusWithin(i);return e.watch(r,(e=>{e&&o.focusOnHover&&(u.value=!0)})),(t,o)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({role:e.unref(a)},{ref_key:"element",ref:i,class:["vv-dropdown__item",{"focus-visible":e.unref(u)||e.unref(s)}]}),[e.renderSlot(t.$slots,"default")],16))}}),Y=["title"],G=e.defineComponent({name:"VvDropdownOption",props:F,setup(t){const o=t,{modifiers:l}=e.toRefs(o),a=q("vv-dropdown-option",l,e.computed((()=>({disabled:o.disabled,selected:o.selected,unselectable:o.unselectable&&o.selected})))),n=e.computed((()=>o.selected?o.unselectable?o.deselectHintLabel:o.selectedHintLabel:o.disabled?"":o.selectHintLabel));return(t,o)=>(e.openBlock(),e.createBlock(J,{class:e.normalizeClass(e.unref(a)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled,"focus-on-hover":t.focusOnHover},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default"),e.createElementVNode("span",{class:"vv-dropdown-option__hint",title:e.unref(n)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(n)),1)]))],8,Y)])),_:3},8,["class","tabindex","aria-selected","aria-disabled","focus-on-hover"]))}}),Q="eye-on",Z="eye-off",ee="calendar",te="time",oe="color",le="close",ae="trash",ne={prefix:"normal"};function ie(){return e.inject(g)}const re=e.defineComponent({name:"VvIcon",props:e.mergeDefaults({name:{},color:{},width:{},height:{},provider:{},prefix:{},src:{},horizontalFlip:{type:Boolean},verticalFlip:{type:Boolean},flip:{},mode:{},inline:{type:Boolean},rotate:{},onLoad:{type:Function},svg:{},modifiers:{}},ne),setup(t){const o=t,l=e.computed((()=>"string"==typeof o.rotate?Number.parseFloat(o.rotate):o.rotate)),a=e.ref(!0),i=ie(),{modifiers:r}=e.toRefs(o),u=q("vv-icon",r),s=e.computed((()=>o.provider||(null==i?void 0:i.iconsProvider))),d=e.computed((()=>{const e=o.name??"",t=`@${s.value}:${o.prefix}:${e}`;if(n.iconExists(t))return t;const l=null==i?void 0:i.iconsCollections.find((t=>{const o=`@${s.value}:${t.prefix}:${e}`;return n.iconExists(o)}));return l?`@${s.value}:${l.prefix}:${e}`:e}));function c(e){const t=function(e){let t;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");t=(new e).window}return(t?new t.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),l=(null==t?void 0:t.innerHTML.trim())||"";t&&l&&n.addIcon(`@${s.value}:${o.prefix}:${o.name}`,{body:l,height:t.viewBox.baseVal.height,width:t.viewBox.baseVal.width})}return i&&o.src&&!n.iconExists(`@${s.value}:${o.prefix}:${o.name}`)&&(a.value=!1,i.fetchIcon(o.src).then((e=>{e&&(c(e),a.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),o.svg&&c(o.svg),(t,o)=>e.unref(a)?(e.openBlock(),e.createBlock(e.unref(n.Icon),e.mergeProps({key:0,class:e.unref(u)},{inline:t.inline,width:t.width,height:t.height,horizontalFlip:t.horizontalFlip,verticalFlip:t.verticalFlip,flip:t.flip,rotate:e.unref(l),color:t.color,onLoad:t.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}}),ue={TEXT:"text",PASSWORD:"password",NUMBER:"number",EMAIL:"email",TEL:"tel",URL:"url",COLOR:"color",SEARCH:"search",DATE:"date",TIME:"time",DATETIME_LOCAL:"datetime-local",MONTH:"month",WEEK:"week"},se={...H,...j,modelValue:[String,Number],type:{type:String,default:ue.TEXT,validator:e=>Object.values(ue).includes(e)},min:[Number,Date,String],max:[Number,Date,String],step:{type:[String,Number],default:1},pattern:String,multiple:Boolean,iconShowPassword:{type:[String,Object],default:Q},iconHidePassword:{type:[String,Object],default:Z},iconClear:{type:[String,Object],default:le},iconRemoveSuggestion:{type:[String,Object],default:ae},labelStepUp:{type:String,default:"Increase value"},labelStepDown:{type:String,default:"Decrease value"},labelShowPassword:{type:String,default:"Show password"},labelHidePassword:{type:String,default:"Hide password"},labelClear:{type:String,default:"Clear"},labelRemoveSuggestion:{type:String,default:"Remove suggestion"},iMask:{type:Object,default:void 0},masked:{type:String,default:void 0},autoWidth:{type:Boolean,default:!1},hideActions:{type:Boolean,default:!1},unit:{type:String},selectOnFocus:{type:Boolean,default:!1},maxSuggestions:{type:Number,default:5}};function de(t,o){const l=e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),a=e.computed((()=>(null==o?void 0:o.value)===v.before?l.value:void 0)),n=e.computed((()=>(null==o?void 0:o.value)===v.after?l.value:void 0)),i=e.computed((()=>(null==o?void 0:o.value)===d.left?l.value:void 0)),r=e.computed((()=>(null==o?void 0:o.value)===d.right?l.value:void 0)),u=e.computed((()=>(null==o?void 0:o.value)===d.top?l.value:void 0)),s=e.computed((()=>(null==o?void 0:o.value)===d.bottom?l.value:void 0));return{hasIcon:l,hasIconLeft:i,hasIconRight:r,hasIconTop:u,hasIconBottom:s,hasIconBefore:a,hasIconAfter:n}}const ce=e.defineComponent({components:{VvIcon:re},props:{disabled:{type:Boolean,default:!1},label:{type:String,default:"Clear"},icon:{type:[String,Object],default:"close"}},emits:["clear"],setup(t,{emit:o}){const{hasIcon:l}=de(e.computed((()=>t.icon)));return{hasIcon:l,onClick:function(e){null==e||e.stopPropagation(),t.disabled||o("clear")}}},render(){const t=this.hasIcon?e.h(re,{...this.hasIcon,class:"vv-input-text__icon"}):void 0;return e.h("button",{disabled:this.disabled,class:"vv-input-text__action",ariaLabel:this.label,type:"button",onClick:this.onClick},t)}}),ve=e.defineComponent({components:{VvIcon:re},props:{disabled:{type:Boolean,default:!1},labelShow:{type:String,default:"Show password"},labelHide:{type:String,default:"Hide password"},iconShow:{type:[String,Object],default:Q},iconHide:{type:[String,Object],default:Z}},emits:["toggle-password"],setup(t,{emit:o}){const l=e.ref(!1),a=e.computed((()=>l.value?t.iconHide:t.iconShow)),{hasIcon:n}=de(a);return{active:l,activeIcon:a,hasIcon:n,onClick:function(e){null==e||e.stopPropagation(),t.disabled||(l.value=!l.value,o("toggle-password",l.value))}}},render(){const t=this.hasIcon?e.h(re,{...this.hasIcon,class:"vv-input-text__icon"}):void 0;return e.h("button",{disabled:this.disabled,class:"vv-input-text__action",ariaLabel:this.active?this.labelHide:this.labelShow,type:"button",onClick:this.onClick},t)}}),pe=e.defineComponent({components:{VvIcon:re},props:{disabled:{type:Boolean,default:!1},label:{type:String},mode:{type:String,validator:e=>["up","down"].includes(e),default:"up"}},emits:["step-up","step-down"],setup(t,{emit:o}){const l=e.computed((()=>"up"===t.mode));return{isUp:l,onClick:e=>{null==e||e.stopPropagation(),t.disabled||o(l.value?"step-up":"step-down")}}},render(){return e.h("button",{class:["vv-input-text__action vv-input-text__action-chevron",this.isUp&&"vv-input-text__action-chevron-up"],disabled:this.disabled,ariaLabel:this.label,type:"button",onClick:this.onClick})}});function fe(t,o){return{name:"VvInputTextActions",components:{VvIcon:re,VvInputPasswordAction:ve,VvInputStepAction:pe,VvInputClearAction:ce},setup:()=>({isDisabled:e.computed((()=>o.disabled||o.readonly)),labelStepUp:o.labelStepUp,labelStepDown:o.labelStepDown,labelShowPassword:o.labelShowPassword,labelHidePassword:o.labelHidePassword,labelClear:o.labelClear,iconShowPassword:o.iconShowPassword,iconHidePassword:o.iconHidePassword}),render(){let l=null;switch(t){case ue.SEARCH:{const{onClear:t}=this.$attrs;l=[e.h(ce,{disabled:this.isDisabled,label:this.labelShowPassword,onClear:t})];break}case ue.PASSWORD:{const{onTogglePassword:t}=this.$attrs;l=[e.h(ve,{disabled:this.isDisabled,onTogglePassword:t,labelShow:this.labelShowPassword,labelHide:this.labelHidePassword,iconShow:this.iconShowPassword,iconHide:this.iconHidePassword})];break}case ue.NUMBER:{const{onStepUp:t,onStepDown:a}=this.$attrs;l=[e.h(pe,{mode:"up",disabled:this.isDisabled||void 0!==o.max&&o.modelValue===o.max,label:this.labelStepUp,onStepUp:t,onStepDown:a}),e.h(pe,{mode:"down",disabled:this.isDisabled||void 0!==o.min&&o.modelValue===o.min,label:this.labelStepDown,onStepUp:t,onStepDown:a})];break}}return Array.isArray(l)?e.h("div",{class:"vv-input-text__actions-group"},l):l}}}const me=["for"],be={key:0,class:"vv-input-text__input-before"},he=["id"],ge={key:1,class:"vv-input-text__unit"},ye={key:5,class:"vv-input-text__input-after"},Se={key:6,class:"vv-input-text__limit"},we={class:"flex-1"},ke=["title","onClick"];return e.defineComponent({name:"VvInputText",props:se,emits:["update:modelValue","update:masked","accept","accept:typed","accept:masked","accept:unmasked","complete","complete:typed","complete:masked","complete:unmasked","focus","blur","keyup","keydown","keypress"],setup(o,{expose:a,emit:n}){const s=o,d=n,c=e.useSlots(),v=function(t,o,l){const a=ie(),n=e.computed((()=>{var e;if(a&&(null==(e=a.defaults.value)?void 0:e[t]))return a.defaults.value[t]}));return e.computed((()=>{if(void 0===n.value)return l;const e=n.value,t=o,a=l;return Object.keys(t).reduce(((o,l)=>{const n=a[l];if(o[l]=n,l in e){if(Array.isArray(t[l])){const a=t[l];a.length&&a[0]===n&&(o[l]=e[l])}if("function"==typeof t[l]&&(0,t[l])()===n&&(o[l]=e[l]),"object"==typeof t[l]){let a=t[l].default;"function"==typeof a&&(a=a()),"object"==typeof a?JSON.stringify(a)===JSON.stringify(n)&&(o[l]=e[l]):a===n&&(o[l]=e[l])}}return o}),{})}))}("VvInputText",se,s),{count:p,debounce:f,icon:m,iconPosition:b,iconRemoveSuggestion:h,id:g,invalid:y,label:S,loading:w,maxlength:k,minlength:x,modelValue:E,step:L,storageKey:B,storageType:$,type:C,valid:P}=e.toRefs(s),O=W(g),N=e.computed((()=>`${O.value}-hint`)),T=e.computed((()=>s.floating&&i(s.placeholder)?" ":s.placeholder)),V=function(t,o,l=0,{getter:a=e=>e,setter:n=e=>e}={}){let i;return"string"==typeof l&&(l=Number.parseInt(l)),e.computed({get:()=>a(null==t?void 0:t.value),set:e=>{i&&clearTimeout(i),i=setTimeout((()=>{o("update:modelValue",n(e))}),l)}})}(E,d,(null==f?void 0:f.value)??0),A=/^-0?[.,]?[0*]?$/,D=e.ref(!1),{el:_,mask:I,typed:R,masked:M,unmasked:H}=t.useIMask(e.computed((()=>{if(!s.iMask)return{mask:/./};if(s.iMask.mask===Number){const e={...s.iMask};return s.min&&(e.min=Number(s.min)),s.max&&(e.max=Number(s.max)),e}return s.iMask})),{emit:d,onAccept:()=>{if(D.value){if(d("update:masked",M.value),C.value===ue.NUMBER){if(/^-$|^$/.test(H.value)){if(null===V.value||void 0===V.value)return;return void(V.value=void 0)}return A.test(H.value)?void(V.value=0):"number"!=typeof R.value?void(V.value=Number(R.value)):void(V.value=R.value)}if(C.value===ue.DATE){if(_.value instanceof HTMLInputElement&&"date"===_.value.type)return void(V.value=_.value.value);let e=R.value;if(null===e||""===e){if(!V.value)return;return void(V.value="")}return e instanceof Date||(e=new Date(e)),void(V.value=`${e.getFullYear()}-${`0${e.getMonth()+1}`.slice(-2)}-${`0${e.getDate()}`.slice(-2)}`)}if(C.value===ue.DATETIME_LOCAL){if(_.value instanceof HTMLInputElement&&"datetime-local"===_.value.type)return void(V.value=_.value.value);let e=R.value;if(null===e||""===e){if(!V.value)return;return void(V.value="")}return R.value instanceof Date||(e=new Date(e)),void(V.value=`${e.getFullYear()}-${`0${e.getMonth()+1}`.slice(-2)}-${`0${e.getDate()}`.slice(-2)}T${`0${e.getHours()}`.slice(-2)}:${`0${e.getMinutes()}`.slice(-2)}`)}(V.value||H.value)&&(V.value=H.value)}}});function j(e){var t;if(null==e)return R.value="",void(H.value="");(null==(t=s.iMask)?void 0:t.mask)!==Date?C.value===ue.NUMBER&&A.test(H.value)&&0===e||(R.value=e,H.value=`${R.value}`):R.value=new Date(e)}e.onMounted((()=>{I.value&&(D.value=!0,j(s.modelValue))})),e.watch((()=>s.modelValue),(e=>{I.value&&j(e)})),e.watch((()=>s.masked),(e=>{M.value=e??""}));const z=_,U=e.ref(),F=e.ref(),K=e.ref();a({$inner:U});const{focused:J}=function(t,o){const{focused:a}=l.useFocus(t);return e.watch(a,(l=>{o(l?"focus":"blur",e.unref(t))})),{focused:a}}(z,d),Y=e.computed((()=>J.value&&!s.disabled&&!s.readonly));e.watch(Y,(e=>{var t,o;if(e&&v.value.selectOnFocus&&z.value&&z.value.select(),e&&(null==(t=Ae.value)?void 0:t.size))null==(o=K.value)||o.show();else if(Te.value&&Ae.value){const e=s.maxSuggestions;Ae.value.size>=e&&!Ae.value.has(V.value)&&(Ae.value=new Set([...Ae.value].slice(Ae.value.size-e+1))),Ae.value.add(V.value)}}));const Q=l.useElementVisibility(z);e.watch(Q,(e=>{e&&s.autofocus&&!s.disabled&&!s.readonly&&(J.value=!0)}));const Z=e.ref(!1),le=e.computed((()=>s.type===ue.PASSWORD));function ae(){Z.value=!Z.value}const ne=e.computed((()=>s.type===ue.TIME||s.type===ue.DATETIME_LOCAL||s.type===ue.DATE||s.type===ue.WEEK||s.type===ue.MONTH)),ce=e.computed((()=>s.type===ue.NUMBER));function ve(){if(Oe.value){if(s.iMask)return void(R.value=Number(R.value)+Number((null==L?void 0:L.value)??1));z.value.stepUp(),V.value=Number(e.unref(z).value)}}function pe(){if(Oe.value){if(s.iMask)return void(R.value=Number(R.value)-Number((null==L?void 0:L.value)??1));z.value.stepDown(),V.value=Number(e.unref(z).value)}}const xe=e.computed((()=>s.type===ue.SEARCH));function Ee(){V.value=""}const{hasIconBefore:Le,hasIconAfter:Be}=de(m,b),$e=e.computed((()=>{if(void 0!==Be.value)return Be.value;switch(s.type){case ue.COLOR:return{name:oe};case ue.DATE:case ue.DATETIME_LOCAL:case ue.WEEK:case ue.MONTH:return{name:ee};case ue.TIME:return{name:te}}})),{hasIcon:Ce}=de(h),{formatted:Pe}=function(t,o){const l=e.computed((()=>(e.unref(t)??"").length)),a=e.computed((()=>void 0!==(null==o?void 0:o.lowerLimit)&&l.value<(null==o?void 0:o.lowerLimit)?l.value-o.lowerLimit:void 0!==(null==o?void 0:o.upperLimit)&&l.value<(null==o?void 0:o.upperLimit)?o.upperLimit-l.value:0)),n=e.computed((()=>{if(!1===(null==o?void 0:o.mode))return"";if("limit"===(null==o?void 0:o.mode)&&(null==o?void 0:o.upperLimit))return`${l.value} / ${o.lowerLimit?`${o.lowerLimit}-`:""}${o.upperLimit}`;if("countdown"===(null==o?void 0:o.mode)){if(0===a.value)return;return a}return l.value}));return{length:l,gap:a,formatted:n}}(V,{mode:p.value,upperLimit:Number(null==k?void 0:k.value),lowerLimit:Number(null==x?void 0:x.value)}),Oe=e.computed((()=>!s.disabled&&!s.readonly)),Ne=e.computed((()=>Oe.value?s.tabindex:-1)),Te=e.computed((()=>!i(E))),Ve=e.computed((()=>!0===y.value||!0!==P.value&&void 0)),Ae=function(t,o=u.local,a){const n=e.ref();let i;return a&&(n.value=a),t&&e.watch(t,((t,a)=>{const r=e.unref(o)===u.session?sessionStorage:localStorage;a&&a!==t&&r.removeItem(a),i=t?l.useStorage(t,(null==i?void 0:i.value)??n.value,r):void 0}),{immediate:!0}),e.isRef(o)&&e.watch(o,((e,o)=>{if(null==t?void 0:t.value){if(e){const o=e===u.session?sessionStorage:localStorage;i=l.useStorage(t.value,(null==i?void 0:i.value)??n.value,o)}o&&o!==e&&(o===u.session?sessionStorage:localStorage).removeItem(t.value)}})),e.computed({get:()=>(null==i?void 0:i.value)??n.value,set:e=>{i?i.value=e:n.value=e}})}(B,$,new Set),De=e.computed((()=>Ae.value?[...Ae.value].filter((e=>i(V.value)||`${e}`.toLowerCase().includes(`${V.value}`.toLowerCase())&&e!==V.value)).reverse():[])),_e=e.computed((()=>(null==B?void 0:B.value)&&Ae.value&&Ae.value.size>0));const{modifiers:Ie}=e.toRefs(s),Re=q("vv-input-text",Ie,e.computed((()=>({valid:P.value,invalid:y.value,loading:w.value,disabled:s.disabled,required:s.required,readonly:s.readonly,"icon-before":!!Le.value,"icon-after":!!$e.value,floating:s.floating&&!i(s.label),dirty:Te.value,focus:Y.value,"auto-width":s.autoWidth})))),Me=e.computed((()=>{const e=le.value&&Z.value?ue.TEXT:!ne.value||Te.value||J.value?s.iMask?ue.TEXT:s.type:ue.TEXT,t={type:e,name:s.name,tabindex:Ne.value,disabled:s.disabled,readonly:s.readonly,required:s.required,autocomplete:s.autocomplete,"aria-invalid":Ve.value,"aria-describedby":ze.value?N.value:void 0,"aria-errormessage":Ue.value?N.value:void 0};if(e===ue.DATE||e===ue.MONTH||e===ue.WEEK||e===ue.TIME||e===ue.DATETIME_LOCAL||e===ue.NUMBER){let o=s.max;e!==ue.DATE||o||(o="9999-12-31"),t.step=s.step,t.max=void 0!==o?String(o):void 0,t.min=void 0!==s.min?String(s.min):void 0}return e!==ue.TEXT&&e!==ue.SEARCH&&e!==ue.URL&&e!==ue.TEL&&e!==ue.EMAIL&&e!==ue.PASSWORD&&e!==ue.NUMBER||(t.placeholder=T.value),e!==ue.TEXT&&e!==ue.SEARCH&&e!==ue.URL&&e!==ue.TEL&&e!==ue.EMAIL&&e!==ue.PASSWORD||(t.minlength=s.minlength,t.maxlength=s.maxlength,t.pattern=s.pattern),e===ue.EMAIL&&(t.multiple=s.multiple),t})),He=e.computed((()=>({valid:s.valid,invalid:s.invalid,modelValue:s.modelValue,togglePassword:ae,stepUp:ve,stepDown:pe,clear:Ee}))),{HintSlot:je,hasHintLabelOrSlot:ze,hasInvalidLabelOrSlot:Ue,hintSlotScope:Fe}=function(t,o){const l=e.computed((()=>e.isRef(t)?t.value:t)),a=e.computed((()=>r(l.value.invalidLabel))),n=e.computed((()=>r(l.value.validLabel))),i=e.computed((()=>l.value.loadingLabel)),u=e.computed((()=>l.value.hintLabel)),s=e.computed((()=>Boolean(l.value.loading&&(o.loading||i.value)))),d=e.computed((()=>!s.value&&Boolean(l.value.invalid&&(o.invalid||a.value)))),c=e.computed((()=>!s.value&&!d.value&&Boolean(l.value.valid&&(o.valid||n.value)))),v=e.computed((()=>!s.value&&!d.value&&!c.value&&Boolean(o.hint||u.value))),p=e.computed((()=>d.value||c.value||s.value||v.value)),f=e.computed((()=>({modelValue:l.value.modelValue,valid:l.value.valid,invalid:l.value.invalid,loading:l.value.loading}))),m=e.defineComponent({name:"HintSlot",props:{tag:{type:String,default:"small"}},setup:()=>({isVisible:p,invalidLabel:a,validLabel:n,loadingLabel:i,hintLabel:u,hasInvalidLabelOrSlot:d,hasValidLabelOrSlot:c,hasLoadingLabelOrSlot:s,hasHintLabelOrSlot:v}),render(){var t,o,l,a,n,i,r,u;if(this.isVisible){let s;return this.hasInvalidLabelOrSlot&&(s="alert"),this.hasValidLabelOrSlot&&(s="status"),this.hasLoadingLabelOrSlot?e.h(this.tag,{role:s},(null==(o=(t=this.$slots).loading)?void 0:o.call(t))??this.loadingLabel):this.hasInvalidLabelOrSlot?e.h(this.tag,{role:s},(null==(a=(l=this.$slots).invalid)?void 0:a.call(l))??this.$slots.invalid??this.invalidLabel):this.hasValidLabelOrSlot?e.h(this.tag,{role:s},(null==(i=(n=this.$slots).valid)?void 0:i.call(n))??this.validLabel):e.h(this.tag,{role:s},(null==(u=(r=this.$slots).hint)?void 0:u.call(r))??this.$slots.hint??this.hintLabel)}return null}});return{hasInvalidLabelOrSlot:d,hasHintLabelOrSlot:v,hasValidLabelOrSlot:c,hasLoadingLabelOrSlot:s,hintSlotScope:f,HintSlot:m}}(v,c),We=fe(ue.PASSWORD,s),qe=fe(ue.NUMBER,s),Ke=fe(ue.SEARCH,s);function Xe(){Oe.value&&(J.value=!0)}const Je=e.computed((()=>{if(s.autoWidth)return{width:void 0!==V.value?`${String(V.value).length+1}ch`:void 0}}));function Ye(e){switch(e.code){case"ArrowUp":ce.value&&(ve(),e.preventDefault());break;case"ArrowDown":ce.value&&(pe(),e.preventDefault())}d("keydown",e)}return(t,o)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref(Re))},[e.unref(S)?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(O),class:"vv-input-text__label"},e.toDisplayString(e.unref(S)),9,me)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:F,class:"vv-input-text__wrapper"},[t.$slots.before?(e.openBlock(),e.createElementBlock("div",be,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(He))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"innerEl",ref:U,class:"vv-input-text__inner",onClick:e.withModifiers(Xe,["stop"])},[e.unref(Le)?(e.openBlock(),e.createBlock(re,e.mergeProps({key:0},e.unref(Le),{class:"vv-input-text__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.createElementVNode("input",e.mergeProps({id:e.unref(O),ref_key:"inputEl",ref:z},e.unref(Me),{style:e.unref(Je),onKeyup:o[0]||(o[0]=e=>d("keyup",e)),onKeydown:Ye,onKeypress:o[1]||(o[1]=e=>d("keypress",e))}),null,16,he),(t.unit||t.$slots.unit)&&e.unref(Te)?(e.openBlock(),e.createElementBlock("div",ge,[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps(e.unref(He))),(()=>[e.createTextVNode(e.toDisplayString(t.unit),1)]))])):e.createCommentVNode("v-if",!0)],512),e.unref($e)?(e.openBlock(),e.createBlock(re,e.mergeProps({key:1},e.unref($e),{class:"vv-input-text__icon vv-input-text__icon-after"}),null,16)):e.unref(le)&&!t.hideActions&&e.unref(Oe)?(e.openBlock(),e.createBlock(e.unref(We),{key:2,onTogglePassword:ae})):e.unref(ce)&&!t.hideActions&&e.unref(Oe)?(e.openBlock(),e.createBlock(e.unref(qe),{key:3,onStepUp:ve,onStepDown:pe})):e.unref(xe)&&!t.hideActions&&e.unref(Oe)?(e.openBlock(),e.createBlock(e.unref(Ke),{key:4,onClear:Ee})):e.createCommentVNode("v-if",!0),t.$slots.after?(e.openBlock(),e.createElementBlock("div",ye,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(He))))])):e.createCommentVNode("v-if",!0),e.unref(p)?(e.openBlock(),e.createElementBlock("span",Se,[e.renderSlot(t.$slots,"count",e.normalizeProps(e.guardReactiveProps(e.unref(He))),(()=>[e.createTextVNode(e.toDisplayString(e.unref(Pe)),1)]))])):e.createCommentVNode("v-if",!0)],512),e.createVNode(e.unref(je),{id:e.unref(N),class:"vv-input-text__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"3"}:void 0]),1032,["id"]),e.unref(_e)?(e.openBlock(),e.createBlock(X,{key:1,ref_key:"suggestionsDropdownEl",ref:K,reference:e.unref(F),"autofocus-first":!1,"trigger-width":!0},{items:e.withCtx((()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(De),(o=>(e.openBlock(),e.createBlock(G,{key:o,onClick:e.withModifiers((e=>{return t=o,V.value=t,void(null==(l=K.value)||l.hide());var t,l}),["stop"])},{default:e.withCtx((()=>[e.createElementVNode("div",we,[e.renderSlot(t.$slots,"suggestion",e.mergeProps({ref_for:!0},{value:o}),(()=>[e.createTextVNode(e.toDisplayString(o),1)]))]),e.unref(Ae)&&e.unref(Ce)?(e.openBlock(),e.createElementBlock("button",{key:0,type:"button",tabindex:"-1",class:"cursor-pointer",title:t.labelRemoveSuggestion,onClick:e.withModifiers((e=>{return t=o,void(null==(l=Ae.value)||l.delete(t));var t,l}),["stop"])},[e.createVNode(re,e.mergeProps({ref_for:!0},e.unref(Ce)),null,16)],8,ke)):e.createCommentVNode("v-if",!0)])),_:2},1032,["onClick"])))),128))])),_:3},8,["reference"])):e.createCommentVNode("v-if",!0)],2))}})}));
|