@volverjs/ui-vue 0.0.3-beta.4 → 0.0.4

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 (853) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +56 -16
  3. package/auto-imports.d.ts +10 -6
  4. package/bin/icons.cjs +8 -8
  5. package/bin/icons.js +8 -8
  6. package/dist/Volver.d.ts +43 -13
  7. package/dist/components/VvAccordion/VvAccordion.es.js +133 -59
  8. package/dist/components/VvAccordion/VvAccordion.umd.js +1 -1
  9. package/dist/components/VvAccordion/index.d.ts +2 -2
  10. package/dist/components/VvAccordionGroup/VvAccordionGroup.es.js +207 -100
  11. package/dist/components/VvAccordionGroup/VvAccordionGroup.umd.js +1 -1
  12. package/dist/components/VvAccordionGroup/VvAccordionGroup.vue.d.ts +1 -1
  13. package/dist/components/VvAction/VvAction.es.js +170 -0
  14. package/dist/components/VvAction/VvAction.umd.js +1 -0
  15. package/dist/components/VvAction/VvAction.vue.d.ts +63 -0
  16. package/dist/components/VvAction/index.d.ts +24 -0
  17. package/dist/components/VvBadge/VvBadge.es.js +92 -17
  18. package/dist/components/VvBadge/VvBadge.umd.js +1 -1
  19. package/dist/components/VvBreadcrumb/VvBreadcrumb.es.js +104 -57
  20. package/dist/components/VvBreadcrumb/VvBreadcrumb.umd.js +1 -1
  21. package/dist/components/VvButton/VvButton.es.js +526 -202
  22. package/dist/components/VvButton/VvButton.umd.js +1 -1
  23. package/dist/components/VvButton/VvButton.vue.d.ts +59 -62
  24. package/dist/components/VvButton/index.d.ts +32 -83
  25. package/dist/components/VvButtonGroup/VvButtonGroup.es.js +133 -43
  26. package/dist/components/VvButtonGroup/VvButtonGroup.umd.js +1 -1
  27. package/dist/components/VvButtonGroup/VvButtonGroup.vue.d.ts +1 -1
  28. package/dist/components/VvCard/VvCard.es.js +38 -27
  29. package/dist/components/VvCard/VvCard.umd.js +1 -1
  30. package/dist/components/VvCheckbox/VvCheckbox.es.js +386 -147
  31. package/dist/components/VvCheckbox/VvCheckbox.umd.js +1 -1
  32. package/dist/components/VvCheckbox/VvCheckbox.vue.d.ts +7 -5
  33. package/dist/components/VvCheckbox/index.d.ts +6 -10
  34. package/dist/components/VvCheckboxGroup/VvCheckboxGroup.es.js +475 -189
  35. package/dist/components/VvCheckboxGroup/VvCheckboxGroup.umd.js +1 -1
  36. package/dist/components/VvCheckboxGroup/VvCheckboxGroup.vue.d.ts +14 -3
  37. package/dist/components/VvCheckboxGroup/index.d.ts +6 -1
  38. package/dist/components/VvCombobox/VvCombobox.es.js +1488 -457
  39. package/dist/components/VvCombobox/VvCombobox.umd.js +1 -1
  40. package/dist/components/VvCombobox/VvCombobox.vue.d.ts +282 -25
  41. package/dist/components/VvCombobox/index.d.ts +141 -15
  42. package/dist/components/VvDialog/VvDialog.es.js +248 -82
  43. package/dist/components/VvDialog/VvDialog.umd.js +1 -1
  44. package/dist/components/VvDialog/VvDialog.vue.d.ts +3 -9
  45. package/dist/components/VvDialog/index.d.ts +16 -4
  46. package/dist/components/VvDropdown/VvDropdown.es.js +448 -89
  47. package/dist/components/VvDropdown/VvDropdown.umd.js +1 -1
  48. package/dist/components/VvDropdown/VvDropdown.vue.d.ts +184 -51
  49. package/dist/components/VvDropdown/VvDropdownAction.vue.d.ts +61 -0
  50. package/dist/components/VvDropdown/VvDropdownItem.vue.d.ts +9 -0
  51. package/dist/components/VvDropdown/VvDropdownOption.vue.d.ts +52 -0
  52. package/dist/components/VvDropdown/index.d.ts +70 -31
  53. package/dist/components/VvDropdownAction/VvDropdownAction.es.js +251 -0
  54. package/dist/components/VvDropdownAction/VvDropdownAction.umd.js +1 -0
  55. package/dist/components/VvDropdownItem/VvDropdownItem.es.js +38 -0
  56. package/dist/components/VvDropdownItem/VvDropdownItem.umd.js +1 -0
  57. package/dist/components/VvDropdownOption/VvDropdownOption.es.js +176 -0
  58. package/dist/components/VvDropdownOption/VvDropdownOption.umd.js +1 -0
  59. package/dist/components/VvIcon/VvIcon.es.js +113 -34
  60. package/dist/components/VvIcon/VvIcon.umd.js +1 -1
  61. package/dist/components/VvInputText/VvInputText.es.js +721 -342
  62. package/dist/components/VvInputText/VvInputText.umd.js +1 -1
  63. package/dist/components/VvInputText/VvInputText.vue.d.ts +21 -14
  64. package/dist/components/VvInputText/index.d.ts +17 -6
  65. package/dist/components/VvProgress/VvProgress.es.js +113 -19
  66. package/dist/components/VvProgress/VvProgress.umd.js +1 -1
  67. package/dist/components/VvRadio/VvRadio.es.js +345 -120
  68. package/dist/components/VvRadio/VvRadio.umd.js +1 -1
  69. package/dist/components/VvRadio/VvRadio.vue.d.ts +6 -4
  70. package/dist/components/VvRadio/index.d.ts +6 -4
  71. package/dist/components/VvRadioGroup/VvRadioGroup.es.js +434 -162
  72. package/dist/components/VvRadioGroup/VvRadioGroup.umd.js +1 -1
  73. package/dist/components/VvRadioGroup/VvRadioGroup.vue.d.ts +14 -3
  74. package/dist/components/VvRadioGroup/index.d.ts +6 -1
  75. package/dist/components/VvSelect/VvSelect.es.js +542 -222
  76. package/dist/components/VvSelect/VvSelect.umd.js +1 -1
  77. package/dist/components/VvSelect/VvSelect.vue.d.ts +44 -21
  78. package/dist/components/VvSelect/index.d.ts +13 -9
  79. package/dist/components/VvTextarea/VvTextarea.es.js +579 -236
  80. package/dist/components/VvTextarea/VvTextarea.umd.js +1 -1
  81. package/dist/components/VvTextarea/VvTextarea.vue.d.ts +20 -13
  82. package/dist/components/VvTextarea/index.d.ts +9 -6
  83. package/dist/components/VvTooltip/VvTooltip.es.js +104 -14
  84. package/dist/components/VvTooltip/VvTooltip.umd.js +1 -1
  85. package/dist/components/VvTooltip/VvTooltip.vue.d.ts +11 -5
  86. package/dist/components/VvTooltip/index.d.ts +7 -9
  87. package/dist/components/index.es.js +2800 -1423
  88. package/dist/components/index.umd.js +1 -1
  89. package/dist/composables/dropdown/useInjectDropdown.d.ts +31 -0
  90. package/dist/composables/dropdown/useProvideDropdown.d.ts +36 -0
  91. package/dist/composables/group/useInjectedGroupState.d.ts +4 -4
  92. package/dist/composables/group/useProvideGroupState.d.ts +2 -2
  93. package/dist/composables/useComponentIcon.d.ts +10 -0
  94. package/dist/composables/useModifiers.d.ts +1 -9
  95. package/dist/composables/useOptions.d.ts +2 -1
  96. package/dist/composables/useUniqueId.d.ts +2 -0
  97. package/dist/composables/useVolver.d.ts +2 -0
  98. package/dist/constants.d.ts +59 -4
  99. package/dist/directives/index.d.ts +4 -0
  100. package/dist/directives/index.es.js +128 -0
  101. package/dist/directives/index.umd.js +1 -0
  102. package/dist/directives/v-tooltip.d.ts +3 -0
  103. package/dist/directives/v-tooltip.es.js +126 -0
  104. package/dist/directives/v-tooltip.umd.js +1 -0
  105. package/dist/icons.d.ts +9 -0
  106. package/dist/icons.es.js +30 -21
  107. package/dist/icons.umd.js +1 -1
  108. package/dist/index.d.ts +1 -1
  109. package/dist/index.es.js +2866 -1455
  110. package/dist/index.umd.js +1 -1
  111. package/dist/props/index.d.ts +327 -33
  112. package/dist/resolvers/unplugin.d.ts +8 -8
  113. package/dist/resolvers/unplugin.es.js +54 -33
  114. package/dist/resolvers/unplugin.umd.js +1 -1
  115. package/dist/stories/CheckboxGroup/CheckboxGroup.settings.d.ts +14 -0
  116. package/dist/stories/Combobox/Combobox.settings.d.ts +270 -3
  117. package/dist/stories/Dropdown/Dropdown.settings.d.ts +139 -28
  118. package/dist/stories/Dropdown/Dropdown.test.d.ts +1 -1
  119. package/dist/stories/InputText/InputText.settings.d.ts +24 -24
  120. package/dist/stories/RadioGroup/RadioGroup.settings.d.ts +14 -0
  121. package/dist/stories/Select/Select.settings.d.ts +15 -1
  122. package/dist/stories/Textarea/Textarea.settings.d.ts +24 -24
  123. package/dist/stories/Tooltip/Tooltip.settings.d.ts +1 -1
  124. package/dist/stories/argTypes.d.ts +164 -3
  125. package/package.json +83 -48
  126. package/src/Volver.ts +152 -33
  127. package/src/assets/icons/detailed/add-circle.svg +12 -1
  128. package/src/assets/icons/detailed/add.svg +8 -1
  129. package/src/assets/icons/detailed/align-center.svg +12 -1
  130. package/src/assets/icons/detailed/align-justify.svg +12 -1
  131. package/src/assets/icons/detailed/align-left.svg +12 -1
  132. package/src/assets/icons/detailed/align-right.svg +12 -1
  133. package/src/assets/icons/detailed/analysis-2.svg +20 -1
  134. package/src/assets/icons/detailed/analysis-3.svg +8 -1
  135. package/src/assets/icons/detailed/analysis.svg +16 -1
  136. package/src/assets/icons/detailed/apple.svg +16 -1
  137. package/src/assets/icons/detailed/arrow-down.svg +8 -1
  138. package/src/assets/icons/detailed/arrow-left.svg +8 -1
  139. package/src/assets/icons/detailed/arrow-right.svg +8 -1
  140. package/src/assets/icons/detailed/arrow-up.svg +8 -1
  141. package/src/assets/icons/detailed/attachment.svg +8 -1
  142. package/src/assets/icons/detailed/back-to-front.svg +17 -1
  143. package/src/assets/icons/detailed/bell-active.svg +14 -1
  144. package/src/assets/icons/detailed/bell.svg +14 -1
  145. package/src/assets/icons/detailed/bold.svg +8 -1
  146. package/src/assets/icons/detailed/bookmark-active.svg +12 -1
  147. package/src/assets/icons/detailed/bookmark.svg +12 -1
  148. package/src/assets/icons/detailed/building.svg +26 -1
  149. package/src/assets/icons/detailed/bullet-list.svg +22 -1
  150. package/src/assets/icons/detailed/calendar.svg +26 -1
  151. package/src/assets/icons/detailed/camera-off.svg +12 -1
  152. package/src/assets/icons/detailed/camera-on.svg +17 -1
  153. package/src/assets/icons/detailed/catalog.svg +15 -1
  154. package/src/assets/icons/detailed/certificate.svg +10 -1
  155. package/src/assets/icons/detailed/chat.svg +6 -1
  156. package/src/assets/icons/detailed/check-badge.svg +9 -1
  157. package/src/assets/icons/detailed/check-circle.svg +10 -1
  158. package/src/assets/icons/detailed/check.svg +6 -1
  159. package/src/assets/icons/detailed/checkbox.svg +8 -1
  160. package/src/assets/icons/detailed/chevron-down-circle.svg +10 -1
  161. package/src/assets/icons/detailed/chevron-down.svg +6 -1
  162. package/src/assets/icons/detailed/chevron-left-circle.svg +10 -1
  163. package/src/assets/icons/detailed/chevron-left.svg +6 -1
  164. package/src/assets/icons/detailed/chevron-right-circle.svg +7 -1
  165. package/src/assets/icons/detailed/chevron-up-circle.svg +10 -1
  166. package/src/assets/icons/detailed/chevron-up.svg +6 -1
  167. package/src/assets/icons/detailed/circle.svg +8 -0
  168. package/src/assets/icons/detailed/classroom.svg +38 -1
  169. package/src/assets/icons/detailed/clear-field.svg +14 -1
  170. package/src/assets/icons/detailed/clear-style.svg +9 -1
  171. package/src/assets/icons/detailed/close-circle.svg +14 -1
  172. package/src/assets/icons/detailed/close-loader.svg +6 -1
  173. package/src/assets/icons/detailed/close.svg +8 -1
  174. package/src/assets/icons/detailed/coffee.svg +21 -1
  175. package/src/assets/icons/detailed/color.svg +20 -1
  176. package/src/assets/icons/detailed/contact-us.svg +27 -1
  177. package/src/assets/icons/detailed/copy.svg +10 -1
  178. package/src/assets/icons/detailed/courses.svg +22 -1
  179. package/src/assets/icons/detailed/dashboard.svg +20 -1
  180. package/src/assets/icons/detailed/download.svg +10 -1
  181. package/src/assets/icons/detailed/drag.svg +10 -1
  182. package/src/assets/icons/detailed/duplicate.svg +23 -1
  183. package/src/assets/icons/detailed/edit.svg +16 -1
  184. package/src/assets/icons/detailed/elearning.svg +13 -1
  185. package/src/assets/icons/detailed/email.svg +11 -1
  186. package/src/assets/icons/detailed/error-2.svg +8 -1
  187. package/src/assets/icons/detailed/error.svg +12 -1
  188. package/src/assets/icons/detailed/exercise.svg +26 -1
  189. package/src/assets/icons/detailed/external-link.svg +11 -1
  190. package/src/assets/icons/detailed/extract.svg +20 -1
  191. package/src/assets/icons/detailed/eye-off.svg +15 -1
  192. package/src/assets/icons/detailed/eye-on.svg +8 -1
  193. package/src/assets/icons/detailed/fail.svg +11 -1
  194. package/src/assets/icons/detailed/fast-back.svg +20 -1
  195. package/src/assets/icons/detailed/fast-forward.svg +20 -1
  196. package/src/assets/icons/detailed/file-add.svg +19 -1
  197. package/src/assets/icons/detailed/file-duplicate.svg +16 -1
  198. package/src/assets/icons/detailed/file-remove.svg +17 -1
  199. package/src/assets/icons/detailed/file-required.svg +23 -1
  200. package/src/assets/icons/detailed/file.svg +13 -1
  201. package/src/assets/icons/detailed/filter-2.svg +22 -1
  202. package/src/assets/icons/detailed/filter-active.svg +12 -1
  203. package/src/assets/icons/detailed/filter.svg +12 -1
  204. package/src/assets/icons/detailed/flag.svg +11 -1
  205. package/src/assets/icons/detailed/folder.svg +14 -1
  206. package/src/assets/icons/detailed/full-width.svg +11 -1
  207. package/src/assets/icons/detailed/go-to-back.svg +19 -1
  208. package/src/assets/icons/detailed/grid.svg +20 -1
  209. package/src/assets/icons/detailed/group-add.svg +24 -1
  210. package/src/assets/icons/detailed/group.svg +16 -1
  211. package/src/assets/icons/detailed/heart-active.svg +12 -1
  212. package/src/assets/icons/detailed/heart.svg +12 -1
  213. package/src/assets/icons/detailed/highlighter.svg +10 -1
  214. package/src/assets/icons/detailed/home.svg +12 -1
  215. package/src/assets/icons/detailed/hourglass.svg +12 -1
  216. package/src/assets/icons/detailed/image.svg +15 -1
  217. package/src/assets/icons/detailed/info-badge.svg +9 -1
  218. package/src/assets/icons/detailed/information.svg +12 -1
  219. package/src/assets/icons/detailed/italic.svg +10 -1
  220. package/src/assets/icons/detailed/key.svg +5 -1
  221. package/src/assets/icons/detailed/language.svg +14 -1
  222. package/src/assets/icons/detailed/learning-path.svg +7 -1
  223. package/src/assets/icons/detailed/light-off.svg +10 -1
  224. package/src/assets/icons/detailed/light-on.svg +18 -1
  225. package/src/assets/icons/detailed/link.svg +12 -1
  226. package/src/assets/icons/detailed/lock.svg +13 -1
  227. package/src/assets/icons/detailed/login.svg +11 -1
  228. package/src/assets/icons/detailed/logout.svg +11 -1
  229. package/src/assets/icons/detailed/maximaze.svg +12 -1
  230. package/src/assets/icons/detailed/menu.svg +9 -1
  231. package/src/assets/icons/detailed/merge.svg +20 -1
  232. package/src/assets/icons/detailed/minimize.svg +14 -1
  233. package/src/assets/icons/detailed/mixed-class.svg +40 -1
  234. package/src/assets/icons/detailed/more-horizontal.svg +7 -1
  235. package/src/assets/icons/detailed/more-vertical.svg +7 -1
  236. package/src/assets/icons/detailed/news.svg +12 -1
  237. package/src/assets/icons/detailed/no-prerequisites.svg +13 -1
  238. package/src/assets/icons/detailed/notes.svg +14 -1
  239. package/src/assets/icons/detailed/number-code.svg +34 -1
  240. package/src/assets/icons/detailed/numbered-list.svg +18 -1
  241. package/src/assets/icons/detailed/on-site.svg +22 -1
  242. package/src/assets/icons/detailed/order-down.svg +12 -1
  243. package/src/assets/icons/detailed/order-up.svg +12 -1
  244. package/src/assets/icons/detailed/paste.svg +14 -1
  245. package/src/assets/icons/detailed/pausa.svg +8 -1
  246. package/src/assets/icons/detailed/pdf.svg +12 -1
  247. package/src/assets/icons/detailed/phone.svg +10 -1
  248. package/src/assets/icons/detailed/pin-map.svg +12 -1
  249. package/src/assets/icons/detailed/pin.svg +15 -1
  250. package/src/assets/icons/detailed/pizza.svg +17 -1
  251. package/src/assets/icons/detailed/play.svg +11 -1
  252. package/src/assets/icons/detailed/plug-in.svg +10 -1
  253. package/src/assets/icons/detailed/pointer.svg +12 -1
  254. package/src/assets/icons/detailed/printer.svg +26 -1
  255. package/src/assets/icons/detailed/profile-add.svg +20 -1
  256. package/src/assets/icons/detailed/profile.svg +10 -1
  257. package/src/assets/icons/detailed/push-pin-off.svg +11 -1
  258. package/src/assets/icons/detailed/push-pin-on.svg +9 -1
  259. package/src/assets/icons/detailed/qrcode.svg +28 -1
  260. package/src/assets/icons/detailed/question-badge.svg +10 -1
  261. package/src/assets/icons/detailed/radio.svg +8 -1
  262. package/src/assets/icons/detailed/redo.svg +9 -1
  263. package/src/assets/icons/detailed/relations.svg +32 -1
  264. package/src/assets/icons/detailed/reload.svg +13 -1
  265. package/src/assets/icons/detailed/remove-circle.svg +10 -1
  266. package/src/assets/icons/detailed/remove.svg +5 -1
  267. package/src/assets/icons/detailed/reorder.svg +12 -1
  268. package/src/assets/icons/detailed/repeat.svg +12 -1
  269. package/src/assets/icons/detailed/repository.svg +18 -1
  270. package/src/assets/icons/detailed/request-form.svg +18 -1
  271. package/src/assets/icons/detailed/resize-100%.svg +15 -1
  272. package/src/assets/icons/detailed/resize-height.svg +12 -1
  273. package/src/assets/icons/detailed/resize-width.svg +12 -1
  274. package/src/assets/icons/detailed/search.svg +12 -1
  275. package/src/assets/icons/detailed/sequential-prerequisites.svg +20 -1
  276. package/src/assets/icons/detailed/settings.svg +14 -1
  277. package/src/assets/icons/detailed/share.svg +20 -1
  278. package/src/assets/icons/detailed/sketch.svg +12 -1
  279. package/src/assets/icons/detailed/skills.svg +20 -1
  280. package/src/assets/icons/detailed/skip-back.svg +12 -1
  281. package/src/assets/icons/detailed/skip-forward.svg +13 -1
  282. package/src/assets/icons/detailed/sms.svg +18 -1
  283. package/src/assets/icons/detailed/sso-access.svg +18 -1
  284. package/src/assets/icons/detailed/star-active.svg +6 -1
  285. package/src/assets/icons/detailed/star.svg +6 -1
  286. package/src/assets/icons/detailed/success.svg +10 -1
  287. package/src/assets/icons/detailed/sun.svg +24 -1
  288. package/src/assets/icons/detailed/sunrise.svg +18 -1
  289. package/src/assets/icons/detailed/support.svg +18 -1
  290. package/src/assets/icons/detailed/survey.svg +24 -1
  291. package/src/assets/icons/detailed/table.svg +11 -1
  292. package/src/assets/icons/detailed/tematic-channels.svg +12 -1
  293. package/src/assets/icons/detailed/test.svg +14 -1
  294. package/src/assets/icons/detailed/text-body.svg +8 -1
  295. package/src/assets/icons/detailed/text-edit.svg +11 -1
  296. package/src/assets/icons/detailed/text-style.svg +10 -1
  297. package/src/assets/icons/detailed/time.svg +10 -1
  298. package/src/assets/icons/detailed/toilet-piper.svg +15 -1
  299. package/src/assets/icons/detailed/training-points.svg +16 -1
  300. package/src/assets/icons/detailed/trash.svg +19 -1
  301. package/src/assets/icons/detailed/underline.svg +8 -1
  302. package/src/assets/icons/detailed/undo.svg +9 -1
  303. package/src/assets/icons/detailed/unlock.svg +13 -1
  304. package/src/assets/icons/detailed/upload.svg +10 -1
  305. package/src/assets/icons/detailed/user-add.svg +16 -1
  306. package/src/assets/icons/detailed/user-badge.svg +11 -1
  307. package/src/assets/icons/detailed/user.svg +8 -1
  308. package/src/assets/icons/detailed/video-off.svg +17 -1
  309. package/src/assets/icons/detailed/video-on.svg +16 -1
  310. package/src/assets/icons/detailed/video-rec.svg +19 -1
  311. package/src/assets/icons/detailed/view-card.svg +12 -1
  312. package/src/assets/icons/detailed/view-list.svg +20 -1
  313. package/src/assets/icons/detailed/view.svg +7 -1
  314. package/src/assets/icons/detailed/voice-off.svg +14 -1
  315. package/src/assets/icons/detailed/voice-on.svg +16 -1
  316. package/src/assets/icons/detailed/volume-down.svg +14 -1
  317. package/src/assets/icons/detailed/volume-off.svg +19 -1
  318. package/src/assets/icons/detailed/volume-up.svg +16 -1
  319. package/src/assets/icons/detailed/warning.svg +16 -1
  320. package/src/assets/icons/detailed/webinar.svg +57 -1
  321. package/src/assets/icons/detailed/whiteboard.svg +16 -1
  322. package/src/assets/icons/detailed/wine.svg +22 -1
  323. package/src/assets/icons/detailed/zip.svg +17 -1
  324. package/src/assets/icons/detailed/zoom-in.svg +18 -1
  325. package/src/assets/icons/detailed/zoom-out.svg +16 -1
  326. package/src/assets/icons/detailed.json +1 -1
  327. package/src/assets/icons/normal/add-circle.svg +12 -1
  328. package/src/assets/icons/normal/add.svg +4 -1
  329. package/src/assets/icons/normal/align-center.svg +11 -1
  330. package/src/assets/icons/normal/align-justify.svg +11 -1
  331. package/src/assets/icons/normal/align-left.svg +11 -1
  332. package/src/assets/icons/normal/align-right.svg +11 -1
  333. package/src/assets/icons/normal/analysis-2.svg +18 -1
  334. package/src/assets/icons/normal/analysis-3.svg +8 -1
  335. package/src/assets/icons/normal/analysis.svg +14 -1
  336. package/src/assets/icons/normal/apple.svg +16 -1
  337. package/src/assets/icons/normal/arrow-down.svg +8 -1
  338. package/src/assets/icons/normal/arrow-left.svg +8 -1
  339. package/src/assets/icons/normal/arrow-right.svg +8 -1
  340. package/src/assets/icons/normal/arrow-up.svg +8 -1
  341. package/src/assets/icons/normal/attachment.svg +6 -1
  342. package/src/assets/icons/normal/back-to-front.svg +15 -1
  343. package/src/assets/icons/normal/bell-active.svg +14 -1
  344. package/src/assets/icons/normal/bell.svg +14 -1
  345. package/src/assets/icons/normal/bold.svg +8 -1
  346. package/src/assets/icons/normal/bookmark active.svg +12 -1
  347. package/src/assets/icons/normal/bookmark.svg +10 -1
  348. package/src/assets/icons/normal/building.svg +21 -1
  349. package/src/assets/icons/normal/bulleted-list.svg +23 -1
  350. package/src/assets/icons/normal/calendar.svg +20 -1
  351. package/src/assets/icons/normal/camera-off.svg +17 -1
  352. package/src/assets/icons/normal/camera-on.svg +16 -1
  353. package/src/assets/icons/normal/catalog.svg +13 -1
  354. package/src/assets/icons/normal/certificate.svg +12 -1
  355. package/src/assets/icons/normal/chat.svg +6 -1
  356. package/src/assets/icons/normal/check-badge.svg +9 -1
  357. package/src/assets/icons/normal/check-circle.svg +10 -1
  358. package/src/assets/icons/normal/check.svg +4 -1
  359. package/src/assets/icons/normal/checkbox.svg +8 -1
  360. package/src/assets/icons/normal/chevron-down-circle.svg +10 -1
  361. package/src/assets/icons/normal/chevron-down.svg +6 -1
  362. package/src/assets/icons/normal/chevron-left-circle.svg +10 -1
  363. package/src/assets/icons/normal/chevron-left.svg +6 -1
  364. package/src/assets/icons/normal/chevron-right-circle.svg +10 -1
  365. package/src/assets/icons/normal/chevron-right.svg +7 -1
  366. package/src/assets/icons/normal/chevron-up-circle.svg +10 -1
  367. package/src/assets/icons/normal/chevron-up.svg +6 -1
  368. package/src/assets/icons/normal/circle.svg +8 -0
  369. package/src/assets/icons/normal/classroom.svg +36 -1
  370. package/src/assets/icons/normal/clear-field.svg +14 -1
  371. package/src/assets/icons/normal/clear-style.svg +18 -1
  372. package/src/assets/icons/normal/close-circle.svg +14 -1
  373. package/src/assets/icons/normal/close-loader.svg +6 -1
  374. package/src/assets/icons/normal/close.svg +8 -1
  375. package/src/assets/icons/normal/coffee.svg +26 -1
  376. package/src/assets/icons/normal/color.svg +18 -1
  377. package/src/assets/icons/normal/contact-us.svg +29 -1
  378. package/src/assets/icons/normal/copy.svg +10 -1
  379. package/src/assets/icons/normal/courses.svg +22 -1
  380. package/src/assets/icons/normal/dashboard.svg +18 -1
  381. package/src/assets/icons/normal/download.svg +10 -1
  382. package/src/assets/icons/normal/drag.svg +5 -1
  383. package/src/assets/icons/normal/dulicate.svg +22 -1
  384. package/src/assets/icons/normal/edit.svg +16 -1
  385. package/src/assets/icons/normal/elearning.svg +16 -1
  386. package/src/assets/icons/normal/email.svg +11 -1
  387. package/src/assets/icons/normal/error-2.svg +8 -1
  388. package/src/assets/icons/normal/error.svg +12 -1
  389. package/src/assets/icons/normal/exercise.svg +26 -1
  390. package/src/assets/icons/normal/external-link.svg +11 -1
  391. package/src/assets/icons/normal/extract.svg +14 -1
  392. package/src/assets/icons/normal/eye-off.svg +14 -1
  393. package/src/assets/icons/normal/eye-on.svg +16 -1
  394. package/src/assets/icons/normal/fail.svg +11 -1
  395. package/src/assets/icons/normal/fast-back.svg +19 -1
  396. package/src/assets/icons/normal/fast-forward.svg +17 -1
  397. package/src/assets/icons/normal/file-add.svg +16 -1
  398. package/src/assets/icons/normal/file-duplicate.svg +22 -1
  399. package/src/assets/icons/normal/file-remove.svg +14 -1
  400. package/src/assets/icons/normal/file-required.svg +24 -1
  401. package/src/assets/icons/normal/file.svg +13 -1
  402. package/src/assets/icons/normal/filter-2.svg +20 -1
  403. package/src/assets/icons/normal/filter-active.svg +12 -1
  404. package/src/assets/icons/normal/filter.svg +12 -1
  405. package/src/assets/icons/normal/flag.svg +10 -1
  406. package/src/assets/icons/normal/folder.svg +12 -1
  407. package/src/assets/icons/normal/full-width.svg +9 -1
  408. package/src/assets/icons/normal/go-to-back.svg +19 -1
  409. package/src/assets/icons/normal/grid.svg +20 -1
  410. package/src/assets/icons/normal/group-add.svg +18 -1
  411. package/src/assets/icons/normal/group.svg +14 -1
  412. package/src/assets/icons/normal/heart-active.svg +10 -1
  413. package/src/assets/icons/normal/heart.svg +10 -1
  414. package/src/assets/icons/normal/highlighter.svg +11 -1
  415. package/src/assets/icons/normal/home.svg +12 -1
  416. package/src/assets/icons/normal/hourglass.svg +8 -1
  417. package/src/assets/icons/normal/image.svg +15 -1
  418. package/src/assets/icons/normal/info-badge.svg +9 -1
  419. package/src/assets/icons/normal/information.svg +12 -1
  420. package/src/assets/icons/normal/italic.svg +10 -1
  421. package/src/assets/icons/normal/key.svg +8 -1
  422. package/src/assets/icons/normal/language.svg +14 -1
  423. package/src/assets/icons/normal/learning-path.svg +7 -1
  424. package/src/assets/icons/normal/light-off.svg +10 -1
  425. package/src/assets/icons/normal/light-on.svg +17 -1
  426. package/src/assets/icons/normal/link.svg +12 -1
  427. package/src/assets/icons/normal/lock.svg +12 -1
  428. package/src/assets/icons/normal/login.svg +10 -1
  429. package/src/assets/icons/normal/logout.svg +10 -1
  430. package/src/assets/icons/normal/maximize.svg +10 -1
  431. package/src/assets/icons/normal/menu.svg +8 -1
  432. package/src/assets/icons/normal/merge.svg +20 -1
  433. package/src/assets/icons/normal/minimize.svg +12 -1
  434. package/src/assets/icons/normal/mixed-class.svg +36 -1
  435. package/src/assets/icons/normal/more-horizontal.svg +7 -1
  436. package/src/assets/icons/normal/more-vertical.svg +7 -1
  437. package/src/assets/icons/normal/news.svg +9 -1
  438. package/src/assets/icons/normal/no-prerequisites.svg +12 -1
  439. package/src/assets/icons/normal/notes.svg +15 -1
  440. package/src/assets/icons/normal/number-code.svg +34 -1
  441. package/src/assets/icons/normal/numbered-list.svg +19 -1
  442. package/src/assets/icons/normal/on-site.svg +18 -1
  443. package/src/assets/icons/normal/order-down.svg +12 -1
  444. package/src/assets/icons/normal/order-up.svg +11 -1
  445. package/src/assets/icons/normal/paste.svg +14 -1
  446. package/src/assets/icons/normal/pausa.svg +7 -1
  447. package/src/assets/icons/normal/pdf.svg +12 -1
  448. package/src/assets/icons/normal/phone.svg +10 -1
  449. package/src/assets/icons/normal/pin-map.svg +10 -1
  450. package/src/assets/icons/normal/pin.svg +12 -1
  451. package/src/assets/icons/normal/pizza.svg +17 -1
  452. package/src/assets/icons/normal/play.svg +9 -1
  453. package/src/assets/icons/normal/plug-in.svg +10 -1
  454. package/src/assets/icons/normal/pointer.svg +12 -1
  455. package/src/assets/icons/normal/printer.svg +28 -1
  456. package/src/assets/icons/normal/profile-add.svg +28 -1
  457. package/src/assets/icons/normal/profile.svg +15 -1
  458. package/src/assets/icons/normal/push pin on.svg +9 -1
  459. package/src/assets/icons/normal/push-pin-off.svg +23 -1
  460. package/src/assets/icons/normal/qrcode.svg +26 -1
  461. package/src/assets/icons/normal/question-badge.svg +10 -1
  462. package/src/assets/icons/normal/radio.svg +8 -1
  463. package/src/assets/icons/normal/redo.svg +9 -1
  464. package/src/assets/icons/normal/relations.svg +28 -1
  465. package/src/assets/icons/normal/reload.svg +12 -1
  466. package/src/assets/icons/normal/remove-circle.svg +10 -1
  467. package/src/assets/icons/normal/remove.svg +4 -1
  468. package/src/assets/icons/normal/reorder.svg +12 -1
  469. package/src/assets/icons/normal/repeat.svg +12 -1
  470. package/src/assets/icons/normal/repository.svg +18 -1
  471. package/src/assets/icons/normal/request-form.svg +18 -1
  472. package/src/assets/icons/normal/resize-100%.svg +17 -1
  473. package/src/assets/icons/normal/resize-height.svg +12 -1
  474. package/src/assets/icons/normal/resize-width.svg +12 -1
  475. package/src/assets/icons/normal/search.svg +10 -1
  476. package/src/assets/icons/normal/sequential-prerequisites.svg +20 -1
  477. package/src/assets/icons/normal/settings.svg +14 -1
  478. package/src/assets/icons/normal/share.svg +20 -1
  479. package/src/assets/icons/normal/sketch.svg +11 -1
  480. package/src/assets/icons/normal/skills.svg +16 -1
  481. package/src/assets/icons/normal/skip-back.svg +12 -1
  482. package/src/assets/icons/normal/skip-forward.svg +13 -1
  483. package/src/assets/icons/normal/sms.svg +20 -1
  484. package/src/assets/icons/normal/sso-access.svg +20 -1
  485. package/src/assets/icons/normal/star-active.svg +4 -1
  486. package/src/assets/icons/normal/star.svg +4 -1
  487. package/src/assets/icons/normal/success.svg +10 -1
  488. package/src/assets/icons/normal/sun.svg +24 -1
  489. package/src/assets/icons/normal/sunrise.svg +18 -1
  490. package/src/assets/icons/normal/support.svg +18 -1
  491. package/src/assets/icons/normal/survey.svg +24 -1
  492. package/src/assets/icons/normal/table.svg +11 -1
  493. package/src/assets/icons/normal/tematic-channels.svg +10 -1
  494. package/src/assets/icons/normal/test.svg +15 -1
  495. package/src/assets/icons/normal/text-body.svg +8 -1
  496. package/src/assets/icons/normal/text-edit.svg +11 -1
  497. package/src/assets/icons/normal/text-style.svg +10 -1
  498. package/src/assets/icons/normal/time.svg +10 -1
  499. package/src/assets/icons/normal/toilet-paper.svg +15 -1
  500. package/src/assets/icons/normal/training-points.svg +16 -1
  501. package/src/assets/icons/normal/trash.svg +19 -1
  502. package/src/assets/icons/normal/underline.svg +8 -1
  503. package/src/assets/icons/normal/undo.svg +9 -1
  504. package/src/assets/icons/normal/unlock.svg +13 -1
  505. package/src/assets/icons/normal/upload.svg +10 -1
  506. package/src/assets/icons/normal/user-add.svg +14 -1
  507. package/src/assets/icons/normal/user-badge.svg +11 -1
  508. package/src/assets/icons/normal/user.svg +5 -1
  509. package/src/assets/icons/normal/video-off.svg +11 -1
  510. package/src/assets/icons/normal/video-on.svg +20 -1
  511. package/src/assets/icons/normal/video-rec.svg +23 -1
  512. package/src/assets/icons/normal/view-card.svg +10 -1
  513. package/src/assets/icons/normal/view-list.svg +18 -1
  514. package/src/assets/icons/normal/view.svg +8 -1
  515. package/src/assets/icons/normal/voice-off.svg +18 -1
  516. package/src/assets/icons/normal/voice-on.svg +15 -1
  517. package/src/assets/icons/normal/volume-down.svg +14 -1
  518. package/src/assets/icons/normal/volume-off.svg +18 -1
  519. package/src/assets/icons/normal/volume-up.svg +16 -1
  520. package/src/assets/icons/normal/warning.svg +16 -1
  521. package/src/assets/icons/normal/webinar.svg +36 -1
  522. package/src/assets/icons/normal/whiteboard.svg +17 -1
  523. package/src/assets/icons/normal/wine.svg +22 -1
  524. package/src/assets/icons/normal/zip.svg +19 -1
  525. package/src/assets/icons/normal/zoom-in.svg +16 -1
  526. package/src/assets/icons/normal/zoom-out.svg +14 -1
  527. package/src/assets/icons/normal.json +1 -1
  528. package/src/assets/icons/simple/add-circle.svg +12 -1
  529. package/src/assets/icons/simple/add.svg +8 -1
  530. package/src/assets/icons/simple/align-center.svg +12 -1
  531. package/src/assets/icons/simple/align-justify.svg +12 -1
  532. package/src/assets/icons/simple/align-left.svg +12 -1
  533. package/src/assets/icons/simple/align-right.svg +12 -1
  534. package/src/assets/icons/simple/analysis-2.svg +21 -1
  535. package/src/assets/icons/simple/analysis-3.svg +8 -1
  536. package/src/assets/icons/simple/analysis.svg +16 -1
  537. package/src/assets/icons/simple/apple.svg +18 -1
  538. package/src/assets/icons/simple/arrow-down.svg +8 -1
  539. package/src/assets/icons/simple/arrow-left.svg +8 -1
  540. package/src/assets/icons/simple/arrow-right.svg +8 -1
  541. package/src/assets/icons/simple/arrow-up.svg +8 -1
  542. package/src/assets/icons/simple/attachment.svg +10 -1
  543. package/src/assets/icons/simple/bck-to-front.svg +19 -1
  544. package/src/assets/icons/simple/bell-active.svg +14 -1
  545. package/src/assets/icons/simple/bell.svg +14 -1
  546. package/src/assets/icons/simple/bold.svg +8 -1
  547. package/src/assets/icons/simple/bookmark-active.svg +12 -1
  548. package/src/assets/icons/simple/bookmark.svg +12 -1
  549. package/src/assets/icons/simple/building.svg +25 -1
  550. package/src/assets/icons/simple/bulleted-list.svg +22 -1
  551. package/src/assets/icons/simple/calendar.svg +22 -1
  552. package/src/assets/icons/simple/camera-off.svg +12 -1
  553. package/src/assets/icons/simple/camera-on.svg +16 -1
  554. package/src/assets/icons/simple/catalog.svg +14 -1
  555. package/src/assets/icons/simple/certificate.svg +15 -1
  556. package/src/assets/icons/simple/chat.svg +9 -1
  557. package/src/assets/icons/simple/check-badge.svg +9 -1
  558. package/src/assets/icons/simple/check-circle.svg +10 -1
  559. package/src/assets/icons/simple/check.svg +6 -1
  560. package/src/assets/icons/simple/checkbox.svg +6 -1
  561. package/src/assets/icons/simple/chevron-down-circle.svg +10 -1
  562. package/src/assets/icons/simple/chevron-down.svg +6 -1
  563. package/src/assets/icons/simple/chevron-left-circle.svg +10 -1
  564. package/src/assets/icons/simple/chevron-left.svg +6 -1
  565. package/src/assets/icons/simple/chevron-right-circle.svg +10 -1
  566. package/src/assets/icons/simple/chevron-right.svg +7 -1
  567. package/src/assets/icons/simple/chevron-up-circle.svg +10 -1
  568. package/src/assets/icons/simple/chevron-up.svg +6 -1
  569. package/src/assets/icons/simple/circle.svg +8 -0
  570. package/src/assets/icons/simple/classroom.svg +38 -1
  571. package/src/assets/icons/simple/clear-field.svg +11 -1
  572. package/src/assets/icons/simple/clear-style.svg +15 -1
  573. package/src/assets/icons/simple/close-circle.svg +14 -1
  574. package/src/assets/icons/simple/close-loader.svg +6 -1
  575. package/src/assets/icons/simple/close.svg +10 -1
  576. package/src/assets/icons/simple/coffee.svg +28 -1
  577. package/src/assets/icons/simple/color.svg +20 -1
  578. package/src/assets/icons/simple/contact-us.svg +26 -1
  579. package/src/assets/icons/simple/copy.svg +10 -1
  580. package/src/assets/icons/simple/courses.svg +21 -1
  581. package/src/assets/icons/simple/dashboard.svg +20 -1
  582. package/src/assets/icons/simple/download.svg +10 -1
  583. package/src/assets/icons/simple/drag.svg +10 -1
  584. package/src/assets/icons/simple/duplicate.svg +24 -1
  585. package/src/assets/icons/simple/edit.svg +17 -1
  586. package/src/assets/icons/simple/elearning.svg +17 -1
  587. package/src/assets/icons/simple/email.svg +11 -1
  588. package/src/assets/icons/simple/error-2.svg +8 -1
  589. package/src/assets/icons/simple/error.svg +12 -1
  590. package/src/assets/icons/simple/exercise.svg +30 -1
  591. package/src/assets/icons/simple/external-link.svg +13 -1
  592. package/src/assets/icons/simple/extract.svg +17 -1
  593. package/src/assets/icons/simple/eye-off.svg +13 -1
  594. package/src/assets/icons/simple/eye-on.svg +11 -1
  595. package/src/assets/icons/simple/fail.svg +11 -1
  596. package/src/assets/icons/simple/fast-back.svg +20 -1
  597. package/src/assets/icons/simple/fast-forward.svg +19 -1
  598. package/src/assets/icons/simple/file-add.svg +20 -1
  599. package/src/assets/icons/simple/file-duplicate.svg +22 -1
  600. package/src/assets/icons/simple/file-remove.svg +18 -1
  601. package/src/assets/icons/simple/file-required.svg +24 -1
  602. package/src/assets/icons/simple/file.svg +14 -1
  603. package/src/assets/icons/simple/filter-2.svg +24 -1
  604. package/src/assets/icons/simple/filter-active.svg +13 -1
  605. package/src/assets/icons/simple/filter.svg +12 -1
  606. package/src/assets/icons/simple/flag.svg +12 -1
  607. package/src/assets/icons/simple/folder.svg +14 -1
  608. package/src/assets/icons/simple/full-width.svg +11 -1
  609. package/src/assets/icons/simple/go-to-back.svg +18 -1
  610. package/src/assets/icons/simple/grid.svg +20 -1
  611. package/src/assets/icons/simple/group-add.svg +24 -1
  612. package/src/assets/icons/simple/group.svg +18 -1
  613. package/src/assets/icons/simple/heart-active.svg +12 -1
  614. package/src/assets/icons/simple/heart.svg +12 -1
  615. package/src/assets/icons/simple/highlighter.svg +12 -1
  616. package/src/assets/icons/simple/home.svg +13 -1
  617. package/src/assets/icons/simple/hourglass.svg +11 -1
  618. package/src/assets/icons/simple/image.svg +15 -1
  619. package/src/assets/icons/simple/info-badge.svg +9 -1
  620. package/src/assets/icons/simple/information.svg +12 -1
  621. package/src/assets/icons/simple/italic.svg +12 -1
  622. package/src/assets/icons/simple/key.svg +11 -1
  623. package/src/assets/icons/simple/language.svg +12 -1
  624. package/src/assets/icons/simple/learning-path.svg +9 -1
  625. package/src/assets/icons/simple/light-off.svg +7 -1
  626. package/src/assets/icons/simple/light-on.svg +18 -1
  627. package/src/assets/icons/simple/link.svg +14 -1
  628. package/src/assets/icons/simple/lock.svg +13 -1
  629. package/src/assets/icons/simple/login.svg +11 -1
  630. package/src/assets/icons/simple/logout.svg +11 -1
  631. package/src/assets/icons/simple/maximaze.svg +12 -1
  632. package/src/assets/icons/simple/menu.svg +10 -1
  633. package/src/assets/icons/simple/merge.svg +20 -1
  634. package/src/assets/icons/simple/minimaze.svg +12 -1
  635. package/src/assets/icons/simple/mixed-class.svg +40 -1
  636. package/src/assets/icons/simple/more-horizontal.svg +8 -1
  637. package/src/assets/icons/simple/more-vertical.svg +8 -1
  638. package/src/assets/icons/simple/news.svg +12 -1
  639. package/src/assets/icons/simple/no-prerequisites.svg +17 -1
  640. package/src/assets/icons/simple/notes.svg +14 -1
  641. package/src/assets/icons/simple/number-code.svg +29 -1
  642. package/src/assets/icons/simple/numbered-list.svg +18 -1
  643. package/src/assets/icons/simple/on-site.svg +18 -1
  644. package/src/assets/icons/simple/order-down.svg +12 -1
  645. package/src/assets/icons/simple/order-up.svg +12 -1
  646. package/src/assets/icons/simple/paste.svg +14 -1
  647. package/src/assets/icons/simple/pausa.svg +8 -1
  648. package/src/assets/icons/simple/pdf.svg +12 -1
  649. package/src/assets/icons/simple/phone.svg +10 -1
  650. package/src/assets/icons/simple/pin-map.svg +13 -1
  651. package/src/assets/icons/simple/pin.svg +14 -1
  652. package/src/assets/icons/simple/pizza.svg +17 -1
  653. package/src/assets/icons/simple/play.svg +10 -1
  654. package/src/assets/icons/simple/plug-in.svg +10 -1
  655. package/src/assets/icons/simple/pointer.svg +6 -1
  656. package/src/assets/icons/simple/printer.svg +28 -1
  657. package/src/assets/icons/simple/profile-add.svg +28 -1
  658. package/src/assets/icons/simple/profile.svg +13 -1
  659. package/src/assets/icons/simple/push-pin-off.svg +11 -1
  660. package/src/assets/icons/simple/push-pin-on.svg +12 -1
  661. package/src/assets/icons/simple/qrcode.svg +26 -1
  662. package/src/assets/icons/simple/question-badge.svg +10 -1
  663. package/src/assets/icons/simple/radio.svg +8 -1
  664. package/src/assets/icons/simple/redo.svg +9 -1
  665. package/src/assets/icons/simple/relations.svg +28 -1
  666. package/src/assets/icons/simple/reload.svg +12 -1
  667. package/src/assets/icons/simple/remove-circle.svg +10 -1
  668. package/src/assets/icons/simple/remove.svg +6 -1
  669. package/src/assets/icons/simple/repeart.svg +14 -1
  670. package/src/assets/icons/simple/repository.svg +18 -1
  671. package/src/assets/icons/simple/request-form.svg +20 -1
  672. package/src/assets/icons/simple/resize-100%.svg +15 -1
  673. package/src/assets/icons/simple/resize-height.svg +12 -1
  674. package/src/assets/icons/simple/resize-width.svg +14 -1
  675. package/src/assets/icons/simple/search.svg +10 -1
  676. package/src/assets/icons/simple/sequential-prerequisites.svg +22 -1
  677. package/src/assets/icons/simple/settings.svg +17 -1
  678. package/src/assets/icons/simple/share.svg +21 -1
  679. package/src/assets/icons/simple/sketch.svg +13 -1
  680. package/src/assets/icons/simple/skills.svg +17 -1
  681. package/src/assets/icons/simple/skip-back.svg +14 -1
  682. package/src/assets/icons/simple/skip-forward.svg +14 -1
  683. package/src/assets/icons/simple/sms.svg +22 -1
  684. package/src/assets/icons/simple/sso-access.svg +20 -1
  685. package/src/assets/icons/simple/star-active.svg +6 -1
  686. package/src/assets/icons/simple/star.svg +6 -1
  687. package/src/assets/icons/simple/success.svg +12 -1
  688. package/src/assets/icons/simple/sun.svg +22 -1
  689. package/src/assets/icons/simple/sunrise.svg +18 -1
  690. package/src/assets/icons/simple/support.svg +18 -1
  691. package/src/assets/icons/simple/survey.svg +32 -1
  692. package/src/assets/icons/simple/table.svg +11 -1
  693. package/src/assets/icons/simple/tematic-channels.svg +15 -1
  694. package/src/assets/icons/simple/test.svg +23 -1
  695. package/src/assets/icons/simple/text-body.svg +7 -1
  696. package/src/assets/icons/simple/text-edit.svg +11 -1
  697. package/src/assets/icons/simple/text-style.svg +10 -1
  698. package/src/assets/icons/simple/time.svg +10 -1
  699. package/src/assets/icons/simple/toilet-paper.svg +17 -1
  700. package/src/assets/icons/simple/training-points.svg +18 -1
  701. package/src/assets/icons/simple/trash.svg +20 -1
  702. package/src/assets/icons/simple/underline.svg +9 -1
  703. package/src/assets/icons/simple/undo.svg +9 -1
  704. package/src/assets/icons/simple/unlock.svg +15 -1
  705. package/src/assets/icons/simple/upload.svg +10 -1
  706. package/src/assets/icons/simple/user-add.svg +18 -1
  707. package/src/assets/icons/simple/user-badge.svg +12 -1
  708. package/src/assets/icons/simple/user.svg +8 -1
  709. package/src/assets/icons/simple/video-off.svg +17 -1
  710. package/src/assets/icons/simple/video-on.svg +17 -1
  711. package/src/assets/icons/simple/video-rec.svg +20 -1
  712. package/src/assets/icons/simple/view-card.svg +12 -1
  713. package/src/assets/icons/simple/view-list.svg +20 -1
  714. package/src/assets/icons/simple/view.svg +17 -1
  715. package/src/assets/icons/simple/voice-off.svg +16 -1
  716. package/src/assets/icons/simple/voice-on.svg +16 -1
  717. package/src/assets/icons/simple/volume-down.svg +15 -1
  718. package/src/assets/icons/simple/volume-off.svg +16 -1
  719. package/src/assets/icons/simple/volume-up.svg +16 -1
  720. package/src/assets/icons/simple/warning.svg +14 -1
  721. package/src/assets/icons/simple/webinar.svg +19 -1
  722. package/src/assets/icons/simple/whiteboard.svg +16 -1
  723. package/src/assets/icons/simple/wine.svg +24 -1
  724. package/src/assets/icons/simple/zip.svg +22 -1
  725. package/src/assets/icons/simple/zoom-in.svg +18 -1
  726. package/src/assets/icons/simple/zoom-out.svg +17 -1
  727. package/src/assets/icons/simple.json +1 -1
  728. package/src/components/VvAccordion/VvAccordion.vue +16 -9
  729. package/src/components/VvAccordion/index.ts +5 -3
  730. package/src/components/VvAccordionGroup/VvAccordionGroup.vue +16 -11
  731. package/src/components/VvAction/VvAction.vue +144 -0
  732. package/src/components/VvAction/index.ts +5 -0
  733. package/src/components/VvBadge/VvBadge.vue +3 -3
  734. package/src/components/VvBreadcrumb/VvBreadcrumb.vue +5 -5
  735. package/src/components/VvButton/VvButton.vue +53 -100
  736. package/src/components/VvButton/index.ts +21 -94
  737. package/src/components/VvButtonGroup/VvButtonGroup.vue +7 -10
  738. package/src/components/VvCard/VvCard.vue +6 -3
  739. package/src/components/VvCheckbox/VvCheckbox.vue +17 -12
  740. package/src/components/VvCheckbox/index.ts +7 -5
  741. package/src/components/VvCheckboxGroup/VvCheckboxGroup.vue +21 -19
  742. package/src/components/VvCombobox/VvCombobox.vue +330 -101
  743. package/src/components/VvCombobox/index.ts +63 -7
  744. package/src/components/VvDialog/VvDialog.vue +14 -6
  745. package/src/components/VvDialog/index.ts +18 -1
  746. package/src/components/VvDropdown/VvDropdown.vue +344 -95
  747. package/src/components/VvDropdown/VvDropdownAction.vue +44 -0
  748. package/src/components/VvDropdown/VvDropdownItem.vue +32 -0
  749. package/src/components/VvDropdown/VvDropdownOption.vue +65 -0
  750. package/src/components/VvDropdown/index.ts +20 -23
  751. package/src/components/VvIcon/VvIcon.vue +16 -16
  752. package/src/components/VvInputText/VvInputText.vue +45 -34
  753. package/src/components/VvProgress/VvProgress.vue +7 -5
  754. package/src/components/VvRadio/VvRadio.vue +16 -14
  755. package/src/components/VvRadio/index.ts +6 -3
  756. package/src/components/VvRadioGroup/VvRadioGroup.vue +20 -16
  757. package/src/components/VvSelect/VvSelect.vue +69 -56
  758. package/src/components/VvSelect/index.ts +4 -6
  759. package/src/components/VvTextarea/VvTextarea.vue +46 -33
  760. package/src/components/VvTooltip/VvTooltip.vue +16 -10
  761. package/src/components/VvTooltip/index.ts +8 -11
  762. package/src/components/common/HintSlot.ts +5 -4
  763. package/src/composables/dropdown/useInjectDropdown.ts +51 -0
  764. package/src/composables/dropdown/useProvideDropdown.ts +95 -0
  765. package/src/composables/group/useInjectedGroupState.ts +7 -7
  766. package/src/composables/group/useProvideGroupState.ts +3 -3
  767. package/src/composables/useComponentIcon.ts +41 -0
  768. package/src/composables/useModifiers.ts +28 -91
  769. package/src/composables/useOptions.ts +11 -3
  770. package/src/composables/useUniqueId.ts +5 -0
  771. package/src/composables/useVolver.ts +6 -0
  772. package/src/constants.ts +74 -5
  773. package/src/directives/index.ts +5 -0
  774. package/src/directives/v-tooltip.ts +15 -0
  775. package/src/index.ts +1 -1
  776. package/src/props/index.ts +222 -26
  777. package/src/resolvers/unplugin.ts +83 -47
  778. package/src/shims.d.ts +1 -1
  779. package/src/stories/Accordion/Accordion.stories.mdx +9 -7
  780. package/src/stories/Accordion/Accordion.test.ts +1 -1
  781. package/src/stories/Accordion/AccordionSlots.stories.mdx +2 -2
  782. package/src/stories/AccordionGroup/AccordionGroup.stories.mdx +6 -4
  783. package/src/stories/AccordionGroup/AccordionGroupSlots.stories.mdx +12 -9
  784. package/src/stories/Badge/Badge.stories.mdx +4 -3
  785. package/src/stories/Breadcrumb/Breadcrumb.stories.mdx +6 -4
  786. package/src/stories/Breadcrumb/Breadcrumb.test.ts +14 -12
  787. package/src/stories/Breadcrumb/BreadcrumbSlots.stories.mdx +8 -8
  788. package/src/stories/Button/Button.stories.mdx +10 -8
  789. package/src/stories/Button/Button.test.ts +9 -7
  790. package/src/stories/Button/ButtonModifiers.stories.mdx +4 -4
  791. package/src/stories/Button/ButtonSlots.stories.mdx +20 -15
  792. package/src/stories/Button/ButtonState.stories.mdx +2 -11
  793. package/src/stories/ButtonGroup/ButtonGroup.stories.mdx +2 -2
  794. package/src/stories/ButtonGroup/ButtonGroupSlots.stories.mdx +2 -2
  795. package/src/stories/Card/Card.stories.mdx +4 -3
  796. package/src/stories/Card/Card.test.ts +1 -1
  797. package/src/stories/Card/CardSlots.stories.mdx +2 -2
  798. package/src/stories/Checkbox/Checkbox.stories.mdx +9 -8
  799. package/src/stories/CheckboxGroup/CheckboxGroup.stories.mdx +9 -8
  800. package/src/stories/CheckboxGroup/CheckboxGroupSlots.stories.mdx +11 -10
  801. package/src/stories/Combobox/Combobox.settings.ts +155 -4
  802. package/src/stories/Combobox/Combobox.stories.mdx +125 -5
  803. package/src/stories/Combobox/Combobox.test.ts +2 -2
  804. package/src/stories/Combobox/ComboboxIconPosition.stories.mdx +78 -0
  805. package/src/stories/Combobox/ComboboxMultiple.stories.mdx +1 -2
  806. package/src/stories/Combobox/ComboboxSlots.stories.mdx +107 -2
  807. package/src/stories/Dialog/Dialog.stories.mdx +4 -3
  808. package/src/stories/Dialog/Dialog.test.ts +4 -4
  809. package/src/stories/Dropdown/Dropdown.settings.ts +55 -36
  810. package/src/stories/Dropdown/Dropdown.stories.mdx +60 -59
  811. package/src/stories/Dropdown/Dropdown.test.ts +10 -32
  812. package/src/stories/Dropdown/DropdownMultilevel.stories.mdx +56 -0
  813. package/src/stories/Dropdown/DropdownSlots.stories.mdx +114 -0
  814. package/src/stories/Icon/Icon.stories.mdx +3 -2
  815. package/src/stories/Icon/IconsCollection.stories.mdx +4 -3
  816. package/src/stories/InputText/InputText.settings.ts +2 -1
  817. package/src/stories/InputText/InputText.stories.mdx +9 -5
  818. package/src/stories/InputText/InputTextIconPosition.stories.mdx +2 -2
  819. package/src/stories/InputText/InputTextSlots.stories.mdx +2 -2
  820. package/src/stories/Progress/Progress.stories.mdx +5 -2
  821. package/src/stories/Progress/Progress.test.ts +1 -1
  822. package/src/stories/Radio/Radio.stories.mdx +3 -2
  823. package/src/stories/RadioGroup/RadioGroup.stories.mdx +9 -8
  824. package/src/stories/RadioGroup/RadioGroupSlots.stories.mdx +11 -10
  825. package/src/stories/Select/Select.settings.ts +2 -2
  826. package/src/stories/Select/Select.stories.mdx +5 -4
  827. package/src/stories/Select/SelectIconPosition.stories.mdx +78 -0
  828. package/src/stories/Select/SelectSlots.stories.mdx +2 -2
  829. package/src/stories/Textarea/Textarea.settings.ts +2 -1
  830. package/src/stories/Textarea/Textarea.stories.mdx +6 -5
  831. package/src/stories/Textarea/TextareaSlots.stories.mdx +2 -2
  832. package/src/stories/Textarea/TextareatIconPosition.stories.mdx +2 -2
  833. package/src/stories/Tooltip/Tooltip.settings.ts +13 -13
  834. package/src/stories/Tooltip/Tooltip.stories.mdx +26 -22
  835. package/src/stories/Tooltip/Tooltip.test.ts +22 -13
  836. package/src/stories/Tooltip/TooltipDirective.stories.mdx +99 -0
  837. package/src/stories/argTypes.ts +153 -4
  838. package/src/types/floating-ui.d.ts +7 -0
  839. package/src/types/generic.d.ts +0 -1
  840. package/src/types/group.d.ts +37 -0
  841. package/src/utils/ObjectUtilities.ts +4 -1
  842. package/dist/composables/group/types/IAccordionGroupState.d.ts +0 -9
  843. package/dist/composables/group/types/IButtonGroupState.d.ts +0 -13
  844. package/dist/composables/group/types/IGroupState.d.ts +0 -8
  845. package/dist/composables/group/types/IInputGroup.d.ts +0 -8
  846. package/dist/composables/useComponentIcons.d.ts +0 -27
  847. package/src/composables/group/types/IAccordionGroupState.ts +0 -10
  848. package/src/composables/group/types/IButtonGroupState.ts +0 -14
  849. package/src/composables/group/types/IGroupState.ts +0 -10
  850. package/src/composables/group/types/IInputGroup.ts +0 -9
  851. package/src/composables/useComponentIcons.ts +0 -96
  852. package/src/directives/.gitkeep +0 -0
  853. package/src/stories/Dropdown/DropdownOptions.stories.mdx +0 -96
