sprintify-ui 0.1.17 → 0.2.0

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 (395) hide show
  1. package/README.md +228 -229
  2. package/dist/sprintify-ui.es.js +15738 -13373
  3. package/dist/style.css +1 -1
  4. package/dist/tailwindcss/index.js +306 -306
  5. package/dist/types/src/components/BaseActionItem.vue.d.ts +33 -33
  6. package/dist/types/src/components/BaseActionItemButton.vue.d.ts +32 -29
  7. package/dist/types/src/components/BaseAddressForm.vue.d.ts +71 -81
  8. package/dist/types/src/components/BaseAlert.vue.d.ts +51 -51
  9. package/dist/types/src/components/BaseApp.vue.d.ts +9 -9
  10. package/dist/types/src/components/BaseAppDialogs.vue.d.ts +14 -14
  11. package/dist/types/src/components/BaseAppNotifications.vue.d.ts +2 -2
  12. package/dist/types/src/components/BaseAutocomplete.vue.d.ts +237 -232
  13. package/dist/types/src/components/BaseAutocompleteDrawer.vue.d.ts +91 -90
  14. package/dist/types/src/components/BaseAutocompleteFetch.vue.d.ts +210 -213
  15. package/dist/types/src/components/BaseAvatar.vue.d.ts +52 -52
  16. package/dist/types/src/components/BaseAvatarGroup.vue.d.ts +43 -43
  17. package/dist/types/src/components/BaseBadge.vue.d.ts +53 -50
  18. package/dist/types/src/components/BaseBelongsTo.vue.d.ts +216 -219
  19. package/dist/types/src/components/BaseBoolean.vue.d.ts +15 -15
  20. package/dist/types/src/components/BaseBreadcrumbs.vue.d.ts +14 -14
  21. package/dist/types/src/components/BaseButton.vue.d.ts +23 -23
  22. package/dist/types/src/components/BaseButtonGroup.vue.d.ts +143 -143
  23. package/dist/types/src/components/BaseCard.vue.d.ts +21 -21
  24. package/dist/types/src/components/BaseCardRow.vue.d.ts +16 -16
  25. package/dist/types/src/components/BaseCharacterCounter.vue.d.ts +49 -49
  26. package/dist/types/src/components/BaseClickOutside.vue.d.ts +26 -26
  27. package/dist/types/src/components/BaseClipboard.vue.d.ts +21 -21
  28. package/dist/types/src/components/BaseColor.vue.d.ts +80 -80
  29. package/dist/types/src/components/BaseContainer.vue.d.ts +34 -34
  30. package/dist/types/src/components/BaseCounter.vue.d.ts +42 -42
  31. package/dist/types/src/components/BaseCropper.vue.d.ts +59 -57
  32. package/dist/types/src/components/BaseCropperModal.vue.d.ts +27 -27
  33. package/dist/types/src/components/BaseDataIterator.vue.d.ts +212 -212
  34. package/dist/types/src/components/BaseDataIteratorSectionBox.vue.d.ts +23 -23
  35. package/dist/types/src/components/BaseDataIteratorSectionButton.vue.d.ts +20 -20
  36. package/dist/types/src/components/BaseDataIteratorSectionColumns.vue.d.ts +637 -665
  37. package/dist/types/src/components/BaseDataIteratorSectionModal.vue.d.ts +29 -29
  38. package/dist/types/src/components/BaseDataTable.vue.d.ts +385 -383
  39. package/dist/types/src/components/BaseDataTableRowAction.vue.d.ts +18 -18
  40. package/dist/types/src/components/BaseDatePicker.vue.d.ts +87 -84
  41. package/dist/types/src/components/BaseDateSelect.vue.d.ts +70 -70
  42. package/dist/types/src/components/BaseDescriptionList.vue.d.ts +9 -9
  43. package/dist/types/src/components/BaseDescriptionListItem.vue.d.ts +10 -10
  44. package/dist/types/src/components/BaseDialog.vue.d.ts +60 -60
  45. package/dist/types/src/components/BaseDisplayRelativeTime.vue.d.ts +68 -68
  46. package/dist/types/src/components/BaseDraggable.vue.d.ts +34 -34
  47. package/dist/types/src/components/BaseDropdown.vue.d.ts +65 -62
  48. package/dist/types/src/components/BaseDropdownAutocomplete.vue.d.ts +132 -132
  49. package/dist/types/src/components/BaseField.vue.d.ts +58 -58
  50. package/dist/types/src/components/BaseFieldI18n.vue.d.ts +93 -96
  51. package/dist/types/src/components/BaseFilePicker.vue.d.ts +62 -59
  52. package/dist/types/src/components/BaseFilePickerCrop.vue.d.ts +60 -57
  53. package/dist/types/src/components/BaseFileUploader.vue.d.ts +112 -85
  54. package/dist/types/src/components/BaseForm.vue.d.ts +134 -131
  55. package/dist/types/src/components/BaseHasMany.vue.d.ts +149 -152
  56. package/dist/types/src/components/BaseHeader.vue.d.ts +83 -80
  57. package/dist/types/src/components/BaseIconPicker.vue.d.ts +41 -38
  58. package/dist/types/src/components/BaseInput.vue.d.ts +169 -169
  59. package/dist/types/src/components/BaseInputError.vue.d.ts +9 -9
  60. package/dist/types/src/components/BaseInputLabel.vue.d.ts +43 -43
  61. package/dist/types/src/components/BaseInputPercent.vue.d.ts +133 -133
  62. package/dist/types/src/components/BaseLayoutNotificationDropdown.vue.d.ts +36 -36
  63. package/dist/types/src/components/BaseLayoutNotificationItem.vue.d.ts +16 -16
  64. package/dist/types/src/components/BaseLayoutNotificationItemContent.vue.d.ts +18 -18
  65. package/dist/types/src/components/BaseLayoutSidebar.vue.d.ts +51 -51
  66. package/dist/types/src/components/BaseLayoutSidebarConfigurable.vue.d.ts +87 -87
  67. package/dist/types/src/components/BaseLayoutStacked.vue.d.ts +23 -23
  68. package/dist/types/src/components/BaseLayoutStackedConfigurable.vue.d.ts +78 -78
  69. package/dist/types/src/components/BaseLoadingCover.vue.d.ts +96 -96
  70. package/dist/types/src/components/BaseMediaGallery.vue.d.ts +64 -64
  71. package/dist/types/src/components/BaseMediaGalleryItem.vue.d.ts +45 -45
  72. package/dist/types/src/components/BaseMediaItem.vue.d.ts +27 -27
  73. package/dist/types/src/components/BaseMediaLibrary.vue.d.ts +190 -172
  74. package/dist/types/src/components/BaseMediaList.vue.d.ts +47 -47
  75. package/dist/types/src/components/BaseMediaListItem.vue.d.ts +47 -47
  76. package/dist/types/src/components/BaseMediaPictures.vue.d.ts +55 -55
  77. package/dist/types/src/components/BaseMediaPicturesItem.vue.d.ts +54 -54
  78. package/dist/types/src/components/BaseMediaPreview.vue.d.ts +36 -36
  79. package/dist/types/src/components/BaseMenu.vue.d.ts +68 -68
  80. package/dist/types/src/components/BaseMenuItem.vue.d.ts +61 -61
  81. package/dist/types/src/components/BaseModalCenter.vue.d.ts +80 -79
  82. package/dist/types/src/components/BaseModalSide.vue.d.ts +62 -61
  83. package/dist/types/src/components/BaseNavbar.vue.d.ts +38 -35
  84. package/dist/types/src/components/BaseNavbarItem.vue.d.ts +26 -26
  85. package/dist/types/src/components/BaseNavbarItemContent.vue.d.ts +60 -60
  86. package/dist/types/src/components/BaseNavbarSideItem.vue.d.ts +44 -44
  87. package/dist/types/src/components/BaseNavbarSideItemContent.vue.d.ts +60 -60
  88. package/dist/types/src/components/BaseNumber.vue.d.ts +125 -125
  89. package/dist/types/src/components/BasePagination.vue.d.ts +35 -35
  90. package/dist/types/src/components/BasePanel.vue.d.ts +31 -31
  91. package/dist/types/src/components/BasePassword.vue.d.ts +62 -62
  92. package/dist/types/src/components/BaseProgressCircle.vue.d.ts +37 -37
  93. package/dist/types/src/components/BaseRadioGroup.vue.d.ts +105 -105
  94. package/dist/types/src/components/BaseReadMore.vue.d.ts +21 -21
  95. package/dist/types/src/components/BaseRichText.vue.d.ts +92 -92
  96. package/dist/types/src/components/BaseSelect.vue.d.ts +98 -97
  97. package/dist/types/src/components/BaseShortcut.vue.d.ts +86 -86
  98. package/dist/types/src/components/BaseSideNavigation.vue.d.ts +36 -33
  99. package/dist/types/src/components/BaseSideNavigationItem.vue.d.ts +46 -43
  100. package/dist/types/src/components/BaseSkeleton.vue.d.ts +31 -30
  101. package/dist/types/src/components/BaseStatistic.vue.d.ts +56 -56
  102. package/dist/types/src/components/BaseStepper.vue.d.ts +16 -16
  103. package/dist/types/src/components/BaseStepperItem.vue.d.ts +51 -51
  104. package/dist/types/src/components/BaseSwitch.vue.d.ts +87 -87
  105. package/dist/types/src/components/BaseSystemAlert.vue.d.ts +52 -52
  106. package/dist/types/src/components/BaseTabItem.vue.d.ts +46 -43
  107. package/dist/types/src/components/BaseTable.vue.d.ts +212 -212
  108. package/dist/types/src/components/BaseTableColumn.vue.d.ts +174 -174
  109. package/dist/types/src/components/BaseTabs.vue.d.ts +36 -33
  110. package/dist/types/src/components/BaseTagAutocomplete.vue.d.ts +209 -204
  111. package/dist/types/src/components/BaseTagAutocompleteFetch.vue.d.ts +141 -144
  112. package/dist/types/src/components/BaseTextarea.vue.d.ts +98 -98
  113. package/dist/types/src/components/BaseTextareaAutoresize.vue.d.ts +108 -98
  114. package/dist/types/src/components/BaseTimeline.vue.d.ts +14 -14
  115. package/dist/types/src/components/BaseTimelineItem.vue.d.ts +14 -14
  116. package/dist/types/src/components/SlotComponent.d.ts +43 -43
  117. package/dist/types/src/components/index.d.ts +93 -93
  118. package/dist/types/src/composables/breakpoints.d.ts +27 -27
  119. package/dist/types/src/composables/clickOutside.d.ts +8 -8
  120. package/dist/types/src/composables/field.d.ts +19 -19
  121. package/dist/types/src/composables/hasOptions.d.ts +7 -7
  122. package/dist/types/src/composables/mediaQuery.d.ts +2 -2
  123. package/dist/types/src/composables/modal.d.ts +6 -6
  124. package/dist/types/src/composables/paginatedData.d.ts +7 -7
  125. package/dist/types/src/constants/MyConstants.d.ts +1 -1
  126. package/dist/types/src/constants/index.d.ts +2 -2
  127. package/dist/types/src/i18n/index.d.ts +1 -1
  128. package/dist/types/src/index.d.ts +220 -220
  129. package/dist/types/src/stores/dialogs.d.ts +9 -9
  130. package/dist/types/src/stores/i18n.d.ts +5 -5
  131. package/dist/types/src/stores/notifications.d.ts +10 -10
  132. package/dist/types/src/stores/systemAlerts.d.ts +9 -9
  133. package/dist/types/src/svg/BaseEmptyState.vue.d.ts +2 -2
  134. package/dist/types/src/svg/BaseSpinnerLarge.vue.d.ts +2 -2
  135. package/dist/types/src/svg/BaseSpinnerSmall.vue.d.ts +2 -2
  136. package/dist/types/src/types/Color.d.ts +9 -9
  137. package/dist/types/src/types/Country.d.ts +4 -4
  138. package/dist/types/src/types/ImagePickerResult.d.ts +5 -5
  139. package/dist/types/src/types/Media.d.ts +9 -9
  140. package/dist/types/src/types/Notification.d.ts +8 -8
  141. package/dist/types/src/types/Region.d.ts +5 -5
  142. package/dist/types/src/types/Status.d.ts +5 -5
  143. package/dist/types/src/types/StepperItem.d.ts +7 -7
  144. package/dist/types/src/types/TimelineItem.d.ts +8 -8
  145. package/dist/types/src/types/UploadedFile.d.ts +10 -10
  146. package/dist/types/src/types/User.d.ts +6 -6
  147. package/dist/types/src/types/index.d.ts +218 -218
  148. package/dist/types/src/utils/blob.d.ts +3 -3
  149. package/dist/types/src/utils/colors.d.ts +13 -13
  150. package/dist/types/src/utils/cropper/avatar.d.ts +5 -5
  151. package/dist/types/src/utils/cropper/cover.d.ts +5 -5
  152. package/dist/types/src/utils/cropper/presetInterface.d.ts +7 -7
  153. package/dist/types/src/utils/cropper/presets.d.ts +6 -6
  154. package/dist/types/src/utils/fileSizeFormat.d.ts +1 -1
  155. package/dist/types/src/utils/fileValidations.d.ts +2 -2
  156. package/dist/types/src/utils/index.d.ts +6 -6
  157. package/dist/types/src/utils/resizeImageFromURI.d.ts +1 -1
  158. package/dist/types/src/utils/scrollPreventer.d.ts +3 -3
  159. package/dist/types/src/utils/toHumanList.d.ts +1 -1
  160. package/package.json +138 -139
  161. package/src/assets/form.css +6 -6
  162. package/src/assets/main.css +35 -35
  163. package/src/assets/tailwind.css +2 -2
  164. package/src/components/BaseActionItem.vue +63 -63
  165. package/src/components/BaseActionItemButton.vue +75 -75
  166. package/src/components/BaseAddressForm.stories.js +103 -103
  167. package/src/components/BaseAddressForm.vue +353 -353
  168. package/src/components/BaseAlert.stories.js +52 -52
  169. package/src/components/BaseAlert.vue +152 -152
  170. package/src/components/BaseApp.vue +16 -16
  171. package/src/components/BaseAppDialogs.vue +124 -124
  172. package/src/components/BaseAppNotifications.vue +73 -73
  173. package/src/components/BaseAutocomplete.stories.js +236 -236
  174. package/src/components/BaseAutocomplete.vue +514 -514
  175. package/src/components/BaseAutocompleteDrawer.vue +354 -354
  176. package/src/components/BaseAutocompleteFetch.stories.js +224 -224
  177. package/src/components/BaseAutocompleteFetch.vue +277 -277
  178. package/src/components/BaseAvatar.stories.js +39 -39
  179. package/src/components/BaseAvatar.vue +120 -120
  180. package/src/components/BaseAvatarGroup.stories.js +71 -71
  181. package/src/components/BaseAvatarGroup.vue +148 -148
  182. package/src/components/BaseBadge.stories.js +124 -124
  183. package/src/components/BaseBadge.vue +79 -79
  184. package/src/components/BaseBelongsTo.stories.js +223 -223
  185. package/src/components/BaseBelongsTo.vue +184 -184
  186. package/src/components/BaseBoolean.stories.js +35 -35
  187. package/src/components/BaseBoolean.vue +26 -26
  188. package/src/components/BaseBreadcrumbs.stories.js +45 -45
  189. package/src/components/BaseBreadcrumbs.vue +98 -98
  190. package/src/components/BaseButton.stories.js +88 -88
  191. package/src/components/BaseButton.vue +39 -39
  192. package/src/components/BaseButtonGroup.stories.js +86 -85
  193. package/src/components/BaseButtonGroup.vue +147 -147
  194. package/src/components/BaseCard.stories.js +61 -61
  195. package/src/components/BaseCard.vue +49 -49
  196. package/src/components/BaseCardRow.vue +34 -34
  197. package/src/components/BaseCharacterCounter.stories.js +30 -30
  198. package/src/components/BaseCharacterCounter.vue +61 -61
  199. package/src/components/BaseClickOutside.vue +37 -37
  200. package/src/components/BaseClipboard.stories.js +31 -31
  201. package/src/components/BaseClipboard.vue +96 -96
  202. package/src/components/BaseColor.stories.js +46 -46
  203. package/src/components/BaseColor.vue +151 -151
  204. package/src/components/BaseContainer.stories.js +34 -34
  205. package/src/components/BaseContainer.vue +50 -50
  206. package/src/components/BaseCounter.stories.js +47 -47
  207. package/src/components/BaseCounter.vue +82 -82
  208. package/src/components/BaseCropper.stories.js +113 -113
  209. package/src/components/BaseCropper.vue +446 -446
  210. package/src/components/BaseCropperModal.stories.js +54 -54
  211. package/src/components/BaseCropperModal.vue +140 -140
  212. package/src/components/BaseDataIterator.stories.js +197 -197
  213. package/src/components/BaseDataIterator.vue +784 -777
  214. package/src/components/BaseDataIteratorSectionBox.vue +33 -33
  215. package/src/components/BaseDataIteratorSectionButton.vue +40 -40
  216. package/src/components/BaseDataIteratorSectionColumns.vue +67 -67
  217. package/src/components/BaseDataIteratorSectionModal.vue +41 -41
  218. package/src/components/BaseDataTable.stories.js +341 -341
  219. package/src/components/BaseDataTable.vue +724 -724
  220. package/src/components/BaseDataTableRowAction.vue +28 -28
  221. package/src/components/BaseDatePicker.stories.js +130 -130
  222. package/src/components/BaseDatePicker.vue +374 -374
  223. package/src/components/BaseDateSelect.stories.js +47 -47
  224. package/src/components/BaseDateSelect.vue +209 -209
  225. package/src/components/BaseDescriptionList.stories.js +35 -35
  226. package/src/components/BaseDescriptionList.vue +13 -13
  227. package/src/components/BaseDescriptionListItem.vue +47 -47
  228. package/src/components/BaseDialog.stories.js +51 -51
  229. package/src/components/BaseDialog.vue +119 -119
  230. package/src/components/BaseDisplayRelativeTime.stories.js +59 -59
  231. package/src/components/BaseDisplayRelativeTime.vue +120 -120
  232. package/src/components/BaseDraggable.vue +71 -71
  233. package/src/components/BaseDropdown.stories.js +210 -210
  234. package/src/components/BaseDropdown.vue +269 -269
  235. package/src/components/BaseDropdownAutocomplete.stories.js +187 -187
  236. package/src/components/BaseDropdownAutocomplete.vue +232 -230
  237. package/src/components/BaseField.vue +109 -109
  238. package/src/components/BaseFieldI18n.stories.js +38 -38
  239. package/src/components/BaseFieldI18n.vue +162 -162
  240. package/src/components/BaseFilePicker.stories.js +78 -78
  241. package/src/components/BaseFilePicker.vue +132 -132
  242. package/src/components/BaseFilePickerCrop.stories.js +134 -134
  243. package/src/components/BaseFilePickerCrop.vue +127 -127
  244. package/src/components/BaseFileUploader.stories.js +84 -84
  245. package/src/components/BaseFileUploader.vue +163 -163
  246. package/src/components/BaseForm.stories.js +48 -48
  247. package/src/components/BaseForm.vue +324 -323
  248. package/src/components/BaseHasMany.stories.js +189 -189
  249. package/src/components/BaseHasMany.vue +125 -125
  250. package/src/components/BaseHeader.stories.js +127 -127
  251. package/src/components/BaseHeader.vue +188 -188
  252. package/src/components/BaseIconPicker.stories.js +22 -22
  253. package/src/components/BaseIconPicker.vue +215 -215
  254. package/src/components/BaseInput.stories.js +151 -151
  255. package/src/components/BaseInput.vue +266 -266
  256. package/src/components/BaseInputError.vue +7 -7
  257. package/src/components/BaseInputLabel.stories.js +36 -36
  258. package/src/components/BaseInputLabel.vue +72 -72
  259. package/src/components/BaseInputPercent.stories.js +50 -50
  260. package/src/components/BaseInputPercent.vue +123 -123
  261. package/src/components/BaseLayoutNotificationDropdown.vue +144 -144
  262. package/src/components/BaseLayoutNotificationItem.vue +43 -43
  263. package/src/components/BaseLayoutNotificationItemContent.vue +27 -27
  264. package/src/components/BaseLayoutSidebar.vue +219 -219
  265. package/src/components/BaseLayoutSidebarConfigurable.stories.js +166 -166
  266. package/src/components/BaseLayoutSidebarConfigurable.vue +167 -167
  267. package/src/components/BaseLayoutStacked.vue +52 -52
  268. package/src/components/BaseLayoutStackedConfigurable.stories.js +109 -109
  269. package/src/components/BaseLayoutStackedConfigurable.vue +141 -141
  270. package/src/components/BaseLoadingCover.stories.js +55 -55
  271. package/src/components/BaseLoadingCover.vue +101 -94
  272. package/src/components/BaseMediaGallery.vue +93 -93
  273. package/src/components/BaseMediaGalleryItem.vue +92 -92
  274. package/src/components/BaseMediaItem.stories.js +41 -41
  275. package/src/components/BaseMediaItem.vue +71 -71
  276. package/src/components/BaseMediaLibrary.stories.js +262 -262
  277. package/src/components/BaseMediaLibrary.vue +313 -313
  278. package/src/components/BaseMediaList.vue +68 -68
  279. package/src/components/BaseMediaListItem.vue +172 -172
  280. package/src/components/BaseMediaPictures.vue +64 -64
  281. package/src/components/BaseMediaPicturesItem.vue +94 -94
  282. package/src/components/BaseMediaPreview.stories.js +72 -72
  283. package/src/components/BaseMediaPreview.vue +106 -106
  284. package/src/components/BaseMenu.stories.js +125 -125
  285. package/src/components/BaseMenu.vue +137 -129
  286. package/src/components/BaseMenuItem.vue +107 -107
  287. package/src/components/BaseModalCenter.stories.js +68 -68
  288. package/src/components/BaseModalCenter.vue +131 -125
  289. package/src/components/BaseModalSide.stories.js +55 -55
  290. package/src/components/BaseModalSide.vue +122 -116
  291. package/src/components/BaseNavbar.stories.js +151 -151
  292. package/src/components/BaseNavbar.vue +91 -91
  293. package/src/components/BaseNavbarItem.vue +49 -49
  294. package/src/components/BaseNavbarItemContent.vue +86 -86
  295. package/src/components/BaseNavbarSideItem.vue +111 -111
  296. package/src/components/BaseNavbarSideItemContent.vue +104 -104
  297. package/src/components/BaseNumber.stories.js +66 -66
  298. package/src/components/BaseNumber.vue +366 -366
  299. package/src/components/BasePagination.stories.js +35 -35
  300. package/src/components/BasePagination.vue +266 -266
  301. package/src/components/BasePanel.stories.js +56 -56
  302. package/src/components/BasePanel.vue +39 -39
  303. package/src/components/BasePassword.stories.js +41 -41
  304. package/src/components/BasePassword.vue +88 -88
  305. package/src/components/BaseProgressCircle.stories.js +27 -27
  306. package/src/components/BaseProgressCircle.vue +77 -77
  307. package/src/components/BaseRadioGroup.stories.js +88 -88
  308. package/src/components/BaseRadioGroup.vue +122 -122
  309. package/src/components/BaseReadMore.stories.js +30 -30
  310. package/src/components/BaseReadMore.vue +73 -73
  311. package/src/components/BaseRichText.stories.js +102 -102
  312. package/src/components/BaseRichText.vue +183 -183
  313. package/src/components/BaseSelect.stories.js +118 -118
  314. package/src/components/BaseSelect.vue +220 -220
  315. package/src/components/BaseShortcut.stories.js +102 -102
  316. package/src/components/BaseShortcut.vue +105 -105
  317. package/src/components/BaseSideNavigation.stories.js +80 -80
  318. package/src/components/BaseSideNavigation.vue +29 -29
  319. package/src/components/BaseSideNavigationItem.vue +92 -92
  320. package/src/components/BaseSkeleton.stories.js +36 -36
  321. package/src/components/BaseSkeleton.vue +40 -24
  322. package/src/components/BaseStatistic.stories.js +51 -51
  323. package/src/components/BaseStatistic.vue +98 -98
  324. package/src/components/BaseStepper.stories.js +94 -94
  325. package/src/components/BaseStepper.vue +69 -69
  326. package/src/components/BaseStepperItem.stories.js +65 -65
  327. package/src/components/BaseStepperItem.vue +149 -149
  328. package/src/components/BaseSwitch.stories.js +131 -131
  329. package/src/components/BaseSwitch.vue +209 -209
  330. package/src/components/BaseSystemAlert.stories.js +63 -63
  331. package/src/components/BaseSystemAlert.vue +86 -86
  332. package/src/components/BaseTabItem.vue +93 -93
  333. package/src/components/BaseTable.vue +880 -880
  334. package/src/components/BaseTableColumn.vue +124 -124
  335. package/src/components/BaseTabs.stories.js +85 -85
  336. package/src/components/BaseTabs.vue +73 -73
  337. package/src/components/BaseTagAutocomplete.stories.js +258 -258
  338. package/src/components/BaseTagAutocomplete.vue +429 -428
  339. package/src/components/BaseTagAutocompleteFetch.stories.js +185 -185
  340. package/src/components/BaseTagAutocompleteFetch.vue +206 -206
  341. package/src/components/BaseTextarea.stories.js +43 -43
  342. package/src/components/BaseTextarea.vue +87 -87
  343. package/src/components/BaseTextareaAutoresize.stories.js +87 -58
  344. package/src/components/BaseTextareaAutoresize.vue +146 -140
  345. package/src/components/BaseTimeline.stories.js +53 -53
  346. package/src/components/BaseTimeline.vue +29 -29
  347. package/src/components/BaseTimelineItem.stories.js +78 -78
  348. package/src/components/BaseTimelineItem.vue +79 -79
  349. package/src/components/SlotComponent.ts +37 -37
  350. package/src/components/index.ts +188 -188
  351. package/src/composables/breakpoints.ts +94 -94
  352. package/src/composables/clickOutside.ts +80 -80
  353. package/src/composables/field.ts +117 -117
  354. package/src/composables/hasOptions.ts +68 -68
  355. package/src/composables/mediaQuery.ts +42 -42
  356. package/src/composables/modal.ts +73 -73
  357. package/src/composables/paginatedData.ts +65 -65
  358. package/src/constants/MyConstants.ts +1 -1
  359. package/src/constants/index.ts +5 -5
  360. package/src/env.d.ts +15 -15
  361. package/src/i18n/index.ts +60 -60
  362. package/src/index.ts +111 -111
  363. package/src/lang/en.json +87 -87
  364. package/src/lang/fr.json +87 -87
  365. package/src/stores/dialogs.ts +45 -45
  366. package/src/stores/i18n.ts +14 -14
  367. package/src/stores/notifications.ts +47 -47
  368. package/src/stores/systemAlerts.ts +33 -33
  369. package/src/svg/BaseEmptyState.vue +34 -34
  370. package/src/svg/BaseSpinnerLarge.vue +47 -47
  371. package/src/svg/BaseSpinnerSmall.vue +9 -9
  372. package/src/types/Color.ts +9 -9
  373. package/src/types/Country.ts +4 -4
  374. package/src/types/ImagePickerResult.ts +5 -5
  375. package/src/types/Media.ts +10 -10
  376. package/src/types/Notification.ts +10 -10
  377. package/src/types/Region.ts +5 -5
  378. package/src/types/Status.ts +5 -5
  379. package/src/types/StepperItem.ts +8 -8
  380. package/src/types/TimelineItem.ts +8 -8
  381. package/src/types/UploadedFile.ts +11 -11
  382. package/src/types/User.ts +7 -7
  383. package/src/types/index.ts +267 -267
  384. package/src/utils/blob.ts +30 -30
  385. package/src/utils/colors.ts +200 -200
  386. package/src/utils/cropper/avatar.ts +33 -33
  387. package/src/utils/cropper/cover.ts +41 -41
  388. package/src/utils/cropper/presetInterface.ts +16 -16
  389. package/src/utils/cropper/presets.ts +7 -7
  390. package/src/utils/fileSizeFormat.ts +15 -15
  391. package/src/utils/fileValidations.ts +26 -26
  392. package/src/utils/index.ts +16 -16
  393. package/src/utils/resizeImageFromURI.ts +118 -118
  394. package/src/utils/scrollPreventer.ts +11 -11
  395. package/src/utils/toHumanList.ts +20 -20
