@volverjs/ui-vue 0.0.5-beta.1 → 0.0.5-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (62) hide show
  1. package/dist/components/VvAction/VvAction.es.js +10 -0
  2. package/dist/components/VvBadge/VvBadge.es.js +10 -0
  3. package/dist/components/VvBreadcrumb/VvBreadcrumb.es.js +10 -0
  4. package/dist/components/VvButton/VvButton.es.js +10 -0
  5. package/dist/components/VvButtonGroup/VvButtonGroup.es.js +10 -0
  6. package/dist/components/VvCheckbox/VvCheckbox.es.js +10 -0
  7. package/dist/components/VvCheckboxGroup/VvCheckboxGroup.es.js +10 -0
  8. package/dist/components/VvCombobox/VvCombobox.es.js +17 -3
  9. package/dist/components/VvCombobox/VvCombobox.umd.js +1 -1
  10. package/dist/components/VvCombobox/VvCombobox.vue.d.ts +24 -11
  11. package/dist/components/VvCombobox/index.d.ts +6 -1
  12. package/dist/components/VvDialog/VvDialog.es.js +10 -0
  13. package/dist/components/VvDropdown/VvDropdown.es.js +14 -2
  14. package/dist/components/VvDropdown/VvDropdown.umd.js +1 -1
  15. package/dist/components/VvDropdown/VvDropdown.vue.d.ts +27 -11
  16. package/dist/components/VvDropdown/index.d.ts +6 -1
  17. package/dist/components/VvDropdownAction/VvDropdownAction.es.js +10 -0
  18. package/dist/components/VvDropdownOption/VvDropdownOption.es.js +10 -0
  19. package/dist/components/VvInputText/VvInputText.es.js +14 -4
  20. package/dist/components/VvInputText/VvInputText.umd.js +1 -1
  21. package/dist/components/VvInputText/VvInputText.vue.d.ts +4 -4
  22. package/dist/components/VvInputText/index.d.ts +2 -2
  23. package/dist/components/VvProgress/VvProgress.es.js +10 -0
  24. package/dist/components/VvRadio/VvRadio.es.js +10 -0
  25. package/dist/components/VvRadioGroup/VvRadioGroup.es.js +10 -0
  26. package/dist/components/VvSelect/VvSelect.es.js +10 -0
  27. package/dist/components/VvTextarea/VvTextarea.es.js +14 -4
  28. package/dist/components/VvTextarea/VvTextarea.umd.js +1 -1
  29. package/dist/components/VvTextarea/VvTextarea.vue.d.ts +10 -10
  30. package/dist/components/VvTextarea/index.d.ts +2 -2
  31. package/dist/components/VvTooltip/VvTooltip.es.js +10 -0
  32. package/dist/components/index.es.js +23 -9
  33. package/dist/components/index.umd.js +1 -1
  34. package/dist/directives/index.d.ts +1 -0
  35. package/dist/directives/index.es.js +51 -2
  36. package/dist/directives/index.umd.js +1 -1
  37. package/dist/directives/v-contextmenu.d.ts +3 -0
  38. package/dist/directives/v-contextmenu.es.js +42 -0
  39. package/dist/directives/v-contextmenu.umd.js +1 -0
  40. package/dist/directives/v-tooltip.es.js +10 -0
  41. package/dist/icons.d.ts +3 -1
  42. package/dist/icons.es.js +6 -4
  43. package/dist/icons.umd.js +1 -1
  44. package/dist/props/index.d.ts +11 -3
  45. package/dist/stories/Combobox/Combobox.settings.d.ts +12 -0
  46. package/dist/stories/Dropdown/Dropdown.settings.d.ts +12 -0
  47. package/dist/stories/argTypes.d.ts +12 -0
  48. package/package.json +50 -42
  49. package/src/assets/icons/detailed.json +1 -1
  50. package/src/assets/icons/normal.json +1 -1
  51. package/src/assets/icons/simple.json +1 -1
  52. package/src/components/VvCombobox/VvCombobox.vue +5 -3
  53. package/src/components/VvDropdown/VvDropdown.vue +3 -2
  54. package/src/components/VvInputText/VvInputText.vue +2 -2
  55. package/src/components/VvTextarea/VvTextarea.vue +2 -2
  56. package/src/directives/index.ts +2 -0
  57. package/src/directives/v-contextmenu.ts +40 -0
  58. package/src/icons.ts +1 -1
  59. package/src/props/index.ts +12 -2
  60. package/src/stories/Dropdown/DropdownContextmenuDirective.stories.mdx +41 -0
  61. package/src/stories/Tooltip/TooltipDirective.stories.mdx +1 -1
  62. package/src/stories/argTypes.ts +10 -0
@@ -122,6 +122,16 @@ const LabelProps = {
122
122
  return Object.values(Side).includes(value) || Object.values(Placement).includes(value);
123
123
  }
124
124
  },
125
+ /**
126
+ * Dropdown strategy
127
+ */
128
+ strategy: {
129
+ type: String,
130
+ default: "absolute",
131
+ validator: (value) => {
132
+ return ["fixed", "absolute"].includes(value);
133
+ }
134
+ },
125
135
  /**
126
136
  * Dropdown show / hide transition name
127
137
  */
@@ -118,6 +118,16 @@ const ModifiersProps = {
118
118
  return Object.values(Side).includes(value) || Object.values(Placement).includes(value);
119
119
  }
120
120
  },
121
+ /**
122
+ * Dropdown strategy
123
+ */
124
+ strategy: {
125
+ type: String,
126
+ default: "absolute",
127
+ validator: (value) => {
128
+ return ["fixed", "absolute"].includes(value);
129
+ }
130
+ },
121
131
  /**
122
132
  * Dropdown show / hide transition name
123
133
  */
@@ -141,6 +141,16 @@ const ModifiersProps = {
141
141
  return Object.values(Side).includes(value) || Object.values(Placement).includes(value);
142
142
  }
143
143
  },
144
+ /**
145
+ * Dropdown strategy
146
+ */
147
+ strategy: {
148
+ type: String,
149
+ default: "absolute",
150
+ validator: (value) => {
151
+ return ["fixed", "absolute"].includes(value);
152
+ }
153
+ },
144
154
  /**
145
155
  * Dropdown show / hide transition name
146
156
  */
@@ -367,6 +367,16 @@ const IdProps = {
367
367
  return Object.values(Side).includes(value) || Object.values(Placement).includes(value);
368
368
  }
369
369
  },
370
+ /**
371
+ * Dropdown strategy
372
+ */
373
+ strategy: {
374
+ type: String,
375
+ default: "absolute",
376
+ validator: (value) => {
377
+ return ["fixed", "absolute"].includes(value);
378
+ }
379
+ },
370
380
  /**
371
381
  * Dropdown show / hide transition name
372
382
  */
@@ -125,6 +125,16 @@ const UnselectableProps = {
125
125
  return Object.values(Side).includes(value) || Object.values(Placement).includes(value);
126
126
  }
127
127
  },
128
+ /**
129
+ * Dropdown strategy
130
+ */
131
+ strategy: {
132
+ type: String,
133
+ default: "absolute",
134
+ validator: (value) => {
135
+ return ["fixed", "absolute"].includes(value);
136
+ }
137
+ },
128
138
  /**
129
139
  * Dropdown show / hide transition name
130
140
  */
@@ -164,6 +164,16 @@ const IdProps = {
164
164
  return Object.values(Side).includes(value) || Object.values(Placement).includes(value);
165
165
  }
166
166
  },
167
+ /**
168
+ * Dropdown strategy
169
+ */
170
+ strategy: {
171
+ type: String,
172
+ default: "absolute",
173
+ validator: (value) => {
174
+ return ["fixed", "absolute"].includes(value);
175
+ }
176
+ },
167
177
  /**
168
178
  * Dropdown show / hide transition name
169
179
  */
@@ -377,6 +377,16 @@ const IdProps = {
377
377
  return Object.values(Side).includes(value) || Object.values(Placement).includes(value);
378
378
  }
379
379
  },
380
+ /**
381
+ * Dropdown strategy
382
+ */
383
+ strategy: {
384
+ type: String,
385
+ default: "absolute",
386
+ validator: (value) => {
387
+ return ["fixed", "absolute"].includes(value);
388
+ }
389
+ },
380
390
  /**
381
391
  * Dropdown show / hide transition name
382
392
  */
@@ -238,6 +238,16 @@ const DropdownProps = {
238
238
  return Object.values(Side).includes(value) || Object.values(Placement).includes(value);
239
239
  }
240
240
  },
241
+ /**
242
+ * Dropdown strategy
243
+ */
244
+ strategy: {
245
+ type: String,
246
+ default: "absolute",
247
+ validator: (value) => {
248
+ return ["fixed", "absolute"].includes(value);
249
+ }
250
+ },
241
251
  /**
242
252
  * Dropdown show / hide transition name
243
253
  */
@@ -776,7 +786,7 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
776
786
  ...__default__$5,
777
787
  props: VvDropdownProps,
778
788
  emits: ["update:modelValue"],
