@volverjs/ui-vue 0.0.10-beta.27 → 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.
Files changed (89) hide show
  1. package/README.md +8 -7
  2. package/dist/components/VvAction/VvAction.es.js +17 -4
  3. package/dist/components/VvAction/VvAction.umd.js +1 -1
  4. package/dist/components/VvAlert/VvAlert.es.js +13 -11
  5. package/dist/components/VvAlert/VvAlert.umd.js +1 -1
  6. package/dist/components/VvAlert/VvAlert.vue.d.ts +17 -17
  7. package/dist/components/VvAlert/index.d.ts +12 -8
  8. package/dist/components/VvAlertGroup/VvAlertGroup.es.js +13 -2
  9. package/dist/components/VvAlertGroup/VvAlertGroup.umd.js +1 -1
  10. package/dist/components/VvAlertGroup/VvAlertGroup.vue.d.ts +3 -3
  11. package/dist/components/VvAlertGroup/index.d.ts +2 -14
  12. package/dist/components/VvBreadcrumb/VvBreadcrumb.es.js +17 -4
  13. package/dist/components/VvBreadcrumb/VvBreadcrumb.umd.js +1 -1
  14. package/dist/components/VvButton/VvButton.es.js +30 -7
  15. package/dist/components/VvButton/VvButton.umd.js +1 -1
  16. package/dist/components/VvButton/VvButton.vue.d.ts +3 -3
  17. package/dist/components/VvCombobox/VvCombobox.es.js +31 -7
  18. package/dist/components/VvCombobox/VvCombobox.umd.js +1 -1
  19. package/dist/components/VvCombobox/VvCombobox.vue.d.ts +5 -5
  20. package/dist/components/VvDropdown/VvDropdown.vue.d.ts +1 -1
  21. package/dist/components/VvDropdown/VvDropdownAction.vue.d.ts +6 -6
  22. package/dist/components/VvDropdownAction/VvDropdownAction.es.js +17 -4
  23. package/dist/components/VvDropdownAction/VvDropdownAction.umd.js +1 -1
  24. package/dist/components/VvDropdownOption/VvDropdownOption.es.js +1 -0
  25. package/dist/components/VvDropdownOption/VvDropdownOption.umd.js +1 -1
  26. package/dist/components/VvIcon/VvIcon.vue.d.ts +11 -11
  27. package/dist/components/VvInputFile/VvInputFile.es.js +30 -7
  28. package/dist/components/VvInputFile/VvInputFile.umd.js +1 -1
  29. package/dist/components/VvInputText/VvInputText.es.js +1 -0
  30. package/dist/components/VvInputText/VvInputText.umd.js +1 -1
  31. package/dist/components/VvInputText/VvInputText.vue.d.ts +1 -1
  32. package/dist/components/VvNav/VvNav.es.js +17 -4
  33. package/dist/components/VvNav/VvNav.umd.js +1 -1
  34. package/dist/components/VvNav/VvNav.vue.d.ts +3 -3
  35. package/dist/components/VvNavItem/VvNavItem.es.js +17 -4
  36. package/dist/components/VvNavItem/VvNavItem.umd.js +1 -1
  37. package/dist/components/VvSelect/VvSelect.vue.d.ts +8 -8
  38. package/dist/components/VvTab/VvTab.es.js +17 -4
  39. package/dist/components/VvTab/VvTab.umd.js +1 -1
  40. package/dist/components/VvTextarea/VvTextarea.vue.d.ts +1 -1
  41. package/dist/components/index.es.js +44 -9
  42. package/dist/components/index.umd.js +1 -1
  43. package/dist/composables/alert/useAlert.d.ts +80 -18
  44. package/dist/composables/index.es.js +6 -4
  45. package/dist/composables/index.umd.js +1 -1
  46. package/dist/composables/usePersistence.d.ts +1 -1
  47. package/dist/constants.d.ts +5 -2
  48. package/dist/icons.es.js +226 -226
  49. package/dist/icons.umd.js +1 -1
  50. package/dist/stories/AccordionGroup/AccordionGroupSlots.stories.d.ts +8 -8
  51. package/dist/test/expect.d.ts +1 -1
  52. package/dist/types/alert.d.ts +9 -7
  53. package/package.json +43 -53
  54. package/src/assets/icons/detailed.json +1 -1
  55. package/src/assets/icons/normal.json +1 -1
  56. package/src/assets/icons/simple.json +1 -1
  57. package/src/components/VvAction/VvAction.vue +13 -3
  58. package/src/components/VvAlert/index.ts +13 -6
  59. package/src/components/VvAlertGroup/index.ts +3 -16
  60. package/src/components/VvButton/VvButton.vue +11 -1
  61. package/src/components/VvDropdown/VvDropdownOption.vue +1 -0
  62. package/src/composables/alert/useAlert.ts +12 -9
  63. package/src/constants.ts +7 -2
  64. package/src/stories/Accordion/Accordion.test.ts +1 -1
  65. package/src/stories/AccordionGroup/AccordionGroup.test.ts +1 -1
  66. package/src/stories/Alert/Alert.test.ts +1 -1
  67. package/src/stories/AlertGroup/AlertGroup.test.ts +1 -1
  68. package/src/stories/Avatar/Avatar.test.ts +1 -1
  69. package/src/stories/AvatarGroup/AvatarGroup.test.ts +1 -1
  70. package/src/stories/Badge/Badge.test.ts +1 -1
  71. package/src/stories/Button/Button.test.ts +1 -1
  72. package/src/stories/ButtonGroup/ButtonGroup.test.ts +1 -1
  73. package/src/stories/Card/Card.test.ts +1 -1
  74. package/src/stories/Checkbox/Checkbox.test.ts +1 -1
  75. package/src/stories/CheckboxGroup/CheckboxGroup.test.ts +1 -1
  76. package/src/stories/Combobox/Combobox.test.ts +1 -1
  77. package/src/stories/Dialog/Dialog.test.ts +2 -2
  78. package/src/stories/Dropdown/Dropdown.test.ts +1 -1
  79. package/src/stories/InputText/InputText.test.ts +1 -1
  80. package/src/stories/Nav/Nav.test.ts +1 -1
  81. package/src/stories/Progress/Progress.test.ts +1 -1
  82. package/src/stories/Radio/Radio.test.ts +1 -1
  83. package/src/stories/RadioGroup/RadioGroup.test.ts +1 -1
  84. package/src/stories/Select/Select.test.ts +1 -1
  85. package/src/stories/Tab/Tab.test.ts +1 -1
  86. package/src/stories/Textarea/Textarea.test.ts +1 -1
  87. package/src/stories/Tooltip/Tooltip.test.ts +1 -1
  88. package/src/test/expect.ts +2 -4
  89. 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 AlertModifiers =
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: string | Record<string, unknown>
184
+ icon?: string | VvIconProps
185
185
  content?: string