@@ -1,7 +1,7 @@
1
- import { CropperConfig } from '@/types';
2
- export declare abstract class PresetInterface {
3
- protected config: CropperConfig | null;
4
- protected presetOptions: Record<string, any> | null;
5
- constructor(config?: CropperConfig | null, presetOptions?: Record<string, any> | null);
6
- abstract handle(): CropperConfig;
7
- }
1
+ import { CropperConfig } from '@/types';
2
+ export declare abstract class PresetInterface {
3
+ protected config: CropperConfig | null;
4
+ protected presetOptions: Record<string, any> | null;
5
+ constructor(config?: CropperConfig | null, presetOptions?: Record<string, any> | null);
6
+ abstract handle(): CropperConfig;
7
+ }
@@ -1,6 +1,6 @@
1
- import { AvatarPreset } from './avatar';
2
- import { CoverPreset } from './cover';
3
- export declare const presets: {
4
- avatar: typeof AvatarPreset;
5
- cover: typeof CoverPreset;
6
- };
1
+ import { AvatarPreset } from './avatar';
2
+ import { CoverPreset } from './cover';
3
+ export declare const presets: {
4
+ avatar: typeof AvatarPreset;
5
+ cover: typeof CoverPreset;
6
+ };
@@ -1 +1 @@
1
- export default function (size: number): string;
1
+ export default function (size: number): string;
@@ -1,2 +1,2 @@
1
- export declare function maxSize(blob: Blob, maxSize: number): boolean;
2
- export declare function validExtension(blob: Blob | File, extensions?: string[] | undefined): boolean;
1
+ export declare function maxSize(blob: Blob, maxSize: number): boolean;
2
+ export declare function validExtension(blob: Blob | File, extensions?: string[] | undefined): boolean;
@@ -1,6 +1,6 @@
1
- import toHumanList from './toHumanList';
2
- import fileSizeFormat from './fileSizeFormat';
3
- import resizeImageFromURI from './resizeImageFromURI';
4
- import { disableScroll, enableScroll } from './scrollPreventer';
5
- import { blobToBase64, validateBase64, base64ToBlob } from './blob';
6
- export { toHumanList, fileSizeFormat, disableScroll, enableScroll, resizeImageFromURI, blobToBase64, validateBase64, base64ToBlob, };
1
+ import toHumanList from './toHumanList';
2
+ import fileSizeFormat from './fileSizeFormat';
3
+ import resizeImageFromURI from './resizeImageFromURI';
4
+ import { disableScroll, enableScroll } from './scrollPreventer';
5
+ import { blobToBase64, validateBase64, base64ToBlob } from './blob';
6
+ export { toHumanList, fileSizeFormat, disableScroll, enableScroll, resizeImageFromURI, blobToBase64, validateBase64, base64ToBlob, };
@@ -1 +1 @@
1
- export default function resizeImageFromURI(source: string, height: number, width: number): Promise<string>;
1
+ export default function resizeImageFromURI(source: string, height: number, width: number): Promise<string>;
@@ -1,3 +1,3 @@
1
- declare function disableScroll(): void;
2
- declare function enableScroll(): void;
3
- export { disableScroll, enableScroll };
1
+ declare function disableScroll(): void;
2
+ declare function enableScroll(): void;
3
+ export { disableScroll, enableScroll };
@@ -1 +1 @@
1
- export default function (list: string[], conjunction?: string): string;
1
+ export default function (list: string[], conjunction?: string): string;
package/package.json CHANGED
@@ -1,139 +1,138 @@
1
- {
2
- "name": "sprintify-ui",
3
- "version": "0.1.17",
4
- "scripts": {
5
- "build": "rimraf dist && vue-tsc && vite build",
6
- "build-fast": "rimraf dist && vite build",
7
- "docs:dev": "vitepress dev docs",
8
- "docs:build": "vitepress build docs",
9
- "docs:serve": "vitepress serve docs",
10
- "storybook": "start-storybook -p 6006",
11
- "build-storybook": "build-storybook",
12
- "prepack": "npm run build",
13
- "prepare": "husky install && relative-deps",
14
- "release": "standard-version",
15
- "commit": "cz"
16
- },
17
- "peerDependencies": {
18
- "@tailwindcss/aspect-ratio": "^0.4.2",
19
- "@tailwindcss/forms": "^0.5.3",
20
- "@tailwindcss/line-clamp": "^0.4.2",
21
- "@tailwindcss/typography": "^0.5.8",
22
- "@vueup/vue-quill": "^1.0.0",
23
- "@vueuse/core": "^10.0.0",
24
- "axios": "^0.26.1",
25
- "croppie": "^2.6.5",
26
- "flatpickr": "^4.6.13",
27
- "humanize-duration": "^3.0.0",
28
- "lodash": "^4.17.21",
29
- "luxon": "^3.0.0",
30
- "maska": "^2.1.3",
31
- "microtip": "^0.2.2",
32
- "object-to-formdata": "^4.4.2",
33
- "pinia": "^2.0.0",
34
- "qs": "^6.0.0",
35
- "sortablejs": "^1.15.0",
36
- "tailwindcss": "^3.0.0",
37
- "vue": "^3.0.0",
38
- "vue-router": "^4.0.0"
39
- },
40
- "dependencies": {
41
- "@headlessui/vue": "^1.7.12",
42
- "color2k": "^2.0.2"
43
- },
44
- "devDependencies": {
45
- "@babel/core": "^7.20.12",
46
- "@commitlint/cli": "^17.4.4",
47
- "@commitlint/config-conventional": "^17.4.4",
48
- "@iconify/vue": "^4.1.0",
49
- "@storybook/addon-actions": "^6.5.16",
50
- "@storybook/addon-essentials": "^6.5.16",
51
- "@storybook/addon-interactions": "^6.5.16",
52
- "@storybook/addon-links": "^6.5.16",
53
- "@storybook/builder-vite": "^0.4.0",
54
- "@storybook/testing-library": "^0.0.13",
55
- "@storybook/vue3": "^6.5.16",
56
- "@tailwindcss/aspect-ratio": "^0.4.2",
57
- "@tailwindcss/forms": "^0.5.3",
58
- "@tailwindcss/line-clamp": "^0.4.2",
59
- "@tailwindcss/typography": "^0.5.9",
60
- "@types/croppie": "^2.6.1",
61
- "@types/google.maps": "^3.51.1",
62
- "@types/humanize-duration": "^3.27.1",
63
- "@types/luxon": "^3.2.0",
64
- "@types/object-hash": "^2.2.1",
65
- "@types/qs": "^6.9.7",
66
- "@types/scroll-lock": "^2.1.0",
67
- "@types/sortablejs": "^1.15.1",
68
- "@typescript-eslint/eslint-plugin": "^5.51.0",
69
- "@typescript-eslint/parser": "^5.51.0",
70
- "@vitejs/plugin-vue": "^4.0.0",
71
- "@vue/eslint-config-typescript": "^11.0.2",
72
- "@vueup/vue-quill": "^1.1.0",
73
- "@vueuse/core": "^10.0.2",
74
- "autoprefixer": "^10.4.13",
75
- "axios": "^0.26.1",
76
- "babel-loader": "^8.3.0",
77
- "croppie": "^2.6.5",
78
- "cz-conventional-changelog": "^3.3.0",
79
- "eslint": "^8.33.0",
80
- "eslint-config-prettier": "^8.6.0",
81
- "eslint-plugin-import": "^2.27.5",
82
- "eslint-plugin-storybook": "^0.6.10",
83
- "eslint-plugin-vue": "^9.9.0",
84
- "eslint-plugin-vue-scoped-css": "^2.4.0",
85
- "flatpickr": "^4.6.13",
86
- "humanize-duration": "^3.28.0",
87
- "husky": "^8.0.3",
88
- "lodash": "^4.17.21",
89
- "luxon": "^3.2.1",
90
- "maska": "^2.1.6",
91
- "microtip": "^0.2.2",
92
- "object-hash": "^3.0.0",
93
- "object-to-formdata": "^4.4.2",
94
- "pinia": "^2.0.30",
95
- "postcss": "^8.4.21",
96
- "postcss-import": "^15.1.0",
97
- "prettier": "^2.8.4",
98
- "prettier-plugin-tailwindcss": "^0.2.2",
99
- "qs": "^6.11.0",
100
- "relative-deps": "^1.0.7",
101
- "rimraf": "^3.0.2",
102
- "rollup-plugin-analyzer": "^4.0.0",
103
- "scroll-lock": "^2.1.5",
104
- "sortablejs": "^1.15.0",
105
- "standard-version": "^9.5.0",
106
- "storybook": "^6.5.16",
107
- "storybook-addon-mock": "^3.2.0",
108
- "tailwindcss": "^3.2.6",
109
- "typescript": "^4.9.5",
110
- "unplugin-auto-import": "^0.12.2",
111
- "vite": "^4.1.1",
112
- "vitepress": "^0.21.6",
113
- "vue": "^3.2.47",
114
- "vue-i18n": "^9.2.2",
115
- "vue-loader": "^17.0.1",
116
- "vue-router": "^4.1.6",
117
- "vue-tsc": "^1.0.24"
118
- },
119
- "files": [
120
- "src",
121
- "dist"
122
- ],
123
- "types": "./dist/types/src/index.d.ts",
124
- "module": "./dist/sprintify-ui.es.js",
125
- "exports": {
126
- ".": {
127
- "import": "./dist/sprintify-ui.es.js"
128
- },
129
- "./dist/style.css": "./dist/style.css",
130
- "./tailwindcss": "./dist/tailwindcss/index.js",
131
- "./dist/types/src/types": "./dist/types/src/types/index.ts"
132
- },
133
- "config": {
134
- "commitizen": {
135
- "path": "cz-conventional-changelog"
136
- }
137
- },
138
- "relativeDependencies": {}
139
- }
1
+ {
2
+ "name": "sprintify-ui",
3
+ "version": "0.2.0",
4
+ "scripts": {
5
+ "build": "rimraf dist && vue-tsc && vite build",
6
+ "build-fast": "rimraf dist && vite build",
7
+ "docs:dev": "vitepress dev docs",
8
+ "docs:build": "vitepress build docs",
9
+ "docs:serve": "vitepress serve docs",
10
+ "storybook": "start-storybook -p 6006",
11
+ "build-storybook": "build-storybook",
12
+ "prepack": "npm run build",
13
+ "prepare": "husky install && relative-deps",
14
+ "release": "standard-version",
15
+ "commit": "cz"
16
+ },
17
+ "peerDependencies": {
18
+ "@tailwindcss/aspect-ratio": "^0.4.2",
19
+ "@tailwindcss/forms": "^0.5.3",
20
+ "@tailwindcss/typography": "^0.5.8",
21
+ "@vueup/vue-quill": "^1.0.0",
22
+ "@vueuse/core": "^10.0.0",
23
+ "axios": "^0.26.1",
24
+ "croppie": "^2.6.5",
25
+ "flatpickr": "^4.6.13",
26
+ "humanize-duration": "^3.0.0",
27
+ "lodash": "^4.17.21",
28
+ "luxon": "^3.0.0",
29
+ "maska": "^2.1.3",
30
+ "microtip": "^0.2.2",
31
+ "object-to-formdata": "^4.4.2",
32
+ "pinia": "^2.0.0",
33
+ "qs": "^6.0.0",
34
+ "sortablejs": "^1.15.0",
35
+ "tailwindcss": "^3.3.0",
36
+ "vue": "^3.0.0",
37
+ "vue-router": "^4.0.0"
38
+ },
39
+ "dependencies": {
40
+ "@headlessui/vue": "^1.7.12",
41
+ "color2k": "^2.0.2",
42
+ "tailwind-merge": "^1.12.0"
43
+ },
44
+ "devDependencies": {
45
+ "@babel/core": "^7.20.12",
46
+ "@commitlint/cli": "^17.4.4",
47
+ "@commitlint/config-conventional": "^17.4.4",
48
+ "@iconify/vue": "^4.1.0",
49
+ "@storybook/addon-actions": "^6.5.16",
50
+ "@storybook/addon-essentials": "^6.5.16",
51
+ "@storybook/addon-interactions": "^6.5.16",
52
+ "@storybook/addon-links": "^6.5.16",
53
+ "@storybook/builder-vite": "^0.4.0",
54
+ "@storybook/testing-library": "^0.0.13",
55
+ "@storybook/vue3": "^6.5.16",
56
+ "@tailwindcss/aspect-ratio": "^0.4.2",
57
+ "@tailwindcss/forms": "^0.5.3",
58
+ "@tailwindcss/typography": "^0.5.9",
59
+ "@types/croppie": "^2.6.1",
60
+ "@types/google.maps": "^3.51.1",
61
+ "@types/humanize-duration": "^3.27.1",
62
+ "@types/luxon": "^3.2.0",
63
+ "@types/object-hash": "^2.2.1",
64
+ "@types/qs": "^6.9.7",
65
+ "@types/scroll-lock": "^2.1.0",
66
+ "@types/sortablejs": "^1.15.1",
67
+ "@typescript-eslint/eslint-plugin": "^5.51.0",
68
+ "@typescript-eslint/parser": "^5.51.0",
69
+ "@vitejs/plugin-vue": "^4.0.0",
70
+ "@vue/eslint-config-typescript": "^11.0.2",
71
+ "@vueup/vue-quill": "^1.1.0",
72
+ "@vueuse/core": "^10.0.2",
73
+ "autoprefixer": "^10.4.13",
74
+ "axios": "^0.26.1",
75
+ "babel-loader": "^8.3.0",
76
+ "croppie": "^2.6.5",
77
+ "cz-conventional-changelog": "^3.3.0",
78
+ "eslint": "^8.33.0",
79
+ "eslint-config-prettier": "^8.6.0",
80
+ "eslint-plugin-import": "^2.27.5",
81
+ "eslint-plugin-storybook": "^0.6.10",
82
+ "eslint-plugin-vue": "^9.9.0",
83
+ "eslint-plugin-vue-scoped-css": "^2.4.0",
84
+ "flatpickr": "^4.6.13",
85
+ "humanize-duration": "^3.28.0",
86
+ "husky": "^8.0.3",
87
+ "lodash": "^4.17.21",
88
+ "luxon": "^3.2.1",
89
+ "maska": "^2.1.6",
90
+ "microtip": "^0.2.2",
91
+ "object-hash": "^3.0.0",
92
+ "object-to-formdata": "^4.4.2",
93
+ "pinia": "^2.0.30",
94
+ "postcss": "^8.4.21",
95
+ "postcss-import": "^15.1.0",
96
+ "prettier": "^2.8.4",
97
+ "prettier-plugin-tailwindcss": "^0.2.2",
98
+ "qs": "^6.11.0",
99
+ "relative-deps": "^1.0.7",
100
+ "rimraf": "^3.0.2",
101
+ "rollup-plugin-analyzer": "^4.0.0",
102
+ "scroll-lock": "^2.1.5",
103
+ "sortablejs": "^1.15.0",
104
+ "standard-version": "^9.5.0",
105
+ "storybook": "^6.5.16",
106
+ "storybook-addon-mock": "^3.2.0",
107
+ "tailwindcss": "^3.2.6",
108
+ "typescript": "^4.9.5",
109
+ "unplugin-auto-import": "^0.12.2",
110
+ "vite": "^4.1.1",
111
+ "vitepress": "^0.21.6",
112
+ "vue": "^3.2.47",
113
+ "vue-i18n": "^9.2.2",
114
+ "vue-loader": "^17.0.1",
115
+ "vue-router": "^4.1.6",
116
+ "vue-tsc": "^1.0.24"
117
+ },
118
+ "files": [
119
+ "src",
120
+ "dist"
121
+ ],
122
+ "types": "./dist/types/src/index.d.ts",
123
+ "module": "./dist/sprintify-ui.es.js",
124
+ "exports": {
125
+ ".": {
126
+ "import": "./dist/sprintify-ui.es.js"
127
+ },
128
+ "./dist/style.css": "./dist/style.css",
129
+ "./tailwindcss": "./dist/tailwindcss/index.js",
130
+ "./dist/types/src/types": "./dist/types/src/types/index.ts"
131
+ },
132
+ "config": {
133
+ "commitizen": {
134
+ "path": "cz-conventional-changelog"
135
+ }
136
+ },
137
+ "relativeDependencies": {}
138
+ }
@@ -1,6 +1,6 @@
1
- /** Placeholder color */
2
-
3
- input,
4
- textarea {
5
- @apply placeholder-slate-400;
6
- }
1
+ /** Placeholder color */
2
+
3
+ input,
4
+ textarea {
5
+ @apply placeholder-slate-400;
6
+ }
@@ -1,35 +1,35 @@
1
- @import 'microtip/microtip.css';
2
- @import './form.css';
3
-
4
- [aria-label][role~='tooltip']::after {
5
- white-space: pre-line;
6
- }
7
-
8
- .btn-group {
9
- display: flex;
10
- align-items: center;
11
- justify-content: center;
12
- margin: 0 -0.5rem;
13
-
14
- & > *:not(:first-child) .btn,
15
- & > .btn:not(:first-child) {
16
- margin-left: -1px;
17
- }
18
-
19
- & > *:first-child:not(:last-child) .btn,
20
- & > .btn:first-child:not(:last-child) {
21
- border-bottom-right-radius: 0;
22
- border-top-right-radius: 0;
23
- }
24
-
25
- & > *:last-child:not(:first-child) .btn,
26
- & > .btn:last-child:not(:first-child) {
27
- border-bottom-left-radius: 0;
28
- border-top-left-radius: 0;
29
- }
30
-
31
- & > *:not(:first-child):not(:last-child) .btn,
32
- & > .btn:not(:first-child):not(:last-child) {
33
- border-radius: 0;
34
- }
35
- }
1
+ @import 'microtip/microtip.css';
2
+ @import './form.css';
3
+
4
+ [aria-label][role~='tooltip']::after {
5
+ white-space: pre-line;
6
+ }
7
+
8
+ .btn-group {
9
+ display: flex;
10
+ align-items: center;
11
+ justify-content: center;
12
+ margin: 0 -0.5rem;
13
+
14
+ & > *:not(:first-child) .btn,
15
+ & > .btn:not(:first-child) {
16
+ margin-left: -1px;
17
+ }
18
+
19
+ & > *:first-child:not(:last-child) .btn,
20
+ & > .btn:first-child:not(:last-child) {
21
+ border-bottom-right-radius: 0;
22
+ border-top-right-radius: 0;
23
+ }
24
+
25
+ & > *:last-child:not(:first-child) .btn,
26
+ & > .btn:last-child:not(:first-child) {
27
+ border-bottom-left-radius: 0;
28
+ border-top-left-radius: 0;
29
+ }
30
+
31
+ & > *:not(:first-child):not(:last-child) .btn,
32
+ & > .btn:not(:first-child):not(:last-child) {
33
+ border-radius: 0;
34
+ }
35
+ }
@@ -1,3 +1,3 @@
1
- @tailwind base;
2
- @tailwind components;
1
+ @tailwind base;
2
+ @tailwind components;
3
3
  @tailwind utilities;
