@volverjs/ui-vue 0.0.10-beta.28 → 0.0.10-beta.29
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +8 -7
- package/dist/components/VvAlert/VvAlert.es.js +13 -11
- package/dist/components/VvAlert/VvAlert.umd.js +1 -1
- package/dist/components/VvAlert/VvAlert.vue.d.ts +10 -10
- package/dist/components/VvAlert/index.d.ts +12 -8
- package/dist/components/VvAlertGroup/VvAlertGroup.es.js +13 -2
- package/dist/components/VvAlertGroup/VvAlertGroup.umd.js +1 -1
- package/dist/components/VvAlertGroup/VvAlertGroup.vue.d.ts +3 -3
- package/dist/components/VvAlertGroup/index.d.ts +2 -14
- package/dist/components/VvCombobox/VvCombobox.es.js +1 -0
- package/dist/components/VvCombobox/VvCombobox.umd.js +1 -1
- package/dist/components/VvDropdownOption/VvDropdownOption.es.js +1 -0
- package/dist/components/VvDropdownOption/VvDropdownOption.umd.js +1 -1
- package/dist/components/VvInputText/VvInputText.es.js +1 -0
- package/dist/components/VvInputText/VvInputText.umd.js +1 -1
- package/dist/components/index.es.js +14 -2
- package/dist/components/index.umd.js +1 -1
- package/dist/composables/alert/useAlert.d.ts +80 -18
- package/dist/composables/index.es.js +3 -2
- package/dist/composables/index.umd.js +1 -1
- package/dist/constants.d.ts +5 -2
- package/dist/icons.es.js +3 -3
- package/dist/icons.umd.js +1 -1
- package/dist/stories/AccordionGroup/AccordionGroupSlots.stories.d.ts +2 -2
- package/dist/test/expect.d.ts +1 -1
- package/dist/types/alert.d.ts +9 -7
- package/package.json +24 -34
- package/src/assets/icons/detailed.json +1 -1
- package/src/assets/icons/normal.json +1 -1
- package/src/assets/icons/simple.json +1 -1
- package/src/components/VvAlert/index.ts +13 -6
- package/src/components/VvAlertGroup/index.ts +3 -16
- package/src/components/VvDropdown/VvDropdownOption.vue +1 -0
- package/src/composables/alert/useAlert.ts +12 -9
- package/src/constants.ts +7 -2
- package/src/stories/Accordion/Accordion.test.ts +1 -1
- package/src/stories/AccordionGroup/AccordionGroup.test.ts +1 -1
- package/src/stories/Alert/Alert.test.ts +1 -1
- package/src/stories/AlertGroup/AlertGroup.test.ts +1 -1
- package/src/stories/Avatar/Avatar.test.ts +1 -1
- package/src/stories/AvatarGroup/AvatarGroup.test.ts +1 -1
- package/src/stories/Badge/Badge.test.ts +1 -1
- package/src/stories/Button/Button.test.ts +1 -1
- package/src/stories/ButtonGroup/ButtonGroup.test.ts +1 -1
- package/src/stories/Card/Card.test.ts +1 -1
- package/src/stories/Checkbox/Checkbox.test.ts +1 -1
- package/src/stories/CheckboxGroup/CheckboxGroup.test.ts +1 -1
- package/src/stories/Combobox/Combobox.test.ts +1 -1
- package/src/stories/Dialog/Dialog.test.ts +2 -2
- package/src/stories/Dropdown/Dropdown.test.ts +1 -1
- package/src/stories/InputText/InputText.test.ts +1 -1
- package/src/stories/Nav/Nav.test.ts +1 -1
- package/src/stories/Progress/Progress.test.ts +1 -1
- package/src/stories/Radio/Radio.test.ts +1 -1
- package/src/stories/RadioGroup/RadioGroup.test.ts +1 -1
- package/src/stories/Select/Select.test.ts +1 -1
- package/src/stories/Tab/Tab.test.ts +1 -1
- package/src/stories/Textarea/Textarea.test.ts +1 -1
- package/src/stories/Tooltip/Tooltip.test.ts +1 -1
- package/src/test/expect.ts +2 -4
- package/src/types/alert.ts +11 -7
package/README.md
CHANGED
|
@@ -167,27 +167,28 @@ export default defineConfig({
|
|
|
167
167
|
Used to show alert messages and notifications
|
|
168
168
|
|
|
169
169
|
```typescript
|
|
170
|
-
export type
|
|
170
|
+
export type AlertModifier =
|
|
171
171
|
| 'success'
|
|
172
172
|
| 'info'
|
|
173
173
|
| 'warning'
|
|
174
174
|
| 'danger'
|
|
175
175
|
| 'brand'
|
|
176
176
|
| 'accent'
|
|
177
|
+
| string
|
|
177
178
|
```
|
|
178
179
|
|
|
179
180
|
```typescript
|
|
180
181
|
export type Alert = {
|
|
181
182
|
id: string | number
|
|
182
|
-
group: string
|
|
183
183
|
title?: string
|
|
184
|
-
icon
|
|
184
|
+
icon?: string | VvIconProps
|
|
185
185
|
content?: string
|
|
186
186
|
footer?: string
|
|
187
|
-
modifiers
|
|
188
|
-
dismissable
|
|
189
|
-
autoClose
|
|
190
|
-
|
|
187
|
+
modifiers?: AlertModifier | AlertModifier[]
|
|
188
|
+
dismissable?: boolean
|
|
189
|
+
autoClose?: number
|
|
190
|
+
closeLabel?: string
|
|
191
|
+
role?: AlertRole
|
|
191
192
|
}
|
|
192
193
|
```
|
|
193
194
|
|
|
@@ -51,6 +51,11 @@ var ActionTag = /* @__PURE__ */ ((ActionTag2) => {
|
|
|
51
51
|
ActionTag2["button"] = "button";
|
|
52
52
|
return ActionTag2;
|
|
53
53
|
})(ActionTag || {});
|
|
54
|
+
var AlertRole = /* @__PURE__ */ ((AlertRole2) => {
|
|
55
|
+
AlertRole2["alert"] = "alert";
|
|
56
|
+
AlertRole2["alertdialog"] = "alertdialog";
|
|
57
|
+
return AlertRole2;
|
|
58
|
+
})(AlertRole || {});
|
|
54
59
|
const INJECTION_KEY_VOLVER = Symbol.for("volver");
|
|
55
60
|
const INJECTION_KEY_ALERT_GROUP = Symbol.for(
|
|
56
61
|
"alertGroup"
|
|
@@ -263,15 +268,6 @@ const LabelProps = {
|
|
|
263
268
|
default: void 0
|
|
264
269
|
}
|
|
265
270
|
};
|
|
266
|
-
const ModifiersProps = {
|
|
267
|
-
/**
|
|
268
|
-
* Component BEM modifiers
|
|
269
|
-
*/
|
|
270
|
-
modifiers: {
|
|
271
|
-
type: [String, Array],
|
|
272
|
-
default: void 0
|
|
273
|
-
}
|
|
274
|
-
};
|
|
275
271
|
const IconProps = {
|
|
276
272
|
/**
|
|
277
273
|
* VvIcon name or props
|
|
@@ -470,8 +466,14 @@ function useComponentIcon(icon, iconPosition) {
|
|
|
470
466
|
}
|
|
471
467
|
const VvAlertProps = {
|
|
472
468
|
...IdProps,
|
|
473
|
-
...ModifiersProps,
|
|
474
469
|
...IconProps,
|
|
470
|
+
/**
|
|
471
|
+
* Component BEM modifiers
|
|
472
|
+
*/
|
|
473
|
+
modifiers: {
|
|
474
|
+
type: [String, Array],
|
|
475
|
+
default: void 0
|
|
476
|
+
},
|
|
475
477
|
/**
|
|
476
478
|
* The alert is dismissable
|
|
477
479
|
* @default false
|
|
@@ -536,7 +538,7 @@ const VvAlertProps = {
|
|
|
536
538
|
*/
|
|
537
539
|
role: {
|
|
538
540
|
type: String,
|
|
539
|
-
default:
|
|
541
|
+
default: AlertRole.alert
|
|
540
542
|
}
|
|
541
543
|
};
|
|
542
544
|
const VvAlertEvents = ["close"];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
!function(e,o){"object"==typeof exports&&"undefined"!=typeof module?module.exports=o(require("vue"),require("@iconify/vue"),require("uid")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","uid"],o):(e="undefined"!=typeof globalThis?globalThis:e||self).VvAlert=o(e.vue,e.vue$1,e.uid)}(this,(function(e,o,t){"use strict";const l={prefix:"normal"};var n=(e=>(e.local="local",e.session="session",e))(n||{}),i=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(i||{}),r=(e=>(e.before="before",e.after="after",e))(r||{}),a=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(a||{}),s=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(s||{});const
|
|
1
|
+
!function(e,o){"object"==typeof exports&&"undefined"!=typeof module?module.exports=o(require("vue"),require("@iconify/vue"),require("uid")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","uid"],o):(e="undefined"!=typeof globalThis?globalThis:e||self).VvAlert=o(e.vue,e.vue$1,e.uid)}(this,(function(e,o,t){"use strict";const l={prefix:"normal"};var n=(e=>(e.local="local",e.session="session",e))(n||{}),i=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(i||{}),r=(e=>(e.before="before",e.after="after",e))(r||{}),a=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(a||{}),s=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(s||{}),u=(e=>(e.alert="alert",e.alertdialog="alertdialog",e))(u||{});const c=Symbol.for("volver"),d=Symbol.for("alertGroup");function v(o,t,l){return e.computed((()=>{const n={[o]:!0},i="string"==typeof(null==t?void 0:t.value)?t.value.split(" "):null==t?void 0:t.value;return i&&Array.isArray(i)&&i.forEach((e=>{e&&(n[`${o}--${e}`]=!0)})),l&&Object.keys(l.value).forEach((t=>{n[`${o}--${t}`]=e.unref(l.value[t])})),n}))}const f=e.defineComponent({name:"VvIcon",props:e.mergeDefaults({name:{},color:{},width:{},height:{},provider:{},prefix:{},src:{},horizontalFlip:{type:Boolean},verticalFlip:{type:Boolean},flip:{},mode:{},inline:{type:Boolean},rotate:{},onLoad:{type:Function},svg:{},modifiers:{}},l),setup(t){const l=t,n=e.computed((()=>"string"==typeof l.rotate?parseFloat(l.rotate):l.rotate)),i=e.ref(!0),r=e.inject(c),{modifiers:a}=e.toRefs(l),s=v("vv-icon",a),u=e.computed((()=>l.provider||(null==r?void 0:r.iconsProvider))),d=e.computed((()=>{const e=l.name??"",t=`@${u.value}:${l.prefix}:${e}`;if(o.iconExists(t))return t;const n=null==r?void 0:r.iconsCollections.find((t=>{const l=`@${u.value}:${t.prefix}:${e}`;return o.iconExists(l)}));return n?`@${u.value}:${n.prefix}:${e}`:e}));function f(e){const t=function(e){let o;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");o=(new e).window}return(o?new o.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),n=(null==t?void 0:t.innerHTML.trim())||"";t&&n&&o.addIcon(`@${u.value}:${l.prefix}:${l.name}`,{body:n,height:t.viewBox.baseVal.height,width:t.viewBox.baseVal.width})}return r&&l.src&&!o.iconExists(`@${u.value}:${l.prefix}:${l.name}`)&&(i.value=!1,r.fetchIcon(l.src).then((e=>{e&&(f(e),i.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),l.svg&&f(l.svg),(t,l)=>e.unref(i)?(e.openBlock(),e.createBlock(e.unref(o.Icon),e.mergeProps({key:0,class:e.unref(s)},{inline:t.inline,width:t.width,height:t.height,horizontalFlip:t.horizontalFlip,verticalFlip:t.verticalFlip,flip:t.flip,rotate:e.unref(n),color:t.color,onLoad:t.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}}),p=(Boolean,Boolean,Boolean,Boolean,{icon:{type:[String,Object],default:void 0},iconPosition:{type:String,default:r.before,validation:e=>Object.values(r).includes(e)}}),m={id:[String,Number]};i.bottom,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,a.button,s.button,n.local;const h={...m,...p,modifiers:{type:[String,Array],default:void 0},dismissable:{type:Boolean,default:!1},autoClose:{type:Number,default:0},closeLabel:{type:String,default:"Close"},title:{type:String,default:void 0},content:{type:String,default:void 0},footer:{type:String,default:void 0},role:{type:String,default:u.alert}},b=(o,l)=>{const{bus:n}=e.inject(d,{}),a=(s=e.computed((()=>o.id)),e.computed((()=>String((null==s?void 0:s.value)||t.uid()))));var s;const u=e.computed((()=>`${a.value}-title`)),{hasIcon:c}=function(o,t){const l=e.computed((()=>"string"==typeof(null==o?void 0:o.value)?{name:null==o?void 0:o.value}:null==o?void 0:o.value)),n=e.computed((()=>(null==t?void 0:t.value)===r.before?l.value:void 0)),a=e.computed((()=>(null==t?void 0:t.value)===r.after?l.value:void 0)),s=e.computed((()=>(null==t?void 0:t.value)===i.left?l.value:void 0)),u=e.computed((()=>(null==t?void 0:t.value)===i.right?l.value:void 0)),c=e.computed((()=>(null==t?void 0:t.value)===i.top?l.value:void 0)),d=e.computed((()=>(null==t?void 0:t.value)===i.bottom?l.value:void 0));return{hasIcon:l,hasIconLeft:s,hasIconRight:u,hasIconTop:c,hasIconBottom:d,hasIconBefore:n,hasIconAfter:a}}(e.computed((()=>o.icon))),f=v("vv-alert",e.computed((()=>o.modifiers)),e.computed((()=>({dismissable:o.autoClose>0||o.dismissable,"auto-close":o.autoClose>0,hover:b.value})))),p=e.computed((()=>({"--alert-duration":`${o.autoClose}ms`}))),m=()=>{h&&clearTimeout(h),l("close",a.value),null==n||n.emit("close",a.value)};let h;e.watch((()=>o.autoClose),(e=>{e>0?h=setTimeout(m,e):h&&clearTimeout(h)}),{immediate:!0});const b=e.ref(!1),y=e.withModifiers((()=>{b.value=!0,h&&clearTimeout(h)}),["passive"]),g=e.withModifiers((()=>{b.value=!1,o.autoClose>0&&(h=setTimeout(m,o.autoClose))}),["passive"]);return{close:m,hasIcon:c,hasTitleId:u,hasProps:e.computed((()=>({onMouseover:y,onMouseleave:g,class:f.value,style:p.value,role:o.role,"aria-labelledby":u.value})))}},y={key:0,class:"vv-alert__header"},g=["id"],$=["aria-label"],B=[e.createElementVNode("div",{class:"vv-alert__close-mask"},null,-1)],k={key:1,class:"vv-alert__content"},S={key:2,class:"vv-alert__footer"};return e.defineComponent({name:"VvAlert",props:h,emits:["close"],setup(o,{expose:t,emit:l}){const n=o,i=l,{hasProps:r,hasTitleId:a,hasIcon:s,close:u}=b(n,i);return t({close:u}),(o,t)=>(e.openBlock(),e.createElementBlock("div",e.normalizeProps(e.guardReactiveProps(e.unref(r))),[o.$slots.header||o.$slots.title||o.$slots.close||o.$slots["title::before"]||o.$slots["title::after"]||o.title||o.dismissable||o.autoClose?(e.openBlock(),e.createElementBlock("div",y,[e.unref(s)?(e.openBlock(),e.createBlock(f,e.mergeProps({key:0},e.unref(s),{class:"vv-alert__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.renderSlot(o.$slots,"header",{},(()=>[e.renderSlot(o.$slots,"title::before"),o.$slots.title||o.title?(e.openBlock(),e.createElementBlock("strong",{key:0,id:e.unref(a),class:"vv-alert__title"},[e.renderSlot(o.$slots,"title",{},(()=>[e.createTextVNode(e.toDisplayString(o.title),1)]))],8,g)):e.createCommentVNode("v-if",!0),e.renderSlot(o.$slots,"title::after")])),e.renderSlot(o.$slots,"close",e.normalizeProps(e.guardReactiveProps({close:e.unref(u)})),(()=>[o.dismissable||o.autoClose?(e.openBlock(),e.createElementBlock("button",{key:0,class:"vv-alert__close",type:"button","aria-label":o.closeLabel,onClick:t[0]||(t[0]=e.withModifiers(((...o)=>e.unref(u)&&e.unref(u)(...o)),["stop"]))},B,8,$)):e.createCommentVNode("v-if",!0)]))])):e.createCommentVNode("v-if",!0),o.$slots.default||o.content?(e.openBlock(),e.createElementBlock("div",k,[e.renderSlot(o.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(o.content),1)]))])):e.createCommentVNode("v-if",!0),o.$slots.footer||o.footer?(e.openBlock(),e.createElementBlock("div",S,[e.renderSlot(o.$slots,"footer",{},(()=>[e.createTextVNode(e.toDisplayString(o.footer),1)]))])):e.createCommentVNode("v-if",!0)],16))}})}));
|
|
@@ -1,4 +1,8 @@
|
|
|
1
1
|
declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
2
|
+
modifiers: {
|
|
3
|
+
type: globalThis.PropType<string | string[]>;
|
|
4
|
+
default: undefined;
|
|
5
|
+
};
|
|
2
6
|
dismissable: {
|
|
3
7
|
type: BooleanConstructor;
|
|
4
8
|
default: boolean;
|
|
@@ -25,7 +29,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
25
29
|
};
|
|
26
30
|
role: {
|
|
27
31
|
type: globalThis.PropType<"alert" | "alertdialog">;
|
|
28
|
-
default:
|
|
32
|
+
default: import("../../constants.js").AlertRole;
|
|
29
33
|
};
|
|
30
34
|
icon: {
|
|
31
35
|
type: globalThis.PropType<string | import("../VvIcon/index.js").VvIconProps>;
|
|
@@ -36,16 +40,16 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
36
40
|
default: import("../../constants.js").Position;
|
|
37
41
|
validation: (value: import("../../constants.js").Position) => boolean;
|
|
38
42
|
};
|
|
39
|
-
modifiers: {
|
|
40
|
-
type: globalThis.PropType<string | string[]>;
|
|
41
|
-
default: undefined;
|
|
42
|
-
};
|
|
43
43
|
id: (StringConstructor | NumberConstructor)[];
|
|
44
44
|
}, {
|
|
45
45
|
close: () => void;
|
|
46
46
|
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
|
47
47
|
[x: string]: (...args: any[]) => void;
|
|
48
48
|
}, string, import("vue").PublicProps, Readonly<globalThis.ExtractPropTypes<{
|
|
49
|
+
modifiers: {
|
|
50
|
+
type: globalThis.PropType<string | string[]>;
|
|
51
|
+
default: undefined;
|
|
52
|
+
};
|
|
49
53
|
dismissable: {
|
|
50
54
|
type: BooleanConstructor;
|
|
51
55
|
default: boolean;
|
|
@@ -72,7 +76,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
72
76
|
};
|
|
73
77
|
role: {
|
|
74
78
|
type: globalThis.PropType<"alert" | "alertdialog">;
|
|
75
|
-
default:
|
|
79
|
+
default: import("../../constants.js").AlertRole;
|
|
76
80
|
};
|
|
77
81
|
icon: {
|
|
78
82
|
type: globalThis.PropType<string | import("../VvIcon/index.js").VvIconProps>;
|
|
@@ -83,10 +87,6 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
83
87
|
default: import("../../constants.js").Position;
|
|
84
88
|
validation: (value: import("../../constants.js").Position) => boolean;
|
|
85
89
|
};
|
|
86
|
-
modifiers: {
|
|
87
|
-
type: globalThis.PropType<string | string[]>;
|
|
88
|
-
default: undefined;
|
|
89
|
-
};
|
|
90
90
|
id: (StringConstructor | NumberConstructor)[];
|
|
91
91
|
}>>, {
|
|
92
92
|
title: string;
|
|
@@ -1,5 +1,13 @@
|
|
|
1
|
-
import type
|
|
1
|
+
import { type ExtractPropTypes, type PropType } from 'vue';
|
|
2
|
+
import { AlertRole } from '@/constants';
|
|
2
3
|
export declare const VvAlertProps: {
|
|
4
|
+
/**
|
|
5
|
+
* Component BEM modifiers
|
|
6
|
+
*/
|
|
7
|
+
modifiers: {
|
|
8
|
+
type: PropType<string | string[]>;
|
|
9
|
+
default: undefined;
|
|
10
|
+
};
|
|
3
11
|
/**
|
|
4
12
|
* The alert is dismissable
|
|
5
13
|
* @default false
|
|
@@ -64,7 +72,7 @@ export declare const VvAlertProps: {
|
|
|
64
72
|
*/
|
|
65
73
|
role: {
|
|
66
74
|
type: PropType<"alert" | "alertdialog">;
|
|
67
|
-
default:
|
|
75
|
+
default: AlertRole;
|
|
68
76
|
};
|
|
69
77
|
icon: {
|
|
70
78
|
type: PropType<string | import("../VvIcon").VvIconProps>;
|
|
@@ -72,12 +80,8 @@ export declare const VvAlertProps: {
|
|
|
72
80
|
};
|
|
73
81
|
iconPosition: {
|
|
74
82
|
type: PropType<"before" | "after">;
|
|
75
|
-
default: import("
|
|
76
|
-
validation: (value: import("
|
|
77
|
-
};
|
|
78
|
-
modifiers: {
|
|
79
|
-
type: PropType<string | string[]>;
|
|
80
|
-
default: undefined;
|
|
83
|
+
default: import("@/constants").Position;
|
|
84
|
+
validation: (value: import("@/constants").Position) => boolean;
|
|
81
85
|
};
|
|
82
86
|
id: (StringConstructor | NumberConstructor)[];
|
|
83
87
|
};
|
|
@@ -48,6 +48,11 @@ var ActionTag = /* @__PURE__ */ ((ActionTag2) => {
|
|
|
48
48
|
ActionTag2["button"] = "button";
|
|
49
49
|
return ActionTag2;
|
|
50
50
|
})(ActionTag || {});
|
|
51
|
+
var AlertRole = /* @__PURE__ */ ((AlertRole2) => {
|
|
52
|
+
AlertRole2["alert"] = "alert";
|
|
53
|
+
AlertRole2["alertdialog"] = "alertdialog";
|
|
54
|
+
return AlertRole2;
|
|
55
|
+
})(AlertRole || {});
|
|
51
56
|
const INJECTION_KEY_VOLVER = Symbol.for("volver");
|
|
52
57
|
const INJECTION_KEY_ALERT_GROUP = Symbol.for(
|
|
53
58
|
"alertGroup"
|
|
@@ -583,8 +588,14 @@ function useComponentIcon(icon, iconPosition) {
|
|
|
583
588
|
}
|
|
584
589
|
const VvAlertProps = {
|
|
585
590
|
...IdProps,
|
|
586
|
-
...ModifiersProps,
|
|
587
591
|
...IconProps,
|
|
592
|
+
/**
|
|
593
|
+
* Component BEM modifiers
|
|
594
|
+
*/
|
|
595
|
+
modifiers: {
|
|
596
|
+
type: [String, Array],
|
|
597
|
+
default: void 0
|
|
598
|
+
},
|
|
588
599
|
/**
|
|
589
600
|
* The alert is dismissable
|
|
590
601
|
* @default false
|
|
@@ -649,7 +660,7 @@ const VvAlertProps = {
|
|
|
649
660
|
*/
|
|
650
661
|
role: {
|
|
651
662
|
type: String,
|
|
652
|
-
default:
|
|
663
|
+
default: AlertRole.alert
|
|
653
664
|
}
|
|
654
665
|
};
|
|
655
666
|
const VvAlertEvents = ["close"];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
!function(e,
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("mitt"),require("@iconify/vue"),require("uid")):"function"==typeof define&&define.amd?define(["vue","mitt","@iconify/vue","uid"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvAlertGroup=t(e.vue,e.mitt,e.vue$1,e.uid)}(this,(function(e,t,o,l){"use strict";var r=(e=>(e.local="local",e.session="session",e))(r||{}),n=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(n||{}),a=(e=>(e.before="before",e.after="after",e))(a||{}),i=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(i||{}),s=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(s||{}),u=(e=>(e.alert="alert",e.alertdialog="alertdialog",e))(u||{});const c=Symbol.for("volver"),d=Symbol.for("alertGroup"),v=(Boolean,Boolean,Boolean,Boolean,{modifiers:{type:[String,Array],default:void 0}}),f={icon:{type:[String,Object],default:void 0},iconPosition:{type:String,default:a.before,validation:e=>Object.values(a).includes(e)}},p={id:[String,Number]};function m(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}))}n.bottom,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,i.button,s.button,r.local;const b={...v,name:{type:String,required:!0},items:{type:Array,default:()=>[]},stack:{type:Boolean,default:!1},reverse:{type:Boolean,default:!1},inline:{type:String,default:void 0},block:{type:String,default:void 0},position:{type:String,default:void 0},transition:{type:String,default:void 0}},h=(o,l)=>{const r=function({name:o}){const l=t();return e.provide(d,{name:o,bus:l}),l}({name:e.computed((()=>o.name))});(o.block&&!o.inline||!o.block&&o.inline)&&console.warn("[VvAlertGroup]: block and inline props must coexist at the same time.");const n=e.computed((()=>{const t=[m("vv-alert-group",e.computed((()=>o.modifiers)),e.computed((()=>({stack:o.stack,reverse:o.reverse,absolute:"absolute"===o.position,fixed:"fixed"===o.position})))).value];return o.inline&&o.block&&t.push(`vv-alert-group--${o.block}-${o.inline}`),t})),a=e.computed((()=>o.transition?o.transition:o.position?"start"===o.inline?"vv-alert--fade-inline-start":"end"===o.inline?"vv-alert--fade-inline-end":"top"===o.block?"vv-alert--fade-block-top":"bottom"===o.block?"vv-alert--fade-block-bottom":"vv-alert--fade":"vv-alert--fade"));return r.on("close",(e=>{l("close",e)})),{hasTransition:a,hasProps:e.computed((()=>({class:n.value})))}},g={prefix:"normal"};const y=e.defineComponent({name:"VvIcon",props:e.mergeDefaults({name:{},color:{},width:{},height:{},provider:{},prefix:{},src:{},horizontalFlip:{type:Boolean},verticalFlip:{type:Boolean},flip:{},mode:{},inline:{type:Boolean},rotate:{},onLoad:{type:Function},svg:{},modifiers:{}},g),setup(t){const l=t,r=e.computed((()=>"string"==typeof l.rotate?parseFloat(l.rotate):l.rotate)),n=e.ref(!0),a=e.inject(c),{modifiers:i}=e.toRefs(l),s=m("vv-icon",i),u=e.computed((()=>l.provider||(null==a?void 0:a.iconsProvider))),d=e.computed((()=>{const e=l.name??"",t=`@${u.value}:${l.prefix}:${e}`;if(o.iconExists(t))return t;const r=null==a?void 0:a.iconsCollections.find((t=>{const l=`@${u.value}:${t.prefix}:${e}`;return o.iconExists(l)}));return r?`@${u.value}:${r.prefix}:${e}`:e}));function v(e){const t=function(e){let t;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");t=(new e).window}return(t?new t.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),r=(null==t?void 0:t.innerHTML.trim())||"";t&&r&&o.addIcon(`@${u.value}:${l.prefix}:${l.name}`,{body:r,height:t.viewBox.baseVal.height,width:t.viewBox.baseVal.width})}return a&&l.src&&!o.iconExists(`@${u.value}:${l.prefix}:${l.name}`)&&(n.value=!1,a.fetchIcon(l.src).then((e=>{e&&(v(e),n.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),l.svg&&v(l.svg),(t,l)=>e.unref(n)?(e.openBlock(),e.createBlock(e.unref(o.Icon),e.mergeProps({key:0,class:e.unref(s)},{inline:t.inline,width:t.width,height:t.height,horizontalFlip:t.horizontalFlip,verticalFlip:t.verticalFlip,flip:t.flip,rotate:e.unref(r),color:t.color,onLoad:t.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}});const k={...p,...f,modifiers:{type:[String,Array],default:void 0},dismissable:{type:Boolean,default:!1},autoClose:{type:Number,default:0},closeLabel:{type:String,default:"Close"},title:{type:String,default:void 0},content:{type:String,default:void 0},footer:{type:String,default:void 0},role:{type:String,default:u.alert}},B=(t,o)=>{const{bus:r}=e.inject(d,{}),i=(s=e.computed((()=>t.id)),e.computed((()=>String((null==s?void 0:s.value)||l.uid()))));var s;const u=e.computed((()=>`${i.value}-title`)),{hasIcon:c}=function(t,o){const l=e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),r=e.computed((()=>(null==o?void 0:o.value)===a.before?l.value:void 0)),i=e.computed((()=>(null==o?void 0:o.value)===a.after?l.value:void 0)),s=e.computed((()=>(null==o?void 0:o.value)===n.left?l.value:void 0)),u=e.computed((()=>(null==o?void 0:o.value)===n.right?l.value:void 0)),c=e.computed((()=>(null==o?void 0:o.value)===n.top?l.value:void 0)),d=e.computed((()=>(null==o?void 0:o.value)===n.bottom?l.value:void 0));return{hasIcon:l,hasIconLeft:s,hasIconRight:u,hasIconTop:c,hasIconBottom:d,hasIconBefore:r,hasIconAfter:i}}(e.computed((()=>t.icon))),v=m("vv-alert",e.computed((()=>t.modifiers)),e.computed((()=>({dismissable:t.autoClose>0||t.dismissable,"auto-close":t.autoClose>0,hover:h.value})))),f=e.computed((()=>({"--alert-duration":`${t.autoClose}ms`}))),p=()=>{b&&clearTimeout(b),o("close",i.value),null==r||r.emit("close",i.value)};let b;e.watch((()=>t.autoClose),(e=>{e>0?b=setTimeout(p,e):b&&clearTimeout(b)}),{immediate:!0});const h=e.ref(!1),g=e.withModifiers((()=>{h.value=!0,b&&clearTimeout(b)}),["passive"]),y=e.withModifiers((()=>{h.value=!1,t.autoClose>0&&(b=setTimeout(p,t.autoClose))}),["passive"]);return{close:p,hasIcon:c,hasTitleId:u,hasProps:e.computed((()=>({onMouseover:g,onMouseleave:y,class:v.value,style:f.value,role:t.role,"aria-labelledby":u.value})))}},$={key:0,class:"vv-alert__header"},S=["id"],x=["aria-label"],w=[e.createElementVNode("div",{class:"vv-alert__close-mask"},null,-1)],C={key:1,class:"vv-alert__content"},V={key:2,class:"vv-alert__footer"},P=e.defineComponent({name:"VvAlert",props:k,emits:["close"],setup(t,{expose:o,emit:l}){const r=t,n=l,{hasProps:a,hasTitleId:i,hasIcon:s,close:u}=B(r,n);return o({close:u}),(t,o)=>(e.openBlock(),e.createElementBlock("div",e.normalizeProps(e.guardReactiveProps(e.unref(a))),[t.$slots.header||t.$slots.title||t.$slots.close||t.$slots["title::before"]||t.$slots["title::after"]||t.title||t.dismissable||t.autoClose?(e.openBlock(),e.createElementBlock("div",$,[e.unref(s)?(e.openBlock(),e.createBlock(y,e.mergeProps({key:0},e.unref(s),{class:"vv-alert__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"header",{},(()=>[e.renderSlot(t.$slots,"title::before"),t.$slots.title||t.title?(e.openBlock(),e.createElementBlock("strong",{key:0,id:e.unref(i),class:"vv-alert__title"},[e.renderSlot(t.$slots,"title",{},(()=>[e.createTextVNode(e.toDisplayString(t.title),1)]))],8,S)):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"title::after")])),e.renderSlot(t.$slots,"close",e.normalizeProps(e.guardReactiveProps({close:e.unref(u)})),(()=>[t.dismissable||t.autoClose?(e.openBlock(),e.createElementBlock("button",{key:0,class:"vv-alert__close",type:"button","aria-label":t.closeLabel,onClick:o[0]||(o[0]=e.withModifiers(((...t)=>e.unref(u)&&e.unref(u)(...t)),["stop"]))},w,8,x)):e.createCommentVNode("v-if",!0)]))])):e.createCommentVNode("v-if",!0),t.$slots.default||t.content?(e.openBlock(),e.createElementBlock("div",C,[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.content),1)]))])):e.createCommentVNode("v-if",!0),t.$slots.footer||t.footer?(e.openBlock(),e.createElementBlock("div",V,[e.renderSlot(t.$slots,"footer",{},(()=>[e.createTextVNode(e.toDisplayString(t.footer),1)]))])):e.createCommentVNode("v-if",!0)],16))}});return e.defineComponent({name:"VvAlertGroup",props:b,emits:["close","before-enter","after-leave","enter","after-enter","enter-cancelled","before-leave","leave","leave-cancelled"],setup(t,{emit:o}){const l=t,r=o,{hasProps:n,hasTransition:a}=h(l,r),i={"before-enter":()=>{r("before-enter")},"after-leave":()=>{r("after-leave")},enter:()=>{r("enter")},"after-enter":()=>{r("after-enter")},"enter-cancelled":()=>{r("enter-cancelled")},"before-leave":()=>{r("before-leave")},leave:()=>{r("leave")},"leave-cancelled":()=>{r("leave-cancelled")}};return(t,o)=>(e.openBlock(),e.createElementBlock("div",e.normalizeProps(e.guardReactiveProps(e.unref(n))),[e.renderSlot(t.$slots,"before"),e.createVNode(e.TransitionGroup,e.mergeProps({tag:"div",role:"group",name:e.unref(a),class:"vv-alert-group__list"},e.toHandlers(i)),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.items,(t=>(e.openBlock(),e.createBlock(P,e.mergeProps(t,{key:t.id}),null,16)))),128))]))])),_:3},16,["name"]),e.renderSlot(t.$slots,"after")],16))}})}));
|
|
@@ -4,7 +4,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
4
4
|
required: boolean;
|
|
5
5
|
};
|
|
6
6
|
items: {
|
|
7
|
-
type: globalThis.PropType<import("
|
|
7
|
+
type: globalThis.PropType<import("../..").Alert[]>;
|
|
8
8
|
default: () => never[];
|
|
9
9
|
};
|
|
10
10
|
stack: {
|
|
@@ -43,7 +43,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
43
43
|
required: boolean;
|
|
44
44
|
};
|
|
45
45
|
items: {
|
|
46
|
-
type: globalThis.PropType<import("
|
|
46
|
+
type: globalThis.PropType<import("../..").Alert[]>;
|
|
47
47
|
default: () => never[];
|
|
48
48
|
};
|
|
49
49
|
stack: {
|
|
@@ -77,7 +77,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
77
77
|
}>>, {
|
|
78
78
|
modifiers: string | string[];
|
|
79
79
|
reverse: boolean;
|
|
80
|
-
items: import("
|
|
80
|
+
items: import("../..").Alert[];
|
|
81
81
|
transition: string;
|
|
82
82
|
inline: "start" | "end" | "middle";
|
|
83
83
|
stack: boolean;
|
|
@@ -1,24 +1,12 @@
|
|
|
1
1
|
import type { ExtractPropTypes } from 'vue';
|
|
2
|
-
import type {
|
|
3
|
-
export type AlertItem = {
|
|
4
|
-
id: string | number;
|
|
5
|
-
title?: string;
|
|
6
|
-
icon?: string | VvIconProps;
|
|
7
|
-
content?: string;
|
|
8
|
-
footer?: string;
|
|
9
|
-
modifiers?: string | string[];
|
|
10
|
-
dismissable?: boolean;
|
|
11
|
-
autoClose?: number;
|
|
12
|
-
closeLabel?: string;
|
|
13
|
-
role?: 'alert' | 'alertdialog';
|
|
14
|
-
};
|
|
2
|
+
import type { Alert } from '@/types';
|
|
15
3
|
export declare const VvAlertGroupProps: {
|
|
16
4
|
name: {
|
|
17
5
|
type: StringConstructor;
|
|
18
6
|
required: boolean;
|
|
19
7
|
};
|
|
20
8
|
items: {
|
|
21
|
-
type: globalThis.PropType<
|
|
9
|
+
type: globalThis.PropType<Alert[]>;
|
|
22
10
|
default: () => never[];
|
|
23
11
|
};
|
|
24
12
|
stack: {
|
|
@@ -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("uid"),require("@vueuse/core"),require("mitt"),require("ts-dot-prop")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","@floating-ui/vue","uid","@vueuse/core","mitt","ts-dot-prop"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvCombobox=t(e.vue,e.vue$1,e.vue$2,e.uid,e.core,e.mitt,e.tsDotProp)}(this,(function(e,t,l,o,a,n,r){"use strict";var i=(e=>(e.local="local",e.session="session",e))(i||{}),u=(e=>(e.absolute="absolute",e.fixed="fixed",e))(u||{}),d=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(d||{}),s=(e=>(e.topStart="top-start",e.topEnd="top-end",e.bottomStart="bottom-start",e.bottomEnd="bottom-end",e.leftStart="left-start",e.leftEnd="left-end",e.rightStart="right-start",e.rightEnd="right-end",e))(s||{}),c=(e=>(e.before="before",e.after="after",e))(c||{}),v=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(v||{}),f=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(f||{}),p=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(p||{}),m=(e=>(e.listbox="listbox",e.menu="menu",e))(m||{}),b=(e=>(e.option="option",e.presentation="presentation",e))(b||{});const g=Symbol.for("volver"),y=Symbol.for("buttonGroup"),h=Symbol.for("dropdownTrigger"),k=Symbol.for("dropdownItem"),S=Symbol.for("dropdownAction"),B={to:{type:[String,Object]},href:String,target:String,rel:{type:String,default:"noopener noreferrer"}},V={valid:{type:Boolean,default:!1},validLabel:{type:[String,Array],default:void 0}},x={invalid:{type:Boolean,default:!1},invalidLabel:{type:[String,Array],default:void 0}},w={loading:{type:Boolean,default:!1},loadingLabel:{type:String,default:"Loading..."}},L={disabled:{type:Boolean,default:!1}},P={selected:{type:Boolean,default:!1}},$={active:{type:Boolean,default:!1}},C={current:{type:Boolean,default:!1}},O={pressed:{type:Boolean,default:!1}},E={label:{type:[String,Number],default:void 0}},_={readonly:{type:Boolean,default:!1}},N={modifiers:{type:[String,Array],default:void 0}},A={hintLabel:{type:String,default:""}},D={options:{type:Array,default:()=>[]},labelKey:{type:[String,Function],default:"label"},valueKey:{type:[String,Function],default:"value"},disabledKey:{type:[String,Function],default:"disabled"}},R={icon:{type:[String,Object],default:void 0},iconPosition:{type:String,default:c.before,validation:e=>Object.values(c).includes(e)}},j={tabindex:{type:[String,Number],default:0}},F={floating:{type:Boolean,default:!1}},z={unselectable:{type:Boolean,default:!0}},H={id:[String,Number]},I={placement:{type:String,default:d.bottom,validator:e=>Object.values(d).includes(e)||Object.values(s).includes(e)},strategy:{type:String,default:void 0,validator:e=>Object.values(u).includes(e)},transitionName:{type:String,default:void 0},offset:{type:[Number,String,Object],default:0},shift:{type:[Boolean,Object],default:!1},flip:{type:[Boolean,Object],default:!0},size:{type:[Boolean,Object],default:()=>({padding:10})},autoPlacement:{type:[Boolean,Object],default:!1},arrow:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean,default:!1}},T={...H,name:{type:String,required:!0}},M={autofocus:{type:Boolean,default:!1}},K={autocomplete:{type:String,default:"off"}},q={...L,...E,...O,...$,...C,...B,type:{type:String,default:v.button,validator:e=>Object.values(v).includes(e)},ariaLabel:{type:String,default:void 0},defaultTag:{type:String,default:f.button}};i.local;const W={...T,...j,...V,...x,...A,...w,...L,..._,...N,...D,...R,...F,...z,...I,...E,transitionName:{type:String,default:"vv-dropdown--mobile-fade-block"},modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},noResultsLabel:{type:String,default:"No results"},noOptionsLabel:{type:String,default:"No options available"},selectedHintLabel:{type:String,default:"Selected"},deselectActionLabel:{type:String,default:"Deselect"},selectHintLabel:{type:String,default:"Press enter to select"},deselectHintLabel:{type:String,default:"Press enter to remove"},closeLabel:{type:String,default:"Close"},placeholder:String,searchable:Boolean,searchFunction:{type:Function,default:void 0},searchPlaceholder:{type:String,default:"Search..."},debounceSearch:{type:[Number,String],default:0},multiple:Boolean,maxValues:[Number,String],separator:{type:String,default:", "},native:Boolean,badges:Boolean,badgeModifiers:{type:[String,Array],default:"action sm"},triggerWidth:{...I.triggerWidth,default:!0},dropdownModifiers:{type:[String,Array],default:"mobile"},autoOpen:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1}},G={prefix:"normal"};function U(){return e.inject(g)}function J(t,l,o){return e.computed((()=>{const a={[t]:!0},n="string"==typeof(null==l?void 0:l.value)?l.value.split(" "):null==l?void 0:l.value;return n&&Array.isArray(n)&&n.forEach((e=>{e&&(a[`${t}--${e}`]=!0)})),o&&Object.keys(o.value).forEach((l=>{a[`${t}--${l}`]=e.unref(o.value[l])})),a}))}const Q=e.defineComponent({name:"VvIcon",props:e.mergeDefaults({name:{},color:{},width:{},height:{},provider:{},prefix:{},src:{},horizontalFlip:{type:Boolean},verticalFlip:{type:Boolean},flip:{},mode:{},inline:{type:Boolean},rotate:{},onLoad:{type:Function},svg:{},modifiers:{}},G),setup(l){const o=l,a=e.computed((()=>"string"==typeof o.rotate?parseFloat(o.rotate):o.rotate)),n=e.ref(!0),r=U(),{modifiers:i}=e.toRefs(o),u=J("vv-icon",i),d=e.computed((()=>o.provider||(null==r?void 0:r.iconsProvider))),s=e.computed((()=>{const e=o.name??"",l=`@${d.value}:${o.prefix}:${e}`;if(t.iconExists(l))return l;const a=null==r?void 0:r.iconsCollections.find((l=>{const o=`@${d.value}:${l.prefix}:${e}`;return t.iconExists(o)}));return a?`@${d.value}:${a.prefix}:${e}`:e}));function c(e){const l=function(e){let t;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");t=(new e).window}return(t?new t.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),a=(null==l?void 0:l.innerHTML.trim())||"";l&&a&&t.addIcon(`@${d.value}:${o.prefix}:${o.name}`,{body:a,height:l.viewBox.baseVal.height,width:l.viewBox.baseVal.width})}return r&&o.src&&!t.iconExists(`@${d.value}:${o.prefix}:${o.name}`)&&(n.value=!1,r.fetchIcon(o.src).then((e=>{e&&(c(e),n.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),o.svg&&c(o.svg),(l,o)=>e.unref(n)?(e.openBlock(),e.createBlock(e.unref(t.Icon),e.mergeProps({key:0,class:e.unref(u)},{inline:l.inline,width:l.width,height:l.height,horizontalFlip:l.horizontalFlip,verticalFlip:l.verticalFlip,flip:l.flip,rotate:e.unref(a),color:l.color,onLoad:l.onLoad,icon:e.unref(s)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}}),X={...H,...I,...N,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:m.menu,validator:e=>Object.values(m).includes(e)}},Y={focusOnHover:{type:Boolean,default:!1}},Z={...L,...P,...z,...N,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String},focusOnHover:{type:Boolean,default:!1}},ee=t=>e.computed((()=>String((null==t?void 0:t.value)||o.uid())));const te=["id","tabindex","role","aria-labelledby"],le=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:X,emits:["update:modelValue","beforeExpand","beforeCollapse","afterExpand","afterCollapse","before-enter","after-leave","enter","after-enter","enter-cancelled","before-leave","leave","leave-cancelled"],setup(t,{expose:o,emit:r}){const i=t,s=r,{id:c}=e.toRefs(i),v=ee(c),f=e.useAttrs(),p=e.ref("auto"),g=e.ref("auto"),y=e.ref(null),S=e.ref(),B=e.ref(null),V=e.ref(null),x=e.computed({get:()=>i.reference??y.value,set:e=>{y.value=e}}),w=e.ref(!1);e.onMounted((()=>{a.useMutationObserver(S.value,(()=>{var e;w.value="true"===(null==(e=window.getComputedStyle(S.value).getPropertyValue("--dropdown-custom-position"))?void 0:e.trim())}),{attributeFilter:["style"],window:window})}));const L=e.computed((()=>{const e=[];if(i.autoPlacement?"boolean"==typeof i.autoPlacement?e.push(l.autoPlacement()):e.push(l.autoPlacement(i.autoPlacement)):i.flip&&("boolean"==typeof i.flip?e.push(l.flip({fallbackStrategy:"initialPlacement"})):e.push(l.flip(i.flip))),i.shift&&("boolean"==typeof i.shift?e.push(l.shift()):e.push(l.shift(i.shift))),i.size){const t=({availableWidth:e,availableHeight:t})=>{p.value=`${e}px`,g.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:B})),e})),{x:P,y:$,middlewareData:C,placement:O,strategy:E}=l.useFloating(x,S,{whileElementsMounted:(...e)=>l.autoUpdate(...e,{animationFrame:i.strategy===u.fixed}),placement:e.computed((()=>i.placement)),strategy:e.computed((()=>i.strategy)),middleware:L}),_=e.computed((()=>{var e;if(w.value)return;const t=i.triggerWidth&&x.value?`${null==(e=x.value)?void 0:e.offsetWidth}px`:void 0;return{position:E.value,top:`${$.value??0}px`,left:`${P.value??0}px`,maxWidth:t?void 0:p.value,maxHeight:g.value,width:t}})),N=e.computed((()=>O.value.split("-")[0])),A=e.computed((()=>{var e,t,l,o,a;if(w.value)return;const n={[d.top]:d.bottom,[d.right]:d.left,[d.bottom]:d.top,[d.left]:d.right}[N.value];return{left:void 0!==(null==(e=C.value.arrow)?void 0:e.x)?`${null==(t=C.value.arrow)?void 0:t.x}px`:void 0,top:void 0!==(null==(l=C.value.arrow)?void 0:l.y)?`${null==(o=C.value.arrow)?void 0:o.y}px`:void 0,[n]:-((null==(a=B.value)?void 0:a.offsetWidth)??0)/2+"px"}})),D=a.useVModel(i,"modelValue",s),R=e.ref(!1),j=e.computed({get:()=>D.value??R.value,set:e=>{void 0!==D.value?D.value=e:R.value=e}}),F=()=>{j.value=!0},z=()=>{j.value=!1},H=()=>{j.value=!j.value},I=e=>{x.value=e};o({toggle:H,show:F,hide:z,init:I,customPosition:w}),e.watch(j,(t=>{t&&i.autofocusFirst&&e.nextTick((()=>{const e=X(S.value);e.length>0&&e[0].focus({preventScroll:!0})}))})),a.onClickOutside(S,(()=>{!i.keepOpen&&j.value&&(j.value=!1)}),{ignore:[x]});const T=e.computed((()=>{var e,t;return(null==(t=null==(e=x.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),M=e.computed((()=>({"aria-controls":v.value,"aria-haspopup":!0,"aria-expanded":j.value}))),{component:K,bus:q}=function({reference:t,id:l,expanded:o,aria:a}){const r=n(),i=e.defineComponent({name:"VvDropdownTriggerProvider",setup(){e.provide(h,{reference:t,id:l,expanded:o,aria:a,bus:r})},render(){var t,l;return e.h(e.Fragment,{},null==(l=(t=this.$slots).default)?void 0:l.call(t))}});return{bus:r,component:i}}({reference:x,id:v,expanded:j,aria:M});q.on("click",H);const{role:W,modifiers:G}=e.toRefs(i),U=J("vv-dropdown",G,e.computed((()=>({arrow:i.arrow})))),{focused:Q}=a.useFocusWithin(S);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"))):[]}const Y=a.useElementHover(S),{itemRole:Z}=function({role:t,...l}){const o=e.computed((()=>t.value===m.listbox?b.option:b.presentation));return e.provide(k,{role:o,...l}),{itemRole:o}}({role:W,expanded:j,focused:Q,hovered:Y});a.onKeyStroke("Escape",(e=>{j.value&&(e.preventDefault(),z())})),a.onKeyStroke("ArrowDown",(t=>{j.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=X(S.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus({preventScroll:!0}):e[0].focus({preventScroll:!0})}})))})),a.onKeyStroke("ArrowUp",(t=>{j.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=X(S.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus({preventScroll:!0}):e[e.length-1].focus({preventScroll:!0})}})))})),a.onKeyStroke([" ","Enter"],(e=>{const t=e.target;j.value&&Q.value&&t&&(null==t||t.click())}));const le={"before-enter":()=>{s(j.value?"beforeExpand":"beforeCollapse"),s("before-enter")},"after-leave":()=>{s(j.value?"afterExpand":"afterCollapse"),s("after-leave")},enter:()=>{s("enter")},"after-enter":()=>{s("after-enter")},"enter-cancelled":()=>{s("enter-cancelled")},"before-leave":()=>{s("before-leave")},leave:()=>{s("leave")},"leave-cancelled":()=>{s("leave-cancelled")}};return(t,l)=>(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:I,show:F,hide:z,toggle:H,expanded:e.unref(j),aria:e.unref(M)})))])),_:3}),e.createVNode(e.Transition,e.mergeProps({name:t.transitionName},e.toHandlers(le),{persisted:""}),{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:S,style:e.normalizeStyle(e.unref(_)),class:e.normalizeClass(e.unref(U))},[i.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:B,style:e.normalizeStyle(e.unref(A)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(j)}))),e.createElementVNode("div",e.mergeProps(e.unref(f),{id:e.unref(v),ref_key:"listEl",ref:V,tabindex:e.unref(j)?void 0:-1,role:e.unref(W),"aria-labelledby":e.unref(T),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(Z)})))],16,te),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(j)})))],6),[[e.vShow,e.unref(j)]])])),_:3},16,["name"])],64))}});const oe=e.defineComponent({name:"VvDropdownItem",props:Y,setup(t){const l=t,{role:o,expanded:n}=e.inject(k,{}),r=e.ref(null);!function({expanded:t}){e.provide(S,{role:e.ref(p.menuitem),expanded:t})}({expanded:n});const i=a.useElementHover(r),{focused:u}=a.useFocus(r),{focused:d}=a.useFocusWithin(r);return e.watch(i,(e=>{e&&l.focusOnHover&&(u.value=!0)})),(t,l)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({role:e.unref(o)},{ref_key:"element",ref:r,class:["vv-dropdown__item",{"focus-visible":e.unref(u)||e.unref(d)}]}),[e.renderSlot(t.$slots,"default")],16))}}),ae=["title"],ne=e.defineComponent({name:"VvDropdownOption",props:Z,setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=J("vv-dropdown-option",o,e.computed((()=>({disabled:l.disabled,selected:l.selected,unselectable:l.unselectable&&l.selected})))),n=e.computed((()=>l.selected?l.unselectable?l.deselectHintLabel:l.selectedHintLabel:l.disabled?void 0:l.selectHintLabel));return(t,l)=>(e.openBlock(),e.createBlock(oe,{class:e.normalizeClass(e.unref(a)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled,"focus-on-hover":t.focusOnHover},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default"),e.createElementVNode("span",{class:"vv-dropdown-option__hint",title:e.unref(n)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(n)),1)]))],8,ae)])),_:3},8,["class","tabindex","aria-selected","aria-disabled","focus-on-hover"]))}}),re={class:"vv-dropdown-optgroup",role:"presentation",tabindex:"-1"},ie=e.defineComponent({name:"VvDropdownOptgroup",props:{...E},setup(t){const l=t;return(t,o)=>(e.openBlock(),e.createElementBlock("li",re,e.toDisplayString(l.label),1))}});function ue(e,t,l){return l?se(e,l)===se(t,l):de(e,t)}function de(e,t){if(e===t)return!0;if(e&&t&&"object"==typeof e&&"object"==typeof t){const l=Array.isArray(e),o=Array.isArray(t);let a,n,r;if(l&&o){if(n=e.length,n!=t.length)return!1;for(a=n;0!=a--;)if(!de(e[a],t[a]))return!1;return!0}if(l!=o)return!1;const i=e instanceof Date,u=t instanceof Date;if(i!=u)return!1;if(i&&u)return e.getTime()==t.getTime();const 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(n=c.length,n!==Object.keys(t).length)return!1;for(a=n;0!=a--;)if(!Object.prototype.hasOwnProperty.call(t,c[a]))return!1;for(a=n;0!=a--;)if(r=c[a],!de(e[r],t[r]))return!1;return!0}return e!=e&&t!=t}function se(e,t){if(e&&Object.keys(e).length&&t){if(-1===t.indexOf("."))return e[t];{const l=t.split(".");let o=e;for(let t=0,a=l.length;t<a;++t){if(null==e)return null;o=o[l[t]]}return o}}return null}function ce(e,t){if(null!=e&&t&&t.length)for(const l of t)if(ue(e,l))return!0;return!1}function ve(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 fe(e,t){const l=function(e,t){let l=-1;if(t)for(let o=0;o<t.length;o++)if(ue(t[o],e)){l=o;break}return l}(e,t);return l>-1?t.filter(((e,t)=>t!==l)):t}function pe(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}function me(t,l){const o=e.computed((()=>e.isRef(t)?t.value:t)),a=e.computed((()=>pe(o.value.invalidLabel))),n=e.computed((()=>pe(o.value.validLabel))),r=e.computed((()=>o.value.loadingLabel)),i=e.computed((()=>o.value.hintLabel)),u=e.computed((()=>Boolean(o.value.loading&&(l.loading||r.value)))),d=e.computed((()=>!u.value&&Boolean(o.value.invalid&&(l.invalid||a.value)))),s=e.computed((()=>!u.value&&!d.value&&Boolean(o.value.valid&&(l.valid||n.value)))),c=e.computed((()=>!u.value&&!d.value&&!s.value&&Boolean(l.hint||i.value))),v=e.computed((()=>d.value||s.value||u.value||c.value)),f=e.computed((()=>({modelValue:o.value.modelValue,valid:o.value.valid,invalid:o.value.invalid,loading:o.value.loading}))),p=e.defineComponent({name:"HintSlot",props:{tag:{type:String,default:"small"}},setup:()=>({isVisible:v,invalidLabel:a,validLabel:n,loadingLabel:r,hintLabel:i,hasInvalidLabelOrSlot:d,hasValidLabelOrSlot:s,hasLoadingLabelOrSlot:u,hasHintLabelOrSlot:c}),render(){var t,l,o,a,n,r,i,u;if(this.isVisible){let d;return this.hasInvalidLabelOrSlot&&(d="alert"),this.hasValidLabelOrSlot&&(d="status"),this.hasLoadingLabelOrSlot?e.h(this.tag,{role:d},(null==(l=(t=this.$slots).loading)?void 0:l.call(t))??this.loadingLabel):this.hasInvalidLabelOrSlot?e.h(this.tag,{role:d},(null==(a=(o=this.$slots).invalid)?void 0:a.call(o))??this.$slots.invalid??this.invalidLabel):this.hasValidLabelOrSlot?e.h(this.tag,{role:d},(null==(r=(n=this.$slots).valid)?void 0:r.call(n))??this.validLabel):e.h(this.tag,{role:d},(null==(u=(i=this.$slots).hint)?void 0:u.call(i))??this.$slots.hint??this.hintLabel)}return null}});return{hasInvalidLabelOrSlot:d,hasHintLabelOrSlot:c,hasValidLabelOrSlot:s,hasLoadingLabelOrSlot:u,hintSlotScope:f,HintSlot:p}}const be={...T,...M,...K,...j,...V,...x,...A,...w,...L,..._,...N,...D,...R,...F,...z,...E,multiple:Boolean,required:Boolean,size:[String,Number],modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},placeholder:String};function ge(t,l,o){const a=U(),n=e.computed((()=>{var e;if(a&&(null==(e=a.defaults.value)?void 0:e[t]))return a.defaults.value[t]}));return e.computed((()=>{if(void 0===n.value)return o;const e=n.value,t=l,a=o;return Object.keys(t).reduce(((l,o)=>{const n=a[o];if(l[o]=n,o in e){if(Array.isArray(t[o])){const a=t[o];if(a.length){a[0]===n&&(l[o]=e[o])}}if("function"==typeof t[o]){(0,t[o])()===n&&(l[o]=e[o])}if("object"==typeof t[o]){let a=t[o].default;"function"==typeof a&&(a=a()),"object"==typeof a?JSON.stringify(a)===JSON.stringify(n)&&(l[o]=e[o]):a===n&&(l[o]=e[o])}}return l}),{})}))}function ye(t,l){const{focused:o}=a.useFocus(t);return e.watch(o,(o=>{l(o?"focus":"blur",e.unref(t))})),{focused:o}}function he(t,l){const o=e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),a=e.computed((()=>(null==l?void 0:l.value)===c.before?o.value:void 0)),n=e.computed((()=>(null==l?void 0:l.value)===c.after?o.value:void 0)),r=e.computed((()=>(null==l?void 0:l.value)===d.left?o.value:void 0)),i=e.computed((()=>(null==l?void 0:l.value)===d.right?o.value:void 0)),u=e.computed((()=>(null==l?void 0:l.value)===d.top?o.value:void 0)),s=e.computed((()=>(null==l?void 0:l.value)===d.bottom?o.value:void 0));return{hasIcon:o,hasIconLeft:r,hasIconRight:i,hasIconTop:u,hasIconBottom:s,hasIconBefore:a,hasIconAfter:n}}function ke(t){const{options:l,labelKey:o,valueKey:a,disabledKey:n}=e.toRefs(t);return{options:l,getOptionLabel:e=>"object"!=typeof e&&null!==e?e:String("function"==typeof o.value?o.value(e):r.get(e,o.value)),getOptionValue:e=>"object"!=typeof e&&null!==e?e:"function"==typeof a.value?a.value(e):r.get(e,a.value),isOptionDisabled:e=>("object"==typeof e||null===e)&&("function"==typeof n.value?n.value(e):r.get(e,n.value)),getOptionGrouped:e=>"object"!=typeof e&&null!==e?[]:e.options||[]}}const Se=["for"],Be={class:"vv-select__wrapper"},Ve={key:0,class:"vv-select__input-before"},xe={class:"vv-select__inner"},we=["id"],Le=["disabled","hidden"],Pe=["disabled","value"],$e=["disabled","label"],Ce=["disabled","value"],Oe={key:1,class:"vv-select__input-after"},Ee=e.defineComponent({name:"VvSelect",props:be,emits:["update:modelValue","focus","blur"],setup(t,{emit:l}){const o=t,n=l,r=e.useSlots(),i=ge("VvSelect",be,o),u=e.ref(),{HintSlot:d,hasHintLabelOrSlot:s,hasInvalidLabelOrSlot:c,hintSlotScope:v}=me(i,r),{id:f,modifiers:p,disabled:m,readonly:b,loading:g,icon:y,iconPosition:h,invalid:k,valid:S,floating:B,multiple:V}=e.toRefs(o),x=ee(f),w=e.computed((()=>`${x.value}-hint`)),{focused:L}=ye(u,n),P=a.useElementVisibility(u);e.watch(P,(e=>{e&&o.autofocus&&(L.value=!0)}));const{hasIconBefore:$,hasIconAfter:C}=he(y,h),O=e.computed((()=>!ve(o.modelValue))),E=e.computed((()=>o.disabled||o.readonly)),_=e.computed((()=>E.value?-1:o.tabindex)),N=e.computed((()=>!0===o.invalid||!0!==o.valid&&void 0)),A=J("vv-select",p,e.computed((()=>({valid:S.value,invalid:k.value,loading:g.value,disabled:m.value,readonly:b.value,"icon-before":void 0!==$.value,"icon-after":void 0!==C.value,dirty:O.value,focus:L.value,floating:B.value,multiple:V.value})))),D=e.computed((()=>({name:o.name,tabindex:_.value,disabled:E.value,required:o.required,size:o.size,autocomplete:o.autocomplete,multiple:o.multiple,"aria-invalid":N.value,"aria-describedby":s.value?w.value:void 0,"aria-errormessage":c.value?w.value:void 0}))),R=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue}))),{getOptionLabel:j,getOptionValue:F,isOptionDisabled:z,getOptionGrouped:H}=ke(o),I=e.computed({get:()=>o.modelValue,set:e=>{Array.isArray(e)&&(e=e.filter((e=>void 0!==e))),n("update:modelValue",e)}}),T=e=>"string"!=typeof e&&(e&&e.options&&e.options.length>0);return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref(A))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(x)},e.toDisplayString(t.label),9,Se)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",Be,[t.$slots.before?(e.openBlock(),e.createElementBlock("div",Ve,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(R))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",xe,[e.unref($)?(e.openBlock(),e.createBlock(Q,e.mergeProps({key:0},e.unref($),{class:"vv-select__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.withDirectives(e.createElementVNode("select",e.mergeProps({id:e.unref(x),ref_key:"select",ref:u,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(I)?I.value=t:null)},e.unref(D)),[t.placeholder?(e.openBlock(),e.createElementBlock("option",{key:0,value:void 0,disabled:!t.unselectable,hidden:!t.unselectable},e.toDisplayString(t.placeholder),9,Le)):e.createCommentVNode("v-if",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,((t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[T(t)?(e.openBlock(),e.createElementBlock("optgroup",{key:`group-${l}`,disabled:e.unref(z)(t),label:e.unref(j)(t)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(H)(t),((t,o)=>(e.openBlock(),e.createElementBlock("option",{key:`group-${l}-item-${o}`,disabled:e.unref(z)(t),value:e.unref(F)(t)},e.toDisplayString(e.unref(j)(t)),9,Ce)))),128))],8,$e)):(e.openBlock(),e.createElementBlock("option",{key:l,disabled:e.unref(z)(t),value:e.unref(F)(t)},e.toDisplayString(e.unref(j)(t)),9,Pe))],64)))),256))],16,we),[[e.vModelSelect,e.unref(I)]]),e.unref(C)?(e.openBlock(),e.createBlock(Q,e.mergeProps({key:1},e.unref(C),{class:"vv-select__icon vv-select__icon-after"}),null,16)):e.createCommentVNode("v-if",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Oe,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(R))))])):e.createCommentVNode("v-if",!0)]),e.createVNode(e.unref(d),{id:e.unref(w),class:"vv-select__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"3"}:void 0]),1032,["id"])],2))}}),_e={...N,value:[String,Number]},Ne=e.defineComponent({name:"VvBadge",props:_e,setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=J("vv-badge",o);return(t,l)=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass(e.unref(a)),role:"status"},[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.value),1)]))],2))}}),Ae=q,De=e.defineComponent({name:"VvAction",props:Ae,emits:["click","mouseover","mouseleave"],setup(t,{expose:l,emit:o}){const a=t,n=o,r=e.getCurrentInstance(),i=U(),u=e.ref(null);l({$el:u});const{reference:d,bus:s,aria:c,expanded:v}=e.inject(h,{});e.watch((()=>u.value),(e=>{d&&(d.value=e)}));const p=e.computed((()=>a.pressed||(null==v?void 0:v.value))),{role:m}=e.inject(S,{}),b=e.computed((()=>{switch(!0){case a.disabled:return f.button;case void 0!==a.to:return(null==i?void 0:i.nuxt)?f.nuxtLink:f.routerLink;case void 0!==a.href:return f.a;default:return a.defaultTag}})),g=e.computed((()=>{const e={...null==c?void 0:c.value,ariaPressed:!!p.value||void 0,ariaLabel:a.ariaLabel,role:null==m?void 0:m.value};switch(b.value){case f.a:return{...e,href:a.href,target:a.target,rel:a.rel};case f.routerLink:case f.nuxtLink:return{...e,to:a.to,target:a.target};case f.button:return{...e,type:a.type,disabled:a.disabled};default:return e}})),y=e=>{var t;a.disabled?e.preventDefault():(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onClick)?n("click",e):null==s||s.emit("click",e)},k=e=>{var t;(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onMouseover)?n("mouseover",e):null==s||s.emit("mouseover",e)},B=e=>{var t;(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onMouseleave)?n("mouseleave",e):null==s||s.emit("mouseleave",e)};return(t,l)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(b)),e.mergeProps(e.unref(g),{ref_key:"element",ref:u,class:{active:t.active,pressed:e.unref(p),disabled:t.disabled,current:t.current},onClickPassive:y,onMouseoverPassive:k,onMouseleavePassive:B}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.label),1)]))])),_:3},16,["class"]))}});const Re={...q,...H,...N,...z,...w,...R,iconPosition:{type:String,default:d.left,validator:e=>Object.values(d).includes(e)},loadingIcon:{type:String,default:"eos-icons:bubble-loading"},toggle:{type:Boolean,default:!1},value:{type:[String,Number,Boolean],default:void 0},uncheckedValue:{type:[String,Number,Boolean],default:void 0},modelValue:{type:[String,Number,Boolean],default:void 0}};function je(t,l){const{group:o,isInGroup:a,getGroupOrLocalRef:n}=function(t){const l=e.inject(t,void 0),o=e.computed((()=>void 0!==l));return{group:l,isInGroup:o,getGroupOrLocalRef:function(t,o,a){const n=null==l?void 0:l[t];if(n)return e.computed({get:()=>n.value,set(e){n.value=e}});const r=e.toRef(o,t);return e.computed({get:()=>r.value,set(e){a&&a(`update:${t}`,e)}})}}}(y),{id:r,iconPosition:i,icon:u,label:d,pressed:s}=e.toRefs(t),c=n("modelValue",t,l),v=n("toggle",t),f=n("unselectable",t),p=e.computed((()=>(null==o?void 0:o.multiple.value)??!1)),m=e.computed((()=>{let e=t.modifiers,l=null==o?void 0:o.modifiers.value;const a=new Set;return e&&(Array.isArray(e)||(e=e.split(" ")),e.forEach((e=>a.add(e)))),l&&(Array.isArray(l)||(l=l.split(" ")),l.forEach((e=>a.add(e)))),Array.from(a)})),b=e.computed((()=>Boolean(t.disabled||(null==o?void 0:o.disabled.value))));return{group:o,isInGroup:a,modelValue:c,toggle:v,unselectable:f,multiple:p,modifiers:m,disabled:b,id:r,pressed:s,iconPosition:i,icon:u,label:d}}const Fe={key:1,class:"vv-button__label"},ze={key:1,class:"vv-button__label"},He=e.defineComponent({name:"VvButton",inheritAttrs:!1,props:Re,emits:["update:modelValue"],setup(t,{expose:l,emit:o}){const a=t,n=e.useAttrs(),r=e.useSlots(),i=o,{id:u,modifiers:s,iconPosition:c,icon:v,label:f,modelValue:p,disabled:m,toggle:b,unselectable:g}=je(a,i),y=ee(u),h=e.computed((()=>(null==n?void 0:n.name)||y.value)),k=e.ref(null);l({$el:e.computed((()=>{var e;return null==(e=k.value)?void 0:e.$el}))});const S=e.computed((()=>b.value?Array.isArray(p.value)?ce(h.value,p.value):ue(h.value,p.value):a.pressed)),B=J("vv-button",s,e.computed((()=>({reverse:[d.right,d.bottom].includes(c.value),column:[d.top,d.bottom].includes(c.value),"icon-only":Boolean((null==v?void 0:v.value)&&!(null==f?void 0:f.value)&&!r.default)})))),{hasIcon:V}=he(v),x=e.computed((()=>void 0!==a.value?a.value:h.value)),w=e.computed((()=>{if(b.value)return{onClick:L}})),L=()=>{if(b.value){if(Array.isArray(p.value))return ce(x.value,p.value)?void(g.value&&(p.value=p.value.filter((e=>e!==x.value)))):void p.value.push(x.value);if(x.value===p.value&&g.value)return void(p.value=a.uncheckedValue);p.value=x.value}};return(t,l)=>(e.openBlock(),e.createBlock(De,e.mergeProps({...e.unref(n),...e.unref(w),disabled:e.unref(m),pressed:e.unref(S),active:t.active,type:t.type,to:t.to,href:t.href,target:t.target,rel:t.rel,ariaLabel:t.ariaLabel},{id:e.unref(y),ref_key:"element",ref:k,class:e.unref(B)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[t.loading?e.renderSlot(t.$slots,"loading",{key:0},(()=>[t.loadingIcon?(e.openBlock(),e.createBlock(Q,{key:0,class:"vv-button__loading-icon",name:t.loadingIcon},null,8,["name"])):e.createCommentVNode("v-if",!0),t.loadingLabel?(e.openBlock(),e.createElementBlock("span",Fe,e.toDisplayString(t.loadingLabel),1)):e.createCommentVNode("v-if",!0)])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.renderSlot(t.$slots,"before"),e.unref(V)?(e.openBlock(),e.createBlock(Q,e.mergeProps({key:0},e.unref(V),{class:"vv-button__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.unref(f)?(e.openBlock(),e.createElementBlock("span",ze,[e.renderSlot(t.$slots,"label",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(f)),1)]))])):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"after")],64))]))])),_:3},16,["id","class"]))}}),Ie=["id"],Te=["id","for"],Me=["id","aria-controls","placeholder"],Ke={key:0,class:"vv-select__input-before"},qe={class:"vv-select__inner"},We=["aria-expanded","aria-labelledby","aria-describedby","aria-errormessage","tabindex"],Ge={key:0,class:"vv-select__value"},Ue=["aria-label","onClick"],Je={key:1,class:"vv-select__input-after"},Qe={name:"VvCombobox",components:{VvDropdown:le,VvDropdownOption:ne,VvDropdownOptgroup:ie,VvButton:He}};return e.defineComponent({...Qe,props:W,emits:["update:modelValue","update:search","change:search","focus","blur"],setup(t,{emit:l}){const o=t,n=l,r=e.useSlots(),i=ge("VvCombobox",W,o),u=e=>"string"!=typeof e&&(e.options&&e.options.length>0),{HintSlot:d,hasHintLabelOrSlot:s,hasInvalidLabelOrSlot:c,hintSlotScope:v}=me(i,r),f=e.ref(null),p=e.ref(null),b=e.ref(null),{focused:g}=ye(f,n),{focused:y}=a.useFocusWithin(b);e.watch(g,(e=>{o.autoOpen&&(!e||S.value?e||!S.value||y.value||x():V())})),e.watch(y,(e=>{g.value||e||!S.value||x()}));const h=e.ref(""),k=a.refDebounced(h,e.computed((()=>Number(o.debounceSearch))));e.watch(k,(()=>{n("update:search",k.value),n("change:search",k.value)}));const S=e.ref(!1),B=()=>{o.disabled||o.readonly||(S.value=!S.value)},V=()=>{o.disabled||o.readonly||S.value||(S.value=!0)},x=()=>{o.disabled||o.readonly||!S.value||(S.value=!1)},w=()=>{i.value.searchable&&p.value&&p.value.focus({preventScroll:!0})},L=()=>{i.value.searchable&&(h.value="")},{id:P,icon:$,iconPosition:C,modifiers:O,disabled:E,readonly:_,loading:N,valid:A,invalid:D,floating:R}=e.toRefs(o),j=ee(P),F=e.computed((()=>`${j.value}-hint`)),z=e.computed((()=>`${j.value}-dropdown`)),H=e.computed((()=>`${j.value}-search`)),I=e.computed((()=>`${j.value}-label`)),T=e.ref(!1),M=e.computed((()=>T.value||N.value)),K=e.ref(),{hasIconBefore:q,hasIconAfter:G}=he($,C),U=e.computed((()=>!ve(o.modelValue))),X=e.computed((()=>E.value||_.value?-1:o.tabindex)),Y=J("vv-select",O,e.computed((()=>({disabled:E.value,loading:M.value,readonly:_.value,"icon-before":void 0!==q.value,"icon-after":void 0!==G.value,valid:A.value,invalid:D.value,dirty:U.value,focus:g.value||y.value||S.value,floating:R.value,badges:o.badges})))),{getOptionLabel:Z,getOptionValue:te,getOptionGrouped:oe,isOptionDisabled:ae}=ke(o),re=a.computedAsync((async()=>{var e;if(i.value.searchFunction){T.value=!0;const e=await Promise.resolve(i.value.searchFunction(k.value,o.options));return T.value=!1,e}return null==(e=o.options)?void 0:e.filter((e=>Z(e).toLowerCase().includes(k.value.toLowerCase().trim())))}));function de(e){return Array.isArray(o.modelValue)?ce(e,o.modelValue)||ce(te(e),o.modelValue):ue(e,o.modelValue)||ue(te(e),o.modelValue)}const se=e.computed((()=>o.options.reduce(((e,t)=>u(t)?[...e,...oe(t)]:[...e,t]),[]).filter((e=>de(e))))),pe=e.computed((()=>se.value.map((e=>Z(e))).join(o.separator))),be=()=>{o.autoOpen?V():B()},Se=e=>{var t;if(o.disabled||o.readonly)return;const l=te(e);let a=l;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&&!ce(l,o.modelValue))return;a=ce(l,o.modelValue)?fe(l,o.modelValue):[...o.modelValue,l]}else a=[l];else o.keepOpen||x(),Array.isArray(o.modelValue)?a=o.unselectable&&o.modelValue.includes(l)?[]:[l]:o.unselectable&&l===o.modelValue&&(a=void 0);n("update:modelValue",a)},Be=e.computed((()=>({id:j.value,name:o.name,tabindex:X.value,valid:A.value,validLabel:i.value.validLabel,invalid:D.value,invalidLabel:i.value.invalidLabel,hintLabel:i.value.hintLabel,loading:M.value,loadingLabel:i.value.loadingLabel,disabled:E.value,readonly:_.value,modifiers:i.value.modifiers,options:i.value.options,labelKey:i.value.labelKey,valueKey:i.value.valueKey,icon:i.value.icon,iconPosition:i.value.iconPosition,floating:i.value.floating,unselectable:i.value.unselectable,multiple:i.value.multiple,label:i.value.label,placeholder:i.value.placeholder,modelValue:o.modelValue}))),Ve=e.computed((()=>({id:z.value,reference:b.value,placement:i.value.placement,strategy:i.value.strategy,transitionName:i.value.transitionName,offset:i.value.offset,shift:i.value.shift,flip:i.value.flip,autoPlacement:i.value.autoPlacement,arrow:i.value.arrow,autofocusFirst:!!i.value.searchable||i.value.autofocusFirst,triggerWidth:i.value.triggerWidth,modifiers:i.value.dropdownModifiers}))),xe=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue})));return a.onKeyStroke([" ","Enter"],(e=>{o.autoOpen||!S.value&&g.value&&(e.preventDefault(),e.stopImmediatePropagation(),B())}),{target:f}),(t,l)=>t.native?(e.openBlock(),e.createBlock(Ee,e.mergeProps({key:1},e.unref(Be),{"onUpdate:modelValue":l[3]||(l[3]=e=>n("update:modelValue",e))}),null,16)):(e.openBlock(),e.createElementBlock("div",{key:0,id:e.unref(j),class:e.normalizeClass(e.unref(Y))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,id:e.unref(I),for:e.unref(i).searchable?e.unref(H):void 0},e.toDisplayString(t.label),9,Te)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:b,class:"vv-select__wrapper"},[e.createVNode(le,e.mergeProps({ref_key:"dropdownEl",ref:K,modelValue:e.unref(S),"onUpdate:modelValue":l[2]||(l[2]=t=>e.isRef(S)?S.value=t:null)},e.unref(Ve),{role:e.unref(m).listbox,onAfterExpand:w,onAfterCollapse:L}),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(xe))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",qe,[e.unref(q)?(e.openBlock(),e.createBlock(Q,e.mergeProps({key:0},e.unref(q),{class:"vv-select__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",e.mergeProps({ref_key:"inputEl",ref:f},l,{class:"vv-select__input",role:"combobox","aria-expanded":e.unref(S),"aria-labelledby":e.unref(I),"aria-describedby":e.unref(s)?e.unref(F):void 0,"aria-errormessage":e.unref(c)?e.unref(F):void 0,tabindex:e.unref(X),onClickPassive:be}),[e.renderSlot(t.$slots,"value",e.normalizeProps(e.guardReactiveProps({selectedOptions:e.unref(se),onInput:Se})),(()=>[e.unref(pe)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.badges?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(e.unref(se),((l,o)=>(e.openBlock(),e.createBlock(Ne,{key:o,modifiers:t.badgeModifiers,class:"vv-select__badge"},{default:e.withCtx((()=>[e.createTextVNode(e.toDisplayString(e.unref(Z)(l))+" ",1),!t.unselectable||e.unref(_)||e.unref(E)?e.createCommentVNode("v-if",!0):(e.openBlock(),e.createElementBlock("button",{key:0,"aria-label":e.unref(i).deselectActionLabel,type:"button",onClick:e.withModifiers((e=>Se(l)),["stop"])},[e.createVNode(Q,{name:"close"})],8,Ue))])),_:2},1032,["modifiers"])))),128)):(e.openBlock(),e.createElementBlock("div",Ge,e.toDisplayString(e.unref(pe)),1))],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(t.placeholder),1)],64))]))],16,We),e.unref(G)?(e.openBlock(),e.createBlock(Q,e.mergeProps({key:1},e.unref(G),{class:"vv-select__icon vv-select__icon-after"}),null,16)):e.createCommentVNode("v-if",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Je,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(xe))))])):e.createCommentVNode("v-if",!0)])),items:e.withCtx((()=>{var l;return[!e.unref(E)&&(null==(l=e.unref(re))?void 0:l.length)?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(e.unref(re),((l,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:o},[u(l)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createVNode(ie,{label:e.unref(Z)(l)},null,8,["label"]),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(oe)(l),((o,a)=>(e.openBlock(),e.createBlock(ne,e.mergeProps({selected:de(o),disabled:e.unref(ae)(o),unselectable:t.unselectable,deselectHintLabel:e.unref(i).deselectHintLabel,selectHintLabel:e.unref(i).selectHintLabel,selectedHintLabel:e.unref(i).selectedHintLabel},{key:a,class:"vv-dropdown-option","focus-on-hover":"",onClickPassive:e=>Se(o)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(se),selected:de(o),disabled:e.unref(ae)(o)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(Z)(o)),1)]))])),_:2},1040,["onClickPassive"])))),128))],64)):(e.openBlock(),e.createBlock(ne,e.mergeProps({key:1},{selected:de(l),disabled:e.unref(ae)(l),unselectable:t.unselectable,deselectHintLabel:e.unref(i).deselectHintLabel,selectHintLabel:e.unref(i).selectHintLabel,selectedHintLabel:e.unref(i).selectedHintLabel},{class:"vv-dropdown-option","focus-on-hover":"",onClickPassive:e=>Se(l)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(se),selected:de(l),disabled:e.unref(ae)(l)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(Z)(l)),1)]))])),_:2},1040,["onClickPassive"]))],64)))),128)):t.options.length?e.unref(E)?e.createCommentVNode("v-if",!0):(e.openBlock(),e.createBlock(ne,{key:2,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-results",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(i).noResultsLabel),1)]))])),_:3})):(e.openBlock(),e.createBlock(ne,{key:1,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-options",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(i).noOptionsLabel),1)]))])),_:3}))]})),after:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::after",{},(()=>{var t;return[(null==(t=e.unref(K))?void 0:t.customPosition)?(e.openBlock(),e.createBlock(He,{key:0,label:e.unref(i).closeLabel,modifiers:"secondary",onClick:l[1]||(l[1]=t=>e.unref(K).hide())},null,8,["label"])):e.createCommentVNode("v-if",!0)]}))])),_:2},[e.unref(i).searchable||t.$slots["dropdown::before"]?{name:"before",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::before"),e.unref(i).searchable&&!e.unref(E)?e.withDirectives((e.openBlock(),e.createElementBlock("input",{key:0,id:e.unref(H),ref_key:"inputSearchEl",ref:p,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(h)?h.value=t:null),"aria-autocomplete":"list","aria-controls":e.unref(z),autocomplete:"off",spellcheck:"false",type:"search",class:"vv-dropdown__search",placeholder:e.unref(i).searchPlaceholder},null,8,Me)),[[e.vModelText,e.unref(h)]]):e.createCommentVNode("v-if",!0)])),key:"0"}:void 0]),1040,["modelValue","role"])],512),e.createVNode(e.unref(d),{id:e.unref(F),class:"vv-select__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"3"}:void 0]),1032,["id"])],10,Ie))}})}));
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("@iconify/vue"),require("@floating-ui/vue"),require("uid"),require("@vueuse/core"),require("mitt"),require("ts-dot-prop")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","@floating-ui/vue","uid","@vueuse/core","mitt","ts-dot-prop"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvCombobox=t(e.vue,e.vue$1,e.vue$2,e.uid,e.core,e.mitt,e.tsDotProp)}(this,(function(e,t,l,o,a,n,r){"use strict";var i=(e=>(e.local="local",e.session="session",e))(i||{}),u=(e=>(e.absolute="absolute",e.fixed="fixed",e))(u||{}),d=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(d||{}),s=(e=>(e.topStart="top-start",e.topEnd="top-end",e.bottomStart="bottom-start",e.bottomEnd="bottom-end",e.leftStart="left-start",e.leftEnd="left-end",e.rightStart="right-start",e.rightEnd="right-end",e))(s||{}),c=(e=>(e.before="before",e.after="after",e))(c||{}),v=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(v||{}),f=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(f||{}),p=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(p||{}),m=(e=>(e.listbox="listbox",e.menu="menu",e))(m||{}),b=(e=>(e.option="option",e.presentation="presentation",e))(b||{});const g=Symbol.for("volver"),y=Symbol.for("buttonGroup"),h=Symbol.for("dropdownTrigger"),k=Symbol.for("dropdownItem"),S=Symbol.for("dropdownAction"),B={to:{type:[String,Object]},href:String,target:String,rel:{type:String,default:"noopener noreferrer"}},V={valid:{type:Boolean,default:!1},validLabel:{type:[String,Array],default:void 0}},x={invalid:{type:Boolean,default:!1},invalidLabel:{type:[String,Array],default:void 0}},w={loading:{type:Boolean,default:!1},loadingLabel:{type:String,default:"Loading..."}},L={disabled:{type:Boolean,default:!1}},P={selected:{type:Boolean,default:!1}},$={active:{type:Boolean,default:!1}},C={current:{type:Boolean,default:!1}},O={pressed:{type:Boolean,default:!1}},E={label:{type:[String,Number],default:void 0}},_={readonly:{type:Boolean,default:!1}},N={modifiers:{type:[String,Array],default:void 0}},A={hintLabel:{type:String,default:""}},D={options:{type:Array,default:()=>[]},labelKey:{type:[String,Function],default:"label"},valueKey:{type:[String,Function],default:"value"},disabledKey:{type:[String,Function],default:"disabled"}},R={icon:{type:[String,Object],default:void 0},iconPosition:{type:String,default:c.before,validation:e=>Object.values(c).includes(e)}},j={tabindex:{type:[String,Number],default:0}},F={floating:{type:Boolean,default:!1}},z={unselectable:{type:Boolean,default:!0}},H={id:[String,Number]},I={placement:{type:String,default:d.bottom,validator:e=>Object.values(d).includes(e)||Object.values(s).includes(e)},strategy:{type:String,default:void 0,validator:e=>Object.values(u).includes(e)},transitionName:{type:String,default:void 0},offset:{type:[Number,String,Object],default:0},shift:{type:[Boolean,Object],default:!1},flip:{type:[Boolean,Object],default:!0},size:{type:[Boolean,Object],default:()=>({padding:10})},autoPlacement:{type:[Boolean,Object],default:!1},arrow:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean,default:!1}},T={...H,name:{type:String,required:!0}},M={autofocus:{type:Boolean,default:!1}},K={autocomplete:{type:String,default:"off"}},q={...L,...E,...O,...$,...C,...B,type:{type:String,default:v.button,validator:e=>Object.values(v).includes(e)},ariaLabel:{type:String,default:void 0},defaultTag:{type:String,default:f.button}};i.local;const W={...T,...j,...V,...x,...A,...w,...L,..._,...N,...D,...R,...F,...z,...I,...E,transitionName:{type:String,default:"vv-dropdown--mobile-fade-block"},modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},noResultsLabel:{type:String,default:"No results"},noOptionsLabel:{type:String,default:"No options available"},selectedHintLabel:{type:String,default:"Selected"},deselectActionLabel:{type:String,default:"Deselect"},selectHintLabel:{type:String,default:"Press enter to select"},deselectHintLabel:{type:String,default:"Press enter to remove"},closeLabel:{type:String,default:"Close"},placeholder:String,searchable:Boolean,searchFunction:{type:Function,default:void 0},searchPlaceholder:{type:String,default:"Search..."},debounceSearch:{type:[Number,String],default:0},multiple:Boolean,maxValues:[Number,String],separator:{type:String,default:", "},native:Boolean,badges:Boolean,badgeModifiers:{type:[String,Array],default:"action sm"},triggerWidth:{...I.triggerWidth,default:!0},dropdownModifiers:{type:[String,Array],default:"mobile"},autoOpen:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1}},G={prefix:"normal"};function U(){return e.inject(g)}function J(t,l,o){return e.computed((()=>{const a={[t]:!0},n="string"==typeof(null==l?void 0:l.value)?l.value.split(" "):null==l?void 0:l.value;return n&&Array.isArray(n)&&n.forEach((e=>{e&&(a[`${t}--${e}`]=!0)})),o&&Object.keys(o.value).forEach((l=>{a[`${t}--${l}`]=e.unref(o.value[l])})),a}))}const Q=e.defineComponent({name:"VvIcon",props:e.mergeDefaults({name:{},color:{},width:{},height:{},provider:{},prefix:{},src:{},horizontalFlip:{type:Boolean},verticalFlip:{type:Boolean},flip:{},mode:{},inline:{type:Boolean},rotate:{},onLoad:{type:Function},svg:{},modifiers:{}},G),setup(l){const o=l,a=e.computed((()=>"string"==typeof o.rotate?parseFloat(o.rotate):o.rotate)),n=e.ref(!0),r=U(),{modifiers:i}=e.toRefs(o),u=J("vv-icon",i),d=e.computed((()=>o.provider||(null==r?void 0:r.iconsProvider))),s=e.computed((()=>{const e=o.name??"",l=`@${d.value}:${o.prefix}:${e}`;if(t.iconExists(l))return l;const a=null==r?void 0:r.iconsCollections.find((l=>{const o=`@${d.value}:${l.prefix}:${e}`;return t.iconExists(o)}));return a?`@${d.value}:${a.prefix}:${e}`:e}));function c(e){const l=function(e){let t;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");t=(new e).window}return(t?new t.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),a=(null==l?void 0:l.innerHTML.trim())||"";l&&a&&t.addIcon(`@${d.value}:${o.prefix}:${o.name}`,{body:a,height:l.viewBox.baseVal.height,width:l.viewBox.baseVal.width})}return r&&o.src&&!t.iconExists(`@${d.value}:${o.prefix}:${o.name}`)&&(n.value=!1,r.fetchIcon(o.src).then((e=>{e&&(c(e),n.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),o.svg&&c(o.svg),(l,o)=>e.unref(n)?(e.openBlock(),e.createBlock(e.unref(t.Icon),e.mergeProps({key:0,class:e.unref(u)},{inline:l.inline,width:l.width,height:l.height,horizontalFlip:l.horizontalFlip,verticalFlip:l.verticalFlip,flip:l.flip,rotate:e.unref(a),color:l.color,onLoad:l.onLoad,icon:e.unref(s)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}}),X={...H,...I,...N,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:m.menu,validator:e=>Object.values(m).includes(e)}},Y={focusOnHover:{type:Boolean,default:!1}},Z={...L,...P,...z,...N,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String},focusOnHover:{type:Boolean,default:!1}},ee=t=>e.computed((()=>String((null==t?void 0:t.value)||o.uid())));const te=["id","tabindex","role","aria-labelledby"],le=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:X,emits:["update:modelValue","beforeExpand","beforeCollapse","afterExpand","afterCollapse","before-enter","after-leave","enter","after-enter","enter-cancelled","before-leave","leave","leave-cancelled"],setup(t,{expose:o,emit:r}){const i=t,s=r,{id:c}=e.toRefs(i),v=ee(c),f=e.useAttrs(),p=e.ref("auto"),g=e.ref("auto"),y=e.ref(null),S=e.ref(),B=e.ref(null),V=e.ref(null),x=e.computed({get:()=>i.reference??y.value,set:e=>{y.value=e}}),w=e.ref(!1);e.onMounted((()=>{a.useMutationObserver(S.value,(()=>{var e;w.value="true"===(null==(e=window.getComputedStyle(S.value).getPropertyValue("--dropdown-custom-position"))?void 0:e.trim())}),{attributeFilter:["style"],window:window})}));const L=e.computed((()=>{const e=[];if(i.autoPlacement?"boolean"==typeof i.autoPlacement?e.push(l.autoPlacement()):e.push(l.autoPlacement(i.autoPlacement)):i.flip&&("boolean"==typeof i.flip?e.push(l.flip({fallbackStrategy:"initialPlacement"})):e.push(l.flip(i.flip))),i.shift&&("boolean"==typeof i.shift?e.push(l.shift()):e.push(l.shift(i.shift))),i.size){const t=({availableWidth:e,availableHeight:t})=>{p.value=`${e}px`,g.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:B})),e})),{x:P,y:$,middlewareData:C,placement:O,strategy:E}=l.useFloating(x,S,{whileElementsMounted:(...e)=>l.autoUpdate(...e,{animationFrame:i.strategy===u.fixed}),placement:e.computed((()=>i.placement)),strategy:e.computed((()=>i.strategy)),middleware:L}),_=e.computed((()=>{var e;if(w.value)return;const t=i.triggerWidth&&x.value?`${null==(e=x.value)?void 0:e.offsetWidth}px`:void 0;return{position:E.value,top:`${$.value??0}px`,left:`${P.value??0}px`,maxWidth:t?void 0:p.value,maxHeight:g.value,width:t}})),N=e.computed((()=>O.value.split("-")[0])),A=e.computed((()=>{var e,t,l,o,a;if(w.value)return;const n={[d.top]:d.bottom,[d.right]:d.left,[d.bottom]:d.top,[d.left]:d.right}[N.value];return{left:void 0!==(null==(e=C.value.arrow)?void 0:e.x)?`${null==(t=C.value.arrow)?void 0:t.x}px`:void 0,top:void 0!==(null==(l=C.value.arrow)?void 0:l.y)?`${null==(o=C.value.arrow)?void 0:o.y}px`:void 0,[n]:-((null==(a=B.value)?void 0:a.offsetWidth)??0)/2+"px"}})),D=a.useVModel(i,"modelValue",s),R=e.ref(!1),j=e.computed({get:()=>D.value??R.value,set:e=>{void 0!==D.value?D.value=e:R.value=e}}),F=()=>{j.value=!0},z=()=>{j.value=!1},H=()=>{j.value=!j.value},I=e=>{x.value=e};o({toggle:H,show:F,hide:z,init:I,customPosition:w}),e.watch(j,(t=>{t&&i.autofocusFirst&&e.nextTick((()=>{const e=X(S.value);e.length>0&&e[0].focus({preventScroll:!0})}))})),a.onClickOutside(S,(()=>{!i.keepOpen&&j.value&&(j.value=!1)}),{ignore:[x]});const T=e.computed((()=>{var e,t;return(null==(t=null==(e=x.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),M=e.computed((()=>({"aria-controls":v.value,"aria-haspopup":!0,"aria-expanded":j.value}))),{component:K,bus:q}=function({reference:t,id:l,expanded:o,aria:a}){const r=n(),i=e.defineComponent({name:"VvDropdownTriggerProvider",setup(){e.provide(h,{reference:t,id:l,expanded:o,aria:a,bus:r})},render(){var t,l;return e.h(e.Fragment,{},null==(l=(t=this.$slots).default)?void 0:l.call(t))}});return{bus:r,component:i}}({reference:x,id:v,expanded:j,aria:M});q.on("click",H);const{role:W,modifiers:G}=e.toRefs(i),U=J("vv-dropdown",G,e.computed((()=>({arrow:i.arrow})))),{focused:Q}=a.useFocusWithin(S);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"))):[]}const Y=a.useElementHover(S),{itemRole:Z}=function({role:t,...l}){const o=e.computed((()=>t.value===m.listbox?b.option:b.presentation));return e.provide(k,{role:o,...l}),{itemRole:o}}({role:W,expanded:j,focused:Q,hovered:Y});a.onKeyStroke("Escape",(e=>{j.value&&(e.preventDefault(),z())})),a.onKeyStroke("ArrowDown",(t=>{j.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=X(S.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus({preventScroll:!0}):e[0].focus({preventScroll:!0})}})))})),a.onKeyStroke("ArrowUp",(t=>{j.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=X(S.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus({preventScroll:!0}):e[e.length-1].focus({preventScroll:!0})}})))})),a.onKeyStroke([" ","Enter"],(e=>{const t=e.target;j.value&&Q.value&&t&&(null==t||t.click())}));const le={"before-enter":()=>{s(j.value?"beforeExpand":"beforeCollapse"),s("before-enter")},"after-leave":()=>{s(j.value?"afterExpand":"afterCollapse"),s("after-leave")},enter:()=>{s("enter")},"after-enter":()=>{s("after-enter")},"enter-cancelled":()=>{s("enter-cancelled")},"before-leave":()=>{s("before-leave")},leave:()=>{s("leave")},"leave-cancelled":()=>{s("leave-cancelled")}};return(t,l)=>(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:I,show:F,hide:z,toggle:H,expanded:e.unref(j),aria:e.unref(M)})))])),_:3}),e.createVNode(e.Transition,e.mergeProps({name:t.transitionName},e.toHandlers(le),{persisted:""}),{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:S,style:e.normalizeStyle(e.unref(_)),class:e.normalizeClass(e.unref(U))},[i.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:B,style:e.normalizeStyle(e.unref(A)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(j)}))),e.createElementVNode("div",e.mergeProps(e.unref(f),{id:e.unref(v),ref_key:"listEl",ref:V,tabindex:e.unref(j)?void 0:-1,role:e.unref(W),"aria-labelledby":e.unref(T),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(Z)})))],16,te),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(j)})))],6),[[e.vShow,e.unref(j)]])])),_:3},16,["name"])],64))}});const oe=e.defineComponent({name:"VvDropdownItem",props:Y,setup(t){const l=t,{role:o,expanded:n}=e.inject(k,{}),r=e.ref(null);!function({expanded:t}){e.provide(S,{role:e.ref(p.menuitem),expanded:t})}({expanded:n});const i=a.useElementHover(r),{focused:u}=a.useFocus(r),{focused:d}=a.useFocusWithin(r);return e.watch(i,(e=>{e&&l.focusOnHover&&(u.value=!0)})),(t,l)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({role:e.unref(o)},{ref_key:"element",ref:r,class:["vv-dropdown__item",{"focus-visible":e.unref(u)||e.unref(d)}]}),[e.renderSlot(t.$slots,"default")],16))}}),ae=["title"],ne=e.defineComponent({name:"VvDropdownOption",props:Z,setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=J("vv-dropdown-option",o,e.computed((()=>({disabled:l.disabled,selected:l.selected,unselectable:l.unselectable&&l.selected})))),n=e.computed((()=>l.selected?l.unselectable?l.deselectHintLabel:l.selectedHintLabel:l.disabled?"":l.selectHintLabel));return(t,l)=>(e.openBlock(),e.createBlock(oe,{class:e.normalizeClass(e.unref(a)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled,"focus-on-hover":t.focusOnHover},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default"),e.createElementVNode("span",{class:"vv-dropdown-option__hint",title:e.unref(n)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(n)),1)]))],8,ae)])),_:3},8,["class","tabindex","aria-selected","aria-disabled","focus-on-hover"]))}}),re={class:"vv-dropdown-optgroup",role:"presentation",tabindex:"-1"},ie=e.defineComponent({name:"VvDropdownOptgroup",props:{...E},setup(t){const l=t;return(t,o)=>(e.openBlock(),e.createElementBlock("li",re,e.toDisplayString(l.label),1))}});function ue(e,t,l){return l?se(e,l)===se(t,l):de(e,t)}function de(e,t){if(e===t)return!0;if(e&&t&&"object"==typeof e&&"object"==typeof t){const l=Array.isArray(e),o=Array.isArray(t);let a,n,r;if(l&&o){if(n=e.length,n!=t.length)return!1;for(a=n;0!=a--;)if(!de(e[a],t[a]))return!1;return!0}if(l!=o)return!1;const i=e instanceof Date,u=t instanceof Date;if(i!=u)return!1;if(i&&u)return e.getTime()==t.getTime();const 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(n=c.length,n!==Object.keys(t).length)return!1;for(a=n;0!=a--;)if(!Object.prototype.hasOwnProperty.call(t,c[a]))return!1;for(a=n;0!=a--;)if(r=c[a],!de(e[r],t[r]))return!1;return!0}return e!=e&&t!=t}function se(e,t){if(e&&Object.keys(e).length&&t){if(-1===t.indexOf("."))return e[t];{const l=t.split(".");let o=e;for(let t=0,a=l.length;t<a;++t){if(null==e)return null;o=o[l[t]]}return o}}return null}function ce(e,t){if(null!=e&&t&&t.length)for(const l of t)if(ue(e,l))return!0;return!1}function ve(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 fe(e,t){const l=function(e,t){let l=-1;if(t)for(let o=0;o<t.length;o++)if(ue(t[o],e)){l=o;break}return l}(e,t);return l>-1?t.filter(((e,t)=>t!==l)):t}function pe(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}function me(t,l){const o=e.computed((()=>e.isRef(t)?t.value:t)),a=e.computed((()=>pe(o.value.invalidLabel))),n=e.computed((()=>pe(o.value.validLabel))),r=e.computed((()=>o.value.loadingLabel)),i=e.computed((()=>o.value.hintLabel)),u=e.computed((()=>Boolean(o.value.loading&&(l.loading||r.value)))),d=e.computed((()=>!u.value&&Boolean(o.value.invalid&&(l.invalid||a.value)))),s=e.computed((()=>!u.value&&!d.value&&Boolean(o.value.valid&&(l.valid||n.value)))),c=e.computed((()=>!u.value&&!d.value&&!s.value&&Boolean(l.hint||i.value))),v=e.computed((()=>d.value||s.value||u.value||c.value)),f=e.computed((()=>({modelValue:o.value.modelValue,valid:o.value.valid,invalid:o.value.invalid,loading:o.value.loading}))),p=e.defineComponent({name:"HintSlot",props:{tag:{type:String,default:"small"}},setup:()=>({isVisible:v,invalidLabel:a,validLabel:n,loadingLabel:r,hintLabel:i,hasInvalidLabelOrSlot:d,hasValidLabelOrSlot:s,hasLoadingLabelOrSlot:u,hasHintLabelOrSlot:c}),render(){var t,l,o,a,n,r,i,u;if(this.isVisible){let d;return this.hasInvalidLabelOrSlot&&(d="alert"),this.hasValidLabelOrSlot&&(d="status"),this.hasLoadingLabelOrSlot?e.h(this.tag,{role:d},(null==(l=(t=this.$slots).loading)?void 0:l.call(t))??this.loadingLabel):this.hasInvalidLabelOrSlot?e.h(this.tag,{role:d},(null==(a=(o=this.$slots).invalid)?void 0:a.call(o))??this.$slots.invalid??this.invalidLabel):this.hasValidLabelOrSlot?e.h(this.tag,{role:d},(null==(r=(n=this.$slots).valid)?void 0:r.call(n))??this.validLabel):e.h(this.tag,{role:d},(null==(u=(i=this.$slots).hint)?void 0:u.call(i))??this.$slots.hint??this.hintLabel)}return null}});return{hasInvalidLabelOrSlot:d,hasHintLabelOrSlot:c,hasValidLabelOrSlot:s,hasLoadingLabelOrSlot:u,hintSlotScope:f,HintSlot:p}}const be={...T,...M,...K,...j,...V,...x,...A,...w,...L,..._,...N,...D,...R,...F,...z,...E,multiple:Boolean,required:Boolean,size:[String,Number],modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},placeholder:String};function ge(t,l,o){const a=U(),n=e.computed((()=>{var e;if(a&&(null==(e=a.defaults.value)?void 0:e[t]))return a.defaults.value[t]}));return e.computed((()=>{if(void 0===n.value)return o;const e=n.value,t=l,a=o;return Object.keys(t).reduce(((l,o)=>{const n=a[o];if(l[o]=n,o in e){if(Array.isArray(t[o])){const a=t[o];if(a.length){a[0]===n&&(l[o]=e[o])}}if("function"==typeof t[o]){(0,t[o])()===n&&(l[o]=e[o])}if("object"==typeof t[o]){let a=t[o].default;"function"==typeof a&&(a=a()),"object"==typeof a?JSON.stringify(a)===JSON.stringify(n)&&(l[o]=e[o]):a===n&&(l[o]=e[o])}}return l}),{})}))}function ye(t,l){const{focused:o}=a.useFocus(t);return e.watch(o,(o=>{l(o?"focus":"blur",e.unref(t))})),{focused:o}}function he(t,l){const o=e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),a=e.computed((()=>(null==l?void 0:l.value)===c.before?o.value:void 0)),n=e.computed((()=>(null==l?void 0:l.value)===c.after?o.value:void 0)),r=e.computed((()=>(null==l?void 0:l.value)===d.left?o.value:void 0)),i=e.computed((()=>(null==l?void 0:l.value)===d.right?o.value:void 0)),u=e.computed((()=>(null==l?void 0:l.value)===d.top?o.value:void 0)),s=e.computed((()=>(null==l?void 0:l.value)===d.bottom?o.value:void 0));return{hasIcon:o,hasIconLeft:r,hasIconRight:i,hasIconTop:u,hasIconBottom:s,hasIconBefore:a,hasIconAfter:n}}function ke(t){const{options:l,labelKey:o,valueKey:a,disabledKey:n}=e.toRefs(t);return{options:l,getOptionLabel:e=>"object"!=typeof e&&null!==e?e:String("function"==typeof o.value?o.value(e):r.get(e,o.value)),getOptionValue:e=>"object"!=typeof e&&null!==e?e:"function"==typeof a.value?a.value(e):r.get(e,a.value),isOptionDisabled:e=>("object"==typeof e||null===e)&&("function"==typeof n.value?n.value(e):r.get(e,n.value)),getOptionGrouped:e=>"object"!=typeof e&&null!==e?[]:e.options||[]}}const Se=["for"],Be={class:"vv-select__wrapper"},Ve={key:0,class:"vv-select__input-before"},xe={class:"vv-select__inner"},we=["id"],Le=["disabled","hidden"],Pe=["disabled","value"],$e=["disabled","label"],Ce=["disabled","value"],Oe={key:1,class:"vv-select__input-after"},Ee=e.defineComponent({name:"VvSelect",props:be,emits:["update:modelValue","focus","blur"],setup(t,{emit:l}){const o=t,n=l,r=e.useSlots(),i=ge("VvSelect",be,o),u=e.ref(),{HintSlot:d,hasHintLabelOrSlot:s,hasInvalidLabelOrSlot:c,hintSlotScope:v}=me(i,r),{id:f,modifiers:p,disabled:m,readonly:b,loading:g,icon:y,iconPosition:h,invalid:k,valid:S,floating:B,multiple:V}=e.toRefs(o),x=ee(f),w=e.computed((()=>`${x.value}-hint`)),{focused:L}=ye(u,n),P=a.useElementVisibility(u);e.watch(P,(e=>{e&&o.autofocus&&(L.value=!0)}));const{hasIconBefore:$,hasIconAfter:C}=he(y,h),O=e.computed((()=>!ve(o.modelValue))),E=e.computed((()=>o.disabled||o.readonly)),_=e.computed((()=>E.value?-1:o.tabindex)),N=e.computed((()=>!0===o.invalid||!0!==o.valid&&void 0)),A=J("vv-select",p,e.computed((()=>({valid:S.value,invalid:k.value,loading:g.value,disabled:m.value,readonly:b.value,"icon-before":void 0!==$.value,"icon-after":void 0!==C.value,dirty:O.value,focus:L.value,floating:B.value,multiple:V.value})))),D=e.computed((()=>({name:o.name,tabindex:_.value,disabled:E.value,required:o.required,size:o.size,autocomplete:o.autocomplete,multiple:o.multiple,"aria-invalid":N.value,"aria-describedby":s.value?w.value:void 0,"aria-errormessage":c.value?w.value:void 0}))),R=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue}))),{getOptionLabel:j,getOptionValue:F,isOptionDisabled:z,getOptionGrouped:H}=ke(o),I=e.computed({get:()=>o.modelValue,set:e=>{Array.isArray(e)&&(e=e.filter((e=>void 0!==e))),n("update:modelValue",e)}}),T=e=>"string"!=typeof e&&(e&&e.options&&e.options.length>0);return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref(A))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(x)},e.toDisplayString(t.label),9,Se)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",Be,[t.$slots.before?(e.openBlock(),e.createElementBlock("div",Ve,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(R))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",xe,[e.unref($)?(e.openBlock(),e.createBlock(Q,e.mergeProps({key:0},e.unref($),{class:"vv-select__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.withDirectives(e.createElementVNode("select",e.mergeProps({id:e.unref(x),ref_key:"select",ref:u,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(I)?I.value=t:null)},e.unref(D)),[t.placeholder?(e.openBlock(),e.createElementBlock("option",{key:0,value:void 0,disabled:!t.unselectable,hidden:!t.unselectable},e.toDisplayString(t.placeholder),9,Le)):e.createCommentVNode("v-if",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,((t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[T(t)?(e.openBlock(),e.createElementBlock("optgroup",{key:`group-${l}`,disabled:e.unref(z)(t),label:e.unref(j)(t)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(H)(t),((t,o)=>(e.openBlock(),e.createElementBlock("option",{key:`group-${l}-item-${o}`,disabled:e.unref(z)(t),value:e.unref(F)(t)},e.toDisplayString(e.unref(j)(t)),9,Ce)))),128))],8,$e)):(e.openBlock(),e.createElementBlock("option",{key:l,disabled:e.unref(z)(t),value:e.unref(F)(t)},e.toDisplayString(e.unref(j)(t)),9,Pe))],64)))),256))],16,we),[[e.vModelSelect,e.unref(I)]]),e.unref(C)?(e.openBlock(),e.createBlock(Q,e.mergeProps({key:1},e.unref(C),{class:"vv-select__icon vv-select__icon-after"}),null,16)):e.createCommentVNode("v-if",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Oe,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(R))))])):e.createCommentVNode("v-if",!0)]),e.createVNode(e.unref(d),{id:e.unref(w),class:"vv-select__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"3"}:void 0]),1032,["id"])],2))}}),_e={...N,value:[String,Number]},Ne=e.defineComponent({name:"VvBadge",props:_e,setup(t){const l=t,{modifiers:o}=e.toRefs(l),a=J("vv-badge",o);return(t,l)=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass(e.unref(a)),role:"status"},[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.value),1)]))],2))}}),Ae=q,De=e.defineComponent({name:"VvAction",props:Ae,emits:["click","mouseover","mouseleave"],setup(t,{expose:l,emit:o}){const a=t,n=o,r=e.getCurrentInstance(),i=U(),u=e.ref(null);l({$el:u});const{reference:d,bus:s,aria:c,expanded:v}=e.inject(h,{});e.watch((()=>u.value),(e=>{d&&(d.value=e)}));const p=e.computed((()=>a.pressed||(null==v?void 0:v.value))),{role:m}=e.inject(S,{}),b=e.computed((()=>{switch(!0){case a.disabled:return f.button;case void 0!==a.to:return(null==i?void 0:i.nuxt)?f.nuxtLink:f.routerLink;case void 0!==a.href:return f.a;default:return a.defaultTag}})),g=e.computed((()=>{const e={...null==c?void 0:c.value,ariaPressed:!!p.value||void 0,ariaLabel:a.ariaLabel,role:null==m?void 0:m.value};switch(b.value){case f.a:return{...e,href:a.href,target:a.target,rel:a.rel};case f.routerLink:case f.nuxtLink:return{...e,to:a.to,target:a.target};case f.button:return{...e,type:a.type,disabled:a.disabled};default:return e}})),y=e=>{var t;a.disabled?e.preventDefault():(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onClick)?n("click",e):null==s||s.emit("click",e)},k=e=>{var t;(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onMouseover)?n("mouseover",e):null==s||s.emit("mouseover",e)},B=e=>{var t;(null==(t=null==r?void 0:r.vnode.props)?void 0:t.onMouseleave)?n("mouseleave",e):null==s||s.emit("mouseleave",e)};return(t,l)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(b)),e.mergeProps(e.unref(g),{ref_key:"element",ref:u,class:{active:t.active,pressed:e.unref(p),disabled:t.disabled,current:t.current},onClickPassive:y,onMouseoverPassive:k,onMouseleavePassive:B}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.label),1)]))])),_:3},16,["class"]))}});const Re={...q,...H,...N,...z,...w,...R,iconPosition:{type:String,default:d.left,validator:e=>Object.values(d).includes(e)},loadingIcon:{type:String,default:"eos-icons:bubble-loading"},toggle:{type:Boolean,default:!1},value:{type:[String,Number,Boolean],default:void 0},uncheckedValue:{type:[String,Number,Boolean],default:void 0},modelValue:{type:[String,Number,Boolean],default:void 0}};function je(t,l){const{group:o,isInGroup:a,getGroupOrLocalRef:n}=function(t){const l=e.inject(t,void 0),o=e.computed((()=>void 0!==l));return{group:l,isInGroup:o,getGroupOrLocalRef:function(t,o,a){const n=null==l?void 0:l[t];if(n)return e.computed({get:()=>n.value,set(e){n.value=e}});const r=e.toRef(o,t);return e.computed({get:()=>r.value,set(e){a&&a(`update:${t}`,e)}})}}}(y),{id:r,iconPosition:i,icon:u,label:d,pressed:s}=e.toRefs(t),c=n("modelValue",t,l),v=n("toggle",t),f=n("unselectable",t),p=e.computed((()=>(null==o?void 0:o.multiple.value)??!1)),m=e.computed((()=>{let e=t.modifiers,l=null==o?void 0:o.modifiers.value;const a=new Set;return e&&(Array.isArray(e)||(e=e.split(" ")),e.forEach((e=>a.add(e)))),l&&(Array.isArray(l)||(l=l.split(" ")),l.forEach((e=>a.add(e)))),Array.from(a)})),b=e.computed((()=>Boolean(t.disabled||(null==o?void 0:o.disabled.value))));return{group:o,isInGroup:a,modelValue:c,toggle:v,unselectable:f,multiple:p,modifiers:m,disabled:b,id:r,pressed:s,iconPosition:i,icon:u,label:d}}const Fe={key:1,class:"vv-button__label"},ze={key:1,class:"vv-button__label"},He=e.defineComponent({name:"VvButton",inheritAttrs:!1,props:Re,emits:["update:modelValue"],setup(t,{expose:l,emit:o}){const a=t,n=e.useAttrs(),r=e.useSlots(),i=o,{id:u,modifiers:s,iconPosition:c,icon:v,label:f,modelValue:p,disabled:m,toggle:b,unselectable:g}=je(a,i),y=ee(u),h=e.computed((()=>(null==n?void 0:n.name)||y.value)),k=e.ref(null);l({$el:e.computed((()=>{var e;return null==(e=k.value)?void 0:e.$el}))});const S=e.computed((()=>b.value?Array.isArray(p.value)?ce(h.value,p.value):ue(h.value,p.value):a.pressed)),B=J("vv-button",s,e.computed((()=>({reverse:[d.right,d.bottom].includes(c.value),column:[d.top,d.bottom].includes(c.value),"icon-only":Boolean((null==v?void 0:v.value)&&!(null==f?void 0:f.value)&&!r.default)})))),{hasIcon:V}=he(v),x=e.computed((()=>void 0!==a.value?a.value:h.value)),w=e.computed((()=>{if(b.value)return{onClick:L}})),L=()=>{if(b.value){if(Array.isArray(p.value))return ce(x.value,p.value)?void(g.value&&(p.value=p.value.filter((e=>e!==x.value)))):void p.value.push(x.value);if(x.value===p.value&&g.value)return void(p.value=a.uncheckedValue);p.value=x.value}};return(t,l)=>(e.openBlock(),e.createBlock(De,e.mergeProps({...e.unref(n),...e.unref(w),disabled:e.unref(m),pressed:e.unref(S),active:t.active,type:t.type,to:t.to,href:t.href,target:t.target,rel:t.rel,ariaLabel:t.ariaLabel},{id:e.unref(y),ref_key:"element",ref:k,class:e.unref(B)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[t.loading?e.renderSlot(t.$slots,"loading",{key:0},(()=>[t.loadingIcon?(e.openBlock(),e.createBlock(Q,{key:0,class:"vv-button__loading-icon",name:t.loadingIcon},null,8,["name"])):e.createCommentVNode("v-if",!0),t.loadingLabel?(e.openBlock(),e.createElementBlock("span",Fe,e.toDisplayString(t.loadingLabel),1)):e.createCommentVNode("v-if",!0)])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.renderSlot(t.$slots,"before"),e.unref(V)?(e.openBlock(),e.createBlock(Q,e.mergeProps({key:0},e.unref(V),{class:"vv-button__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.unref(f)?(e.openBlock(),e.createElementBlock("span",ze,[e.renderSlot(t.$slots,"label",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(f)),1)]))])):e.createCommentVNode("v-if",!0),e.renderSlot(t.$slots,"after")],64))]))])),_:3},16,["id","class"]))}}),Ie=["id"],Te=["id","for"],Me=["id","aria-controls","placeholder"],Ke={key:0,class:"vv-select__input-before"},qe={class:"vv-select__inner"},We=["aria-expanded","aria-labelledby","aria-describedby","aria-errormessage","tabindex"],Ge={key:0,class:"vv-select__value"},Ue=["aria-label","onClick"],Je={key:1,class:"vv-select__input-after"},Qe={name:"VvCombobox",components:{VvDropdown:le,VvDropdownOption:ne,VvDropdownOptgroup:ie,VvButton:He}};return e.defineComponent({...Qe,props:W,emits:["update:modelValue","update:search","change:search","focus","blur"],setup(t,{emit:l}){const o=t,n=l,r=e.useSlots(),i=ge("VvCombobox",W,o),u=e=>"string"!=typeof e&&(e.options&&e.options.length>0),{HintSlot:d,hasHintLabelOrSlot:s,hasInvalidLabelOrSlot:c,hintSlotScope:v}=me(i,r),f=e.ref(null),p=e.ref(null),b=e.ref(null),{focused:g}=ye(f,n),{focused:y}=a.useFocusWithin(b);e.watch(g,(e=>{o.autoOpen&&(!e||S.value?e||!S.value||y.value||x():V())})),e.watch(y,(e=>{g.value||e||!S.value||x()}));const h=e.ref(""),k=a.refDebounced(h,e.computed((()=>Number(o.debounceSearch))));e.watch(k,(()=>{n("update:search",k.value),n("change:search",k.value)}));const S=e.ref(!1),B=()=>{o.disabled||o.readonly||(S.value=!S.value)},V=()=>{o.disabled||o.readonly||S.value||(S.value=!0)},x=()=>{o.disabled||o.readonly||!S.value||(S.value=!1)},w=()=>{i.value.searchable&&p.value&&p.value.focus({preventScroll:!0})},L=()=>{i.value.searchable&&(h.value="")},{id:P,icon:$,iconPosition:C,modifiers:O,disabled:E,readonly:_,loading:N,valid:A,invalid:D,floating:R}=e.toRefs(o),j=ee(P),F=e.computed((()=>`${j.value}-hint`)),z=e.computed((()=>`${j.value}-dropdown`)),H=e.computed((()=>`${j.value}-search`)),I=e.computed((()=>`${j.value}-label`)),T=e.ref(!1),M=e.computed((()=>T.value||N.value)),K=e.ref(),{hasIconBefore:q,hasIconAfter:G}=he($,C),U=e.computed((()=>!ve(o.modelValue))),X=e.computed((()=>E.value||_.value?-1:o.tabindex)),Y=J("vv-select",O,e.computed((()=>({disabled:E.value,loading:M.value,readonly:_.value,"icon-before":void 0!==q.value,"icon-after":void 0!==G.value,valid:A.value,invalid:D.value,dirty:U.value,focus:g.value||y.value||S.value,floating:R.value,badges:o.badges})))),{getOptionLabel:Z,getOptionValue:te,getOptionGrouped:oe,isOptionDisabled:ae}=ke(o),re=a.computedAsync((async()=>{var e;if(i.value.searchFunction){T.value=!0;const e=await Promise.resolve(i.value.searchFunction(k.value,o.options));return T.value=!1,e}return null==(e=o.options)?void 0:e.filter((e=>Z(e).toLowerCase().includes(k.value.toLowerCase().trim())))}));function de(e){return Array.isArray(o.modelValue)?ce(e,o.modelValue)||ce(te(e),o.modelValue):ue(e,o.modelValue)||ue(te(e),o.modelValue)}const se=e.computed((()=>o.options.reduce(((e,t)=>u(t)?[...e,...oe(t)]:[...e,t]),[]).filter((e=>de(e))))),pe=e.computed((()=>se.value.map((e=>Z(e))).join(o.separator))),be=()=>{o.autoOpen?V():B()},Se=e=>{var t;if(o.disabled||o.readonly)return;const l=te(e);let a=l;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&&!ce(l,o.modelValue))return;a=ce(l,o.modelValue)?fe(l,o.modelValue):[...o.modelValue,l]}else a=[l];else o.keepOpen||x(),Array.isArray(o.modelValue)?a=o.unselectable&&o.modelValue.includes(l)?[]:[l]:o.unselectable&&l===o.modelValue&&(a=void 0);n("update:modelValue",a)},Be=e.computed((()=>({id:j.value,name:o.name,tabindex:X.value,valid:A.value,validLabel:i.value.validLabel,invalid:D.value,invalidLabel:i.value.invalidLabel,hintLabel:i.value.hintLabel,loading:M.value,loadingLabel:i.value.loadingLabel,disabled:E.value,readonly:_.value,modifiers:i.value.modifiers,options:i.value.options,labelKey:i.value.labelKey,valueKey:i.value.valueKey,icon:i.value.icon,iconPosition:i.value.iconPosition,floating:i.value.floating,unselectable:i.value.unselectable,multiple:i.value.multiple,label:i.value.label,placeholder:i.value.placeholder,modelValue:o.modelValue}))),Ve=e.computed((()=>({id:z.value,reference:b.value,placement:i.value.placement,strategy:i.value.strategy,transitionName:i.value.transitionName,offset:i.value.offset,shift:i.value.shift,flip:i.value.flip,autoPlacement:i.value.autoPlacement,arrow:i.value.arrow,autofocusFirst:!!i.value.searchable||i.value.autofocusFirst,triggerWidth:i.value.triggerWidth,modifiers:i.value.dropdownModifiers}))),xe=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue})));return a.onKeyStroke([" ","Enter"],(e=>{o.autoOpen||!S.value&&g.value&&(e.preventDefault(),e.stopImmediatePropagation(),B())}),{target:f}),(t,l)=>t.native?(e.openBlock(),e.createBlock(Ee,e.mergeProps({key:1},e.unref(Be),{"onUpdate:modelValue":l[3]||(l[3]=e=>n("update:modelValue",e))}),null,16)):(e.openBlock(),e.createElementBlock("div",{key:0,id:e.unref(j),class:e.normalizeClass(e.unref(Y))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,id:e.unref(I),for:e.unref(i).searchable?e.unref(H):void 0},e.toDisplayString(t.label),9,Te)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:b,class:"vv-select__wrapper"},[e.createVNode(le,e.mergeProps({ref_key:"dropdownEl",ref:K,modelValue:e.unref(S),"onUpdate:modelValue":l[2]||(l[2]=t=>e.isRef(S)?S.value=t:null)},e.unref(Ve),{role:e.unref(m).listbox,onAfterExpand:w,onAfterCollapse:L}),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(xe))))])):e.createCommentVNode("v-if",!0),e.createElementVNode("div",qe,[e.unref(q)?(e.openBlock(),e.createBlock(Q,e.mergeProps({key:0},e.unref(q),{class:"vv-select__icon"}),null,16)):e.createCommentVNode("v-if",!0),e.createElementVNode("div",e.mergeProps({ref_key:"inputEl",ref:f},l,{class:"vv-select__input",role:"combobox","aria-expanded":e.unref(S),"aria-labelledby":e.unref(I),"aria-describedby":e.unref(s)?e.unref(F):void 0,"aria-errormessage":e.unref(c)?e.unref(F):void 0,tabindex:e.unref(X),onClickPassive:be}),[e.renderSlot(t.$slots,"value",e.normalizeProps(e.guardReactiveProps({selectedOptions:e.unref(se),onInput:Se})),(()=>[e.unref(pe)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.badges?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(e.unref(se),((l,o)=>(e.openBlock(),e.createBlock(Ne,{key:o,modifiers:t.badgeModifiers,class:"vv-select__badge"},{default:e.withCtx((()=>[e.createTextVNode(e.toDisplayString(e.unref(Z)(l))+" ",1),!t.unselectable||e.unref(_)||e.unref(E)?e.createCommentVNode("v-if",!0):(e.openBlock(),e.createElementBlock("button",{key:0,"aria-label":e.unref(i).deselectActionLabel,type:"button",onClick:e.withModifiers((e=>Se(l)),["stop"])},[e.createVNode(Q,{name:"close"})],8,Ue))])),_:2},1032,["modifiers"])))),128)):(e.openBlock(),e.createElementBlock("div",Ge,e.toDisplayString(e.unref(pe)),1))],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(t.placeholder),1)],64))]))],16,We),e.unref(G)?(e.openBlock(),e.createBlock(Q,e.mergeProps({key:1},e.unref(G),{class:"vv-select__icon vv-select__icon-after"}),null,16)):e.createCommentVNode("v-if",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Je,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(xe))))])):e.createCommentVNode("v-if",!0)])),items:e.withCtx((()=>{var l;return[!e.unref(E)&&(null==(l=e.unref(re))?void 0:l.length)?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(e.unref(re),((l,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:o},[u(l)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createVNode(ie,{label:e.unref(Z)(l)},null,8,["label"]),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(oe)(l),((o,a)=>(e.openBlock(),e.createBlock(ne,e.mergeProps({selected:de(o),disabled:e.unref(ae)(o),unselectable:t.unselectable,deselectHintLabel:e.unref(i).deselectHintLabel,selectHintLabel:e.unref(i).selectHintLabel,selectedHintLabel:e.unref(i).selectedHintLabel},{key:a,class:"vv-dropdown-option","focus-on-hover":"",onClickPassive:e=>Se(o)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(se),selected:de(o),disabled:e.unref(ae)(o)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(Z)(o)),1)]))])),_:2},1040,["onClickPassive"])))),128))],64)):(e.openBlock(),e.createBlock(ne,e.mergeProps({key:1},{selected:de(l),disabled:e.unref(ae)(l),unselectable:t.unselectable,deselectHintLabel:e.unref(i).deselectHintLabel,selectHintLabel:e.unref(i).selectHintLabel,selectedHintLabel:e.unref(i).selectedHintLabel},{class:"vv-dropdown-option","focus-on-hover":"",onClickPassive:e=>Se(l)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(se),selected:de(l),disabled:e.unref(ae)(l)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(Z)(l)),1)]))])),_:2},1040,["onClickPassive"]))],64)))),128)):t.options.length?e.unref(E)?e.createCommentVNode("v-if",!0):(e.openBlock(),e.createBlock(ne,{key:2,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-results",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(i).noResultsLabel),1)]))])),_:3})):(e.openBlock(),e.createBlock(ne,{key:1,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-options",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(i).noOptionsLabel),1)]))])),_:3}))]})),after:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::after",{},(()=>{var t;return[(null==(t=e.unref(K))?void 0:t.customPosition)?(e.openBlock(),e.createBlock(He,{key:0,label:e.unref(i).closeLabel,modifiers:"secondary",onClick:l[1]||(l[1]=t=>e.unref(K).hide())},null,8,["label"])):e.createCommentVNode("v-if",!0)]}))])),_:2},[e.unref(i).searchable||t.$slots["dropdown::before"]?{name:"before",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::before"),e.unref(i).searchable&&!e.unref(E)?e.withDirectives((e.openBlock(),e.createElementBlock("input",{key:0,id:e.unref(H),ref_key:"inputSearchEl",ref:p,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(h)?h.value=t:null),"aria-autocomplete":"list","aria-controls":e.unref(z),autocomplete:"off",spellcheck:"false",type:"search",class:"vv-dropdown__search",placeholder:e.unref(i).searchPlaceholder},null,8,Me)),[[e.vModelText,e.unref(h)]]):e.createCommentVNode("v-if",!0)])),key:"0"}:void 0]),1040,["modelValue","role"])],512),e.createVNode(e.unref(d),{id:e.unref(F),class:"vv-select__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(v))))])),key:"3"}:void 0]),1032,["id"])],10,Ie))}})}));
|