186
186
  footer?: string
187
- modifiers: AlertModifiers
188
- dismissable: boolean
189
- autoClose: number
190
- timestamp: number
187
+ modifiers?: AlertModifier | AlertModifier[]
188
+ dismissable?: boolean
189
+ autoClose?: number
190
+ closeLabel?: string
191
+ role?: AlertRole
191
192
  }
192
193
  ```
193
194
 
@@ -1,4 +1,4 @@
1
- import { inject, defineComponent, ref, watch, computed, openBlock, createBlock, resolveDynamicComponent, unref, mergeProps, withCtx, renderSlot, createTextVNode, toDisplayString } from "vue";
1
+ import { inject, defineComponent, getCurrentInstance, ref, watch, computed, openBlock, createBlock, resolveDynamicComponent, unref, mergeProps, withCtx, renderSlot, createTextVNode, toDisplayString } from "vue";
2
2
  var StorageType = /* @__PURE__ */ ((StorageType2) => {
3
3
  StorageType2["local"] = "local";
4
4
  StorageType2["session"] = "session";
@@ -292,6 +292,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
292
292
  setup(__props, { expose: __expose, emit: __emit }) {
293
293
  const props = __props;
294
294
  const emit = __emit;
295
+ const instance = getCurrentInstance();
295
296
  const volver = useVolver();
296
297
  const element = ref(null);
297
298
  __expose({ $el: element });
@@ -358,20 +359,32 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
358
359
  }
359
360
  });
360
361
  const onClick = (e) => {
362
+ var _a;
361
363
  if (props.disabled) {
362
364
  e.preventDefault();
363
365
  return;
364
366
  }
367
+ if ((_a = instance == null ? void 0 : instance.vnode.props) == null ? void 0 : _a.onClick) {
368
+ emit("click", e);
369
+ return;
370
+ }
365
371
  dropdownEventBus == null ? void 0 : dropdownEventBus.emit("click", e);
366
- emit("click", e);
367
372
  };
368
373
  const onMouseover = (e) => {
374
+ var _a;
375
+ if ((_a = instance == null ? void 0 : instance.vnode.props) == null ? void 0 : _a.onMouseover) {
376
+ emit("mouseover", e);
377
+ return;
378
+ }
369
379
  dropdownEventBus == null ? void 0 : dropdownEventBus.emit("mouseover", e);
370
- emit("mouseover", e);
371
380
  };
372
381
  const onMouseleave = (e) => {
382
+ var _a;
383
+ if ((_a = instance == null ? void 0 : instance.vnode.props) == null ? void 0 : _a.onMouseleave) {
384
+ emit("mouseleave", e);
385
+ return;
386
+ }
373
387
  dropdownEventBus == null ? void 0 : dropdownEventBus.emit("mouseleave", e);
374
- emit("mouseleave", e);
375
388
  };
376
389
  return (_ctx, _cache) => {
377
390
  return openBlock(), createBlock(resolveDynamicComponent(unref(hasTag)), mergeProps(unref(hasProps), {
@@ -1 +1 @@
1
- !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue")):"function"==typeof define&&define.amd?define(["vue"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvAction=t(e.vue)}(this,(function(e){"use strict";var t=(e=>(e.local="local",e.session="session",e))(t||{}),o=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(o||{}),r=(e=>(e.before="before",e.after="after",e))(r||{}),n=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(n||{}),l=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(l||{});const a=Symbol.for("volver"),u=Symbol.for("dropdownTrigger"),i=Symbol.for("dropdownAction"),s={to:{type:[String,Object]},href:String,target:String,rel:{type:String,default:"noopener noreferrer"}},d={disabled:{type:Boolean,default:!1}},c={active:{type:Boolean,default:!1}},f={current:{type:Boolean,default:!1}},v={pressed:{type:Boolean,default:!1}},p={label:{type:[String,Number],default:void 0}};r.before,o.bottom,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean;const b={...d,...p,...v,...c,...f,...s,type:{type:String,default:n.button,validator:e=>Object.values(n).includes(e)},ariaLabel:{type:String,default:void 0},defaultTag:{type:String,default:l.button}};t.local;const m=b;return e.defineComponent({name:"VvAction",props:m,emits:["click","mouseover","mouseleave"],setup(t,{expose:o,emit:r}){const n=t,s=r,d=e.inject(a),c=e.ref(null);o({$el:c});const{reference:f,bus:v,aria:p,expanded:b}=e.inject(u,{});e.watch((()=>c.value),(e=>{f&&(f.value=e)}));const m=e.computed((()=>n.pressed||(null==b?void 0:b.value))),{role:g}=e.inject(i,{}),y=e.computed((()=>{switch(!0){case n.disabled:return l.button;case void 0!==n.to:return(null==d?void 0:d.nuxt)?l.nuxtLink:l.routerLink;case void 0!==n.href:return l.a;default:return n.defaultTag}})),k=e.computed((()=>{const e={...null==p?void 0:p.value,ariaPressed:!!m.value||void 0,ariaLabel:n.ariaLabel,role:null==g?void 0:g.value};switch(y.value){case l.a:return{...e,href:n.href,target:n.target,rel:n.rel};case l.routerLink:case l.nuxtLink:return{...e,to:n.to,target:n.target};case l.button:return{...e,type:n.type,disabled:n.disabled};default:return e}})),B=e=>{n.disabled?e.preventDefault():(null==v||v.emit("click",e),s("click",e))},h=e=>{null==v||v.emit("mouseover",e),s("mouseover",e)},S=e=>{null==v||v.emit("mouseleave",e),s("mouseleave",e)};return(t,o)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(y)),e.mergeProps(e.unref(k),{ref_key:"element",ref:c,class:{active:t.active,pressed:e.unref(m),disabled:t.disabled,current:t.current},onClickPassive:B,onMouseoverPassive:h,onMouseleavePassive:S}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.label),1)]))])),_:3},16,["class"]))}})}));
1
+ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue")):"function"==typeof define&&define.amd?define(["vue"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvAction=t(e.vue)}(this,(function(e){"use strict";var t=(e=>(e.local="local",e.session="session",e))(t||{}),o=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(o||{}),n=(e=>(e.before="before",e.after="after",e))(n||{}),l=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(l||{}),r=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(r||{});const a=Symbol.for("volver"),u=Symbol.for("dropdownTrigger"),i=Symbol.for("dropdownAction"),s={to:{type:[String,Object]},href:String,target:String,rel:{type:String,default:"noopener noreferrer"}},d={disabled:{type:Boolean,default:!1}},c={active:{type:Boolean,default:!1}},v={current:{type:Boolean,default:!1}},f={pressed:{type:Boolean,default:!1}},p={label:{type:[String,Number],default:void 0}};n.before,o.bottom,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean;const b={...d,...p,...f,...c,...v,...s,type:{type:String,default:l.button,validator:e=>Object.values(l).includes(e)},ariaLabel:{type:String,default:void 0},defaultTag:{type:String,default:r.button}};t.local;const m=b;return e.defineComponent({name:"VvAction",props:m,emits:["click","mouseover","mouseleave"],setup(t,{expose:o,emit:n}){const l=t,s=n,d=e.getCurrentInstance(),c=e.inject(a),v=e.ref(null);o({$el:v});const{reference:f,bus:p,aria:b,expanded:m}=e.inject(u,{});e.watch((()=>v.value),(e=>{f&&(f.value=e)}));const g=e.computed((()=>l.pressed||(null==m?void 0:m.value))),{role:y}=e.inject(i,{}),k=e.computed((()=>{switch(!0){case l.disabled:return r.button;case void 0!==l.to:return(null==c?void 0:c.nuxt)?r.nuxtLink:r.routerLink;case void 0!==l.href:return r.a;default:return l.defaultTag}})),B=e.computed((()=>{const e={...null==b?void 0:b.value,ariaPressed:!!g.value||void 0,ariaLabel:l.ariaLabel,role:null==y?void 0:y.value};switch(k.value){case r.a:return{...e,href:l.href,target:l.target,rel:l.rel};case r.routerLink:case r.nuxtLink:return{...e,to:l.to,target:l.target};case r.button:return{...e,type:l.type,disabled:l.disabled};default:return e}})),h=e=>{var t;l.disabled?e.preventDefault():(null==(t=null==d?void 0:d.vnode.props)?void 0:t.onClick)?s("click",e):null==p||p.emit("click",e)},S=e=>{var t;(null==(t=null==d?void 0:d.vnode.props)?void 0:t.onMouseover)?s("mouseover",e):null==p||p.emit("mouseover",e)},x=e=>{var t;(null==(t=null==d?void 0:d.vnode.props)?void 0:t.onMouseleave)?s("mouseleave",e):null==p||p.emit("mouseleave",e)};return(t,o)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(k)),e.mergeProps(e.unref(B),{ref_key:"element",ref:v,class:{active:t.active,pressed:e.unref(g),disabled:t.disabled,current:t.current},onClickPassive:h,onMouseoverPassive:S,onMouseleavePassive:x}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.label),1)]))])),_:3},16,["class"]))}})}));
@@ -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: "alert"
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 u=Symbol.for("volver"),c=Symbol.for("alertGroup");function d(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 v=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(u),{modifiers:a}=e.toRefs(l),s=d("vv-icon",a),c=e.computed((()=>l.provider||(null==r?void 0:r.iconsProvider))),v=e.computed((()=>{const e=l.name??"",t=`@${c.value}:${l.prefix}:${e}`;if(o.iconExists(t))return t;const n=null==r?void 0:r.iconsCollections.find((t=>{const l=`@${c.value}:${t.prefix}:${e}`;return o.iconExists(l)}));return n?`@${c.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(`@${c.value}:${l.prefix}:${l.name}`,{body:n,height:t.viewBox.baseVal.height,width:t.viewBox.baseVal.width})}return r&&l.src&&!o.iconExists(`@${c.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(v)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}}),f=(Boolean,Boolean,Boolean,Boolean,{modifiers:{type:[String,Array],default:void 0}}),p={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,...f,...p,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:"alert"}},b=(o,l)=>{const{bus:n}=e.inject(c,{}),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:v}=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=d("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:v,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(v,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
+ !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,20 +29,16 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
25
29
  };
26
30
  role: {
27
31
  type: globalThis.PropType<"alert" | "alertdialog">;
28
- default: string;
32
+ default: import("../../constants.js").AlertRole;
29
33
  };
30
34
  icon: {
31
- type: globalThis.PropType<string | import("../VvIcon").VvIconProps>;
35
+ type: globalThis.PropType<string | import("../VvIcon/index.js").VvIconProps>;
32
36
  default: undefined;
33
37
  };
34
38
  iconPosition: {
35
39
  type: globalThis.PropType<"before" | "after">;
36
- default: import("../../constants").Position;
37
- validation: (value: import("../../constants").Position) => boolean;
38
- };
39
- modifiers: {
40
- type: globalThis.PropType<string | string[]>;
41
- default: undefined;
40
+ default: import("../../constants.js").Position;
41
+ validation: (value: import("../../constants.js").Position) => boolean;
42
42
  };
43
43
  id: (StringConstructor | NumberConstructor)[];
44
44
  }, {
@@ -46,6 +46,10 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
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,20 +76,16 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
72
76
  };
73
77
  role: {
74
78
  type: globalThis.PropType<"alert" | "alertdialog">;
75
- default: string;
79
+ default: import("../../constants.js").AlertRole;
76
80
  };
77
81
  icon: {
78
- type: globalThis.PropType<string | import("../VvIcon").VvIconProps>;
82
+ type: globalThis.PropType<string | import("../VvIcon/index.js").VvIconProps>;
79
83
  default: undefined;
80
84
  };
81
85
  iconPosition: {
82
86
  type: globalThis.PropType<"before" | "after">;
83
- default: import("../../constants").Position;
84
- validation: (value: import("../../constants").Position) => boolean;
85
- };
86
- modifiers: {
87
- type: globalThis.PropType<string | string[]>;
88
- default: undefined;
87
+ default: import("../../constants.js").Position;
88
+ validation: (value: import("../../constants.js").Position) => boolean;
89
89
  };
90
90
  id: (StringConstructor | NumberConstructor)[];
91
91
  }>>, {
@@ -94,10 +94,10 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
94
94
  modifiers: string | string[];
95
95
  footer: string;
96
96
  role: "alert" | "alertdialog";
97
- icon: string | import("../VvIcon").VvIconProps;
98
97
  dismissable: boolean;
99
98
  autoClose: number;
100
99
  closeLabel: string;
100
+ icon: string | import("../VvIcon/index.js").VvIconProps;
101
101
  iconPosition: "before" | "after";
102
102
  }, {}>, {
103
103
  header?(_: {}): any;
@@ -1,5 +1,13 @@
1
- import type { ExtractPropTypes, PropType } from 'vue';
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: string;
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("../../constants").Position;
76
- validation: (value: import("../../constants").Position) => boolean;
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: "alert"
663
+ default: AlertRole.alert
653
664
  }
654
665
  };
655
666
  const VvAlertEvents = ["close"];
@@ -1 +1 @@
1
- !function(e,o){"object"==typeof exports&&"undefined"!=typeof module?module.exports=o(require("vue"),require("mitt"),require("@iconify/vue"),require("uid")):"function"==typeof define&&define.amd?define(["vue","mitt","@iconify/vue","uid"],o):(e="undefined"!=typeof globalThis?globalThis:e||self).VvAlertGroup=o(e.vue,e.mitt,e.vue$1,e.uid)}(this,(function(e,o,t,l){"use strict";var n=(e=>(e.local="local",e.session="session",e))(n||{}),r=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(r||{}),i=(e=>(e.before="before",e.after="after",e))(i||{}),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 u=Symbol.for("volver"),c=Symbol.for("alertGroup"),d=(Boolean,Boolean,Boolean,Boolean,{modifiers:{type:[String,Array],default:void 0}}),v={icon:{type:[String,Object],default:void 0},iconPosition:{type:String,default:i.before,validation:e=>Object.values(i).includes(e)}},f={id:[String,Number]};function p(o,t,l){return e.computed((()=>{const n={[o]:!0},r="string"==typeof(null==t?void 0:t.value)?t.value.split(" "):null==t?void 0:t.value;return r&&Array.isArray(r)&&r.forEach((e=>{e&&(n[`${o}--${e}`]=!0)})),l&&Object.keys(l.value).forEach((t=>{n[`${o}--${t}`]=e.unref(l.value[t])})),n}))}r.bottom,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,a.button,s.button,n.local;const m={...d,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}},b=(t,l)=>{const n=function({name:t}){const l=o();return e.provide(c,{name:t,bus:l}),l}({name:e.computed((()=>t.name))});(t.block&&!t.inline||!t.block&&t.inline)&&console.warn("[VvAlertGroup]: block and inline props must coexist at the same time.");const r=e.computed((()=>{const o=[p("vv-alert-group",e.computed((()=>t.modifiers)),e.computed((()=>({stack:t.stack,reverse:t.reverse,absolute:"absolute"===t.position,fixed:"fixed"===t.position})))).value];return t.inline&&t.block&&o.push(`vv-alert-group--${t.block}-${t.inline}`),o})),i=e.computed((()=>t.transition?t.transition:t.position?"start"===t.inline?"vv-alert--fade-inline-start":"end"===t.inline?"vv-alert--fade-inline-end":"top"===t.block?"vv-alert--fade-block-top":"bottom"===t.block?"vv-alert--fade-block-bottom":"vv-alert--fade":"vv-alert--fade"));return n.on("close",(e=>{l("close",e)})),{hasTransition:i,hasProps:e.computed((()=>({class:r.value})))}},h={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:{}},h),setup(o){const l=o,n=e.computed((()=>"string"==typeof l.rotate?parseFloat(l.rotate):l.rotate)),r=e.ref(!0),i=e.inject(u),{modifiers:a}=e.toRefs(l),s=p("vv-icon",a),c=e.computed((()=>l.provider||(null==i?void 0:i.iconsProvider))),d=e.computed((()=>{const e=l.name??"",o=`@${c.value}:${l.prefix}:${e}`;if(t.iconExists(o))return o;const n=null==i?void 0:i.iconsCollections.find((o=>{const l=`@${c.value}:${o.prefix}:${e}`;return t.iconExists(l)}));return n?`@${c.value}:${n.prefix}:${e}`:e}));function v(e){const o=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==o?void 0:o.innerHTML.trim())||"";o&&n&&t.addIcon(`@${c.value}:${l.prefix}:${l.name}`,{body:n,height:o.viewBox.baseVal.height,width:o.viewBox.baseVal.width})}return i&&l.src&&!t.iconExists(`@${c.value}:${l.prefix}:${l.name}`)&&(r.value=!1,i.fetchIcon(l.src).then((e=>{e&&(v(e),r.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),l.svg&&v(l.svg),(o,l)=>e.unref(r)?(e.openBlock(),e.createBlock(e.unref(t.Icon),e.mergeProps({key:0,class:e.unref(s)},{inline:o.inline,width:o.width,height:o.height,horizontalFlip:o.horizontalFlip,verticalFlip:o.verticalFlip,flip:o.flip,rotate:e.unref(n),color:o.color,onLoad:o.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("v-if",!0)}});const g={...f,...d,...v,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:"alert"}},k=(o,t)=>{const{bus:n}=e.inject(c,{}),a=(s=e.computed((()=>o.id)),e.computed((()=>String((null==s?void 0:s.value)||l.uid()))));var s;const u=e.computed((()=>`${a.value}-title`)),{hasIcon:d}=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)===i.before?l.value:void 0)),a=e.computed((()=>(null==t?void 0:t.value)===i.after?l.value:void 0)),s=e.computed((()=>(null==t?void 0:t.value)===r.left?l.value:void 0)),u=e.computed((()=>(null==t?void 0:t.value)===r.right?l.value:void 0)),c=e.computed((()=>(null==t?void 0:t.value)===r.top?l.value:void 0)),d=e.computed((()=>(null==t?void 0:t.value)===r.bottom?l.value:void 0));return{hasIcon:l,hasIconLeft:s,hasIconRight:u,hasIconTop:c,hasIconBottom:d,hasIconBefore:n,hasIconAfter:a}}(e.computed((()=>o.icon))),v=p("vv-alert",e.computed((()=>o.modifiers)),e.computed((()=>({dismissable:o.autoClose>0||o.dismissable,"auto-close":o.autoClose>0,hover:h.value})))),f=e.computed((()=>({"--alert-duration":`${o.autoClose}ms`}))),m=()=>{b&&clearTimeout(b),t("close",a.value),null==n||n.emit("close",a.value)};let b;e.watch((()=>o.autoClose),(e=>{e>0?b=setTimeout(m,e):b&&clearTimeout(b)}),{immediate:!0});const h=e.ref(!1),y=e.withModifiers((()=>{h.value=!0,b&&clearTimeout(b)}),["passive"]),g=e.withModifiers((()=>{h.value=!1,o.autoClose>0&&(b=setTimeout(m,o.autoClose))}),["passive"]);return{close:m,hasIcon:d,hasTitleId:u,hasProps:e.computed((()=>({onMouseover:y,onMouseleave:g,class:v.value,style:f.value,role:o.role,"aria-labelledby":u.value})))}},B={key:0,class:"vv-alert__header"},$=["id"],S=["aria-label"],x=[e.createElementVNode("div",{class:"vv-alert__close-mask"},null,-1)],w={key:1,class:"vv-alert__content"},C={key:2,class:"vv-alert__footer"},V=e.defineComponent({name:"VvAlert",props:g,emits:["close"],setup(o,{expose:t,emit:l}){const n=o,r=l,{hasProps:i,hasTitleId:a,hasIcon:s,close:u}=k(n,r);return t({close:u}),(o,t)=>(e.openBlock(),e.createElementBlock("div",e.normalizeProps(e.guardReactiveProps(e.unref(i))),[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",B,[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(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,$)):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"]))},x,8,S)):e.createCommentVNode("v-if",!0)]))])):e.createCommentVNode("v-if",!0),o.$slots.default||o.content?(e.openBlock(),e.createElementBlock("div",w,[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",C,[e.renderSlot(o.$slots,"footer",{},(()=>[e.createTextVNode(e.toDisplayString(o.footer),1)]))])):e.createCommentVNode("v-if",!0)],16))}});return e.defineComponent({name:"VvAlertGroup",props:m,emits:["close","before-enter","after-leave","enter","after-enter","enter-cancelled","before-leave","leave","leave-cancelled"],setup(o,{emit:t}){const l=o,n=t,{hasProps:r,hasTransition:i}=b(l,n),a={"before-enter":()=>{n("before-enter")},"after-leave":()=>{n("after-leave")},enter:()=>{n("enter")},"after-enter":()=>{n("after-enter")},"enter-cancelled":()=>{n("enter-cancelled")},"before-leave":()=>{n("before-leave")},leave:()=>{n("leave")},"leave-cancelled":()=>{n("leave-cancelled")}};return(o,t)=>(e.openBlock(),e.createElementBlock("div",e.normalizeProps(e.guardReactiveProps(e.unref(r))),[e.renderSlot(o.$slots,"before"),e.createVNode(e.TransitionGroup,e.mergeProps({tag:"div",role:"group",name:e.unref(i),class:"vv-alert-group__list"},e.toHandlers(a)),{default:e.withCtx((()=>[e.renderSlot(o.$slots,"default",{},(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(o.items,(o=>(e.openBlock(),e.createBlock(V,e.mergeProps(o,{key:o.id}),null,16)))),128))]))])),_:3},16,["name"]),e.renderSlot(o.$slots,"after")],16))}})}));
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(".").AlertItem[]>;
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(".").AlertItem[]>;
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(".").AlertItem[];
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 { VvIconProps } from '../VvIcon';
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<AlertItem[]>;
9
+ type: globalThis.PropType<Alert[]>;
22
10
  default: () => never[];
23
11
  };
24
12
  stack: {
@@ -1,4 +1,4 @@
1
- import { computed, unref, inject, defineComponent, ref, watch, openBlock, createBlock, resolveDynamicComponent, mergeProps, withCtx, renderSlot, createTextVNode, toDisplayString, toRefs, createElementBlock, normalizeClass, createElementVNode, Fragment, renderList, createVNode, normalizeProps, guardReactiveProps } from "vue";
1
+ import { computed, unref, inject, defineComponent, getCurrentInstance, ref, watch, openBlock, createBlock, resolveDynamicComponent, mergeProps, withCtx, renderSlot, createTextVNode, toDisplayString, toRefs, createElementBlock, normalizeClass, createElementVNode, Fragment, renderList, createVNode, normalizeProps, guardReactiveProps } from "vue";
2
2
  function useModifiers(prefix, modifiers, others) {
3
3
  return computed(() => {
4
4
  const toReturn = {
@@ -328,6 +328,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
328
328
  setup(__props, { expose: __expose, emit: __emit }) {
329
329
  const props = __props;
330
330
  const emit = __emit;
331
+ const instance = getCurrentInstance();
331
332
  const volver = useVolver();
332
333
  const element = ref(null);
333
334
  __expose({ $el: element });
@@ -394,20 +395,32 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
394
395
  }
395
396
  });
396
397
  const onClick = (e) => {
398
+ var _a;
397
399
  if (props.disabled) {
398
400
  e.preventDefault();
399
401
  return;
400
402
  }
403
+ if ((_a = instance == null ? void 0 : instance.vnode.props) == null ? void 0 : _a.onClick) {
404
+ emit("click", e);
405
+ return;
406
+ }
401
407
  dropdownEventBus == null ? void 0 : dropdownEventBus.emit("click", e);
402
- emit("click", e);
403
408
  };
404
409
  const onMouseover = (e) => {
410
+ var _a;
411
+ if ((_a = instance == null ? void 0 : instance.vnode.props) == null ? void 0 : _a.onMouseover) {
412
+ emit("mouseover", e);
413
+ return;
414
+ }
405
415
  dropdownEventBus == null ? void 0 : dropdownEventBus.emit("mouseover", e);
406
- emit("mouseover", e);
407
416
  };
408
417
  const onMouseleave = (e) => {
418
+ var _a;
419
+ if ((_a = instance == null ? void 0 : instance.vnode.props) == null ? void 0 : _a.onMouseleave) {
420
+ emit("mouseleave", e);
421
+ return;
422
+ }
409
423
  dropdownEventBus == null ? void 0 : dropdownEventBus.emit("mouseleave", e);
410
- emit("mouseleave", e);
411
424
  };
412
425
  return (_ctx, _cache) => {
413
426
  return openBlock(), createBlock(resolveDynamicComponent(unref(hasTag)), mergeProps(unref(hasProps), {
@@ -1 +1 @@
1
- !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue")):"function"==typeof define&&define.amd?define(["vue"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvBreadcrumb=t(e.vue)}(this,(function(e){"use strict";var t=(e=>(e.local="local",e.session="session",e))(t||{}),r=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(r||{}),o=(e=>(e.before="before",e.after="after",e))(o||{}),a=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(a||{}),l=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(l||{});const n=Symbol.for("volver"),u=Symbol.for("dropdownTrigger"),i=Symbol.for("dropdownAction"),s={to:{type:[String,Object]},href:String,target:String,rel:{type:String,default:"noopener noreferrer"}},c={disabled:{type:Boolean,default:!1}},d={active:{type:Boolean,default:!1}},m={current:{type:Boolean,default:!1}},v={pressed:{type:Boolean,default:!1}},p={label:{type:[String,Number],default:void 0}},f={modifiers:{type:[String,Array],default:void 0}};o.before,r.bottom,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean;const b={...c,...p,...v,...d,...m,...s,type:{type:String,default:a.button,validator:e=>Object.values(a).includes(e)},ariaLabel:{type:String,default:void 0},defaultTag:{type:String,default:l.button}};t.local;const g={...f,routes:Array},y=b;const k=e.defineComponent({name:"VvAction",props:y,emits:["click","mouseover","mouseleave"],setup(t,{expose:r,emit:o}){const a=t,s=o,c=e.inject(n),d=e.ref(null);r({$el:d});const{reference:m,bus:v,aria:p,expanded:f}=e.inject(u,{});e.watch((()=>d.value),(e=>{m&&(m.value=e)}));const b=e.computed((()=>a.pressed||(null==f?void 0:f.value))),{role:g}=e.inject(i,{}),y=e.computed((()=>{switch(!0){case a.disabled:return l.button;case void 0!==a.to:return(null==c?void 0:c.nuxt)?l.nuxtLink:l.routerLink;case void 0!==a.href:return l.a;default:return a.defaultTag}})),k=e.computed((()=>{const e={...null==p?void 0:p.value,ariaPressed:!!b.value||void 0,ariaLabel:a.ariaLabel,role:null==g?void 0:g.value};switch(y.value){case l.a:return{...e,href:a.href,target:a.target,rel:a.rel};case l.routerLink:case l.nuxtLink:return{...e,to:a.to,target:a.target};case l.button:return{...e,type:a.type,disabled:a.disabled};default:return e}})),B=e=>{a.disabled?e.preventDefault():(null==v||v.emit("click",e),s("click",e))},h=e=>{null==v||v.emit("mouseover",e),s("mouseover",e)},S=e=>{null==v||v.emit("mouseleave",e),s("mouseleave",e)};return(t,r)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(y)),e.mergeProps(e.unref(k),{ref_key:"element",ref:d,class:{active:t.active,pressed:e.unref(b),disabled:t.disabled,current:t.current},onClickPassive:B,onMouseoverPassive:h,onMouseleavePassive:S}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.label),1)]))])),_:3},16,["class"]))}}),B={class:"vv-breadcrumb__list"},h=["content"];return e.defineComponent({name:"VvBreadcrumb",props:g,setup(t){const r=t,{modifiers:o}=e.toRefs(r),a=function(t,r,o){return e.computed((()=>{const a={[t]:!0},l="string"==typeof(null==r?void 0:r.value)?r.value.split(" "):null==r?void 0:r.value;return l&&Array.isArray(l)&&l.forEach((e=>{e&&(a[`${t}--${e}`]=!0)})),o&&Object.keys(o.value).forEach((r=>{a[`${t}--${r}`]=e.unref(o.value[r])})),a}))}("vv-breadcrumb",o),l=e.computed((()=>{var e;return(null==(e=r.routes)?void 0:e.length)??0})),n=e=>e===l.value-1;return(t,r)=>(e.openBlock(),e.createElementBlock("nav",{class:e.normalizeClass(e.unref(a)),"aria-label":"breadcrumbs"},[e.createElementVNode("ol",B,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.routes,(({label:r,...o},a)=>(e.openBlock(),e.createElementBlock("li",{key:`${r}-${a}`,class:e.normalizeClass(n(a)?"vv-breadcrumb__item-active":"vv-breadcrumb__item"),itemprop:"itemListElement",itemtype:"https://schema.org/ListItem",itemscope:""},[e.createVNode(k,e.mergeProps(o,{class:n(a)?"vv-breadcrumb__label":"vv-breadcrumb__link","aria-current":n(a)?"page":void 0,itemprop:"item","default-tag":"span"}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"label",e.normalizeProps(e.guardReactiveProps({route:o,index:a})),(()=>[e.createTextVNode(e.toDisplayString(r),1)]))])),_:2},1040,["class","aria-current"]),e.createElementVNode("meta",{itemprop:"position",content:`${a+1}`},null,8,h)],2)))),128))])],2))}})}));
1
+ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue")):"function"==typeof define&&define.amd?define(["vue"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvBreadcrumb=t(e.vue)}(this,(function(e){"use strict";var t=(e=>(e.local="local",e.session="session",e))(t||{}),o=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(o||{}),r=(e=>(e.before="before",e.after="after",e))(r||{}),l=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(l||{}),n=(e=>(e.nuxtLink="nuxt-link",e.routerLink="router-link",e.a="a",e.button="button",e))(n||{});const a=Symbol.for("volver"),u=Symbol.for("dropdownTrigger"),i=Symbol.for("dropdownAction"),s={to:{type:[String,Object]},href:String,target:String,rel:{type:String,default:"noopener noreferrer"}},d={disabled:{type:Boolean,default:!1}},c={active:{type:Boolean,default:!1}},v={current:{type:Boolean,default:!1}},p={pressed:{type:Boolean,default:!1}},m={label:{type:[String,Number],default:void 0}},f={modifiers:{type:[String,Array],default:void 0}};r.before,o.bottom,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean;const b={...d,...m,...p,...c,...v,...s,type:{type:String,default:l.button,validator:e=>Object.values(l).includes(e)},ariaLabel:{type:String,default:void 0},defaultTag:{type:String,default:n.button}};t.local;const g={...f,routes:Array},y=b;const k=e.defineComponent({name:"VvAction",props:y,emits:["click","mouseover","mouseleave"],setup(t,{expose:o,emit:r}){const l=t,s=r,d=e.getCurrentInstance(),c=e.inject(a),v=e.ref(null);o({$el:v});const{reference:p,bus:m,aria:f,expanded:b}=e.inject(u,{});e.watch((()=>v.value),(e=>{p&&(p.value=e)}));const g=e.computed((()=>l.pressed||(null==b?void 0:b.value))),{role:y}=e.inject(i,{}),k=e.computed((()=>{switch(!0){case l.disabled:return n.button;case void 0!==l.to:return(null==c?void 0:c.nuxt)?n.nuxtLink:n.routerLink;case void 0!==l.href:return n.a;default:return l.defaultTag}})),B=e.computed((()=>{const e={...null==f?void 0:f.value,ariaPressed:!!g.value||void 0,ariaLabel:l.ariaLabel,role:null==y?void 0:y.value};switch(k.value){case n.a:return{...e,href:l.href,target:l.target,rel:l.rel};case n.routerLink:case n.nuxtLink:return{...e,to:l.to,target:l.target};case n.button:return{...e,type:l.type,disabled:l.disabled};default:return e}})),h=e=>{var t;l.disabled?e.preventDefault():(null==(t=null==d?void 0:d.vnode.props)?void 0:t.onClick)?s("click",e):null==m||m.emit("click",e)},S=e=>{var t;(null==(t=null==d?void 0:d.vnode.props)?void 0:t.onMouseover)?s("mouseover",e):null==m||m.emit("mouseover",e)},x=e=>{var t;(null==(t=null==d?void 0:d.vnode.props)?void 0:t.onMouseleave)?s("mouseleave",e):null==m||m.emit("mouseleave",e)};return(t,o)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(k)),e.mergeProps(e.unref(B),{ref_key:"element",ref:v,class:{active:t.active,pressed:e.unref(g),disabled:t.disabled,current:t.current},onClickPassive:h,onMouseoverPassive:S,onMouseleavePassive:x}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.label),1)]))])),_:3},16,["class"]))}}),B={class:"vv-breadcrumb__list"},h=["content"];return e.defineComponent({name:"VvBreadcrumb",props:g,setup(t){const o=t,{modifiers:r}=e.toRefs(o),l=function(t,o,r){return e.computed((()=>{const l={[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&&(l[`${t}--${e}`]=!0)})),r&&Object.keys(r.value).forEach((o=>{l[`${t}--${o}`]=e.unref(r.value[o])})),l}))}("vv-breadcrumb",r),n=e.computed((()=>{var e;return(null==(e=o.routes)?void 0:e.length)??0})),a=e=>e===n.value-1;return(t,o)=>(e.openBlock(),e.createElementBlock("nav",{class:e.normalizeClass(e.unref(l)),"aria-label":"breadcrumbs"},[e.createElementVNode("ol",B,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.routes,(({label:o,...r},l)=>(e.openBlock(),e.createElementBlock("li",{key:`${o}-${l}`,class:e.normalizeClass(a(l)?"vv-breadcrumb__item-active":"vv-breadcrumb__item"),itemprop:"itemListElement",itemtype:"https://schema.org/ListItem",itemscope:""},[e.createVNode(k,e.mergeProps(r,{class:a(l)?"vv-breadcrumb__label":"vv-breadcrumb__link","aria-current":a(l)?"page":void 0,itemprop:"item","default-tag":"span"}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"label",e.normalizeProps(e.guardReactiveProps({route:r,index:l})),(()=>[e.createTextVNode(e.toDisplayString(o),1)]))])),_:2},1040,["class","aria-current"]),e.createElementVNode("meta",{itemprop:"position",content:`${l+1}`},null,8,h)],2)))),128))])],2))}})}));