@volverjs/ui-vue 0.0.10-beta.3 → 0.0.10-beta.31

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 (294) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +106 -10
  3. package/auto-imports.d.ts +7 -2
  4. package/bin/icons.cjs +1 -1
  5. package/bin/icons.js +22 -15
  6. package/dist/Volver.d.ts +1 -1
  7. package/dist/components/VvAccordion/VvAccordion.es.js +192 -103
  8. package/dist/components/VvAccordion/VvAccordion.umd.js +1 -1
  9. package/dist/components/VvAccordion/VvAccordion.vue.d.ts +160 -8
  10. package/dist/components/VvAccordion/index.d.ts +8 -9
  11. package/dist/components/VvAccordionGroup/VvAccordionGroup.es.js +451 -172
  12. package/dist/components/VvAccordionGroup/VvAccordionGroup.umd.js +1 -1
  13. package/dist/components/VvAccordionGroup/VvAccordionGroup.vue.d.ts +58 -13
  14. package/dist/components/VvAccordionGroup/index.d.ts +14 -6
  15. package/dist/components/VvAction/VvAction.es.js +78 -27
  16. package/dist/components/VvAction/VvAction.umd.js +1 -1
  17. package/dist/components/VvAction/VvAction.vue.d.ts +57 -22
  18. package/dist/components/VvAction/index.d.ts +25 -9
  19. package/dist/components/VvAlert/VvAlert.es.js +204 -171
  20. package/dist/components/VvAlert/VvAlert.umd.js +1 -1
  21. package/dist/components/VvAlert/VvAlert.vue.d.ts +24 -14
  22. package/dist/components/VvAlert/index.d.ts +17 -9
  23. package/dist/components/VvAlertGroup/VvAlertGroup.es.js +250 -188
  24. package/dist/components/VvAlertGroup/VvAlertGroup.umd.js +1 -1
  25. package/dist/components/VvAlertGroup/VvAlertGroup.vue.d.ts +16 -9
  26. package/dist/components/VvAlertGroup/index.d.ts +6 -14
  27. package/dist/components/VvAvatar/VvAvatar.es.js +61 -21
  28. package/dist/components/VvAvatar/VvAvatar.umd.js +1 -1
  29. package/dist/components/VvAvatar/VvAvatar.vue.d.ts +12 -4
  30. package/dist/components/VvAvatar/index.d.ts +4 -1
  31. package/dist/components/VvAvatarGroup/VvAvatarGroup.es.js +118 -48
  32. package/dist/components/VvAvatarGroup/VvAvatarGroup.umd.js +1 -1
  33. package/dist/components/VvAvatarGroup/VvAvatarGroup.vue.d.ts +10 -3
  34. package/dist/components/VvAvatarGroup/index.d.ts +4 -1
  35. package/dist/components/VvBadge/VvBadge.es.js +78 -28
  36. package/dist/components/VvBadge/VvBadge.umd.js +1 -1
  37. package/dist/components/VvBadge/VvBadge.vue.d.ts +12 -4
  38. package/dist/components/VvBadge/index.d.ts +4 -1
  39. package/dist/components/VvBreadcrumb/VvBreadcrumb.es.js +276 -60
  40. package/dist/components/VvBreadcrumb/VvBreadcrumb.umd.js +1 -1
  41. package/dist/components/VvBreadcrumb/VvBreadcrumb.vue.d.ts +27 -7
  42. package/dist/components/VvBreadcrumb/index.d.ts +6 -10
  43. package/dist/components/VvButton/VvButton.es.js +291 -252
  44. package/dist/components/VvButton/VvButton.umd.js +1 -1
  45. package/dist/components/VvButton/VvButton.vue.d.ts +94 -40
  46. package/dist/components/VvButton/index.d.ts +51 -29
  47. package/dist/components/VvButtonGroup/VvButtonGroup.es.js +81 -40
  48. package/dist/components/VvButtonGroup/VvButtonGroup.umd.js +1 -1
  49. package/dist/components/VvButtonGroup/VvButtonGroup.vue.d.ts +24 -11
  50. package/dist/components/VvButtonGroup/index.d.ts +8 -2
  51. package/dist/components/VvCard/VvCard.es.js +86 -36
  52. package/dist/components/VvCard/VvCard.umd.js +1 -1
  53. package/dist/components/VvCard/VvCard.vue.d.ts +12 -4
  54. package/dist/components/VvCard/index.d.ts +4 -1
  55. package/dist/components/VvCheckbox/VvCheckbox.es.js +177 -120
  56. package/dist/components/VvCheckbox/VvCheckbox.umd.js +1 -1
  57. package/dist/components/VvCheckbox/VvCheckbox.vue.d.ts +105 -33
  58. package/dist/components/VvCheckbox/index.d.ts +47 -14
  59. package/dist/components/VvCheckboxGroup/VvCheckboxGroup.es.js +190 -107
  60. package/dist/components/VvCheckboxGroup/VvCheckboxGroup.umd.js +1 -1
  61. package/dist/components/VvCheckboxGroup/VvCheckboxGroup.vue.d.ts +101 -30
  62. package/dist/components/VvCheckboxGroup/index.d.ts +45 -12
  63. package/dist/components/VvCombobox/VvCombobox.es.js +806 -581
  64. package/dist/components/VvCombobox/VvCombobox.umd.js +1 -1
  65. package/dist/components/VvCombobox/VvCombobox.vue.d.ts +171 -104
  66. package/dist/components/VvCombobox/index.d.ts +62 -26
  67. package/dist/components/VvDialog/VvDialog.es.js +140 -153
  68. package/dist/components/VvDialog/VvDialog.umd.js +1 -1
  69. package/dist/components/VvDialog/VvDialog.vue.d.ts +4 -4
  70. package/dist/components/VvDropdown/VvDropdown.es.js +138 -71
  71. package/dist/components/VvDropdown/VvDropdown.umd.js +1 -1
  72. package/dist/components/VvDropdown/VvDropdown.vue.d.ts +101 -75
  73. package/dist/components/VvDropdown/VvDropdownAction.vue.d.ts +66 -25
  74. package/dist/components/VvDropdown/VvDropdownItem.vue.d.ts +13 -1
  75. package/dist/components/VvDropdown/VvDropdownOptgroup.vue.d.ts +12 -4
  76. package/dist/components/VvDropdown/VvDropdownOption.vue.d.ts +35 -7
  77. package/dist/components/VvDropdown/index.d.ts +52 -10
  78. package/dist/components/VvDropdownAction/VvDropdownAction.es.js +152 -39
  79. package/dist/components/VvDropdownAction/VvDropdownAction.umd.js +1 -1
  80. package/dist/components/VvDropdownItem/VvDropdownItem.es.js +335 -8
  81. package/dist/components/VvDropdownItem/VvDropdownItem.umd.js +1 -1
  82. package/dist/components/VvDropdownOptgroup/VvDropdownOptgroup.es.js +63 -20
  83. package/dist/components/VvDropdownOptgroup/VvDropdownOptgroup.umd.js +1 -1
  84. package/dist/components/VvDropdownOption/VvDropdownOption.es.js +188 -80
  85. package/dist/components/VvDropdownOption/VvDropdownOption.umd.js +1 -1
  86. package/dist/components/VvIcon/VvIcon.es.js +23 -96
  87. package/dist/components/VvIcon/VvIcon.umd.js +1 -1
  88. package/dist/components/VvIcon/VvIcon.vue.d.ts +23 -66
  89. package/dist/components/VvIcon/index.d.ts +33 -48
  90. package/dist/components/VvInputFile/VvInputFile.es.js +1777 -0
  91. package/dist/components/VvInputFile/VvInputFile.umd.js +1 -0
  92. package/dist/components/VvInputFile/VvInputFile.vue.d.ts +359 -0
  93. package/dist/components/VvInputFile/index.d.ts +200 -0
  94. package/dist/components/VvInputText/VvInputClearAction.d.ts +7 -5
  95. package/dist/components/VvInputText/VvInputPasswordAction.d.ts +10 -8
  96. package/dist/components/VvInputText/VvInputStepAction.d.ts +2 -2
  97. package/dist/components/VvInputText/VvInputText.es.js +1237 -324
  98. package/dist/components/VvInputText/VvInputText.umd.js +1 -1
  99. package/dist/components/VvInputText/VvInputText.vue.d.ts +207 -57
  100. package/dist/components/VvInputText/index.d.ts +99 -29
  101. package/dist/components/VvNav/VvNav.es.js +135 -56
  102. package/dist/components/VvNav/VvNav.umd.js +1 -1
  103. package/dist/components/VvNav/VvNav.vue.d.ts +32 -9
  104. package/dist/components/VvNav/VvNavItem.vue.d.ts +1 -1
  105. package/dist/components/VvNav/VvNavSeparator.vue.d.ts +1 -1
  106. package/dist/components/VvNav/index.d.ts +5 -2
  107. package/dist/components/VvNavItem/VvNavItem.es.js +91 -33
  108. package/dist/components/VvNavItem/VvNavItem.umd.js +1 -1
  109. package/dist/components/VvProgress/VvProgress.es.js +72 -26
  110. package/dist/components/VvProgress/VvProgress.umd.js +1 -1
  111. package/dist/components/VvProgress/VvProgress.vue.d.ts +10 -3
  112. package/dist/components/VvProgress/index.d.ts +4 -1
  113. package/dist/components/VvRadio/VvRadio.es.js +160 -103
  114. package/dist/components/VvRadio/VvRadio.umd.js +1 -1
  115. package/dist/components/VvRadio/VvRadio.vue.d.ts +103 -31
  116. package/dist/components/VvRadio/index.d.ts +50 -17
  117. package/dist/components/VvRadioGroup/VvRadioGroup.es.js +190 -107
  118. package/dist/components/VvRadioGroup/VvRadioGroup.umd.js +1 -1
  119. package/dist/components/VvRadioGroup/VvRadioGroup.vue.d.ts +101 -30
  120. package/dist/components/VvRadioGroup/index.d.ts +45 -12
  121. package/dist/components/VvSelect/VvSelect.es.js +251 -238
  122. package/dist/components/VvSelect/VvSelect.umd.js +1 -1
  123. package/dist/components/VvSelect/VvSelect.vue.d.ts +117 -44
  124. package/dist/components/VvSelect/index.d.ts +48 -14
  125. package/dist/components/VvTab/VvTab.es.js +191 -75
  126. package/dist/components/VvTab/VvTab.umd.js +1 -1
  127. package/dist/components/VvTab/VvTab.vue.d.ts +31 -7
  128. package/dist/components/VvTab/index.d.ts +4 -1
  129. package/dist/components/VvTextarea/VvTextarea.es.js +232 -224
  130. package/dist/components/VvTextarea/VvTextarea.umd.js +1 -1
  131. package/dist/components/VvTextarea/VvTextarea.vue.d.ts +156 -49
  132. package/dist/components/VvTextarea/index.d.ts +68 -19
  133. package/dist/components/VvTooltip/VvTooltip.es.js +79 -29
  134. package/dist/components/VvTooltip/VvTooltip.umd.js +1 -1
  135. package/dist/components/VvTooltip/VvTooltip.vue.d.ts +13 -6
  136. package/dist/components/VvTooltip/index.d.ts +5 -2
  137. package/dist/components/common/HintSlot.d.ts +1 -1
  138. package/dist/components/index.d.ts +10 -0
  139. package/dist/components/index.es.js +3534 -1650
  140. package/dist/components/index.umd.js +1 -1
  141. package/dist/composables/alert/useAlert.d.ts +99 -4
  142. package/dist/composables/alert/useInjectAlert.d.ts +1 -6
  143. package/dist/composables/dropdown/useInjectDropdown.d.ts +3 -23
  144. package/dist/composables/dropdown/useProvideDropdown.d.ts +3 -4
  145. package/dist/composables/group/useInjectedGroupState.d.ts +4 -5
  146. package/dist/composables/group/useProvideGroupState.d.ts +3 -3
  147. package/dist/composables/index.d.ts +1 -0
  148. package/dist/composables/index.es.js +92 -3
  149. package/dist/composables/index.umd.js +1 -1
  150. package/dist/composables/useBlurhash.d.ts +7 -0
  151. package/dist/composables/useComponentIcon.d.ts +9 -8
  152. package/dist/composables/usePersistence.d.ts +2 -0
  153. package/dist/composables/useVolver.d.ts +1 -1
  154. package/dist/constants.d.ts +34 -32
  155. package/dist/directives/index.d.ts +3 -5
  156. package/dist/directives/index.es.js +99 -43
  157. package/dist/directives/index.umd.js +1 -1
  158. package/dist/directives/v-tooltip.es.js +97 -38
  159. package/dist/directives/v-tooltip.umd.js +1 -1
  160. package/dist/icons.es.js +267 -267
  161. package/dist/icons.umd.js +1 -1
  162. package/dist/index.d.ts +3 -1
  163. package/dist/index.es.js +90 -16
  164. package/dist/index.umd.js +1 -1
  165. package/dist/props/index.d.ts +272 -81
  166. package/dist/resolvers/unplugin.d.ts +6 -1
  167. package/dist/resolvers/unplugin.es.js +87 -10
  168. package/dist/resolvers/unplugin.umd.js +1 -1
  169. package/dist/stories/AccordionGroup/AccordionGroup.stories.d.ts +143 -89
  170. package/dist/stories/AccordionGroup/AccordionGroupSlots.stories.d.ts +1075 -492
  171. package/dist/stories/AlertGroup/AlertGroupWithComposable.stories.d.ts +1 -1
  172. package/dist/stories/Blurhash/BlurhashComposable.stories.d.ts +4 -0
  173. package/dist/stories/Button/Button.settings.d.ts +0 -1
  174. package/dist/stories/Combobox/Combobox.settings.d.ts +8 -0
  175. package/dist/stories/Icon/Icon.settings.d.ts +1 -0
  176. package/dist/stories/InputFile/InputFile.settings.d.ts +56 -0
  177. package/dist/stories/InputFile/InputFile.stories.d.ts +12 -0
  178. package/dist/stories/InputFile/InputFileDropArea.stories.d.ts +9 -0
  179. package/dist/stories/InputFile/InputFileIconPosition.stories.d.ts +8 -0
  180. package/dist/stories/InputFile/InputFileSlots.stories.d.ts +7 -0
  181. package/dist/stories/Tab/Tab.settings.d.ts +2 -15
  182. package/dist/test/expect.d.ts +1 -1
  183. package/dist/types/alert.d.ts +9 -7
  184. package/dist/types/blurhash.d.ts +12 -0
  185. package/dist/types/generic.d.ts +1 -2
  186. package/dist/types/group.d.ts +37 -15
  187. package/dist/types/index.d.ts +7 -0
  188. package/dist/types/input-file.d.ts +16 -0
  189. package/dist/types/nav.d.ts +2 -2
  190. package/dist/utils/ObjectUtilities.d.ts +0 -1
  191. package/dist/workers/blurhash.d.ts +1 -0
  192. package/package.json +78 -78
  193. package/src/Volver.ts +31 -20
  194. package/src/assets/icons/detailed.json +1 -1
  195. package/src/assets/icons/normal.json +1 -1
  196. package/src/assets/icons/simple.json +1 -1
  197. package/src/components/VvAccordion/VvAccordion.vue +121 -58
  198. package/src/components/VvAccordion/index.ts +8 -23
  199. package/src/components/VvAccordionGroup/VvAccordionGroup.vue +164 -47
  200. package/src/components/VvAccordionGroup/index.ts +6 -6
  201. package/src/components/VvAction/VvAction.vue +17 -5
  202. package/src/components/VvAlert/index.ts +14 -9
  203. package/src/components/VvAlertGroup/index.ts +3 -15
  204. package/src/components/VvBreadcrumb/VvBreadcrumb.vue +20 -19
  205. package/src/components/VvBreadcrumb/index.ts +2 -8
  206. package/src/components/VvButton/VvButton.vue +17 -7
  207. package/src/components/VvButton/index.ts +9 -16
  208. package/src/components/VvButtonGroup/VvButtonGroup.vue +1 -2
  209. package/src/components/VvCheckbox/index.ts +2 -2
  210. package/src/components/VvCheckboxGroup/VvCheckboxGroup.vue +1 -2
  211. package/src/components/VvCombobox/VvCombobox.vue +15 -12
  212. package/src/components/VvCombobox/index.ts +4 -0
  213. package/src/components/VvDropdown/VvDropdown.vue +11 -2
  214. package/src/components/VvDropdown/VvDropdownItem.vue +4 -1
  215. package/src/components/VvDropdown/VvDropdownOption.vue +4 -21
  216. package/src/components/VvDropdown/index.ts +35 -1
  217. package/src/components/VvIcon/VvIcon.vue +2 -2
  218. package/src/components/VvIcon/index.ts +35 -48
  219. package/src/components/VvInputFile/VvInputFile.vue +395 -0
  220. package/src/components/VvInputFile/index.ts +135 -0
  221. package/src/components/VvInputText/VvInputClearAction.ts +10 -6
  222. package/src/components/VvInputText/VvInputPasswordAction.ts +13 -9
  223. package/src/components/VvInputText/VvInputText.vue +141 -33
  224. package/src/components/VvInputText/index.ts +31 -16
  225. package/src/components/VvNav/VvNav.vue +4 -2
  226. package/src/components/VvRadio/index.ts +5 -5
  227. package/src/components/VvRadioGroup/VvRadioGroup.vue +1 -2
  228. package/src/components/VvSelect/VvSelect.vue +5 -8
  229. package/src/components/VvTab/VvTab.vue +5 -1
  230. package/src/components/VvTextarea/VvTextarea.vue +6 -9
  231. package/src/components/index.ts +10 -0
  232. package/src/composables/alert/useAlert.ts +12 -9
  233. package/src/composables/dropdown/useProvideDropdown.ts +4 -4
  234. package/src/composables/group/useInjectedGroupState.ts +20 -16
  235. package/src/composables/group/useProvideGroupState.ts +10 -15
  236. package/src/composables/index.ts +1 -0
  237. package/src/composables/useBlurhash.ts +76 -0
  238. package/src/composables/useComponentIcon.ts +15 -14
  239. package/src/composables/usePersistence.ts +76 -0
  240. package/src/composables/useUniqueId.ts +2 -2
  241. package/src/constants.ts +47 -32
  242. package/src/directives/index.ts +3 -6
  243. package/src/directives/v-tooltip.ts +19 -10
  244. package/src/index.ts +3 -1
  245. package/src/props/index.ts +108 -31
  246. package/src/resolvers/unplugin.ts +24 -14
  247. package/src/stories/Accordion/Accordion.test.ts +1 -1
  248. package/src/stories/AccordionGroup/AccordionGroup.settings.ts +2 -2
  249. package/src/stories/AccordionGroup/AccordionGroup.test.ts +17 -11
  250. package/src/stories/AccordionGroup/AccordionGroupSlots.stories.ts +1 -1
  251. package/src/stories/Alert/Alert.test.ts +1 -1
  252. package/src/stories/AlertGroup/AlertGroup.test.ts +1 -1
  253. package/src/stories/AlertGroup/AlertGroupWithComposable.stories.ts +2 -2
  254. package/src/stories/Avatar/Avatar.test.ts +1 -1
  255. package/src/stories/AvatarGroup/AvatarGroup.test.ts +1 -1
  256. package/src/stories/Badge/Badge.test.ts +1 -1
  257. package/src/stories/Blurhash/BlurhashComposable.stories.ts +195 -0
  258. package/src/stories/Button/Button.settings.ts +1 -4
  259. package/src/stories/Button/Button.test.ts +1 -1
  260. package/src/stories/ButtonGroup/ButtonGroup.test.ts +1 -1
  261. package/src/stories/Card/Card.test.ts +1 -1
  262. package/src/stories/Checkbox/Checkbox.test.ts +1 -1
  263. package/src/stories/CheckboxGroup/CheckboxGroup.test.ts +1 -1
  264. package/src/stories/Combobox/Combobox.settings.ts +8 -0
  265. package/src/stories/Combobox/Combobox.test.ts +1 -1
  266. package/src/stories/Dialog/Dialog.test.ts +2 -2
  267. package/src/stories/Dropdown/Dropdown.test.ts +1 -1
  268. package/src/stories/Icon/Icon.settings.ts +3 -3
  269. package/src/stories/InputFile/InputFile.settings.ts +36 -0
  270. package/src/stories/InputFile/InputFile.stories.ts +89 -0
  271. package/src/stories/InputFile/InputFileDropArea.stories.ts +56 -0
  272. package/src/stories/InputFile/InputFileIconPosition.stories.ts +43 -0
  273. package/src/stories/InputFile/InputFileSlots.stories.ts +33 -0
  274. package/src/stories/InputText/InputText.test.ts +1 -1
  275. package/src/stories/Nav/Nav.test.ts +1 -1
  276. package/src/stories/Progress/Progress.test.ts +1 -1
  277. package/src/stories/Radio/Radio.test.ts +1 -1
  278. package/src/stories/RadioGroup/RadioGroup.test.ts +1 -1
  279. package/src/stories/Select/Select.test.ts +1 -1
  280. package/src/stories/Tab/Tab.settings.ts +2 -2
  281. package/src/stories/Tab/Tab.test.ts +1 -1
  282. package/src/stories/Textarea/Textarea.test.ts +1 -1
  283. package/src/stories/Tooltip/Tooltip.test.ts +1 -1
  284. package/src/stories/argTypes.ts +1 -1
  285. package/src/test/expect.ts +2 -4
  286. package/src/types/alert.ts +11 -7
  287. package/src/types/blurhash.ts +21 -0
  288. package/src/types/generic.ts +3 -3
  289. package/src/types/group.ts +22 -14
  290. package/src/types/index.ts +7 -0
  291. package/src/types/input-file.ts +18 -0
  292. package/src/types/nav.ts +2 -3
  293. package/src/utils/ObjectUtilities.ts +0 -11
  294. package/src/workers/blurhash.ts +9 -0