779
- setup(__props, { emit }) {
789
+ setup(__props, { expose, emit }) {
780
790
  const props = __props;
781
791
  const { id } = toRefs(props);
782
792
  const hasId = useUniqueId(id);
@@ -862,7 +872,8 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
862
872
  floatingEl,
863
873
  {
864
874
  whileElementsMounted: autoUpdate,
865
- placement: props.placement,
875
+ placement: computed(() => props.placement),
876
+ strategy: computed(() => props.strategy),
866
877
  middleware
867
878
  }
868
879
  );
@@ -920,6 +931,7 @@ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
920
931
  const init = (el) => {
921
932
  referenceEl.value = el;
922
933
  };
934
+ expose({ toggle, show, hide, init });
923
935
  watch(expanded, (newValue) => {
924
936
  if (newValue && props.autofocusFirst) {
925
937
  nextTick(() => {
@@ -1945,7 +1957,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
1945
1957
  let toReturn = value;
1946
1958
  if (props.multiple) {
1947
1959
  if (Array.isArray(props.modelValue)) {
1948
- if (props.maxValues !== void 0 && props.maxValues >= 0 && ((_a = props.modelValue) == null ? void 0 : _a.length) >= props.maxValues) {
1960
+ const maxValues = Number(props.maxValues);
1961
+ if (props.maxValues !== void 0 && maxValues >= 0 && ((_a = props.modelValue) == null ? void 0 : _a.length) >= maxValues) {
1949
1962
  if (!contains(value, props.modelValue)) {
1950
1963
  return;
1951
1964
  }
@@ -1994,6 +2007,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
1994
2007
  id: hasDropdownId.value,
1995
2008
  reference: wrapperEl.value,
1996
2009
  placement: props.placement,
2010
+ strategy: props.strategy,
1997
2011
  transitionName: props.transitionName,
1998
2012
  offset: props.offset,
1999
2013
  shift: props.shift,
@@ -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")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","@floating-ui/vue","nanoid","@vueuse/core","mitt"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvCombobox=t(e.vue,e.vue$1,e.vue$2,e.nanoid,e.core,e.mitt)}(this,(function(e,t,l,o,n,a){"use strict";var r=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(r||{}),i=(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))(i||{}),u=(e=>(e.before="before",e.after="after",e))(u||{}),d=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(d||{}),s=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(s||{}),c=(e=>(e.listbox="listbox",e.menu="menu",e))(c||{}),f=(e=>(e.option="option",e.presentation="presentation",e))(f||{});const p=Symbol.for("volver"),v=Symbol.for("dropdownTrigger"),m=Symbol.for("dropdownItem"),b=Symbol.for("dropdownAction"),g={valid:Boolean,validLabel:[String,Array]},y={invalid:Boolean,invalidLabel:[String,Array]},h={loading:Boolean,loadingLabel:{type:String,default:"Loading..."}},k={disabled:Boolean},S={selected:Boolean},B=(Boolean,Boolean,{label:[String,Number]}),V={readonly:Boolean},x={modifiers:[String,Array]},w={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"}},_={icon:{type:[String,Object]},iconPosition:{type:String,default:u.before,validation:e=>Object.values(u).includes(e)}},E={tabindex:{type:[String,Number],default:0}},C={floating:Boolean},P={unselectable:{type:Boolean,default:!0}},L={id:[String,Number]},$={placement:{type:String,default:r.bottom,validator:e=>Object.values(r).includes(e)||Object.values(i).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},autoClose:{type:Boolean,default:!0},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean}},O={...L,name:{type:String,required:!0}},A={autofocus:Boolean},D={autocomplete:{type:String,default:"off"}};d.button;const j={...O,...E,...g,...y,...w,...h,...k,...V,...x,...N,..._,...C,...P,...$,...B,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"},placeholder:String,searchable:Boolean,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:{...$.triggerWidth,default:!0},dropdownModifiers:{type:[String,Array]},autoOpen:Boolean,autoClose:Boolean},R={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 z(){return e.inject(p)}function F(t,l,o){return e.computed((()=>{const n={[t]:!0},a="string"==typeof(null==l?void 0:l.value)?l.value.split(" "):null==l?void 0:l.value;return a&&Array.isArray(a)&&a.forEach((e=>{e&&(n[`${t}--${e}`]=!0)})),o&&Object.keys(o.value).forEach((l=>{n[`${t}--${l}`]=e.unref(o.value[l])})),n}))}const H=e.defineComponent({name:"VvIcon",props:R,setup(l){const o=l,n=e.ref(!0),a=z(),{modifiers:r}=e.toRefs(o),i=F("vv-icon",r),u=e.computed((()=>o.provider||(null==a?void 0:a.iconsProvider))),d=e.computed((()=>{const e=o.name??"",l=`@${u.value}:${o.prefix}:${o.name}`;return t.iconExists(e)?e:t.iconExists(l)?l:(null==a?void 0:a.iconsCollections.find((l=>{const o=`@${u.value}:${l.prefix}:${e}`;if(t.iconExists(o))return o})))||e}));function s(e){const l=function(e){let t=null;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),n=(null==l?void 0:l.innerHTML.trim())||"";l&&n&&t.addIcon(`@${u.value}:${o.prefix}:${o.name}`,{body:n,height:l.viewBox.baseVal.height,width:l.viewBox.baseVal.width})}return a&&(o.src&&!t.iconExists(`@${u.value}:${o.prefix}:${o.name}`)?(n.value=!1,a.fetchIcon(o.src).then((e=>{e&&(s(e),n.value=!0)})).catch((e=>{throw new Error(`During fetch icon: ${null==e?void 0:e.message}`)}))):o.svg&&s(o.svg)),(l,o)=>e.unref(n)?(e.openBlock(),e.createBlock(e.unref(t.Icon),e.mergeProps({key:0,class:e.unref(i)},{inline:l.inline,width:l.width,height:l.height,horizontalFlip:l.horizontalFlip,verticalFlip:l.verticalFlip,flip:l.flip,rotate:l.rotate,color:l.color,onLoad:l.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("",!0)}}),I={...L,...x,...$,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:c.menu,validator:e=>Object.values(c).includes(e)}},T=t=>e.computed((()=>String((null==t?void 0:t.value)||o.nanoid())));const K=["id","tabindex","role","aria-labelledby"],q=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:I,emits:["update:modelValue"],setup(t,{emit:o}){const r=t,{id:i}=e.toRefs(r),u=T(i),d=e.useAttrs(),s=e.ref("auto"),p=e.ref("auto"),b=e.ref(null),g=e.ref(null),y=e.ref(null),h=e.ref(null),k=e.computed({get:()=>r.reference??b.value,set:e=>{b.value=e}}),S=e.computed((()=>{const e=[];if(r.autoPlacement?"boolean"==typeof r.autoPlacement?e.push(l.autoPlacement()):e.push(l.autoPlacement(r.autoPlacement)):r.flip&&("boolean"==typeof r.flip?e.push(l.flip()):e.push(l.flip(r.flip))),r.shift&&("boolean"==typeof r.shift?e.push(l.shift()):e.push(l.shift(r.shift))),r.size){const t=({availableWidth:e,availableHeight:t})=>{s.value=`${e}px`,p.value=`${t}px`};"boolean"==typeof r.size?e.push(l.size({apply:t})):e.push(l.size({...r.size,apply:t}))}return r.offset&&(e.push(l.offset(Number(r.offset))),["string","number"].includes(typeof r.offset)?e.push(l.offset(Number(r.offset))):e.push(l.offset(r.offset))),r.arrow&&e.push(l.arrow({element:y})),e})),{x:B,y:V,strategy:x,middlewareData:w,placement:N}=l.useFloating(k,g,{whileElementsMounted:l.autoUpdate,placement:r.placement,middleware:S}),_=e.computed((()=>({position:x.value,top:`${V.value??0}px`,left:`${B.value??0}px`,maxWidth:s.value,maxHeight:p.value,width:r.triggerWidth&&k.value?`${k.value.offsetWidth}px`:void 0}))),E=e.computed((()=>N.value.split("-")[0])),C=e.computed((()=>({top:"bottom",right:"left",bottom:"top",left:"right"}[E.value]??"bottom"))),P=e.computed((()=>{var e,t,l,o;return["bottom","top"].includes(C.value)?{right:`${(null==(e=w.value.arrow)?void 0:e.x)??0}px`,[C.value]:-((null==(t=y.value)?void 0:t.offsetWidth)??0)/2+"px"}:{top:`${(null==(l=w.value.arrow)?void 0:l.y)??0}px`,[C.value]:-((null==(o=y.value)?void 0:o.offsetWidth)??0)/2+"px"}})),L=n.useVModel(r,"modelValue",o),$=e.ref(!1),O=e.computed({get:()=>L.value??$.value,set:e=>{void 0!==L.value?L.value=e:$.value=e}}),A=()=>{O.value=!0},D=()=>{O.value=!1},j=()=>{O.value=!O.value},R=e=>{k.value=e};e.watch(O,(t=>{t&&r.autofocusFirst&&e.nextTick((()=>{const e=Q(g.value);e.length>0&&e[0].focus()}))})),n.onClickOutside(g,(()=>{r.autoClose&&(O.value=!1)}),{ignore:[k]});const z=e.computed((()=>{var e,t;return(null==(t=null==(e=k.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),H=e.computed((()=>({"aria-controls":u.value,"aria-haspopup":!0,"aria-expanded":O.value}))),{component:I,bus:q}=function({reference:t,id:l,expanded:o,aria:n}){const r=a(),i=e.defineComponent({name:"VvDropdownTriggerProvider",provide:()=>({[v]:{reference:t,id:l,expanded:o,aria:n,bus:r}}),setup:()=>({}),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:k,id:u,expanded:O,aria:H});q.on("click",j);const{role:W,modifiers:M}=e.toRefs(r),{itemRole:U}=function({role:t,expanded:l}){const o=e.computed((()=>t.value===c.listbox?f.option:f.presentation));return e.provide(m,{role:o,expanded:l}),{itemRole:o}}({role:W,expanded:O}),J=F("vv-dropdown",M,e.computed((()=>({arrow:r.arrow})))),{focused:G}=n.useFocusWithin(g);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"))):[]}return n.onKeyStroke("Escape",(e=>{O.value&&(e.preventDefault(),D())})),n.onKeyStroke("ArrowDown",(t=>{O.value&&G.value&&(t.preventDefault(),e.nextTick((()=>{if(G.value){const e=Q(g.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus():e[0].focus()}})))})),n.onKeyStroke("ArrowUp",(t=>{O.value&&G.value&&(t.preventDefault(),e.nextTick((()=>{if(G.value){const e=Q(g.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus():e[e.length-1].focus()}})))})),n.onKeyStroke([" ","Enter"],(e=>{if(O.value&&G.value){e.preventDefault();document.activeElement.click()}})),(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:R,show:A,hide:D,toggle:j,expanded:e.unref(O),aria:e.unref(H)})))])),_:3}),e.createVNode(e.Transition,{name:t.transitionName},{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:g,style:e.normalizeStyle(e.unref(_)),class:e.normalizeClass(e.unref(J))},[r.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:y,style:e.normalizeStyle(e.unref(P)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(O)}))),e.createElementVNode("ul",e.mergeProps(e.unref(d),{id:e.unref(u),ref_key:"listEl",ref:h,tabindex:e.unref(O)?void 0:-1,role:e.unref(W),"aria-labelledby":e.unref(z),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(U)})))],16,K),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(O)})))],6),[[e.vShow,e.unref(O)]])])),_:3},8,["name"])],64))}});const W=e.defineComponent({name:"VvDropdownItem",setup(t){const{role:l,expanded:o}=e.inject(m,{}),a=e.ref(null);!function({expanded:t}){e.provide(b,{role:s.menuitem,expanded:t})}({expanded:o});const r=n.useElementHover(a),{focused:i}=n.useFocus(a),{focused:u}=n.useFocusWithin(a);return e.watch(r,(e=>{e&&(i.value=!0)})),(t,o)=>(e.openBlock(),e.createElementBlock("li",e.mergeProps({role:e.unref(l)},{ref_key:"element",ref:a,class:["vv-dropdown__item",{"focus-visible":e.unref(i)||e.unref(u)}]}),[e.renderSlot(t.$slots,"default")],16))}}),M=["title"],U=e.defineComponent({name:"VvDropdownOption",props:{...k,...S,...P,...x,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String}},setup(t){const l=t,{modifiers:o}=e.toRefs(l),n=F("vv-dropdown-option",o,e.computed((()=>({disabled:l.disabled,selected:l.selected,unselectable:l.unselectable&&l.selected})))),a=e.computed((()=>l.selected?l.unselectable?l.deselectHintLabel:l.selectedHintLabel:l.disabled?void 0:l.selectHintLabel));return(t,l)=>(e.openBlock(),e.createBlock(W,{class:e.normalizeClass(e.unref(n)),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(a)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(a)),1)]))],8,M)])),_:3},8,["class","tabindex","aria-selected","aria-disabled"]))}});function J(e,t,l){return l?Q(e,l)===Q(t,l):G(e,t)}function G(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 n,a,r;if(l&&o){if(a=e.length,a!=t.length)return!1;for(n=a;0!=n--;)if(!G(e[n],t[n]))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 d=e instanceof RegExp,s=t instanceof RegExp;if(d!=s)return!1;if(d&&s)return e.toString()==t.toString();const c=Object.keys(e);if(a=c.length,a!==Object.keys(t).length)return!1;for(n=a;0!=n--;)if(!Object.prototype.hasOwnProperty.call(t,c[n]))return!1;for(n=a;0!=n--;)if(r=c[n],!G(e[r],t[r]))return!1;return!0}return e!=e&&t!=t}function Q(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,n=l.length;t<n;++t){if(null==e)return null;o=o[l[t]]}return o}}return null}function X(e,t){if(null!=e&&t&&t.length)for(const l of t)if(J(e,l))return!0;return!1}function Y(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 Z(e,t){const l=function(e,t){let l=-1;if(t)for(let o=0;o<t.length;o++)if(J(t[o],e)){l=o;break}return l}(e,t);return l>-1?t.filter(((e,t)=>t!==l)):t}function ee(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}function te(t,l){const{invalid:o,valid:a,hint:r,loading:i}=l,{hintLabel:u,modelValue:d,valid:s,validLabel:c,invalid:f,invalidLabel:p,...v}=e.toRefs(t),m=Q(v,"loading"),b=Q(v,"loadingLabel"),g=e.computed((()=>!!f.value&&(!(!f.value||!o)||(!!((null==p?void 0:p.value)&&Array.isArray(p.value)&&p.value.length>0)||!(!(null==p?void 0:p.value)||Y(p)))))),y=e.computed((()=>!!(u&&u.value||r))),h=e.computed((()=>!!(c&&c.value||a))),k=e.computed((()=>!!((null==m?void 0:m.value)&&i||(null==m?void 0:m.value)&&(null==b?void 0:b.value)))),S=e.computed((()=>y.value||h.value||g.value||k.value));return{hasInvalid:g,hasHint:y,hasValid:h,hasLoading:k,HintSlot:{name:"HintSlot",props:{params:{type:Object,default:()=>({})}},setup(t){const l=e.computed((()=>{const e=n.toReactive({hintLabel:u,modelValue:d,valid:s,validLabel:c,invalid:f,invalidLabel:p,loading:m,loadingLabel:b,...t.params});return(null==f?void 0:f.value)?(null==o?void 0:o(e))||ee(null==p?void 0:p.value)||(null==u?void 0:u.value):(null==s?void 0:s.value)?(null==a?void 0:a(e))||ee(null==c?void 0:c.value)||(null==u?void 0:u.value):(null==m?void 0:m.value)?(null==i?void 0:i(e))||ee(null==b?void 0:b.value)||(null==u?void 0:u.value):(null==r?void 0:r(e))||ee(null==u?void 0:u.value)||(null==u?void 0:u.value)}));return{isVisible:S,hasInvalid:g,hasValid:h,hintContent:l}},render(){if(this.isVisible)return e.h("small",{role:this.hasInvalid?"alert":this.hasValid?"status":void 0},this.hintContent)}}}}const le={...O,...A,...D,...E,...g,...y,...w,...h,...k,...V,...x,...N,..._,...C,...P,...B,multiple:Boolean,required:Boolean,size:[String,Number],modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},placeholder:String};function oe(t,l){const{focused:o}=n.useFocus(t);return e.watch(o,(o=>{l(o?"focus":"blur",e.unref(t))})),{focused:o}}function ne(t,l){const o=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===u.before))),n=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===u.after))),a=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.left))),i=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.right))),d=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.top))),s=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.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:a,hasIconRight:i,hasIconTop:d,hasIconBottom:s,hasIconBefore:o,hasIconAfter:n}}function ae(t){const{options:l,labelKey:o,valueKey:n,disabledKey:a}=e.toRefs(t);return{options:l,getOptionLabel:e=>"object"!=typeof e&&null!==e?e:"function"==typeof o.value?o.value(e):e[o.value],getOptionValue:e=>"object"!=typeof e&&null!==e?e:"function"==typeof n.value?n.value(e):e[n.value],getOptionDisabled:e=>("object"==typeof e||null===e)&&("function"==typeof a.value?a.value(e):e[a.value])}}const re=["for"],ie={class:"vv-select__wrapper"},ue={key:0,class:"vv-select__input-before"},de={class:"vv-select__inner"},se=["id"],ce=["disabled","hidden"],fe=["disabled","value"],pe={key:1,class:"vv-select__input-after"},ve=e.defineComponent({name:"VvSelect",props:le,emits:["update:modelValue","focus","blur"],setup(t,{emit:l}){const o=t,a=e.useSlots(),r=e.ref(),{HintSlot:i,hasHint:u,hasInvalid:d}=te(o,a),{id:s,modifiers:c,disabled:f,readonly:p,loading:v,icon:m,iconPosition:b,invalid:g,valid:y,floating:h,multiple:k}=e.toRefs(o),S=T(s),B=e.computed((()=>`${S.value}-hint`)),{focused:V}=oe(r,l),x=n.useElementVisibility(r);e.watch(x,(e=>{e&&o.autofocus&&(V.value=!0)}));const{hasIcon:w,hasIconBefore:N,hasIconAfter:_}=ne(m,b),E=e.computed((()=>!Y(o.modelValue))),C=e.computed((()=>o.disabled||o.readonly)),P=e.computed((()=>C.value?-1:o.tabindex)),L=e.computed((()=>!0===o.invalid||!0!==o.valid&&void 0)),$=F("vv-select",c,e.computed((()=>({valid:y.value,invalid:g.value,loading:v.value,disabled:f.value,readonly:p.value,"icon-before":N.value,"icon-after":_.value,dirty:E.value,focus:V.value,floating:h.value,multiple:k.value})))),O=e.computed((()=>({name:o.name,tabindex:P.value,disabled:C.value,required:o.required,size:o.size,autocomplete:o.autocomplete,multiple:o.multiple,"aria-invalid":L.value,"aria-describedby":!d.value&&u.value?B.value:void 0,"aria-errormessage":d.value?B.value:void 0}))),A=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue}))),{getOptionLabel:D,getOptionValue:j,getOptionDisabled:R}=ae(o),z=e.computed({get:()=>o.modelValue,set:e=>{Array.isArray(e)&&(e=e.filter((e=>void 0!==e))),l("update:modelValue",e)}});return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref($))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(S)},e.toDisplayString(t.label),9,re)):e.createCommentVNode("",!0),e.createElementVNode("div",ie,[t.$slots.before?(e.openBlock(),e.createElementBlock("div",ue,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(A))))])):e.createCommentVNode("",!0),e.createElementVNode("div",de,[e.unref(N)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(w)),null,16)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("select",e.mergeProps({id:e.unref(S),ref_key:"select",ref:r,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(z)?z.value=t:null)},e.unref(O)),[t.placeholder?(e.openBlock(),e.createElementBlock("option",{key:0,value:void 0,disabled:!t.unselectable,hidden:!t.unselectable},e.toDisplayString(t.placeholder),9,ce)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,((t,l)=>(e.openBlock(),e.createElementBlock("option",{key:l,disabled:e.unref(R)(t),value:e.unref(j)(t)},e.toDisplayString(e.unref(D)(t)),9,fe)))),128))],16,se),[[e.vModelSelect,e.unref(z)]]),e.unref(_)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(w)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",pe,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(A))))])):e.createCommentVNode("",!0)]),e.createVNode(e.unref(i),{id:e.unref(B),class:"vv-select__hint"},null,8,["id"])],2))}}),me={...x,value:[String,Number]},be=e.defineComponent({name:"VvBadge",props:me,setup(t){const l=t,{modifiers:o}=e.toRefs(l),n=F("vv-badge",o);return(t,l)=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass(e.unref(n)),role:"status"},[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.value),1)]))],2))}});const ge=["id"],ye=["id","for"],he=["id","aria-controls","aria-labelledby","aria-describedby","placeholder"],ke={key:0,class:"vv-select__input-before"},Se={class:"vv-select__inner"},Be=["aria-labelledby","tabindex"],Ve=["aria-label","onClick"],xe={key:1,class:"vv-select__input-after"},we={name:"VvCombobox",components:{VvDropdown:q,VvDropdownOption:U}};return e.defineComponent({...we,props:j,emits:["update:modelValue","change:search","focus","blur"],setup(t,{emit:l}){const o=t,a=e.useSlots(),r=function(t,l,o){const n=z(),a=e.computed((()=>{var e;if(n&&(null==(e=n.defaults.value)?void 0:e[t]))return n.defaults.value[t]}));return e.computed((()=>{if(void 0===a.value)return o;const e=a.value,t=l,n=o;return Object.keys(t).reduce(((l,o)=>{const a=n[o];if(l[o]=a,o in e){if(Array.isArray(t[o])){const n=t[o];n.length&&n[0]===a&&(l[o]=e[o])}if("function"==typeof t[o]&&(0,t[o])()===a&&(l[o]=e[o]),"object"==typeof t[o]){let n=t[o].default;"function"==typeof n&&(n=n()),"object"==typeof n?JSON.stringify(n)===JSON.stringify(a)&&(l[o]=e[o]):n===a&&(l[o]=e[o])}}return l}),{})}))}("VvCombobox",j,o),{HintSlot:i}=te(o,a),u=e.ref(null),d=e.ref(null),s=e.ref(null),{focused:f}=oe(u,l),{focused:p}=n.useFocusWithin(s);e.watch(f,(e=>{o.autoOpen&&(!e||b.value?e||!b.value||p.value||h():y())})),e.watch(p,(e=>{f.value||e||!b.value||h()}));const v=e.ref(""),m=n.refDebounced(v,Number(o.debounceSearch));e.watch(m,(()=>l("change:search",m.value)));const b=e.ref(!1),g=()=>{o.disabled||o.readonly||(b.value=!b.value)},y=()=>{o.disabled||o.readonly||b.value||(b.value=!0)},h=()=>{o.disabled||o.readonly||!b.value||(b.value=!1)};e.watch(b,(t=>{P.value&&e.nextTick((()=>{t?d.value&&d.value.focus():v.value=""}))}));const{id:k,icon:S,iconPosition:B,modifiers:V,disabled:x,readonly:w,loading:N,valid:_,invalid:E,floating:C,searchable:P}=e.toRefs(o),L=T(k),$=e.computed((()=>`${L.value}-hint`)),O=e.computed((()=>`${L.value}-dropdown`)),A=e.computed((()=>`${L.value}-search`)),D=e.computed((()=>`${L.value}-label`)),{hasIcon:R,hasIconBefore:I,hasIconAfter:K}=ne(S,B),W=e.computed((()=>!Y(o.modelValue))),M=e.computed((()=>x.value||w.value?-1:o.tabindex)),G=F("vv-select",V,e.computed((()=>({disabled:x.value,loading:N.value,readonly:w.value,"icon-before":Boolean(I.value),"icon-after":Boolean(K.value),valid:_.value,invalid:E.value,dirty:W.value,focus:f.value,floating:C.value})))),Q=e.computed((()=>o.searchable?ie.value:o.options)),{getOptionLabel:ee,getOptionValue:le,getOptionDisabled:re}=ae(o),ie=e.computed((()=>{var e;return null==(e=o.options)?void 0:e.filter((e=>ee(e).toLowerCase().includes(m.value.toLowerCase().trim())))}));function ue(e){return Array.isArray(o.modelValue)?X(e,o.modelValue)||X(le(e),o.modelValue):J(e,o.modelValue)||J(le(e),o.modelValue)}const de=e.computed((()=>{let e=[];return Array.isArray(o.modelValue)?e=o.modelValue:o.modelValue&&(e=[o.modelValue]),o.options.filter((t=>e.includes(le(t))))})),se=e.computed((()=>de.value.map((e=>ee(e))).join(o.separator)));e.watch(de,(()=>{!o.multiple&&o.autoClose&&h()}));const ce=()=>{o.autoOpen?y():g()},fe=e=>{var t;if(o.disabled||o.readonly)return;const n=le(e);let a=n;if(o.multiple)if(Array.isArray(o.modelValue)){if(void 0!==o.maxValues&&o.maxValues>=0&&(null==(t=o.modelValue)?void 0:t.length)>=o.maxValues&&!X(n,o.modelValue))return;a=X(n,o.modelValue)?Z(n,o.modelValue):[...o.modelValue,n]}else a=[n];else o.autoClose&&h(),o.unselectable&&n===o.modelValue&&(a=void 0);l("update:modelValue",a)},pe=e.computed((()=>({id:L.value,name:o.name,tabindex:M.value,valid:_.value,validLabel:r.value.validLabel,invalid:E.value,invalidLabel:r.value.invalidLabel,hintLabel:r.value.hintLabel,loading:N.value,loadingLabel:r.value.loadingLabel,disabled:x.value,readonly:w.value,modifiers:o.modifiers,options:Q.value,labelKey:o.labelKey,valueKey:o.valueKey,icon:o.icon,iconPosition:o.iconPosition,floating:o.floating,unselectable:o.unselectable,multiple:o.multiple,label:o.label,placeholder:o.placeholder,modelValue:o.modelValue}))),me=e.computed((()=>({id:O.value,reference:s.value,placement:o.placement,transitionName:o.transitionName,offset:o.offset,shift:o.shift,flip:o.flip,autoPlacement:o.autoPlacement,arrow:o.arrow,autoClose:o.autoClose,autofocusFirst:!P.value&&o.autofocusFirst,triggerWidth:o.triggerWidth,modifiers:o.dropdownModifiers}))),we=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue})));return n.onKeyStroke([" ","Enter"],(e=>{o.autoOpen||!b.value&&f.value&&(e.preventDefault(),e.stopImmediatePropagation(),g())})),(t,o)=>t.native?(e.openBlock(),e.createBlock(ve,e.mergeProps({key:1},e.unref(pe),{"onUpdate:modelValue":o[2]||(o[2]=e=>l("update:modelValue",e))}),null,16)):(e.openBlock(),e.createElementBlock("div",{key:0,id:e.unref(L),class:e.normalizeClass(e.unref(G))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,id:e.unref(D),for:e.unref(P)?e.unref(A):void 0},e.toDisplayString(t.label),9,ye)):e.createCommentVNode("",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:s,class:"vv-select__wrapper"},[e.createVNode(q,e.mergeProps({modelValue:e.unref(b),"onUpdate:modelValue":o[1]||(o[1]=t=>e.isRef(b)?b.value=t:null)},e.unref(me),{role:e.unref(c).listbox}),e.createSlots({default:e.withCtx((({aria:l})=>[t.$slots.before?(e.openBlock(),e.createElementBlock("div",ke,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(we))))])):e.createCommentVNode("",!0),e.createElementVNode("div",Se,[e.unref(I)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(R)),null,16)):e.createCommentVNode("",!0),e.createElementVNode("div",e.mergeProps({ref_key:"inputEl",ref:u},l,{"aria-labelledby":e.unref(D),class:"vv-select__input",role:"combobox",tabindex:e.unref(M),onClickPassive:ce}),[e.renderSlot(t.$slots,"value",e.normalizeProps(e.guardReactiveProps({selectedOptions:e.unref(de),onInput:fe})),(()=>[e.unref(se)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.badges?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(e.unref(de),((l,o)=>(e.openBlock(),e.createBlock(be,{key:o,modifiers:t.badgeModifiers,class:"vv-select__badge"},{default:e.withCtx((()=>[e.createTextVNode(e.toDisplayString(e.unref(ee)(l))+" ",1),!t.unselectable||e.unref(w)||e.unref(x)?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("button",{key:0,"aria-label":e.unref(r).deselectActionLabel,onClick:e.withModifiers((e=>fe(l)),["stop"])},[e.createVNode(H,{name:"close"})],8,Ve))])),_:2},1032,["modifiers"])))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(e.unref(se)),1)],64))],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(t.placeholder),1)],64))]))],16,Be),e.unref(K)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(R)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",xe,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(we))))])):e.createCommentVNode("",!0)])),items:e.withCtx((()=>[e.unref(ie).length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(e.unref(ie),((l,o)=>(e.openBlock(),e.createBlock(U,e.mergeProps({disabled:e.unref(re)(l),selected:ue(l),unselectable:t.unselectable,deselectHintLabel:e.unref(r).deselectHintLabel,selectHintLabel:e.unref(r).selectHintLabel,selectedHintLabel:e.unref(r).selectedHintLabel},{key:o,class:"vv-dropdown-option",onClickPassive:e=>fe(l)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(de),selected:ue(l),disabled:e.unref(re)(l)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(ee)(l)),1)]))])),_:2},1040,["onClickPassive"])))),128)):t.options.length?(e.openBlock(),e.createBlock(U,{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(U,{key:1,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-options",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(r).noOptionsLabel),1)]))])),_:3}))])),_:2},[e.unref(P)||t.$slots["dropdown::before"]?{name:"before",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::before"),e.unref(P)?e.withDirectives((e.openBlock(),e.createElementBlock("input",{key:0,id:e.unref(A),ref_key:"inputSearchEl",ref:d,"onUpdate:modelValue":o[0]||(o[0]=t=>e.isRef(v)?v.value=t:null),"aria-autocomplete":"list","aria-controls":e.unref(O),"aria-labelledby":e.unref(D),"aria-describedby":e.unref($),autocomplete:"off",spellcheck:"false",type:"search",class:"vv-dropdown__search",placeholder:e.unref(r).searchPlaceholder},null,8,he)),[[e.vShow,e.unref(b)],[e.vModelText,e.unref(v)]]):e.createCommentVNode("",!0)])),key:"0"}:void 0,t.$slots["dropdown::after"]?{name:"after",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::after")])),key:"1"}:void 0]),1040,["modelValue","role"])],512),e.createVNode(e.unref(i),{id:e.unref($),class:"vv-select__hint"},null,8,["id"])],10,ge))}})}));
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")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","@floating-ui/vue","nanoid","@vueuse/core","mitt"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvCombobox=t(e.vue,e.vue$1,e.vue$2,e.nanoid,e.core,e.mitt)}(this,(function(e,t,l,o,n,a){"use strict";var r=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(r||{}),i=(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))(i||{}),u=(e=>(e.before="before",e.after="after",e))(u||{}),d=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(d||{}),s=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(s||{}),c=(e=>(e.listbox="listbox",e.menu="menu",e))(c||{}),f=(e=>(e.option="option",e.presentation="presentation",e))(f||{});const p=Symbol.for("volver"),v=Symbol.for("dropdownTrigger"),m=Symbol.for("dropdownItem"),b=Symbol.for("dropdownAction"),g={valid:Boolean,validLabel:[String,Array]},y={invalid:Boolean,invalidLabel:[String,Array]},h={loading:Boolean,loadingLabel:{type:String,default:"Loading..."}},k={disabled:Boolean},S={selected:Boolean},B=(Boolean,Boolean,{label:[String,Number]}),V={readonly:Boolean},x={modifiers:[String,Array]},w={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"}},_={icon:{type:[String,Object]},iconPosition:{type:String,default:u.before,validation:e=>Object.values(u).includes(e)}},E={tabindex:{type:[String,Number],default:0}},C={floating:Boolean},P={unselectable:{type:Boolean,default:!0}},L={id:[String,Number]},$={placement:{type:String,default:r.bottom,validator:e=>Object.values(r).includes(e)||Object.values(i).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},autoClose:{type:Boolean,default:!0},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean}},O={...L,name:{type:String,required:!0}},A={autofocus:Boolean},D={autocomplete:{type:String,default:"off"}};d.button;const j={...O,...E,...g,...y,...w,...h,...k,...V,...x,...N,..._,...C,...P,...$,...B,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"},placeholder:String,searchable:Boolean,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:{...$.triggerWidth,default:!0},dropdownModifiers:{type:[String,Array]},autoOpen:Boolean,autoClose:Boolean},R={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 z(){return e.inject(p)}function F(t,l,o){return e.computed((()=>{const n={[t]:!0},a="string"==typeof(null==l?void 0:l.value)?l.value.split(" "):null==l?void 0:l.value;return a&&Array.isArray(a)&&a.forEach((e=>{e&&(n[`${t}--${e}`]=!0)})),o&&Object.keys(o.value).forEach((l=>{n[`${t}--${l}`]=e.unref(o.value[l])})),n}))}const H=e.defineComponent({name:"VvIcon",props:R,setup(l){const o=l,n=e.ref(!0),a=z(),{modifiers:r}=e.toRefs(o),i=F("vv-icon",r),u=e.computed((()=>o.provider||(null==a?void 0:a.iconsProvider))),d=e.computed((()=>{const e=o.name??"",l=`@${u.value}:${o.prefix}:${o.name}`;return t.iconExists(e)?e:t.iconExists(l)?l:(null==a?void 0:a.iconsCollections.find((l=>{const o=`@${u.value}:${l.prefix}:${e}`;if(t.iconExists(o))return o})))||e}));function s(e){const l=function(e){let t=null;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),n=(null==l?void 0:l.innerHTML.trim())||"";l&&n&&t.addIcon(`@${u.value}:${o.prefix}:${o.name}`,{body:n,height:l.viewBox.baseVal.height,width:l.viewBox.baseVal.width})}return a&&(o.src&&!t.iconExists(`@${u.value}:${o.prefix}:${o.name}`)?(n.value=!1,a.fetchIcon(o.src).then((e=>{e&&(s(e),n.value=!0)})).catch((e=>{throw new Error(`During fetch icon: ${null==e?void 0:e.message}`)}))):o.svg&&s(o.svg)),(l,o)=>e.unref(n)?(e.openBlock(),e.createBlock(e.unref(t.Icon),e.mergeProps({key:0,class:e.unref(i)},{inline:l.inline,width:l.width,height:l.height,horizontalFlip:l.horizontalFlip,verticalFlip:l.verticalFlip,flip:l.flip,rotate:l.rotate,color:l.color,onLoad:l.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("",!0)}}),I={...L,...x,...$,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:c.menu,validator:e=>Object.values(c).includes(e)}},T=t=>e.computed((()=>String((null==t?void 0:t.value)||o.nanoid())));const K=["id","tabindex","role","aria-labelledby"],q=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:I,emits:["update:modelValue"],setup(t,{expose:o,emit:r}){const i=t,{id:u}=e.toRefs(i),d=T(u),s=e.useAttrs(),p=e.ref("auto"),b=e.ref("auto"),g=e.ref(null),y=e.ref(null),h=e.ref(null),k=e.ref(null),S=e.computed({get:()=>i.reference??g.value,set:e=>{g.value=e}}),B=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()):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})=>{p.value=`${e}px`,b.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:h})),e})),{x:V,y:x,strategy:w,middlewareData:N,placement:_}=l.useFloating(S,y,{whileElementsMounted:l.autoUpdate,placement:e.computed((()=>i.placement)),strategy:e.computed((()=>i.strategy)),middleware:B}),E=e.computed((()=>({position:w.value,top:`${x.value??0}px`,left:`${V.value??0}px`,maxWidth:p.value,maxHeight:b.value,width:i.triggerWidth&&S.value?`${S.value.offsetWidth}px`:void 0}))),C=e.computed((()=>_.value.split("-")[0])),P=e.computed((()=>({top:"bottom",right:"left",bottom:"top",left:"right"}[C.value]??"bottom"))),L=e.computed((()=>{var e,t,l,o;return["bottom","top"].includes(P.value)?{right:`${(null==(e=N.value.arrow)?void 0:e.x)??0}px`,[P.value]:-((null==(t=h.value)?void 0:t.offsetWidth)??0)/2+"px"}:{top:`${(null==(l=N.value.arrow)?void 0:l.y)??0}px`,[P.value]:-((null==(o=h.value)?void 0:o.offsetWidth)??0)/2+"px"}})),$=n.useVModel(i,"modelValue",r),O=e.ref(!1),A=e.computed({get:()=>$.value??O.value,set:e=>{void 0!==$.value?$.value=e:O.value=e}}),D=()=>{A.value=!0},j=()=>{A.value=!1},R=()=>{A.value=!A.value},z=e=>{S.value=e};o({toggle:R,show:D,hide:j,init:z}),e.watch(A,(t=>{t&&i.autofocusFirst&&e.nextTick((()=>{const e=X(y.value);e.length>0&&e[0].focus()}))})),n.onClickOutside(y,(()=>{i.autoClose&&(A.value=!1)}),{ignore:[S]});const H=e.computed((()=>{var e,t;return(null==(t=null==(e=S.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),I=e.computed((()=>({"aria-controls":d.value,"aria-haspopup":!0,"aria-expanded":A.value}))),{component:q,bus:W}=function({reference:t,id:l,expanded:o,aria:n}){const r=a(),i=e.defineComponent({name:"VvDropdownTriggerProvider",provide:()=>({[v]:{reference:t,id:l,expanded:o,aria:n,bus:r}}),setup:()=>({}),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:d,expanded:A,aria:I});W.on("click",R);const{role:M,modifiers:U}=e.toRefs(i),{itemRole:J}=function({role:t,expanded:l}){const o=e.computed((()=>t.value===c.listbox?f.option:f.presentation));return e.provide(m,{role:o,expanded:l}),{itemRole:o}}({role:M,expanded:A}),G=F("vv-dropdown",U,e.computed((()=>({arrow:i.arrow})))),{focused:Q}=n.useFocusWithin(y);function X(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"))):[]}return n.onKeyStroke("Escape",(e=>{A.value&&(e.preventDefault(),j())})),n.onKeyStroke("ArrowDown",(t=>{A.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=X(y.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus():e[0].focus()}})))})),n.onKeyStroke("ArrowUp",(t=>{A.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=X(y.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus():e[e.length-1].focus()}})))})),n.onKeyStroke([" ","Enter"],(e=>{if(A.value&&Q.value){e.preventDefault();document.activeElement.click()}})),(t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(q),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:z,show:D,hide:j,toggle:R,expanded:e.unref(A),aria:e.unref(I)})))])),_:3}),e.createVNode(e.Transition,{name:t.transitionName},{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:y,style:e.normalizeStyle(e.unref(E)),class:e.normalizeClass(e.unref(G))},[i.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:h,style:e.normalizeStyle(e.unref(L)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(A)}))),e.createElementVNode("ul",e.mergeProps(e.unref(s),{id:e.unref(d),ref_key:"listEl",ref:k,tabindex:e.unref(A)?void 0:-1,role:e.unref(M),"aria-labelledby":e.unref(H),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(J)})))],16,K),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(A)})))],6),[[e.vShow,e.unref(A)]])])),_:3},8,["name"])],64))}});const W=e.defineComponent({name:"VvDropdownItem",setup(t){const{role:l,expanded:o}=e.inject(m,{}),a=e.ref(null);!function({expanded:t}){e.provide(b,{role:s.menuitem,expanded:t})}({expanded:o});const r=n.useElementHover(a),{focused:i}=n.useFocus(a),{focused:u}=n.useFocusWithin(a);return e.watch(r,(e=>{e&&(i.value=!0)})),(t,o)=>(e.openBlock(),e.createElementBlock("li",e.mergeProps({role:e.unref(l)},{ref_key:"element",ref:a,class:["vv-dropdown__item",{"focus-visible":e.unref(i)||e.unref(u)}]}),[e.renderSlot(t.$slots,"default")],16))}}),M=["title"],U=e.defineComponent({name:"VvDropdownOption",props:{...k,...S,...P,...x,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String}},setup(t){const l=t,{modifiers:o}=e.toRefs(l),n=F("vv-dropdown-option",o,e.computed((()=>({disabled:l.disabled,selected:l.selected,unselectable:l.unselectable&&l.selected})))),a=e.computed((()=>l.selected?l.unselectable?l.deselectHintLabel:l.selectedHintLabel:l.disabled?void 0:l.selectHintLabel));return(t,l)=>(e.openBlock(),e.createBlock(W,{class:e.normalizeClass(e.unref(n)),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(a)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(a)),1)]))],8,M)])),_:3},8,["class","tabindex","aria-selected","aria-disabled"]))}});function J(e,t,l){return l?Q(e,l)===Q(t,l):G(e,t)}function G(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 n,a,r;if(l&&o){if(a=e.length,a!=t.length)return!1;for(n=a;0!=n--;)if(!G(e[n],t[n]))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 d=e instanceof RegExp,s=t instanceof RegExp;if(d!=s)return!1;if(d&&s)return e.toString()==t.toString();const c=Object.keys(e);if(a=c.length,a!==Object.keys(t).length)return!1;for(n=a;0!=n--;)if(!Object.prototype.hasOwnProperty.call(t,c[n]))return!1;for(n=a;0!=n--;)if(r=c[n],!G(e[r],t[r]))return!1;return!0}return e!=e&&t!=t}function Q(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,n=l.length;t<n;++t){if(null==e)return null;o=o[l[t]]}return o}}return null}function X(e,t){if(null!=e&&t&&t.length)for(const l of t)if(J(e,l))return!0;return!1}function Y(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 Z(e,t){const l=function(e,t){let l=-1;if(t)for(let o=0;o<t.length;o++)if(J(t[o],e)){l=o;break}return l}(e,t);return l>-1?t.filter(((e,t)=>t!==l)):t}function ee(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}function te(t,l){const{invalid:o,valid:a,hint:r,loading:i}=l,{hintLabel:u,modelValue:d,valid:s,validLabel:c,invalid:f,invalidLabel:p,...v}=e.toRefs(t),m=Q(v,"loading"),b=Q(v,"loadingLabel"),g=e.computed((()=>!!f.value&&(!(!f.value||!o)||(!!((null==p?void 0:p.value)&&Array.isArray(p.value)&&p.value.length>0)||!(!(null==p?void 0:p.value)||Y(p)))))),y=e.computed((()=>!!(u&&u.value||r))),h=e.computed((()=>!!(c&&c.value||a))),k=e.computed((()=>!!((null==m?void 0:m.value)&&i||(null==m?void 0:m.value)&&(null==b?void 0:b.value)))),S=e.computed((()=>y.value||h.value||g.value||k.value));return{hasInvalid:g,hasHint:y,hasValid:h,hasLoading:k,HintSlot:{name:"HintSlot",props:{params:{type:Object,default:()=>({})}},setup(t){const l=e.computed((()=>{const e=n.toReactive({hintLabel:u,modelValue:d,valid:s,validLabel:c,invalid:f,invalidLabel:p,loading:m,loadingLabel:b,...t.params});return(null==f?void 0:f.value)?(null==o?void 0:o(e))||ee(null==p?void 0:p.value)||(null==u?void 0:u.value):(null==s?void 0:s.value)?(null==a?void 0:a(e))||ee(null==c?void 0:c.value)||(null==u?void 0:u.value):(null==m?void 0:m.value)?(null==i?void 0:i(e))||ee(null==b?void 0:b.value)||(null==u?void 0:u.value):(null==r?void 0:r(e))||ee(null==u?void 0:u.value)||(null==u?void 0:u.value)}));return{isVisible:S,hasInvalid:g,hasValid:h,hintContent:l}},render(){if(this.isVisible)return e.h("small",{role:this.hasInvalid?"alert":this.hasValid?"status":void 0},this.hintContent)}}}}const le={...O,...A,...D,...E,...g,...y,...w,...h,...k,...V,...x,...N,..._,...C,...P,...B,multiple:Boolean,required:Boolean,size:[String,Number],modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},placeholder:String};function oe(t,l){const{focused:o}=n.useFocus(t);return e.watch(o,(o=>{l(o?"focus":"blur",e.unref(t))})),{focused:o}}function ne(t,l){const o=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===u.before))),n=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===u.after))),a=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.left))),i=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.right))),d=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.top))),s=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.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:a,hasIconRight:i,hasIconTop:d,hasIconBottom:s,hasIconBefore:o,hasIconAfter:n}}function ae(t){const{options:l,labelKey:o,valueKey:n,disabledKey:a}=e.toRefs(t);return{options:l,getOptionLabel:e=>"object"!=typeof e&&null!==e?e:"function"==typeof o.value?o.value(e):e[o.value],getOptionValue:e=>"object"!=typeof e&&null!==e?e:"function"==typeof n.value?n.value(e):e[n.value],getOptionDisabled:e=>("object"==typeof e||null===e)&&("function"==typeof a.value?a.value(e):e[a.value])}}const re=["for"],ie={class:"vv-select__wrapper"},ue={key:0,class:"vv-select__input-before"},de={class:"vv-select__inner"},se=["id"],ce=["disabled","hidden"],fe=["disabled","value"],pe={key:1,class:"vv-select__input-after"},ve=e.defineComponent({name:"VvSelect",props:le,emits:["update:modelValue","focus","blur"],setup(t,{emit:l}){const o=t,a=e.useSlots(),r=e.ref(),{HintSlot:i,hasHint:u,hasInvalid:d}=te(o,a),{id:s,modifiers:c,disabled:f,readonly:p,loading:v,icon:m,iconPosition:b,invalid:g,valid:y,floating:h,multiple:k}=e.toRefs(o),S=T(s),B=e.computed((()=>`${S.value}-hint`)),{focused:V}=oe(r,l),x=n.useElementVisibility(r);e.watch(x,(e=>{e&&o.autofocus&&(V.value=!0)}));const{hasIcon:w,hasIconBefore:N,hasIconAfter:_}=ne(m,b),E=e.computed((()=>!Y(o.modelValue))),C=e.computed((()=>o.disabled||o.readonly)),P=e.computed((()=>C.value?-1:o.tabindex)),L=e.computed((()=>!0===o.invalid||!0!==o.valid&&void 0)),$=F("vv-select",c,e.computed((()=>({valid:y.value,invalid:g.value,loading:v.value,disabled:f.value,readonly:p.value,"icon-before":N.value,"icon-after":_.value,dirty:E.value,focus:V.value,floating:h.value,multiple:k.value})))),O=e.computed((()=>({name:o.name,tabindex:P.value,disabled:C.value,required:o.required,size:o.size,autocomplete:o.autocomplete,multiple:o.multiple,"aria-invalid":L.value,"aria-describedby":!d.value&&u.value?B.value:void 0,"aria-errormessage":d.value?B.value:void 0}))),A=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue}))),{getOptionLabel:D,getOptionValue:j,getOptionDisabled:R}=ae(o),z=e.computed({get:()=>o.modelValue,set:e=>{Array.isArray(e)&&(e=e.filter((e=>void 0!==e))),l("update:modelValue",e)}});return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref($))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(S)},e.toDisplayString(t.label),9,re)):e.createCommentVNode("",!0),e.createElementVNode("div",ie,[t.$slots.before?(e.openBlock(),e.createElementBlock("div",ue,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(A))))])):e.createCommentVNode("",!0),e.createElementVNode("div",de,[e.unref(N)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(w)),null,16)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("select",e.mergeProps({id:e.unref(S),ref_key:"select",ref:r,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(z)?z.value=t:null)},e.unref(O)),[t.placeholder?(e.openBlock(),e.createElementBlock("option",{key:0,value:void 0,disabled:!t.unselectable,hidden:!t.unselectable},e.toDisplayString(t.placeholder),9,ce)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,((t,l)=>(e.openBlock(),e.createElementBlock("option",{key:l,disabled:e.unref(R)(t),value:e.unref(j)(t)},e.toDisplayString(e.unref(D)(t)),9,fe)))),128))],16,se),[[e.vModelSelect,e.unref(z)]]),e.unref(_)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(w)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",pe,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(A))))])):e.createCommentVNode("",!0)]),e.createVNode(e.unref(i),{id:e.unref(B),class:"vv-select__hint"},null,8,["id"])],2))}}),me={...x,value:[String,Number]},be=e.defineComponent({name:"VvBadge",props:me,setup(t){const l=t,{modifiers:o}=e.toRefs(l),n=F("vv-badge",o);return(t,l)=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass(e.unref(n)),role:"status"},[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.value),1)]))],2))}});const ge=["id"],ye=["id","for"],he=["id","aria-controls","aria-labelledby","aria-describedby","placeholder"],ke={key:0,class:"vv-select__input-before"},Se={class:"vv-select__inner"},Be=["aria-labelledby","tabindex"],Ve=["aria-label","onClick"],xe={key:1,class:"vv-select__input-after"},we={name:"VvCombobox",components:{VvDropdown:q,VvDropdownOption:U}};return e.defineComponent({...we,props:j,emits:["update:modelValue","change:search","focus","blur"],setup(t,{emit:l}){const o=t,a=e.useSlots(),r=function(t,l,o){const n=z(),a=e.computed((()=>{var e;if(n&&(null==(e=n.defaults.value)?void 0:e[t]))return n.defaults.value[t]}));return e.computed((()=>{if(void 0===a.value)return o;const e=a.value,t=l,n=o;return Object.keys(t).reduce(((l,o)=>{const a=n[o];if(l[o]=a,o in e){if(Array.isArray(t[o])){const n=t[o];n.length&&n[0]===a&&(l[o]=e[o])}if("function"==typeof t[o]&&(0,t[o])()===a&&(l[o]=e[o]),"object"==typeof t[o]){let n=t[o].default;"function"==typeof n&&(n=n()),"object"==typeof n?JSON.stringify(n)===JSON.stringify(a)&&(l[o]=e[o]):n===a&&(l[o]=e[o])}}return l}),{})}))}("VvCombobox",j,o),{HintSlot:i}=te(o,a),u=e.ref(null),d=e.ref(null),s=e.ref(null),{focused:f}=oe(u,l),{focused:p}=n.useFocusWithin(s);e.watch(f,(e=>{o.autoOpen&&(!e||b.value?e||!b.value||p.value||h():y())})),e.watch(p,(e=>{f.value||e||!b.value||h()}));const v=e.ref(""),m=n.refDebounced(v,Number(o.debounceSearch));e.watch(m,(()=>l("change:search",m.value)));const b=e.ref(!1),g=()=>{o.disabled||o.readonly||(b.value=!b.value)},y=()=>{o.disabled||o.readonly||b.value||(b.value=!0)},h=()=>{o.disabled||o.readonly||!b.value||(b.value=!1)};e.watch(b,(t=>{P.value&&e.nextTick((()=>{t?d.value&&d.value.focus():v.value=""}))}));const{id:k,icon:S,iconPosition:B,modifiers:V,disabled:x,readonly:w,loading:N,valid:_,invalid:E,floating:C,searchable:P}=e.toRefs(o),L=T(k),$=e.computed((()=>`${L.value}-hint`)),O=e.computed((()=>`${L.value}-dropdown`)),A=e.computed((()=>`${L.value}-search`)),D=e.computed((()=>`${L.value}-label`)),{hasIcon:R,hasIconBefore:I,hasIconAfter:K}=ne(S,B),W=e.computed((()=>!Y(o.modelValue))),M=e.computed((()=>x.value||w.value?-1:o.tabindex)),G=F("vv-select",V,e.computed((()=>({disabled:x.value,loading:N.value,readonly:w.value,"icon-before":Boolean(I.value),"icon-after":Boolean(K.value),valid:_.value,invalid:E.value,dirty:W.value,focus:f.value,floating:C.value})))),Q=e.computed((()=>o.searchable?ie.value:o.options)),{getOptionLabel:ee,getOptionValue:le,getOptionDisabled:re}=ae(o),ie=e.computed((()=>{var e;return null==(e=o.options)?void 0:e.filter((e=>ee(e).toLowerCase().includes(m.value.toLowerCase().trim())))}));function ue(e){return Array.isArray(o.modelValue)?X(e,o.modelValue)||X(le(e),o.modelValue):J(e,o.modelValue)||J(le(e),o.modelValue)}const de=e.computed((()=>{let e=[];return Array.isArray(o.modelValue)?e=o.modelValue:o.modelValue&&(e=[o.modelValue]),o.options.filter((t=>e.includes(le(t))))})),se=e.computed((()=>de.value.map((e=>ee(e))).join(o.separator)));e.watch(de,(()=>{!o.multiple&&o.autoClose&&h()}));const ce=()=>{o.autoOpen?y():g()},fe=e=>{var t;if(o.disabled||o.readonly)return;const n=le(e);let a=n;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&&!X(n,o.modelValue))return;a=X(n,o.modelValue)?Z(n,o.modelValue):[...o.modelValue,n]}else a=[n];else o.autoClose&&h(),o.unselectable&&n===o.modelValue&&(a=void 0);l("update:modelValue",a)},pe=e.computed((()=>({id:L.value,name:o.name,tabindex:M.value,valid:_.value,validLabel:r.value.validLabel,invalid:E.value,invalidLabel:r.value.invalidLabel,hintLabel:r.value.hintLabel,loading:N.value,loadingLabel:r.value.loadingLabel,disabled:x.value,readonly:w.value,modifiers:o.modifiers,options:Q.value,labelKey:o.labelKey,valueKey:o.valueKey,icon:o.icon,iconPosition:o.iconPosition,floating:o.floating,unselectable:o.unselectable,multiple:o.multiple,label:o.label,placeholder:o.placeholder,modelValue:o.modelValue}))),me=e.computed((()=>({id:O.value,reference:s.value,placement:o.placement,strategy:o.strategy,transitionName:o.transitionName,offset:o.offset,shift:o.shift,flip:o.flip,autoPlacement:o.autoPlacement,arrow:o.arrow,autoClose:o.autoClose,autofocusFirst:!P.value&&o.autofocusFirst,triggerWidth:o.triggerWidth,modifiers:o.dropdownModifiers}))),we=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue})));return n.onKeyStroke([" ","Enter"],(e=>{o.autoOpen||!b.value&&f.value&&(e.preventDefault(),e.stopImmediatePropagation(),g())})),(t,o)=>t.native?(e.openBlock(),e.createBlock(ve,e.mergeProps({key:1},e.unref(pe),{"onUpdate:modelValue":o[2]||(o[2]=e=>l("update:modelValue",e))}),null,16)):(e.openBlock(),e.createElementBlock("div",{key:0,id:e.unref(L),class:e.normalizeClass(e.unref(G))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,id:e.unref(D),for:e.unref(P)?e.unref(A):void 0},e.toDisplayString(t.label),9,ye)):e.createCommentVNode("",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:s,class:"vv-select__wrapper"},[e.createVNode(q,e.mergeProps({modelValue:e.unref(b),"onUpdate:modelValue":o[1]||(o[1]=t=>e.isRef(b)?b.value=t:null)},e.unref(me),{role:e.unref(c).listbox}),e.createSlots({default:e.withCtx((({aria:l})=>[t.$slots.before?(e.openBlock(),e.createElementBlock("div",ke,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(we))))])):e.createCommentVNode("",!0),e.createElementVNode("div",Se,[e.unref(I)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(R)),null,16)):e.createCommentVNode("",!0),e.createElementVNode("div",e.mergeProps({ref_key:"inputEl",ref:u},l,{"aria-labelledby":e.unref(D),class:"vv-select__input",role:"combobox",tabindex:e.unref(M),onClickPassive:ce}),[e.renderSlot(t.$slots,"value",e.normalizeProps(e.guardReactiveProps({selectedOptions:e.unref(de),onInput:fe})),(()=>[e.unref(se)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.badges?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(e.unref(de),((l,o)=>(e.openBlock(),e.createBlock(be,{key:o,modifiers:t.badgeModifiers,class:"vv-select__badge"},{default:e.withCtx((()=>[e.createTextVNode(e.toDisplayString(e.unref(ee)(l))+" ",1),!t.unselectable||e.unref(w)||e.unref(x)?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("button",{key:0,"aria-label":e.unref(r).deselectActionLabel,onClick:e.withModifiers((e=>fe(l)),["stop"])},[e.createVNode(H,{name:"close"})],8,Ve))])),_:2},1032,["modifiers"])))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(e.unref(se)),1)],64))],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(t.placeholder),1)],64))]))],16,Be),e.unref(K)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(R)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",xe,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(we))))])):e.createCommentVNode("",!0)])),items:e.withCtx((()=>[e.unref(ie).length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(e.unref(ie),((l,o)=>(e.openBlock(),e.createBlock(U,e.mergeProps({disabled:e.unref(re)(l),selected:ue(l),unselectable:t.unselectable,deselectHintLabel:e.unref(r).deselectHintLabel,selectHintLabel:e.unref(r).selectHintLabel,selectedHintLabel:e.unref(r).selectedHintLabel},{key:o,class:"vv-dropdown-option",onClickPassive:e=>fe(l)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(de),selected:ue(l),disabled:e.unref(re)(l)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(ee)(l)),1)]))])),_:2},1040,["onClickPassive"])))),128)):t.options.length?(e.openBlock(),e.createBlock(U,{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(U,{key:1,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-options",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(r).noOptionsLabel),1)]))])),_:3}))])),_:2},[e.unref(P)||t.$slots["dropdown::before"]?{name:"before",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::before"),e.unref(P)?e.withDirectives((e.openBlock(),e.createElementBlock("input",{key:0,id:e.unref(A),ref_key:"inputSearchEl",ref:d,"onUpdate:modelValue":o[0]||(o[0]=t=>e.isRef(v)?v.value=t:null),"aria-autocomplete":"list","aria-controls":e.unref(O),"aria-labelledby":e.unref(D),"aria-describedby":e.unref($),autocomplete:"off",spellcheck:"false",type:"search",class:"vv-dropdown__search",placeholder:e.unref(r).searchPlaceholder},null,8,he)),[[e.vShow,e.unref(b)],[e.vModelText,e.unref(v)]]):e.createCommentVNode("",!0)])),key:"0"}:void 0,t.$slots["dropdown::after"]?{name:"after",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::after")])),key:"1"}:void 0]),1040,["modelValue","role"])],512),e.createVNode(e.unref(i),{id:e.unref($),class:"vv-select__hint"},null,8,["id"])],10,ge))}})}));
@@ -65,14 +65,16 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
65
65
  default: import("../../constants").Side;