@@ -18,7 +18,9 @@
18
18
  const emit = defineEmits(VvAccordionEvents)
19
19
 
20
20
  // data
21
- const accordionName = props.name || (attrs?.id as string) || nanoid()
21
+ const accordionName = computed(
22
+ () => props.name || (attrs?.id as string) || nanoid(),
23
+ )
22
24
  const {
23
25
  modifiers,
24
26
  title,
@@ -33,9 +35,9 @@
33
35
  get: () => {
34
36
  if (isInGroup.value) {
35
37
  if (collapse.value && Array.isArray(modelValue.value)) {
36
- return modelValue.value.includes(accordionName)
38
+ return modelValue.value.includes(accordionName.value)
37
39
  }
38
- return modelValue.value === accordionName
40
+ return modelValue.value === accordionName.value
39
41
  }
40
42
  // localModelValue is used when the accordion is not in a group
41
43
  if (modelValue.value === undefined) {
@@ -47,15 +49,15 @@
47
49
  if (isInGroup.value) {
48
50
  if (collapse.value && Array.isArray(modelValue.value)) {
49
51
  if (newValue) {
50
- modelValue.value.push(accordionName)
52
+ modelValue.value.push(accordionName.value)
51
53
  return
52
54
  }
53
55
  modelValue.value = modelValue.value.filter(
54
- (name: string) => name !== accordionName,
56
+ (name: string) => name !== accordionName.value,
55
57
  )
56
58
  return
57
59
  }
58
- modelValue.value = newValue ? accordionName : null
60
+ modelValue.value = newValue ? accordionName.value : null
59
61
  return
60
62
  }
61
63
  // localModelValue is used when the accordion is not in a group
@@ -71,10 +73,13 @@
71
73
  })
72
74
 
73
75
  // styles
74
- const { bemCssClasses } = useBemModifiers('vv-accordion', {
76
+ const bemCssClasses = useBemModifiers(
77
+ 'vv-accordion',
75
78
  modifiers,
76
- disabled,
77
- })
79
+ computed(() => ({
80
+ disabled: disabled.value,
81
+ })),
82
+ )
78
83
 
79
84
  // methods
80
85
  const onClick = useToggle(isOpen)
@@ -92,11 +97,13 @@
92
97
  :aria-expanded="isOpen"
93
98
  class="vv-collapse__summary"
94
99
  >
100
+ <!-- @slot Slot for title -->
95
101
  <slot name="summary" v-bind="{ open: isOpen }">
96
102
  {{ title }}
97
103
  </slot>
98
104
  </summary>
99
105
  <div :aria-hidden="!isOpen" class="vv-collapse__content">
106
+ <!-- @slot Slot for content -->
100
107
  <slot name="details" v-bind="{ open: isOpen }">
101
108
  {{ content }}
102
109
  </slot>
@@ -1,6 +1,6 @@
1
1
  import type { ExtractPropTypes, Ref } from 'vue'
2
- import type IAccordionGroupState from '@/composables/group/types/IAccordionGroupState'
3
- import { VV_ACCORDION_GROUP } from '@/constants'
2
+ import type { AccordionGroupState } from '@/types/group'
3
+ import { INJECTION_KEY_ACCORDION_GROUP } from '@/constants'
4
4
 
5
5
  export const VvAccordionProps = {
6
6
  /**
@@ -43,7 +43,9 @@ export function useGroupProps(
43
43
  emit: (event: string, value: unknown) => void,
44
44
  ) {
45
45
  const { group, isInGroup, getGroupOrLocalRef } =
46
- useInjectedGroupState<IAccordionGroupState>(VV_ACCORDION_GROUP)
46
+ useInjectedGroupState<AccordionGroupState>(
47
+ INJECTION_KEY_ACCORDION_GROUP,
48
+ )
47
49
 
48
50
  // local props
49
51
  const { title, content } = toRefs(props)
@@ -6,8 +6,8 @@
6
6
 
7
7
  <script setup lang="ts">
8
8
  import type { Ref } from 'vue'
9
- import type IAccordionGroupState from '@/composables/group/types/IAccordionGroupState'
10
- import { VV_ACCORDION_GROUP } from '@/constants'
9
+ import type { AccordionGroupState } from '@/types/group'
10
+ import { INJECTION_KEY_ACCORDION_GROUP } from '@/constants'
11
11
  import VvAccordion from '@/components/VvAccordion/VvAccordion.vue'
12
12
  import {
13
13
  VvAccordionGroupProps,
@@ -61,26 +61,29 @@
61
61
  })
62
62
 
63
63
  // provide
64
- const accordionGroupState: IAccordionGroupState = {
65
- key: VV_ACCORDION_GROUP,
64
+ useProvideGroupState<AccordionGroupState>({
65
+ key: INJECTION_KEY_ACCORDION_GROUP,
66
66
  modelValue,
67
67
  disabled,
68
68
  collapse,
69
69
  modifiers: itemModifiers,
70
- }
71
- useProvideGroupState(accordionGroupState)
70
+ })
72
71
 
73
72
  // styles
74
- const { bemCssClasses } = useBemModifiers('vv-accordion-group', {
73
+ const bemCssClasses = useBemModifiers(
74
+ 'vv-accordion-group',
75
75
  modifiers,
76
- disabled,
77
- })
76
+ computed(() => ({
77
+ disabled: disabled.value,
78
+ })),
79
+ )
78
80
  </script>
79
81
 
80
82
  <template>
81
83
  <div :class="bemCssClasses">
84
+ <!-- @slot Default slot -->
82
85
  <slot>
83
- <vv-accordion
86
+ <VvAccordion
84
87
  v-for="item in items"
85
88
  :key="item.title"
86
89
  v-bind="{
@@ -90,12 +93,14 @@
90
93
  }"
91
94
  >
92
95
  <template #header="data">
96
+ <!-- @slot Slot for accordion header -->
93
97
  <slot v-bind="data" :name="`header::${item.name}`" />
94
98
  </template>
95
99
  <template #details="data">
100
+ <!-- @slot Slot for accordion details -->
96
101
  <slot v-bind="data" :name="`details::${item.name}`" />
97
102
  </template>
98
- </vv-accordion>
103
+ </VvAccordion>
99
104
  </slot>
100
105
  </div>
101
106
  </template>
@@ -0,0 +1,144 @@
1
+ <script lang="ts">
2
+ export default {
3
+ name: 'VvAction',
4
+ }
5
+ </script>
6
+
7
+ <script setup lang="ts">
8
+ import { VvActionProps, VvActionEvents } from '@/components/VvAction'
9
+ import { ActionTag } from '@/constants'
10
+
11
+ // props and emits
12
+ const props = defineProps(VvActionProps)
13
+ const emits = defineEmits(VvActionEvents)
14
+
15
+ // inject plugin
16
+ const volver = useVolver()
17
+
18
+ const element = ref<HTMLElement | null>(null)
19
+ defineExpose({ $el: element })
20
+
21
+ // drowpdown trigger
22
+ const {
23
+ reference: dropdownTriggerReference,
24
+ bus: dropdownEventBus,
25
+ aria: dropdownAria,
26
+ expanded: dropdownExpanded,
27
+ } = useInjectedDropdownTrigger()
28
+ watch(
29
+ () => element.value,
30
+ (newValue) => {
31
+ if (dropdownTriggerReference) {
32
+ dropdownTriggerReference.value = newValue
33
+ }
34
+ },
35
+ )
36
+
37
+ // pressed
38
+ const pressed = computed(() => {
39
+ return props.pressed || dropdownExpanded?.value
40
+ })
41
+
42
+ // dropdown parent
43
+ const { role } = useInjectedDropdownAction()
44
+
45
+ /**
46
+ * @description The tag defined by props.
47
+ * @returns {string} The tag.
48
+ */
49
+ const hasTag = computed(() => {
50
+ switch (true) {
51
+ case props.disabled:
52
+ return ActionTag.button
53
+ case props.to !== undefined:
54
+ return volver?.nuxt ? ActionTag.nuxtLink : ActionTag.routerLink
55
+ case props.href !== undefined:
56
+ return ActionTag.a
57
+ default:
58
+ return ActionTag.button
59
+ }
60
+ })
61
+
62
+ /**
63
+ * @description Define component attributes.
64
+ * @returns {Object} The component attributes.
65
+ */
66
+ const hasProps = computed(() => {
67
+ const toReturn = {
68
+ ...dropdownAria?.value,
69
+ 'aria-pressed': pressed.value ? true : undefined,
70
+ role,
71
+ }
72
+ switch (hasTag.value) {
73
+ case ActionTag.a:
74
+ return {
75
+ ...toReturn,
76
+ href: props.href,
77
+ target: props.target,
78
+ rel: props.rel,
79
+ }
80
+ case ActionTag.routerLink:
81
+ case ActionTag.nuxtLink:
82
+ return {
83
+ ...toReturn,
84
+ to: props.to,
85
+ target: props.target,
86
+ }
87
+ default:
88
+ return {
89
+ ...toReturn,
90
+ type: props.type,
91
+ disabled: props.disabled,
92
+ }
93
+ }
94
+ })
95
+
96
+ /**
97
+ * @description Catch click event
98
+ */
99
+ const onClick = (e: Event) => {
100
+ if (props.disabled) {
101
+ e.preventDefault()
102
+ return
103
+ }
104
+ dropdownEventBus?.emit('click', e)
105
+ emits('click', e)
106
+ }
107
+
108
+ /**
109
+ * @description Catch mouseover event
110
+ */
111
+ const onMouseover = (e: Event) => {
112
+ dropdownEventBus?.emit('mouseover', e)
113
+ emits('mouseover', e)
114
+ }
115
+
116
+ /**
117
+ * @description Catch mouseleave event
118
+ */
119
+ const onMouseleave = (e: Event) => {
120
+ dropdownEventBus?.emit('mouseleave', e)
121
+ emits('mouseleave', e)
122
+ }
123
+ </script>
124
+
125
+ <template>
126
+ <component
127
+ v-bind="hasProps"
128
+ :is="hasTag"
129
+ ref="element"
130
+ :class="{
131
+ active,
132
+ pressed,
133
+ disabled,
134
+ }"
135
+ @click.passive="onClick"
136
+ @mouseover.passive="onMouseover"
137
+ @mouseleave.passive="onMouseleave"
138
+ >
139
+ <!-- @slot Default slot -->
140
+ <slot>
141
+ {{ label }}
142
+ </slot>
143
+ </component>
144
+ </template>
@@ -0,0 +1,5 @@
1
+ import { ActionProps } from '@/props'
2
+
3
+ export const VvActionEvents = ['click', 'mouseover', 'mouseleave']
4
+
5
+ export const VvActionProps = ActionProps
@@ -8,13 +8,13 @@
8
8
  import { VvBadgeProps } from '@/components/VvBadge'
9
9
 
10
10
  const props = defineProps(VvBadgeProps)
11
- const { bemCssClasses } = useBemModifiers('vv-badge', {
12
- modifiers: props.modifiers,
13
- })
11
+ const { modifiers } = toRefs(props)
12
+ const bemCssClasses = useBemModifiers('vv-badge', modifiers)
14
13
  </script>
15
14
 
16
15
  <template>
17
16
  <span :class="bemCssClasses" role="status">
17
+ <!-- @slot Default slot -->
18
18
  <slot>{{ value }}</slot>
19
19
  </span>
20
20
  </template>
@@ -9,9 +9,8 @@
9
9
  import { VvBreadcrumbProps } from '@/components/VvBreadcrumb'
10
10
 
11
11
  const props = defineProps(VvBreadcrumbProps)
12
- const { bemCssClasses } = useBemModifiers('vv-breadcrumb', {
13
- modifiers: props.modifiers,
14
- })
12
+ const { modifiers } = toRefs(props)
13
+ const bemCssClasses = useBemModifiers('vv-breadcrumb', modifiers)
15
14
  </script>
16
15
 
17
16
  <template>
@@ -29,7 +28,7 @@
29
28
  itemtype="https://schema.org/ListItem"
30
29
  itemscope
31
30
  >
32
- <component
31
+ <Component
33
32
  :is="route.to ? 'router-link' : route.href ? 'a' : 'span'"
34
33
  v-bind="route"
35
34
  :class="{
@@ -43,10 +42,11 @@
43
42
  "
44
43
  itemprop="item"
45
44
  >
45
+ <!-- @slot Slot for label -->
46
46
  <slot name="label" v-bind="{ route, index }">
47
47
  {{ route.label }}
48
48
  </slot>
49
- </component>
49
+ </Component>
50
50
  <meta itemprop="position" :content="`${index + 1}`" />
51
51
  </li>
52
52
  </ol>
@@ -5,16 +5,14 @@
5
5
  </script>
6
6
 
7
7
  <script setup lang="ts">
8
- import { nanoid } from 'nanoid'
9
- import { type IVolver, VOLVER_PREFIX } from '@/Volver'
10
8
  import VvIcon from '@/components/VvIcon/VvIcon.vue'
9
+ import VvAction from '@/components/VvAction/VvAction.vue'
11
10
  import {
12
- ButtonIconPosition,
13
11
  VvButtonEvents,
14
- ButtonTag,
15
12
  VvButtonProps,
16
13
  useGroupProps,
17
14
  } from '@/components/VvButton'
15
+ import { Side } from '@/constants'
18
16
 
19
17
  // props, attrs, slots and emit
20
18
  const props = defineProps(VvButtonProps)
@@ -23,8 +21,8 @@
23
21
  const emit = defineEmits(VvButtonEvents)
24
22
 
25
23
  // data
26
- const name = (attrs?.name as string) || nanoid()
27
24
  const {
25
+ id,
28
26
  modifiers,
29
27
  iconPosition,
30
28
  icon,
@@ -34,62 +32,43 @@
34
32
  toggle,
35
33
  unselectable,
36
34
  } = useGroupProps(props, emit)
35
+ const hasId = useUniqueId(id)
36
+ const name = computed(() => (attrs?.name as string) || hasId.value)
37
37
 
38
- // inject Volver
39
- const ds = inject<IVolver>(VOLVER_PREFIX)
40
-
41
- /**
42
- * @description The tag defined by props.
43
- * @returns {string} The tag.
44
- */
45
- const hasTag = computed(() => {
46
- switch (true) {
47
- case disabled.value:
48
- return ButtonTag.button
49
- case props.to !== undefined:
50
- return ds?.nuxt ? ButtonTag.nuxtLink : ButtonTag.routerLink
51
- case props.href !== undefined:
52
- return ButtonTag.a
53
- default:
54
- return ButtonTag.button
55
- }
56
- })
38
+ // expose el
39
+ const element = ref<{ $el: HTMLElement } | null>(null)
40
+ const $el = computed(() => element.value?.$el)
41
+ defineExpose({ $el })
57
42
 
58
43
  /**
59
44
  * @description The component pressed state by prop or group.
60
45
  * @returns {string} The component tag.
61
46
  */
62
- const isPressed = computed(() => {
63
- if (!toggle.value) return props.pressed
64
-
65
- return Array.isArray(modelValue.value)
66
- ? contains(name, modelValue.value)
67
- : equals(name, modelValue.value)
47
+ const pressed = computed(() => {
48
+ if (!toggle.value) {
49
+ return props.pressed
50
+ }
51
+ if (Array.isArray(modelValue.value)) {
52
+ return contains(name.value, modelValue.value)
53
+ }
54
+ return equals(name.value, modelValue.value)
68
55
  })
69
56
 
70
57
  /**
71
58
  * @description Define component classes with BEM style.
72
59
  * @returns {Array} The component classes.
73
60
  */
74
- const { bemCssClasses } = useBemModifiers('vv-button', {
61
+ const bemCssClasses = useBemModifiers(
62
+ 'vv-button',
75
63
  modifiers,
76
- active: props.active,
77
- pressed: isPressed,
78
- disabled,
79
- reverse: computed(() =>
80
- [ButtonIconPosition.right, ButtonIconPosition.bottom].includes(
81
- iconPosition.value,
64
+ computed(() => ({
65
+ reverse: [Side.right, Side.bottom].includes(iconPosition.value),
66
+ column: [Side.top, Side.bottom].includes(iconPosition.value),
67
+ 'icon-only': Boolean(
68
+ icon?.value && !label?.value && !slots.default,
82
69
  ),
83
- ),
84
- column: computed(() =>
85
- [ButtonIconPosition.top, ButtonIconPosition.bottom].includes(
86
- iconPosition.value,
87
- ),
88
- ),
89
- iconOnly: computed(
90
- () => icon?.value && !label?.value && !slots['default'],
91
- ),
92
- })
70
+ })),
71
+ )
93
72
 
94
73
  /**
95
74
  * @description Define icon attributes.
@@ -100,74 +79,53 @@
100
79
  )
101
80
 
102
81
  /**
103
- * @description Define component attributes.
104
- * @returns {Object} The component attributes.
105
- */
106
- const hasProps = computed(() => {
107
- const toReturn = {
108
- class: bemCssClasses.value,
109
- 'aria-pressed': isPressed.value ? true : undefined,
110
- }
111
- switch (hasTag.value) {
112
- case ButtonTag.a:
113
- return {
114
- ...toReturn,
115
- role: 'button',
116
- href: props.href,
117
- target: props.target,
118
- rel: props.rel,
119
- }
120
- case ButtonTag.routerLink:
121
- case ButtonTag.nuxtLink:
122
- return {
123
- ...toReturn,
124
- role: 'button',
125
- to: props.to,
126
- target: props.target,
127
- }
128
- default:
129
- return {
130
- ...toReturn,
131
- type: props.type,
132
- disabled: disabled.value,
133
- }
134
- }
135
- })
136
-
137
- /**
138
- * @description Catch click event in a group.
82
+ * @description Catch click event
139
83
  */
140
84
  const onClick = () => {
141
85
  if (toggle.value) {
142
86
  if (Array.isArray(modelValue.value)) {
143
- if (contains(name, modelValue.value)) {
87
+ if (contains(name.value, modelValue.value)) {
144
88
  if (unselectable.value) {
145
89
  modelValue.value = modelValue.value.filter(
146
- (n) => n !== name,
90
+ (n) => n !== name.value,
147
91
  )
148
92
  }
149
93
  return
150
94
  }
151
- modelValue.value.push(name)
95
+ modelValue.value.push(name.value)
152
96
  return
153
97
  }
154
- if (equals(name, modelValue.value) && unselectable.value) {
98
+ if (equals(name.value, modelValue.value) && unselectable.value) {
155
99
  modelValue.value = undefined
156
100
  return
157
101
  }
158
- modelValue.value = name
102
+ modelValue.value = name.value
159
103
  }
160
104
  }
161
105
  </script>
162
106
 
163
107
  <template>
164
- <!-- #region component: "button" | "a" | "router-link" | "nuxt-link" -->
165
- <component v-bind="hasProps" :is="hasTag" @click.passive="onClick">
166
- <!-- @slot Replace all button content -->
108
+ <VvAction
109
+ v-bind="{
110
+ disabled,
111
+ pressed,
112
+ active,
113
+ type,
114
+ to,
115
+ href,
116
+ target,
117
+ rel,
118
+ }"
119
+ :id="hasId"
120
+ ref="element"
121
+ :class="bemCssClasses"
122
+ @click="onClick"
123
+ >
124
+ <!-- @slot Default slot -->
167
125
  <slot>
168
126
  <!-- #region loading -->
169
127
  <template v-if="loading">
170
- <!-- @slot Replace all button content on loading -->
128
+ <!-- @slot Slot for loading content -->
171
129
  <slot name="loading">
172
130
  <VvIcon
173
131
  v-if="loadingIcon"
@@ -179,29 +137,24 @@
179
137
  </span>
180
138
  </slot>
181
139
  </template>
182
- <!-- #endregion loading -->
140
+ <!-- #endregion -->
183
141
  <!-- #region button -->
184
142
  <template v-else>
185
143
  <!-- @slot Before label and icon -->
186
144
  <slot name="before" />
187
- <!-- #region icon -->
188
145
  <template v-if="icon">
189
146
  <VvIcon class="vv-button__icon" v-bind="hasIconProps" />
190
147
  </template>
191
- <!-- #endregion icon -->
192
- <!-- #region label -->
193
148
  <span v-if="label" class="vv-button__label">
194
149
  <!-- @slot Use this slot for button label -->
195
150
  <slot name="label">
196
151
  {{ label }}
197
152
  </slot>
198
153
  </span>
199
- <!-- #endregion label -->
200
154
  <!-- @slot After label and icon -->
201
155
  <slot name="after" />
202
156
  </template>
203
- <!-- #endregion button -->
157
+ <!-- #endregion -->
204
158
  </slot>
205
- </component>
206
- <!-- #endregion component: button | a | router-link | nuxt-link -->
159
+ </VvAction>
207
160
  </template>