@volverjs/ui-vue 0.0.1-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (933) hide show
  1. package/README.md +32 -0
  2. package/dist/DesignSystem.d.ts +67 -0
  3. package/dist/components/VvAccordion/VvAccordion.d.ts +32 -0
  4. package/dist/components/VvAccordion/VvAccordion.vue.d.ts +104 -0
  5. package/dist/components/VvAccordion/useAccordionProps.d.ts +16 -0
  6. package/dist/components/VvAccordion/vv-accordion.es.js +262 -0
  7. package/dist/components/VvAccordion/vv-accordion.umd.js +1 -0
  8. package/dist/components/VvAccordionGroup/VvAccordionGroup.d.ts +50 -0
  9. package/dist/components/VvAccordionGroup/VvAccordionGroup.vue.d.ts +170 -0
  10. package/dist/components/VvAccordionGroup/vv-accordion-group.es.js +315 -0
  11. package/dist/components/VvAccordionGroup/vv-accordion-group.umd.js +1 -0
  12. package/dist/components/VvBadge/VvBadge.d.ts +4 -0
  13. package/dist/components/VvBadge/VvBadge.vue.d.ts +56 -0
  14. package/dist/components/VvBadge/vv-badge.es.js +18 -0
  15. package/dist/components/VvBadge/vv-badge.umd.js +1 -0
  16. package/dist/components/VvBreadcrumb/VvBreadcrumb.d.ts +26 -0
  17. package/dist/components/VvBreadcrumb/VvBreadcrumb.vue.d.ts +118 -0
  18. package/dist/components/VvBreadcrumb/vv-breadcrumb.es.js +206 -0
  19. package/dist/components/VvBreadcrumb/vv-breadcrumb.umd.js +1 -0
  20. package/dist/components/VvButton/VvButton.d.ts +115 -0
  21. package/dist/components/VvButton/VvButton.vue.d.ts +228 -0
  22. package/dist/components/VvButton/useButtonGroupProps.d.ts +23 -0
  23. package/dist/components/VvButton/vv-button.es.js +424 -0
  24. package/dist/components/VvButton/vv-button.umd.js +1 -0
  25. package/dist/components/VvButtonGroup/VvButtonGroup.d.ts +57 -0
  26. package/dist/components/VvButtonGroup/VvButtonGroup.vue.d.ts +210 -0
  27. package/dist/components/VvButtonGroup/vv-button-group.es.js +210 -0
  28. package/dist/components/VvButtonGroup/vv-button-group.umd.js +1 -0
  29. package/dist/components/VvCard/VvCard.d.ts +4 -0
  30. package/dist/components/VvCard/VvCard.vue.d.ts +63 -0
  31. package/dist/components/VvCard/vv-card.es.js +188 -0
  32. package/dist/components/VvCard/vv-card.umd.js +1 -0
  33. package/dist/components/VvCheck/VvCheck.d.ts +47 -0
  34. package/dist/components/VvCheck/VvCheck.vue.d.ts +165 -0
  35. package/dist/components/VvCheck/useCheckProps.d.ts +16 -0
  36. package/dist/components/VvCheck/vv-check.es.js +321 -0
  37. package/dist/components/VvCheck/vv-check.umd.js +1 -0
  38. package/dist/components/VvCheckGroup/VvCheckGroup.d.ts +65 -0
  39. package/dist/components/VvCheckGroup/VvCheckGroup.vue.d.ts +272 -0
  40. package/dist/components/VvCheckGroup/vv-check-group.es.js +434 -0
  41. package/dist/components/VvCheckGroup/vv-check-group.umd.js +2 -0
  42. package/dist/components/VvDialog/VvDialog.d.ts +22 -0
  43. package/dist/components/VvDialog/VvDialog.vue.d.ts +153 -0
  44. package/dist/components/VvDialog/constants.d.ts +5 -0
  45. package/dist/components/VvDialog/vv-dialog.es.js +315 -0
  46. package/dist/components/VvDialog/vv-dialog.umd.js +1 -0
  47. package/dist/components/VvDropdown/VvDropdown.d.ts +52 -0
  48. package/dist/components/VvDropdown/VvDropdown.vue.d.ts +166 -0
  49. package/dist/components/VvDropdown/vv-dropdown.es.js +236 -0
  50. package/dist/components/VvDropdown/vv-dropdown.umd.js +1 -0
  51. package/dist/components/VvIcon/VvIcon.d.ts +92 -0
  52. package/dist/components/VvIcon/VvIcon.vue.d.ts +183 -0
  53. package/dist/components/VvIcon/vv-icon.es.js +229 -0
  54. package/dist/components/VvIcon/vv-icon.umd.js +1 -0
  55. package/dist/components/VvInputText/VvInputText.d.ts +59 -0
  56. package/dist/components/VvInputText/VvInputText.vue.d.ts +292 -0
  57. package/dist/components/VvInputText/constants.d.ts +55 -0
  58. package/dist/components/VvInputText/useInputNumber.d.ts +16 -0
  59. package/dist/components/VvInputText/useInputPassword.d.ts +16 -0
  60. package/dist/components/VvInputText/vv-input-text.es.js +596 -0
  61. package/dist/components/VvInputText/vv-input-text.umd.js +2 -0
  62. package/dist/components/VvNativeSelect/VvNativeSelect.d.ts +70 -0
  63. package/dist/components/VvNativeSelect/VvNativeSelect.vue.d.ts +228 -0
  64. package/dist/components/VvNativeSelect/vv-native-select.es.js +395 -0
  65. package/dist/components/VvNativeSelect/vv-native-select.umd.js +2 -0
  66. package/dist/components/VvProgress/VvProgress.d.ts +29 -0
  67. package/dist/components/VvProgress/VvProgress.vue.d.ts +117 -0
  68. package/dist/components/VvProgress/vv-progress.es.js +185 -0
  69. package/dist/components/VvProgress/vv-progress.umd.js +1 -0
  70. package/dist/components/VvRadio/VvRadio.d.ts +22 -0
  71. package/dist/components/VvRadio/VvRadio.vue.d.ts +136 -0
  72. package/dist/components/VvRadio/useRadioProps.d.ts +15 -0
  73. package/dist/components/VvRadio/vv-radio.es.js +309 -0
  74. package/dist/components/VvRadio/vv-radio.umd.js +1 -0
  75. package/dist/components/VvRadioGroup/VvRadioGroup.d.ts +54 -0
  76. package/dist/components/VvRadioGroup/VvRadioGroup.vue.d.ts +264 -0
  77. package/dist/components/VvRadioGroup/vv-radio-group.es.js +423 -0
  78. package/dist/components/VvRadioGroup/vv-radio-group.umd.js +2 -0
  79. package/dist/components/VvSelect/VvSelect.d.ts +99 -0
  80. package/dist/components/VvSelect/VvSelect.vue.d.ts +294 -0
  81. package/dist/components/VvSelect/vv-select.es.js +427 -0
  82. package/dist/components/VvSelect/vv-select.umd.js +2 -0
  83. package/dist/components/VvTextarea/VvTextarea.d.ts +67 -0
  84. package/dist/components/VvTextarea/VvTextarea.vue.d.ts +314 -0
  85. package/dist/components/VvTextarea/constants.d.ts +19 -0
  86. package/dist/components/VvTextarea/vv-textarea.es.js +472 -0
  87. package/dist/components/VvTextarea/vv-textarea.umd.js +2 -0
  88. package/dist/components/common/HintSlot.d.ts +25 -0
  89. package/dist/components/index.d.ts +12 -0
  90. package/dist/composables/focus/useComponentFocus.d.ts +7 -0
  91. package/dist/composables/group/types/IAccordionGroupState.d.ts +10 -0
  92. package/dist/composables/group/types/IButtonGroupState.d.ts +19 -0
  93. package/dist/composables/group/types/IGroupState.d.ts +11 -0
  94. package/dist/composables/group/types/IInputGroup.d.ts +11 -0
  95. package/dist/composables/group/useInjectedGroupState.d.ts +10 -0
  96. package/dist/composables/group/useProvideGroupState.d.ts +6 -0
  97. package/dist/composables/icons/useComponentIcons.d.ts +20 -0
  98. package/dist/composables/options/useOptions.d.ts +5 -0
  99. package/dist/composables/useModifiers.d.ts +9 -0
  100. package/dist/constants.d.ts +4 -0
  101. package/dist/icons.es.js +1885 -0
  102. package/dist/icons.umd.js +1 -0
  103. package/dist/index.d.ts +4 -0
  104. package/dist/props/index.d.ts +50 -0
  105. package/dist/stories/Icon/IconList.vue.d.ts +44 -0
  106. package/dist/ui-vue.es.js +2985 -0
  107. package/dist/ui-vue.umd.js +2 -0
  108. package/dist/utils/ObjectUtilities.d.ts +96 -0
  109. package/package.json +187 -0
  110. package/src/DesignSystem.ts +115 -0
  111. package/src/assets/icons/detailed/add-circle.svg +1 -0
  112. package/src/assets/icons/detailed/add.svg +1 -0
  113. package/src/assets/icons/detailed/align-center.svg +1 -0
  114. package/src/assets/icons/detailed/align-justify.svg +1 -0
  115. package/src/assets/icons/detailed/align-left.svg +1 -0
  116. package/src/assets/icons/detailed/align-right.svg +1 -0
  117. package/src/assets/icons/detailed/analysis-2.svg +1 -0
  118. package/src/assets/icons/detailed/analysis-3.svg +1 -0
  119. package/src/assets/icons/detailed/analysis.svg +1 -0
  120. package/src/assets/icons/detailed/apple.svg +1 -0
  121. package/src/assets/icons/detailed/arrow-down.svg +1 -0
  122. package/src/assets/icons/detailed/arrow-left.svg +1 -0
  123. package/src/assets/icons/detailed/arrow-right.svg +1 -0
  124. package/src/assets/icons/detailed/arrow-up.svg +1 -0
  125. package/src/assets/icons/detailed/attachment.svg +1 -0
  126. package/src/assets/icons/detailed/back-to-front.svg +1 -0
  127. package/src/assets/icons/detailed/bell-active.svg +1 -0
  128. package/src/assets/icons/detailed/bell.svg +1 -0
  129. package/src/assets/icons/detailed/bold.svg +1 -0
  130. package/src/assets/icons/detailed/bookmark-active.svg +1 -0
  131. package/src/assets/icons/detailed/bookmark.svg +1 -0
  132. package/src/assets/icons/detailed/building.svg +1 -0
  133. package/src/assets/icons/detailed/bullet-list.svg +1 -0
  134. package/src/assets/icons/detailed/calendar.svg +1 -0
  135. package/src/assets/icons/detailed/camera-off.svg +1 -0
  136. package/src/assets/icons/detailed/camera-on.svg +1 -0
  137. package/src/assets/icons/detailed/catalog.svg +1 -0
  138. package/src/assets/icons/detailed/certificate.svg +1 -0
  139. package/src/assets/icons/detailed/chat.svg +1 -0
  140. package/src/assets/icons/detailed/check-badge.svg +1 -0
  141. package/src/assets/icons/detailed/check-circle.svg +1 -0
  142. package/src/assets/icons/detailed/check.svg +1 -0
  143. package/src/assets/icons/detailed/checkbox.svg +1 -0
  144. package/src/assets/icons/detailed/chevron-down-circle.svg +1 -0
  145. package/src/assets/icons/detailed/chevron-down.svg +1 -0
  146. package/src/assets/icons/detailed/chevron-left-circle.svg +1 -0
  147. package/src/assets/icons/detailed/chevron-left.svg +1 -0
  148. package/src/assets/icons/detailed/chevron-right-circle.svg +1 -0
  149. package/src/assets/icons/detailed/chevron-up-circle.svg +1 -0
  150. package/src/assets/icons/detailed/chevron-up.svg +1 -0
  151. package/src/assets/icons/detailed/classroom.svg +1 -0
  152. package/src/assets/icons/detailed/clear-field.svg +1 -0
  153. package/src/assets/icons/detailed/clear-style.svg +1 -0
  154. package/src/assets/icons/detailed/close-circle.svg +1 -0
  155. package/src/assets/icons/detailed/close-loader.svg +1 -0
  156. package/src/assets/icons/detailed/close.svg +1 -0
  157. package/src/assets/icons/detailed/coffee.svg +1 -0
  158. package/src/assets/icons/detailed/color.svg +1 -0
  159. package/src/assets/icons/detailed/contact-us.svg +1 -0
  160. package/src/assets/icons/detailed/copy.svg +1 -0
  161. package/src/assets/icons/detailed/courses.svg +1 -0
  162. package/src/assets/icons/detailed/dashboard.svg +1 -0
  163. package/src/assets/icons/detailed/download.svg +1 -0
  164. package/src/assets/icons/detailed/drag.svg +1 -0
  165. package/src/assets/icons/detailed/duplicate.svg +1 -0
  166. package/src/assets/icons/detailed/edit.svg +1 -0
  167. package/src/assets/icons/detailed/elearning.svg +1 -0
  168. package/src/assets/icons/detailed/email.svg +1 -0
  169. package/src/assets/icons/detailed/error-2.svg +1 -0
  170. package/src/assets/icons/detailed/error.svg +1 -0
  171. package/src/assets/icons/detailed/exercise.svg +1 -0
  172. package/src/assets/icons/detailed/external-link.svg +1 -0
  173. package/src/assets/icons/detailed/extract.svg +1 -0
  174. package/src/assets/icons/detailed/eye-off.svg +1 -0
  175. package/src/assets/icons/detailed/eye-on.svg +1 -0
  176. package/src/assets/icons/detailed/fail.svg +1 -0
  177. package/src/assets/icons/detailed/fast-back.svg +1 -0
  178. package/src/assets/icons/detailed/fast-forward.svg +1 -0
  179. package/src/assets/icons/detailed/file-add.svg +1 -0
  180. package/src/assets/icons/detailed/file-duplicate.svg +1 -0
  181. package/src/assets/icons/detailed/file-remove.svg +1 -0
  182. package/src/assets/icons/detailed/file-required.svg +1 -0
  183. package/src/assets/icons/detailed/file.svg +1 -0
  184. package/src/assets/icons/detailed/filter-2.svg +1 -0
  185. package/src/assets/icons/detailed/filter-active.svg +1 -0
  186. package/src/assets/icons/detailed/filter.svg +1 -0
  187. package/src/assets/icons/detailed/flag.svg +1 -0
  188. package/src/assets/icons/detailed/folder.svg +1 -0
  189. package/src/assets/icons/detailed/full-width.svg +1 -0
  190. package/src/assets/icons/detailed/go-to-back.svg +1 -0
  191. package/src/assets/icons/detailed/grid.svg +1 -0
  192. package/src/assets/icons/detailed/group-add.svg +1 -0
  193. package/src/assets/icons/detailed/group.svg +1 -0
  194. package/src/assets/icons/detailed/heart-active.svg +1 -0
  195. package/src/assets/icons/detailed/heart.svg +1 -0
  196. package/src/assets/icons/detailed/highlighter.svg +1 -0
  197. package/src/assets/icons/detailed/home.svg +1 -0
  198. package/src/assets/icons/detailed/hourglass.svg +1 -0
  199. package/src/assets/icons/detailed/image.svg +1 -0
  200. package/src/assets/icons/detailed/info-badge.svg +1 -0
  201. package/src/assets/icons/detailed/information.svg +1 -0
  202. package/src/assets/icons/detailed/italic.svg +1 -0
  203. package/src/assets/icons/detailed/key.svg +1 -0
  204. package/src/assets/icons/detailed/language.svg +1 -0
  205. package/src/assets/icons/detailed/learning-path.svg +1 -0
  206. package/src/assets/icons/detailed/light-off.svg +1 -0
  207. package/src/assets/icons/detailed/light-on.svg +1 -0
  208. package/src/assets/icons/detailed/link.svg +1 -0
  209. package/src/assets/icons/detailed/lock.svg +1 -0
  210. package/src/assets/icons/detailed/login.svg +1 -0
  211. package/src/assets/icons/detailed/logout.svg +1 -0
  212. package/src/assets/icons/detailed/maximaze.svg +1 -0
  213. package/src/assets/icons/detailed/menu.svg +1 -0
  214. package/src/assets/icons/detailed/merge.svg +1 -0
  215. package/src/assets/icons/detailed/minimize.svg +1 -0
  216. package/src/assets/icons/detailed/mixed-class.svg +1 -0
  217. package/src/assets/icons/detailed/more-horizontal.svg +1 -0
  218. package/src/assets/icons/detailed/more-vertical.svg +1 -0
  219. package/src/assets/icons/detailed/news.svg +1 -0
  220. package/src/assets/icons/detailed/no-prerequisites.svg +1 -0
  221. package/src/assets/icons/detailed/notes.svg +1 -0
  222. package/src/assets/icons/detailed/number-code.svg +1 -0
  223. package/src/assets/icons/detailed/numbered-list.svg +1 -0
  224. package/src/assets/icons/detailed/on-site.svg +1 -0
  225. package/src/assets/icons/detailed/order-down.svg +1 -0
  226. package/src/assets/icons/detailed/order-up.svg +1 -0
  227. package/src/assets/icons/detailed/paste.svg +1 -0
  228. package/src/assets/icons/detailed/pausa.svg +1 -0
  229. package/src/assets/icons/detailed/pdf.svg +1 -0
  230. package/src/assets/icons/detailed/phone.svg +1 -0
  231. package/src/assets/icons/detailed/pin-map.svg +1 -0
  232. package/src/assets/icons/detailed/pin.svg +1 -0
  233. package/src/assets/icons/detailed/pizza.svg +1 -0
  234. package/src/assets/icons/detailed/play.svg +1 -0
  235. package/src/assets/icons/detailed/plug-in.svg +1 -0
  236. package/src/assets/icons/detailed/pointer.svg +1 -0
  237. package/src/assets/icons/detailed/printer.svg +1 -0
  238. package/src/assets/icons/detailed/profile-add.svg +1 -0
  239. package/src/assets/icons/detailed/profile.svg +1 -0
  240. package/src/assets/icons/detailed/push-pin-off.svg +1 -0
  241. package/src/assets/icons/detailed/push-pin-on.svg +1 -0
  242. package/src/assets/icons/detailed/qrcode.svg +1 -0
  243. package/src/assets/icons/detailed/question-badge.svg +1 -0
  244. package/src/assets/icons/detailed/radio.svg +1 -0
  245. package/src/assets/icons/detailed/redo.svg +1 -0
  246. package/src/assets/icons/detailed/relations.svg +1 -0
  247. package/src/assets/icons/detailed/reload.svg +1 -0
  248. package/src/assets/icons/detailed/remove-circle.svg +1 -0
  249. package/src/assets/icons/detailed/remove.svg +1 -0
  250. package/src/assets/icons/detailed/reorder.svg +1 -0
  251. package/src/assets/icons/detailed/repeat.svg +1 -0
  252. package/src/assets/icons/detailed/repository.svg +1 -0
  253. package/src/assets/icons/detailed/request-form.svg +1 -0
  254. package/src/assets/icons/detailed/resize-100%.svg +1 -0
  255. package/src/assets/icons/detailed/resize-height.svg +1 -0
  256. package/src/assets/icons/detailed/resize-width.svg +1 -0
  257. package/src/assets/icons/detailed/search.svg +1 -0
  258. package/src/assets/icons/detailed/sequential-prerequisites.svg +1 -0
  259. package/src/assets/icons/detailed/settings.svg +1 -0
  260. package/src/assets/icons/detailed/share.svg +1 -0
  261. package/src/assets/icons/detailed/sketch.svg +1 -0
  262. package/src/assets/icons/detailed/skills.svg +1 -0
  263. package/src/assets/icons/detailed/skip-back.svg +1 -0
  264. package/src/assets/icons/detailed/skip-forward.svg +1 -0
  265. package/src/assets/icons/detailed/sms.svg +1 -0
  266. package/src/assets/icons/detailed/sso-access.svg +1 -0
  267. package/src/assets/icons/detailed/star-active.svg +1 -0
  268. package/src/assets/icons/detailed/star.svg +1 -0
  269. package/src/assets/icons/detailed/success.svg +1 -0
  270. package/src/assets/icons/detailed/sun.svg +1 -0
  271. package/src/assets/icons/detailed/sunrise.svg +1 -0
  272. package/src/assets/icons/detailed/support.svg +1 -0
  273. package/src/assets/icons/detailed/survey.svg +1 -0
  274. package/src/assets/icons/detailed/table.svg +1 -0
  275. package/src/assets/icons/detailed/tematic-channels.svg +1 -0
  276. package/src/assets/icons/detailed/test.svg +1 -0
  277. package/src/assets/icons/detailed/text-body.svg +1 -0
  278. package/src/assets/icons/detailed/text-edit.svg +1 -0
  279. package/src/assets/icons/detailed/text-style.svg +1 -0
  280. package/src/assets/icons/detailed/time.svg +1 -0
  281. package/src/assets/icons/detailed/toilet-piper.svg +1 -0
  282. package/src/assets/icons/detailed/training-points.svg +1 -0
  283. package/src/assets/icons/detailed/trash.svg +1 -0
  284. package/src/assets/icons/detailed/underline.svg +1 -0
  285. package/src/assets/icons/detailed/undo.svg +1 -0
  286. package/src/assets/icons/detailed/unlock.svg +1 -0
  287. package/src/assets/icons/detailed/upload.svg +1 -0
  288. package/src/assets/icons/detailed/user-add.svg +1 -0
  289. package/src/assets/icons/detailed/user-badge.svg +1 -0
  290. package/src/assets/icons/detailed/user.svg +1 -0
  291. package/src/assets/icons/detailed/video-off.svg +1 -0
  292. package/src/assets/icons/detailed/video-on.svg +1 -0
  293. package/src/assets/icons/detailed/video-rec.svg +1 -0
  294. package/src/assets/icons/detailed/view-card.svg +1 -0
  295. package/src/assets/icons/detailed/view-list.svg +1 -0
  296. package/src/assets/icons/detailed/view.svg +1 -0
  297. package/src/assets/icons/detailed/voice-off.svg +1 -0
  298. package/src/assets/icons/detailed/voice-on.svg +1 -0
  299. package/src/assets/icons/detailed/volume-down.svg +1 -0
  300. package/src/assets/icons/detailed/volume-off.svg +1 -0
  301. package/src/assets/icons/detailed/volume-up.svg +1 -0
  302. package/src/assets/icons/detailed/warning.svg +1 -0
  303. package/src/assets/icons/detailed/webinar.svg +1 -0
  304. package/src/assets/icons/detailed/whiteboard.svg +1 -0
  305. package/src/assets/icons/detailed/wine.svg +1 -0
  306. package/src/assets/icons/detailed/zip.svg +1 -0
  307. package/src/assets/icons/detailed/zoom-in.svg +1 -0
  308. package/src/assets/icons/detailed/zoom-out.svg +1 -0
  309. package/src/assets/icons/detailed.json +1 -0
  310. package/src/assets/icons/index.js +7 -0
  311. package/src/assets/icons/normal/add-circle.svg +1 -0
  312. package/src/assets/icons/normal/add.svg +1 -0
  313. package/src/assets/icons/normal/align-center.svg +1 -0
  314. package/src/assets/icons/normal/align-justify.svg +1 -0
  315. package/src/assets/icons/normal/align-left.svg +1 -0
  316. package/src/assets/icons/normal/align-right.svg +1 -0
  317. package/src/assets/icons/normal/analysis-2.svg +1 -0
  318. package/src/assets/icons/normal/analysis-3.svg +1 -0
  319. package/src/assets/icons/normal/analysis.svg +1 -0
  320. package/src/assets/icons/normal/apple.svg +1 -0
  321. package/src/assets/icons/normal/arrow-down.svg +1 -0
  322. package/src/assets/icons/normal/arrow-left.svg +1 -0
  323. package/src/assets/icons/normal/arrow-right.svg +1 -0
  324. package/src/assets/icons/normal/arrow-up.svg +1 -0
  325. package/src/assets/icons/normal/attachment.svg +1 -0
  326. package/src/assets/icons/normal/back-to-front.svg +1 -0
  327. package/src/assets/icons/normal/bell-active.svg +1 -0
  328. package/src/assets/icons/normal/bell.svg +1 -0
  329. package/src/assets/icons/normal/bold.svg +1 -0
  330. package/src/assets/icons/normal/bookmark active.svg +1 -0
  331. package/src/assets/icons/normal/bookmark.svg +1 -0
  332. package/src/assets/icons/normal/building.svg +1 -0
  333. package/src/assets/icons/normal/bulleted-list.svg +1 -0
  334. package/src/assets/icons/normal/calendar.svg +1 -0
  335. package/src/assets/icons/normal/camera-off.svg +1 -0
  336. package/src/assets/icons/normal/camera-on.svg +1 -0
  337. package/src/assets/icons/normal/catalog.svg +1 -0
  338. package/src/assets/icons/normal/certificate.svg +1 -0
  339. package/src/assets/icons/normal/chat.svg +1 -0
  340. package/src/assets/icons/normal/check-badge.svg +1 -0
  341. package/src/assets/icons/normal/check-circle.svg +1 -0
  342. package/src/assets/icons/normal/check.svg +1 -0
  343. package/src/assets/icons/normal/checkbox.svg +1 -0
  344. package/src/assets/icons/normal/chevron-down-circle.svg +1 -0
  345. package/src/assets/icons/normal/chevron-down.svg +1 -0
  346. package/src/assets/icons/normal/chevron-left-circle.svg +1 -0
  347. package/src/assets/icons/normal/chevron-left.svg +1 -0
  348. package/src/assets/icons/normal/chevron-right-circle.svg +1 -0
  349. package/src/assets/icons/normal/chevron-right.svg +1 -0
  350. package/src/assets/icons/normal/chevron-up-circle.svg +1 -0
  351. package/src/assets/icons/normal/chevron-up.svg +1 -0
  352. package/src/assets/icons/normal/classroom.svg +1 -0
  353. package/src/assets/icons/normal/clear-field.svg +1 -0
  354. package/src/assets/icons/normal/clear-style.svg +1 -0
  355. package/src/assets/icons/normal/close-circle.svg +1 -0
  356. package/src/assets/icons/normal/close-loader.svg +1 -0
  357. package/src/assets/icons/normal/close.svg +1 -0
  358. package/src/assets/icons/normal/coffee.svg +1 -0
  359. package/src/assets/icons/normal/color.svg +1 -0
  360. package/src/assets/icons/normal/contact-us.svg +1 -0
  361. package/src/assets/icons/normal/copy.svg +1 -0
  362. package/src/assets/icons/normal/courses.svg +1 -0
  363. package/src/assets/icons/normal/dashboard.svg +1 -0
  364. package/src/assets/icons/normal/download.svg +1 -0
  365. package/src/assets/icons/normal/drag.svg +1 -0
  366. package/src/assets/icons/normal/dulicate.svg +1 -0
  367. package/src/assets/icons/normal/edit.svg +1 -0
  368. package/src/assets/icons/normal/elearning.svg +1 -0
  369. package/src/assets/icons/normal/email.svg +1 -0
  370. package/src/assets/icons/normal/error-2.svg +1 -0
  371. package/src/assets/icons/normal/error.svg +1 -0
  372. package/src/assets/icons/normal/exercise.svg +1 -0
  373. package/src/assets/icons/normal/external-link.svg +1 -0
  374. package/src/assets/icons/normal/extract.svg +1 -0
  375. package/src/assets/icons/normal/eye-off.svg +1 -0
  376. package/src/assets/icons/normal/eye-on.svg +1 -0
  377. package/src/assets/icons/normal/fail.svg +1 -0
  378. package/src/assets/icons/normal/fast-back.svg +1 -0
  379. package/src/assets/icons/normal/fast-forward.svg +1 -0
  380. package/src/assets/icons/normal/file-add.svg +1 -0
  381. package/src/assets/icons/normal/file-duplicate.svg +1 -0
  382. package/src/assets/icons/normal/file-remove.svg +1 -0
  383. package/src/assets/icons/normal/file-required.svg +1 -0
  384. package/src/assets/icons/normal/file.svg +1 -0
  385. package/src/assets/icons/normal/filter-2.svg +1 -0
  386. package/src/assets/icons/normal/filter-active.svg +1 -0
  387. package/src/assets/icons/normal/filter.svg +1 -0
  388. package/src/assets/icons/normal/flag.svg +1 -0
  389. package/src/assets/icons/normal/folder.svg +1 -0
  390. package/src/assets/icons/normal/full-width.svg +1 -0
  391. package/src/assets/icons/normal/go-to-back.svg +1 -0
  392. package/src/assets/icons/normal/grid.svg +1 -0
  393. package/src/assets/icons/normal/group-add.svg +1 -0
  394. package/src/assets/icons/normal/group.svg +1 -0
  395. package/src/assets/icons/normal/heart-active.svg +1 -0
  396. package/src/assets/icons/normal/heart.svg +1 -0
  397. package/src/assets/icons/normal/highlighter.svg +1 -0
  398. package/src/assets/icons/normal/home.svg +1 -0
  399. package/src/assets/icons/normal/hourglass.svg +1 -0
  400. package/src/assets/icons/normal/image.svg +1 -0
  401. package/src/assets/icons/normal/info-badge.svg +1 -0
  402. package/src/assets/icons/normal/information.svg +1 -0
  403. package/src/assets/icons/normal/italic.svg +1 -0
  404. package/src/assets/icons/normal/key.svg +1 -0
  405. package/src/assets/icons/normal/language.svg +1 -0
  406. package/src/assets/icons/normal/learning-path.svg +1 -0
  407. package/src/assets/icons/normal/light-off.svg +1 -0
  408. package/src/assets/icons/normal/light-on.svg +1 -0
  409. package/src/assets/icons/normal/link.svg +1 -0
  410. package/src/assets/icons/normal/lock.svg +1 -0
  411. package/src/assets/icons/normal/login.svg +1 -0
  412. package/src/assets/icons/normal/logout.svg +1 -0
  413. package/src/assets/icons/normal/maximize.svg +1 -0
  414. package/src/assets/icons/normal/menu.svg +1 -0
  415. package/src/assets/icons/normal/merge.svg +1 -0
  416. package/src/assets/icons/normal/minimize.svg +1 -0
  417. package/src/assets/icons/normal/mixed-class.svg +1 -0
  418. package/src/assets/icons/normal/more-horizontal.svg +1 -0
  419. package/src/assets/icons/normal/more-vertical.svg +1 -0
  420. package/src/assets/icons/normal/news.svg +1 -0
  421. package/src/assets/icons/normal/no-prerequisites.svg +1 -0
  422. package/src/assets/icons/normal/notes.svg +1 -0
  423. package/src/assets/icons/normal/number-code.svg +1 -0
  424. package/src/assets/icons/normal/numbered-list.svg +1 -0
  425. package/src/assets/icons/normal/on-site.svg +1 -0
  426. package/src/assets/icons/normal/order-down.svg +1 -0
  427. package/src/assets/icons/normal/order-up.svg +1 -0
  428. package/src/assets/icons/normal/paste.svg +1 -0
  429. package/src/assets/icons/normal/pausa.svg +1 -0
  430. package/src/assets/icons/normal/pdf.svg +1 -0
  431. package/src/assets/icons/normal/phone.svg +1 -0
  432. package/src/assets/icons/normal/pin-map.svg +1 -0
  433. package/src/assets/icons/normal/pin.svg +1 -0
  434. package/src/assets/icons/normal/pizza.svg +1 -0
  435. package/src/assets/icons/normal/play.svg +1 -0
  436. package/src/assets/icons/normal/plug-in.svg +1 -0
  437. package/src/assets/icons/normal/pointer.svg +1 -0
  438. package/src/assets/icons/normal/printer.svg +1 -0
  439. package/src/assets/icons/normal/profile-add.svg +1 -0
  440. package/src/assets/icons/normal/profile.svg +1 -0
  441. package/src/assets/icons/normal/push pin on.svg +1 -0
  442. package/src/assets/icons/normal/push-pin-off.svg +1 -0
  443. package/src/assets/icons/normal/qrcode.svg +1 -0
  444. package/src/assets/icons/normal/question-badge.svg +1 -0
  445. package/src/assets/icons/normal/radio.svg +1 -0
  446. package/src/assets/icons/normal/redo.svg +1 -0
  447. package/src/assets/icons/normal/relations.svg +1 -0
  448. package/src/assets/icons/normal/reload.svg +1 -0
  449. package/src/assets/icons/normal/remove-circle.svg +1 -0
  450. package/src/assets/icons/normal/remove.svg +1 -0
  451. package/src/assets/icons/normal/reorder.svg +1 -0
  452. package/src/assets/icons/normal/repeat.svg +1 -0
  453. package/src/assets/icons/normal/repository.svg +1 -0
  454. package/src/assets/icons/normal/request-form.svg +1 -0
  455. package/src/assets/icons/normal/resize-100%.svg +1 -0
  456. package/src/assets/icons/normal/resize-height.svg +1 -0
  457. package/src/assets/icons/normal/resize-width.svg +1 -0
  458. package/src/assets/icons/normal/search.svg +1 -0
  459. package/src/assets/icons/normal/sequential-prerequisites.svg +1 -0
  460. package/src/assets/icons/normal/settings.svg +1 -0
  461. package/src/assets/icons/normal/share.svg +1 -0
  462. package/src/assets/icons/normal/sketch.svg +1 -0
  463. package/src/assets/icons/normal/skills.svg +1 -0
  464. package/src/assets/icons/normal/skip-back.svg +1 -0
  465. package/src/assets/icons/normal/skip-forward.svg +1 -0
  466. package/src/assets/icons/normal/sms.svg +1 -0
  467. package/src/assets/icons/normal/sso-access.svg +1 -0
  468. package/src/assets/icons/normal/star-active.svg +1 -0
  469. package/src/assets/icons/normal/star.svg +1 -0
  470. package/src/assets/icons/normal/success.svg +1 -0
  471. package/src/assets/icons/normal/sun.svg +1 -0
  472. package/src/assets/icons/normal/sunrise.svg +1 -0
  473. package/src/assets/icons/normal/support.svg +1 -0
  474. package/src/assets/icons/normal/survey.svg +1 -0
  475. package/src/assets/icons/normal/table.svg +1 -0
  476. package/src/assets/icons/normal/tematic-channels.svg +1 -0
  477. package/src/assets/icons/normal/test.svg +1 -0
  478. package/src/assets/icons/normal/text-body.svg +1 -0
  479. package/src/assets/icons/normal/text-edit.svg +1 -0
  480. package/src/assets/icons/normal/text-style.svg +1 -0
  481. package/src/assets/icons/normal/time.svg +1 -0
  482. package/src/assets/icons/normal/toilet-paper.svg +1 -0
  483. package/src/assets/icons/normal/training-points.svg +1 -0
  484. package/src/assets/icons/normal/trash.svg +1 -0
  485. package/src/assets/icons/normal/underline.svg +1 -0
  486. package/src/assets/icons/normal/undo.svg +1 -0
  487. package/src/assets/icons/normal/unlock.svg +1 -0
  488. package/src/assets/icons/normal/upload.svg +1 -0
  489. package/src/assets/icons/normal/user-add.svg +1 -0
  490. package/src/assets/icons/normal/user-badge.svg +1 -0
  491. package/src/assets/icons/normal/user.svg +1 -0
  492. package/src/assets/icons/normal/video-off.svg +1 -0
  493. package/src/assets/icons/normal/video-on.svg +1 -0
  494. package/src/assets/icons/normal/video-rec.svg +1 -0
  495. package/src/assets/icons/normal/view-card.svg +1 -0
  496. package/src/assets/icons/normal/view-list.svg +1 -0
  497. package/src/assets/icons/normal/view.svg +1 -0
  498. package/src/assets/icons/normal/voice-off.svg +1 -0
  499. package/src/assets/icons/normal/voice-on.svg +1 -0
  500. package/src/assets/icons/normal/volume-down.svg +1 -0
  501. package/src/assets/icons/normal/volume-off.svg +1 -0
  502. package/src/assets/icons/normal/volume-up.svg +1 -0
  503. package/src/assets/icons/normal/warning.svg +1 -0
  504. package/src/assets/icons/normal/webinar.svg +1 -0
  505. package/src/assets/icons/normal/whiteboard.svg +1 -0
  506. package/src/assets/icons/normal/wine.svg +1 -0
  507. package/src/assets/icons/normal/zip.svg +1 -0
  508. package/src/assets/icons/normal/zoom-in.svg +1 -0
  509. package/src/assets/icons/normal/zoom-out.svg +1 -0
  510. package/src/assets/icons/normal.json +1 -0
  511. package/src/assets/icons/simple/add-circle.svg +1 -0
  512. package/src/assets/icons/simple/add.svg +1 -0
  513. package/src/assets/icons/simple/align-center.svg +1 -0
  514. package/src/assets/icons/simple/align-justify.svg +1 -0
  515. package/src/assets/icons/simple/align-left.svg +1 -0
  516. package/src/assets/icons/simple/align-right.svg +1 -0
  517. package/src/assets/icons/simple/analysis-2.svg +1 -0
  518. package/src/assets/icons/simple/analysis-3.svg +1 -0
  519. package/src/assets/icons/simple/analysis.svg +1 -0
  520. package/src/assets/icons/simple/apple.svg +1 -0
  521. package/src/assets/icons/simple/arrow-down.svg +1 -0
  522. package/src/assets/icons/simple/arrow-left.svg +1 -0
  523. package/src/assets/icons/simple/arrow-right.svg +1 -0
  524. package/src/assets/icons/simple/arrow-up.svg +1 -0
  525. package/src/assets/icons/simple/attachment.svg +1 -0
  526. package/src/assets/icons/simple/bck-to-front.svg +1 -0
  527. package/src/assets/icons/simple/bell-active.svg +1 -0
  528. package/src/assets/icons/simple/bell.svg +1 -0
  529. package/src/assets/icons/simple/bold.svg +1 -0
  530. package/src/assets/icons/simple/bookmark-active.svg +1 -0
  531. package/src/assets/icons/simple/bookmark.svg +1 -0
  532. package/src/assets/icons/simple/building.svg +1 -0
  533. package/src/assets/icons/simple/bulleted-list.svg +1 -0
  534. package/src/assets/icons/simple/calendar.svg +1 -0
  535. package/src/assets/icons/simple/camera-off.svg +1 -0
  536. package/src/assets/icons/simple/camera-on.svg +1 -0
  537. package/src/assets/icons/simple/catalog.svg +1 -0
  538. package/src/assets/icons/simple/certificate.svg +1 -0
  539. package/src/assets/icons/simple/chat.svg +1 -0
  540. package/src/assets/icons/simple/check-badge.svg +1 -0
  541. package/src/assets/icons/simple/check-circle.svg +1 -0
  542. package/src/assets/icons/simple/check.svg +1 -0
  543. package/src/assets/icons/simple/checkbox.svg +1 -0
  544. package/src/assets/icons/simple/chevron-down-circle.svg +1 -0
  545. package/src/assets/icons/simple/chevron-down.svg +1 -0
  546. package/src/assets/icons/simple/chevron-left-circle.svg +1 -0
  547. package/src/assets/icons/simple/chevron-left.svg +1 -0
  548. package/src/assets/icons/simple/chevron-right-circle.svg +1 -0
  549. package/src/assets/icons/simple/chevron-right.svg +1 -0
  550. package/src/assets/icons/simple/chevron-up-circle.svg +1 -0
  551. package/src/assets/icons/simple/chevron-up.svg +1 -0
  552. package/src/assets/icons/simple/classroom.svg +1 -0
  553. package/src/assets/icons/simple/clear-field.svg +1 -0
  554. package/src/assets/icons/simple/clear-style.svg +1 -0
  555. package/src/assets/icons/simple/close-circle.svg +1 -0
  556. package/src/assets/icons/simple/close-loader.svg +1 -0
  557. package/src/assets/icons/simple/close.svg +1 -0
  558. package/src/assets/icons/simple/coffee.svg +1 -0
  559. package/src/assets/icons/simple/color.svg +1 -0
  560. package/src/assets/icons/simple/contact-us.svg +1 -0
  561. package/src/assets/icons/simple/copy.svg +1 -0
  562. package/src/assets/icons/simple/courses.svg +1 -0
  563. package/src/assets/icons/simple/dashboard.svg +1 -0
  564. package/src/assets/icons/simple/download.svg +1 -0
  565. package/src/assets/icons/simple/drag.svg +1 -0
  566. package/src/assets/icons/simple/duplicate.svg +1 -0
  567. package/src/assets/icons/simple/edit.svg +1 -0
  568. package/src/assets/icons/simple/elearning.svg +1 -0
  569. package/src/assets/icons/simple/email.svg +1 -0
  570. package/src/assets/icons/simple/error-2.svg +1 -0
  571. package/src/assets/icons/simple/error.svg +1 -0
  572. package/src/assets/icons/simple/exercise.svg +1 -0
  573. package/src/assets/icons/simple/external-link.svg +1 -0
  574. package/src/assets/icons/simple/extract.svg +1 -0
  575. package/src/assets/icons/simple/eye-off.svg +1 -0
  576. package/src/assets/icons/simple/eye-on.svg +1 -0
  577. package/src/assets/icons/simple/fail.svg +1 -0
  578. package/src/assets/icons/simple/fast-back.svg +1 -0
  579. package/src/assets/icons/simple/fast-forward.svg +1 -0
  580. package/src/assets/icons/simple/file-add.svg +1 -0
  581. package/src/assets/icons/simple/file-duplicate.svg +1 -0
  582. package/src/assets/icons/simple/file-remove.svg +1 -0
  583. package/src/assets/icons/simple/file-required.svg +1 -0
  584. package/src/assets/icons/simple/file.svg +1 -0
  585. package/src/assets/icons/simple/filter-2.svg +1 -0
  586. package/src/assets/icons/simple/filter-active.svg +1 -0
  587. package/src/assets/icons/simple/filter.svg +1 -0
  588. package/src/assets/icons/simple/flag.svg +1 -0
  589. package/src/assets/icons/simple/folder.svg +1 -0
  590. package/src/assets/icons/simple/full-width.svg +1 -0
  591. package/src/assets/icons/simple/go-to-back.svg +1 -0
  592. package/src/assets/icons/simple/grid.svg +1 -0
  593. package/src/assets/icons/simple/group-add.svg +1 -0
  594. package/src/assets/icons/simple/group.svg +1 -0
  595. package/src/assets/icons/simple/heart-active.svg +1 -0
  596. package/src/assets/icons/simple/heart.svg +1 -0
  597. package/src/assets/icons/simple/highlighter.svg +1 -0
  598. package/src/assets/icons/simple/home.svg +1 -0
  599. package/src/assets/icons/simple/hourglass.svg +1 -0
  600. package/src/assets/icons/simple/image.svg +1 -0
  601. package/src/assets/icons/simple/info-badge.svg +1 -0
  602. package/src/assets/icons/simple/information.svg +1 -0
  603. package/src/assets/icons/simple/italic.svg +1 -0
  604. package/src/assets/icons/simple/key.svg +1 -0
  605. package/src/assets/icons/simple/language.svg +1 -0
  606. package/src/assets/icons/simple/learning-path.svg +1 -0
  607. package/src/assets/icons/simple/light-off.svg +1 -0
  608. package/src/assets/icons/simple/light-on.svg +1 -0
  609. package/src/assets/icons/simple/link.svg +1 -0
  610. package/src/assets/icons/simple/lock.svg +1 -0
  611. package/src/assets/icons/simple/login.svg +1 -0
  612. package/src/assets/icons/simple/logout.svg +1 -0
  613. package/src/assets/icons/simple/maximaze.svg +1 -0
  614. package/src/assets/icons/simple/menu.svg +1 -0
  615. package/src/assets/icons/simple/merge.svg +1 -0
  616. package/src/assets/icons/simple/minimaze.svg +1 -0
  617. package/src/assets/icons/simple/mixed-class.svg +1 -0
  618. package/src/assets/icons/simple/more-horizontal.svg +1 -0
  619. package/src/assets/icons/simple/more-vertical.svg +1 -0
  620. package/src/assets/icons/simple/news.svg +1 -0
  621. package/src/assets/icons/simple/no-prerequisites.svg +1 -0
  622. package/src/assets/icons/simple/notes.svg +1 -0
  623. package/src/assets/icons/simple/number-code.svg +1 -0
  624. package/src/assets/icons/simple/numbered-list.svg +1 -0
  625. package/src/assets/icons/simple/on-site.svg +1 -0
  626. package/src/assets/icons/simple/order-down.svg +1 -0
  627. package/src/assets/icons/simple/order-up.svg +1 -0
  628. package/src/assets/icons/simple/paste.svg +1 -0
  629. package/src/assets/icons/simple/pausa.svg +1 -0
  630. package/src/assets/icons/simple/pdf.svg +1 -0
  631. package/src/assets/icons/simple/phone.svg +1 -0
  632. package/src/assets/icons/simple/pin-map.svg +1 -0
  633. package/src/assets/icons/simple/pin.svg +1 -0
  634. package/src/assets/icons/simple/pizza.svg +1 -0
  635. package/src/assets/icons/simple/play.svg +1 -0
  636. package/src/assets/icons/simple/plug-in.svg +1 -0
  637. package/src/assets/icons/simple/pointer.svg +1 -0
  638. package/src/assets/icons/simple/printer.svg +1 -0
  639. package/src/assets/icons/simple/profile-add.svg +1 -0
  640. package/src/assets/icons/simple/profile.svg +1 -0
  641. package/src/assets/icons/simple/push-pin-off.svg +1 -0
  642. package/src/assets/icons/simple/push-pin-on.svg +1 -0
  643. package/src/assets/icons/simple/qrcode.svg +1 -0
  644. package/src/assets/icons/simple/question-badge.svg +1 -0
  645. package/src/assets/icons/simple/radio.svg +1 -0
  646. package/src/assets/icons/simple/redo.svg +1 -0
  647. package/src/assets/icons/simple/relations.svg +1 -0
  648. package/src/assets/icons/simple/reload.svg +1 -0
  649. package/src/assets/icons/simple/remove-circle.svg +1 -0
  650. package/src/assets/icons/simple/remove.svg +1 -0
  651. package/src/assets/icons/simple/repeart.svg +1 -0
  652. package/src/assets/icons/simple/repository.svg +1 -0
  653. package/src/assets/icons/simple/request-form.svg +1 -0
  654. package/src/assets/icons/simple/resize-100%.svg +1 -0
  655. package/src/assets/icons/simple/resize-height.svg +1 -0
  656. package/src/assets/icons/simple/resize-width.svg +1 -0
  657. package/src/assets/icons/simple/search.svg +1 -0
  658. package/src/assets/icons/simple/sequential-prerequisites.svg +1 -0
  659. package/src/assets/icons/simple/settings.svg +1 -0
  660. package/src/assets/icons/simple/share.svg +1 -0
  661. package/src/assets/icons/simple/sketch.svg +1 -0
  662. package/src/assets/icons/simple/skills.svg +1 -0
  663. package/src/assets/icons/simple/skip-back.svg +1 -0
  664. package/src/assets/icons/simple/skip-forward.svg +1 -0
  665. package/src/assets/icons/simple/sms.svg +1 -0
  666. package/src/assets/icons/simple/sso-access.svg +1 -0
  667. package/src/assets/icons/simple/star-active.svg +1 -0
  668. package/src/assets/icons/simple/star.svg +1 -0
  669. package/src/assets/icons/simple/success.svg +1 -0
  670. package/src/assets/icons/simple/sun.svg +1 -0
  671. package/src/assets/icons/simple/sunrise.svg +1 -0
  672. package/src/assets/icons/simple/support.svg +1 -0
  673. package/src/assets/icons/simple/survey.svg +1 -0
  674. package/src/assets/icons/simple/table.svg +1 -0
  675. package/src/assets/icons/simple/tematic-channels.svg +1 -0
  676. package/src/assets/icons/simple/test.svg +1 -0
  677. package/src/assets/icons/simple/text-body.svg +1 -0
  678. package/src/assets/icons/simple/text-edit.svg +1 -0
  679. package/src/assets/icons/simple/text-style.svg +1 -0
  680. package/src/assets/icons/simple/time.svg +1 -0
  681. package/src/assets/icons/simple/toilet-paper.svg +1 -0
  682. package/src/assets/icons/simple/training-points.svg +1 -0
  683. package/src/assets/icons/simple/trash.svg +1 -0
  684. package/src/assets/icons/simple/underline.svg +1 -0
  685. package/src/assets/icons/simple/undo.svg +1 -0
  686. package/src/assets/icons/simple/unlock.svg +1 -0
  687. package/src/assets/icons/simple/upload.svg +1 -0
  688. package/src/assets/icons/simple/user-add.svg +1 -0
  689. package/src/assets/icons/simple/user-badge.svg +1 -0
  690. package/src/assets/icons/simple/user.svg +1 -0
  691. package/src/assets/icons/simple/video-off.svg +1 -0
  692. package/src/assets/icons/simple/video-on.svg +1 -0
  693. package/src/assets/icons/simple/video-rec.svg +1 -0
  694. package/src/assets/icons/simple/view-card.svg +1 -0
  695. package/src/assets/icons/simple/view-list.svg +1 -0
  696. package/src/assets/icons/simple/view.svg +1 -0
  697. package/src/assets/icons/simple/voice-off.svg +1 -0
  698. package/src/assets/icons/simple/voice-on.svg +1 -0
  699. package/src/assets/icons/simple/volume-down.svg +1 -0
  700. package/src/assets/icons/simple/volume-off.svg +1 -0
  701. package/src/assets/icons/simple/volume-up.svg +1 -0
  702. package/src/assets/icons/simple/warning.svg +1 -0
  703. package/src/assets/icons/simple/webinar.svg +1 -0
  704. package/src/assets/icons/simple/whiteboard.svg +1 -0
  705. package/src/assets/icons/simple/wine.svg +1 -0
  706. package/src/assets/icons/simple/zip.svg +1 -0
  707. package/src/assets/icons/simple/zoom-in.svg +1 -0
  708. package/src/assets/icons/simple/zoom-out.svg +1 -0
  709. package/src/assets/icons/simple.json +1 -0
  710. package/src/components/VvAccordion/VvAccordion.ts +34 -0
  711. package/src/components/VvAccordion/VvAccordion.vue +92 -0
  712. package/src/components/VvAccordion/useAccordionProps.ts +45 -0
  713. package/src/components/VvAccordionGroup/VvAccordionGroup.ts +36 -0
  714. package/src/components/VvAccordionGroup/VvAccordionGroup.vue +63 -0
  715. package/src/components/VvBadge/VvBadge.ts +4 -0
  716. package/src/components/VvBadge/VvBadge.vue +12 -0
  717. package/src/components/VvBreadcrumb/VvBreadcrumb.ts +14 -0
  718. package/src/components/VvBreadcrumb/VvBreadcrumb.vue +52 -0
  719. package/src/components/VvButton/VvButton.ts +117 -0
  720. package/src/components/VvButton/VvButton.vue +190 -0
  721. package/src/components/VvButton/useButtonGroupProps.ts +51 -0
  722. package/src/components/VvButtonGroup/VvButtonGroup.ts +37 -0
  723. package/src/components/VvButtonGroup/VvButtonGroup.vue +55 -0
  724. package/src/components/VvCard/VvCard.ts +4 -0
  725. package/src/components/VvCard/VvCard.vue +37 -0
  726. package/src/components/VvCheck/VvCheck.ts +48 -0
  727. package/src/components/VvCheck/VvCheck.vue +149 -0
  728. package/src/components/VvCheck/useCheckProps.ts +41 -0
  729. package/src/components/VvCheckGroup/VvCheckGroup.ts +34 -0
  730. package/src/components/VvCheckGroup/VvCheckGroup.vue +84 -0
  731. package/src/components/VvDialog/VvDialog.ts +17 -0
  732. package/src/components/VvDialog/VvDialog.vue +91 -0
  733. package/src/components/VvDialog/constants.ts +5 -0
  734. package/src/components/VvDropdown/VvDropdown.ts +46 -0
  735. package/src/components/VvDropdown/VvDropdown.vue +130 -0
  736. package/src/components/VvIcon/VvIcon.ts +94 -0
  737. package/src/components/VvIcon/VvIcon.vue +123 -0
  738. package/src/components/VvInputText/VvInputText.ts +49 -0
  739. package/src/components/VvInputText/VvInputText.vue +276 -0
  740. package/src/components/VvInputText/constants.ts +34 -0
  741. package/src/components/VvInputText/useInputNumber.ts +40 -0
  742. package/src/components/VvInputText/useInputPassword.ts +38 -0
  743. package/src/components/VvNativeSelect/VvNativeSelect.ts +70 -0
  744. package/src/components/VvNativeSelect/VvNativeSelect.vue +106 -0
  745. package/src/components/VvProgress/VvProgress.ts +28 -0
  746. package/src/components/VvProgress/VvProgress.vue +34 -0
  747. package/src/components/VvRadio/VvRadio.ts +25 -0
  748. package/src/components/VvRadio/VvRadio.vue +130 -0
  749. package/src/components/VvRadio/useRadioProps.ts +40 -0
  750. package/src/components/VvRadioGroup/VvRadioGroup.ts +25 -0
  751. package/src/components/VvRadioGroup/VvRadioGroup.vue +80 -0
  752. package/src/components/VvSelect/VvSelect.ts +91 -0
  753. package/src/components/VvSelect/VvSelect.vue +194 -0
  754. package/src/components/VvTextarea/VvTextarea.ts +55 -0
  755. package/src/components/VvTextarea/VvTextarea.vue +189 -0
  756. package/src/components/VvTextarea/constants.ts +14 -0
  757. package/src/components/common/HintSlot.ts +164 -0
  758. package/src/components/index.ts +12 -0
  759. package/src/composables/focus/useComponentFocus.ts +22 -0
  760. package/src/composables/group/types/IAccordionGroupState.ts +12 -0
  761. package/src/composables/group/types/IButtonGroupState.ts +21 -0
  762. package/src/composables/group/types/IGroupState.ts +12 -0
  763. package/src/composables/group/types/IInputGroup.ts +13 -0
  764. package/src/composables/group/useInjectedGroupState.ts +64 -0
  765. package/src/composables/group/useProvideGroupState.ts +23 -0
  766. package/src/composables/icons/useComponentIcons.ts +52 -0
  767. package/src/composables/options/useOptions.ts +27 -0
  768. package/src/composables/useModifiers.ts +54 -0
  769. package/src/constants.ts +7 -0
  770. package/src/directives/.README +0 -0
  771. package/src/index.ts +7 -0
  772. package/src/props/index.ts +45 -0
  773. package/src/stories/Accordion/Accordion.stories.mdx +37 -0
  774. package/src/stories/Accordion/AccordionBordered.stories.mdx +26 -0
  775. package/src/stories/Accordion/AccordionIconRight.stories.mdx +32 -0
  776. package/src/stories/Accordion/AccordionSlots.stories.mdx +82 -0
  777. package/src/stories/Accordion/accordionTest.js +36 -0
  778. package/src/stories/AccordionGroup/Accordion.stories.mdx +42 -0
  779. package/src/stories/AccordionGroup/AccordionGroup.stories.mdx +43 -0
  780. package/src/stories/AccordionGroup/AccordionItems.stories.mdx +51 -0
  781. package/src/stories/AccordionGroup/accordionGroupTest.js +51 -0
  782. package/src/stories/Badge/Badge.stories.mdx +38 -0
  783. package/src/stories/Badge/BadgeColor.stories.mdx +54 -0
  784. package/src/stories/Badge/BadgeDot.stories.mdx +20 -0
  785. package/src/stories/Badge/BadgeTest.js +21 -0
  786. package/src/stories/Breadcrumb/Breadcrumb.stories.mdx +46 -0
  787. package/src/stories/Breadcrumb/BreadcrumbMultiline.stories.mdx +41 -0
  788. package/src/stories/Button/Button.stories.mdx +73 -0
  789. package/src/stories/Button/ButtonBadge.stories.mdx +33 -0
  790. package/src/stories/Button/ButtonIcon.stories.mdx +51 -0
  791. package/src/stories/Button/ButtonIconPosition.stories.mdx +103 -0
  792. package/src/stories/Button/ButtonLink.stories.mdx +156 -0
  793. package/src/stories/Button/ButtonLoading.stories.mdx +62 -0
  794. package/src/stories/Button/ButtonModifiers.stories.mdx +194 -0
  795. package/src/stories/Button/ButtonSlots.stories.mdx +123 -0
  796. package/src/stories/Button/ButtonVariant.stories.mdx +223 -0
  797. package/src/stories/Button/test.js +41 -0
  798. package/src/stories/ButtonGroup/ButtonGroup.stories.mdx +39 -0
  799. package/src/stories/ButtonGroup/ButtonGroupAction.stories.mdx +83 -0
  800. package/src/stories/ButtonGroup/ButtonGroupActionQuiet.stories.mdx +50 -0
  801. package/src/stories/ButtonGroup/ButtonGroupBlock.stories.mdx +40 -0
  802. package/src/stories/ButtonGroup/ButtonGroupCompact.stories.mdx +38 -0
  803. package/src/stories/ButtonGroup/ButtonGroupRounded.stories.mdx +77 -0
  804. package/src/stories/ButtonGroup/ButtonGroupTest.js +61 -0
  805. package/src/stories/ButtonGroup/ButtonGroupToggle.stories.mdx +131 -0
  806. package/src/stories/ButtonGroup/ButtonGroupVertical.stories.mdx +38 -0
  807. package/src/stories/Card/Card.stories.mdx +23 -0
  808. package/src/stories/Card/CardSlots.stories.mdx +42 -0
  809. package/src/stories/Card/CardVariant.stories.mdx +37 -0
  810. package/src/stories/Check/Check.stories.mdx +62 -0
  811. package/src/stories/Check/CheckBinary.stories.mdx +80 -0
  812. package/src/stories/Check/CheckDisabled.stories.mdx +30 -0
  813. package/src/stories/Check/CheckError.stories.mdx +64 -0
  814. package/src/stories/Check/CheckErrorTests.js +72 -0
  815. package/src/stories/Check/CheckHintLabel.stories.mdx +30 -0
  816. package/src/stories/Check/CheckPropertyTest.js +101 -0
  817. package/src/stories/Check/CheckReadonly.stories.mdx +30 -0
  818. package/src/stories/Check/CheckSlots.stories.mdx +51 -0
  819. package/src/stories/Check/CheckSwitch.stories.mdx +30 -0
  820. package/src/stories/CheckGroup/CheckGroup.stories.mdx +69 -0
  821. package/src/stories/CheckGroup/CheckGroupDisabled.stories.mdx +26 -0
  822. package/src/stories/CheckGroup/CheckGroupError.stories.mdx +28 -0
  823. package/src/stories/CheckGroup/CheckGroupHintLabel.stories.mdx +27 -0
  824. package/src/stories/CheckGroup/CheckGroupLabel.stories.mdx +26 -0
  825. package/src/stories/CheckGroup/CheckGroupOptionLabel.stories.mdx +48 -0
  826. package/src/stories/CheckGroup/CheckGroupOptionValue.stories.mdx +48 -0
  827. package/src/stories/CheckGroup/CheckGroupOptions.stories.mdx +40 -0
  828. package/src/stories/CheckGroup/CheckGroupReadonly.stories.mdx +26 -0
  829. package/src/stories/CheckGroup/CheckGroupSlots.stories.mdx +152 -0
  830. package/src/stories/CheckGroup/CheckGroupValid.stories.mdx +28 -0
  831. package/src/stories/CheckGroup/CheckGroupVertical.stories.mdx +26 -0
  832. package/src/stories/Dialog/Dialog.stories.mdx +29 -0
  833. package/src/stories/Dialog/DialogAutoClose.stories.mdx +18 -0
  834. package/src/stories/Dialog/DialogSize.stories.mdx +36 -0
  835. package/src/stories/Dropdown/Dropdown.stories.mdx +50 -0
  836. package/src/stories/Dropdown/DropdownDisabled.stories.mdx +25 -0
  837. package/src/stories/Dropdown/DropdownLabelNoResults.stories.mdx +25 -0
  838. package/src/stories/Dropdown/DropdownMaxValues.stories.mdx +26 -0
  839. package/src/stories/Dropdown/DropdownMultiple.stories.mdx +56 -0
  840. package/src/stories/Dropdown/DropdownOptions.stories.mdx +76 -0
  841. package/src/stories/Dropdown/DropdownUseObject.stories.mdx +58 -0
  842. package/src/stories/Icon/Icon.stories.mdx +73 -0
  843. package/src/stories/Icon/IconList.vue +34 -0
  844. package/src/stories/Icon/IconPrefix.stories.mdx +79 -0
  845. package/src/stories/Icon/IconRemote.stories.mdx +39 -0
  846. package/src/stories/Icon/IconTest.js +27 -0
  847. package/src/stories/Icon/IconsList.stories.mdx +35 -0
  848. package/src/stories/InputText/InputText.stories.mdx +94 -0
  849. package/src/stories/InputText/InputTextAutocomplete.stories.mdx +15 -0
  850. package/src/stories/InputText/InputTextAutofocus.stories.mdx +20 -0
  851. package/src/stories/InputText/InputTextDisabled.stories.mdx +19 -0
  852. package/src/stories/InputText/InputTextError.stories.mdx +19 -0
  853. package/src/stories/InputText/InputTextFloating.stories.mdx +20 -0
  854. package/src/stories/InputText/InputTextHintLabel.stories.mdx +18 -0
  855. package/src/stories/InputText/InputTextIcon.stories.mdx +18 -0
  856. package/src/stories/InputText/InputTextIconPosition.stories.mdx +31 -0
  857. package/src/stories/InputText/InputTextLabel.stories.mdx +15 -0
  858. package/src/stories/InputText/InputTextLoading.stories.mdx +19 -0
  859. package/src/stories/InputText/InputTextMax.stories.mdx +31 -0
  860. package/src/stories/InputText/InputTextMaxLength.stories.mdx +15 -0
  861. package/src/stories/InputText/InputTextMin.stories.mdx +31 -0
  862. package/src/stories/InputText/InputTextMinLength.stories.mdx +15 -0
  863. package/src/stories/InputText/InputTextPlaceholder.stories.mdx +15 -0
  864. package/src/stories/InputText/InputTextReadonly.stories.mdx +19 -0
  865. package/src/stories/InputText/InputTextSlots.stories.mdx +30 -0
  866. package/src/stories/InputText/InputTextStep.stories.mdx +31 -0
  867. package/src/stories/InputText/InputTextType.stories.mdx +81 -0
  868. package/src/stories/InputText/InputTextValid.stories.mdx +19 -0
  869. package/src/stories/NativeSelect/NativeSelect.stories.mdx +53 -0
  870. package/src/stories/NativeSelect/NativeSelectDisabled.stories.mdx +32 -0
  871. package/src/stories/NativeSelect/NativeSelectError.stories.mdx +36 -0
  872. package/src/stories/NativeSelect/NativeSelectHintLabel.stories.mdx +34 -0
  873. package/src/stories/NativeSelect/NativeSelectIconLeftRight.stories.mdx +42 -0
  874. package/src/stories/NativeSelect/NativeSelectLoading.stories.mdx +27 -0
  875. package/src/stories/NativeSelect/NativeSelectOptions.stories.mdx +78 -0
  876. package/src/stories/NativeSelect/NativeSelectReadonly.stories.mdx +34 -0
  877. package/src/stories/NativeSelect/NativeSelectUseObject.stories.mdx +66 -0
  878. package/src/stories/NativeSelect/NativeSelectValid.stories.mdx +36 -0
  879. package/src/stories/NativeSelect/NativeSelectValueKey.stories.mdx +66 -0
  880. package/src/stories/Progress/Progress.stories.mdx +29 -0
  881. package/src/stories/Progress/ProgressDeterminate.stories.mdx +19 -0
  882. package/src/stories/Radio/Radio.stories.mdx +67 -0
  883. package/src/stories/Radio/RadioDisabled.stories.mdx +30 -0
  884. package/src/stories/Radio/RadioError.stories.mdx +64 -0
  885. package/src/stories/Radio/RadioHintLabel.stories.mdx +30 -0
  886. package/src/stories/Radio/RadioSlots.stories.mdx +29 -0
  887. package/src/stories/Radio/RadioTest.js +89 -0
  888. package/src/stories/RadioGroup/RadioGroup.stories.mdx +73 -0
  889. package/src/stories/RadioGroup/RadioGroupDisabled.stories.mdx +29 -0
  890. package/src/stories/RadioGroup/RadioGroupError.stories.mdx +31 -0
  891. package/src/stories/RadioGroup/RadioGroupHintLabel.stories.mdx +28 -0
  892. package/src/stories/RadioGroup/RadioGroupLabel.stories.mdx +29 -0
  893. package/src/stories/RadioGroup/RadioGroupOptionLabel.stories.mdx +65 -0
  894. package/src/stories/RadioGroup/RadioGroupOptionValue.stories.mdx +65 -0
  895. package/src/stories/RadioGroup/RadioGroupOptions.stories.mdx +58 -0
  896. package/src/stories/RadioGroup/RadioGroupReadonly.stories.mdx +29 -0
  897. package/src/stories/RadioGroup/RadioGroupSlots.stories.mdx +162 -0
  898. package/src/stories/RadioGroup/RadioGroupValid.stories.mdx +31 -0
  899. package/src/stories/RadioGroup/RadioGroupVertical.stories.mdx +29 -0
  900. package/src/stories/RadioGroup/RadioOptionsTest.js +78 -0
  901. package/src/stories/RadioGroup/RadioPropertyTest.js +131 -0
  902. package/src/stories/RadioGroup/RadioSlotsTest.js +20 -0
  903. package/src/stories/Select/Select.stories.mdx +55 -0
  904. package/src/stories/Select/SelectDisabled.stories.mdx +32 -0
  905. package/src/stories/Select/SelectMaxValues.stories.mdx +33 -0
  906. package/src/stories/Select/SelectMultiple.stories.mdx +64 -0
  907. package/src/stories/Select/SelectOptions.stories.mdx +78 -0
  908. package/src/stories/Select/SelectSearchable.stories.mdx +80 -0
  909. package/src/stories/Select/SelectSeparator.stories.mdx +64 -0
  910. package/src/stories/Select/SelectUseObject.stories.mdx +66 -0
  911. package/src/stories/Textarea/Textarea.stories.mdx +84 -0
  912. package/src/stories/Textarea/TextareaAutocomplete.stories.mdx +15 -0
  913. package/src/stories/Textarea/TextareaAutofocus.stories.mdx +20 -0
  914. package/src/stories/Textarea/TextareaDisabled.stories.mdx +19 -0
  915. package/src/stories/Textarea/TextareaError.stories.mdx +19 -0
  916. package/src/stories/Textarea/TextareaFloating.stories.mdx +20 -0
  917. package/src/stories/Textarea/TextareaHintLabel.stories.mdx +18 -0
  918. package/src/stories/Textarea/TextareaIcon.stories.mdx +18 -0
  919. package/src/stories/Textarea/TextareaIconPosition.stories.mdx +31 -0
  920. package/src/stories/Textarea/TextareaLabel.stories.mdx +15 -0
  921. package/src/stories/Textarea/TextareaLoading.stories.mdx +19 -0
  922. package/src/stories/Textarea/TextareaMaxLength.stories.mdx +15 -0
  923. package/src/stories/Textarea/TextareaMinLength.stories.mdx +15 -0
  924. package/src/stories/Textarea/TextareaPlaceholder.stories.mdx +15 -0
  925. package/src/stories/Textarea/TextareaReadonly.stories.mdx +19 -0
  926. package/src/stories/Textarea/TextareaRowsCols.stories.mdx +31 -0
  927. package/src/stories/Textarea/TextareaSlots.stories.mdx +31 -0
  928. package/src/stories/Textarea/TextareaValid.stories.mdx +19 -0
  929. package/src/stories/stories.scss +24 -0
  930. package/src/stories/volver-ui-vue.stories.mdx +70 -0
  931. package/src/types/.README +0 -0
  932. package/src/types/generic.d.ts +1 -0
  933. package/src/utils/ObjectUtilities.ts +275 -0