66
66
  validator: (value: never) => boolean;
67
67
  };
68
+ strategy: {
69
+ type: globalThis.PropType<"fixed" | "absolute">;
70
+ default: string;
71
+ validator: (value: "fixed" | "absolute") => boolean;
72
+ };
68
73
  transitionName: {
69
74
  type: StringConstructor;
70
75
  };
71
76
  offset: {
72
- type: globalThis.PropType<string | import("@floating-ui/core").OffsetOptions | undefined>; /**
73
- * Compute the label to show to the user
74
- * Check if is multiple mode, object mode or "string" mode
75
- */
77
+ type: globalThis.PropType<string | import("@floating-ui/core").OffsetOptions | undefined>;
76
78
  default: number;
77
79
  };
78
80
  shift: {
@@ -101,8 +103,8 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
101
103
  x: number;
102
104
  y: number;
103
105
  placement: import("@floating-ui/core").Placement;
104
- initialPlacement: import("@floating-ui/core").Placement;
105
106
  strategy: import("@floating-ui/core").Strategy;
107
+ initialPlacement: import("@floating-ui/core").Placement;
106
108
  middlewareData: import("@floating-ui/core").MiddlewareData;
107
109
  rects: import("@floating-ui/core").ElementRects;
108
110
  platform: import("@floating-ui/core").Platform;
@@ -122,6 +124,10 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
122
124
  padding: number;
123
125
  };