@@ -1,100 +1,15 @@
1
- import { inject, computed, unref, defineComponent, ref, toRefs, openBlock, createBlock, mergeProps, createCommentVNode, watch, withModifiers, createElementBlock, normalizeProps, guardReactiveProps, renderSlot, createTextVNode, toDisplayString, createElementVNode } from "vue";
1
+ import { inject, computed, unref, defineComponent, mergeDefaults, ref, toRefs, openBlock, createBlock, mergeProps, createCommentVNode, watch, withModifiers, createElementBlock, normalizeProps, guardReactiveProps, renderSlot, createTextVNode, toDisplayString, createElementVNode } from "vue";
2
2
  import { iconExists, Icon, addIcon } from "@iconify/vue";
3
- import { nanoid } from "nanoid";
4
- const VvIconProps = {
5
- /**
6
- * Color
7
- */
8
- color: String,
9
- /**
10
- * Width
11
- */
12
- width: {
13
- type: [String, Number]
14
- },
15
- /**
16
- * Height
17
- */
18
- height: {
19
- type: [String, Number]
20
- },
21
- /**
22
- * Icon name
23
- * Can be the full composition of iconify name "@{provider}:{prefix}:{name}" or "{prefix}:{name}" or "{name}"
24
- * https://docs.iconify.design/api/providers.html#provider-in-icon-name
25
- */
26
- name: {
27
- type: String,
28
- required: true
29
- },
30
- /**
31
- * By default 'vv'
32
- * If custom collection is not added with "addCollection" DS class method, this prop could not be used
33
- * Icon provider: https://docs.iconify.design/api/providers.html#provider-in-icon-name
34
- */
35
- provider: {
36
- type: String
37
- },
38
- /**
39
- * The name of icon set.
40
- * Icon default options prefix: simple | normal | detailed
41
- */
42
- prefix: {
43
- type: String,
44
- default: "normal"
45
- },
46
- /**
47
- * Url remote SVG icon
48
- */
49
- src: String,
50
- /**
51
- * Horizontal flip
52
- */
53
- horizontalFlip: Boolean,
54
- /**
55
- * Vertical flip
56
- */
57
- verticalFlip: Boolean,
58
- /**
59
- * String alternative to "horizontalFlip" and "verticalFlip".
60
- * Example: https://docs.iconify.design/icon-components/vue/transform.html
61
- */
62
- flip: String,
63
- /**
64
- * Icon render mode
65
- * 'style' = 'bg' or 'mask', depending on icon content
66
- * 'bg' = span with style using `background`
67
- * 'mask' = span with style using `mask`
68
- * 'svg' = svg
69
- * Iconify doc: https://docs.iconify.design/iconify-icon/modes.html
70
- */
71
- mode: String,
72
- /**
73
- * Toggles inline or block mode
74
- * Example https://docs.iconify.design/icon-components/vue/inline.html
75
- */
76
- inline: Boolean,
77
- /**
78
- * rotates icon
79
- * Example https://docs.iconify.design/icon-components/vue/transform.html
80
- */
81
- rotate: [Number, String],
82
- /**
83
- * A callback that is called when icon data has been loaded
84
- */
85
- onLoad: Function,
86
- /**
87
- * SVG icon string
88
- */
89
- svg: String,
90
- /**
91
- * Icon modifiers: vv-icon css helper classes, value/s are concatened with prefix 'vv-icon--'
92
- * @values string | string[]
93
- */
94
- modifiers: {
95
- type: [String, Array]
96
- }
3
+ import { uid } from "uid";
4
+ const VvIconPropsDefaults = {
5
+ prefix: "normal"
6
+ /* normal */
97
7
  };
8
+ var StorageType = /* @__PURE__ */ ((StorageType2) => {
9
+ StorageType2["local"] = "local";
10
+ StorageType2["session"] = "session";
11
+ return StorageType2;
12
+ })(StorageType || {});
98
13
  var Strategy = /* @__PURE__ */ ((Strategy2) => {
99
14
  Strategy2["absolute"] = "absolute";
100
15
  Strategy2["fixed"] = "fixed";
@@ -129,13 +44,18 @@ var ButtonType = /* @__PURE__ */ ((ButtonType2) => {
129
44
  ButtonType2["reset"] = "reset";
130
45
  return ButtonType2;
131
46
  })(ButtonType || {});
132
- var AnchorTarget = /* @__PURE__ */ ((AnchorTarget2) => {
133
- AnchorTarget2["_blank"] = "_blank";
134
- AnchorTarget2["_self"] = "_self";
135
- AnchorTarget2["_parent"] = "_parent";
136
- AnchorTarget2["_top"] = "_top";
137
- return AnchorTarget2;
138
- })(AnchorTarget || {});
47
+ var ActionTag = /* @__PURE__ */ ((ActionTag2) => {
48
+ ActionTag2["nuxtLink"] = "nuxt-link";
49
+ ActionTag2["routerLink"] = "router-link";
50
+ ActionTag2["a"] = "a";
51
+ ActionTag2["button"] = "button";
52
+ return ActionTag2;
53
+ })(ActionTag || {});
54
+ var AlertRole = /* @__PURE__ */ ((AlertRole2) => {
55
+ AlertRole2["alert"] = "alert";
56
+ AlertRole2["alertdialog"] = "alertdialog";
57
+ return AlertRole2;
58
+ })(AlertRole || {});
139
59
  const INJECTION_KEY_VOLVER = Symbol.for("volver");
140
60
  const INJECTION_KEY_ALERT_GROUP = Symbol.for(
141
61
  "alertGroup"
@@ -171,7 +91,24 @@ const __default__$1 = {
171
91
  };
172
92
  const _sfc_main$1 = /* @__PURE__ */ defineComponent({
173
93
  ...__default__$1,
174
- props: VvIconProps,
94
+ props: /* @__PURE__ */ mergeDefaults({
95
+ name: {},
96
+ color: {},
97
+ width: {},
98
+ height: {},
99
+ provider: {},
100
+ prefix: {},
101
+ src: {},
102
+ horizontalFlip: { type: Boolean },
103
+ verticalFlip: { type: Boolean },
104
+ flip: {},
105
+ mode: {},
106
+ inline: { type: Boolean },
107
+ rotate: {},
108
+ onLoad: { type: Function },
109
+ svg: {},
110
+ modifiers: {}
111
+ }, VvIconPropsDefaults),
175
112
  setup(__props) {
176
113
  const props = __props;
177
114
  const hasRotate = computed(() => {
@@ -258,7 +195,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
258
195
  color: _ctx.color,
259
196
  onLoad: _ctx.onLoad,
260
197
  icon: unref(icon)
261
- }), null, 16, ["class"])) : createCommentVNode("", true);
198
+ }), null, 16, ["class"])) : createCommentVNode("v-if", true);
262
199
  };