@@ -1,63 +1,63 @@
1
- <template>
2
- <RouterLink
3
- v-if="to"
4
- v-slot="{ isActive, href: slotHref, navigate }"
5
- custom
6
- :to="to"
7
- >
8
- <a
9
- :active="isActive"
10
- :href="slotHref"
11
- :class="props.class"
12
- :aria-current="isActive ? 'page' : undefined"
13
- @click.prevent="onClick(navigate)"
14
- >
15
- <slot :active="isActive"> </slot>
16
- </a>
17
- </RouterLink>
18
- <button
19
- v-else-if="action"
20
- type="button"
21
- class="text-left"
22
- :class="props.class"
23
- @click="onClick(action)"
24
- >
25
- <slot :active="false"> </slot>
26
- </button>
27
- <a v-else-if="href" :href="href" :class="props.class" @click="onClick()">
28
- <slot :active="false"> </slot>
29
- </a>
30
- </template>
31
-
32
- <script lang="ts">
33
- export default {
34
- inheritAttrs: false,
35
- };
36
- </script>
37
-
38
- <script setup lang="ts">
39
- import { RouteLocationRaw } from 'vue-router';
40
-
41
- const props = defineProps<{
42
- to?: RouteLocationRaw;
43
- href?: string;
44
- action?: (() => Promise<void>) | (() => void);
45
- class?: string | string[] | null;
46
- }>();
47
-
48
- const closeMenu = inject('closeMenu', () => {
49
- return;
50
- }) as () => void;
51
-
52
- const emit = defineEmits(['click']);
53
-
54
- type asyncFunc = () => Promise<void>;
55
-
56
- async function onClick(func: asyncFunc | null = null) {
57
- if (func) {
58
- await func();
59
- }
60
- emit('click');
61
- closeMenu();
62
- }
63
- </script>
1
+ <template>
2
+ <RouterLink
3
+ v-if="to"
4
+ v-slot="{ isActive, href: slotHref, navigate }"
5
+ custom
6
+ :to="to"
7
+ >
8
+ <a
9
+ :active="isActive"
10
+ :href="slotHref"
11
+ :class="props.class"
12
+ :aria-current="isActive ? 'page' : undefined"
13
+ @click.prevent="onClick(navigate)"
14
+ >
15
+ <slot :active="isActive"> </slot>
16
+ </a>
17
+ </RouterLink>
18
+ <button
19
+ v-else-if="action"
20
+ type="button"
21
+ class="text-left"
22
+ :class="props.class"
23
+ @click="onClick(action)"
24
+ >
25
+ <slot :active="false"> </slot>
26
+ </button>
27
+ <a v-else-if="href" :href="href" :class="props.class" @click="onClick()">
28
+ <slot :active="false"> </slot>
29
+ </a>
30
+ </template>
31
+
32
+ <script lang="ts">
33
+ export default {
34
+ inheritAttrs: false,
35
+ };
36
+ </script>
37
+
38
+ <script setup lang="ts">
39
+ import { RouteLocationRaw } from 'vue-router';
40
+
41
+ const props = defineProps<{
42
+ to?: RouteLocationRaw;
43
+ href?: string;
44
+ action?: (() => Promise<void>) | (() => void);
45
+ class?: string | string[] | null;
46
+ }>();
47
+
48
+ const closeMenu = inject('closeMenu', () => {
49
+ return;
50
+ }) as () => void;
51
+
52
+ const emit = defineEmits(['click']);
53
+
54
+ type asyncFunc = () => Promise<void>;
55
+
56
+ async function onClick(func: asyncFunc | null = null) {
57
+ if (func) {
58
+ await func();
59
+ }
60
+ emit('click');
61
+ closeMenu();
62
+ }
63
+ </script>