124
126
  };
127
+ /**
128
+ * Function triggered on input of checkbox or radio (multple or single mode)
129
+ * @param event on input event (checkbox or radio input)
130
+ */
125
131
  autoPlacement: {
126
132
  type: globalThis.PropType<boolean | Partial<import("@floating-ui/core").AutoPlacementOptions & {
127
133
  rootBoundary: import("@floating-ui/core").RootBoundary;
@@ -260,14 +266,16 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
260
266
  default: import("../../constants").Side;
261
267
  validator: (value: never) => boolean;
262
268
  };
269
+ strategy: {
270
+ type: globalThis.PropType<"fixed" | "absolute">;
271
+ default: string;
272
+ validator: (value: "fixed" | "absolute") => boolean;
273
+ };
263
274
  transitionName: {
264
275
  type: StringConstructor;
265
276
  };
266
277
  offset: {
267
- type: globalThis.PropType<string | import("@floating-ui/core").OffsetOptions | undefined>; /**
268
- * Compute the label to show to the user
269
- * Check if is multiple mode, object mode or "string" mode
270
- */
278
+ type: globalThis.PropType<string | import("@floating-ui/core").OffsetOptions | undefined>;
271
279
  default: number;
272
280
  };
273
281
  shift: {
@@ -296,8 +304,8 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
296
304
  x: number;
297
305
  y: number;
298
306
  placement: import("@floating-ui/core").Placement;
299
- initialPlacement: import("@floating-ui/core").Placement;
300
307
  strategy: import("@floating-ui/core").Strategy;
308
+ initialPlacement: import("@floating-ui/core").Placement;
301
309
  middlewareData: import("@floating-ui/core").MiddlewareData;
302
310
  rects: import("@floating-ui/core").ElementRects;
303
311
  platform: import("@floating-ui/core").Platform;
@@ -317,6 +325,10 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
317
325
  padding: number;
318
326
  };
319
327
  };
