@volverjs/ui-vue 0.0.1-beta.8 → 0.0.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 (561) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +108 -56
  3. package/bin/icons.cjs +73 -0
  4. package/bin/icons.js +75 -0
  5. package/dist/{DesignSystem.d.ts → Volver.d.ts} +22 -18
  6. package/dist/components/VvAccordion/VvAccordion.es.js +165 -0
  7. package/dist/components/VvAccordion/VvAccordion.umd.js +1 -0
  8. package/dist/components/VvAccordion/VvAccordion.vue.d.ts +32 -97
  9. package/dist/components/VvAccordion/index.d.ts +46 -0
  10. package/dist/components/VvAccordionGroup/VvAccordionGroup.es.js +243 -0
  11. package/dist/components/VvAccordionGroup/VvAccordionGroup.umd.js +1 -0
  12. package/dist/components/VvAccordionGroup/VvAccordionGroup.vue.d.ts +77 -151
  13. package/dist/components/VvAccordionGroup/{VvAccordionGroup.d.ts → index.d.ts} +30 -13
  14. package/dist/components/VvBadge/VvBadge.es.js +62 -0
  15. package/dist/components/VvBadge/VvBadge.umd.js +1 -0
  16. package/dist/components/VvBadge/VvBadge.vue.d.ts +13 -54
  17. package/dist/components/VvBadge/{VvBadge.d.ts → index.d.ts} +1 -1
  18. package/dist/components/VvBreadcrumb/VvBreadcrumb.es.js +93 -0
  19. package/dist/components/VvBreadcrumb/VvBreadcrumb.umd.js +1 -0
  20. package/dist/components/VvBreadcrumb/VvBreadcrumb.vue.d.ts +33 -107
  21. package/dist/components/VvBreadcrumb/{VvBreadcrumb.d.ts → index.d.ts} +2 -3
  22. package/dist/components/VvButton/VvButton.es.js +439 -0
  23. package/dist/components/VvButton/VvButton.umd.js +1 -0
  24. package/dist/components/VvButton/VvButton.vue.d.ts +100 -199
  25. package/dist/components/VvButton/index.d.ts +132 -0
  26. package/dist/components/VvButtonGroup/VvButtonGroup.es.js +107 -0
  27. package/dist/components/VvButtonGroup/VvButtonGroup.umd.js +1 -0
  28. package/dist/components/VvButtonGroup/VvButtonGroup.vue.d.ts +92 -186
  29. package/dist/components/VvButtonGroup/index.d.ts +54 -0
  30. package/dist/components/VvCard/VvCard.es.js +77 -0
  31. package/dist/components/VvCard/VvCard.umd.js +1 -0
  32. package/dist/components/VvCard/VvCard.vue.d.ts +16 -61
  33. package/dist/components/VvCard/{VvCard.d.ts → index.d.ts} +1 -1
  34. package/dist/components/VvCheckbox/VvCheckbox.es.js +357 -0
  35. package/dist/components/VvCheckbox/VvCheckbox.umd.js +1 -0
  36. package/dist/components/VvCheckbox/VvCheckbox.vue.d.ts +74 -0
  37. package/dist/components/VvCheckbox/index.d.ts +54 -0
  38. package/dist/components/VvCheckboxGroup/VvCheckboxGroup.es.js +435 -0
  39. package/dist/components/VvCheckboxGroup/VvCheckboxGroup.umd.js +1 -0
  40. package/dist/components/VvCheckboxGroup/VvCheckboxGroup.vue.d.ts +82 -0
  41. package/dist/components/VvCheckboxGroup/index.d.ts +32 -0
  42. package/dist/components/VvCombobox/VvCombobox.es.js +775 -0
  43. package/dist/components/VvCombobox/VvCombobox.umd.js +1 -0
  44. package/dist/components/VvCombobox/VvCombobox.vue.d.ts +175 -0
  45. package/dist/components/VvCombobox/index.d.ts +108 -0
  46. package/dist/components/VvDialog/VvDialog.es.js +200 -0
  47. package/dist/components/VvDialog/VvDialog.umd.js +1 -0
  48. package/dist/components/VvDialog/VvDialog.vue.d.ts +28 -132
  49. package/dist/components/VvDialog/{VvDialog.d.ts → index.d.ts} +2 -6
  50. package/dist/components/VvDropdown/VvDropdown.es.js +227 -0
  51. package/dist/components/VvDropdown/VvDropdown.umd.js +1 -0
  52. package/dist/components/VvDropdown/VvDropdown.vue.d.ts +59 -146
  53. package/dist/components/VvDropdown/index.d.ts +49 -0
  54. package/dist/components/VvIcon/VvIcon.es.js +124 -0
  55. package/dist/components/VvIcon/VvIcon.umd.js +1 -0
  56. package/dist/components/VvIcon/VvIcon.vue.d.ts +36 -150
  57. package/dist/components/VvIcon/{VvIcon.d.ts → index.d.ts} +9 -0
  58. package/dist/components/VvInputText/VvInputClearAction.d.ts +36 -0
  59. package/dist/components/VvInputText/VvInputPasswordAction.d.ts +56 -0
  60. package/dist/components/VvInputText/VvInputStepAction.d.ts +37 -0
  61. package/dist/components/VvInputText/VvInputText.es.js +772 -0
  62. package/dist/components/VvInputText/VvInputText.umd.js +1 -0
  63. package/dist/components/VvInputText/VvInputText.vue.d.ts +211 -288
  64. package/dist/components/VvInputText/VvInputTextActions.d.ts +1 -1
  65. package/dist/components/VvInputText/index.d.ts +182 -0
  66. package/dist/components/VvProgress/VvProgress.es.js +71 -0
  67. package/dist/components/VvProgress/VvProgress.umd.js +1 -0
  68. package/dist/components/VvProgress/VvProgress.vue.d.ts +20 -107
  69. package/dist/components/VvProgress/index.d.ts +30 -0
  70. package/dist/components/VvRadio/VvRadio.es.js +320 -0
  71. package/dist/components/VvRadio/VvRadio.umd.js +1 -0
  72. package/dist/components/VvRadio/VvRadio.vue.d.ts +55 -125
  73. package/dist/components/VvRadio/index.d.ts +40 -0
  74. package/dist/components/VvRadioGroup/VvRadioGroup.es.js +398 -0
  75. package/dist/components/VvRadioGroup/VvRadioGroup.umd.js +1 -0
  76. package/dist/components/VvRadioGroup/VvRadioGroup.vue.d.ts +56 -238
  77. package/dist/components/VvRadioGroup/index.d.ts +32 -0
  78. package/dist/components/VvSelect/VvSelect.es.js +434 -0
  79. package/dist/components/VvSelect/VvSelect.umd.js +1 -0
  80. package/dist/components/VvSelect/VvSelect.vue.d.ts +125 -263
  81. package/dist/components/VvSelect/index.d.ts +89 -0
  82. package/dist/components/VvTextarea/VvTextarea.es.js +471 -0
  83. package/dist/components/VvTextarea/VvTextarea.umd.js +1 -0
  84. package/dist/components/VvTextarea/VvTextarea.vue.d.ts +140 -321
  85. package/dist/components/VvTextarea/index.d.ts +102 -0
  86. package/dist/components/common/HintSlot.d.ts +12 -6
  87. package/dist/components/index.d.ts +19 -12
  88. package/dist/components/index.es.js +2379 -0
  89. package/dist/components/index.umd.js +1 -0
  90. package/dist/composables/group/types/IAccordionGroupState.d.ts +3 -4
  91. package/dist/composables/group/types/IButtonGroupState.d.ts +5 -11
  92. package/dist/composables/group/types/IGroupState.d.ts +3 -6
  93. package/dist/composables/group/types/IInputGroup.d.ts +1 -4
  94. package/dist/composables/group/useInjectedGroupState.d.ts +4 -4
  95. package/dist/composables/group/useProvideGroupState.d.ts +2 -2
  96. package/dist/composables/useComponentFocus.d.ts +4 -0
  97. package/dist/composables/{icons/useComponentIcons.d.ts → useComponentIcons.d.ts} +3 -2
  98. package/dist/composables/useDebouncedInput.d.ts +2 -0
  99. package/dist/composables/useOptions.d.ts +6 -0
  100. package/dist/composables/useTextCount.d.ts +10 -0
  101. package/dist/constants.d.ts +4 -4
  102. package/dist/icons.d.ts +1881 -0
  103. package/dist/icons.es.js +12 -14
  104. package/dist/icons.umd.js +1 -1
  105. package/dist/index.d.ts +9 -4
  106. package/dist/index.es.js +2420 -0
  107. package/dist/index.umd.js +1 -0
  108. package/dist/props/index.d.ts +328 -30
  109. package/dist/resolvers/unplugin.d.ts +27 -0
  110. package/dist/resolvers/unplugin.es.js +42 -0
  111. package/dist/resolvers/unplugin.umd.js +1 -0
  112. package/dist/stories/Accordion/Accordion.settings.d.ts +63 -0
  113. package/dist/stories/Accordion/Accordion.test.d.ts +2 -0
  114. package/dist/stories/AccordionGroup/AccordionGroup.settings.d.ts +58 -0
  115. package/dist/stories/AccordionGroup/AccordionGroup.test.d.ts +2 -0
  116. package/dist/stories/Badge/Badge.settings.d.ts +32 -0
  117. package/dist/stories/Badge/Badge.test.d.ts +2 -0
  118. package/dist/stories/Breadcrumb/Breadcrumb.settings.d.ts +29 -0
  119. package/dist/stories/Breadcrumb/Breadcrumb.test.d.ts +2 -0
  120. package/dist/stories/Button/Button.settings.d.ts +198 -0
  121. package/dist/stories/Button/Button.test.d.ts +1 -10
  122. package/dist/stories/ButtonGroup/ButtonGroup.settings.d.ts +47 -0
  123. package/dist/stories/ButtonGroup/ButtonGroup.test.d.ts +2 -0
  124. package/dist/stories/Card/Card.settings.d.ts +70 -0
  125. package/dist/stories/Card/Card.test.d.ts +2 -0
  126. package/dist/stories/Checkbox/Checkbox.settings.d.ts +165 -0
  127. package/dist/stories/Checkbox/Checkbox.test.d.ts +2 -0
  128. package/dist/stories/CheckboxGroup/CheckboxGroup.settings.d.ts +164 -0
  129. package/dist/stories/CheckboxGroup/CheckboxGroup.test.d.ts +2 -0
  130. package/dist/stories/Combobox/Combobox.settings.d.ts +286 -0
  131. package/dist/stories/Combobox/Combobox.test.d.ts +2 -0
  132. package/dist/stories/Dialog/Dialog.settings.d.ts +55 -0
  133. package/dist/stories/Dialog/Dialog.test.d.ts +2 -0
  134. package/dist/stories/Dropdown/Dropdown.settings.d.ts +85 -0
  135. package/dist/stories/Dropdown/Dropdown.test.d.ts +2 -0
  136. package/dist/stories/Icon/Icon.settings.d.ts +74 -0
  137. package/dist/stories/InputText/InputText.settings.d.ts +445 -0
  138. package/dist/stories/InputText/InputText.test.d.ts +2 -0
  139. package/dist/stories/Progress/Progress.settings.d.ts +38 -0
  140. package/dist/stories/Progress/Progress.test.d.ts +2 -0
  141. package/dist/stories/Radio/Radio.settings.d.ts +139 -0
  142. package/dist/stories/Radio/Radio.test.d.ts +2 -0
  143. package/dist/stories/RadioGroup/RadioGroup.settings.d.ts +164 -0
  144. package/dist/stories/RadioGroup/RadioGroup.test.d.ts +2 -0
  145. package/dist/stories/Select/Select.settings.d.ts +284 -0
  146. package/dist/stories/Select/Select.test.d.ts +2 -0
  147. package/dist/stories/Textarea/Textarea.settings.d.ts +336 -0
  148. package/dist/stories/Textarea/Textarea.test.d.ts +2 -0
  149. package/dist/stories/argTypes.d.ts +842 -0
  150. package/dist/test/expect.d.ts +3 -0
  151. package/dist/test/options.d.ts +1 -0
  152. package/dist/test/sleep.d.ts +1 -0
  153. package/dist/utils/ObjectUtilities.d.ts +82 -95
  154. package/env.d.ts +1 -0
  155. package/package.json +199 -126
  156. package/src/{DesignSystem.ts → Volver.ts} +57 -29
  157. package/src/assets/icons/detailed.json +1 -1
  158. package/src/assets/icons/normal.json +1 -1
  159. package/src/assets/icons/simple.json +1 -1
  160. package/src/components/VvAccordion/VvAccordion.vue +94 -78
  161. package/src/components/VvAccordion/index.ts +72 -0
  162. package/src/components/VvAccordionGroup/VvAccordionGroup.vue +93 -53
  163. package/src/components/VvAccordionGroup/{VvAccordionGroup.ts → index.ts} +18 -14
  164. package/src/components/VvBadge/VvBadge.vue +17 -8
  165. package/src/components/VvBadge/index.ts +6 -0
  166. package/src/components/VvBreadcrumb/VvBreadcrumb.vue +26 -24
  167. package/src/components/VvBreadcrumb/{VvBreadcrumb.ts → index.ts} +1 -2
  168. package/src/components/VvButton/VvButton.vue +174 -153
  169. package/src/components/VvButton/index.ts +189 -0
  170. package/src/components/VvButtonGroup/VvButtonGroup.vue +76 -48
  171. package/src/components/VvButtonGroup/index.ts +16 -0
  172. package/src/components/VvCard/VvCard.vue +20 -22
  173. package/src/components/VvCard/{VvCard.ts → index.ts} +1 -1
  174. package/src/components/VvCheckbox/VvCheckbox.vue +172 -0
  175. package/src/components/VvCheckbox/index.ts +60 -0
  176. package/src/components/VvCheckboxGroup/VvCheckboxGroup.vue +85 -0
  177. package/src/components/VvCheckboxGroup/index.ts +5 -0
  178. package/src/components/VvCombobox/VvCombobox.vue +261 -0
  179. package/src/components/VvCombobox/index.ts +88 -0
  180. package/src/components/VvDialog/VvDialog.vue +69 -67
  181. package/src/components/VvDialog/index.ts +10 -0
  182. package/src/components/VvDropdown/VvDropdown.vue +115 -114
  183. package/src/components/VvDropdown/index.ts +35 -0
  184. package/src/components/VvIcon/README.md +64 -0
  185. package/src/components/VvIcon/VvIcon.vue +122 -107
  186. package/src/components/VvIcon/{VvIcon.ts → index.ts} +17 -8
  187. package/src/components/VvInputText/VvInputClearAction.ts +53 -0
  188. package/src/components/VvInputText/VvInputPasswordAction.ts +70 -0
  189. package/src/components/VvInputText/VvInputStepAction.ts +49 -0
  190. package/src/components/VvInputText/VvInputText.vue +307 -238
  191. package/src/components/VvInputText/VvInputTextActions.ts +63 -114
  192. package/src/components/VvInputText/index.ts +140 -0
  193. package/src/components/VvProgress/VvProgress.vue +29 -29
  194. package/src/components/VvProgress/index.ts +32 -0
  195. package/src/components/VvRadio/VvRadio.vue +90 -119
  196. package/src/components/VvRadio/index.ts +40 -0
  197. package/src/components/VvRadioGroup/VvRadioGroup.vue +76 -69
  198. package/src/components/VvRadioGroup/index.ts +5 -0
  199. package/src/components/VvSelect/VvSelect.vue +187 -186
  200. package/src/components/VvSelect/index.ts +71 -0
  201. package/src/components/VvTextarea/VvTextarea.vue +188 -174
  202. package/src/components/VvTextarea/index.ts +50 -0
  203. package/src/components/common/HintSlot.ts +167 -137
  204. package/src/components/index.ts +19 -12
  205. package/src/composables/group/types/IAccordionGroupState.ts +3 -4
  206. package/src/composables/group/types/IButtonGroupState.ts +5 -11
  207. package/src/composables/group/types/IGroupState.ts +4 -6
  208. package/src/composables/group/types/IInputGroup.ts +1 -4
  209. package/src/composables/group/useInjectedGroupState.ts +23 -35
  210. package/src/composables/group/useProvideGroupState.ts +5 -7
  211. package/src/composables/useComponentFocus.ts +17 -0
  212. package/src/composables/{icons/useComponentIcons.ts → useComponentIcons.ts} +29 -20
  213. package/src/composables/useDebouncedInput.ts +25 -0
  214. package/src/composables/useModifiers.ts +18 -20
  215. package/src/composables/useOptions.ts +31 -0
  216. package/src/composables/useTextCount.ts +57 -0
  217. package/src/constants.ts +5 -7
  218. package/src/directives/{.README → .gitkeep} +0 -0
  219. package/src/icons.ts +7 -0
  220. package/src/index.ts +12 -5
  221. package/src/props/index.ts +204 -36
  222. package/src/resolvers/unplugin.ts +112 -0
  223. package/src/shims.d.ts +13 -0
  224. package/src/stories/Accordion/Accordion.settings.ts +46 -0
  225. package/src/stories/Accordion/Accordion.stories.mdx +21 -21
  226. package/src/stories/Accordion/Accordion.test.ts +61 -0
  227. package/src/stories/Accordion/AccordionSlots.stories.mdx +46 -70
  228. package/src/stories/AccordionGroup/AccordionGroup.settings.ts +55 -0
  229. package/src/stories/AccordionGroup/AccordionGroup.stories.mdx +24 -27
  230. package/src/stories/AccordionGroup/AccordionGroup.test.ts +50 -0
  231. package/src/stories/AccordionGroup/AccordionGroupSlots.stories.mdx +56 -0
  232. package/src/stories/Badge/Badge.settings.ts +26 -0
  233. package/src/stories/Badge/Badge.stories.mdx +36 -24
  234. package/src/stories/Badge/Badge.test.ts +12 -0
  235. package/src/stories/Badge/BadgeSlots.stories.mdx +20 -0
  236. package/src/stories/Breadcrumb/Breadcrumb.settings.ts +41 -0
  237. package/src/stories/Breadcrumb/Breadcrumb.stories.mdx +32 -29
  238. package/src/stories/Breadcrumb/Breadcrumb.test.ts +50 -0
  239. package/src/stories/Breadcrumb/BreadcrumbSlots.stories.mdx +43 -0
  240. package/src/stories/Button/Button.settings.ts +145 -0
  241. package/src/stories/Button/Button.stories.mdx +20 -54
  242. package/src/stories/Button/Button.test.ts +35 -46
  243. package/src/stories/Button/ButtonIcon.stories.mdx +139 -29
  244. package/src/stories/Button/ButtonLink.stories.mdx +58 -111
  245. package/src/stories/Button/ButtonLoading.stories.mdx +89 -62
  246. package/src/stories/Button/ButtonModifiers.stories.mdx +198 -121
  247. package/src/stories/Button/ButtonSlots.stories.mdx +83 -95
  248. package/src/stories/Button/ButtonState.stories.mdx +75 -0
  249. package/src/stories/Button/ButtonToggle.stories.mdx +50 -0
  250. package/src/stories/ButtonGroup/ButtonGroup.settings.ts +33 -0
  251. package/src/stories/ButtonGroup/ButtonGroup.stories.mdx +16 -18
  252. package/src/stories/ButtonGroup/ButtonGroup.test.ts +35 -0
  253. package/src/stories/ButtonGroup/ButtonGroupModifiers.stories.mdx +52 -0
  254. package/src/stories/ButtonGroup/ButtonGroupSlots.stories.mdx +37 -0
  255. package/src/stories/ButtonGroup/ButtonGroupToggle.stories.mdx +52 -110
  256. package/src/stories/Card/Card.settings.ts +55 -0
  257. package/src/stories/Card/Card.stories.mdx +27 -11
  258. package/src/stories/Card/Card.test.ts +23 -0
  259. package/src/stories/Card/CardSlots.stories.mdx +80 -24
  260. package/src/stories/Checkbox/Checkbox.settings.ts +43 -0
  261. package/src/stories/Checkbox/Checkbox.stories.mdx +163 -0
  262. package/src/stories/Checkbox/Checkbox.test.ts +81 -0
  263. package/src/stories/Checkbox/CheckboxBinary.stories.mdx +68 -0
  264. package/src/stories/Checkbox/CheckboxSlots.stories.mdx +46 -0
  265. package/src/stories/CheckboxGroup/CheckboxGroup.settings.ts +15 -0
  266. package/src/stories/CheckboxGroup/CheckboxGroup.stories.mdx +134 -0
  267. package/src/stories/CheckboxGroup/CheckboxGroup.test.ts +83 -0
  268. package/src/stories/CheckboxGroup/CheckboxGroupOptions.stories.mdx +100 -0
  269. package/src/stories/CheckboxGroup/CheckboxGroupSlots.stories.mdx +67 -0
  270. package/src/stories/Combobox/Combobox.settings.ts +127 -0
  271. package/src/stories/Combobox/Combobox.stories.mdx +204 -0
  272. package/src/stories/Combobox/Combobox.test.ts +103 -0
  273. package/src/stories/Combobox/ComboboxMultiple.stories.mdx +74 -0
  274. package/src/stories/Combobox/ComboboxOptions.stories.mdx +100 -0
  275. package/src/stories/Combobox/ComboboxSlots.stories.mdx +48 -0
  276. package/src/stories/Dialog/Dialog.settings.ts +45 -0
  277. package/src/stories/Dialog/Dialog.stories.mdx +42 -16
  278. package/src/stories/Dialog/Dialog.test.ts +69 -0
  279. package/src/stories/Dialog/DialogSlots.stories.mdx +63 -0
  280. package/src/stories/Dropdown/Dropdown.settings.ts +51 -0
  281. package/src/stories/Dropdown/Dropdown.stories.mdx +102 -29
  282. package/src/stories/Dropdown/Dropdown.test.ts +43 -0
  283. package/src/stories/Dropdown/DropdownOptions.stories.mdx +87 -67
  284. package/src/stories/Icon/Icon.settings.ts +72 -0
  285. package/src/stories/Icon/Icon.stories.mdx +76 -59
  286. package/src/stories/Icon/IconsCollection.stories.mdx +68 -0
  287. package/src/stories/InputText/InputText.settings.ts +221 -0
  288. package/src/stories/InputText/InputText.stories.mdx +142 -69
  289. package/src/stories/InputText/InputText.test.ts +125 -0
  290. package/src/stories/InputText/InputTextIconPosition.stories.mdx +63 -16
  291. package/src/stories/InputText/InputTextLength.stories.mdx +110 -0
  292. package/src/stories/InputText/InputTextMinMax.stories.mdx +112 -0
  293. package/src/stories/InputText/InputTextSlots.stories.mdx +61 -22
  294. package/src/stories/InputText/InputTextType.stories.mdx +207 -29
  295. package/src/stories/Progress/Progress.settings.ts +33 -0
  296. package/src/stories/Progress/Progress.stories.mdx +12 -14
  297. package/src/stories/Progress/Progress.test.ts +9 -0
  298. package/src/stories/Radio/Radio.settings.ts +15 -0
  299. package/src/stories/Radio/Radio.stories.mdx +102 -42
  300. package/src/stories/Radio/Radio.test.ts +70 -0
  301. package/src/stories/Radio/RadioSlots.stories.mdx +39 -22
  302. package/src/stories/RadioGroup/RadioGroup.settings.ts +15 -0
  303. package/src/stories/RadioGroup/RadioGroup.stories.mdx +115 -54
  304. package/src/stories/RadioGroup/RadioGroup.test.ts +83 -0
  305. package/src/stories/RadioGroup/RadioGroupOptions.stories.mdx +83 -41
  306. package/src/stories/RadioGroup/RadioGroupSlots.stories.mdx +49 -144
  307. package/src/stories/Select/Select.settings.ts +86 -0
  308. package/src/stories/Select/Select.stories.mdx +173 -33
  309. package/src/stories/Select/Select.test.ts +82 -0
  310. package/src/stories/Select/SelectOptions.stories.mdx +91 -69
  311. package/src/stories/Select/SelectSlots.stories.mdx +48 -0
  312. package/src/stories/Textarea/Textarea.settings.ts +96 -0
  313. package/src/stories/Textarea/Textarea.stories.mdx +167 -47
  314. package/src/stories/Textarea/Textarea.test.ts +90 -0
  315. package/src/stories/Textarea/TextareaLength.stories.mdx +110 -0
  316. package/src/stories/Textarea/TextareaSlots.stories.mdx +61 -23
  317. package/src/stories/Textarea/TextareatIconPosition.stories.mdx +78 -0
  318. package/src/stories/argTypes.ts +457 -0
  319. package/src/test/expect.ts +27 -6
  320. package/src/test/options.ts +17 -0
  321. package/src/test/sleep.ts +2 -0
  322. package/src/test/types.d.ts +14 -0
  323. package/src/types/generic.d.ts +5 -0
  324. package/src/utils/ObjectUtilities.ts +253 -244
  325. package/dist/components/VvAccordion/VvAccordion.d.ts +0 -32
  326. package/dist/components/VvAccordion/useAccordionProps.d.ts +0 -16
  327. package/dist/components/VvAccordion/vv-accordion.es.js +0 -262
  328. package/dist/components/VvAccordion/vv-accordion.umd.js +0 -1
  329. package/dist/components/VvAccordionGroup/vv-accordion-group.es.js +0 -315
  330. package/dist/components/VvAccordionGroup/vv-accordion-group.umd.js +0 -1
  331. package/dist/components/VvBadge/vv-badge.es.js +0 -18
  332. package/dist/components/VvBadge/vv-badge.umd.js +0 -1
  333. package/dist/components/VvBreadcrumb/vv-breadcrumb.es.js +0 -206
  334. package/dist/components/VvBreadcrumb/vv-breadcrumb.umd.js +0 -1
  335. package/dist/components/VvButton/VvButton.d.ts +0 -115
  336. package/dist/components/VvButton/useButtonGroupProps.d.ts +0 -23
  337. package/dist/components/VvButton/vv-button.es.js +0 -422
  338. package/dist/components/VvButton/vv-button.umd.js +0 -1
  339. package/dist/components/VvButtonGroup/VvButtonGroup.d.ts +0 -57
  340. package/dist/components/VvButtonGroup/vv-button-group.es.js +0 -210
  341. package/dist/components/VvButtonGroup/vv-button-group.umd.js +0 -1
  342. package/dist/components/VvCard/vv-card.es.js +0 -188
  343. package/dist/components/VvCard/vv-card.umd.js +0 -1
  344. package/dist/components/VvCheck/VvCheck.d.ts +0 -47
  345. package/dist/components/VvCheck/VvCheck.vue.d.ts +0 -165
  346. package/dist/components/VvCheck/useCheckProps.d.ts +0 -16
  347. package/dist/components/VvCheck/vv-check.es.js +0 -321
  348. package/dist/components/VvCheck/vv-check.umd.js +0 -1
  349. package/dist/components/VvCheckGroup/VvCheckGroup.d.ts +0 -65
  350. package/dist/components/VvCheckGroup/VvCheckGroup.vue.d.ts +0 -272
  351. package/dist/components/VvCheckGroup/vv-check-group.es.js +0 -452
  352. package/dist/components/VvCheckGroup/vv-check-group.umd.js +0 -2
  353. package/dist/components/VvDialog/constants.d.ts +0 -5
  354. package/dist/components/VvDialog/vv-dialog.es.js +0 -315
  355. package/dist/components/VvDialog/vv-dialog.umd.js +0 -1
  356. package/dist/components/VvDropdown/VvDropdown.d.ts +0 -52
  357. package/dist/components/VvDropdown/vv-dropdown.es.js +0 -236
  358. package/dist/components/VvDropdown/vv-dropdown.umd.js +0 -1
  359. package/dist/components/VvIcon/vv-icon.es.js +0 -229
  360. package/dist/components/VvIcon/vv-icon.umd.js +0 -1
  361. package/dist/components/VvInputText/VvInputText.d.ts +0 -73
  362. package/dist/components/VvInputText/constants.d.ts +0 -55
  363. package/dist/components/VvInputText/vv-input-text.es.js +0 -725
  364. package/dist/components/VvInputText/vv-input-text.umd.js +0 -2
  365. package/dist/components/VvNativeSelect/VvNativeSelect.d.ts +0 -70
  366. package/dist/components/VvNativeSelect/VvNativeSelect.vue.d.ts +0 -228
  367. package/dist/components/VvNativeSelect/vv-native-select.es.js +0 -414
  368. package/dist/components/VvNativeSelect/vv-native-select.umd.js +0 -2
  369. package/dist/components/VvProgress/VvProgress.d.ts +0 -29
  370. package/dist/components/VvProgress/vv-progress.es.js +0 -185
  371. package/dist/components/VvProgress/vv-progress.umd.js +0 -1
  372. package/dist/components/VvRadio/VvRadio.d.ts +0 -22
  373. package/dist/components/VvRadio/useRadioProps.d.ts +0 -15
  374. package/dist/components/VvRadio/vv-radio.es.js +0 -309
  375. package/dist/components/VvRadio/vv-radio.umd.js +0 -1
  376. package/dist/components/VvRadioGroup/VvRadioGroup.d.ts +0 -54
  377. package/dist/components/VvRadioGroup/vv-radio-group.es.js +0 -441
  378. package/dist/components/VvRadioGroup/vv-radio-group.umd.js +0 -2
  379. package/dist/components/VvSelect/VvSelect.d.ts +0 -99
  380. package/dist/components/VvSelect/vv-select.es.js +0 -445
  381. package/dist/components/VvSelect/vv-select.umd.js +0 -2
  382. package/dist/components/VvTextarea/VvTextarea.d.ts +0 -88
  383. package/dist/components/VvTextarea/constants.d.ts +0 -19
  384. package/dist/components/VvTextarea/vv-textarea.es.js +0 -548
  385. package/dist/components/VvTextarea/vv-textarea.umd.js +0 -2
  386. package/dist/composables/debouncedInput/useDebouncedInput.d.ts +0 -2
  387. package/dist/composables/focus/useComponentFocus.d.ts +0 -7
  388. package/dist/composables/options/useOptions.d.ts +0 -5
  389. package/dist/composables/textLimit/useTextLimit.d.ts +0 -14
  390. package/dist/stories/Icon/IconList.vue.d.ts +0 -44
  391. package/dist/stories/utils.d.ts +0 -5
  392. package/dist/ui-vue.es.js +0 -3001
  393. package/dist/ui-vue.umd.js +0 -2
  394. package/src/assets/icons/index.js +0 -7
  395. package/src/components/VvAccordion/VvAccordion.ts +0 -34
  396. package/src/components/VvAccordion/useAccordionProps.ts +0 -45
  397. package/src/components/VvBadge/VvBadge.ts +0 -4
  398. package/src/components/VvButton/VvButton.ts +0 -117
  399. package/src/components/VvButton/useButtonGroupProps.ts +0 -51
  400. package/src/components/VvButtonGroup/VvButtonGroup.ts +0 -37
  401. package/src/components/VvCheck/VvCheck.ts +0 -48
  402. package/src/components/VvCheck/VvCheck.vue +0 -149
  403. package/src/components/VvCheck/useCheckProps.ts +0 -41
  404. package/src/components/VvCheckGroup/VvCheckGroup.ts +0 -34
  405. package/src/components/VvCheckGroup/VvCheckGroup.vue +0 -84
  406. package/src/components/VvDialog/VvDialog.ts +0 -17
  407. package/src/components/VvDialog/constants.ts +0 -5
  408. package/src/components/VvDropdown/VvDropdown.ts +0 -46
  409. package/src/components/VvInputText/VvInputText.ts +0 -66
  410. package/src/components/VvInputText/constants.ts +0 -34
  411. package/src/components/VvNativeSelect/VvNativeSelect.ts +0 -70
  412. package/src/components/VvNativeSelect/VvNativeSelect.vue +0 -106
  413. package/src/components/VvProgress/VvProgress.ts +0 -28
  414. package/src/components/VvRadio/VvRadio.ts +0 -25
  415. package/src/components/VvRadio/useRadioProps.ts +0 -40
  416. package/src/components/VvRadioGroup/VvRadioGroup.ts +0 -25
  417. package/src/components/VvSelect/VvSelect.ts +0 -91
  418. package/src/components/VvTextarea/VvTextarea.ts +0 -64
  419. package/src/components/VvTextarea/constants.ts +0 -14
  420. package/src/composables/debouncedInput/useDebouncedInput.ts +0 -19
  421. package/src/composables/focus/useComponentFocus.ts +0 -22
  422. package/src/composables/options/useOptions.ts +0 -27
  423. package/src/composables/textLimit/useTextLimit.ts +0 -44
  424. package/src/stories/Accordion/AccordionBordered.stories.mdx +0 -26
  425. package/src/stories/Accordion/AccordionIconRight.stories.mdx +0 -32
  426. package/src/stories/Accordion/accordionTest.js +0 -36
  427. package/src/stories/AccordionGroup/Accordion.stories.mdx +0 -42
  428. package/src/stories/AccordionGroup/AccordionItems.stories.mdx +0 -51
  429. package/src/stories/AccordionGroup/accordionGroupTest.js +0 -51
  430. package/src/stories/Badge/BadgeColor.stories.mdx +0 -54
  431. package/src/stories/Badge/BadgeDot.stories.mdx +0 -20
  432. package/src/stories/Badge/BadgeTest.js +0 -21
  433. package/src/stories/Breadcrumb/BreadcrumbMultiline.stories.mdx +0 -41
  434. package/src/stories/Button/ButtonBadge.stories.mdx +0 -34
  435. package/src/stories/Button/ButtonIconPosition.stories.mdx +0 -106
  436. package/src/stories/Button/ButtonVariant.stories.mdx +0 -205
  437. package/src/stories/Button/test.js +0 -41
  438. package/src/stories/ButtonGroup/ButtonGroupAction.stories.mdx +0 -83
  439. package/src/stories/ButtonGroup/ButtonGroupActionQuiet.stories.mdx +0 -50
  440. package/src/stories/ButtonGroup/ButtonGroupBlock.stories.mdx +0 -40
  441. package/src/stories/ButtonGroup/ButtonGroupCompact.stories.mdx +0 -38
  442. package/src/stories/ButtonGroup/ButtonGroupRounded.stories.mdx +0 -77
  443. package/src/stories/ButtonGroup/ButtonGroupTest.js +0 -61
  444. package/src/stories/ButtonGroup/ButtonGroupVertical.stories.mdx +0 -38
  445. package/src/stories/Card/CardVariant.stories.mdx +0 -37
  446. package/src/stories/Check/Check.stories.mdx +0 -62
  447. package/src/stories/Check/CheckBinary.stories.mdx +0 -80
  448. package/src/stories/Check/CheckDisabled.stories.mdx +0 -30
  449. package/src/stories/Check/CheckError.stories.mdx +0 -64
  450. package/src/stories/Check/CheckErrorTests.js +0 -72
  451. package/src/stories/Check/CheckHintLabel.stories.mdx +0 -30
  452. package/src/stories/Check/CheckPropertyTest.js +0 -101
  453. package/src/stories/Check/CheckReadonly.stories.mdx +0 -30
  454. package/src/stories/Check/CheckSlots.stories.mdx +0 -51
  455. package/src/stories/Check/CheckSwitch.stories.mdx +0 -30
  456. package/src/stories/CheckGroup/CheckGroup.stories.mdx +0 -69
  457. package/src/stories/CheckGroup/CheckGroupDisabled.stories.mdx +0 -26
  458. package/src/stories/CheckGroup/CheckGroupError.stories.mdx +0 -28
  459. package/src/stories/CheckGroup/CheckGroupHintLabel.stories.mdx +0 -27
  460. package/src/stories/CheckGroup/CheckGroupLabel.stories.mdx +0 -26
  461. package/src/stories/CheckGroup/CheckGroupOptionLabel.stories.mdx +0 -48
  462. package/src/stories/CheckGroup/CheckGroupOptionValue.stories.mdx +0 -48
  463. package/src/stories/CheckGroup/CheckGroupOptions.stories.mdx +0 -40
  464. package/src/stories/CheckGroup/CheckGroupReadonly.stories.mdx +0 -26
  465. package/src/stories/CheckGroup/CheckGroupSlots.stories.mdx +0 -152
  466. package/src/stories/CheckGroup/CheckGroupValid.stories.mdx +0 -28
  467. package/src/stories/CheckGroup/CheckGroupVertical.stories.mdx +0 -26
  468. package/src/stories/Dialog/DialogAutoClose.stories.mdx +0 -18
  469. package/src/stories/Dialog/DialogSize.stories.mdx +0 -36
  470. package/src/stories/Dropdown/DropdownDisabled.stories.mdx +0 -25
  471. package/src/stories/Dropdown/DropdownLabelNoResults.stories.mdx +0 -25
  472. package/src/stories/Dropdown/DropdownMaxValues.stories.mdx +0 -26
  473. package/src/stories/Dropdown/DropdownMultiple.stories.mdx +0 -56
  474. package/src/stories/Dropdown/DropdownUseObject.stories.mdx +0 -58
  475. package/src/stories/Icon/IconList.vue +0 -34
  476. package/src/stories/Icon/IconPrefix.stories.mdx +0 -79
  477. package/src/stories/Icon/IconRemote.stories.mdx +0 -39
  478. package/src/stories/Icon/IconTest.js +0 -27
  479. package/src/stories/Icon/IconsList.stories.mdx +0 -35
  480. package/src/stories/InputText/InputTextAutocomplete.stories.mdx +0 -15
  481. package/src/stories/InputText/InputTextAutofocus.stories.mdx +0 -20
  482. package/src/stories/InputText/InputTextDisabled.stories.mdx +0 -19
  483. package/src/stories/InputText/InputTextError.stories.mdx +0 -19
  484. package/src/stories/InputText/InputTextFloating.stories.mdx +0 -20
  485. package/src/stories/InputText/InputTextHintLabel.stories.mdx +0 -18
  486. package/src/stories/InputText/InputTextIcon.stories.mdx +0 -18
  487. package/src/stories/InputText/InputTextLabel.stories.mdx +0 -15
  488. package/src/stories/InputText/InputTextLoading.stories.mdx +0 -19
  489. package/src/stories/InputText/InputTextMax.stories.mdx +0 -31
  490. package/src/stories/InputText/InputTextMaxLength.stories.mdx +0 -36
  491. package/src/stories/InputText/InputTextMin.stories.mdx +0 -31
  492. package/src/stories/InputText/InputTextMinLength.stories.mdx +0 -15
  493. package/src/stories/InputText/InputTextPlaceholder.stories.mdx +0 -15
  494. package/src/stories/InputText/InputTextReadonly.stories.mdx +0 -19
  495. package/src/stories/InputText/InputTextStep.stories.mdx +0 -31
  496. package/src/stories/InputText/InputTextValid.stories.mdx +0 -19
  497. package/src/stories/NativeSelect/NativeSelect.stories.mdx +0 -53
  498. package/src/stories/NativeSelect/NativeSelectDisabled.stories.mdx +0 -32
  499. package/src/stories/NativeSelect/NativeSelectError.stories.mdx +0 -36
  500. package/src/stories/NativeSelect/NativeSelectHintLabel.stories.mdx +0 -34
  501. package/src/stories/NativeSelect/NativeSelectIconLeftRight.stories.mdx +0 -42
  502. package/src/stories/NativeSelect/NativeSelectLoading.stories.mdx +0 -27
  503. package/src/stories/NativeSelect/NativeSelectOptions.stories.mdx +0 -78
  504. package/src/stories/NativeSelect/NativeSelectReadonly.stories.mdx +0 -34
  505. package/src/stories/NativeSelect/NativeSelectUseObject.stories.mdx +0 -66
  506. package/src/stories/NativeSelect/NativeSelectValid.stories.mdx +0 -36
  507. package/src/stories/NativeSelect/NativeSelectValueKey.stories.mdx +0 -66
  508. package/src/stories/Progress/ProgressDeterminate.stories.mdx +0 -19
  509. package/src/stories/Radio/RadioDisabled.stories.mdx +0 -30
  510. package/src/stories/Radio/RadioError.stories.mdx +0 -64
  511. package/src/stories/Radio/RadioHintLabel.stories.mdx +0 -30
  512. package/src/stories/Radio/RadioTest.js +0 -89
  513. package/src/stories/RadioGroup/RadioGroupDisabled.stories.mdx +0 -29
  514. package/src/stories/RadioGroup/RadioGroupError.stories.mdx +0 -31
  515. package/src/stories/RadioGroup/RadioGroupHintLabel.stories.mdx +0 -28
  516. package/src/stories/RadioGroup/RadioGroupLabel.stories.mdx +0 -29
  517. package/src/stories/RadioGroup/RadioGroupOptionLabel.stories.mdx +0 -65
  518. package/src/stories/RadioGroup/RadioGroupOptionValue.stories.mdx +0 -65
  519. package/src/stories/RadioGroup/RadioGroupReadonly.stories.mdx +0 -29
  520. package/src/stories/RadioGroup/RadioGroupValid.stories.mdx +0 -31
  521. package/src/stories/RadioGroup/RadioGroupVertical.stories.mdx +0 -29
  522. package/src/stories/RadioGroup/RadioOptionsTest.js +0 -78
  523. package/src/stories/RadioGroup/RadioPropertyTest.js +0 -131
  524. package/src/stories/RadioGroup/RadioSlotsTest.js +0 -20
  525. package/src/stories/Select/SelectDisabled.stories.mdx +0 -32
  526. package/src/stories/Select/SelectMaxValues.stories.mdx +0 -33
  527. package/src/stories/Select/SelectMultiple.stories.mdx +0 -64
  528. package/src/stories/Select/SelectSearchable.stories.mdx +0 -80
  529. package/src/stories/Select/SelectSeparator.stories.mdx +0 -64
  530. package/src/stories/Select/SelectUseObject.stories.mdx +0 -66
  531. package/src/stories/Textarea/TextareaAutoclear.stories.mdx +0 -23
  532. package/src/stories/Textarea/TextareaAutocomplete.stories.mdx +0 -23
  533. package/src/stories/Textarea/TextareaAutofocus.stories.mdx +0 -24
  534. package/src/stories/Textarea/TextareaDebounce.stories.mdx +0 -23
  535. package/src/stories/Textarea/TextareaDisabled.stories.mdx +0 -23
  536. package/src/stories/Textarea/TextareaError.stories.mdx +0 -22
  537. package/src/stories/Textarea/TextareaErrorLabel.stories.mdx +0 -37
  538. package/src/stories/Textarea/TextareaFloating.stories.mdx +0 -25
  539. package/src/stories/Textarea/TextareaHintLabel.stories.mdx +0 -22
  540. package/src/stories/Textarea/TextareaIcon.stories.mdx +0 -22
  541. package/src/stories/Textarea/TextareaIconPosition.stories.mdx +0 -39
  542. package/src/stories/Textarea/TextareaId.stories.mdx +0 -19
  543. package/src/stories/Textarea/TextareaLabel.stories.mdx +0 -19
  544. package/src/stories/Textarea/TextareaLimit.stories.mdx +0 -50
  545. package/src/stories/Textarea/TextareaLoading.stories.mdx +0 -22
  546. package/src/stories/Textarea/TextareaLoadingLabel.stories.mdx +0 -23
  547. package/src/stories/Textarea/TextareaMaxLength.stories.mdx +0 -19
  548. package/src/stories/Textarea/TextareaMinLength.stories.mdx +0 -19
  549. package/src/stories/Textarea/TextareaModifiers.stories.mdx +0 -24
  550. package/src/stories/Textarea/TextareaName.stories.mdx +0 -23
  551. package/src/stories/Textarea/TextareaPlaceholder.stories.mdx +0 -19
  552. package/src/stories/Textarea/TextareaReadonly.stories.mdx +0 -23
  553. package/src/stories/Textarea/TextareaRequired.stories.mdx +0 -22
  554. package/src/stories/Textarea/TextareaResizable.stories.mdx +0 -22
  555. package/src/stories/Textarea/TextareaRowsCols.stories.mdx +0 -39
  556. package/src/stories/Textarea/TextareaValid.stories.mdx +0 -22
  557. package/src/stories/Textarea/TextareaValidLabel.stories.mdx +0 -35
  558. package/src/stories/stories.scss +0 -35
  559. package/src/stories/utils.ts +0 -12
  560. package/src/stories/volver-ui-vue.stories.mdx +0 -77
  561. package/src/types/.README +0 -0