@@ -0,0 +1,194 @@
1
+ <template>
2
+ <div :id="id" :class="selectClasses">
3
+ <label v-if="label" for="select">{{ label }}</label>
4
+ <details
5
+ ref="dropdown"
6
+ role="list"
7
+ class="vv-select__wrapper"
8
+ @click="disabled || readonly ? $event.preventDefault() : null"
9
+ @keyup.esc="dropdown.open = false"
10
+ @toggle="onToggle">
11
+ <summary
12
+ class="vv-select__input"
13
+ aria-haspopup="listbox"
14
+ @keyup.space="searchable ? $event.preventDefault() : null">
15
+ <!-- #region search input -->
16
+ <template v-if="searchable && dropdownOpen">
17
+ <input
18
+ ref="inputSearch"
19
+ v-model="searchText"
20
+ :placeholder="searchPlaceholder" />
21
+ </template>
22
+ <!-- #endregion search input -->
23
+ <!-- #region label of selected value/s -->
24
+ <template v-else>
25
+ {{ labelValue || placeholder }}
26
+ </template>
27
+ <!-- #endregion label of selected value/s -->
28
+ </summary>
29
+ <VvDropdown
30
+ v-bind="{
31
+ ...props,
32
+ options: currentOptions
33
+ }"
34
+ @update:model-value="onInput" />
35
+ </details>
36
+ <HintSlot class="vv-select__hint" />
37
+ </div>
38
+ </template>
39
+
40
+ <script setup lang="ts">
41
+ import type { Option } from '../VvDropdown/VvDropdown'
42
+ import { computed, ref, toRefs, useSlots, watch } from 'vue'
43
+ import { onClickOutside, refDebounced, useFocus } from '@vueuse/core'
44
+ import { v4 as uuidv4 } from 'uuid'
45
+ import ObjectUtilities from '../../utils/ObjectUtilities'
46
+ import { VvSelectProps } from './VvSelect'
47
+ import HintSlotFactory from '../common/HintSlot'
48
+ import VvDropdown from '../VvDropdown/VvDropdown.vue'
49
+ import { useBemModifiers } from '../../composables/useModifiers'
50
+
51
+ const props = defineProps(VvSelectProps)
52
+ const slots = useSlots()
53
+ const emit = defineEmits(['update:modelValue', 'change:search'])
54
+
55
+ //Hint component
56
+ const HintSlot = HintSlotFactory(props, slots)
57
+
58
+ // html ref
59
+ const dropdown = ref()
60
+ const inputSearch = ref()
61
+ // autofocus input search
62
+ useFocus(inputSearch, { initialValue: true })
63
+
64
+ // data
65
+ const id = uuidv4()
66
+ const searchText = ref('')
67
+ const debouncedSearchText = refDebounced(
68
+ searchText,
69
+ Number(props.debounceSearch)
70
+ )
71
+ const dropdownOpen = ref(false)
72
+ const {
73
+ modifiers,
74
+ disabled,
75
+ readonly,
76
+ loading,
77
+ iconLeft,
78
+ iconRight,
79
+ valid,
80
+ error
81
+ } = toRefs(props)
82
+
83
+ // watch
84
+ // emit on change search text
85
+ watch(debouncedSearchText, () =>
86
+ emit('change:search', debouncedSearchText.value)
87
+ )
88
+
89
+ //Styles & css classes modifiers
90
+ const { bemCssClasses: selectClasses } = useBemModifiers('vv-select', {
91
+ modifiers,
92
+ disabled,
93
+ loading,
94
+ readonly,
95
+ iconLeft,
96
+ iconRight,
97
+ valid,
98
+ invalid: error,
99
+ dirty: computed(() => ObjectUtilities.isNotEmpty(props.modelValue))
100
+ })
101
+
102
+ // computed
103
+
104
+ // Check if options are objects
105
+ const isOptionsObjects = computed(() =>
106
+ props.options?.every((option) => typeof option === 'object')
107
+ )
108
+
109
+ // current options, filtered or prop options
110
+ const currentOptions = computed(() =>
111
+ props.searchable ? filteredOptions.value : props.options
112
+ )
113
+
114
+ // options filtered by search text
115
+ const filteredOptions = computed(() => {
116
+ return props.options?.filter((option) => {
117
+ if (typeof option === 'string') {
118
+ return option
119
+ .toLowerCase()
120
+ .includes(debouncedSearchText.value.toLowerCase().trim())
121
+ }
122
+ return option[props.labelKey]
123
+ .toLowerCase()
124
+ .includes(debouncedSearchText.value.toLowerCase().trim())
125
+ })
126
+ })
127
+
128
+ /**
129
+ * Compute the label to show to the user
130
+ * Check if is multiple mode, object mode or "string" mode
131
+ */
132
+ const labelValue = computed(() => {
133
+ // #region multiple mode
134
+ if (
135
+ props.multiple &&
136
+ props.modelValue?.length &&
137
+ Array.isArray(props.modelValue)
138
+ ) {
139
+ if (isOptionsObjects.value) {
140
+ // filter options by selected values
141
+ return ObjectUtilities.filterArray<Option>(
142
+ props.options as Option[],
143
+ props.modelValue,
144
+ props.valueKey
145
+ )
146
+ .map((option) => option[props.labelKey])
147
+ .join(props.separator)
148
+ } else {
149
+ return props.modelValue.join(props.separator)
150
+ }
151
+ }
152
+ // #endregion multiple mode
153
+
154
+ // #region single mode
155
+ const selectedOption = props.useObject
156
+ ? props.modelValue
157
+ : props.options?.find((option) =>
158
+ typeof option === 'object'
159
+ ? option[props.valueKey] == props.modelValue
160
+ : option == props.modelValue
161
+ )
162
+
163
+ return typeof selectedOption === 'object'
164
+ ? selectedOption?.[props.labelKey]
165
+ : selectedOption
166
+ // #endregion single mode
167
+ })
168
+
169
+ // methods
170
+
171
+ // close dropdown on click outside
172
+ onClickOutside(dropdown, () => {
173
+ dropdown.value.open = false
174
+ })
175
+
176
+ // Function triggered on toggle dropdown (open/close)
177
+ function onToggle(event: Event) {
178
+ const target = event.target as HTMLDetailsElement
179
+ dropdownOpen.value = target.open
180
+ }
181
+
182
+ /**
183
+ * Function triggered on input of checkbox or radio (multple or single mode)
184
+ * @param event on input event (checkbox or radio input)
185
+ */
186
+ function onInput(value: typeof props.modelValue) {
187
+ // close dropdown in single mode
188
+ if (dropdown.value && !props.multiple) {
189
+ dropdown.value.open = false
190
+ }
191
+
192
+ emit('update:modelValue', value)
193
+ }
194
+ </script>
@@ -0,0 +1,55 @@
1
+ import {
2
+ ValidProps,
3
+ ErrorProps,
4
+ HintProps,
5
+ LoadingProps,
6
+ DisabledProps,
7
+ ReadonlyProps
8
+ } from '../../props'
9
+ import { ICON_POSITIONS, WRAP } from './constants'
10
+
11
+ export const VvTextareaEvents = ['update:modelValue', 'focus', 'blur']
12
+
13
+ export const VvTextareaProps = {
14
+ ...ValidProps,
15
+ ...ErrorProps,
16
+ ...HintProps,
17
+ ...LoadingProps,
18
+ ...DisabledProps,
19
+ ...ReadonlyProps,
20
+ modelValue: null,
21
+ id: String,
22
+ name: { type: String, required: true },
23
+ autocomplete: { type: String, default: 'off' },
24
+ autofocus: Boolean,
25
+ minlength: Number,
26
+ maxlength: Number,
27
+ label: String,
28
+ placeholder: String,
29
+ /**
30
+ * Nome dell'icona
31
+ * @see DsIcon
32
+ */
33
+ icon: { type: String, default: '' },
34
+ /**
35
+ * Posizione dell'icona
36
+ */
37
+ iconPosition: {
38
+ type: String,
39
+ validation: (value: string) =>
40
+ Object.values(ICON_POSITIONS).includes(value),
41
+ default: ICON_POSITIONS.RIGHT
42
+ },
43
+ /**
44
+ * True = label flottante
45
+ */
46
+ floating: Boolean,
47
+ debounce: Number,
48
+ cols: { type: Number, default: 50 },
49
+ rows: { type: Number, default: 5 },
50
+ /**
51
+ * Specifica come il testo sarà wrappato
52
+ * @see Documentation https://www.w3schools.com/tags/att_textarea_wrap.asp
53
+ */
54
+ wrap: { type: String, default: WRAP.soft }
55
+ }
@@ -0,0 +1,189 @@
1
+ <template>
2
+ <div v-bind="vvTextareaProps" :class="vvInputTextareaClass">
3
+ <label v-if="label" :for="innerTextareaProps.id">{{ label }}</label>
4
+ <div class="vv-textarea__wrapper">
5
+ <!-- @slot icon-left to replace icon left -->
6
+ <slot v-if="hasIconLeft" name="icon-left" v-bind="iconSlotProps">
7
+ <vv-icon class="vv-textarea__icon-left" :name="icon" />
8
+ </slot>
9
+ <textarea
10
+ ref="input"
11
+ v-bind="innerTextareaProps"
12
+ v-model="inputTextData"
13
+ @input="emit('input', $event)" />
14
+ <!-- @slot icon-right to replace icon right -->
15
+ <slot v-if="hasIconRight" name="icon-right" v-bind="iconSlotProps">
16
+ <!-- default password icon -->
17
+ <vv-icon :name="icon" />
18
+ </slot>
19
+ </div>
20
+ <HintSlot
21
+ :id="inputAriaAttrs['aria-describedby']"
22
+ class="vv-textarea__hint" />
23
+ </div>
24
+ </template>
25
+
26
+ <script setup lang="ts">
27
+ import {
28
+ computed,
29
+ useAttrs,
30
+ useSlots,
31
+ ref,
32
+ toRefs,
33
+ onMounted,
34
+ watch,
35
+ type HTMLAttributes,
36
+ type TextareaHTMLAttributes
37
+ } from 'vue'
38
+ import ObjectUtilities from '../../utils/ObjectUtilities'
39
+ import { VvTextareaProps, VvTextareaEvents } from './VvTextarea'
40
+
41
+ //Componenti
42
+ import VvIcon from '../../components/VvIcon/VvIcon.vue'
43
+ import HintSlotFactory from '../common/HintSlot'
44
+
45
+ //Composables
46
+ import { refDebounced } from '@vueuse/core'
47
+ import { useComponentIcons } from '../../composables/icons/useComponentIcons'
48
+ import { useComponentFocus } from '../../composables/focus/useComponentFocus'
49
+ import { useBemModifiers } from '@/composables/useModifiers'
50
+
51
+ //Props, Emits, Slots e Attrs
52
+ const props = defineProps(VvTextareaProps)
53
+ const emit = defineEmits(VvTextareaEvents)
54
+ const slots = useSlots()
55
+ const attrs = useAttrs()
56
+
57
+ //Template References
58
+ const input = ref()
59
+
60
+ //Data
61
+ const inputTextData = ref(props.modelValue)
62
+ const {
63
+ readonly,
64
+ icon,
65
+ iconPosition,
66
+ valid,
67
+ error,
68
+ loading,
69
+ floating,
70
+ label,
71
+ modelValue
72
+ } = toRefs(props)
73
+
74
+ //Debounce
75
+ const debouncedInputTextData = refDebounced(inputTextData, props.debounce || 0)
76
+ watch(debouncedInputTextData, (v) => emit('update:modelValue', v))
77
+
78
+ //Gestione ICONE
79
+ const iconProps = { icon, iconPosition }
80
+ const iconSlots = {
81
+ iconLeft: slots['icon-left'],
82
+ iconRight: slots['icon-right']
83
+ }
84
+ const { hasIconLeft, hasIconRight } = useComponentIcons(iconProps, iconSlots)
85
+
86
+ //Input FOCUS
87
+ const { focused } = useComponentFocus(input, emit)
88
+
89
+ //Styles & Bindings
90
+ const { bemCssClasses: bemInputClass } = useBemModifiers('vv-textarea', {
91
+ readonly,
92
+ valid,
93
+ invalid: error,
94
+ loading,
95
+ iconLeft: hasIconLeft,
96
+ iconRight: hasIconRight,
97
+ floating: computed(
98
+ () => floating.value && ObjectUtilities.isNotEmpty(label?.value)
99
+ ),
100
+ dirty: computed(() => ObjectUtilities.isNotEmpty(modelValue))
101
+ })
102
+ const vvInputTextareaClass = computed(() => {
103
+ const { class: cssClass } = attrs
104
+ return {
105
+ class: cssClass,
106
+ ...bemInputClass.value
107
+ }
108
+ })
109
+ const vvTextareaProps = computed(() => {
110
+ const { style } = attrs
111
+ const dataAttrs = ObjectUtilities.pickBy(attrs, (k: string) =>
112
+ k.startsWith('data-')
113
+ )
114
+ return {
115
+ style,
116
+ ...dataAttrs
117
+ } as HTMLAttributes
118
+ })
119
+ const innerTextareaProps = computed(() => {
120
+ const {
121
+ id,
122
+ name,
123
+ autocomplete,
124
+ minlength,
125
+ maxlength,
126
+ disabled,
127
+ readonly,
128
+ floating,
129
+ placeholder,
130
+ cols,
131
+ rows
132
+ } = props
133
+
134
+ const _id = id || name
135
+ //BUG - https://www.samanthaming.com/tidbits/88-css-placeholder-shown/
136
+ const _placeholder =
137
+ floating && ObjectUtilities.isEmpty(placeholder) ? ' ' : placeholder
138
+
139
+ return {
140
+ id: _id,
141
+ placeholder: _placeholder,
142
+ name,
143
+ autocomplete,
144
+ disabled,
145
+ readonly,
146
+ minlength,
147
+ maxlength,
148
+ cols,
149
+ rows,
150
+ ...inputAriaAttrs.value
151
+ } as TextareaHTMLAttributes
152
+ })
153
+ const inputAriaAttrs = computed(() => {
154
+ const { name } = attrs
155
+ const ariaAttrs = ObjectUtilities.pickBy(attrs, (k: string) =>
156
+ k.startsWith('aria-')
157
+ )
158
+ return {
159
+ 'aria-label': name,
160
+ 'aria-describedby': `${name}-hint`,
161
+ 'aria-invalid': props.error,
162
+ ...ariaAttrs
163
+ }
164
+ })
165
+
166
+ //Slot props
167
+ const iconSlotProps = computed(() => {
168
+ const { modelValue, valid, error } = props
169
+ return {
170
+ valid,
171
+ error,
172
+ modelValue
173
+ }
174
+ })
175
+
176
+ //Hint
177
+ const HintSlot = HintSlotFactory(props, slots)
178
+
179
+ onMounted(() => {
180
+ if (props.autofocus) focused.value = true
181
+ console.log('Focused', focused.value)
182
+ })
183
+ </script>
184
+
185
+ <script lang="ts">
186
+ export default {
187
+ inheritAttrs: false
188
+ }
189
+ </script>
@@ -0,0 +1,14 @@
1
+ export const ICON_POSITIONS = {
2
+ LEFT: 'left',
3
+ RIGHT: 'right'
4
+ }
5
+
6
+ export const WRAP = {
7
+ hard: 'hard',
8
+ soft: 'soft'
9
+ }
10
+
11
+ export default {
12
+ ICON_POSITIONS,
13
+ WRAP
14
+ }
@@ -0,0 +1,164 @@
1
+ import { h, type Component, type ExtractPropTypes, type Slots } from 'vue'
2
+ import { computed, toRefs } from 'vue'
3
+ import ObjectUtilities from '../../utils/ObjectUtilities'
4
+
5
+ /**
6
+ * Merge errors from Array<string> to string errors separated from new line (\n)
7
+ * @param {Array<string> | string} errors
8
+ * @returns {string}
9
+ */
10
+ function joinErrors(errors: Array<string> | string) {
11
+ if (Array.isArray(errors))
12
+ return errors
13
+ .filter((e) => ObjectUtilities.isString(e))
14
+ .reduce((prevVal, currVal) => {
15
+ if (prevVal.length > 0) return prevVal + '\n' + currVal
16
+ return currVal
17
+ }, '')
18
+ else return errors
19
+ }
20
+
21
+ interface HintSlotProps {
22
+ hintLabel: {
23
+ type: StringConstructor
24
+ default: ''
25
+ required: true
26
+ }
27
+ modelValue: null
28
+ valid: BooleanConstructor
29
+ validLabel: (StringConstructor | ArrayConstructor)[]
30
+ error: BooleanConstructor
31
+ errorLabel: (StringConstructor | ArrayConstructor)[]
32
+ }
33
+
34
+ interface HintSlotPropsWithLoading extends HintSlotProps {
35
+ loading: BooleanConstructor
36
+ loadingLabel: StringConstructor
37
+ }
38
+
39
+ /**
40
+ * Return a vue component (HintSlot) to render and manage hint, errors, valid, loading state and messages
41
+ * @param {Readonly<ExtractPropTypes<HintSlotProps | HintSlotPropsWithLoading>>} pProps vue props
42
+ * @param {Slots} pSlots vue slots
43
+ * @returns {Component} vue component
44
+ */
45
+ export function HintSlotFactory(
46
+ pProps: Readonly<
47
+ ExtractPropTypes<HintSlotProps | HintSlotPropsWithLoading>
48
+ >,
49
+ pSlots: Slots
50
+ ): Component {
51
+ return {
52
+ name: 'HintSlot',
53
+ setup() {
54
+ const props = toRefs(pProps)
55
+
56
+ //Slots
57
+ const {
58
+ error: errorSlot,
59
+ valid: validSlot,
60
+ hint: hintSlot,
61
+ loading: loadingSlot
62
+ } = pSlots
63
+
64
+ //Props hint + errors
65
+ const {
66
+ hintLabel,
67
+ modelValue,
68
+ valid,
69
+ validLabel,
70
+ error,
71
+ errorLabel
72
+ } = props
73
+ const loading = ObjectUtilities.resolveFieldData(props, 'loading')
74
+ const loadingLabel = ObjectUtilities.resolveFieldData(
75
+ props,
76
+ 'loadingLabel'
77
+ )
78
+
79
+ const hasErrors = computed(() => {
80
+ //No error
81
+ if (!error.value) return false
82
+
83
+ if (error.value && errorSlot) return true
84
+
85
+ if (
86
+ errorLabel?.value &&
87
+ Array.isArray(errorLabel.value) &&
88
+ errorLabel.value.length > 0
89
+ )
90
+ return true
91
+
92
+ if (
93
+ errorLabel?.value &&
94
+ ObjectUtilities.isNotEmpty(errorLabel.value)
95
+ )
96
+ return true
97
+
98
+ return false
99
+ })
100
+
101
+ const hasHint = computed(() => {
102
+ return !!(
103
+ (hintLabel && hintLabel.value) ||
104
+ hintSlot ||
105
+ validSlot ||
106
+ (validLabel && validLabel.value) ||
107
+ hasErrors.value ||
108
+ (loading?.value && loadingSlot) ||
109
+ (loading?.value && loadingLabel?.value)
110
+ )
111
+ })
112
+
113
+ const errorMessage = computed(() => {
114
+ if (Array.isArray(errorLabel?.value))
115
+ return joinErrors(errorLabel?.value || '')
116
+ else return errorLabel?.value
117
+ })
118
+
119
+ const hintContent = computed(() => {
120
+ const slotProps = { modelValue, error, valid }
121
+
122
+ if (error?.value) {
123
+ return (
124
+ errorSlot?.(slotProps) ||
125
+ errorMessage?.value ||
126
+ hintLabel?.value
127
+ )
128
+ }
129
+
130
+ if (valid?.value)
131
+ return (
132
+ validSlot?.(slotProps) ||
133
+ validLabel?.value ||
134
+ hintLabel?.value
135
+ )
136
+
137
+ if (loading?.value)
138
+ return (
139
+ loadingSlot?.(slotProps) ||
140
+ loadingLabel?.value ||
141
+ hintLabel?.value
142
+ )
143
+
144
+ return (
145
+ hintSlot?.(slotProps) ||
146
+ hintLabel?.value ||
147
+ hintLabel?.value
148
+ )
149
+ })
150
+
151
+ return {
152
+ hasHint,
153
+ hintContent
154
+ }
155
+ },
156
+ render() {
157
+ if (this.hasHint) {
158
+ return h('span', null, this.hintContent)
159
+ }
160
+ }
161
+ }
162
+ }
163
+
164
+ export default HintSlotFactory
@@ -0,0 +1,12 @@
1
+ export { default as VvButton } from '@/components/VvButton/VvButton.vue'
2
+ export { default as VvIcon } from '@/components/VvIcon/VvIcon.vue'
3
+ export { default as VvBadge } from '@/components/VvBadge/VvBadge.vue'
4
+ export { default as VvButtonGroup } from '@/components/VvButtonGroup/VvButtonGroup.vue'
5
+ export { default as VvAccordion } from '@/components/VvAccordion/VvAccordion.vue'
6
+ export { default as VvAccordionGroup } from '@/components/VvAccordionGroup/VvAccordionGroup.vue'
7
+ export { default as VvBreadcrumb } from '@/components/VvBreadcrumb/VvBreadcrumb.vue'
8
+ export { default as VvCard } from '@/components/VvCard/VvCard.vue'
9
+ export { default as VvCheck } from '@/components/VvCheck/VvCheck.vue'
10
+ export { default as VvCheckGroup } from '@/components/VvCheckGroup/VvCheckGroup.vue'
11
+ export { default as VvDialog } from '@/components/VvDialog/VvDialog.vue'
12
+ export { default as VvDropdown } from '@/components/VvDropdown/VvDropdown.vue'
@@ -0,0 +1,22 @@
1
+ import type { Ref } from 'vue'
2
+ import { watch } from 'vue'
3
+ import { useFocus } from '@vueuse/core'
4
+
5
+ /**
6
+ *
7
+ */
8
+ export function useComponentFocus(
9
+ inputTemplateRef: Ref<HTMLInputElement>,
10
+ emit: (event: any, ...args: any[]) => void
11
+ ) {
12
+ const { focused } = useFocus(inputTemplateRef)
13
+
14
+ watch(focused, (bFocus) => {
15
+ if (bFocus) emit('focus', inputTemplateRef.value)
16
+ else emit('blur', inputTemplateRef.value)
17
+ })
18
+
19
+ return {
20
+ focused
21
+ }
22
+ }
@@ -0,0 +1,12 @@
1
+ import type { Ref } from 'vue'
2
+
3
+ import type IGroupState from './IGroupState'
4
+
5
+ /**
6
+ * Stato condiviso per un gruppo di pulsanti
7
+ */
8
+ export default interface IAccordionGroupState extends IGroupState {
9
+ iconRight: Ref<boolean>
10
+ bordered: Ref<boolean>
11
+ accordion: Ref<boolean>
12
+ }
@@ -0,0 +1,21 @@
1
+ import type { Ref } from 'vue'
2
+
3
+ import type IGroupState from './IGroupState'
4
+
5
+ /**
6
+ * Stato condiviso per un gruppo di pulsanti
7
+ */
8
+ export default interface IButtonGroupState extends IGroupState {
9
+ /**
10
+ * Singolo bottone selezionato - utilizzo un id (o un name)
11
+ */
12
+ modelValue: Ref<string | undefined>
13
+ /**
14
+ * Stato disabilitato
15
+ */
16
+ disabled: Ref<boolean>
17
+ /**
18
+ * True = gruppo di pulsanti è in modalità TOGGLE (come i radio buttons)
19
+ */
20
+ toggle: Ref<boolean>
21
+ }
@@ -0,0 +1,12 @@
1
+ import type { Ref } from 'vue'
2
+
3
+ /**
4
+ * Stato condiviso per un gruppo di elementi
5
+ */
6
+ export default interface IGroupState {
7
+ [key: string]: Ref<any> | symbol
8
+ /**
9
+ * Chiave usata per il provide del gruppo
10
+ */
11
+ key: symbol
12
+ }