328
+ /**
329
+ * Function triggered on input of checkbox or radio (multple or single mode)
330
+ * @param event on input event (checkbox or radio input)
331
+ */
320
332
  autoPlacement: {
321
333
  type: globalThis.PropType<boolean | Partial<import("@floating-ui/core").AutoPlacementOptions & {
322
334
  rootBoundary: import("@floating-ui/core").RootBoundary;
@@ -424,14 +436,15 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
424
436
  valueKey: string | Function;
425
437
  disabledKey: string | Function;
426
438
  placement: "left" | "right" | "top" | "bottom" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "left-start" | "left-end" | "right-start" | "right-end";
439
+ strategy: "fixed" | "absolute";
427
440
  offset: string | import("@floating-ui/core").OffsetOptions | undefined;
428
441
  size: boolean | Partial<{
429
442
  apply: (args: {
430
443
  x: number;
431
444
  y: number;
432
445
  placement: import("@floating-ui/core").Placement;
433
- initialPlacement: import("@floating-ui/core").Placement;
434
446
  strategy: import("@floating-ui/core").Strategy;
447
+ initialPlacement: import("@floating-ui/core").Placement;
435
448
  middlewareData: import("@floating-ui/core").MiddlewareData;
436
449
  rects: import("@floating-ui/core").ElementRects;
437
450
  platform: import("@floating-ui/core").Platform;
@@ -129,6 +129,11 @@ export declare const VvComboboxProps: {
129
129
  default: import("../../constants").Side;
130
130
  validator: (value: never) => boolean;
131
131
  };
132
+ strategy: {
133
+ type: PropType<"fixed" | "absolute">;
134
+ default: string;
135
+ validator: (value: "fixed" | "absolute") => boolean;
136
+ };
132
137
  transitionName: {
133
138
  type: StringConstructor;
134
139
  };
@@ -162,8 +167,8 @@ export declare const VvComboboxProps: {
162
167
  x: number;
163
168
  y: number;
164
169
  placement: import("@floating-ui/core").Placement;
165
- initialPlacement: import("@floating-ui/core").Placement;
166
170
  strategy: import("@floating-ui/core").Strategy;
171
+ initialPlacement: import("@floating-ui/core").Placement;
167
172
  middlewareData: import("@floating-ui/core").MiddlewareData;
168
173
  rects: import("@floating-ui/core").ElementRects;
169
174
  platform: import("@floating-ui/core").Platform;
@@ -332,6 +332,16 @@ const IdProps = {
332
332
  return Object.values(Side).includes(value) || Object.values(Placement).includes(value);
333
333
  }
334
334
  },
335
+ /**
336
+ * Dropdown strategy
337
+ */
338
+ strategy: {
339
+ type: String,
340
+ default: "absolute",
341
+ validator: (value) => {
342
+ return ["fixed", "absolute"].includes(value);
343
+ }
344
+ },
335
345
  /**
336
346
  * Dropdown show / hide transition name
337
347
  */
@@ -141,6 +141,16 @@ const DropdownProps = {
141
141
  return Object.values(Side).includes(value) || Object.values(Placement).includes(value);
142
142
  }
143
143
  },
144
+ /**
145
+ * Dropdown strategy
146
+ */
147
+ strategy: {
148
+ type: String,
149
+ default: "absolute",
150
+ validator: (value) => {
151
+ return ["fixed", "absolute"].includes(value);
152
+ }
153
+ },
144
154
  /**
145
155
  * Dropdown show / hide transition name
146
156
  */
@@ -337,7 +347,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
337
347
  ...__default__,
338
348
  props: VvDropdownProps,
339
349
  emits: ["update:modelValue"],
340
- setup(__props, { emit }) {
350
+ setup(__props, { expose, emit }) {
341
351
  const props = __props;
342
352
  const { id } = toRefs(props);
343
353
  const hasId = useUniqueId(id);
@@ -423,7 +433,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
423
433
  floatingEl,
424
434
  {
425
435
  whileElementsMounted: autoUpdate,
426
- placement: props.placement,
436
+ placement: computed(() => props.placement),
437
+ strategy: computed(() => props.strategy),
427
438
  middleware
428
439
  }
429
440
  );
@@ -481,6 +492,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
481
492
  const init = (el) => {
482
493
  referenceEl.value = el;
483
494
  };
495
+ expose({ toggle, show, hide, init });
484
496
  watch(expanded, (newValue) => {
485
497
  if (newValue && props.autofocusFirst) {
486
498
  nextTick(() => {
@@ -1 +1 @@
1
- !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("@floating-ui/vue"),require("nanoid"),require("@vueuse/core"),require("mitt")):"function"==typeof define&&define.amd?define(["vue","@floating-ui/vue","nanoid","@vueuse/core","mitt"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvDropdown=t(e.vue,e.vue$1,e.nanoid,e.core,e.mitt)}(this,(function(e,t,o,l,r){"use strict";var n=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(n||{}),a=(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))(a||{}),u=(e=>(e.before="before",e.after="after",e))(u||{}),i=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(i||{}),d=(e=>(e.listbox="listbox",e.menu="menu",e))(d||{}),s=(e=>(e.option="option",e.presentation="presentation",e))(s||{});const f=Symbol.for("dropdownTrigger"),p=Symbol.for("dropdownItem"),c=(Boolean,Boolean,Boolean,{modifiers:[String,Array]});u.before;const v={id:[String,Number]},m={placement:{type:String,default:n.bottom,validator:e=>Object.values(n).includes(e)||Object.values(a).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},autoClose:{type:Boolean,default:!0},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean}};i.button;const b={...v,...c,...m,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:d.menu,validator:e=>Object.values(d).includes(e)}};const h=["id","tabindex","role","aria-labelledby"];return e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:b,emits:["update:modelValue"],setup(n,{emit:a}){const u=n,{id:i}=e.toRefs(u),c=(t=>e.computed((()=>String((null==t?void 0:t.value)||o.nanoid()))))(i),v=e.useAttrs(),m=e.ref("auto"),b=e.ref("auto"),g=e.ref(null),y=e.ref(null),x=e.ref(null),w=e.ref(null),S=e.computed({get:()=>u.reference??g.value,set:e=>{g.value=e}}),E=e.computed((()=>{const e=[];if(u.autoPlacement?"boolean"==typeof u.autoPlacement?e.push(t.autoPlacement()):e.push(t.autoPlacement(u.autoPlacement)):u.flip&&("boolean"==typeof u.flip?e.push(t.flip()):e.push(t.flip(u.flip))),u.shift&&("boolean"==typeof u.shift?e.push(t.shift()):e.push(t.shift(u.shift))),u.size){const o=({availableWidth:e,availableHeight:t})=>{m.value=`${e}px`,b.value=`${t}px`};"boolean"==typeof u.size?e.push(t.size({apply:o})):e.push(t.size({...u.size,apply:o}))}return u.offset&&(e.push(t.offset(Number(u.offset))),["string","number"].includes(typeof u.offset)?e.push(t.offset(Number(u.offset))):e.push(t.offset(u.offset))),u.arrow&&e.push(t.arrow({element:x})),e})),{x:k,y:$,strategy:B,middlewareData:P,placement:z}=t.useFloating(S,y,{whileElementsMounted:t.autoUpdate,placement:u.placement,middleware:E}),O=e.computed((()=>({position:B.value,top:`${$.value??0}px`,left:`${k.value??0}px`,maxWidth:m.value,maxHeight:b.value,width:u.triggerWidth&&S.value?`${S.value.offsetWidth}px`:void 0}))),V=e.computed((()=>z.value.split("-")[0])),j=e.computed((()=>({top:"bottom",right:"left",bottom:"top",left:"right"}[V.value]??"bottom"))),A=e.computed((()=>{var e,t,o,l;return["bottom","top"].includes(j.value)?{right:`${(null==(e=P.value.arrow)?void 0:e.x)??0}px`,[j.value]:-((null==(t=x.value)?void 0:t.offsetWidth)??0)/2+"px"}:{top:`${(null==(o=P.value.arrow)?void 0:o.y)??0}px`,[j.value]:-((null==(l=x.value)?void 0:l.offsetWidth)??0)/2+"px"}})),N=l.useVModel(u,"modelValue",a),D=e.ref(!1),C=e.computed({get:()=>N.value??D.value,set:e=>{void 0!==N.value?N.value=e:D.value=e}}),_=()=>{C.value=!0},R=()=>{C.value=!1},T=()=>{C.value=!C.value},W=e=>{S.value=e};e.watch(C,(t=>{t&&u.autofocusFirst&&e.nextTick((()=>{const e=L(y.value);e.length>0&&e[0].focus()}))})),l.onClickOutside(y,(()=>{u.autoClose&&(C.value=!1)}),{ignore:[S]});const q=e.computed((()=>{var e,t;return(null==(t=null==(e=S.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),F=e.computed((()=>({"aria-controls":c.value,"aria-haspopup":!0,"aria-expanded":C.value}))),{component:K,bus:H}=function({reference:t,id:o,expanded:l,aria:n}){const a=r(),u=e.defineComponent({name:"VvDropdownTriggerProvider",provide:()=>({[f]:{reference:t,id:o,expanded:l,aria:n,bus:a}}),setup:()=>({}),render(){var t,o;return e.h(e.Fragment,{},null==(o=(t=this.$slots).default)?void 0:o.call(t))}});return{bus:a,component:u}}({reference:S,id:c,expanded:C,aria:F});H.on("click",T);const{role:M,modifiers:U}=e.toRefs(u),{itemRole:I}=function({role:t,expanded:o}){const l=e.computed((()=>t.value===d.listbox?s.option:s.presentation));return e.provide(p,{role:l,expanded:o}),{itemRole:l}}({role:M,expanded:C}),G=function(t,o,l){return e.computed((()=>{const r={[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&&(r[`${t}--${e}`]=!0)})),l&&Object.keys(l.value).forEach((o=>{r[`${t}--${o}`]=e.unref(l.value[o])})),r}))}("vv-dropdown",U,e.computed((()=>({arrow:u.arrow})))),{focused:J}=l.useFocusWithin(y);function L(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"))):[]}return l.onKeyStroke("Escape",(e=>{C.value&&(e.preventDefault(),R())})),l.onKeyStroke("ArrowDown",(t=>{C.value&&J.value&&(t.preventDefault(),e.nextTick((()=>{if(J.value){const e=L(y.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus():e[0].focus()}})))})),l.onKeyStroke("ArrowUp",(t=>{C.value&&J.value&&(t.preventDefault(),e.nextTick((()=>{if(J.value){const e=L(y.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus():e[e.length-1].focus()}})))})),l.onKeyStroke([" ","Enter"],(e=>{if(C.value&&J.value){e.preventDefault();document.activeElement.click()}})),(t,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(K),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:W,show:_,hide:R,toggle:T,expanded:e.unref(C),aria:e.unref(F)})))])),_:3}),e.createVNode(e.Transition,{name:t.transitionName},{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:y,style:e.normalizeStyle(e.unref(O)),class:e.normalizeClass(e.unref(G))},[u.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:x,style:e.normalizeStyle(e.unref(A)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(C)}))),e.createElementVNode("ul",e.mergeProps(e.unref(v),{id:e.unref(c),ref_key:"listEl",ref:w,tabindex:e.unref(C)?void 0:-1,role:e.unref(M),"aria-labelledby":e.unref(q),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(I)})))],16,h),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(C)})))],6),[[e.vShow,e.unref(C)]])])),_:3},8,["name"])],64))}})}));
1
+ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("@floating-ui/vue"),require("nanoid"),require("@vueuse/core"),require("mitt")):"function"==typeof define&&define.amd?define(["vue","@floating-ui/vue","nanoid","@vueuse/core","mitt"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvDropdown=t(e.vue,e.vue$1,e.nanoid,e.core,e.mitt)}(this,(function(e,t,o,l,a){"use strict";var r=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(r||{}),n=(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))(n||{}),u=(e=>(e.before="before",e.after="after",e))(u||{}),i=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(i||{}),d=(e=>(e.listbox="listbox",e.menu="menu",e))(d||{}),s=(e=>(e.option="option",e.presentation="presentation",e))(s||{});const f=Symbol.for("dropdownTrigger"),p=Symbol.for("dropdownItem"),c=(Boolean,Boolean,Boolean,{modifiers:[String,Array]});u.before;const v={id:[String,Number]},m={placement:{type:String,default:r.bottom,validator:e=>Object.values(r).includes(e)||Object.values(n).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},autoClose:{type:Boolean,default:!0},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean}};i.button;const b={...v,...c,...m,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:d.menu,validator:e=>Object.values(d).includes(e)}};const h=["id","tabindex","role","aria-labelledby"];return e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:b,emits:["update:modelValue"],setup(r,{expose:n,emit:u}){const i=r,{id:c}=e.toRefs(i),v=(t=>e.computed((()=>String((null==t?void 0:t.value)||o.nanoid()))))(c),m=e.useAttrs(),b=e.ref("auto"),g=e.ref("auto"),y=e.ref(null),x=e.ref(null),w=e.ref(null),S=e.ref(null),E=e.computed({get:()=>i.reference??y.value,set:e=>{y.value=e}}),k=e.computed((()=>{const e=[];if(i.autoPlacement?"boolean"==typeof i.autoPlacement?e.push(t.autoPlacement()):e.push(t.autoPlacement(i.autoPlacement)):i.flip&&("boolean"==typeof i.flip?e.push(t.flip()):e.push(t.flip(i.flip))),i.shift&&("boolean"==typeof i.shift?e.push(t.shift()):e.push(t.shift(i.shift))),i.size){const o=({availableWidth:e,availableHeight:t})=>{b.value=`${e}px`,g.value=`${t}px`};"boolean"==typeof i.size?e.push(t.size({apply:o})):e.push(t.size({...i.size,apply:o}))}return i.offset&&(e.push(t.offset(Number(i.offset))),["string","number"].includes(typeof i.offset)?e.push(t.offset(Number(i.offset))):e.push(t.offset(i.offset))),i.arrow&&e.push(t.arrow({element:w})),e})),{x:$,y:B,strategy:P,middlewareData:z,placement:O}=t.useFloating(E,x,{whileElementsMounted:t.autoUpdate,placement:e.computed((()=>i.placement)),strategy:e.computed((()=>i.strategy)),middleware:k}),V=e.computed((()=>({position:P.value,top:`${B.value??0}px`,left:`${$.value??0}px`,maxWidth:b.value,maxHeight:g.value,width:i.triggerWidth&&E.value?`${E.value.offsetWidth}px`:void 0}))),j=e.computed((()=>O.value.split("-")[0])),A=e.computed((()=>({top:"bottom",right:"left",bottom:"top",left:"right"}[j.value]??"bottom"))),N=e.computed((()=>{var e,t,o,l;return["bottom","top"].includes(A.value)?{right:`${(null==(e=z.value.arrow)?void 0:e.x)??0}px`,[A.value]:-((null==(t=w.value)?void 0:t.offsetWidth)??0)/2+"px"}:{top:`${(null==(o=z.value.arrow)?void 0:o.y)??0}px`,[A.value]:-((null==(l=w.value)?void 0:l.offsetWidth)??0)/2+"px"}})),D=l.useVModel(i,"modelValue",u),C=e.ref(!1),_=e.computed({get:()=>D.value??C.value,set:e=>{void 0!==D.value?D.value=e:C.value=e}}),R=()=>{_.value=!0},T=()=>{_.value=!1},W=()=>{_.value=!_.value},q=e=>{E.value=e};n({toggle:W,show:R,hide:T,init:q}),e.watch(_,(t=>{t&&i.autofocusFirst&&e.nextTick((()=>{const e=Q(x.value);e.length>0&&e[0].focus()}))})),l.onClickOutside(x,(()=>{i.autoClose&&(_.value=!1)}),{ignore:[E]});const F=e.computed((()=>{var e,t;return(null==(t=null==(e=E.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),K=e.computed((()=>({"aria-controls":v.value,"aria-haspopup":!0,"aria-expanded":_.value}))),{component:H,bus:M}=function({reference:t,id:o,expanded:l,aria:r}){const n=a(),u=e.defineComponent({name:"VvDropdownTriggerProvider",provide:()=>({[f]:{reference:t,id:o,expanded:l,aria:r,bus:n}}),setup:()=>({}),render(){var t,o;return e.h(e.Fragment,{},null==(o=(t=this.$slots).default)?void 0:o.call(t))}});return{bus:n,component:u}}({reference:E,id:v,expanded:_,aria:K});M.on("click",W);const{role:U,modifiers:I}=e.toRefs(i),{itemRole:G}=function({role:t,expanded:o}){const l=e.computed((()=>t.value===d.listbox?s.option:s.presentation));return e.provide(p,{role:l,expanded:o}),{itemRole:l}}({role:U,expanded:_}),J=function(t,o,l){return e.computed((()=>{const a={[t]:!0},r="string"==typeof(null==o?void 0:o.value)?o.value.split(" "):null==o?void 0:o.value;return r&&Array.isArray(r)&&r.forEach((e=>{e&&(a[`${t}--${e}`]=!0)})),l&&Object.keys(l.value).forEach((o=>{a[`${t}--${o}`]=e.unref(l.value[o])})),a}))}("vv-dropdown",I,e.computed((()=>({arrow:i.arrow})))),{focused:L}=l.useFocusWithin(x);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"))):[]}return l.onKeyStroke("Escape",(e=>{_.value&&(e.preventDefault(),T())})),l.onKeyStroke("ArrowDown",(t=>{_.value&&L.value&&(t.preventDefault(),e.nextTick((()=>{if(L.value){const e=Q(x.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus():e[0].focus()}})))})),l.onKeyStroke("ArrowUp",(t=>{_.value&&L.value&&(t.preventDefault(),e.nextTick((()=>{if(L.value){const e=Q(x.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus():e[e.length-1].focus()}})))})),l.onKeyStroke([" ","Enter"],(e=>{if(_.value&&L.value){e.preventDefault();document.activeElement.click()}})),(t,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(H),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:q,show:R,hide:T,toggle:W,expanded:e.unref(_),aria:e.unref(K)})))])),_:3}),e.createVNode(e.Transition,{name:t.transitionName},{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:x,style:e.normalizeStyle(e.unref(V)),class:e.normalizeClass(e.unref(J))},[i.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:w,style:e.normalizeStyle(e.unref(N)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(_)}))),e.createElementVNode("ul",e.mergeProps(e.unref(m),{id:e.unref(v),ref_key:"listEl",ref:S,tabindex:e.unref(_)?void 0:-1,role:e.unref(U),"aria-labelledby":e.unref(F),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(G)})))],16,h),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(_)})))],6),[[e.vShow,e.unref(_)]])])),_:3},8,["name"])],64))}})}));