@@ -1,46 +0,0 @@
1
- import type { PropType } from 'vue'
2
- import { DisabledProps, ModifiersProps } from '../../props'
3
-
4
- export interface Option {
5
- [key: string]: any
6
- }
7
-
8
- export const VvDropdownProps = {
9
- ...DisabledProps,
10
- ...ModifiersProps,
11
- /**
12
- * modelValue can be an Object, a String or an Array of Object/String
13
- */
14
- modelValue: [String, Array, Object],
15
- /**
16
- * Label of "no results" options
17
- */
18
- labelNoResult: { type: String, default: 'No results' },
19
- /**
20
- * Select options, can be string[] or object[]
21
- */
22
- options: {
23
- type: Array as PropType<Array<Option | string>>,
24
- required: true
25
- },
26
- /**
27
- * Use objects as modelValue (object or object[])
28
- */
29
- useObject: Boolean,
30
- /**
31
- * Manage modelValue as string[] or object[]
32
- */
33
- multiple: Boolean,
34
- /**
35
- * The max number of selected values
36
- */
37
- maxValues: [Number, String],
38
- /**
39
- * Used when options are objects: key to use for option label
40
- */
41
- labelKey: { type: String, default: 'label' },
42
- /**
43
- * Used when options are objects: key to use for option label
44
- */
45
- valueKey: { type: String, default: 'value' }
46
- }
@@ -1,66 +0,0 @@
1
- import type { ExtractPropTypes } from 'vue'
2
- import {
3
- ValidProps,
4
- ErrorProps,
5
- HintProps,
6
- LoadingProps,
7
- ModifiersProps,
8
- LimitProps
9
- } from '../../props'
10
- import { TYPES, ICON_POSITIONS } from './constants'
11
-
12
- export const VvInputTextEvents = ['update:modelValue', 'focus', 'blur']
13
-
14
- export const VvInputTextProps = {
15
- ...ValidProps,
16
- ...ErrorProps,
17
- ...HintProps,
18
- ...LoadingProps,
19
- ...ModifiersProps,
20
- ...LimitProps,
21
- modelValue: null,
22
- type: {
23
- type: String,
24
- default: TYPES.TEXT,
25
- validator: (value: string) => Object.values(TYPES).includes(value)
26
- },
27
- id: String,
28
- name: { type: String, required: true },
29
- autocomplete: { type: String, default: 'off' },
30
- autofocus: Boolean,
31
- minlength: Number,
32
- maxlength: Number,
33
- min: [Number, Date],
34
- max: [Number, Date],
35
- step: Number,
36
- label: String,
37
- disabled: Boolean,
38
- readonly: Boolean,
39
- placeholder: String,
40
- /**
41
- * Nome dell'icona
42
- * @see DsIcon
43
- */
44
- icon: { type: String, default: '' },
45
- /**
46
- * Posizione dell'icona
47
- */
48
- iconPosition: {
49
- type: String,
50
- validation: (value: string) =>
51
- Object.values(ICON_POSITIONS).includes(value),
52
- default: ICON_POSITIONS.RIGHT
53
- },
54
- /**
55
- * True = label flottante
56
- */
57
- floating: Boolean,
58
- debounce: Number,
59
- /**
60
- * Se true, attiva la possibilità di cancellare il testo nella textarea
61
- */
62
- autoclear: Boolean
63
- }
64
-
65
- type VvInputTextPropsType = typeof VvInputTextProps
66
- export type VvInputTextPropsTypes = ExtractPropTypes<VvInputTextPropsType>
@@ -1,34 +0,0 @@
1
- export const TYPES = {
2
- TEXT: 'text',
3
- PASSWORD: 'password',
4
- DATE: 'date',
5
- DATETIME_LOCAL: 'datetime-local',
6
- NUMBER: 'number',
7
- TIME: 'time',
8
- EMAIL: 'email',
9
- TEL: 'tel',
10
- URL: 'url',
11
- COLOR: 'color',
12
- SEARCH: 'search',
13
- FILE: 'file'
14
- }
15
-
16
- export const ICON_POSITIONS = {
17
- LEFT: 'left',
18
- RIGHT: 'right'
19
- }
20
-
21
- export const TYPES_ICON = {
22
- PASSWORD_ON: 'eye-on',
23
- PASSWORD_OFF: 'eye-off',
24
- DATE: 'calendar',
25
- TIME: 'time',
26
- COLOR: 'color',
27
- SEARCH: 'search'
28
- }
29
-
30
- export default {
31
- TYPES,
32
- ICON_POSITIONS,
33
- TYPES_ICON
34
- }
@@ -1,70 +0,0 @@
1
- import type { PropType } from 'vue'
2
- import {
3
- ValidProps,
4
- ErrorProps,
5
- HintProps,
6
- LoadingProps,
7
- DisabledProps,
8
- ReadonlyProps,
9
- ModifiersProps
10
- } from '../../props'
11
-
12
- export interface Option {
13
- [key: string]: any
14
- }
15
-
16
- export const VvNativeSelectProps = {
17
- ...ValidProps,
18
- ...ErrorProps,
19
- ...HintProps,
20
- ...LoadingProps,
21
- ...DisabledProps,
22
- ...ReadonlyProps,
23
- ...ModifiersProps,
24
- /**
25
- * modelValue can be an Object, a String or an Array of Object/String
26
- */
27
- modelValue: {
28
- type: [String, Object],
29
- required: true
30
- },
31
- /**
32
- * Select input label
33
- */
34
- label: String,
35
- /**
36
- * Select input placeholder
37
- */
38
- placeholder: String,
39
- /**
40
- * Select options, can be an Array of string or an array of objects
41
- */
42
- options: {
43
- type: Array as PropType<Array<Option | string>>,
44
- required: true
45
- },
46
- /**
47
- * Use objects as modelValue (object or object[])
48
- */
49
- useObject: Boolean,
50
- /**
51
- * Used when options are objects: key to use for option label
52
- */
53
- labelKey: { type: String, default: 'label' },
54
- /**
55
- * Used when options are objects: key to use for option label
56
- */
57
- valueKey: { type: String, default: 'value' },
58
- /**
59
- * Icon name of icon in left position
60
- */
61
- iconLeft: String,
62
- /**
63
- * Icon name of icon in right position
64
- */
65
- iconRight: String,
66
- /**
67
- * String or String[] of css classes (modifiers) that will be concatenated to prefix 'vv-native-select--'
68
- */
69
- modifiers: [String, Array]
70
- }
@@ -1,106 +0,0 @@
1
- <template>
2
- <div :class="selectClasses">
3
- <label v-if="label" :for="id">{{ label }}</label>
4
- <!-- #region native select -->
5
- <div class="vv-select__wrapper">
6
- <slot name="icon-left">
7
- <vv-icon v-if="iconLeft" :name="iconLeft" />
8
- </slot>
9
- <select
10
- :id="id"
11
- :value="
12
- typeof modelValue === 'string'
13
- ? modelValue
14
- : modelValue?.[valueKey]
15
- "
16
- :disabled="disabled || readonly"
17
- @input="onInput">
18
- <option v-if="placeholder" value="" disabled selected>
19
- {{ placeholder }}
20
- </option>
21
- <option
22
- v-for="(option, index) in options"
23
- :key="index"
24
- :disabled="
25
- typeof option === 'object'
26
- ? option.disabled ?? disabled
27
- : disabled
28
- "
29
- :value="getValue(option)">
30
- {{ getLabel(option) }}
31
- </option>
32
- </select>
33
- <slot name="icon-right">
34
- <vv-icon v-if="iconRight" :name="iconRight" />
35
- </slot>
36
- </div>
37
- <!-- #endregion native select -->
38
- <HintSlot class="vv-select__hint" />
39
- </div>
40
- </template>
41
-
42
- <script setup lang="ts">
43
- import { computed, toRefs, useSlots } from 'vue'
44
- import { v4 as uuidv4 } from 'uuid'
45
- import ObjectUtilities from '../../utils/ObjectUtilities'
46
- import { VvNativeSelectProps, type Option } from './VvNativeSelect'
47
- import VvIcon from '../VvIcon/VvIcon.vue'
48
- import HintSlotFactory from '../common/HintSlot'
49
- import { useBemModifiers } from '../../composables/useModifiers'
50
-
51
- const props = defineProps(VvNativeSelectProps)
52
- const slots = useSlots()
53
- const emit = defineEmits(['update:modelValue'])
54
- //Hint component
55
- const HintSlot = HintSlotFactory(props, slots)
56
-
57
- // data
58
- const {
59
- modifiers,
60
- disabled,
61
- readonly,
62
- loading,
63
- iconLeft,
64
- iconRight,
65
- error,
66
- valid
67
- } = toRefs(props)
68
-
69
- const id = uuidv4()
70
-
71
- //Styles & css classes modifiers
72
- const { bemCssClasses: selectClasses } = useBemModifiers('vv-select', {
73
- modifiers,
74
- loading,
75
- readonly,
76
- iconLeft,
77
- iconRight,
78
- valid,
79
- invalid: error,
80
- dirty: computed(() => ObjectUtilities.isNotEmpty(props.modelValue))
81
- })
82
-
83
- function getValue(option: string | Option) {
84
- return typeof option === 'string' ? option : option[props.valueKey]
85
- }
86
-
87
- function getLabel(option: string | Option) {
88
- return typeof option === 'string' ? option : option[props.labelKey]
89
- }
90
-
91
- function onInput(event: Event) {
92
- const target = event.target as HTMLSelectElement
93
-
94
- // Find option object if useObject prop is true
95
- const valueObject = props.useObject
96
- ? props.options?.find(
97
- (option) => (option as Option)[props.valueKey] == target.value
98
- )
99
- : null
100
-
101
- // use valueObject if exist or the target value
102
- const value = valueObject || target.value
103
-
104
- emit('update:modelValue', value)
105
- }
106
- </script>
@@ -1,28 +0,0 @@
1
- import { ModifiersProps } from '../../props'
2
-
3
- export const VvProgressProps = {
4
- ...ModifiersProps,
5
- /**
6
- * Progress value
7
- */
8
- value: {
9
- type: [Number, String]
10
- },
11
- /**
12
- * Progress max value
13
- */
14
- max: {
15
- type: [Number, String]
16
- },
17
- /**
18
- * Progress label
19
- */
20
- ariaLabel: {
21
- type: String,
22
- default: 'progress-bar'
23
- },
24
- /**
25
- * determinate attribute
26
- */
27
- determinate: { type: Boolean, default: false }
28
- }
@@ -1,25 +0,0 @@
1
- import type { ExtractPropTypes } from 'vue'
2
- import { ValidProps, ErrorProps } from '../../props'
3
-
4
- export const VvRadioProps = {
5
- ...ValidProps,
6
- ...ErrorProps,
7
- /**
8
- * Valore del radio
9
- */
10
- value: null,
11
- modelValue: { type: [Object, Number, Boolean, String] },
12
- label: { type: String, default: '' },
13
- disabled: Boolean,
14
- readonly: Boolean
15
- }
16
-
17
- export const VvRadioEvents = [
18
- 'click',
19
- 'update:modelValue',
20
- 'change',
21
- 'focus',
22
- 'blur'
23
- ]
24
-
25
- export type VvRadioPropsType = ExtractPropTypes<typeof VvRadioProps>
@@ -1,40 +0,0 @@
1
- import type { VvRadioPropsType } from '../VvRadio/VvRadio'
2
- import type { IInputGroupState } from '@/composables/group/types/IInputGroup'
3
-
4
- import { toRefs } from 'vue'
5
-
6
- //Composables
7
- import { useInjectedGroupState } from '../../composables/group/useInjectedGroupState'
8
-
9
- //Constasts
10
- import { VV_RADIO_GROUP } from '../../constants'
11
-
12
- /**
13
- * Estreae tutte le prop del componente VvButton che possono essere
14
- * "sovrascritte" quando il buttone si trova in un gruppo.
15
- */
16
- export function toRadioInputRefs(
17
- props: VvRadioPropsType,
18
- emit: (event: any, ...args: any[]) => void
19
- ) {
20
- const { group, isInGroup, getGroupOrLocalRef } =
21
- useInjectedGroupState<IInputGroupState>(VV_RADIO_GROUP)
22
-
23
- //Local props
24
- const { valid, error } = toRefs(props)
25
-
26
- //Global props
27
- const modelValue = getGroupOrLocalRef('modelValue', props, emit)
28
- const readonly = getGroupOrLocalRef('readonly', props)
29
- const disabled = getGroupOrLocalRef('disabled', props)
30
-
31
- return {
32
- group,
33
- isInGroup,
34
- valid,
35
- error,
36
- modelValue,
37
- readonly,
38
- disabled
39
- }
40
- }
@@ -1,25 +0,0 @@
1
- import { ValidProps, ErrorProps, OptionsProps, HintProps } from '../../props'
2
-
3
- export const VvRadioGroupEvents = ['update:modelValue']
4
-
5
- export const VvRadioGroupProps = {
6
- ...ValidProps,
7
- ...ErrorProps,
8
- ...OptionsProps,
9
- ...HintProps,
10
- /**
11
- * VModel
12
- */
13
- modelValue: null,
14
- label: { type: String, default: '' },
15
- /**
16
- * Nome da utilizzare per il radio group
17
- */
18
- name: { type: String, default: '', required: true },
19
- disabled: { type: Boolean, default: false },
20
- readonly: { type: Boolean, default: false },
21
- /**
22
- * True = show buttons vertically
23
- */
24
- vertical: { type: Boolean, default: false }
25
- }
@@ -1,91 +0,0 @@
1
- import type { PropType } from 'vue'
2
- import type { Option } from '../VvDropdown/VvDropdown'
3
- import {
4
- ValidProps,
5
- ErrorProps,
6
- HintProps,
7
- LoadingProps,
8
- DisabledProps,
9
- ReadonlyProps,
10
- ModifiersProps
11
- } from '../../props'
12
-
13
- export const VvSelectProps = {
14
- ...ValidProps,
15
- ...ErrorProps,
16
- ...HintProps,
17
- ...LoadingProps,
18
- ...DisabledProps,
19
- ...ReadonlyProps,
20
- ...ModifiersProps,
21
- /**
22
- * modelValue can be an Object, a String or an Array of Object/String
23
- */
24
- modelValue: [String, Array, Object],
25
- /**
26
- * Select input label
27
- */
28
- label: String,
29
- /**
30
- * Label of "no results" options
31
- */
32
- labelNoResult: { type: String, default: 'No results' },
33
- /**
34
- * Select input placeholder
35
- */
36
- placeholder: String,
37
- /**
38
- * Use input text to search on options
39
- */
40
- searchable: Boolean,
41
- /**
42
- * On searchable select is the input search placeholder
43
- */
44
- searchPlaceholder: String,
45
- /**
46
- * the input search debounce time in ms
47
- */
48
- debounceSearch: {
49
- type: [Number, String],
50
- default: 0
51
- },
52
- /**
53
- * Select options, can be string[] or object[]
54
- */
55
- options: {
56
- type: Array as PropType<Array<Option | string>>,
57
- required: true
58
- },
59
- /**
60
- * Use objects as modelValue (object or object[])
61
- */
62
- useObject: Boolean,
63
- /**
64
- * Manage modelValue as string[] or object[]
65
- */
66
- multiple: Boolean,
67
- /**
68
- * The max number of selected values
69
- */
70
- maxValues: [Number, String],
71
- /**
72
- * The select label separator visible to the user
73
- */
74
- separator: { type: String, default: ', ' },
75
- /**
76
- * Used when options are objects: key to use for option label
77
- */
78
- labelKey: { type: String, default: 'label' },
79
- /**
80
- * Used when options are objects: key to use for option label
81
- */
82
- valueKey: { type: String, default: 'value' },
83
- /**
84
- * Icon name of icon in left position
85
- */
86
- iconLeft: String,
87
- /**
88
- * Icon name of icon in right position
89
- */
90
- iconRight: String
91
- }
@@ -1,64 +0,0 @@
1
- import type { ExtractPropTypes } from 'vue'
2
- import {
3
- ValidProps,
4
- ErrorProps,
5
- HintProps,
6
- LoadingProps,
7
- ModifiersProps,
8
- LimitProps,
9
- InputProps,
10
- DebounceProps
11
- } from '../../props'
12
- import { ICON_POSITIONS, WRAP } from './constants'
13
-
14
- export const VvTextareaEvents = ['update:modelValue', 'focus', 'blur']
15
-
16
- export const VvTextareaProps = {
17
- ...ValidProps,
18
- ...ErrorProps,
19
- ...HintProps,
20
- ...LoadingProps,
21
- ...ModifiersProps,
22
- ...LimitProps,
23
- ...InputProps,
24
- ...DebounceProps,
25
- modelValue: null,
26
- cols: { type: Number, default: 50 },
27
- rows: { type: Number, default: 5 },
28
- /**
29
- * Nome dell'icona
30
- * @see DsIcon
31
- */
32
- icon: { type: String, default: '' },
33
- /**
34
- * Posizione dell'icona
35
- */
36
- iconPosition: {
37
- type: String,
38
- validation: (value: string) =>
39
- Object.values(ICON_POSITIONS).includes(value),
40
- default: ICON_POSITIONS.RIGHT
41
- },
42
- /**
43
- * True = label flottante
44
- */
45
- floating: Boolean,
46
- /**
47
- * Specifica come il testo sarà wrappato
48
- * @see Documentation https://www.w3schools.com/tags/att_textarea_wrap.asp
49
- */
50
- wrap: { type: String, default: WRAP.soft },
51
- /**
52
- * Se true, attiva la possibilità di cancellare il testo nella textarea
53
- */
54
- autoclear: Boolean,
55
- /**
56
- * Se true, la textbox può essere ridimensionata verticalmente.
57
- * @description
58
- * Il resize è pilotato via css. Al momento è attivo solamente il resize verticale
59
- */
60
- resizable: Boolean
61
- }
62
-
63
- type VvTextareaPropsType = typeof VvTextareaProps
64
- export type VvTextareaPropsTypes = ExtractPropTypes<VvTextareaPropsType>
@@ -1,14 +0,0 @@
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
- }
@@ -1,19 +0,0 @@
1
- import type { Ref } from 'vue'
2
-
3
- import { refDebounced } from '@vueuse/core'
4
-
5
- import { watch, ref } from 'vue'
6
-
7
- export function useDebouncedInput(
8
- inputText: Ref<any> | undefined,
9
- debounced: number | undefined,
10
- emit: (event: any, ...args: any[]) => void
11
- ): Ref<any> {
12
- const _text = ref(inputText?.value)
13
- const debouncedInputTextData = refDebounced(
14
- _text as Ref<any>,
15
- debounced || 0
16
- )
17
- watch(debouncedInputTextData, (v) => emit('update:modelValue', v))
18
- return _text
19
- }
@@ -1,22 +0,0 @@
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
- }
@@ -1,27 +0,0 @@
1
- import { toRefs } from 'vue'
2
-
3
- export function useOptions(props: any) {
4
- const { options, optionLabel, optionValue } = toRefs(props)
5
-
6
- const getOptionLabel = (o: any) => {
7
- if (typeof o !== 'object' && o !== null) return o
8
-
9
- return typeof optionLabel.value === 'function'
10
- ? optionLabel.value(o)
11
- : o[optionLabel.value]
12
- }
13
-
14
- const getOptionValue = (o: any) => {
15
- if (typeof o !== 'object' && o !== null) return o
16
-
17
- return typeof optionValue.value === 'function'
18
- ? optionValue.value(o)
19
- : o[optionValue.value]
20
- }
21
-
22
- return {
23
- options,
24
- getOptionLabel,
25
- getOptionValue
26
- }
27
- }