263
200
  }
264
201
  });
@@ -277,10 +214,7 @@ const LinkProps = {
277
214
  /**
278
215
  * Anchor target
279
216
  */
280
- target: {
281
- type: String,
282
- validator: (value) => Object.values(AnchorTarget).includes(value)
283
- },
217
+ target: String,
284
218
  /**
285
219
  * Anchor rel
286
220
  */
@@ -293,44 +227,56 @@ const DisabledProps = {
293
227
  /**
294
228
  * Whether the form control is disabled
295
229
  */
296
- disabled: Boolean
230
+ disabled: {
231
+ type: Boolean,
232
+ default: false
233
+ }
297
234
  };
298
235
  const ActiveProps = {
299
236
  /**
300
237
  * Whether the item is active
301
238
  */
302
- active: Boolean
239
+ active: {
240
+ type: Boolean,
241
+ default: false
242
+ }
303
243
  };
304
244
  const CurrentProps = {
305
245
  /**
306
246
  * Whether the item is current
307
247
  */
308
- current: Boolean
248
+ current: {
249
+ type: Boolean,
250
+ default: false
251
+ }
309
252
  };
310
253
  const PressedProps = {
311
254
  /**
312
255
  * Whether the item is pressed
313
256
  */
314
- pressed: Boolean
257
+ pressed: {
258
+ type: Boolean,
259
+ default: false
260
+ }
315
261
  };
316
262
  const LabelProps = {
317
263
  /**
318
264
  * The item label
319
265
  */
320
- label: [String, Number]
321
- };
322
- const ModifiersProps = {
323
- /**
324
- * Component BEM modifiers
325
- */
326
- modifiers: [String, Array]
266
+ label: {
267
+ type: [String, Number],
268
+ default: void 0
269
+ }
327
270
  };
328
271
  const IconProps = {
329
272
  /**
330
273
  * VvIcon name or props
331
274
  * @see VVIcon
332
275
  */
333
- icon: { type: [String, Object] },
276
+ icon: {
277
+ type: [String, Object],
278
+ default: void 0
279
+ },
334
280
  /**
335
281
  * VvIcon position
336
282
  */
@@ -368,7 +314,8 @@ const IdProps = {
368
314
  * Dropdown show / hide transition name
369
315
  */
370
316
  transitionName: {
371
- type: String
317
+ type: String,
318
+ default: void 0
372
319
  },
373
320
  /**
374
321
  * Offset of the dropdown from the trigger
@@ -436,7 +383,8 @@ const IdProps = {
436
383
  * Set dropdown width to the same as the trigger
437
384
  */
438
385
  triggerWidth: {
439
- type: Boolean
386
+ type: Boolean,
387
+ default: false
440
388
  }
441
389
  });
442
390
  ({
@@ -460,16 +408,72 @@ const IdProps = {
460
408
  ariaLabel: {
461
409
  type: String,
462
410
  default: void 0
411
+ },
412
+ /**
413
+ * Default tag for the action
414
+ */
415
+ defaultTag: {
416
+ type: String,
417
+ default: ActionTag.button
463
418
  }
464
419
  });
420
+ ({
421
+ storageType: {
422
+ type: String,
423
+ default: StorageType.local,
424
+ validator: (value) => Object.values(StorageType).includes(value)
425
+ },
426
+ storageKey: String
427
+ });
465
428
  function useInjectedAlertGroup() {
466
429
  return inject(INJECTION_KEY_ALERT_GROUP, {});
467
430
  }
468
- const useUniqueId = (id) => computed(() => String((id == null ? void 0 : id.value) || nanoid()));
431
+ const useUniqueId = (id) => computed(() => String((id == null ? void 0 : id.value) || uid()));
432
+ function useComponentIcon(icon, iconPosition) {
433
+ const hasIcon = computed(() => {
434
+ if (typeof (icon == null ? void 0 : icon.value) === "string") {
435
+ return { name: icon == null ? void 0 : icon.value };
436
+ }
437
+ return icon == null ? void 0 : icon.value;
438
+ });
439
+ const hasIconBefore = computed(
440
+ () => (iconPosition == null ? void 0 : iconPosition.value) === Position.before ? hasIcon.value : void 0
441
+ );
442
+ const hasIconAfter = computed(
443
+ () => (iconPosition == null ? void 0 : iconPosition.value) === Position.after ? hasIcon.value : void 0
444
+ );
445
+ const hasIconLeft = computed(
446
+ () => (iconPosition == null ? void 0 : iconPosition.value) === Side.left ? hasIcon.value : void 0
447
+ );
448
+ const hasIconRight = computed(
449
+ () => (iconPosition == null ? void 0 : iconPosition.value) === Side.right ? hasIcon.value : void 0
450
+ );
451
+ const hasIconTop = computed(
452
+ () => (iconPosition == null ? void 0 : iconPosition.value) === Side.top ? hasIcon.value : void 0
453
+ );
454
+ const hasIconBottom = computed(
455
+ () => (iconPosition == null ? void 0 : iconPosition.value) === Side.bottom ? hasIcon.value : void 0
456
+ );
457
+ return {
458
+ hasIcon,
459
+ hasIconLeft,
460
+ hasIconRight,
461
+ hasIconTop,
462
+ hasIconBottom,
463
+ hasIconBefore,
464
+ hasIconAfter
465
+ };
466
+ }
469
467
  const VvAlertProps = {
470
468
  ...IdProps,
471
- ...ModifiersProps,
472
469
  ...IconProps,
470
+ /**
471
+ * Component BEM modifiers
472
+ */
473
+ modifiers: {
474
+ type: [String, Array],
475
+ default: void 0
476
+ },
473
477
  /**
474
478
  * The alert is dismissable
475
479
  * @default false
@@ -534,7 +538,7 @@ const VvAlertProps = {
534
538
  */
535
539
  role: {
536
540
  type: String,
537
- default: "alert"
541
+ default: AlertRole.alert
538
542
  }
539
543
  };
540
544
  const VvAlertEvents = ["close"];
@@ -542,9 +546,7 @@ const useVvAlert = (props, emit) => {
542
546
  const { bus } = useInjectedAlertGroup();
543
547
  const hasId = useUniqueId(computed(() => props.id));
544
548
  const hasTitleId = computed(() => `${hasId.value}-title`);
545
- const hasIcon = computed(
546
- () => typeof props.icon === "string" ? { name: props.icon } : props.icon
547
- );
549
+ const { hasIcon } = useComponentIcon(computed(() => props.icon));
548
550
  const hasClass = useModifiers(
549
551
  "vv-alert",
550
552
  computed(() => props.modifiers),
@@ -613,7 +615,13 @@ const _hoisted_1 = {
613
615
  };
614
616
  const _hoisted_2 = ["id"];
615
617
  const _hoisted_3 = ["aria-label"];
616
- const _hoisted_4 = /* @__PURE__ */ createElementVNode("div", { class: "vv-alert__close-mask" }, null, -1);
618
+ const _hoisted_4 = /* @__PURE__ */ createElementVNode(
619
+ "div",
620
+ { class: "vv-alert__close-mask" },
621
+ null,
622
+ -1
623
+ /* HOISTED */
624
+ );
617
625
  const _hoisted_5 = [
618
626
  _hoisted_4
619
627
  ];
@@ -632,52 +640,77 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
632
640
  ...__default__,
633
641
  props: VvAlertProps,
634
642
  emits: VvAlertEvents,
635
- setup(__props, { expose: __expose, emit }) {
643
+ setup(__props, { expose: __expose, emit: __emit }) {
636
644
  const props = __props;
645
+ const emit = __emit;
637
646
  const { hasProps, hasTitleId, hasIcon, close } = useVvAlert(props, emit);
638
647
  __expose({ close });
639
648
  return (_ctx, _cache) => {
640
- return openBlock(), createElementBlock("div", normalizeProps(guardReactiveProps(unref(hasProps))), [
641
- _ctx.$slots.header || _ctx.$slots.title || _ctx.$slots.close || _ctx.$slots["title::before"] || _ctx.$slots["title::after"] || _ctx.title || _ctx.dismissable || _ctx.autoClose ? (openBlock(), createElementBlock("div", _hoisted_1, [
642
- unref(hasIcon) ? (openBlock(), createBlock(_sfc_main$1, mergeProps({ key: 0 }, unref(hasIcon), { class: "vv-alert__icon" }), null, 16)) : createCommentVNode("", true),
643
- renderSlot(_ctx.$slots, "header", {}, () => [
644
- renderSlot(_ctx.$slots, "title::before"),
645
- _ctx.$slots.title || _ctx.title ? (openBlock(), createElementBlock("strong", {
646
- key: 0,
647
- id: unref(hasTitleId),
648
- class: "vv-alert__title"
649
- }, [
650
- renderSlot(_ctx.$slots, "title", {}, () => [
651
- createTextVNode(toDisplayString(_ctx.title), 1)
652
- ])
653
- ], 8, _hoisted_2)) : createCommentVNode("", true),
654
- renderSlot(_ctx.$slots, "title::after")
655
- ]),
656
- renderSlot(_ctx.$slots, "close", normalizeProps(guardReactiveProps({ close: unref(close) })), () => [
657
- _ctx.dismissable || _ctx.autoClose ? (openBlock(), createElementBlock("button", {
658
- key: 0,
659
- class: "vv-alert__close",
660
- type: "button",
661
- "aria-label": _ctx.closeLabel,
662
- onClick: _cache[0] || (_cache[0] = withModifiers(
663
- //@ts-ignore
664
- (...args) => unref(close) && unref(close)(...args),
665
- ["stop"]
666
- ))
667
- }, _hoisted_5, 8, _hoisted_3)) : createCommentVNode("", true)
668
- ])
669
- ])) : createCommentVNode("", true),
670
- _ctx.$slots.default || _ctx.content ? (openBlock(), createElementBlock("div", _hoisted_6, [
671
- renderSlot(_ctx.$slots, "default", {}, () => [
672
- createTextVNode(toDisplayString(_ctx.content), 1)
673
- ])
674
- ])) : createCommentVNode("", true),
675
- _ctx.$slots.footer || _ctx.footer ? (openBlock(), createElementBlock("div", _hoisted_7, [
676
- renderSlot(_ctx.$slots, "footer", {}, () => [
677
- createTextVNode(toDisplayString(_ctx.footer), 1)
678
- ])
679
- ])) : createCommentVNode("", true)
680
- ], 16);
649
+ return openBlock(), createElementBlock(
650
+ "div",
651
+ normalizeProps(guardReactiveProps(unref(hasProps))),
652
+ [
653
+ _ctx.$slots.header || _ctx.$slots.title || _ctx.$slots.close || _ctx.$slots["title::before"] || _ctx.$slots["title::after"] || _ctx.title || _ctx.dismissable || _ctx.autoClose ? (openBlock(), createElementBlock("div", _hoisted_1, [
654
+ unref(hasIcon) ? (openBlock(), createBlock(
655
+ _sfc_main$1,
656
+ mergeProps({ key: 0 }, unref(hasIcon), { class: "vv-alert__icon" }),
657
+ null,
658
+ 16
659
+ /* FULL_PROPS */
660
+ )) : createCommentVNode("v-if", true),
661
+ renderSlot(_ctx.$slots, "header", {}, () => [
662
+ renderSlot(_ctx.$slots, "title::before"),
663
+ _ctx.$slots.title || _ctx.title ? (openBlock(), createElementBlock("strong", {
664
+ key: 0,
665
+ id: unref(hasTitleId),
666
+ class: "vv-alert__title"
667
+ }, [
668
+ renderSlot(_ctx.$slots, "title", {}, () => [
669
+ createTextVNode(
670
+ toDisplayString(_ctx.title),
671
+ 1
672
+ /* TEXT */
673
+ )
674
+ ])
675
+ ], 8, _hoisted_2)) : createCommentVNode("v-if", true),
676
+ renderSlot(_ctx.$slots, "title::after")
677
+ ]),
678
+ renderSlot(_ctx.$slots, "close", normalizeProps(guardReactiveProps({ close: unref(close) })), () => [
679
+ _ctx.dismissable || _ctx.autoClose ? (openBlock(), createElementBlock("button", {
680
+ key: 0,
681
+ class: "vv-alert__close",
682
+ type: "button",
683
+ "aria-label": _ctx.closeLabel,
684
+ onClick: _cache[0] || (_cache[0] = withModifiers(
685
+ //@ts-ignore
686
+ (...args) => unref(close) && unref(close)(...args),
687
+ ["stop"]
688
+ ))
689
+ }, _hoisted_5, 8, _hoisted_3)) : createCommentVNode("v-if", true)
690
+ ])
691
+ ])) : createCommentVNode("v-if", true),
692
+ _ctx.$slots.default || _ctx.content ? (openBlock(), createElementBlock("div", _hoisted_6, [
693
+ renderSlot(_ctx.$slots, "default", {}, () => [
694
+ createTextVNode(
695
+ toDisplayString(_ctx.content),
696
+ 1
697
+ /* TEXT */
698
+ )
699
+ ])
700
+ ])) : createCommentVNode("v-if", true),
701
+ _ctx.$slots.footer || _ctx.footer ? (openBlock(), createElementBlock("div", _hoisted_7, [
702
+ renderSlot(_ctx.$slots, "footer", {}, () => [
703
+ createTextVNode(
704
+ toDisplayString(_ctx.footer),
705
+ 1
706
+ /* TEXT */
707
+ )
708
+ ])
709
+ ])) : createCommentVNode("v-if", true)
710
+ ],
711
+ 16
712
+ /* FULL_PROPS */
713
+ );
681
714
  };
682
715
  }
683
716
  });
@@ -1 +1 @@
1
- !function(e,o){"object"==typeof exports&&"undefined"!=typeof module?module.exports=o(require("vue"),require("@iconify/vue"),require("nanoid")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","nanoid"],o):(e="undefined"!=typeof globalThis?globalThis:e||self).VvAlert=o(e.vue,e.vue$1,e.nanoid)}(this,(function(e,o,t){"use strict";const l={color:String,width:{type:[String,Number]},height:{type:[String,Number]},name:{type:String,required:!0},provider:{type:String},prefix:{type:String,default:"normal"},src:String,horizontalFlip:Boolean,verticalFlip:Boolean,flip:String,mode:String,inline:Boolean,rotate:[Number,String],onLoad:Function,svg:String,modifiers:{type:[String,Array]}};var r=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(r||{}),n=(e=>(e.before="before",e.after="after",e))(n||{}),i=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(i||{});const a=Symbol.for("volver"),s=Symbol.for("alertGroup");function c(o,t,l){return e.computed((()=>{const r={[o]:!0},n="string"==typeof(null==t?void 0:t.value)?t.value.split(" "):null==t?void 0:t.value;return n&&Array.isArray(n)&&n.forEach((e=>{e&&(r[`${o}--${e}`]=!0)})),l&&Object.keys(l.value).forEach((t=>{r[`${o}--${t}`]=e.unref(l.value[t])})),r}))}const u=e.defineComponent({name:"VvIcon",props:l,setup(t){const l=t,r=e.computed((()=>"string"==typeof l.rotate?parseFloat(l.rotate):l.rotate)),n=e.ref(!0),i=e.inject(a),{modifiers:s}=e.toRefs(l),u=c("vv-icon",s),d=e.computed((()=>l.provider||(null==i?void 0:i.iconsProvider))),f=e.computed((()=>{const e=l.name??"",t=`@${d.value}:${l.prefix}:${e}`;if(o.iconExists(t))return t;const r=null==i?void 0:i.iconsCollections.find((t=>{const l=`@${d.value}:${t.prefix}:${e}`;return o.iconExists(l)}));return r?`@${d.value}:${r.prefix}:${e}`:e}));function p(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),r=(null==t?void 0:t.innerHTML.trim())||"";t&&r&&o.addIcon(`@${d.value}:${l.prefix}:${l.name}`,{body:r,height:t.viewBox.baseVal.height,width:t.viewBox.baseVal.width})}return i&&l.src&&!o.iconExists(`@${d.value}:${l.prefix}:${l.name}`)&&(n.value=!1,i.fetchIcon(l.src).then((e=>{e&&(p(e),n.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),l.svg&&p(l.svg),(t,l)=>e.unref(n)?(e.openBlock(),e.createBlock(e.unref(o.Icon),e.mergeProps({key:0,class:e.unref(u)},{inline:t.inline,width:t.width,height:t.height,horizontalFlip:t.horizontalFlip,verticalFlip:t.verticalFlip,flip:t.flip,rotate:e.unref(r),color:t.color,onLoad:t.onLoad,icon:e.unref(f)}),null,16,["class"])):e.createCommentVNode("",!0)}}),d=(Boolean,Boolean,Boolean,Boolean,{modifiers:[String,Array]}),f={icon:{type:[String,Object]},iconPosition:{type:String,default:n.before,validation:e=>Object.values(n).includes(e)}},p={id:[String,Number]};r.bottom,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,Boolean,i.button;const m={...p,...d,...f,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"}},v=(o,l)=>{const{bus:r}=e.inject(s,{}),n=(i=e.computed((()=>o.id)),e.computed((()=>String((null==i?void 0:i.value)||t.nanoid()))));var i;const a=e.computed((()=>`${n.value}-title`)),u=e.computed((()=>"string"==typeof o.icon?{name:o.icon}:o.icon)),d=c("vv-alert",e.computed((()=>o.modifiers)),e.computed((()=>({dismissable:o.autoClose>0||o.dismissable,"auto-close":o.autoClose>0,hover:v.value})))),f=e.computed((()=>({"--alert-duration":`${o.autoClose}ms`}))),p=()=>{m&&clearTimeout(m),l("close",n.value),null==r||r.emit("close",n.value)};let m;e.watch((()=>o.autoClose),(e=>{e>0?m=setTimeout(p,e):m&&clearTimeout(m)}),{immediate:!0});const v=e.ref(!1),g=e.withModifiers((()=>{v.value=!0,m&&clearTimeout(m)}),["passive"]),y=e.withModifiers((()=>{v.value=!1,o.autoClose>0&&(m=setTimeout(p,o.autoClose))}),["passive"]);return{close:p,hasIcon:u,hasTitleId:a,hasProps:e.computed((()=>({onMouseover:g,onMouseleave:y,class:d.value,style:f.value,role:o.role,"aria-labelledby":a.value})))}},g={key:0,class:"vv-alert__header"},y=["id"],h=["aria-label"],b=[e.createElementVNode("div",{class:"vv-alert__close-mask"},null,-1)],$={key:1,class:"vv-alert__content"},S={key:2,class:"vv-alert__footer"};return e.defineComponent({name:"VvAlert",props:m,emits:["close"],setup(o,{expose:t,emit:l}){const r=o,{hasProps:n,hasTitleId:i,hasIcon:a,close:s}=v(r,l);return t({close:s}),(o,t)=>(e.openBlock(),e.createElementBlock("div",e.normalizeProps(e.guardReactiveProps(e.unref(n))),[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",g,[e.unref(a)?(e.openBlock(),e.createBlock(u,e.mergeProps({key:0},e.unref(a),{class:"vv-alert__icon"}),null,16)):e.createCommentVNode("",!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(i),class:"vv-alert__title"},[e.renderSlot(o.$slots,"title",{},(()=>[e.createTextVNode(e.toDisplayString(o.title),1)]))],8,y)):e.createCommentVNode("",!0),e.renderSlot(o.$slots,"title::after")])),e.renderSlot(o.$slots,"close",e.normalizeProps(e.guardReactiveProps({close:e.unref(s)})),(()=>[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(s)&&e.unref(s)(...o)),["stop"]))},b,8,h)):e.createCommentVNode("",!0)]))])):e.createCommentVNode("",!0),o.$slots.default||o.content?(e.openBlock(),e.createElementBlock("div",$,[e.renderSlot(o.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(o.content),1)]))])):e.createCommentVNode("",!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("",!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,21 +29,27 @@ 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: (ObjectConstructor | StringConstructor)[];
35
+ type: globalThis.PropType<string | import("../VvIcon/index.js").VvIconProps>;
36
+ default: undefined;
32
37
  };
33
38
  iconPosition: {
34
39
  type: globalThis.PropType<"before" | "after">;
35
- default: import("../../constants").Position;
36
- validation: (value: import("../../constants").Position) => boolean;
40
+ default: import("../../constants.js").Position;
41
+ validation: (value: import("../../constants.js").Position) => boolean;
37
42
  };
38
- modifiers: globalThis.PropType<string | string[]>;
39
43
  id: (StringConstructor | NumberConstructor)[];
40
44
  }, {
41
45
  close: () => void;
42
- }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, string[], string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
46
+ }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
47
+ [x: string]: (...args: any[]) => void;
48
+ }, string, import("vue").PublicProps, Readonly<globalThis.ExtractPropTypes<{
49
+ modifiers: {
50
+ type: globalThis.PropType<string | string[]>;
51
+ default: undefined;
52
+ };
43
53
  dismissable: {
44
54
  type: BooleanConstructor;
45
55
  default: boolean;
@@ -66,25 +76,25 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
66
76
  };
67
77
  role: {
68
78
  type: globalThis.PropType<"alert" | "alertdialog">;
69
- default: string;
79
+ default: import("../../constants.js").AlertRole;
70
80
  };
71
81
  icon: {
72
- type: (ObjectConstructor | StringConstructor)[];
82
+ type: globalThis.PropType<string | import("../VvIcon/index.js").VvIconProps>;
83
+ default: undefined;
73
84
  };
74
85
  iconPosition: {
75
86
  type: globalThis.PropType<"before" | "after">;
76
- default: import("../../constants").Position;
77
- validation: (value: import("../../constants").Position) => boolean;
87
+ default: import("../../constants.js").Position;
88
+ validation: (value: import("../../constants.js").Position) => boolean;
78
89
  };
79
- modifiers: globalThis.PropType<string | string[]>;
80
90
  id: (StringConstructor | NumberConstructor)[];
81
- }>> & {
82
- [x: `on${Capitalize<string>}`]: ((...args: any[]) => any) | undefined;
83
- }, {
91
+ }>>, {
84
92
  title: string;
85
93
  content: string;
94
+ modifiers: string | string[];
86
95
  footer: string;
87
96
  role: "alert" | "alertdialog";
97
+ icon: string | import("../VvIcon/index.js").VvIconProps;
88
98
  dismissable: boolean;
89
99
  autoClose: number;
90
100
  closeLabel: string;
@@ -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,27 +72,27 @@ 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
- type: (ObjectConstructor | StringConstructor)[];
78
+ type: PropType<string | import("../VvIcon").VvIconProps>;
79
+ default: undefined;
71
80
  };
72
81
  iconPosition: {
73
82
  type: PropType<"before" | "after">;
74
- default: import("../../constants").Position;
75
- validation: (value: import("../../constants").Position) => boolean;
83
+ default: import("@/constants").Position;
84
+ validation: (value: import("@/constants").Position) => boolean;
76
85
  };
77
- modifiers: PropType<string | string[]>;
78
86
  id: (StringConstructor | NumberConstructor)[];
79
87
  };
80
88
  export declare const VvAlertEvents: string[];
81
89
  export declare const useVvAlert: (props: Readonly<ExtractPropTypes<typeof VvAlertProps>>, emit: (event: string, ...args: unknown[]) => void) => {
82
90
  close: () => void;
83
- hasIcon: globalThis.ComputedRef<Record<string, any> | undefined>;
91
+ hasIcon: globalThis.ComputedRef<import("../VvIcon").VvIconProps | undefined>;
84
92
  hasTitleId: globalThis.ComputedRef<string>;
85
93
  hasProps: globalThis.ComputedRef<{
86
- onMouseover: (event: Event, ...args: unknown[]) => any;
87
- onMouseleave: (event: Event, ...args: unknown[]) => any;
94
+ onMouseover: () => void;
95
+ onMouseleave: () => void;
88
96
  class: Record<string, boolean>;
89
97
  style: {
90
98
  '--alert-duration': string;