@volverjs/ui-vue 0.0.10-beta.54 → 0.0.10-beta.56
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/auto-imports.d.ts +3 -0
- package/dist/components/VvCombobox/VvCombobox.es.js +357 -357
- package/dist/components/VvCombobox/VvCombobox.umd.js +1 -1
- package/dist/components/VvInputText/VvInputText.es.js +150 -44
- package/dist/components/VvInputText/VvInputText.umd.js +1 -1
- package/dist/components/VvInputText/VvInputText.vue.d.ts +6 -6
- package/dist/components/VvInputText/index.d.ts +1 -1
- package/dist/components/VvTextarea/VvTextarea.es.js +966 -67
- package/dist/components/VvTextarea/VvTextarea.umd.js +1 -1
- package/dist/components/VvTextarea/VvTextarea.vue.d.ts +52 -0
- package/dist/components/VvTextarea/index.d.ts +37 -1
- package/dist/components/index.es.js +542 -284
- 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.test.d.ts +1 -0
- package/dist/stories/InputText/InputTextIso.stories.d.ts +10 -0
- package/dist/utils/DateUtilities.d.ts +22 -0
- package/package.json +22 -22
- package/src/assets/icons/detailed.json +1 -1
- package/src/assets/icons/normal.json +1 -1
- package/src/assets/icons/simple.json +1 -1
- package/src/components/VvCombobox/VvCombobox.vue +3 -3
- package/src/components/VvInputText/VvInputText.vue +103 -63
- package/src/components/VvInputText/index.ts +1 -1
- package/src/components/VvTextarea/VvTextarea.vue +108 -5
- package/src/components/VvTextarea/index.ts +32 -1
- package/src/stories/InputText/InputText.test.ts +25 -0
- package/src/stories/InputText/InputTextIso.stories.ts +69 -0
- package/src/utils/DateUtilities.ts +98 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("vue-imask"),require("@floating-ui/vue"),require("@vueuse/core"),require("mitt"),require("@iconify/vue")):"function"==typeof define&&define.amd?define(["vue","vue-imask","@floating-ui/vue","@vueuse/core","mitt","@iconify/vue"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvInputText=t(e.vue,e.vueImask,e.vue$1,e.core,e.mitt,e.vue$2)}(this,(function(e,t,o,l,a,n){"use strict";function i(t){return null==(o=e.unref(t))||""===o||Array.isArray(o)&&0===o.length||!(o instanceof Date)&&"object"==typeof o&&0===Object.keys(o).length;var o}function r(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}var u=(e=>(e.local="local",e.session="session",e))(u||{}),s=(e=>(e.absolute="absolute",e.fixed="fixed",e))(s||{}),d=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(d||{}),c=(e=>(e.topStart="top-start",e.topEnd="top-end",e.bottomStart="bottom-start",e.bottomEnd="bottom-end",e.leftStart="left-start",e.leftEnd="left-end",e.rightStart="right-start",e.rightEnd="right-end",e))(c||{}),v=(e=>(e.before="before",e.after="after",e))(v||{}),p=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(p||{}),f=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(f||{}),m=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(m||{}),b=(e=>(e.listbox="listbox",e.menu="menu",e))(b||{}),h=(e=>(e.option="option",e.presentation="presentation",e))(h||{});const g=Symbol.for("volver"),y=Symbol.for("dropdownTrigger"),S=Symbol.for("dropdownItem"),w=Symbol.for("dropdownAction"),k={valid:{type:Boolean,default:!1},validLabel:{type:[String,Array],default:void 0}},x={invalid:{type:Boolean,default:!1},invalidLabel:{type:[String,Array],default:void 0}},E={loading:{type:Boolean,default:!1},loadingLabel:{type:String,default:"Loading..."}},L={disabled:{type:Boolean,default:!1}},B={required:{type:Boolean,default:!1}},$={selected:{type:Boolean,default:!1}},C=(Boolean,Boolean,Boolean,{label:{type:[String,Number],default:void 0}}),P={readonly:{type:Boolean,default:!1}},O={modifiers:{type:[String,Array],default:void 0}},N={hintLabel:{type:String,default:""}},T={count:{type:[Boolean,String],default:!1,validator:e=>[!0,!1,"limit","countdown"].includes(e)}},V={debounce:{type:[Number,String],default:void 0}},A={icon:{type:[String,Object],default:void 0},iconPosition:{type:String,default:v.before,validation:e=>Object.values(v).includes(e)}},_={tabindex:{type:[String,Number],default:0}},D={floating:{type:Boolean,default:!1}},I={unselectable:{type:Boolean,default:!0}},R={id:[String,Number]},M={placement:{type:String,default:d.bottom,validator:e=>Object.values(d).includes(e)||Object.values(c).includes(e)},strategy:{type:String,default:void 0,validator:e=>Object.values(s).includes(e)},transitionName:{type:String,default:void 0},offset:{type:[Number,String,Object],default:0},shift:{type:[Boolean,Object],default:!1},flip:{type:[Boolean,Object],default:!0},size:{type:[Boolean,Object],default:()=>({padding:10})},autoPlacement:{type:[Boolean,Object],default:!1},arrow:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean,default:!1}},H={...{...R,name:{type:String,required:!0}},...{autofocus:{type:Boolean,default:!1}},...{autocomplete:{type:String,default:"off"}},..._,...L,...P,...k,...x,...N,...E,...O,...T,...V,...A,...D,...C,minlength:{type:[String,Number],default:void 0},maxlength:{type:[String,Number],default:void 0},placeholder:{type:String,default:void 0},...B};p.button,f.button;const j={storageType:{type:String,default:u.local,validator:e=>Object.values(u).includes(e)},storageKey:String},z={...R,...M,...O,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:b.menu,validator:e=>Object.values(b).includes(e)}},U={focusOnHover:{type:Boolean,default:!1}},F={...L,...$,...I,...O,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String},focusOnHover:{type:Boolean,default:!1}};function W(t){return e.computed((()=>String((null==t?void 0:t.value)||e.useId())))}function q(t,o,l){return e.computed((()=>{const a={[t]:!0},n="string"==typeof(null==o?void 0:o.value)?o.value.split(" "):null==o?void 0:o.value;return n&&Array.isArray(n)&&n.forEach((e=>{e&&(a[`${t}--${e}`]=!0)})),l&&Object.keys(l.value).forEach((o=>{a[`${t}--${o}`]=e.unref(l.value[o])})),a}))}const K=["id","tabindex","role","aria-labelledby"],X=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:z,emits:["update:modelValue","beforeEnter","afterLeave","beforeExpand","beforeCollapse","afterExpand","afterCollapse","before-enter","after-leave","enter","afterEnter","enterCancelled","beforeLeave","leave","leaveCancelled"],setup(t,{expose:n,emit:i}){const r=t,u=i,{id:c}=e.toRefs(r),v=W(c),p=e.useAttrs(),f=e.ref("auto"),m=e.ref("auto"),g=e.ref(),w=e.ref(),k=e.ref(),x=e.ref(),E=e.computed({get:()=>r.reference??g.value,set:e=>{g.value=e}}),L=e.ref(!1);e.onMounted((()=>{l.useMutationObserver(w.value,(()=>{var e;L.value="true"===(null==(e=window.getComputedStyle(w.value).getPropertyValue("--dropdown-custom-position"))?void 0:e.trim())}),{attributeFilter:["style"],window:window})}));const B=e.computed((()=>{const e=[];if(r.autoPlacement?"boolean"==typeof r.autoPlacement?e.push(o.autoPlacement()):e.push(o.autoPlacement(r.autoPlacement)):r.flip&&("boolean"==typeof r.flip?e.push(o.flip({fallbackStrategy:"initialPlacement"})):e.push(o.flip(r.flip))),r.shift&&("boolean"==typeof r.shift?e.push(o.shift()):e.push(o.shift(r.shift))),r.size){const t=({availableWidth:e,availableHeight:t})=>{f.value=`${e}px`,m.value=`${t}px`};"boolean"==typeof r.size?e.push(o.size({apply:t})):e.push(o.size({...r.size,apply:t}))}return r.offset&&(e.push(o.offset(Number(r.offset))),["string","number"].includes(typeof r.offset)?e.push(o.offset(Number(r.offset))):e.push(o.offset(r.offset))),r.arrow&&e.push(o.arrow({element:k})),e})),{x:$,y:C,middlewareData:P,placement:O,strategy:N}=o.useFloating(E,w,{whileElementsMounted:(...e)=>o.autoUpdate(...e,{animationFrame:r.strategy===s.fixed}),placement:e.computed((()=>r.placement)),strategy:e.computed((()=>r.strategy)),middleware:B}),T=e.computed((()=>{var e;if(L.value)return;const t=r.triggerWidth&&E.value?`${null==(e=E.value)?void 0:e.offsetWidth}px`:void 0;return{position:N.value,top:`${C.value??0}px`,left:`${$.value??0}px`,maxWidth:t?void 0:f.value,maxHeight:m.value,width:t}})),V=e.computed((()=>O.value.split("-")[0])),A=e.computed((()=>{var e,t,o,l,a;if(L.value)return;const n={[d.top]:d.bottom,[d.right]:d.left,[d.bottom]:d.top,[d.left]:d.right}[V.value];return{left:void 0!==(null==(e=P.value.arrow)?void 0:e.x)?`${null==(t=P.value.arrow)?void 0:t.x}px`:void 0,top:void 0!==(null==(o=P.value.arrow)?void 0:o.y)?`${null==(l=P.value.arrow)?void 0:l.y}px`:void 0,[n]:-((null==(a=k.value)?void 0:a.offsetWidth)??0)/2+"px"}})),_=l.useVModel(r,"modelValue",u),D=e.ref(!1),I=e.computed({get:()=>_.value??D.value,set:e=>{void 0!==_.value?_.value=e:D.value=e}});function R(){I.value=!0}function M(){I.value=!1}function H(){I.value=!I.value}function j(e){E.value=e}n({toggle:H,show:R,hide:M,init:j,customPosition:L}),e.watch(I,(t=>{t&&r.autofocusFirst&&e.nextTick((()=>{const e=Z(w.value);e.length>0&&e[0].focus({preventScroll:!0})}))})),l.onClickOutside(w,(()=>{!r.keepOpen&&I.value&&(I.value=!1)}),{ignore:[E]});const z=e.computed((()=>{var e,t;return(null==(t=null==(e=E.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),U=e.computed((()=>({"aria-controls":v.value,"aria-haspopup":!0,"aria-expanded":I.value}))),{component:F,bus:X}=function({reference:t,id:o,expanded:l,aria:n}){const i=a(),r=e.defineComponent({name:"VvDropdownTriggerProvider",setup(){e.provide(y,{reference:t,id:o,expanded:l,aria:n,bus:i})},render(){var t,o;return e.h(e.Fragment,{},null==(o=(t=this.$slots).default)?void 0:o.call(t))}});return{bus:i,component:r}}({reference:E,id:v,expanded:I,aria:U});X.on("click",H);const{role:J,modifiers:Y}=e.toRefs(r),G=q("vv-dropdown",Y,e.computed((()=>({arrow:r.arrow})))),{focused:Q}=l.useFocusWithin(w);function Z(e){return e?[...e.querySelectorAll('a[href], button, input, textarea, select, details, [tabindex]:not([tabindex="-1"])')].filter((e=>!e.hasAttribute("disabled")&&!e.getAttribute("aria-hidden"))):[]}const ee=l.useElementHover(w),{itemRole:te}=function({role:t,...o}){const l=e.computed((()=>t.value===b.listbox?h.option:h.presentation));return e.provide(S,{role:l,...o}),{itemRole:l}}({role:J,expanded:I,focused:Q,hovered:ee});l.onKeyStroke("Escape",(e=>{I.value&&(e.preventDefault(),M())})),l.onKeyStroke("ArrowDown",(t=>{I.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=Z(w.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus({preventScroll:!0}):e[0].focus({preventScroll:!0})}})))})),l.onKeyStroke("ArrowUp",(t=>{I.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=Z(w.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus({preventScroll:!0}):e[e.length-1].focus({preventScroll:!0})}})))})),l.onKeyStroke([" ","Enter"],(e=>{const t=e.target;I.value&&Q.value&&t&&(null==t||t.click())}));const oe={"before-enter":()=>{u(I.value?"beforeExpand":"beforeCollapse"),u("beforeEnter")},"after-leave":()=>{u(I.value?"afterExpand":"afterCollapse"),u("afterLeave")},enter:()=>{u("enter")},"after-enter":()=>{u("afterEnter")},"enter-cancelled":()=>{u("enterCancelled")},"before-leave":()=>{u("beforeLeave")},leave:()=>{u("leave")},"leave-cancelled":()=>{u("leaveCancelled")}};return(t,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(F),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:j,show:R,hide:M,toggle:H,expanded:e.unref(I),aria:e.unref(U)})))])),_:3}),e.createVNode(e.Transition,e.mergeProps({name:t.transitionName},e.toHandlers(oe),{persisted:""}),{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:w,style:e.normalizeStyle(e.unref(T)),class:e.normalizeClass(e.unref(G))},[r.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:k,style:e.normalizeStyle(e.unref(A)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(I)}))),e.createElementVNode("div",e.mergeProps(e.unref(p),{id:e.unref(v),ref_key:"listEl",ref:x,tabindex:e.unref(I)?void 0:-1,role:e.unref(J),"aria-labelledby":e.unref(z),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(te)})))],16,K),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(I)})))],6),[[e.vShow,e.unref(I)]])])),_:3},16,["name"])],64))}});const J=e.defineComponent({name:"VvDropdownItem",props:U,setup(t){const o=t,{role:a,expanded:n}=e.inject(S,{}),i=e.ref(null);!function({expanded:t}){e.provide(w,{role:e.ref(m.menuitem),expanded:t})}({expanded:n});const r=l.useElementHover(i),{focused:u}=l.useFocus(i),{focused:s}=l.useFocusWithin(i);return e.watch(r,(e=>{e&&o.focusOnHover&&(u.value=!0)})),(t,o)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({role:e.unref(a)},{ref_key:"element",ref:i,class:["vv-dropdown__item",{"focus-visible":e.unref(u)||e.unref(s)}]}),[e.renderSlot(t.$slots,"default")],16))}}),Y=["title"],G=e.defineComponent({name:"VvDropdownOption",props:F,setup(t){const o=t,{modifiers:l}=e.toRefs(o),a=q("vv-dropdown-option",l,e.computed((()=>({disabled:o.disabled,selected:o.selected,unselectable:o.unselectable&&o.selected})))),n=e.computed((()=>o.selected?o.unselectable?o.deselectHintLabel:o.selectedHintLabel:o.disabled?"":o.selectHintLabel));return(t,o)=>(e.openBlock(),e.createBlock(J,{class:e.normalizeClass(e.unref(a)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled,"focus-on-hover":t.focusOnHover},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default"),e.createElementVNode("span",{class:"vv-dropdown-option__hint",title:e.unref(n)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(n)),1)]))],8,Y)])),_:3},8,["class","tabindex","aria-selected","aria-disabled","focus-on-hover"]))}}),Q="eye-on",Z="eye-off",ee="calendar",te="time",oe="color",le="close",ae="trash",ne={prefix:"normal"};function ie(){return e.inject(g)}const re=e.defineComponent({name:"VvIcon",props:e.mergeDefaults({name:{},color:{},width:{},height:{},provider:{},prefix:{},src:{},horizontalFlip:{type:Boolean},verticalFlip:{type:Boolean},flip:{},mode:{},inline:{type:Boolean},rotate:{},onLoad:{type:Function},svg:{},modifiers:{}},ne),setup(t){const o=t,l=e.computed((()=>"string"==typeof o.rotate?Number.parseFloat(o.rotate):o.rotate)),a=e.ref(!0),i=ie(),{modifiers:r}=e.toRefs(o),u=q("vv-icon",r),s=e.computed((()=>o.provider||(null==i?void 0:i.iconsProvider))),d=e.computed((()=>{const e=o.name??"",t=`@${s.value}:${o.prefix}:${e}`;if(n.iconExists(t))return t;const l=null==i?void 0:i.iconsCollections.find((t=>{const o=`@${s.value}:${t.prefix}:${e}`;return n.iconExists(o)}));return l?`@${s.value}:${l.prefix}:${e}`:e}));function c(e){const t=function(e){let t;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");t=(new e).window}return(t?new t.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),l=(null==t?void 0:t.innerHTML.trim())||"";t&&l&&n.addIcon(`@${s.value}:${o.prefix}:${o.name}`,{body:l,height:t.viewBox.baseVal.height,width:t.viewBox.baseVal.width})}return i&&o.src&&!n.iconExists(`@${s.value}:${o.prefix}:${o.name}`)&&(a.value=!1,i.fetchIcon(o.src).then((e=>{e&&(c(e),a.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),o.svg&&c(o.svg),(t,o)=>e.unref(a)?(e.openBlock(),e.createBlock(e.unref(n.Icon),e.mergeProps({key:0,class:e.unref(u)},{inline:t.inline,width:t.width,height:t.height,horizontalFlip:t.horizontalFlip,verticalFlip:t.verticalFlip,flip:t.flip,rotate:e.unref(l),color:t.color,onLoad:t.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}}),ue={TEXT:"text",PASSWORD:"password",NUMBER:"number",EMAIL:"email",TEL:"tel",URL:"url",COLOR:"color",SEARCH:"search",DATE:"date",TIME:"time",DATETIME_LOCAL:"datetime-local",MONTH:"month",WEEK:"week"},se={...H,...j,modelValue:[String,Number],type:{type:String,default:ue.TEXT,validator:e=>Object.values(ue).includes(e)},min:[Number,Date,String],max:[Number,Date,String],step:{type:[String,Number],default:1},pattern:String,multiple:Boolean,iconShowPassword:{type:[String,Object],default:Q},iconHidePassword:{type:[String,Object],default:Z},iconClear:{type:[String,Object],default:le},iconRemoveSuggestion:{type:[String,Object],default:ae},labelStepUp:{type:String,default:"Increase value"},labelStepDown:{type:String,default:"Decrease value"},labelShowPassword:{type:String,default:"Show password"},labelHidePassword:{type:String,default:"Hide password"},labelClear:{type:String,default:"Clear"},labelRemoveSuggestion:{type:String,default:"Remove suggestion"},iMask:{type:Object,default:void 0},masked:{type:String,default:void 0},autoWidth:{type:Boolean,default:!1},hideActions:{type:Boolean,default:!1},unit:{type:String},selectOnFocus:{type:Boolean,default:!1},maxSuggestions:{type:Number,default:5}};function de(t,o){const l=e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),a=e.computed((()=>(null==o?void 0:o.value)===v.before?l.value:void 0)),n=e.computed((()=>(null==o?void 0:o.value)===v.after?l.value:void 0)),i=e.computed((()=>(null==o?void 0:o.value)===d.left?l.value:void 0)),r=e.computed((()=>(null==o?void 0:o.value)===d.right?l.value:void 0)),u=e.computed((()=>(null==o?void 0:o.value)===d.top?l.value:void 0)),s=e.computed((()=>(null==o?void 0:o.value)===d.bottom?l.value:void 0));return{hasIcon:l,hasIconLeft:i,hasIconRight:r,hasIconTop:u,hasIconBottom:s,hasIconBefore:a,hasIconAfter:n}}const ce=e.defineComponent({components:{VvIcon:re},props:{disabled:{type:Boolean,default:!1},label:{type:String,default:"Clear"},icon:{type:[String,Object],default:"close"}},emits:["clear"],setup(t,{emit:o}){const{hasIcon:l}=de(e.computed((()=>t.icon)));return{hasIcon:l,onClick:function(e){null==e||e.stopPropagation(),t.disabled||o("clear")}}},render(){const t=this.hasIcon?e.h(re,{...this.hasIcon,class:"vv-input-text__icon"}):void 0;return e.h("button",{disabled:this.disabled,class:"vv-input-text__action",ariaLabel:this.label,type:"button",onClick:this.onClick},t)}}),ve=e.defineComponent({components:{VvIcon:re},props:{disabled:{type:Boolean,default:!1},labelShow:{type:String,default:"Show password"},labelHide:{type:String,default:"Hide password"},iconShow:{type:[String,Object],default:Q},iconHide:{type:[String,Object],default:Z}},emits:["toggle-password"],setup(t,{emit:o}){const l=e.ref(!1),a=e.computed((()=>l.value?t.iconHide:t.iconShow)),{hasIcon:n}=de(a);return{active:l,activeIcon:a,hasIcon:n,onClick:function(e){null==e||e.stopPropagation(),t.disabled||(l.value=!l.value,o("toggle-password",l.value))}}},render(){const t=this.hasIcon?e.h(re,{...this.hasIcon,class:"vv-input-text__icon"}):void 0;return e.h("button",{disabled:this.disabled,class:"vv-input-text__action",ariaLabel:this.active?this.labelHide:this.labelShow,type:"button",onClick:this.onClick},t)}}),pe=e.defineComponent({components:{VvIcon:re},props:{disabled:{type:Boolean,default:!1},label:{type:String},mode:{type:String,validator:e=>["up","down"].includes(e),default:"up"}},emits:["step-up","step-down"],setup(t,{emit:o}){const l=e.computed((()=>"up"===t.mode));return{isUp:l,onClick:e=>{null==e||e.stopPropagation(),t.disabled||o(l.value?"step-up":"step-down")}}},render(){return e.h("button",{class:["vv-input-text__action vv-input-text__action-chevron",this.isUp&&"vv-input-text__action-chevron-up"],disabled:this.disabled,ariaLabel:this.label,type:"button",onClick:this.onClick})}});function fe(t,o){return{name:"VvInputTextActions",components:{VvIcon:re,VvInputPasswordAction:ve,VvInputStepAction:pe,VvInputClearAction:ce},setup:()=>({isDisabled:e.computed((()=>o.disabled||o.readonly)),labelStepUp:o.labelStepUp,labelStepDown:o.labelStepDown,labelShowPassword:o.labelShowPassword,labelHidePassword:o.labelHidePassword,labelClear:o.labelClear,iconShowPassword:o.iconShowPassword,iconHidePassword:o.iconHidePassword}),render(){let l=null;switch(t){case ue.SEARCH:{const{onClear:t}=this.$attrs;l=[e.h(ce,{disabled:this.isDisabled,label:this.labelShowPassword,onClear:t})];break}case ue.PASSWORD:{const{onTogglePassword:t}=this.$attrs;l=[e.h(ve,{disabled:this.isDisabled,onTogglePassword:t,labelShow:this.labelShowPassword,labelHide:this.labelHidePassword,iconShow:this.iconShowPassword,iconHide:this.iconHidePassword})];break}case ue.NUMBER:{const{onStepUp:t,onStepDown:a}=this.$attrs;l=[e.h(pe,{mode:"up",disabled:this.isDisabled||void 0!==o.max&&o.modelValue===o.max,label:this.labelStepUp,onStepUp:t,onStepDown:a}),e.h(pe,{mode:"down",disabled:this.isDisabled||void 0!==o.min&&o.modelValue===o.min,label:this.labelStepDown,onStepUp:t,onStepDown:a})];break}}return Array.isArray(l)?e.h("div",{class:"vv-input-text__actions-group"},l):l}}}const me=["for"],be={key:0,class:"vv-input-text__input-before"},he=["id"],ge={key:1,class:"vv-input-text__unit"},ye={key:5,class:"vv-input-text__input-after"},Se={key:6,class:"vv-input-text__limit"},we={class:"flex-1"},ke=["title","onClick"];return e.defineComponent({name:"VvInputText",props:se,emits:["update:modelValue","update:masked","accept","accept:typed","accept:masked","accept:unmasked","complete","complete:typed","complete:masked","complete:unmasked","focus","blur","keyup","keydown","keypress"],setup(o,{expose:a,emit:n}){const s=o,d=n,c=e.useSlots(),v=function(t,o,l){const a=ie(),n=e.computed((()=>{var e;if(a&&(null==(e=a.defaults.value)?void 0:e[t]))return a.defaults.value[t]}));return e.computed((()=>{if(void 0===n.value)return l;const e=n.value,t=o,a=l;return Object.keys(t).reduce(((o,l)=>{const n=a[l];if(o[l]=n,l in e){if(Array.isArray(t[l])){const a=t[l];a.length&&a[0]===n&&(o[l]=e[l])}if("function"==typeof t[l]&&(0,t[l])()===n&&(o[l]=e[l]),"object"==typeof t[l]){let a=t[l].default;"function"==typeof a&&(a=a()),"object"==typeof a?JSON.stringify(a)===JSON.stringify(n)&&(o[l]=e[l]):a===n&&(o[l]=e[l])}}return o}),{})}))}("VvInputText",se,s),{count:p,debounce:f,icon:m,iconPosition:b,iconRemoveSuggestion:h,id:g,invalid:y,label:S,loading:w,maxlength:k,minlength:x,modelValue:E,step:L,storageKey:B,storageType:$,type:C,valid:P}=e.toRefs(s),O=W(g),N=e.computed((()=>`${O.value}-hint`)),T=e.computed((()=>s.floating&&i(s.placeholder)?" ":s.placeholder)),V=function(t,o,l=0,{getter:a=e=>e,setter:n=e=>e}={}){let i;return"string"==typeof l&&(l=Number.parseInt(l)),e.computed({get:()=>a(null==t?void 0:t.value),set:e=>{i&&clearTimeout(i),i=setTimeout((()=>{o("update:modelValue",n(e))}),l)}})}(E,d,(null==f?void 0:f.value)??0),A=/^-0?[.,]?[0*]?$/,_=e.ref(!1),{el:D,mask:I,typed:R,masked:M,unmasked:H}=t.useIMask(e.computed((()=>{if(!s.iMask)return{mask:/./};if(s.iMask.mask===Number){const e={...s.iMask};return s.min&&(e.min=Number(s.min)),s.max&&(e.max=Number(s.max)),e}return s.iMask})),{emit:d,onAccept:()=>{if(_.value){if(d("update:masked",M.value),C.value===ue.NUMBER){if(/^-$|^$/.test(H.value)){if(null===V.value||void 0===V.value)return;return void(V.value=void 0)}return A.test(H.value)?void(V.value=0):"number"!=typeof R.value?void(V.value=Number(R.value)):void(V.value=R.value)}if(C.value===ue.DATE){if(D.value instanceof HTMLInputElement&&"date"===D.value.type)return void(V.value=D.value.value);let e=R.value;if(null===e||""===e){if(!V.value)return;return void(V.value="")}return e instanceof Date||(e=new Date(e)),void(V.value=`${e.getFullYear()}-${`0${e.getMonth()+1}`.slice(-2)}-${`0${e.getDate()}`.slice(-2)}`)}if(C.value===ue.DATETIME_LOCAL){if(D.value instanceof HTMLInputElement&&"datetime-local"===D.value.type)return void(V.value=D.value.value);let e=R.value;if(null===e||""===e){if(!V.value)return;return void(V.value="")}return R.value instanceof Date||(e=new Date(e)),void(V.value=`${e.getFullYear()}-${`0${e.getMonth()+1}`.slice(-2)}-${`0${e.getDate()}`.slice(-2)}T${`0${e.getHours()}`.slice(-2)}:${`0${e.getMinutes()}`.slice(-2)}`)}(V.value||H.value)&&(V.value=H.value)}}});function j(e){var t;if(null==e)return R.value="",void(H.value="");(null==(t=s.iMask)?void 0:t.mask)!==Date?C.value===ue.NUMBER&&A.test(H.value)&&0===e||(R.value=e,H.value=`${R.value}`):R.value=new Date(e)}e.onMounted((()=>{I.value&&(_.value=!0,j(s.modelValue))})),e.watch((()=>s.modelValue),(e=>{I.value&&j(e)})),e.watch((()=>s.masked),(e=>{M.value=e??""}));const z=D,U=e.ref(),F=e.ref(),K=e.ref();a({$inner:U});const{focused:J}=function(t,o){const{focused:a}=l.useFocus(t);return e.watch(a,(l=>{o(l?"focus":"blur",e.unref(t))})),{focused:a}}(z,d),Y=e.computed((()=>J.value&&!s.disabled&&!s.readonly));e.watch(Y,(e=>{var t;e&&v.value.selectOnFocus&&z.value&&z.value.select(),e?null==(t=K.value)||t.show():setTimeout((()=>{if(Te.value&&Ae.value){const e=s.maxSuggestions-1;Ae.value.size>e&&!Ae.value.has(V.value)&&(Ae.value=new Set([...Ae.value].slice(Ae.value.size-e))),Ae.value.add(V.value)}}),300)}));const Q=l.useElementVisibility(z);e.watch(Q,(e=>{e&&s.autofocus&&!s.disabled&&!s.readonly&&(J.value=!0)}));const Z=e.ref(!1),le=e.computed((()=>s.type===ue.PASSWORD));function ae(){Z.value=!Z.value}const ne=e.computed((()=>s.type===ue.TIME||s.type===ue.DATETIME_LOCAL||s.type===ue.DATE||s.type===ue.WEEK||s.type===ue.MONTH)),ce=e.computed((()=>s.type===ue.NUMBER));function ve(){if(Oe.value){if(s.iMask)return void(R.value=Number(R.value)+Number((null==L?void 0:L.value)??1));z.value.stepUp(),V.value=Number(e.unref(z).value)}}function pe(){if(Oe.value){if(s.iMask)return void(R.value=Number(R.value)-Number((null==L?void 0:L.value)??1));z.value.stepDown(),V.value=Number(e.unref(z).value)}}const xe=e.computed((()=>s.type===ue.SEARCH));function Ee(){V.value=""}const{hasIconBefore:Le,hasIconAfter:Be}=de(m,b),$e=e.computed((()=>{if(void 0!==Be.value)return Be.value;switch(s.type){case ue.COLOR:return{name:oe};case ue.DATE:case ue.DATETIME_LOCAL:case ue.WEEK:case ue.MONTH:return{name:ee};case ue.TIME:return{name:te}}})),{hasIcon:Ce}=de(h),{formatted:Pe}=function(t,o){const l=e.computed((()=>(e.unref(t)??"").length)),a=e.computed((()=>void 0!==(null==o?void 0:o.lowerLimit)&&l.value<(null==o?void 0:o.lowerLimit)?l.value-o.lowerLimit:void 0!==(null==o?void 0:o.upperLimit)&&l.value<(null==o?void 0:o.upperLimit)?o.upperLimit-l.value:0)),n=e.computed((()=>{if(!1===(null==o?void 0:o.mode))return"";if("limit"===(null==o?void 0:o.mode)&&(null==o?void 0:o.upperLimit))return`${l.value} / ${o.lowerLimit?`${o.lowerLimit}-`:""}${o.upperLimit}`;if("countdown"===(null==o?void 0:o.mode)){if(0===a.value)return;return a}return l.value}));return{length:l,gap:a,formatted:n}}(V,{mode:p.value,upperLimit:Number(null==k?void 0:k.value),lowerLimit:Number(null==x?void 0:x.value)}),Oe=e.computed((()=>!s.disabled&&!s.readonly)),Ne=e.computed((()=>Oe.value?s.tabindex:-1)),Te=e.computed((()=>!i(E))),Ve=e.computed((()=>!0===y.value||!0!==P.value&&void 0)),Ae=function(t,o=u.local,a){const n=e.ref();let i;return a&&(n.value=a),t&&e.watch(t,((t,a)=>{const r=e.unref(o)===u.session?sessionStorage:localStorage;a&&a!==t&&r.removeItem(a),i=t?l.useStorage(t,(null==i?void 0:i.value)??n.value,r):void 0}),{immediate:!0}),e.isRef(o)&&e.watch(o,((e,o)=>{if(null==t?void 0:t.value){if(e){const o=e===u.session?sessionStorage:localStorage;i=l.useStorage(t.value,(null==i?void 0:i.value)??n.value,o)}o&&o!==e&&(o===u.session?sessionStorage:localStorage).removeItem(t.value)}})),e.computed({get:()=>(null==i?void 0:i.value)??n.value,set:e=>{i?i.value=e:n.value=e}})}(B,$,new Set),_e=e.computed((()=>Ae.value?[...Ae.value].filter((e=>i(V.value)||`${e}`.toLowerCase().includes(`${V.value}`.toLowerCase())&&e!==V.value)).reverse():[])),De=e.computed((()=>(null==B?void 0:B.value)&&Ae.value&&Ae.value.size>0));const{modifiers:Ie}=e.toRefs(s),Re=q("vv-input-text",Ie,e.computed((()=>({valid:P.value,invalid:y.value,loading:w.value,disabled:s.disabled,required:s.required,readonly:s.readonly,"icon-before":!!Le.value,"icon-after":!!$e.value,floating:s.floating&&!i(s.label),dirty:Te.value,focus:Y.value,"auto-width":s.autoWidth})))),Me=e.computed((()=>{const e=le.value&&Z.value?ue.TEXT:!ne.value||Te.value||J.value?s.iMask?ue.TEXT:s.type:ue.TEXT,t={type:e,name:s.name,tabindex:Ne.value,disabled:s.disabled,readonly:s.readonly,required:s.required,autocomplete:s.autocomplete,"aria-invalid":Ve.value,"aria-describedby":ze.value?N.value:void 0,"aria-errormessage":Ue.value?N.value:void 0};if(e===ue.DATE||e===ue.MONTH||e===ue.WEEK||e===ue.TIME||e===ue.DATETIME_LOCAL||e===ue.NUMBER){let o=s.max;e!==ue.DATE||o||(o="9999-12-31"),t.step=s.step,t.max=void 0!==o?String(o):void 0,t.min=void 0!==s.min?String(s.min):void 0}return e!==ue.TEXT&&e!==ue.SEARCH&&e!==ue.URL&&e!==ue.TEL&&e!==ue.EMAIL&&e!==ue.PASSWORD&&e!==ue.NUMBER||(t.placeholder=T.value),e!==ue.TEXT&&e!==ue.SEARCH&&e!==ue.URL&&e!==ue.TEL&&e!==ue.EMAIL&&e!==ue.PASSWORD||(t.minlength=s.minlength,t.maxlength=s.maxlength,t.pattern=s.pattern),e===ue.EMAIL&&(t.multiple=s.multiple),t})),He=e.computed((()=>({valid:s.valid,invalid:s.invalid,modelValue:s.modelValue,togglePassword:ae,stepUp:ve,stepDown:pe,clear:Ee}))),{HintSlot:je,hasHintLabelOrSlot:ze,hasInvalidLabelOrSlot:Ue,hintSlotScope:Fe}=function(t,o){const l=e.computed((()=>e.isRef(t)?t.value:t)),a=e.computed((()=>r(l.value.invalidLabel))),n=e.computed((()=>r(l.value.validLabel))),i=e.computed((()=>l.value.loadingLabel)),u=e.computed((()=>l.value.hintLabel)),s=e.computed((()=>Boolean(l.value.loading&&(o.loading||i.value)))),d=e.computed((()=>!s.value&&Boolean(l.value.invalid&&(o.invalid||a.value)))),c=e.computed((()=>!s.value&&!d.value&&Boolean(l.value.valid&&(o.valid||n.value)))),v=e.computed((()=>!s.value&&!d.value&&!c.value&&Boolean(o.hint||u.value))),p=e.computed((()=>d.value||c.value||s.value||v.value)),f=e.computed((()=>({modelValue:l.value.modelValue,valid:l.value.valid,invalid:l.value.invalid,loading:l.value.loading}))),m=e.defineComponent({name:"HintSlot",props:{tag:{type:String,default:"small"}},setup:()=>({isVisible:p,invalidLabel:a,validLabel:n,loadingLabel:i,hintLabel:u,hasInvalidLabelOrSlot:d,hasValidLabelOrSlot:c,hasLoadingLabelOrSlot:s,hasHintLabelOrSlot:v}),render(){var t,o,l,a,n,i,r,u;if(this.isVisible){let s;return this.hasInvalidLabelOrSlot&&(s="alert"),this.hasValidLabelOrSlot&&(s="status"),this.hasLoadingLabelOrSlot?e.h(this.tag,{role:s},(null==(o=(t=this.$slots).loading)?void 0:o.call(t))??this.loadingLabel):this.hasInvalidLabelOrSlot?e.h(this.tag,{role:s},(null==(a=(l=this.$slots).invalid)?void 0:a.call(l))??this.$slots.invalid??this.invalidLabel):this.hasValidLabelOrSlot?e.h(this.tag,{role:s},(null==(i=(n=this.$slots).valid)?void 0:i.call(n))??this.validLabel):e.h(this.tag,{role:s},(null==(u=(r=this.$slots).hint)?void 0:u.call(r))??this.$slots.hint??this.hintLabel)}return null}});return{hasInvalidLabelOrSlot:d,hasHintLabelOrSlot:v,hasValidLabelOrSlot:c,hasLoadingLabelOrSlot:s,hintSlotScope:f,HintSlot:m}}(v,c),We=fe(ue.PASSWORD,s),qe=fe(ue.NUMBER,s),Ke=fe(ue.SEARCH,s);function Xe(){Oe.value&&(J.value=!0)}const Je=e.computed((()=>{if(s.autoWidth)return{width:void 0!==V.value?`${String(V.value).length+1}ch`:void 0}}));function Ye(e){switch(e.code){case"ArrowUp":ce.value&&(ve(),e.preventDefault());break;case"ArrowDown":ce.value&&(pe(),e.preventDefault())}d("keydown",e)}return(t,o)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref(Re))},[e.unref(S)?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(O),class:"vv-input-text__label"},e.toDisplayString(e.unref(S)),9,me)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:F,class:"vv-input-text__wrapper"},[t.$slots.before?(e.openBlock(),e.createElementBlock("div",be,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(He))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"innerEl",ref:U,class:"vv-input-text__inner",onClick:e.withModifiers(Xe,["stop"])},[e.unref(Le)?(e.openBlock(),e.createBlock(re,e.mergeProps({key:0},e.unref(Le),{class:"vv-input-text__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.createElementVNode("input",e.mergeProps({id:e.unref(O),ref_key:"inputEl",ref:z},e.unref(Me),{style:e.unref(Je),onKeyup:o[0]||(o[0]=e=>d("keyup",e)),onKeydown:Ye,onKeypress:o[1]||(o[1]=e=>d("keypress",e))}),null,16,he),(t.unit||t.$slots.unit)&&e.unref(Te)?(e.openBlock(),e.createElementBlock("div",ge,[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps(e.unref(He))),(()=>[e.createTextVNode(e.toDisplayString(t.unit),1)]))])):e.createCommentVNode("v-if",!0)],512),e.unref($e)?(e.openBlock(),e.createBlock(re,e.mergeProps({key:1},e.unref($e),{class:"vv-input-text__icon vv-input-text__icon-after"}),null,16)):e.unref(le)&&!t.hideActions&&e.unref(Oe)?(e.openBlock(),e.createBlock(e.unref(We),{key:2,onTogglePassword:ae})):e.unref(ce)&&!t.hideActions&&e.unref(Oe)?(e.openBlock(),e.createBlock(e.unref(qe),{key:3,onStepUp:ve,onStepDown:pe})):e.unref(xe)&&!t.hideActions&&e.unref(Oe)?(e.openBlock(),e.createBlock(e.unref(Ke),{key:4,onClear:Ee})):e.createCommentVNode("v-if",!0),t.$slots.after?(e.openBlock(),e.createElementBlock("div",ye,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(He))))])):e.createCommentVNode("v-if",!0),e.unref(p)?(e.openBlock(),e.createElementBlock("span",Se,[e.renderSlot(t.$slots,"count",e.normalizeProps(e.guardReactiveProps(e.unref(He))),(()=>[e.createTextVNode(e.toDisplayString(e.unref(Pe)),1)]))])):e.createCommentVNode("v-if",!0)],512),e.createVNode(e.unref(je),{id:e.unref(N),class:"vv-input-text__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(Fe))))])),key:"3"}:void 0]),1032,["id"]),e.unref(De)?(e.openBlock(),e.createBlock(X,{key:1,ref_key:"dropdownEl",ref:K,reference:e.unref(F),"autofocus-first":!1,"trigger-width":!0},{items:e.withCtx((()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(_e),(o=>(e.openBlock(),e.createBlock(G,{key:o,onClick:e.withModifiers((e=>{return t=o,V.value=t,void(null==(l=K.value)||l.hide());var t,l}),["stop"])},{default:e.withCtx((()=>[e.createElementVNode("div",we,[e.renderSlot(t.$slots,"suggestion",e.mergeProps({ref_for:!0},{value:o}),(()=>[e.createTextVNode(e.toDisplayString(o),1)]))]),e.unref(Ae)&&e.unref(Ce)?(e.openBlock(),e.createElementBlock("button",{key:0,type:"button",tabindex:"-1",class:"cursor-pointer",title:t.labelRemoveSuggestion,onClick:e.withModifiers((e=>{return t=o,void(null==(l=Ae.value)||l.delete(t));var t,l}),["stop"])},[e.createVNode(re,e.mergeProps({ref_for:!0},e.unref(Ce)),null,16)],8,ke)):e.createCommentVNode("v-if",!0)])),_:2},1032,["onClick"])))),128))])),_:3},8,["reference"])):e.createCommentVNode("v-if",!0)],2))}})}));
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("vue-imask"),require("@floating-ui/vue"),require("@vueuse/core"),require("mitt"),require("@iconify/vue")):"function"==typeof define&&define.amd?define(["vue","vue-imask","@floating-ui/vue","@vueuse/core","mitt","@iconify/vue"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvInputText=t(e.vue,e.vueImask,e.vue$1,e.core,e.mitt,e.vue$2)}(this,(function(e,t,o,l,a,n){"use strict";function i(e){if("string"!=typeof e)return!1;if(!/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(?:\.\d{1,3})?(?:Z|[+-]\d{2}:?\d{2})?$/.test(e))return!1;const t=new Date(e);return!Number.isNaN(t.getTime())&&t.toISOString()===e}function r(e,t="date",o){if("string"==typeof e&&!i(e))return"";const l=new Date(e);if(Number.isNaN(l.getTime()))return"";const a=e=>e.toString().padStart(2,"0");let n=`${l.getFullYear()}-${a(l.getMonth()+1)}`;if("month"===t)return n;if(n+=`-${a(l.getDate())}`,"date"===t)return n;const r=o?`${a(l.getHours())}:${a(l.getMinutes())}:${a(l.getSeconds())}`:`${a(l.getHours())}:${a(l.getMinutes())}`;return"time"===t?r:`${n}T${r}`}function u(t){return null==(o=e.unref(t))||""===o||Array.isArray(o)&&0===o.length||!(o instanceof Date)&&"object"==typeof o&&0===Object.keys(o).length;var o}function s(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}var d=(e=>(e.local="local",e.session="session",e))(d||{}),v=(e=>(e.absolute="absolute",e.fixed="fixed",e))(v||{}),c=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(c||{}),p=(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))(p||{}),f=(e=>(e.before="before",e.after="after",e))(f||{}),m=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(m||{}),h=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(h||{}),b=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(b||{}),g=(e=>(e.listbox="listbox",e.menu="menu",e))(g||{}),y=(e=>(e.option="option",e.presentation="presentation",e))(y||{});const S=Symbol.for("volver"),w=Symbol.for("dropdownTrigger"),k=Symbol.for("dropdownItem"),E=Symbol.for("dropdownAction"),x={valid:{type:Boolean,default:!1},validLabel:{type:[String,Array],default:void 0}},$={invalid:{type:Boolean,default:!1},invalidLabel:{type:[String,Array],default:void 0}},L={loading:{type:Boolean,default:!1},loadingLabel:{type:String,default:"Loading..."}},D={disabled:{type:Boolean,default:!1}},T={required:{type:Boolean,default:!1}},B={selected:{type:Boolean,default:!1}},C=(Boolean,Boolean,Boolean,{label:{type:[String,Number],default:void 0}}),O={readonly:{type:Boolean,default:!1}},N={modifiers:{type:[String,Array],default:void 0}},P={hintLabel:{type:String,default:""}},A={count:{type:[Boolean,String],default:!1,validator:e=>[!0,!1,"limit","countdown"].includes(e)}},I={debounce:{type:[Number,String],default:void 0}},M={icon:{type:[String,Object],default:void 0},iconPosition:{type:String,default:f.before,validation:e=>Object.values(f).includes(e)}},_={tabindex:{type:[String,Number],default:0}},V={floating:{type:Boolean,default:!1}},H={unselectable:{type:Boolean,default:!0}},R={id:[String,Number]},j={placement:{type:String,default:c.bottom,validator:e=>Object.values(c).includes(e)||Object.values(p).includes(e)},strategy:{type:String,default:void 0,validator:e=>Object.values(v).includes(e)},transitionName:{type:String,default:void 0},offset:{type:[Number,String,Object],default:0},shift:{type:[Boolean,Object],default:!1},flip:{type:[Boolean,Object],default:!0},size:{type:[Boolean,Object],default:()=>({padding:10})},autoPlacement:{type:[Boolean,Object],default:!1},arrow:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean,default:!1}},z={...{...R,name:{type:String,required:!0}},...{autofocus:{type:Boolean,default:!1}},...{autocomplete:{type:String,default:"off"}},..._,...D,...O,...x,...$,...P,...L,...N,...A,...I,...M,...V,...C,minlength:{type:[String,Number],default:void 0},maxlength:{type:[String,Number],default:void 0},placeholder:{type:String,default:void 0},...T};m.button,h.button;const F={storageType:{type:String,default:d.local,validator:e=>Object.values(d).includes(e)},storageKey:String},U={...R,...j,...N,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:g.menu,validator:e=>Object.values(g).includes(e)}},W={focusOnHover:{type:Boolean,default:!1}},Y={...D,...B,...H,...N,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String},focusOnHover:{type:Boolean,default:!1}};function q(t){return e.computed((()=>String((null==t?void 0:t.value)||e.useId())))}function K(t,o,l){return e.computed((()=>{const a={[t]:!0},n="string"==typeof(null==o?void 0:o.value)?o.value.split(" "):null==o?void 0:o.value;return n&&Array.isArray(n)&&n.forEach((e=>{e&&(a[`${t}--${e}`]=!0)})),l&&Object.keys(l.value).forEach((o=>{a[`${t}--${o}`]=e.unref(l.value[o])})),a}))}const X=["id","tabindex","role","aria-labelledby"],J=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:U,emits:["update:modelValue","beforeEnter","afterLeave","beforeExpand","beforeCollapse","afterExpand","afterCollapse","before-enter","after-leave","enter","afterEnter","enterCancelled","beforeLeave","leave","leaveCancelled"],setup(t,{expose:n,emit:i}){const r=t,u=i,{id:s}=e.toRefs(r),d=q(s),p=e.useAttrs(),f=e.ref("auto"),m=e.ref("auto"),h=e.ref(),b=e.ref(),S=e.ref(),E=e.ref(),x=e.computed({get:()=>r.reference??h.value,set:e=>{h.value=e}}),$=e.ref(!1);e.onMounted((()=>{l.useMutationObserver(b.value,(()=>{var e;$.value="true"===(null==(e=window.getComputedStyle(b.value).getPropertyValue("--dropdown-custom-position"))?void 0:e.trim())}),{attributeFilter:["style"],window:window})}));const L=e.computed((()=>{const e=[];if(r.autoPlacement?"boolean"==typeof r.autoPlacement?e.push(o.autoPlacement()):e.push(o.autoPlacement(r.autoPlacement)):r.flip&&("boolean"==typeof r.flip?e.push(o.flip({fallbackStrategy:"initialPlacement"})):e.push(o.flip(r.flip))),r.shift&&("boolean"==typeof r.shift?e.push(o.shift()):e.push(o.shift(r.shift))),r.size){const t=({availableWidth:e,availableHeight:t})=>{f.value=`${e}px`,m.value=`${t}px`};"boolean"==typeof r.size?e.push(o.size({apply:t})):e.push(o.size({...r.size,apply:t}))}return r.offset&&(e.push(o.offset(Number(r.offset))),["string","number"].includes(typeof r.offset)?e.push(o.offset(Number(r.offset))):e.push(o.offset(r.offset))),r.arrow&&e.push(o.arrow({element:S})),e})),{x:D,y:T,middlewareData:B,placement:C,strategy:O}=o.useFloating(x,b,{whileElementsMounted:(...e)=>o.autoUpdate(...e,{animationFrame:r.strategy===v.fixed}),placement:e.computed((()=>r.placement)),strategy:e.computed((()=>r.strategy)),middleware:L}),N=e.computed((()=>{var e;if($.value)return;const t=r.triggerWidth&&x.value?`${null==(e=x.value)?void 0:e.offsetWidth}px`:void 0;return{position:O.value,top:`${T.value??0}px`,left:`${D.value??0}px`,maxWidth:t?void 0:f.value,maxHeight:m.value,width:t}})),P=e.computed((()=>C.value.split("-")[0])),A=e.computed((()=>{var e,t,o,l,a;if($.value)return;const n={[c.top]:c.bottom,[c.right]:c.left,[c.bottom]:c.top,[c.left]:c.right}[P.value];return{left:void 0!==(null==(e=B.value.arrow)?void 0:e.x)?`${null==(t=B.value.arrow)?void 0:t.x}px`:void 0,top:void 0!==(null==(o=B.value.arrow)?void 0:o.y)?`${null==(l=B.value.arrow)?void 0:l.y}px`:void 0,[n]:-((null==(a=S.value)?void 0:a.offsetWidth)??0)/2+"px"}})),I=l.useVModel(r,"modelValue",u),M=e.ref(!1),_=e.computed({get:()=>I.value??M.value,set:e=>{void 0!==I.value?I.value=e:M.value=e}});function V(){_.value=!0}function H(){_.value=!1}function R(){_.value=!_.value}function j(e){x.value=e}n({toggle:R,show:V,hide:H,init:j,customPosition:$}),e.watch(_,(t=>{t&&r.autofocusFirst&&e.nextTick((()=>{const e=Q(b.value);e.length>0&&e[0].focus({preventScroll:!0})}))})),l.onClickOutside(b,(()=>{!r.keepOpen&&_.value&&(_.value=!1)}),{ignore:[x]});const z=e.computed((()=>{var e,t;return(null==(t=null==(e=x.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),F=e.computed((()=>({"aria-controls":d.value,"aria-haspopup":!0,"aria-expanded":_.value}))),{component:U,bus:W}=function({reference:t,id:o,expanded:l,aria:n}){const i=a(),r=e.defineComponent({name:"VvDropdownTriggerProvider",setup(){e.provide(w,{reference:t,id:o,expanded:l,aria:n,bus:i})},render(){var t,o;return e.h(e.Fragment,{},null==(o=(t=this.$slots).default)?void 0:o.call(t))}});return{bus:i,component:r}}({reference:x,id:d,expanded:_,aria:F});W.on("click",R);const{role:Y,modifiers:J}=e.toRefs(r),Z=K("vv-dropdown",J,e.computed((()=>({arrow:r.arrow})))),{focused:G}=l.useFocusWithin(b);function Q(e){return e?[...e.querySelectorAll('a[href], button, input, textarea, select, details, [tabindex]:not([tabindex="-1"])')].filter((e=>!e.hasAttribute("disabled")&&!e.getAttribute("aria-hidden"))):[]}const ee=l.useElementHover(b),{itemRole:te}=function({role:t,...o}){const l=e.computed((()=>t.value===g.listbox?y.option:y.presentation));return e.provide(k,{role:l,...o}),{itemRole:l}}({role:Y,expanded:_,focused:G,hovered:ee});l.onKeyStroke("Escape",(e=>{_.value&&(e.preventDefault(),H())})),l.onKeyStroke("ArrowDown",(t=>{_.value&&G.value&&(t.preventDefault(),e.nextTick((()=>{if(G.value){const e=Q(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})}})))})),l.onKeyStroke("ArrowUp",(t=>{_.value&&G.value&&(t.preventDefault(),e.nextTick((()=>{if(G.value){const e=Q(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})}})))})),l.onKeyStroke([" ","Enter"],(e=>{const t=e.target;_.value&&G.value&&t&&(null==t||t.click())}));const oe={"before-enter":()=>{u(_.value?"beforeExpand":"beforeCollapse"),u("beforeEnter")},"after-leave":()=>{u(_.value?"afterExpand":"afterCollapse"),u("afterLeave")},enter:()=>{u("enter")},"after-enter":()=>{u("afterEnter")},"enter-cancelled":()=>{u("enterCancelled")},"before-leave":()=>{u("beforeLeave")},leave:()=>{u("leave")},"leave-cancelled":()=>{u("leaveCancelled")}};return(t,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(U),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:j,show:V,hide:H,toggle:R,expanded:e.unref(_),aria:e.unref(F)})))])),_:3}),e.createVNode(e.Transition,e.mergeProps({name:t.transitionName},e.toHandlers(oe),{persisted:""}),{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:b,style:e.normalizeStyle(e.unref(N)),class:e.normalizeClass(e.unref(Z))},[r.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:S,style:e.normalizeStyle(e.unref(A)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(_)}))),e.createElementVNode("div",e.mergeProps(e.unref(p),{id:e.unref(d),ref_key:"listEl",ref:E,tabindex:e.unref(_)?void 0:-1,role:e.unref(Y),"aria-labelledby":e.unref(z),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(te)})))],16,X),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(_)})))],6),[[e.vShow,e.unref(_)]])])),_:3},16,["name"])],64))}});const Z=e.defineComponent({name:"VvDropdownItem",props:W,setup(t){const o=t,{role:a,expanded:n}=e.inject(k,{}),i=e.ref(null);!function({expanded:t}){e.provide(E,{role:e.ref(b.menuitem),expanded:t})}({expanded:n});const r=l.useElementHover(i),{focused:u}=l.useFocus(i),{focused:s}=l.useFocusWithin(i);return e.watch(r,(e=>{e&&o.focusOnHover&&(u.value=!0)})),(t,o)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({role:e.unref(a)},{ref_key:"element",ref:i,class:["vv-dropdown__item",{"focus-visible":e.unref(u)||e.unref(s)}]}),[e.renderSlot(t.$slots,"default")],16))}}),G=["title"],Q=e.defineComponent({name:"VvDropdownOption",props:Y,setup(t){const o=t,{modifiers:l}=e.toRefs(o),a=K("vv-dropdown-option",l,e.computed((()=>({disabled:o.disabled,selected:o.selected,unselectable:o.unselectable&&o.selected})))),n=e.computed((()=>o.selected?o.unselectable?o.deselectHintLabel:o.selectedHintLabel:o.disabled?"":o.selectHintLabel));return(t,o)=>(e.openBlock(),e.createBlock(Z,{class:e.normalizeClass(e.unref(a)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled,"focus-on-hover":t.focusOnHover},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default"),e.createElementVNode("span",{class:"vv-dropdown-option__hint",title:e.unref(n)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(n)),1)]))],8,G)])),_:3},8,["class","tabindex","aria-selected","aria-disabled","focus-on-hover"]))}}),ee="eye-on",te="eye-off",oe="calendar",le="time",ae="color",ne="close",ie="trash",re={prefix:"normal"};function ue(){return e.inject(S)}const se=e.defineComponent({name:"VvIcon",props:e.mergeDefaults({name:{},color:{},width:{},height:{},provider:{},prefix:{},src:{},horizontalFlip:{type:Boolean},verticalFlip:{type:Boolean},flip:{},mode:{},inline:{type:Boolean},rotate:{},onLoad:{type:Function},svg:{},modifiers:{}},re),setup(t){const o=t,l=e.computed((()=>"string"==typeof o.rotate?Number.parseFloat(o.rotate):o.rotate)),a=e.ref(!0),i=ue(),{modifiers:r}=e.toRefs(o),u=K("vv-icon",r),s=e.computed((()=>o.provider||(null==i?void 0:i.iconsProvider))),d=e.computed((()=>{const e=o.name??"",t=`@${s.value}:${o.prefix}:${e}`;if(n.iconExists(t))return t;const l=null==i?void 0:i.iconsCollections.find((t=>{const o=`@${s.value}:${t.prefix}:${e}`;return n.iconExists(o)}));return l?`@${s.value}:${l.prefix}:${e}`:e}));function v(e){const t=function(e){let t;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");t=(new e).window}return(t?new t.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),l=(null==t?void 0:t.innerHTML.trim())||"";t&&l&&n.addIcon(`@${s.value}:${o.prefix}:${o.name}`,{body:l,height:t.viewBox.baseVal.height,width:t.viewBox.baseVal.width})}return i&&o.src&&!n.iconExists(`@${s.value}:${o.prefix}:${o.name}`)&&(a.value=!1,i.fetchIcon(o.src).then((e=>{e&&(v(e),a.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),o.svg&&v(o.svg),(t,o)=>e.unref(a)?(e.openBlock(),e.createBlock(e.unref(n.Icon),e.mergeProps({key:0,class:e.unref(u)},{inline:t.inline,width:t.width,height:t.height,horizontalFlip:t.horizontalFlip,verticalFlip:t.verticalFlip,flip:t.flip,rotate:e.unref(l),color:t.color,onLoad:t.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}}),de={TEXT:"text",PASSWORD:"password",NUMBER:"number",EMAIL:"email",TEL:"tel",URL:"url",COLOR:"color",SEARCH:"search",DATE:"date",TIME:"time",DATETIME_LOCAL:"datetime-local",MONTH:"month",WEEK:"week"},ve={...z,...F,modelValue:[String,Number,Date],type:{type:String,default:de.TEXT,validator:e=>Object.values(de).includes(e)},min:[Number,Date,String],max:[Number,Date,String],step:{type:[String,Number],default:1},pattern:String,multiple:Boolean,iconShowPassword:{type:[String,Object],default:ee},iconHidePassword:{type:[String,Object],default:te},iconClear:{type:[String,Object],default:ne},iconRemoveSuggestion:{type:[String,Object],default:ie},labelStepUp:{type:String,default:"Increase value"},labelStepDown:{type:String,default:"Decrease value"},labelShowPassword:{type:String,default:"Show password"},labelHidePassword:{type:String,default:"Hide password"},labelClear:{type:String,default:"Clear"},labelRemoveSuggestion:{type:String,default:"Remove suggestion"},iMask:{type:Object,default:void 0},masked:{type:String,default:void 0},autoWidth:{type:Boolean,default:!1},hideActions:{type:Boolean,default:!1},unit:{type:String},selectOnFocus:{type:Boolean,default:!1},maxSuggestions:{type:Number,default:5}};function ce(t,o){const l=e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),a=e.computed((()=>(null==o?void 0:o.value)===f.before?l.value:void 0)),n=e.computed((()=>(null==o?void 0:o.value)===f.after?l.value:void 0)),i=e.computed((()=>(null==o?void 0:o.value)===c.left?l.value:void 0)),r=e.computed((()=>(null==o?void 0:o.value)===c.right?l.value:void 0)),u=e.computed((()=>(null==o?void 0:o.value)===c.top?l.value:void 0)),s=e.computed((()=>(null==o?void 0:o.value)===c.bottom?l.value:void 0));return{hasIcon:l,hasIconLeft:i,hasIconRight:r,hasIconTop:u,hasIconBottom:s,hasIconBefore:a,hasIconAfter:n}}const pe=e.defineComponent({components:{VvIcon:se},props:{disabled:{type:Boolean,default:!1},label:{type:String,default:"Clear"},icon:{type:[String,Object],default:"close"}},emits:["clear"],setup(t,{emit:o}){const{hasIcon:l}=ce(e.computed((()=>t.icon)));return{hasIcon:l,onClick:function(e){null==e||e.stopPropagation(),t.disabled||o("clear")}}},render(){const t=this.hasIcon?e.h(se,{...this.hasIcon,class:"vv-input-text__icon"}):void 0;return e.h("button",{disabled:this.disabled,class:"vv-input-text__action",ariaLabel:this.label,type:"button",onClick:this.onClick},t)}}),fe=e.defineComponent({components:{VvIcon:se},props:{disabled:{type:Boolean,default:!1},labelShow:{type:String,default:"Show password"},labelHide:{type:String,default:"Hide password"},iconShow:{type:[String,Object],default:ee},iconHide:{type:[String,Object],default:te}},emits:["toggle-password"],setup(t,{emit:o}){const l=e.ref(!1),a=e.computed((()=>l.value?t.iconHide:t.iconShow)),{hasIcon:n}=ce(a);return{active:l,activeIcon:a,hasIcon:n,onClick:function(e){null==e||e.stopPropagation(),t.disabled||(l.value=!l.value,o("toggle-password",l.value))}}},render(){const t=this.hasIcon?e.h(se,{...this.hasIcon,class:"vv-input-text__icon"}):void 0;return e.h("button",{disabled:this.disabled,class:"vv-input-text__action",ariaLabel:this.active?this.labelHide:this.labelShow,type:"button",onClick:this.onClick},t)}}),me=e.defineComponent({components:{VvIcon:se},props:{disabled:{type:Boolean,default:!1},label:{type:String},mode:{type:String,validator:e=>["up","down"].includes(e),default:"up"}},emits:["step-up","step-down"],setup(t,{emit:o}){const l=e.computed((()=>"up"===t.mode));return{isUp:l,onClick:e=>{null==e||e.stopPropagation(),t.disabled||o(l.value?"step-up":"step-down")}}},render(){return e.h("button",{class:["vv-input-text__action vv-input-text__action-chevron",this.isUp&&"vv-input-text__action-chevron-up"],disabled:this.disabled,ariaLabel:this.label,type:"button",onClick:this.onClick})}});function he(t,o){return{name:"VvInputTextActions",components:{VvIcon:se,VvInputPasswordAction:fe,VvInputStepAction:me,VvInputClearAction:pe},setup:()=>({isDisabled:e.computed((()=>o.disabled||o.readonly)),labelStepUp:o.labelStepUp,labelStepDown:o.labelStepDown,labelShowPassword:o.labelShowPassword,labelHidePassword:o.labelHidePassword,labelClear:o.labelClear,iconShowPassword:o.iconShowPassword,iconHidePassword:o.iconHidePassword}),render(){let l=null;switch(t){case de.SEARCH:{const{onClear:t}=this.$attrs;l=[e.h(pe,{disabled:this.isDisabled,label:this.labelShowPassword,onClear:t})];break}case de.PASSWORD:{const{onTogglePassword:t}=this.$attrs;l=[e.h(fe,{disabled:this.isDisabled,onTogglePassword:t,labelShow:this.labelShowPassword,labelHide:this.labelHidePassword,iconShow:this.iconShowPassword,iconHide:this.iconHidePassword})];break}case de.NUMBER:{const{onStepUp:t,onStepDown:a}=this.$attrs;l=[e.h(me,{mode:"up",disabled:this.isDisabled||void 0!==o.max&&o.modelValue===o.max,label:this.labelStepUp,onStepUp:t,onStepDown:a}),e.h(me,{mode:"down",disabled:this.isDisabled||void 0!==o.min&&o.modelValue===o.min,label:this.labelStepDown,onStepUp:t,onStepDown:a})];break}}return Array.isArray(l)?e.h("div",{class:"vv-input-text__actions-group"},l):l}}}const be=["for"],ge={key:0,class:"vv-input-text__input-before"},ye=["id"],Se={key:1,class:"vv-input-text__unit"},we={key:5,class:"vv-input-text__input-after"},ke={key:6,class:"vv-input-text__limit"},Ee={class:"flex-1"},xe=["title","onClick"];return e.defineComponent({name:"VvInputText",props:ve,emits:["update:modelValue","update:masked","accept","accept:typed","accept:masked","accept:unmasked","complete","complete:typed","complete:masked","complete:unmasked","focus","blur","keyup","keydown","keypress"],setup(o,{expose:a,emit:n}){const v=o,c=n,p=e.useSlots(),f=function(t,o,l){const a=ue(),n=e.computed((()=>{var e;if(a&&(null==(e=a.defaults.value)?void 0:e[t]))return a.defaults.value[t]}));return e.computed((()=>{if(void 0===n.value)return l;const e=n.value,t=o,a=l;return Object.keys(t).reduce(((o,l)=>{const n=a[l];if(o[l]=n,l in e){if(Array.isArray(t[l])){const a=t[l];a.length&&a[0]===n&&(o[l]=e[l])}if("function"==typeof t[l]&&(0,t[l])()===n&&(o[l]=e[l]),"object"==typeof t[l]){let a=t[l].default;"function"==typeof a&&(a=a()),"object"==typeof a?JSON.stringify(a)===JSON.stringify(n)&&(o[l]=e[l]):a===n&&(o[l]=e[l])}}return o}),{})}))}("VvInputText",ve,v),{count:m,debounce:h,icon:b,iconPosition:g,iconRemoveSuggestion:y,id:S,invalid:w,label:k,loading:E,maxlength:x,minlength:$,modelValue:L,step:D,storageKey:T,storageType:B,type:C,valid:O}=e.toRefs(v),N=q(S),P=e.computed((()=>`${N.value}-hint`)),A=e.computed((()=>v.floating&&u(v.placeholder)?" ":v.placeholder)),I=function(t,o,l=0,{getter:a=e=>e,setter:n=e=>e}={}){let i;return"string"==typeof l&&(l=Number.parseInt(l)),e.computed({get:()=>a(null==t?void 0:t.value),set:e=>{i&&clearTimeout(i),i=setTimeout((()=>{o("update:modelValue",n(e))}),l)}})}(L,c,(null==h?void 0:h.value)??0),M=e.computed((()=>{const e="number"==typeof D.value?D.value:Number.parseInt(D.value);return!Number.isNaN(e)&&e%60!=0})),_=/^-0?[.,]?[0*]?$/,V=e.ref(!1),H=e.ref(),R=e.ref(),{el:j,mask:z,typed:F,masked:U,unmasked:W}=t.useIMask(e.computed((()=>{if(!v.iMask)return{mask:/./};if(v.iMask.mask===Number){const e={...v.iMask};return v.min&&(e.min=Number(v.min)),v.max&&(e.max=Number(v.max)),e}return v.iMask})),{emit:c,onAccept:()=>{var e;if(V.value){if(c("update:masked",U.value),C.value===de.NUMBER){if(/^-$|^$/.test(W.value)){if(null===I.value||void 0===I.value)return;return void(I.value=void 0)}return _.test(W.value)?void(I.value=0):"number"!=typeof F.value?void(I.value=Number(F.value)):void(I.value=F.value)}if(C.value!==de.DATETIME_LOCAL&&C.value!==de.DATE&&C.value!==de.TIME&&C.value!==de.MONTH)(I.value||W.value)&&(I.value=W.value);else{if(!F.value){if(!I.value)return;return H.value?void(I.value=void 0):void(I.value="")}if(!(F.value instanceof Date||H.value||R.value))return void(I.value=F.value);let t=F.value;if(t instanceof Date||(t=function(e,t="date"){if(!(null==e?void 0:e.trim()))return null;const o=new Date,l=o.getFullYear(),a=o.getMonth(),n=o.getDate();if("date"===t){if(!/^\d{4}-\d{2}-\d{2}$/.test(e))throw new Error("Invalid date format. Expected: YYYY-MM-DD");return new Date(`${e}T00:00:00`)}if("month"===t){if(!/^\d{4}-\d{2}$/.test(e))throw new Error("Invalid month format. Expected: YYYY-MM");return new Date(`${e}-01T00:00:00`)}if("time"===t){if(!/^(?:[01]\d|2[0-3]):[0-5]\d(?::[0-5]\d)?$/.test(e))throw new Error("Invalid time format. Expected: HH:mm or HH:mm:ss");return 8===e.length?new Date(`${l}-${a+1}-${n}T${e}`):new Date(`${l}-${a+1}-${n}T${e}:00`)}if(!/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}(?::\d{2})?$/.test(e))throw new Error("Invalid datetime format. Expected: YYYY-MM-DDThh:mm or YYYY-MM-DDThh:mm:ss");return 16===e.length?new Date(`${e}:00`):new Date(`${e}`)}(F.value,C.value)),H.value||R.value){const o=new Date(H.value||R.value);if(C.value!==de.DATETIME_LOCAL&&C.value!==de.DATE&&C.value!==de.MONTH||(o.setFullYear(t.getFullYear()),o.setMonth(t.getMonth())),C.value!==de.DATETIME_LOCAL&&C.value!==de.DATE||o.setDate(t.getDate()),C.value!==de.DATETIME_LOCAL&&C.value!==de.TIME||(o.setHours(t.getHours()),o.setMinutes(t.getMinutes()),o.setSeconds(t.getSeconds())),H.value instanceof Date){if((null==(e=I.value)?void 0:e.getTime())===o.getTime())return;return void(I.value=o)}return void(I.value=o.toISOString())}I.value=r(t,C.value,M.value)}}}});function Y(e){var t;if(null==e)return F.value="",void(W.value="");if((null==(t=v.iMask)?void 0:t.mask)!==Date){if(C.value!==de.NUMBER||!_.test(W.value)||0!==e){if(C.value===de.DATE||C.value===de.MONTH||C.value===de.DATETIME_LOCAL||C.value===de.TIME){if(e instanceof Date||i(e)){e instanceof Date?(H.value=e,R.value=void 0):(R.value=e,H.value=void 0);const t=new Date(e);return F.value=r(t,C.value,M.value),void(W.value=F.value)}H.value=void 0,R.value=void 0}F.value=e,W.value=`${F.value}`}}else F.value=e instanceof Date?e:new Date(e)}e.onMounted((()=>{z.value&&(V.value=!0,Y(v.modelValue))})),e.watch((()=>v.modelValue),(e=>{z.value&&Y(e)})),e.watch((()=>v.masked),(e=>{U.value=e??""}));const X=j,Z=e.ref(),G=e.ref(),ee=e.ref();a({$inner:Z});const{focused:te}=function(t,o){const{focused:a}=l.useFocus(t);return e.watch(a,(l=>{o(l?"focus":"blur",e.unref(t))})),{focused:a}}(X,c),ne=e.computed((()=>te.value&&!v.disabled&&!v.readonly));e.watch(ne,(e=>{var t,o;if(e&&f.value.selectOnFocus&&X.value&&X.value.select(),e&&(null==(t=He.value)?void 0:t.size))null==(o=ee.value)||o.show();else if(_e.value&&He.value){const e=v.maxSuggestions;He.value.size>=e&&!He.value.has(I.value)&&(He.value=new Set([...He.value].slice(He.value.size-e+1))),He.value.add(I.value)}}));const ie=l.useElementVisibility(X);e.watch(ie,(e=>{e&&v.autofocus&&!v.disabled&&!v.readonly&&(te.value=!0)}));const re=e.ref(!1),pe=e.computed((()=>v.type===de.PASSWORD));function fe(){re.value=!re.value}const me=e.computed((()=>v.type===de.TIME||v.type===de.DATETIME_LOCAL||v.type===de.DATE||v.type===de.WEEK||v.type===de.MONTH)),$e=e.computed((()=>v.type===de.NUMBER));function Le(){if(Ie.value){if(v.iMask)return void(F.value=Number(F.value)+Number((null==D?void 0:D.value)??1));X.value.stepUp(),I.value=Number(e.unref(X).value)}}function De(){if(Ie.value){if(v.iMask)return void(F.value=Number(F.value)-Number((null==D?void 0:D.value)??1));X.value.stepDown(),I.value=Number(e.unref(X).value)}}const Te=e.computed((()=>v.type===de.SEARCH));function Be(){I.value=""}const{hasIconBefore:Ce,hasIconAfter:Oe}=ce(b,g),Ne=e.computed((()=>{if(void 0!==Oe.value)return Oe.value;switch(v.type){case de.COLOR:return{name:ae};case de.DATE:case de.DATETIME_LOCAL:case de.WEEK:case de.MONTH:return{name:oe};case de.TIME:return{name:le}}})),{hasIcon:Pe}=ce(y),{formatted:Ae}=function(t,o){const l=e.computed((()=>(e.unref(t)??"").length)),a=e.computed((()=>void 0!==(null==o?void 0:o.lowerLimit)&&l.value<(null==o?void 0:o.lowerLimit)?l.value-o.lowerLimit:void 0!==(null==o?void 0:o.upperLimit)&&l.value<(null==o?void 0:o.upperLimit)?o.upperLimit-l.value:0)),n=e.computed((()=>{if(!1===(null==o?void 0:o.mode))return"";if("limit"===(null==o?void 0:o.mode)&&(null==o?void 0:o.upperLimit))return`${l.value} / ${o.lowerLimit?`${o.lowerLimit}-`:""}${o.upperLimit}`;if("countdown"===(null==o?void 0:o.mode)){if(0===a.value)return;return a}return l.value}));return{length:l,gap:a,formatted:n}}(I,{mode:m.value,upperLimit:Number(null==x?void 0:x.value),lowerLimit:Number(null==$?void 0:$.value)}),Ie=e.computed((()=>!v.disabled&&!v.readonly)),Me=e.computed((()=>Ie.value?v.tabindex:-1)),_e=e.computed((()=>!u(L))),Ve=e.computed((()=>!0===w.value||!0!==O.value&&void 0)),He=function(t,o=d.local,a){const n=e.ref();let i;return a&&(n.value=a),t&&e.watch(t,((t,a)=>{const r=e.unref(o)===d.session?sessionStorage:localStorage;a&&a!==t&&r.removeItem(a),i=t?l.useStorage(t,(null==i?void 0:i.value)??n.value,r):void 0}),{immediate:!0}),e.isRef(o)&&e.watch(o,((e,o)=>{if(null==t?void 0:t.value){if(e){const o=e===d.session?sessionStorage:localStorage;i=l.useStorage(t.value,(null==i?void 0:i.value)??n.value,o)}o&&o!==e&&(o===d.session?sessionStorage:localStorage).removeItem(t.value)}})),e.computed({get:()=>(null==i?void 0:i.value)??n.value,set:e=>{i?i.value=e:n.value=e}})}(T,B,new Set),Re=e.computed((()=>He.value?[...He.value].filter((e=>u(I.value)||`${e}`.toLowerCase().includes(`${I.value}`.toLowerCase())&&e!==I.value)).reverse():[])),je=e.computed((()=>(null==T?void 0:T.value)&&He.value&&He.value.size>0));const{modifiers:ze}=e.toRefs(v),Fe=K("vv-input-text",ze,e.computed((()=>({valid:O.value,invalid:w.value,loading:E.value,disabled:v.disabled,required:v.required,readonly:v.readonly,"icon-before":!!Ce.value,"icon-after":!!Ne.value,floating:v.floating&&!u(v.label),dirty:_e.value,focus:ne.value,"auto-width":v.autoWidth})))),Ue=e.computed((()=>{const e=pe.value&&re.value?de.TEXT:!me.value||_e.value||te.value?v.iMask?de.TEXT:v.type:de.TEXT,t={type:e,name:v.name,tabindex:Me.value,disabled:v.disabled,readonly:v.readonly,required:v.required,autocomplete:v.autocomplete,"aria-invalid":Ve.value,"aria-describedby":qe.value?P.value:void 0,"aria-errormessage":Ke.value?P.value:void 0};if(e===de.DATE||e===de.MONTH||e===de.WEEK||e===de.TIME||e===de.DATETIME_LOCAL||e===de.NUMBER){let o=v.max;e!==de.DATE||o||(o="9999-12-31"),t.step=v.step,t.max=void 0!==o?String(o):void 0,t.min=void 0!==v.min?String(v.min):void 0}return e!==de.TEXT&&e!==de.SEARCH&&e!==de.URL&&e!==de.TEL&&e!==de.EMAIL&&e!==de.PASSWORD&&e!==de.NUMBER||(t.placeholder=A.value),e!==de.TEXT&&e!==de.SEARCH&&e!==de.URL&&e!==de.TEL&&e!==de.EMAIL&&e!==de.PASSWORD||(t.minlength=v.minlength,t.maxlength=v.maxlength,t.pattern=v.pattern),e===de.EMAIL&&(t.multiple=v.multiple),t})),We=e.computed((()=>({valid:v.valid,invalid:v.invalid,modelValue:v.modelValue,togglePassword:fe,stepUp:Le,stepDown:De,clear:Be}))),{HintSlot:Ye,hasHintLabelOrSlot:qe,hasInvalidLabelOrSlot:Ke,hintSlotScope:Xe}=function(t,o){const l=e.computed((()=>e.isRef(t)?t.value:t)),a=e.computed((()=>s(l.value.invalidLabel))),n=e.computed((()=>s(l.value.validLabel))),i=e.computed((()=>l.value.loadingLabel)),r=e.computed((()=>l.value.hintLabel)),u=e.computed((()=>Boolean(l.value.loading&&(o.loading||i.value)))),d=e.computed((()=>!u.value&&Boolean(l.value.invalid&&(o.invalid||a.value)))),v=e.computed((()=>!u.value&&!d.value&&Boolean(l.value.valid&&(o.valid||n.value)))),c=e.computed((()=>!u.value&&!d.value&&!v.value&&Boolean(o.hint||r.value))),p=e.computed((()=>d.value||v.value||u.value||c.value)),f=e.computed((()=>({modelValue:l.value.modelValue,valid:l.value.valid,invalid:l.value.invalid,loading:l.value.loading}))),m=e.defineComponent({name:"HintSlot",props:{tag:{type:String,default:"small"}},setup:()=>({isVisible:p,invalidLabel:a,validLabel:n,loadingLabel:i,hintLabel:r,hasInvalidLabelOrSlot:d,hasValidLabelOrSlot:v,hasLoadingLabelOrSlot:u,hasHintLabelOrSlot:c}),render(){var t,o,l,a,n,i,r,u;if(this.isVisible){let s;return this.hasInvalidLabelOrSlot&&(s="alert"),this.hasValidLabelOrSlot&&(s="status"),this.hasLoadingLabelOrSlot?e.h(this.tag,{role:s},(null==(o=(t=this.$slots).loading)?void 0:o.call(t))??this.loadingLabel):this.hasInvalidLabelOrSlot?e.h(this.tag,{role:s},(null==(a=(l=this.$slots).invalid)?void 0:a.call(l))??this.$slots.invalid??this.invalidLabel):this.hasValidLabelOrSlot?e.h(this.tag,{role:s},(null==(i=(n=this.$slots).valid)?void 0:i.call(n))??this.validLabel):e.h(this.tag,{role:s},(null==(u=(r=this.$slots).hint)?void 0:u.call(r))??this.$slots.hint??this.hintLabel)}return null}});return{hasInvalidLabelOrSlot:d,hasHintLabelOrSlot:c,hasValidLabelOrSlot:v,hasLoadingLabelOrSlot:u,hintSlotScope:f,HintSlot:m}}(f,p),Je=he(de.PASSWORD,v),Ze=he(de.NUMBER,v),Ge=he(de.SEARCH,v);function Qe(){Ie.value&&(te.value=!0)}const et=e.computed((()=>{if(v.autoWidth)return{width:void 0!==I.value?`${String(I.value).length+1}ch`:void 0}}));function tt(e){switch(e.code){case"ArrowUp":$e.value&&(Le(),e.preventDefault());break;case"ArrowDown":$e.value&&(De(),e.preventDefault())}c("keydown",e)}return(t,o)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref(Fe))},[e.unref(k)?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(N),class:"vv-input-text__label"},e.toDisplayString(e.unref(k)),9,be)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:G,class:"vv-input-text__wrapper"},[t.$slots.before?(e.openBlock(),e.createElementBlock("div",ge,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(We))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"innerEl",ref:Z,class:"vv-input-text__inner",onClick:e.withModifiers(Qe,["stop"])},[e.unref(Ce)?(e.openBlock(),e.createBlock(se,e.mergeProps({key:0},e.unref(Ce),{class:"vv-input-text__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.createElementVNode("input",e.mergeProps({id:e.unref(N),ref_key:"inputEl",ref:X},e.unref(Ue),{style:e.unref(et),onKeyup:o[0]||(o[0]=e=>c("keyup",e)),onKeydown:tt,onKeypress:o[1]||(o[1]=e=>c("keypress",e))}),null,16,ye),(t.unit||t.$slots.unit)&&e.unref(_e)?(e.openBlock(),e.createElementBlock("div",Se,[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps(e.unref(We))),(()=>[e.createTextVNode(e.toDisplayString(t.unit),1)]))])):e.createCommentVNode("v-if",!0)],512),e.unref(Ne)?(e.openBlock(),e.createBlock(se,e.mergeProps({key:1},e.unref(Ne),{class:"vv-input-text__icon vv-input-text__icon-after"}),null,16)):e.unref(pe)&&!t.hideActions&&e.unref(Ie)?(e.openBlock(),e.createBlock(e.unref(Je),{key:2,onTogglePassword:fe})):e.unref($e)&&!t.hideActions&&e.unref(Ie)?(e.openBlock(),e.createBlock(e.unref(Ze),{key:3,onStepUp:Le,onStepDown:De})):e.unref(Te)&&!t.hideActions&&e.unref(Ie)?(e.openBlock(),e.createBlock(e.unref(Ge),{key:4,onClear:Be})):e.createCommentVNode("v-if",!0),t.$slots.after?(e.openBlock(),e.createElementBlock("div",we,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(We))))])):e.createCommentVNode("v-if",!0),e.unref(m)?(e.openBlock(),e.createElementBlock("span",ke,[e.renderSlot(t.$slots,"count",e.normalizeProps(e.guardReactiveProps(e.unref(We))),(()=>[e.createTextVNode(e.toDisplayString(e.unref(Ae)),1)]))])):e.createCommentVNode("v-if",!0)],512),e.createVNode(e.unref(Ye),{id:e.unref(P),class:"vv-input-text__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(Xe))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(Xe))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(Xe))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(Xe))))])),key:"3"}:void 0]),1032,["id"]),e.unref(je)?(e.openBlock(),e.createBlock(J,{key:1,ref_key:"suggestionsDropdownEl",ref:ee,reference:e.unref(G),"autofocus-first":!1,"trigger-width":!0},{items:e.withCtx((()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(Re),(o=>(e.openBlock(),e.createBlock(Q,{key:o,onClick:e.withModifiers((e=>{return t=o,I.value=t,void(null==(l=ee.value)||l.hide());var t,l}),["stop"])},{default:e.withCtx((()=>[e.createElementVNode("div",Ee,[e.renderSlot(t.$slots,"suggestion",e.mergeProps({ref_for:!0},{value:o}),(()=>[e.createTextVNode(e.toDisplayString(o),1)]))]),e.unref(He)&&e.unref(Pe)?(e.openBlock(),e.createElementBlock("button",{key:0,type:"button",tabindex:"-1",class:"cursor-pointer",title:t.labelRemoveSuggestion,onClick:e.withModifiers((e=>{return t=o,void(null==(l=He.value)||l.delete(t));var t,l}),["stop"])},[e.createVNode(se,e.mergeProps({ref_for:!0},e.unref(Pe)),null,16)],8,xe)):e.createCommentVNode("v-if",!0)])),_:2},1032,["onClick"])))),128))])),_:3},8,["reference"])):e.createCommentVNode("v-if",!0)],2))}})}));
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<globalThis.ExtractPropTypes<{
|
|
2
|
-
modelValue: (StringConstructor | NumberConstructor)[];
|
|
2
|
+
modelValue: (StringConstructor | NumberConstructor | DateConstructor)[];
|
|
3
3
|
type: {
|
|
4
4
|
type: PropType<import("../VvInputText").InputType>;
|
|
5
5
|
default: "text";
|
|
@@ -188,7 +188,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<gl
|
|
|
188
188
|
}>, {
|
|
189
189
|
$inner: globalThis.Ref<HTMLInputElement | undefined, HTMLInputElement | undefined>;
|
|
190
190
|
}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<globalThis.ExtractPropTypes<{
|
|
191
|
-
modelValue: (StringConstructor | NumberConstructor)[];
|
|
191
|
+
modelValue: (StringConstructor | NumberConstructor | DateConstructor)[];
|
|
192
192
|
type: {
|
|
193
193
|
type: PropType<import("../VvInputText").InputType>;
|
|
194
194
|
default: "text";
|
|
@@ -422,7 +422,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<gl
|
|
|
422
422
|
before?(_: {
|
|
423
423
|
valid: boolean;
|
|
424
424
|
invalid: boolean;
|
|
425
|
-
modelValue: string | number | undefined;
|
|
425
|
+
modelValue: string | number | Date | undefined;
|
|
426
426
|
togglePassword: () => void;
|
|
427
427
|
stepUp: () => void;
|
|
428
428
|
stepDown: () => void;
|
|
@@ -431,7 +431,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<gl
|
|
|
431
431
|
default?(_: {
|
|
432
432
|
valid: boolean;
|
|
433
433
|
invalid: boolean;
|
|
434
|
-
modelValue: string | number | undefined;
|
|
434
|
+
modelValue: string | number | Date | undefined;
|
|
435
435
|
togglePassword: () => void;
|
|
436
436
|
stepUp: () => void;
|
|
437
437
|
stepDown: () => void;
|
|
@@ -440,7 +440,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<gl
|
|
|
440
440
|
after?(_: {
|
|
441
441
|
valid: boolean;
|
|
442
442
|
invalid: boolean;
|
|
443
|
-
modelValue: string | number | undefined;
|
|
443
|
+
modelValue: string | number | Date | undefined;
|
|
444
444
|
togglePassword: () => void;
|
|
445
445
|
stepUp: () => void;
|
|
446
446
|
stepDown: () => void;
|
|
@@ -449,7 +449,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<gl
|
|
|
449
449
|
count?(_: {
|
|
450
450
|
valid: boolean;
|
|
451
451
|
invalid: boolean;
|
|
452
|
-
modelValue: string | number | undefined;
|
|
452
|
+
modelValue: string | number | Date | undefined;
|
|
453
453
|
togglePassword: () => void;
|
|
454
454
|
stepUp: () => void;
|
|
455
455
|
stepDown: () => void;
|
|
@@ -23,7 +23,7 @@ export declare const VvInputTextProps: {
|
|
|
23
23
|
* Input value
|
|
24
24
|
* @see https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#value
|
|
25
25
|
*/
|
|
26
|
-
modelValue: (StringConstructor | NumberConstructor)[];
|
|
26
|
+
modelValue: (StringConstructor | NumberConstructor | DateConstructor)[];
|
|
27
27
|
/**
|
|
28
28
|
* Type of form control
|
|
29
29
|
* @see https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#type
|