@volverjs/ui-vue 0.0.9-beta.17 → 0.0.9-beta.18
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 +10 -7
- package/dist/components/VvCombobox/VvCombobox.umd.js +1 -1
- package/dist/components/VvInputText/VvInputText.es.js +141 -96
- package/dist/components/VvInputText/VvInputText.umd.js +1 -1
- package/dist/components/VvInputText/VvInputText.vue.d.ts +10 -37
- package/dist/components/VvInputText/index.d.ts +18 -35
- package/dist/components/VvTextarea/VvTextarea.es.js +8 -5
- package/dist/components/VvTextarea/VvTextarea.umd.js +1 -1
- package/dist/components/index.es.js +159 -108
- package/dist/components/index.umd.js +1 -1
- package/dist/icons.es.js +3 -3
- package/dist/icons.umd.js +1 -1
- package/dist/stories/InputText/InputText.settings.d.ts +4 -30
- package/dist/stories/InputText/InputText.stories.d.ts +0 -1
- package/dist/stories/InputText/InputTextMask.stories.d.ts +12 -0
- package/package.json +39 -38
- 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 +11 -7
- package/src/components/VvInputText/VvInputText.vue +124 -55
- package/src/components/VvInputText/index.ts +25 -34
- package/src/components/VvTextarea/VvTextarea.vue +8 -5
- package/src/stories/InputText/InputText.settings.ts +7 -33
- package/src/stories/InputText/InputText.stories.ts +4 -12
- package/src/stories/InputText/InputText.test.ts +31 -15
- package/src/stories/InputText/InputTextMask.stories.ts +122 -0
|
@@ -2476,7 +2476,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
2476
2476
|
const searchText = ref("");
|
|
2477
2477
|
const debouncedSearchText = refDebounced(
|
|
2478
2478
|
searchText,
|
|
2479
|
-
Number(props.debounceSearch)
|
|
2479
|
+
computed(() => Number(props.debounceSearch))
|
|
2480
2480
|
);
|
|
2481
2481
|
watch(
|
|
2482
2482
|
debouncedSearchText,
|
|
@@ -2593,12 +2593,15 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
2593
2593
|
} else if (props.modelValue) {
|
|
2594
2594
|
selectedValues = [props.modelValue];
|
|
2595
2595
|
}
|
|
2596
|
-
const options = props.options.reduce(
|
|
2597
|
-
|
|
2598
|
-
|
|
2599
|
-
|
|
2600
|
-
|
|
2601
|
-
|
|
2596
|
+
const options = props.options.reduce(
|
|
2597
|
+
(acc, value) => {
|
|
2598
|
+
if (isGroup(value)) {
|
|
2599
|
+
return [...acc, ...getOptionGrouped(value)];
|
|
2600
|
+
}
|
|
2601
|
+
return [...acc, value];
|
|
2602
|
+
},
|
|
2603
|
+
[]
|
|
2604
|
+
);
|
|
2602
2605
|
return options.filter((option) => {
|
|
2603
2606
|
if (isGroup(option)) {
|
|
2604
2607
|
return getOptionGrouped(option).some(
|
|
@@ -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("nanoid"),require("@vueuse/core"),require("mitt"),require("ts-dot-prop")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","@floating-ui/vue","nanoid","@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.nanoid,e.core,e.mitt,e.tsDotProp)}(this,(function(e,t,l,o,a,n,r){"use strict";var i=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(i||{}),u=(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))(u||{}),s=(e=>(e.before="before",e.after="after",e))(s||{}),d=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(d||{}),c=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(c||{}),v=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(v||{}),p=(e=>(e.listbox="listbox",e.menu="menu",e))(p||{}),f=(e=>(e.option="option",e.presentation="presentation",e))(f||{}),m=(e=>(e._blank="_blank",e._self="_self",e._parent="_parent",e._top="_top",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:{type:String,validator:e=>Object.values(m).includes(e)},rel:{type:String,default:"noopener noreferrer"}},B={valid:Boolean,validLabel:[String,Array]},V={invalid:Boolean,invalidLabel:[String,Array]},x={loading:Boolean,loadingLabel:{type:String,default:"Loading..."}},w={disabled:Boolean},L={selected:Boolean},P={active:Boolean},$={pressed:Boolean},_={label:[String,Number]},C={readonly:Boolean},O={modifiers:[String,Array]},E={hintLabel:{type:String,default:""}},N={options:{type:Array,default:()=>[]},labelKey:{type:[String,Function],default:"label"},valueKey:{type:[String,Function],default:"value"},disabledKey:{type:[String,Function],default:"disabled"}},A={icon:{type:[String,Object]},iconPosition:{type:String,default:s.before,validation:e=>Object.values(s).includes(e)}},D={tabindex:{type:[String,Number],default:0}},j={floating:Boolean},R={unselectable:{type:Boolean,default:!0}},F={id:[String,Number]},z={placement:{type:String,default:i.bottom,validator:e=>Object.values(i).includes(e)||Object.values(u).includes(e)},strategy:{type:String,default:"absolute",validator:e=>["fixed","absolute"].includes(e)},transitionName:{type:String},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}},H={...F,name:{type:String,required:!0}},I={autofocus:Boolean},T={autocomplete:{type:String,default:"off"}},M={...w,..._,...$,...P,...S,type:{type:String,default:d.button,validator:e=>Object.values(d).includes(e)},ariaLabel:{type:String,default:void 0}},q={...H,...D,...B,...V,...E,...x,...w,...C,...O,...N,...A,...j,...R,...z,..._,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,maxValues:[Number,String],separator:{type:String,default:", "},native:Boolean,badges:Boolean,badgeModifiers:{type:[String,Array],default:"action sm"},triggerWidth:{...z.triggerWidth,default:!0},dropdownModifiers:{type:[String,Array],default:"mobile"},autoOpen:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1}},K={color:String,width:{type:[String,Number]},height:{type:[String,Number]},name:{type:String,required:!0},provider:{type:String},prefix:{type:String,default:"normal"},src:String,horizontalFlip:Boolean,verticalFlip:Boolean,flip:String,mode:String,inline:Boolean,rotate:[Number,String],onLoad:Function,svg:String,modifiers:{type:[String,Array]}};function W(){return e.inject(b)}function G(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 U=e.defineComponent({name:"VvIcon",props:K,setup(l){const o=l,a=e.computed((()=>"string"==typeof o.rotate?parseFloat(o.rotate):o.rotate)),n=e.ref(!0),r=W(),{modifiers:i}=e.toRefs(o),u=G("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("",!0)}}),J={...F,...z,...O,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:p.menu,validator:e=>Object.values(p).includes(e)}},Q=t=>e.computed((()=>String((null==t?void 0:t.value)||o.nanoid())));const X=["id","tabindex","role","aria-labelledby"],Y=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:J,emits:["update:modelValue","beforeExpand","beforeCollapse","afterExpand","afterCollapse","before-enter","after-leave","enter","after-enter","enter-cancelled","before-leave","leave","leave-cancelled"],setup(t,{expose:o,emit:r}){const i=t,{id:u}=e.toRefs(i),s=Q(u),d=e.useAttrs(),c=e.ref("auto"),v=e.ref("auto"),m=e.ref(null),b=e.ref(),g=e.ref(null),k=e.ref(null),S=e.computed({get:()=>i.reference??m.value,set:e=>{m.value=e}}),B=e.ref(!1);e.onMounted((()=>{a.useMutationObserver(b.value,(()=>{var e;B.value="true"===(null==(e=window.getComputedStyle(b.value).getPropertyValue("--dropdown-custom-position"))?void 0:e.trim())}),{attributeFilter:["style"],window:window})}));const V=e.computed((()=>{const e=[];if(i.autoPlacement?"boolean"==typeof i.autoPlacement?e.push(l.autoPlacement()):e.push(l.autoPlacement(i.autoPlacement)):i.flip&&("boolean"==typeof i.flip?e.push(l.flip({fallbackStrategy:"initialPlacement"})):e.push(l.flip(i.flip))),i.shift&&("boolean"==typeof i.shift?e.push(l.shift()):e.push(l.shift(i.shift))),i.size){const t=({availableWidth:e,availableHeight:t})=>{c.value=`${e}px`,v.value=`${t}px`};"boolean"==typeof i.size?e.push(l.size({apply:t})):e.push(l.size({...i.size,apply:t}))}return i.offset&&(e.push(l.offset(Number(i.offset))),["string","number"].includes(typeof i.offset)?e.push(l.offset(Number(i.offset))):e.push(l.offset(i.offset))),i.arrow&&e.push(l.arrow({element:g})),e})),{x:x,y:w,strategy:L,middlewareData:P,placement:$}=l.useFloating(S,b,{whileElementsMounted:(...e)=>l.autoUpdate(...e,{animationFrame:"fixed"===i.strategy}),placement:e.computed((()=>i.placement)),strategy:e.computed((()=>i.strategy)),middleware:V}),_=e.computed((()=>{var e;if(B.value)return;const t=i.triggerWidth&&S.value?`${null==(e=S.value)?void 0:e.offsetWidth}px`:void 0;return{position:L.value,top:`${w.value??0}px`,left:`${x.value??0}px`,maxWidth:t?void 0:c.value,maxHeight:v.value,width:t}})),C=e.computed((()=>$.value.split("-")[0])),O=e.computed((()=>{var e,t,l,o,a;if(B.value)return;const n={top:"bottom",right:"left",bottom:"top",left:"right"}[C.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==(l=P.value.arrow)?void 0:l.y)?`${null==(o=P.value.arrow)?void 0:o.y}px`:void 0,[n]:-((null==(a=g.value)?void 0:a.offsetWidth)??0)/2+"px"}})),E=a.useVModel(i,"modelValue",r),N=e.ref(!1),A=e.computed({get:()=>E.value??N.value,set:e=>{void 0!==E.value?E.value=e:N.value=e}}),D=()=>{A.value=!0},j=()=>{A.value=!1},R=()=>{A.value=!A.value},F=e=>{S.value=e};o({toggle:R,show:D,hide:j,init:F,customPosition:B}),e.watch(A,(t=>{t&&i.autofocusFirst&&e.nextTick((()=>{const e=J(b.value);e.length>0&&e[0].focus({preventScroll:!0})}))})),a.onClickOutside(b,(()=>{!i.keepOpen&&A.value&&(A.value=!1)}),{ignore:[S]});const z=e.computed((()=>{var e,t;return(null==(t=null==(e=S.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),H=e.computed((()=>({"aria-controls":s.value,"aria-haspopup":!0,"aria-expanded":A.value}))),{component:I,bus:T}=function({reference:t,id:l,expanded:o,aria:a}){const r=n(),i=e.defineComponent({name:"VvDropdownTriggerProvider",setup(){e.provide(y,{reference:t,id:l,expanded:o,aria:a,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:S,id:s,expanded:A,aria:H});T.on("click",R);const{role:M,modifiers:q}=e.toRefs(i),{itemRole:K}=function({role:t,expanded:l}){const o=e.computed((()=>t.value===p.listbox?f.option:f.presentation));return e.provide(h,{role:o,expanded:l}),{itemRole:o}}({role:M,expanded:A}),W=G("vv-dropdown",q,e.computed((()=>({arrow:i.arrow})))),{focused:U}=a.useFocusWithin(b);function J(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"))):[]}a.onKeyStroke("Escape",(e=>{A.value&&(e.preventDefault(),j())})),a.onKeyStroke("ArrowDown",(t=>{A.value&&U.value&&(t.preventDefault(),e.nextTick((()=>{if(U.value){const e=J(b.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})}})))})),a.onKeyStroke("ArrowUp",(t=>{A.value&&U.value&&(t.preventDefault(),e.nextTick((()=>{if(U.value){const e=J(b.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})}})))})),a.onKeyStroke([" ","Enter"],(e=>{const t=e.target;A.value&&U.value&&t&&(null==t||t.click())}));const Y={"before-enter":()=>{r(A.value?"beforeExpand":"beforeCollapse"),r("before-enter")},"after-leave":()=>{r(A.value?"afterExpand":"afterCollapse"),r("after-leave")},enter:()=>{r("enter")},"after-enter":()=>{r("after-enter")},"enter-cancelled":()=>{r("enter-cancelled")},"before-leave":()=>{r("before-leave")},leave:()=>{r("leave")},"leave-cancelled":()=>{r("leave-cancelled")}};return(t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(I),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:F,show:D,hide:j,toggle:R,expanded:e.unref(A),aria:e.unref(H)})))])),_:3}),e.createVNode(e.Transition,e.mergeProps({name:t.transitionName},e.toHandlers(Y)),{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:b,style:e.normalizeStyle(e.unref(_)),class:e.normalizeClass(e.unref(W))},[i.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:g,style:e.normalizeStyle(e.unref(O)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(A)}))),e.createElementVNode("div",e.mergeProps(e.unref(d),{id:e.unref(s),ref_key:"listEl",ref:k,tabindex:e.unref(A)?void 0:-1,role:e.unref(M),"aria-labelledby":e.unref(z),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(K)})))],16,X),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(A)})))],6),[[e.vShow,e.unref(A)]])])),_:3},16,["name"])],64))}});const Z=e.defineComponent({name:"VvDropdownItem",setup(t){const{role:l,expanded:o}=e.inject(h,{}),n=e.ref(null);!function({expanded:t}){e.provide(k,{role:e.ref(v.menuitem),expanded:t})}({expanded:o});const r=a.useElementHover(n),{focused:i}=a.useFocus(n),{focused:u}=a.useFocusWithin(n);return e.watch(r,(e=>{e&&(i.value=!0)})),(t,o)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({role:e.unref(l)},{ref_key:"element",ref:n,class:["vv-dropdown__item",{"focus-visible":e.unref(i)||e.unref(u)}]}),[e.renderSlot(t.$slots,"default")],16))}}),ee=["title"],te=e.defineComponent({name:"VvDropdownOption",props:{...w,...L,...R,...O,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String}},setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=G("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?void 0:l.selectHintLabel));return(t,l)=>(e.openBlock(),e.createBlock(Z,{class:e.normalizeClass(e.unref(a)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled},{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,ee)])),_:3},8,["class","tabindex","aria-selected","aria-disabled"]))}}),le={class:"vv-dropdown-optgroup",role:"presentation",tabindex:"-1"},oe=e.defineComponent({name:"VvDropdownOptgroup",props:{..._},setup(t){const l=t;return(t,o)=>(e.openBlock(),e.createElementBlock("li",le,e.toDisplayString(l.label),1))}});function ae(e,t,l){return l?re(e,l)===re(t,l):ne(e,t)}function ne(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(!ne(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],!ne(e[r],t[r]))return!1;return!0}return e!=e&&t!=t}function re(e,t){if(e&&Object.keys(e).length&&t){if(-1===t.indexOf("."))return e[t];{const l=t.split(".");let o=e;for(let t=0,a=l.length;t<a;++t){if(null==e)return null;o=o[l[t]]}return o}}return null}function ie(e,t){if(null!=e&&t&&t.length)for(const l of t)if(ae(e,l))return!0;return!1}function ue(t){return null==(l=e.unref(t))||""===l||Array.isArray(l)&&0===l.length||!(l instanceof Date)&&"object"==typeof l&&0===Object.keys(l).length;var l}function se(e,t){const l=function(e,t){let l=-1;if(t)for(let o=0;o<t.length;o++)if(ae(t[o],e)){l=o;break}return l}(e,t);return l>-1?t.filter(((e,t)=>t!==l)):t}function de(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}function ce(t,l){const o=e.computed((()=>e.isRef(t)?t.value:t)),a=e.computed((()=>de(o.value.invalidLabel))),n=e.computed((()=>de(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)),p=e.computed((()=>({modelValue:o.value.modelValue,valid:o.value.valid,invalid:o.value.invalid,loading:o.value.loading}))),f=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:p,HintSlot:f}}const ve={...H,...I,...T,...D,...B,...V,...E,...x,...w,...C,...O,...N,...A,...j,...R,..._,multiple:Boolean,required:Boolean,size:[String,Number],modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},placeholder:String};function pe(t,l,o){const a=W(),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 fe(t,l){const{focused:o}=a.useFocus(t);return e.watch(o,(o=>{l(o?"focus":"blur",e.unref(t))})),{focused:o}}function me(t,l){const o=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===s.before))),a=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===s.after))),n=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===i.left))),r=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===i.right))),u=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===i.top))),d=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===i.bottom)));return{hasIcon:e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),hasIconLeft:n,hasIconRight:r,hasIconTop:u,hasIconBottom:d,hasIconBefore:o,hasIconAfter:a}}function be(t){const{options:l,labelKey:o,valueKey:a,disabledKey:n}=e.toRefs(t);return{options:l,getOptionLabel:e=>"object"!=typeof e&&null!==e?e:String("function"==typeof o.value?o.value(e):r.get(e,o.value)),getOptionValue:e=>"object"!=typeof e&&null!==e?e:"function"==typeof a.value?a.value(e):r.get(e,a.value),getOptionDisabled:e=>("object"==typeof e||null===e)&&("function"==typeof n.value?n.value(e):r.get(e,n.value)),getOptionGrouped:e=>"object"!=typeof e&&null!==e?[]:e.options||[]}}const ge=["for"],ye={class:"vv-select__wrapper"},he={key:0,class:"vv-select__input-before"},ke={class:"vv-select__inner"},Se=["id"],Be=["disabled","hidden"],Ve=["disabled","value"],xe=["disabled","label"],we=["disabled","value"],Le={key:1,class:"vv-select__input-after"},Pe=e.defineComponent({name:"VvSelect",props:ve,emits:["update:modelValue","focus","blur"],setup(t,{emit:l}){const o=t,n=e.useSlots(),r=pe("VvSelect",ve,o),i=e.ref(),{HintSlot:u,hasHintLabelOrSlot:s,hasInvalidLabelOrSlot:d,hintSlotScope:c}=ce(r,n),{id:v,modifiers:p,disabled:f,readonly:m,loading:b,icon:g,iconPosition:y,invalid:h,valid:k,floating:S,multiple:B}=e.toRefs(o),V=Q(v),x=e.computed((()=>`${V.value}-hint`)),{focused:w}=fe(i,l),L=a.useElementVisibility(i);e.watch(L,(e=>{e&&o.autofocus&&(w.value=!0)}));const{hasIcon:P,hasIconBefore:$,hasIconAfter:_}=me(g,y),C=e.computed((()=>!ue(o.modelValue))),O=e.computed((()=>o.disabled||o.readonly)),E=e.computed((()=>O.value?-1:o.tabindex)),N=e.computed((()=>!0===o.invalid||!0!==o.valid&&void 0)),A=G("vv-select",p,e.computed((()=>({valid:k.value,invalid:h.value,loading:b.value,disabled:f.value,readonly:m.value,"icon-before":$.value,"icon-after":_.value,dirty:C.value,focus:w.value,floating:S.value,multiple:B.value})))),D=e.computed((()=>({name:o.name,tabindex:E.value,disabled:O.value,required:o.required,size:o.size,autocomplete:o.autocomplete,multiple:o.multiple,"aria-invalid":N.value,"aria-describedby":s.value?x.value:void 0,"aria-errormessage":d.value?x.value:void 0}))),j=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue}))),{getOptionLabel:R,getOptionValue:F,getOptionDisabled:z,getOptionGrouped:H}=be(o),I=e.computed({get:()=>o.modelValue,set:e=>{Array.isArray(e)&&(e=e.filter((e=>void 0!==e))),l("update:modelValue",e)}}),T=e=>"string"!=typeof e&&(e&&e.options&&e.options.length>0);return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref(A))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(V)},e.toDisplayString(t.label),9,ge)):e.createCommentVNode("",!0),e.createElementVNode("div",ye,[t.$slots.before?(e.openBlock(),e.createElementBlock("div",he,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(j))))])):e.createCommentVNode("",!0),e.createElementVNode("div",ke,[e.unref($)?(e.openBlock(),e.createBlock(U,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(P)),null,16)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("select",e.mergeProps({id:e.unref(V),ref_key:"select",ref:i,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(I)?I.value=t:null)},e.unref(D)),[t.placeholder?(e.openBlock(),e.createElementBlock("option",{key:0,value:void 0,disabled:!t.unselectable,hidden:!t.unselectable},e.toDisplayString(t.placeholder),9,Be)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,((t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[T(t)?(e.openBlock(),e.createElementBlock("optgroup",{key:`group-${l}`,disabled:e.unref(z)(t),label:e.unref(R)(t)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(H)(t),((t,o)=>(e.openBlock(),e.createElementBlock("option",{key:`group-${l}-item-${o}`,disabled:e.unref(z)(t),value:e.unref(F)(t)},e.toDisplayString(e.unref(R)(t)),9,we)))),128))],8,xe)):(e.openBlock(),e.createElementBlock("option",{key:l,disabled:e.unref(z)(t),value:e.unref(F)(t)},e.toDisplayString(e.unref(R)(t)),9,Ve))],64)))),256))],16,Se),[[e.vModelSelect,e.unref(I)]]),e.unref(_)?(e.openBlock(),e.createBlock(U,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(P)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Le,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(j))))])):e.createCommentVNode("",!0)]),e.createVNode(e.unref(u),{id:e.unref(x),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(c))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"3"}:void 0]),1032,["id"])],2))}}),$e={...O,value:[String,Number]},_e=e.defineComponent({name:"VvBadge",props:$e,setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=G("vv-badge",o);return(t,l)=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass(e.unref(a)),role:"status"},[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.value),1)]))],2))}}),Ce=M,Oe=e.defineComponent({name:"VvAction",props:Ce,emits:["click","mouseover","mouseleave"],setup(t,{expose:l,emit:o}){const a=t,n=W(),r=e.ref(null);l({$el:r});const{reference:i,bus:u,aria:s,expanded:d}=e.inject(y,{});e.watch((()=>r.value),(e=>{i&&(i.value=e)}));const v=e.computed((()=>a.pressed||(null==d?void 0:d.value))),{role:p}=e.inject(k,{}),f=e.computed((()=>{switch(!0){case a.disabled:return c.button;case void 0!==a.to:return(null==n?void 0:n.nuxt)?c.nuxtLink:c.routerLink;case void 0!==a.href:return c.a;default:return c.button}})),m=e.computed((()=>{const e={...null==s?void 0:s.value,ariaPressed:!!v.value||void 0,ariaLabel:a.ariaLabel,role:null==p?void 0:p.value};switch(f.value){case c.a:return{...e,href:a.href,target:a.target,rel:a.rel};case c.routerLink:case c.nuxtLink:return{...e,to:a.to,target:a.target};default:return{...e,type:a.type,disabled:a.disabled}}})),b=e=>{a.disabled?e.preventDefault():(null==u||u.emit("click",e),o("click",e))},g=e=>{null==u||u.emit("mouseover",e),o("mouseover",e)},h=e=>{null==u||u.emit("mouseleave",e),o("mouseleave",e)};return(t,l)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(f)),e.mergeProps(e.unref(m),{ref_key:"element",ref:r,class:{active:t.active,pressed:e.unref(v),disabled:t.disabled},onClickPassive:b,onMouseoverPassive:g,onMouseleavePassive:h}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.label),1)]))])),_:3},16,["class"]))}});const Ee={...M,...F,...O,...R,...x,icon:[String,Object],iconPosition:{type:String,default:i.left,validator:e=>Object.values(i).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 Ne(t,l){const{group:o,isInGroup:a,getGroupOrLocalRef:n}=function(t){const l=e.inject(t,void 0),o=e.computed((()=>!ue(l)));return{group:l,isInGroup:o,getGroupOrLocalRef:function(t,o,a){if(null==l?void 0:l.value){const o=e.unref(l.value)[t];return e.computed({get:()=>null==o?void 0:o.value,set(e){o.value=e}})}const n=e.toRef(o,t);return e.computed({get:()=>n.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),p=n("unselectable",t),f=e.computed((()=>(null==o?void 0:o.value.multiple.value)??!1)),m=e.computed((()=>{let e=t.modifiers,l=null==o?void 0:o.value.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((()=>{var e;return Boolean(t.disabled||(null==(e=null==o?void 0:o.value)?void 0:e.disabled.value))}));return{group:o,isInGroup:a,modelValue:c,toggle:v,unselectable:p,multiple:f,modifiers:m,disabled:b,id:r,pressed:d,iconPosition:i,icon:u,label:s}}const Ae={key:1,class:"vv-button__label"},De={key:1,class:"vv-button__label"},je=e.defineComponent({name:"VvButton",props:Ee,emits:["update:modelValue"],setup(t,{expose:l,emit:o}){const a=t,n=e.useAttrs(),r=e.useSlots(),{id:u,modifiers:s,iconPosition:d,icon:c,label:v,modelValue:p,disabled:f,toggle:m,unselectable:b}=Ne(a,o),g=Q(u),y=e.computed((()=>(null==n?void 0:n.name)||g.value)),h=e.ref(null);l({$el:e.computed((()=>{var e;return null==(e=h.value)?void 0:e.$el}))});const k=e.computed((()=>m.value?Array.isArray(p.value)?ie(y.value,p.value):ae(y.value,p.value):a.pressed)),S=G("vv-button",s,e.computed((()=>({reverse:[i.right,i.bottom].includes(d.value),column:[i.top,i.bottom].includes(d.value),"icon-only":Boolean((null==c?void 0:c.value)&&!(null==v?void 0:v.value)&&!r.default)})))),B=e.computed((()=>"string"==typeof(null==c?void 0:c.value)?{name:null==c?void 0:c.value}:null==c?void 0:c.value)),V=e.computed((()=>void 0!==a.value?a.value:y.value)),x=()=>{if(m.value){if(Array.isArray(p.value))return ie(V.value,p.value)?void(b.value&&(p.value=p.value.filter((e=>e!==V.value)))):void p.value.push(V.value);if(V.value===p.value&&b.value)return void(p.value=a.uncheckedValue);p.value=V.value}};return(t,l)=>(e.openBlock(),e.createBlock(Oe,e.mergeProps({disabled:e.unref(f),pressed:e.unref(k),active:t.active,type:t.type,to:t.to,href:t.href,target:t.target,rel:t.rel,ariaLabel:t.ariaLabel},{id:e.unref(g),ref_key:"element",ref:h,class:e.unref(S),onClick:x}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[t.loading?e.renderSlot(t.$slots,"loading",{key:0},(()=>[t.loadingIcon?(e.openBlock(),e.createBlock(U,{key:0,class:"vv-button__loading-icon",name:t.loadingIcon},null,8,["name"])):e.createCommentVNode("",!0),t.loadingLabel?(e.openBlock(),e.createElementBlock("span",Ae,e.toDisplayString(t.loadingLabel),1)):e.createCommentVNode("",!0)])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.renderSlot(t.$slots,"before"),e.unref(c)?(e.openBlock(),e.createBlock(U,e.mergeProps({key:0,class:"vv-button__icon"},e.unref(B)),null,16)):e.createCommentVNode("",!0),e.unref(v)?(e.openBlock(),e.createElementBlock("span",De,[e.renderSlot(t.$slots,"label",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(v)),1)]))])):e.createCommentVNode("",!0),e.renderSlot(t.$slots,"after")],64))]))])),_:3},16,["id","class"]))}}),Re=["id"],Fe=["id","for"],ze=["id","aria-controls","placeholder"],He={key:0,class:"vv-select__input-before"},Ie={class:"vv-select__inner"},Te=["aria-expanded","aria-labelledby","aria-describedby","aria-errormessage","tabindex"],Me={key:0,class:"vv-select__value"},qe=["aria-label","onClick"],Ke={key:1,class:"vv-select__input-after"},We={name:"VvCombobox",components:{VvDropdown:Y,VvDropdownOption:te,VvDropdownOptgroup:oe,VvButton:je}};return e.defineComponent({...We,props:q,emits:["update:modelValue","change:search","focus","blur"],setup(t,{emit:l}){const o=t,n=e.useSlots(),r=pe("VvCombobox",q,o),i=e=>"string"!=typeof e&&(e.options&&e.options.length>0),{HintSlot:u,hasHintLabelOrSlot:s,hasInvalidLabelOrSlot:d,hintSlotScope:c}=ce(r,n),v=e.ref(null),f=e.ref(null),m=e.ref(null),{focused:b}=fe(v,l),{focused:g}=a.useFocusWithin(m);e.watch(b,(e=>{o.autoOpen&&(!e||k.value?e||!k.value||g.value||V():B())})),e.watch(g,(e=>{b.value||e||!k.value||V()}));const y=e.ref(""),h=a.refDebounced(y,Number(o.debounceSearch));e.watch(h,(()=>l("change:search",h.value)));const k=e.ref(!1),S=()=>{o.disabled||o.readonly||(k.value=!k.value)},B=()=>{o.disabled||o.readonly||k.value||(k.value=!0)},V=()=>{o.disabled||o.readonly||!k.value||(k.value=!1)},x=()=>{r.value.searchable&&f.value&&f.value.focus({preventScroll:!0})},w=()=>{r.value.searchable&&(y.value="")},{id:L,icon:P,iconPosition:$,modifiers:_,disabled:C,readonly:O,loading:E,valid:N,invalid:A,floating:D}=e.toRefs(o),j=Q(L),R=e.computed((()=>`${j.value}-hint`)),F=e.computed((()=>`${j.value}-dropdown`)),z=e.computed((()=>`${j.value}-search`)),H=e.computed((()=>`${j.value}-label`)),I=e.ref(!1),T=e.computed((()=>I.value||E.value)),M=e.ref(),{hasIcon:K,hasIconBefore:W,hasIconAfter:J}=me(P,$),X=e.computed((()=>!ue(o.modelValue))),Z=e.computed((()=>C.value||O.value?-1:o.tabindex)),ee=G("vv-select",_,e.computed((()=>({disabled:C.value,loading:T.value,readonly:O.value,"icon-before":Boolean(W.value),"icon-after":Boolean(J.value),valid:N.value,invalid:A.value,dirty:X.value,focus:b.value,floating:D.value,badges:o.badges})))),{getOptionLabel:le,getOptionValue:ne,getOptionDisabled:re,getOptionGrouped:de}=be(o),ve=a.computedAsync((async()=>{var e;if(r.value.searchFunction){I.value=!0;const e=await Promise.resolve(r.value.searchFunction(h.value,o.options));return I.value=!1,e}return null==(e=o.options)?void 0:e.filter((e=>le(e).toLowerCase().includes(h.value.toLowerCase().trim())))}));function ge(e){return Array.isArray(o.modelValue)?ie(e,o.modelValue)||ie(ne(e),o.modelValue):ae(e,o.modelValue)||ae(ne(e),o.modelValue)}const ye=e.computed((()=>{let e=[];Array.isArray(o.modelValue)?e=o.modelValue:o.modelValue&&(e=[o.modelValue]);return o.options.reduce(((e,t)=>i(t)?[...e,...de(t)]:[...e,t]),[]).filter((t=>i(t)?de(t).some((t=>e.includes(ne(t)))):e.includes(ne(t))))})),he=e.computed((()=>ye.value.map((e=>le(e))).join(o.separator))),ke=()=>{o.autoOpen?B():S()},Se=e=>{var t;if(o.disabled||o.readonly)return;const a=ne(e);let n=a;if(o.multiple)if(Array.isArray(o.modelValue)){const e=Number(o.maxValues);if(void 0!==o.maxValues&&e>=0&&(null==(t=o.modelValue)?void 0:t.length)>=e&&!ie(a,o.modelValue))return;n=ie(a,o.modelValue)?se(a,o.modelValue):[...o.modelValue,a]}else n=[a];else o.keepOpen||V(),o.unselectable&&a===o.modelValue&&(n=void 0);l("update:modelValue",n)},Be=e.computed((()=>({id:j.value,name:o.name,tabindex:Z.value,valid:N.value,validLabel:r.value.validLabel,invalid:A.value,invalidLabel:r.value.invalidLabel,hintLabel:r.value.hintLabel,loading:T.value,loadingLabel:r.value.loadingLabel,disabled:C.value,readonly:O.value,modifiers:r.value.modifiers,options:r.value.options,labelKey:r.value.labelKey,valueKey:r.value.valueKey,icon:r.value.icon,iconPosition:r.value.iconPosition,floating:r.value.floating,unselectable:r.value.unselectable,multiple:r.value.multiple,label:r.value.label,placeholder:r.value.placeholder,modelValue:o.modelValue}))),Ve=e.computed((()=>({id:F.value,reference:m.value,placement:r.value.placement,strategy:r.value.strategy,transitionName:r.value.transitionName,offset:r.value.offset,shift:r.value.shift,flip:r.value.flip,autoPlacement:r.value.autoPlacement,arrow:r.value.arrow,autofocusFirst:!!r.value.searchable||r.value.autofocusFirst,triggerWidth:r.value.triggerWidth,modifiers:r.value.dropdownModifiers}))),xe=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue})));return a.onKeyStroke([" ","Enter"],(e=>{o.autoOpen||!k.value&&b.value&&(e.preventDefault(),e.stopImmediatePropagation(),S())}),{target:v}),(t,o)=>t.native?(e.openBlock(),e.createBlock(Pe,e.mergeProps({key:1},e.unref(Be),{"onUpdate:modelValue":o[3]||(o[3]=e=>l("update:modelValue",e))}),null,16)):(e.openBlock(),e.createElementBlock("div",{key:0,id:e.unref(j),class:e.normalizeClass(e.unref(ee))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,id:e.unref(H),for:e.unref(r).searchable?e.unref(z):void 0},e.toDisplayString(t.label),9,Fe)):e.createCommentVNode("",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:m,class:"vv-select__wrapper"},[e.createVNode(Y,e.mergeProps({ref_key:"dropdownEl",ref:M,modelValue:e.unref(k),"onUpdate:modelValue":o[2]||(o[2]=t=>e.isRef(k)?k.value=t:null)},e.unref(Ve),{role:e.unref(p).listbox,onAfterExpand:x,onAfterCollapse:w}),e.createSlots({default:e.withCtx((({aria:l})=>[t.$slots.before?(e.openBlock(),e.createElementBlock("div",He,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(xe))))])):e.createCommentVNode("",!0),e.createElementVNode("div",Ie,[e.unref(W)?(e.openBlock(),e.createBlock(U,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(K)),null,16)):e.createCommentVNode("",!0),e.createElementVNode("div",e.mergeProps({ref_key:"inputEl",ref:v},l,{class:"vv-select__input",role:"combobox","aria-expanded":e.unref(k),"aria-labelledby":e.unref(H),"aria-describedby":e.unref(s)?e.unref(R):void 0,"aria-errormessage":e.unref(d)?e.unref(R):void 0,tabindex:e.unref(Z),onClickPassive:ke}),[e.renderSlot(t.$slots,"value",e.normalizeProps(e.guardReactiveProps({selectedOptions:e.unref(ye),onInput:Se})),(()=>[e.unref(he)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.badges?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(e.unref(ye),((l,o)=>(e.openBlock(),e.createBlock(_e,{key:o,modifiers:t.badgeModifiers,class:"vv-select__badge"},{default:e.withCtx((()=>[e.createTextVNode(e.toDisplayString(e.unref(le)(l))+" ",1),!t.unselectable||e.unref(O)||e.unref(C)?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("button",{key:0,"aria-label":e.unref(r).deselectActionLabel,type:"button",onClick:e.withModifiers((e=>Se(l)),["stop"])},[e.createVNode(U,{name:"close"})],8,qe))])),_:2},1032,["modifiers"])))),128)):(e.openBlock(),e.createElementBlock("div",Me,e.toDisplayString(e.unref(he)),1))],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(t.placeholder),1)],64))]))],16,Te),e.unref(J)?(e.openBlock(),e.createBlock(U,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(K)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Ke,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(xe))))])):e.createCommentVNode("",!0)])),items:e.withCtx((()=>{var l;return[!e.unref(C)&&(null==(l=e.unref(ve))?void 0:l.length)?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(e.unref(ve),((l,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:o},[i(l)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createVNode(oe,{label:e.unref(le)(l)},null,8,["label"]),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(de)(l),((o,a)=>(e.openBlock(),e.createBlock(te,e.mergeProps({disabled:e.unref(re)(o),selected:ge(o),unselectable:t.unselectable,deselectHintLabel:e.unref(r).deselectHintLabel,selectHintLabel:e.unref(r).selectHintLabel,selectedHintLabel:e.unref(r).selectedHintLabel},{key:a,class:"vv-dropdown-option",onClickPassive:e=>Se(o)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(ye),selected:ge(o),disabled:e.unref(re)(o)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(le)(o)),1)]))])),_:2},1040,["onClickPassive"])))),128))],64)):(e.openBlock(),e.createBlock(te,e.mergeProps({key:1},{disabled:e.unref(re)(l),selected:ge(l),unselectable:t.unselectable,deselectHintLabel:e.unref(r).deselectHintLabel,selectHintLabel:e.unref(r).selectHintLabel,selectedHintLabel:e.unref(r).selectedHintLabel},{class:"vv-dropdown-option",onClickPassive:e=>Se(l)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(ye),selected:ge(l),disabled:e.unref(re)(l)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(le)(l)),1)]))])),_:2},1040,["onClickPassive"]))],64)))),128)):t.options.length?e.unref(C)?e.createCommentVNode("",!0):(e.openBlock(),e.createBlock(te,{key:2,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-results",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(r).noResultsLabel),1)]))])),_:3})):(e.openBlock(),e.createBlock(te,{key:1,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-options",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(r).noOptionsLabel),1)]))])),_:3}))]})),after:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::after",{},(()=>{var t;return[(null==(t=e.unref(M))?void 0:t.customPosition)?(e.openBlock(),e.createBlock(je,{key:0,label:e.unref(r).closeLabel,modifiers:"secondary",onClick:o[1]||(o[1]=t=>e.unref(M).hide())},null,8,["label"])):e.createCommentVNode("",!0)]}))])),_:2},[e.unref(r).searchable||t.$slots["dropdown::before"]?{name:"before",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::before"),e.unref(r).searchable&&!e.unref(C)?e.withDirectives((e.openBlock(),e.createElementBlock("input",{key:0,id:e.unref(z),ref_key:"inputSearchEl",ref:f,"onUpdate:modelValue":o[0]||(o[0]=t=>e.isRef(y)?y.value=t:null),"aria-autocomplete":"list","aria-controls":e.unref(F),autocomplete:"off",spellcheck:"false",type:"search",class:"vv-dropdown__search",placeholder:e.unref(r).searchPlaceholder},null,8,ze)),[[e.vModelText,e.unref(y)]]):e.createCommentVNode("",!0)])),key:"0"}:void 0]),1040,["modelValue","role"])],512),e.createVNode(e.unref(u),{id:e.unref(R),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(c))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"3"}:void 0]),1032,["id"])],10,Re))}})}));
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("@iconify/vue"),require("@floating-ui/vue"),require("nanoid"),require("@vueuse/core"),require("mitt"),require("ts-dot-prop")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","@floating-ui/vue","nanoid","@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.nanoid,e.core,e.mitt,e.tsDotProp)}(this,(function(e,t,l,o,a,n,r){"use strict";var i=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(i||{}),u=(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))(u||{}),s=(e=>(e.before="before",e.after="after",e))(s||{}),d=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(d||{}),c=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(c||{}),v=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(v||{}),p=(e=>(e.listbox="listbox",e.menu="menu",e))(p||{}),f=(e=>(e.option="option",e.presentation="presentation",e))(f||{}),m=(e=>(e._blank="_blank",e._self="_self",e._parent="_parent",e._top="_top",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:{type:String,validator:e=>Object.values(m).includes(e)},rel:{type:String,default:"noopener noreferrer"}},B={valid:Boolean,validLabel:[String,Array]},V={invalid:Boolean,invalidLabel:[String,Array]},x={loading:Boolean,loadingLabel:{type:String,default:"Loading..."}},w={disabled:Boolean},L={selected:Boolean},P={active:Boolean},$={pressed:Boolean},_={label:[String,Number]},C={readonly:Boolean},O={modifiers:[String,Array]},E={hintLabel:{type:String,default:""}},N={options:{type:Array,default:()=>[]},labelKey:{type:[String,Function],default:"label"},valueKey:{type:[String,Function],default:"value"},disabledKey:{type:[String,Function],default:"disabled"}},A={icon:{type:[String,Object]},iconPosition:{type:String,default:s.before,validation:e=>Object.values(s).includes(e)}},D={tabindex:{type:[String,Number],default:0}},j={floating:Boolean},R={unselectable:{type:Boolean,default:!0}},F={id:[String,Number]},z={placement:{type:String,default:i.bottom,validator:e=>Object.values(i).includes(e)||Object.values(u).includes(e)},strategy:{type:String,default:"absolute",validator:e=>["fixed","absolute"].includes(e)},transitionName:{type:String},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}},H={...F,name:{type:String,required:!0}},I={autofocus:Boolean},T={autocomplete:{type:String,default:"off"}},M={...w,..._,...$,...P,...S,type:{type:String,default:d.button,validator:e=>Object.values(d).includes(e)},ariaLabel:{type:String,default:void 0}},q={...H,...D,...B,...V,...E,...x,...w,...C,...O,...N,...A,...j,...R,...z,..._,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,maxValues:[Number,String],separator:{type:String,default:", "},native:Boolean,badges:Boolean,badgeModifiers:{type:[String,Array],default:"action sm"},triggerWidth:{...z.triggerWidth,default:!0},dropdownModifiers:{type:[String,Array],default:"mobile"},autoOpen:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1}},K={color:String,width:{type:[String,Number]},height:{type:[String,Number]},name:{type:String,required:!0},provider:{type:String},prefix:{type:String,default:"normal"},src:String,horizontalFlip:Boolean,verticalFlip:Boolean,flip:String,mode:String,inline:Boolean,rotate:[Number,String],onLoad:Function,svg:String,modifiers:{type:[String,Array]}};function W(){return e.inject(b)}function G(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 U=e.defineComponent({name:"VvIcon",props:K,setup(l){const o=l,a=e.computed((()=>"string"==typeof o.rotate?parseFloat(o.rotate):o.rotate)),n=e.ref(!0),r=W(),{modifiers:i}=e.toRefs(o),u=G("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("",!0)}}),J={...F,...z,...O,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:p.menu,validator:e=>Object.values(p).includes(e)}},Q=t=>e.computed((()=>String((null==t?void 0:t.value)||o.nanoid())));const X=["id","tabindex","role","aria-labelledby"],Y=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:J,emits:["update:modelValue","beforeExpand","beforeCollapse","afterExpand","afterCollapse","before-enter","after-leave","enter","after-enter","enter-cancelled","before-leave","leave","leave-cancelled"],setup(t,{expose:o,emit:r}){const i=t,{id:u}=e.toRefs(i),s=Q(u),d=e.useAttrs(),c=e.ref("auto"),v=e.ref("auto"),m=e.ref(null),b=e.ref(),g=e.ref(null),k=e.ref(null),S=e.computed({get:()=>i.reference??m.value,set:e=>{m.value=e}}),B=e.ref(!1);e.onMounted((()=>{a.useMutationObserver(b.value,(()=>{var e;B.value="true"===(null==(e=window.getComputedStyle(b.value).getPropertyValue("--dropdown-custom-position"))?void 0:e.trim())}),{attributeFilter:["style"],window:window})}));const V=e.computed((()=>{const e=[];if(i.autoPlacement?"boolean"==typeof i.autoPlacement?e.push(l.autoPlacement()):e.push(l.autoPlacement(i.autoPlacement)):i.flip&&("boolean"==typeof i.flip?e.push(l.flip({fallbackStrategy:"initialPlacement"})):e.push(l.flip(i.flip))),i.shift&&("boolean"==typeof i.shift?e.push(l.shift()):e.push(l.shift(i.shift))),i.size){const t=({availableWidth:e,availableHeight:t})=>{c.value=`${e}px`,v.value=`${t}px`};"boolean"==typeof i.size?e.push(l.size({apply:t})):e.push(l.size({...i.size,apply:t}))}return i.offset&&(e.push(l.offset(Number(i.offset))),["string","number"].includes(typeof i.offset)?e.push(l.offset(Number(i.offset))):e.push(l.offset(i.offset))),i.arrow&&e.push(l.arrow({element:g})),e})),{x:x,y:w,strategy:L,middlewareData:P,placement:$}=l.useFloating(S,b,{whileElementsMounted:(...e)=>l.autoUpdate(...e,{animationFrame:"fixed"===i.strategy}),placement:e.computed((()=>i.placement)),strategy:e.computed((()=>i.strategy)),middleware:V}),_=e.computed((()=>{var e;if(B.value)return;const t=i.triggerWidth&&S.value?`${null==(e=S.value)?void 0:e.offsetWidth}px`:void 0;return{position:L.value,top:`${w.value??0}px`,left:`${x.value??0}px`,maxWidth:t?void 0:c.value,maxHeight:v.value,width:t}})),C=e.computed((()=>$.value.split("-")[0])),O=e.computed((()=>{var e,t,l,o,a;if(B.value)return;const n={top:"bottom",right:"left",bottom:"top",left:"right"}[C.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==(l=P.value.arrow)?void 0:l.y)?`${null==(o=P.value.arrow)?void 0:o.y}px`:void 0,[n]:-((null==(a=g.value)?void 0:a.offsetWidth)??0)/2+"px"}})),E=a.useVModel(i,"modelValue",r),N=e.ref(!1),A=e.computed({get:()=>E.value??N.value,set:e=>{void 0!==E.value?E.value=e:N.value=e}}),D=()=>{A.value=!0},j=()=>{A.value=!1},R=()=>{A.value=!A.value},F=e=>{S.value=e};o({toggle:R,show:D,hide:j,init:F,customPosition:B}),e.watch(A,(t=>{t&&i.autofocusFirst&&e.nextTick((()=>{const e=J(b.value);e.length>0&&e[0].focus({preventScroll:!0})}))})),a.onClickOutside(b,(()=>{!i.keepOpen&&A.value&&(A.value=!1)}),{ignore:[S]});const z=e.computed((()=>{var e,t;return(null==(t=null==(e=S.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),H=e.computed((()=>({"aria-controls":s.value,"aria-haspopup":!0,"aria-expanded":A.value}))),{component:I,bus:T}=function({reference:t,id:l,expanded:o,aria:a}){const r=n(),i=e.defineComponent({name:"VvDropdownTriggerProvider",setup(){e.provide(y,{reference:t,id:l,expanded:o,aria:a,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:S,id:s,expanded:A,aria:H});T.on("click",R);const{role:M,modifiers:q}=e.toRefs(i),{itemRole:K}=function({role:t,expanded:l}){const o=e.computed((()=>t.value===p.listbox?f.option:f.presentation));return e.provide(h,{role:o,expanded:l}),{itemRole:o}}({role:M,expanded:A}),W=G("vv-dropdown",q,e.computed((()=>({arrow:i.arrow})))),{focused:U}=a.useFocusWithin(b);function J(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"))):[]}a.onKeyStroke("Escape",(e=>{A.value&&(e.preventDefault(),j())})),a.onKeyStroke("ArrowDown",(t=>{A.value&&U.value&&(t.preventDefault(),e.nextTick((()=>{if(U.value){const e=J(b.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})}})))})),a.onKeyStroke("ArrowUp",(t=>{A.value&&U.value&&(t.preventDefault(),e.nextTick((()=>{if(U.value){const e=J(b.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})}})))})),a.onKeyStroke([" ","Enter"],(e=>{const t=e.target;A.value&&U.value&&t&&(null==t||t.click())}));const Y={"before-enter":()=>{r(A.value?"beforeExpand":"beforeCollapse"),r("before-enter")},"after-leave":()=>{r(A.value?"afterExpand":"afterCollapse"),r("after-leave")},enter:()=>{r("enter")},"after-enter":()=>{r("after-enter")},"enter-cancelled":()=>{r("enter-cancelled")},"before-leave":()=>{r("before-leave")},leave:()=>{r("leave")},"leave-cancelled":()=>{r("leave-cancelled")}};return(t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(I),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:F,show:D,hide:j,toggle:R,expanded:e.unref(A),aria:e.unref(H)})))])),_:3}),e.createVNode(e.Transition,e.mergeProps({name:t.transitionName},e.toHandlers(Y)),{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:b,style:e.normalizeStyle(e.unref(_)),class:e.normalizeClass(e.unref(W))},[i.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:g,style:e.normalizeStyle(e.unref(O)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(A)}))),e.createElementVNode("div",e.mergeProps(e.unref(d),{id:e.unref(s),ref_key:"listEl",ref:k,tabindex:e.unref(A)?void 0:-1,role:e.unref(M),"aria-labelledby":e.unref(z),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(K)})))],16,X),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(A)})))],6),[[e.vShow,e.unref(A)]])])),_:3},16,["name"])],64))}});const Z=e.defineComponent({name:"VvDropdownItem",setup(t){const{role:l,expanded:o}=e.inject(h,{}),n=e.ref(null);!function({expanded:t}){e.provide(k,{role:e.ref(v.menuitem),expanded:t})}({expanded:o});const r=a.useElementHover(n),{focused:i}=a.useFocus(n),{focused:u}=a.useFocusWithin(n);return e.watch(r,(e=>{e&&(i.value=!0)})),(t,o)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({role:e.unref(l)},{ref_key:"element",ref:n,class:["vv-dropdown__item",{"focus-visible":e.unref(i)||e.unref(u)}]}),[e.renderSlot(t.$slots,"default")],16))}}),ee=["title"],te=e.defineComponent({name:"VvDropdownOption",props:{...w,...L,...R,...O,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String}},setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=G("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?void 0:l.selectHintLabel));return(t,l)=>(e.openBlock(),e.createBlock(Z,{class:e.normalizeClass(e.unref(a)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled},{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,ee)])),_:3},8,["class","tabindex","aria-selected","aria-disabled"]))}}),le={class:"vv-dropdown-optgroup",role:"presentation",tabindex:"-1"},oe=e.defineComponent({name:"VvDropdownOptgroup",props:{..._},setup(t){const l=t;return(t,o)=>(e.openBlock(),e.createElementBlock("li",le,e.toDisplayString(l.label),1))}});function ae(e,t,l){return l?re(e,l)===re(t,l):ne(e,t)}function ne(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(!ne(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],!ne(e[r],t[r]))return!1;return!0}return e!=e&&t!=t}function re(e,t){if(e&&Object.keys(e).length&&t){if(-1===t.indexOf("."))return e[t];{const l=t.split(".");let o=e;for(let t=0,a=l.length;t<a;++t){if(null==e)return null;o=o[l[t]]}return o}}return null}function ie(e,t){if(null!=e&&t&&t.length)for(const l of t)if(ae(e,l))return!0;return!1}function ue(t){return null==(l=e.unref(t))||""===l||Array.isArray(l)&&0===l.length||!(l instanceof Date)&&"object"==typeof l&&0===Object.keys(l).length;var l}function se(e,t){const l=function(e,t){let l=-1;if(t)for(let o=0;o<t.length;o++)if(ae(t[o],e)){l=o;break}return l}(e,t);return l>-1?t.filter(((e,t)=>t!==l)):t}function de(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}function ce(t,l){const o=e.computed((()=>e.isRef(t)?t.value:t)),a=e.computed((()=>de(o.value.invalidLabel))),n=e.computed((()=>de(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)),p=e.computed((()=>({modelValue:o.value.modelValue,valid:o.value.valid,invalid:o.value.invalid,loading:o.value.loading}))),f=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:p,HintSlot:f}}const ve={...H,...I,...T,...D,...B,...V,...E,...x,...w,...C,...O,...N,...A,...j,...R,..._,multiple:Boolean,required:Boolean,size:[String,Number],modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},placeholder:String};function pe(t,l,o){const a=W(),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 fe(t,l){const{focused:o}=a.useFocus(t);return e.watch(o,(o=>{l(o?"focus":"blur",e.unref(t))})),{focused:o}}function me(t,l){const o=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===s.before))),a=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===s.after))),n=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===i.left))),r=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===i.right))),u=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===i.top))),d=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===i.bottom)));return{hasIcon:e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),hasIconLeft:n,hasIconRight:r,hasIconTop:u,hasIconBottom:d,hasIconBefore:o,hasIconAfter:a}}function be(t){const{options:l,labelKey:o,valueKey:a,disabledKey:n}=e.toRefs(t);return{options:l,getOptionLabel:e=>"object"!=typeof e&&null!==e?e:String("function"==typeof o.value?o.value(e):r.get(e,o.value)),getOptionValue:e=>"object"!=typeof e&&null!==e?e:"function"==typeof a.value?a.value(e):r.get(e,a.value),getOptionDisabled:e=>("object"==typeof e||null===e)&&("function"==typeof n.value?n.value(e):r.get(e,n.value)),getOptionGrouped:e=>"object"!=typeof e&&null!==e?[]:e.options||[]}}const ge=["for"],ye={class:"vv-select__wrapper"},he={key:0,class:"vv-select__input-before"},ke={class:"vv-select__inner"},Se=["id"],Be=["disabled","hidden"],Ve=["disabled","value"],xe=["disabled","label"],we=["disabled","value"],Le={key:1,class:"vv-select__input-after"},Pe=e.defineComponent({name:"VvSelect",props:ve,emits:["update:modelValue","focus","blur"],setup(t,{emit:l}){const o=t,n=e.useSlots(),r=pe("VvSelect",ve,o),i=e.ref(),{HintSlot:u,hasHintLabelOrSlot:s,hasInvalidLabelOrSlot:d,hintSlotScope:c}=ce(r,n),{id:v,modifiers:p,disabled:f,readonly:m,loading:b,icon:g,iconPosition:y,invalid:h,valid:k,floating:S,multiple:B}=e.toRefs(o),V=Q(v),x=e.computed((()=>`${V.value}-hint`)),{focused:w}=fe(i,l),L=a.useElementVisibility(i);e.watch(L,(e=>{e&&o.autofocus&&(w.value=!0)}));const{hasIcon:P,hasIconBefore:$,hasIconAfter:_}=me(g,y),C=e.computed((()=>!ue(o.modelValue))),O=e.computed((()=>o.disabled||o.readonly)),E=e.computed((()=>O.value?-1:o.tabindex)),N=e.computed((()=>!0===o.invalid||!0!==o.valid&&void 0)),A=G("vv-select",p,e.computed((()=>({valid:k.value,invalid:h.value,loading:b.value,disabled:f.value,readonly:m.value,"icon-before":$.value,"icon-after":_.value,dirty:C.value,focus:w.value,floating:S.value,multiple:B.value})))),D=e.computed((()=>({name:o.name,tabindex:E.value,disabled:O.value,required:o.required,size:o.size,autocomplete:o.autocomplete,multiple:o.multiple,"aria-invalid":N.value,"aria-describedby":s.value?x.value:void 0,"aria-errormessage":d.value?x.value:void 0}))),j=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue}))),{getOptionLabel:R,getOptionValue:F,getOptionDisabled:z,getOptionGrouped:H}=be(o),I=e.computed({get:()=>o.modelValue,set:e=>{Array.isArray(e)&&(e=e.filter((e=>void 0!==e))),l("update:modelValue",e)}}),T=e=>"string"!=typeof e&&(e&&e.options&&e.options.length>0);return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref(A))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(V)},e.toDisplayString(t.label),9,ge)):e.createCommentVNode("",!0),e.createElementVNode("div",ye,[t.$slots.before?(e.openBlock(),e.createElementBlock("div",he,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(j))))])):e.createCommentVNode("",!0),e.createElementVNode("div",ke,[e.unref($)?(e.openBlock(),e.createBlock(U,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(P)),null,16)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("select",e.mergeProps({id:e.unref(V),ref_key:"select",ref:i,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(I)?I.value=t:null)},e.unref(D)),[t.placeholder?(e.openBlock(),e.createElementBlock("option",{key:0,value:void 0,disabled:!t.unselectable,hidden:!t.unselectable},e.toDisplayString(t.placeholder),9,Be)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,((t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[T(t)?(e.openBlock(),e.createElementBlock("optgroup",{key:`group-${l}`,disabled:e.unref(z)(t),label:e.unref(R)(t)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(H)(t),((t,o)=>(e.openBlock(),e.createElementBlock("option",{key:`group-${l}-item-${o}`,disabled:e.unref(z)(t),value:e.unref(F)(t)},e.toDisplayString(e.unref(R)(t)),9,we)))),128))],8,xe)):(e.openBlock(),e.createElementBlock("option",{key:l,disabled:e.unref(z)(t),value:e.unref(F)(t)},e.toDisplayString(e.unref(R)(t)),9,Ve))],64)))),256))],16,Se),[[e.vModelSelect,e.unref(I)]]),e.unref(_)?(e.openBlock(),e.createBlock(U,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(P)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Le,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(j))))])):e.createCommentVNode("",!0)]),e.createVNode(e.unref(u),{id:e.unref(x),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(c))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"3"}:void 0]),1032,["id"])],2))}}),$e={...O,value:[String,Number]},_e=e.defineComponent({name:"VvBadge",props:$e,setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=G("vv-badge",o);return(t,l)=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass(e.unref(a)),role:"status"},[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.value),1)]))],2))}}),Ce=M,Oe=e.defineComponent({name:"VvAction",props:Ce,emits:["click","mouseover","mouseleave"],setup(t,{expose:l,emit:o}){const a=t,n=W(),r=e.ref(null);l({$el:r});const{reference:i,bus:u,aria:s,expanded:d}=e.inject(y,{});e.watch((()=>r.value),(e=>{i&&(i.value=e)}));const v=e.computed((()=>a.pressed||(null==d?void 0:d.value))),{role:p}=e.inject(k,{}),f=e.computed((()=>{switch(!0){case a.disabled:return c.button;case void 0!==a.to:return(null==n?void 0:n.nuxt)?c.nuxtLink:c.routerLink;case void 0!==a.href:return c.a;default:return c.button}})),m=e.computed((()=>{const e={...null==s?void 0:s.value,ariaPressed:!!v.value||void 0,ariaLabel:a.ariaLabel,role:null==p?void 0:p.value};switch(f.value){case c.a:return{...e,href:a.href,target:a.target,rel:a.rel};case c.routerLink:case c.nuxtLink:return{...e,to:a.to,target:a.target};default:return{...e,type:a.type,disabled:a.disabled}}})),b=e=>{a.disabled?e.preventDefault():(null==u||u.emit("click",e),o("click",e))},g=e=>{null==u||u.emit("mouseover",e),o("mouseover",e)},h=e=>{null==u||u.emit("mouseleave",e),o("mouseleave",e)};return(t,l)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(f)),e.mergeProps(e.unref(m),{ref_key:"element",ref:r,class:{active:t.active,pressed:e.unref(v),disabled:t.disabled},onClickPassive:b,onMouseoverPassive:g,onMouseleavePassive:h}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.label),1)]))])),_:3},16,["class"]))}});const Ee={...M,...F,...O,...R,...x,icon:[String,Object],iconPosition:{type:String,default:i.left,validator:e=>Object.values(i).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 Ne(t,l){const{group:o,isInGroup:a,getGroupOrLocalRef:n}=function(t){const l=e.inject(t,void 0),o=e.computed((()=>!ue(l)));return{group:l,isInGroup:o,getGroupOrLocalRef:function(t,o,a){if(null==l?void 0:l.value){const o=e.unref(l.value)[t];return e.computed({get:()=>null==o?void 0:o.value,set(e){o.value=e}})}const n=e.toRef(o,t);return e.computed({get:()=>n.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),p=n("unselectable",t),f=e.computed((()=>(null==o?void 0:o.value.multiple.value)??!1)),m=e.computed((()=>{let e=t.modifiers,l=null==o?void 0:o.value.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((()=>{var e;return Boolean(t.disabled||(null==(e=null==o?void 0:o.value)?void 0:e.disabled.value))}));return{group:o,isInGroup:a,modelValue:c,toggle:v,unselectable:p,multiple:f,modifiers:m,disabled:b,id:r,pressed:d,iconPosition:i,icon:u,label:s}}const Ae={key:1,class:"vv-button__label"},De={key:1,class:"vv-button__label"},je=e.defineComponent({name:"VvButton",props:Ee,emits:["update:modelValue"],setup(t,{expose:l,emit:o}){const a=t,n=e.useAttrs(),r=e.useSlots(),{id:u,modifiers:s,iconPosition:d,icon:c,label:v,modelValue:p,disabled:f,toggle:m,unselectable:b}=Ne(a,o),g=Q(u),y=e.computed((()=>(null==n?void 0:n.name)||g.value)),h=e.ref(null);l({$el:e.computed((()=>{var e;return null==(e=h.value)?void 0:e.$el}))});const k=e.computed((()=>m.value?Array.isArray(p.value)?ie(y.value,p.value):ae(y.value,p.value):a.pressed)),S=G("vv-button",s,e.computed((()=>({reverse:[i.right,i.bottom].includes(d.value),column:[i.top,i.bottom].includes(d.value),"icon-only":Boolean((null==c?void 0:c.value)&&!(null==v?void 0:v.value)&&!r.default)})))),B=e.computed((()=>"string"==typeof(null==c?void 0:c.value)?{name:null==c?void 0:c.value}:null==c?void 0:c.value)),V=e.computed((()=>void 0!==a.value?a.value:y.value)),x=()=>{if(m.value){if(Array.isArray(p.value))return ie(V.value,p.value)?void(b.value&&(p.value=p.value.filter((e=>e!==V.value)))):void p.value.push(V.value);if(V.value===p.value&&b.value)return void(p.value=a.uncheckedValue);p.value=V.value}};return(t,l)=>(e.openBlock(),e.createBlock(Oe,e.mergeProps({disabled:e.unref(f),pressed:e.unref(k),active:t.active,type:t.type,to:t.to,href:t.href,target:t.target,rel:t.rel,ariaLabel:t.ariaLabel},{id:e.unref(g),ref_key:"element",ref:h,class:e.unref(S),onClick:x}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[t.loading?e.renderSlot(t.$slots,"loading",{key:0},(()=>[t.loadingIcon?(e.openBlock(),e.createBlock(U,{key:0,class:"vv-button__loading-icon",name:t.loadingIcon},null,8,["name"])):e.createCommentVNode("",!0),t.loadingLabel?(e.openBlock(),e.createElementBlock("span",Ae,e.toDisplayString(t.loadingLabel),1)):e.createCommentVNode("",!0)])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.renderSlot(t.$slots,"before"),e.unref(c)?(e.openBlock(),e.createBlock(U,e.mergeProps({key:0,class:"vv-button__icon"},e.unref(B)),null,16)):e.createCommentVNode("",!0),e.unref(v)?(e.openBlock(),e.createElementBlock("span",De,[e.renderSlot(t.$slots,"label",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(v)),1)]))])):e.createCommentVNode("",!0),e.renderSlot(t.$slots,"after")],64))]))])),_:3},16,["id","class"]))}}),Re=["id"],Fe=["id","for"],ze=["id","aria-controls","placeholder"],He={key:0,class:"vv-select__input-before"},Ie={class:"vv-select__inner"},Te=["aria-expanded","aria-labelledby","aria-describedby","aria-errormessage","tabindex"],Me={key:0,class:"vv-select__value"},qe=["aria-label","onClick"],Ke={key:1,class:"vv-select__input-after"},We={name:"VvCombobox",components:{VvDropdown:Y,VvDropdownOption:te,VvDropdownOptgroup:oe,VvButton:je}};return e.defineComponent({...We,props:q,emits:["update:modelValue","change:search","focus","blur"],setup(t,{emit:l}){const o=t,n=e.useSlots(),r=pe("VvCombobox",q,o),i=e=>"string"!=typeof e&&(e.options&&e.options.length>0),{HintSlot:u,hasHintLabelOrSlot:s,hasInvalidLabelOrSlot:d,hintSlotScope:c}=ce(r,n),v=e.ref(null),f=e.ref(null),m=e.ref(null),{focused:b}=fe(v,l),{focused:g}=a.useFocusWithin(m);e.watch(b,(e=>{o.autoOpen&&(!e||k.value?e||!k.value||g.value||V():B())})),e.watch(g,(e=>{b.value||e||!k.value||V()}));const y=e.ref(""),h=a.refDebounced(y,e.computed((()=>Number(o.debounceSearch))));e.watch(h,(()=>l("change:search",h.value)));const k=e.ref(!1),S=()=>{o.disabled||o.readonly||(k.value=!k.value)},B=()=>{o.disabled||o.readonly||k.value||(k.value=!0)},V=()=>{o.disabled||o.readonly||!k.value||(k.value=!1)},x=()=>{r.value.searchable&&f.value&&f.value.focus({preventScroll:!0})},w=()=>{r.value.searchable&&(y.value="")},{id:L,icon:P,iconPosition:$,modifiers:_,disabled:C,readonly:O,loading:E,valid:N,invalid:A,floating:D}=e.toRefs(o),j=Q(L),R=e.computed((()=>`${j.value}-hint`)),F=e.computed((()=>`${j.value}-dropdown`)),z=e.computed((()=>`${j.value}-search`)),H=e.computed((()=>`${j.value}-label`)),I=e.ref(!1),T=e.computed((()=>I.value||E.value)),M=e.ref(),{hasIcon:K,hasIconBefore:W,hasIconAfter:J}=me(P,$),X=e.computed((()=>!ue(o.modelValue))),Z=e.computed((()=>C.value||O.value?-1:o.tabindex)),ee=G("vv-select",_,e.computed((()=>({disabled:C.value,loading:T.value,readonly:O.value,"icon-before":Boolean(W.value),"icon-after":Boolean(J.value),valid:N.value,invalid:A.value,dirty:X.value,focus:b.value,floating:D.value,badges:o.badges})))),{getOptionLabel:le,getOptionValue:ne,getOptionDisabled:re,getOptionGrouped:de}=be(o),ve=a.computedAsync((async()=>{var e;if(r.value.searchFunction){I.value=!0;const e=await Promise.resolve(r.value.searchFunction(h.value,o.options));return I.value=!1,e}return null==(e=o.options)?void 0:e.filter((e=>le(e).toLowerCase().includes(h.value.toLowerCase().trim())))}));function ge(e){return Array.isArray(o.modelValue)?ie(e,o.modelValue)||ie(ne(e),o.modelValue):ae(e,o.modelValue)||ae(ne(e),o.modelValue)}const ye=e.computed((()=>{let e=[];Array.isArray(o.modelValue)?e=o.modelValue:o.modelValue&&(e=[o.modelValue]);return o.options.reduce(((e,t)=>i(t)?[...e,...de(t)]:[...e,t]),[]).filter((t=>i(t)?de(t).some((t=>e.includes(ne(t)))):e.includes(ne(t))))})),he=e.computed((()=>ye.value.map((e=>le(e))).join(o.separator))),ke=()=>{o.autoOpen?B():S()},Se=e=>{var t;if(o.disabled||o.readonly)return;const a=ne(e);let n=a;if(o.multiple)if(Array.isArray(o.modelValue)){const e=Number(o.maxValues);if(void 0!==o.maxValues&&e>=0&&(null==(t=o.modelValue)?void 0:t.length)>=e&&!ie(a,o.modelValue))return;n=ie(a,o.modelValue)?se(a,o.modelValue):[...o.modelValue,a]}else n=[a];else o.keepOpen||V(),o.unselectable&&a===o.modelValue&&(n=void 0);l("update:modelValue",n)},Be=e.computed((()=>({id:j.value,name:o.name,tabindex:Z.value,valid:N.value,validLabel:r.value.validLabel,invalid:A.value,invalidLabel:r.value.invalidLabel,hintLabel:r.value.hintLabel,loading:T.value,loadingLabel:r.value.loadingLabel,disabled:C.value,readonly:O.value,modifiers:r.value.modifiers,options:r.value.options,labelKey:r.value.labelKey,valueKey:r.value.valueKey,icon:r.value.icon,iconPosition:r.value.iconPosition,floating:r.value.floating,unselectable:r.value.unselectable,multiple:r.value.multiple,label:r.value.label,placeholder:r.value.placeholder,modelValue:o.modelValue}))),Ve=e.computed((()=>({id:F.value,reference:m.value,placement:r.value.placement,strategy:r.value.strategy,transitionName:r.value.transitionName,offset:r.value.offset,shift:r.value.shift,flip:r.value.flip,autoPlacement:r.value.autoPlacement,arrow:r.value.arrow,autofocusFirst:!!r.value.searchable||r.value.autofocusFirst,triggerWidth:r.value.triggerWidth,modifiers:r.value.dropdownModifiers}))),xe=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue})));return a.onKeyStroke([" ","Enter"],(e=>{o.autoOpen||!k.value&&b.value&&(e.preventDefault(),e.stopImmediatePropagation(),S())}),{target:v}),(t,o)=>t.native?(e.openBlock(),e.createBlock(Pe,e.mergeProps({key:1},e.unref(Be),{"onUpdate:modelValue":o[3]||(o[3]=e=>l("update:modelValue",e))}),null,16)):(e.openBlock(),e.createElementBlock("div",{key:0,id:e.unref(j),class:e.normalizeClass(e.unref(ee))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,id:e.unref(H),for:e.unref(r).searchable?e.unref(z):void 0},e.toDisplayString(t.label),9,Fe)):e.createCommentVNode("",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:m,class:"vv-select__wrapper"},[e.createVNode(Y,e.mergeProps({ref_key:"dropdownEl",ref:M,modelValue:e.unref(k),"onUpdate:modelValue":o[2]||(o[2]=t=>e.isRef(k)?k.value=t:null)},e.unref(Ve),{role:e.unref(p).listbox,onAfterExpand:x,onAfterCollapse:w}),e.createSlots({default:e.withCtx((({aria:l})=>[t.$slots.before?(e.openBlock(),e.createElementBlock("div",He,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(xe))))])):e.createCommentVNode("",!0),e.createElementVNode("div",Ie,[e.unref(W)?(e.openBlock(),e.createBlock(U,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(K)),null,16)):e.createCommentVNode("",!0),e.createElementVNode("div",e.mergeProps({ref_key:"inputEl",ref:v},l,{class:"vv-select__input",role:"combobox","aria-expanded":e.unref(k),"aria-labelledby":e.unref(H),"aria-describedby":e.unref(s)?e.unref(R):void 0,"aria-errormessage":e.unref(d)?e.unref(R):void 0,tabindex:e.unref(Z),onClickPassive:ke}),[e.renderSlot(t.$slots,"value",e.normalizeProps(e.guardReactiveProps({selectedOptions:e.unref(ye),onInput:Se})),(()=>[e.unref(he)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.badges?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(e.unref(ye),((l,o)=>(e.openBlock(),e.createBlock(_e,{key:o,modifiers:t.badgeModifiers,class:"vv-select__badge"},{default:e.withCtx((()=>[e.createTextVNode(e.toDisplayString(e.unref(le)(l))+" ",1),!t.unselectable||e.unref(O)||e.unref(C)?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("button",{key:0,"aria-label":e.unref(r).deselectActionLabel,type:"button",onClick:e.withModifiers((e=>Se(l)),["stop"])},[e.createVNode(U,{name:"close"})],8,qe))])),_:2},1032,["modifiers"])))),128)):(e.openBlock(),e.createElementBlock("div",Me,e.toDisplayString(e.unref(he)),1))],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(t.placeholder),1)],64))]))],16,Te),e.unref(J)?(e.openBlock(),e.createBlock(U,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(K)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Ke,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(xe))))])):e.createCommentVNode("",!0)])),items:e.withCtx((()=>{var l;return[!e.unref(C)&&(null==(l=e.unref(ve))?void 0:l.length)?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(e.unref(ve),((l,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:o},[i(l)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createVNode(oe,{label:e.unref(le)(l)},null,8,["label"]),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(de)(l),((o,a)=>(e.openBlock(),e.createBlock(te,e.mergeProps({disabled:e.unref(re)(o),selected:ge(o),unselectable:t.unselectable,deselectHintLabel:e.unref(r).deselectHintLabel,selectHintLabel:e.unref(r).selectHintLabel,selectedHintLabel:e.unref(r).selectedHintLabel},{key:a,class:"vv-dropdown-option",onClickPassive:e=>Se(o)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(ye),selected:ge(o),disabled:e.unref(re)(o)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(le)(o)),1)]))])),_:2},1040,["onClickPassive"])))),128))],64)):(e.openBlock(),e.createBlock(te,e.mergeProps({key:1},{disabled:e.unref(re)(l),selected:ge(l),unselectable:t.unselectable,deselectHintLabel:e.unref(r).deselectHintLabel,selectHintLabel:e.unref(r).selectHintLabel,selectedHintLabel:e.unref(r).selectedHintLabel},{class:"vv-dropdown-option",onClickPassive:e=>Se(l)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(ye),selected:ge(l),disabled:e.unref(re)(l)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(le)(l)),1)]))])),_:2},1040,["onClickPassive"]))],64)))),128)):t.options.length?e.unref(C)?e.createCommentVNode("",!0):(e.openBlock(),e.createBlock(te,{key:2,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-results",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(r).noResultsLabel),1)]))])),_:3})):(e.openBlock(),e.createBlock(te,{key:1,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-options",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(r).noOptionsLabel),1)]))])),_:3}))]})),after:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::after",{},(()=>{var t;return[(null==(t=e.unref(M))?void 0:t.customPosition)?(e.openBlock(),e.createBlock(je,{key:0,label:e.unref(r).closeLabel,modifiers:"secondary",onClick:o[1]||(o[1]=t=>e.unref(M).hide())},null,8,["label"])):e.createCommentVNode("",!0)]}))])),_:2},[e.unref(r).searchable||t.$slots["dropdown::before"]?{name:"before",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::before"),e.unref(r).searchable&&!e.unref(C)?e.withDirectives((e.openBlock(),e.createElementBlock("input",{key:0,id:e.unref(z),ref_key:"inputSearchEl",ref:f,"onUpdate:modelValue":o[0]||(o[0]=t=>e.isRef(y)?y.value=t:null),"aria-autocomplete":"list","aria-controls":e.unref(F),autocomplete:"off",spellcheck:"false",type:"search",class:"vv-dropdown__search",placeholder:e.unref(r).searchPlaceholder},null,8,ze)),[[e.vModelText,e.unref(y)]]):e.createCommentVNode("",!0)])),key:"0"}:void 0]),1040,["modelValue","role"])],512),e.createVNode(e.unref(u),{id:e.unref(R),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(c))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(c))))])),key:"3"}:void 0]),1032,["id"])],10,Re))}})}));
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { unref, computed, isRef, defineComponent, h, inject, ref, toRefs, openBlock, createBlock, mergeProps, createCommentVNode, watch, useSlots, createElementBlock, normalizeClass, toDisplayString, createElementVNode, renderSlot, normalizeProps, guardReactiveProps, withModifiers,
|
|
2
|
-
import {
|
|
1
|
+
import { unref, computed, isRef, defineComponent, h, inject, ref, toRefs, openBlock, createBlock, mergeProps, createCommentVNode, watch, useSlots, onMounted, createElementBlock, normalizeClass, toDisplayString, createElementVNode, renderSlot, normalizeProps, guardReactiveProps, withModifiers, createTextVNode, createVNode, createSlots, withCtx } from "vue";
|
|
2
|
+
import { useIMask } from "vue-imask";
|
|
3
3
|
import { iconExists, Icon, addIcon } from "@iconify/vue";
|
|
4
4
|
import { nanoid } from "nanoid";
|
|
5
5
|
import { useFocus, useElementVisibility } from "@vueuse/core";
|
|
@@ -740,7 +740,23 @@ const TYPES_ICON = {
|
|
|
740
740
|
COLOR: "color",
|
|
741
741
|
SEARCH: "close"
|
|
742
742
|
};
|
|
743
|
-
const VvInputTextEvents = [
|
|
743
|
+
const VvInputTextEvents = [
|
|
744
|
+
"update:modelValue",
|
|
745
|
+
"update:masked",
|
|
746
|
+
"accept",
|
|
747
|
+
"accept:typed",
|
|
748
|
+
"accept:masked",
|
|
749
|
+
"accept:unmasked",
|
|
750
|
+
"complete",
|
|
751
|
+
"complete:typed",
|
|
752
|
+
"complete:masked",
|
|
753
|
+
"complete:unmasked",
|
|
754
|
+
"focus",
|
|
755
|
+
"blur",
|
|
756
|
+
"keyup",
|
|
757
|
+
"keydown",
|
|
758
|
+
"keypress"
|
|
759
|
+
];
|
|
744
760
|
const VvInputTextProps = {
|
|
745
761
|
...InputTextareaProps,
|
|
746
762
|
/**
|
|
@@ -847,44 +863,19 @@ const VvInputTextProps = {
|
|
|
847
863
|
default: "Clear"
|
|
848
864
|
},
|
|
849
865
|
/**
|
|
850
|
-
*
|
|
851
|
-
* @see https://
|
|
866
|
+
* iMask options
|
|
867
|
+
* @see https://imask.js.org/guide.html
|
|
852
868
|
*/
|
|
853
|
-
|
|
854
|
-
type: String,
|
|
855
|
-
default: void 0
|
|
856
|
-
},
|
|
857
|
-
/**
|
|
858
|
-
* Show mask before typing
|
|
859
|
-
* @see https://beholdr.github.io/maska/#/?id=maskinput-options
|
|
860
|
-
*/
|
|
861
|
-
maskEager: {
|
|
862
|
-
type: Boolean,
|
|
863
|
-
default: false
|
|
864
|
-
},
|
|
865
|
-
/**
|
|
866
|
-
* Write values reverse (ex. for numbers)
|
|
867
|
-
* @see https://beholdr.github.io/maska/#/?id=maskinput-options
|
|
868
|
-
*/
|
|
869
|
-
maskReversed: {
|
|
870
|
-
type: Boolean,
|
|
871
|
-
default: false
|
|
872
|
-
},
|
|
873
|
-
/**
|
|
874
|
-
* Add mask custom tokens
|
|
875
|
-
* @see https://beholdr.github.io/maska/#/?id=custom-tokens
|
|
876
|
-
*/
|
|
877
|
-
maskTokens: {
|
|
869
|
+
iMask: {
|
|
878
870
|
type: Object,
|
|
879
871
|
default: void 0
|
|
880
872
|
},
|
|
881
873
|
/**
|
|
882
|
-
*
|
|
883
|
-
* @see https://beholdr.github.io/maska/#/?id=custom-tokens
|
|
874
|
+
* Masked value
|
|
884
875
|
*/
|
|
885
|
-
|
|
886
|
-
type:
|
|
887
|
-
default:
|
|
876
|
+
masked: {
|
|
877
|
+
type: String,
|
|
878
|
+
default: void 0
|
|
888
879
|
},
|
|
889
880
|
/**
|
|
890
881
|
* Adjust input width to content
|
|
@@ -1334,9 +1325,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
1334
1325
|
VvInputTextProps,
|
|
1335
1326
|
props
|
|
1336
1327
|
);
|
|
1337
|
-
const inputEl = ref();
|
|
1338
|
-
const innerEl = ref();
|
|
1339
|
-
__expose({ $inner: innerEl });
|
|
1340
1328
|
const {
|
|
1341
1329
|
id,
|
|
1342
1330
|
icon,
|
|
@@ -1346,35 +1334,90 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
1346
1334
|
count,
|
|
1347
1335
|
valid,
|
|
1348
1336
|
invalid,
|
|
1349
|
-
loading
|
|
1337
|
+
loading,
|
|
1338
|
+
debounce,
|
|
1339
|
+
maxlength,
|
|
1340
|
+
minlength,
|
|
1341
|
+
type,
|
|
1342
|
+
iMask,
|
|
1343
|
+
step
|
|
1350
1344
|
} = toRefs(props);
|
|
1351
1345
|
const hasId = useUniqueId(id);
|
|
1352
1346
|
const hasHintId = computed(() => `${hasId.value}-hint`);
|
|
1353
1347
|
const inputTextPlaceholder = computed(
|
|
1354
1348
|
() => props.floating && isEmpty(props.placeholder) ? " " : props.placeholder
|
|
1355
1349
|
);
|
|
1356
|
-
const
|
|
1357
|
-
|
|
1358
|
-
|
|
1359
|
-
|
|
1350
|
+
const maskReady = ref(false);
|
|
1351
|
+
const { el, mask, typed, masked, unmasked } = useIMask(
|
|
1352
|
+
computed(
|
|
1353
|
+
() => (iMask == null ? void 0 : iMask.value) ?? {
|
|
1354
|
+
mask: /./
|
|
1355
|
+
}
|
|
1356
|
+
),
|
|
1360
1357
|
{
|
|
1361
|
-
|
|
1362
|
-
|
|
1363
|
-
|
|
1358
|
+
emit,
|
|
1359
|
+
onAccept: () => {
|
|
1360
|
+
if (!maskReady.value) {
|
|
1361
|
+
return;
|
|
1362
|
+
}
|
|
1363
|
+
emit("update:masked", masked.value);
|
|
1364
|
+
if (type.value === INPUT_TYPES.NUMBER) {
|
|
1365
|
+
if (typeof typed.value !== "number") {
|
|
1366
|
+
localModelValue.value = Number(typed.value);
|
|
1367
|
+
return;
|
|
1368
|
+
}
|
|
1369
|
+
localModelValue.value = typed.value;
|
|
1370
|
+
return;
|
|
1364
1371
|
}
|
|
1365
|
-
|
|
1366
|
-
|
|
1367
|
-
|
|
1368
|
-
|
|
1369
|
-
|
|
1372
|
+
if (type.value === INPUT_TYPES.DATE) {
|
|
1373
|
+
let date = typed.value;
|
|
1374
|
+
if (!(date instanceof Date)) {
|
|
1375
|
+
date = new Date(date);
|
|
1376
|
+
}
|
|
1377
|
+
localModelValue.value = `${date.getFullYear()}-${("0" + (date.getMonth() + 1)).slice(-2)}-${("0" + date.getDate()).slice(-2)}`;
|
|
1378
|
+
return;
|
|
1370
1379
|
}
|
|
1371
|
-
if (
|
|
1372
|
-
|
|
1380
|
+
if (type.value === INPUT_TYPES.DATETIME_LOCAL) {
|
|
1381
|
+
let date = typed.value;
|
|
1382
|
+
if (!(typed.value instanceof Date)) {
|
|
1383
|
+
date = new Date(date);
|
|
1384
|
+
}
|
|
1385
|
+
localModelValue.value = `${date.getFullYear()}-${("0" + (date.getMonth() + 1)).slice(-2)}-${("0" + date.getDate()).slice(-2)}T${("0" + date.getHours()).slice(-2)}:${("0" + date.getMinutes()).slice(-2)}`;
|
|
1386
|
+
return;
|
|
1373
1387
|
}
|
|
1374
|
-
|
|
1388
|
+
localModelValue.value = unmasked.value;
|
|
1375
1389
|
}
|
|
1376
1390
|
}
|
|
1377
1391
|
);
|
|
1392
|
+
onMounted(() => {
|
|
1393
|
+
if (mask.value) {
|
|
1394
|
+
maskReady.value = true;
|
|
1395
|
+
typed.value = localModelValue.value ?? "";
|
|
1396
|
+
}
|
|
1397
|
+
});
|
|
1398
|
+
watch(
|
|
1399
|
+
() => props.modelValue,
|
|
1400
|
+
(newValue) => {
|
|
1401
|
+
var _a;
|
|
1402
|
+
if (mask.value) {
|
|
1403
|
+
typed.value = newValue && ((_a = iMask == null ? void 0 : iMask.value) == null ? void 0 : _a.mask) === Date ? new Date(newValue) : newValue ?? null;
|
|
1404
|
+
}
|
|
1405
|
+
}
|
|
1406
|
+
);
|
|
1407
|
+
watch(
|
|
1408
|
+
() => props.masked,
|
|
1409
|
+
(newValue) => {
|
|
1410
|
+
masked.value = newValue ?? "";
|
|
1411
|
+
}
|
|
1412
|
+
);
|
|
1413
|
+
const inputEl = el;
|
|
1414
|
+
const innerEl = ref();
|
|
1415
|
+
__expose({ $inner: innerEl });
|
|
1416
|
+
const localModelValue = useDebouncedInput(
|
|
1417
|
+
modelValue,
|
|
1418
|
+
emit,
|
|
1419
|
+
(debounce == null ? void 0 : debounce.value) ?? 0
|
|
1420
|
+
);
|
|
1378
1421
|
const { focused } = useComponentFocus(inputEl, emit);
|
|
1379
1422
|
const isFocused = computed(
|
|
1380
1423
|
() => focused.value && !props.disabled && !props.readonly
|
|
@@ -1401,19 +1444,27 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
1401
1444
|
const isNumber = computed(() => props.type === INPUT_TYPES.NUMBER);
|
|
1402
1445
|
const onStepUp = () => {
|
|
1403
1446
|
if (isClickable.value) {
|
|
1447
|
+
if (iMask == null ? void 0 : iMask.value) {
|
|
1448
|
+
typed.value = typed.value + Number((step == null ? void 0 : step.value) ?? 1);
|
|
1449
|
+
return;
|
|
1450
|
+
}
|
|
1404
1451
|
inputEl.value.stepUp();
|
|
1405
1452
|
localModelValue.value = unref(inputEl).value;
|
|
1406
1453
|
}
|
|
1407
1454
|
};
|
|
1408
1455
|
const onStepDown = () => {
|
|
1409
1456
|
if (isClickable.value) {
|
|
1457
|
+
if (iMask == null ? void 0 : iMask.value) {
|
|
1458
|
+
typed.value = typed.value - Number((step == null ? void 0 : step.value) ?? 1);
|
|
1459
|
+
return;
|
|
1460
|
+
}
|
|
1410
1461
|
inputEl.value.stepDown();
|
|
1411
1462
|
localModelValue.value = unref(inputEl).value;
|
|
1412
1463
|
}
|
|
1413
1464
|
};
|
|
1414
1465
|
const isSearch = computed(() => props.type === INPUT_TYPES.SEARCH);
|
|
1415
1466
|
const onClear = () => {
|
|
1416
|
-
localModelValue.value =
|
|
1467
|
+
localModelValue.value = "";
|
|
1417
1468
|
};
|
|
1418
1469
|
const { hasIcon, hasIconBefore, hasIconAfter } = useComponentIcon(
|
|
1419
1470
|
icon,
|
|
@@ -1435,9 +1486,9 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
1435
1486
|
}
|
|
1436
1487
|
});
|
|
1437
1488
|
const { formatted: countFormatted } = useTextCount(localModelValue, {
|
|
1438
|
-
mode:
|
|
1439
|
-
upperLimit: Number(
|
|
1440
|
-
lowerLimit: Number(
|
|
1489
|
+
mode: count.value,
|
|
1490
|
+
upperLimit: Number(maxlength == null ? void 0 : maxlength.value),
|
|
1491
|
+
lowerLimit: Number(minlength == null ? void 0 : minlength.value)
|
|
1441
1492
|
});
|
|
1442
1493
|
const isClickable = computed(() => !props.disabled && !props.readonly);
|
|
1443
1494
|
const hasTabindex = computed(
|
|
@@ -1472,17 +1523,20 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
1472
1523
|
}))
|
|
1473
1524
|
);
|
|
1474
1525
|
const hasAttrs = computed(() => {
|
|
1475
|
-
const
|
|
1526
|
+
const type2 = (() => {
|
|
1476
1527
|
if (isPassword.value && showPassword.value) {
|
|
1477
1528
|
return INPUT_TYPES.TEXT;
|
|
1478
1529
|
}
|
|
1479
1530
|
if (isDateTime.value && !isDirty.value && !focused.value) {
|
|
1480
1531
|
return INPUT_TYPES.TEXT;
|
|
1481
1532
|
}
|
|
1533
|
+
if (iMask == null ? void 0 : iMask.value) {
|
|
1534
|
+
return INPUT_TYPES.TEXT;
|
|
1535
|
+
}
|
|
1482
1536
|
return props.type;
|
|
1483
1537
|
})();
|
|
1484
1538
|
const toReturn = {
|
|
1485
|
-
type,
|
|
1539
|
+
type: type2,
|
|
1486
1540
|
name: props.name,
|
|
1487
1541
|
tabindex: hasTabindex.value,
|
|
1488
1542
|
disabled: props.disabled,
|
|
@@ -1493,20 +1547,20 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
1493
1547
|
"aria-describedby": hasHintLabelOrSlot.value ? hasHintId.value : void 0,
|
|
1494
1548
|
"aria-errormessage": hasInvalidLabelOrSlot.value ? hasHintId.value : void 0
|
|
1495
1549
|
};
|
|
1496
|
-
if (
|
|
1550
|
+
if (type2 === INPUT_TYPES.DATE || type2 === INPUT_TYPES.MONTH || type2 === INPUT_TYPES.WEEK || type2 === INPUT_TYPES.TIME || type2 === INPUT_TYPES.DATETIME_LOCAL || type2 === INPUT_TYPES.NUMBER) {
|
|
1497
1551
|
toReturn.step = props.step;
|
|
1498
1552
|
toReturn.max = props.max !== void 0 ? String(props.max) : void 0;
|
|
1499
1553
|
toReturn.min = props.min !== void 0 ? String(props.min) : void 0;
|
|
1500
1554
|
}
|
|
1501
|
-
if (
|
|
1555
|
+
if (type2 === INPUT_TYPES.TEXT || type2 === INPUT_TYPES.SEARCH || type2 === INPUT_TYPES.URL || type2 === INPUT_TYPES.TEL || type2 === INPUT_TYPES.EMAIL || type2 === INPUT_TYPES.PASSWORD || type2 === INPUT_TYPES.NUMBER) {
|
|
1502
1556
|
toReturn.placeholder = inputTextPlaceholder.value;
|
|
1503
1557
|
}
|
|
1504
|
-
if (
|
|
1558
|
+
if (type2 === INPUT_TYPES.TEXT || type2 === INPUT_TYPES.SEARCH || type2 === INPUT_TYPES.URL || type2 === INPUT_TYPES.TEL || type2 === INPUT_TYPES.EMAIL || type2 === INPUT_TYPES.PASSWORD) {
|
|
1505
1559
|
toReturn.minlength = props.minlength;
|
|
1506
1560
|
toReturn.maxlength = props.maxlength;
|
|
1507
1561
|
toReturn.pattern = props.pattern;
|
|
1508
1562
|
}
|
|
1509
|
-
if (
|
|
1563
|
+
if (type2 === INPUT_TYPES.EMAIL) {
|
|
1510
1564
|
toReturn.multiple = props.multiple;
|
|
1511
1565
|
}
|
|
1512
1566
|
return toReturn;
|
|
@@ -1538,31 +1592,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
1538
1592
|
INPUT_TYPES.SEARCH,
|
|
1539
1593
|
props
|
|
1540
1594
|
);
|
|
1541
|
-
const mask = ref();
|
|
1542
|
-
watch(
|
|
1543
|
-
[
|
|
1544
|
-
() => props.mask,
|
|
1545
|
-
() => props.type,
|
|
1546
|
-
() => props.maskEager,
|
|
1547
|
-
() => props.maskReversed,
|
|
1548
|
-
() => props.maskTokens,
|
|
1549
|
-
() => props.maskTokensReplace
|
|
1550
|
-
],
|
|
1551
|
-
([newMask, newType, eager, reversed, tokens, tokensReplace]) => {
|
|
1552
|
-
if (newMask && newType === INPUT_TYPES.TEXT) {
|
|
1553
|
-
mask.value = new Mask({
|
|
1554
|
-
mask: newMask,
|
|
1555
|
-
eager,
|
|
1556
|
-
reversed,
|
|
1557
|
-
tokens,
|
|
1558
|
-
tokensReplace
|
|
1559
|
-
});
|
|
1560
|
-
return;
|
|
1561
|
-
}
|
|
1562
|
-
mask.value = void 0;
|
|
1563
|
-
},
|
|
1564
|
-
{ immediate: true }
|
|
1565
|
-
);
|
|
1566
1595
|
const onClickInner = () => {
|
|
1567
1596
|
if (isClickable.value) {
|
|
1568
1597
|
focused.value = true;
|
|
@@ -1576,6 +1605,23 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
1576
1605
|
width: localModelValue.value !== void 0 ? `${String(localModelValue.value).length + 1}ch` : void 0
|
|
1577
1606
|
};
|
|
1578
1607
|
});
|
|
1608
|
+
const onKeyDown = (event) => {
|
|
1609
|
+
switch (event.code) {
|
|
1610
|
+
case "ArrowUp":
|
|
1611
|
+
if (isNumber.value) {
|
|
1612
|
+
onStepUp();
|
|
1613
|
+
event.preventDefault();
|
|
1614
|
+
}
|
|
1615
|
+
break;
|
|
1616
|
+
case "ArrowDown":
|
|
1617
|
+
if (isNumber.value) {
|
|
1618
|
+
onStepDown();
|
|
1619
|
+
event.preventDefault();
|
|
1620
|
+
}
|
|
1621
|
+
break;
|
|
1622
|
+
}
|
|
1623
|
+
emit("keydown", event);
|
|
1624
|
+
};
|
|
1579
1625
|
return (_ctx, _cache) => {
|
|
1580
1626
|
return openBlock(), createElementBlock("div", {
|
|
1581
1627
|
class: normalizeClass(unref(bemCssClasses))
|
|
@@ -1599,17 +1645,16 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
1599
1645
|
key: 0,
|
|
1600
1646
|
class: "vv-input-text__icon"
|
|
1601
1647
|
}, unref(hasIcon)), null, 16)) : createCommentVNode("", true),
|
|
1602
|
-
|
|
1648
|
+
createElementVNode("input", mergeProps({
|
|
1603
1649
|
id: unref(hasId),
|
|
1604
1650
|
ref_key: "inputEl",
|
|
1605
|
-
ref: inputEl
|
|
1606
|
-
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => isRef(localModelValue) ? localModelValue.value = $event : null)
|
|
1651
|
+
ref: inputEl
|
|
1607
1652
|
}, unref(hasAttrs), {
|
|
1608
1653
|
style: unref(hasStyle),
|
|
1609
|
-
onKeyup: _cache[
|
|
1610
|
-
|
|
1611
|
-
[
|
|
1612
|
-
|
|
1654
|
+
onKeyup: _cache[0] || (_cache[0] = ($event) => emit("keyup", $event)),
|
|
1655
|
+
onKeydown: onKeyDown,
|
|
1656
|
+
onKeypress: _cache[1] || (_cache[1] = ($event) => emit("keypress", $event))
|
|
1657
|
+
}), null, 16, _hoisted_5),
|
|
1613
1658
|
(_ctx.unit || _ctx.$slots.unit) && unref(isDirty) ? (openBlock(), createElementBlock("div", _hoisted_6, [
|
|
1614
1659
|
renderSlot(_ctx.$slots, "default", normalizeProps(guardReactiveProps(unref(slotProps))), () => [
|
|
1615
1660
|
createTextVNode(toDisplayString(_ctx.unit), 1)
|