sprintify-ui 0.1.17 → 0.1.18

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 +229 -229
  2. package/dist/sprintify-ui.es.js +97 -92
  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 +29 -29
  7. package/dist/types/src/components/BaseAddressForm.vue.d.ts +81 -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 +232 -232
  13. package/dist/types/src/components/BaseAutocompleteDrawer.vue.d.ts +90 -90
  14. package/dist/types/src/components/BaseAutocompleteFetch.vue.d.ts +213 -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 +50 -50
  18. package/dist/types/src/components/BaseBelongsTo.vue.d.ts +219 -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 +57 -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 +665 -665
  37. package/dist/types/src/components/BaseDataIteratorSectionModal.vue.d.ts +29 -29
  38. package/dist/types/src/components/BaseDataTable.vue.d.ts +383 -383
  39. package/dist/types/src/components/BaseDataTableRowAction.vue.d.ts +18 -18
  40. package/dist/types/src/components/BaseDatePicker.vue.d.ts +84 -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 +62 -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 +96 -96
  51. package/dist/types/src/components/BaseFilePicker.vue.d.ts +59 -59
  52. package/dist/types/src/components/BaseFilePickerCrop.vue.d.ts +57 -57
  53. package/dist/types/src/components/BaseFileUploader.vue.d.ts +85 -85
  54. package/dist/types/src/components/BaseForm.vue.d.ts +131 -131
  55. package/dist/types/src/components/BaseHasMany.vue.d.ts +152 -152
  56. package/dist/types/src/components/BaseHeader.vue.d.ts +80 -80
  57. package/dist/types/src/components/BaseIconPicker.vue.d.ts +38 -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 +172 -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 +79 -79
  82. package/dist/types/src/components/BaseModalSide.vue.d.ts +61 -61
  83. package/dist/types/src/components/BaseNavbar.vue.d.ts +35 -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 +97 -97
  97. package/dist/types/src/components/BaseShortcut.vue.d.ts +86 -86
  98. package/dist/types/src/components/BaseSideNavigation.vue.d.ts +33 -33
  99. package/dist/types/src/components/BaseSideNavigationItem.vue.d.ts +43 -43
  100. package/dist/types/src/components/BaseSkeleton.vue.d.ts +30 -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 +43 -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 +33 -33
  110. package/dist/types/src/components/BaseTagAutocomplete.vue.d.ts +204 -204
  111. package/dist/types/src/components/BaseTagAutocompleteFetch.vue.d.ts +144 -144
  112. package/dist/types/src/components/BaseTextarea.vue.d.ts +98 -98
  113. package/dist/types/src/components/BaseTextareaAutoresize.vue.d.ts +98 -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 +139 -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 +85 -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 +230 -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 +323 -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 +94 -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 +129 -129
  286. package/src/components/BaseMenuItem.vue +107 -107
  287. package/src/components/BaseModalCenter.stories.js +68 -68
  288. package/src/components/BaseModalCenter.vue +125 -125
  289. package/src/components/BaseModalSide.stories.js +55 -55
  290. package/src/components/BaseModalSide.vue +116 -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 +24 -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 +428 -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 +58 -58
  344. package/src/components/BaseTextareaAutoresize.vue +140 -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
package/package.json CHANGED
@@ -1,139 +1,139 @@
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.1.18",
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,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>
@@ -1,75 +1,75 @@
1
- <template>
2
- <BaseActionItem
3
- :to="action.to"
4
- :href="action.href"
5
- :action="action.action"
6
- :class="classes"
7
- class="flex items-center justify-center"
8
- >
9
- <BaseIcon
10
- v-if="action.icon"
11
- :icon="action.icon"
12
- :class="iconClasses"
13
- class="mr-2"
14
- ></BaseIcon>
15
- <span :class="[action.icon ? 'pr-1' : '']">{{ action.label }}</span>
16
- </BaseActionItem>
17
- </template>
18
-
19
- <script lang="ts" setup>
20
- import { ActionItem } from '@/types';
21
- import { BaseIcon } from '..';
22
- import BaseActionItem from './BaseActionItem.vue';
23
-
24
- const props = withDefaults(
25
- defineProps<{
26
- action: ActionItem;
27
- size: 'sm' | 'md' | 'lg';
28
- }>(),
29
- {
30
- size: 'md',
31
- }
32
- );
33
-
34
- const classes = computed(() => {
35
- const classList = ['btn'];
36
-
37
- if (props.action.color == 'primary') {
38
- classList.push('btn-primary');
39
- } else if (props.action.color == 'secondary') {
40
- classList.push('btn-secondary-outline');
41
- } else if (props.action.color == 'danger') {
42
- classList.push('btn-danger');
43
- } else if (props.action.color == 'warning') {
44
- classList.push('btn-warning');
45
- } else if (props.action.color == 'success') {
46
- classList.push('btn-success');
47
- } else if (props.action.color == 'light') {
48
- classList.push('');
49
- } else if (props.action.color == 'dark') {
50
- classList.push('btn-black');
51
- }
52
-
53
- if (props.size == 'sm') {
54
- classList.push('btn-sm');
55
- } else if (props.size == 'lg') {
56
- classList.push('btn-lg');
57
- }
58
-
59
- return classList;
60
- });
61
-
62
- const iconClasses = computed(() => {
63
- const classList = [];
64
-
65
- if (props.size == 'sm') {
66
- classList.push('h-4 w-4');
67
- } else if (props.size == 'lg') {
68
- classList.push('h-6 w-6');
69
- } else {
70
- classList.push('h-5 w-5');
71
- }
72
-
73
- return classList;
74
- });
75
- </script>
1
+ <template>
2
+ <BaseActionItem
3
+ :to="action.to"
4
+ :href="action.href"
5
+ :action="action.action"
6
+ :class="classes"
7
+ class="flex items-center justify-center"
8
+ >
9
+ <BaseIcon
10
+ v-if="action.icon"
11
+ :icon="action.icon"
12
+ :class="iconClasses"
13
+ class="mr-2"
14
+ ></BaseIcon>
15
+ <span :class="[action.icon ? 'pr-1' : '']">{{ action.label }}</span>
16
+ </BaseActionItem>
17
+ </template>
18
+
19
+ <script lang="ts" setup>
20
+ import { ActionItem } from '@/types';
21
+ import { BaseIcon } from '..';
22
+ import BaseActionItem from './BaseActionItem.vue';
23
+
24
+ const props = withDefaults(
25
+ defineProps<{
26
+ action: ActionItem;
27
+ size: 'sm' | 'md' | 'lg';
28
+ }>(),
29
+ {
30
+ size: 'md',
31
+ }
32
+ );
33
+
34
+ const classes = computed(() => {
35
+ const classList = ['btn'];
36
+
37
+ if (props.action.color == 'primary') {
38
+ classList.push('btn-primary');
39
+ } else if (props.action.color == 'secondary') {
40
+ classList.push('btn-secondary-outline');
41
+ } else if (props.action.color == 'danger') {
42
+ classList.push('btn-danger');
43
+ } else if (props.action.color == 'warning') {
44
+ classList.push('btn-warning');
45
+ } else if (props.action.color == 'success') {
46
+ classList.push('btn-success');
47
+ } else if (props.action.color == 'light') {
48
+ classList.push('');
49
+ } else if (props.action.color == 'dark') {
50
+ classList.push('btn-black');
51
+ }
52
+
53
+ if (props.size == 'sm') {
54
+ classList.push('btn-sm');
55
+ } else if (props.size == 'lg') {
56
+ classList.push('btn-lg');
57
+ }
58
+
59
+ return classList;
60
+ });
61
+
62
+ const iconClasses = computed(() => {
63
+ const classList = [];
64
+
65
+ if (props.size == 'sm') {
66
+ classList.push('h-4 w-4');
67
+ } else if (props.size == 'lg') {
68
+ classList.push('h-6 w-6');
69
+ } else {
70
+ classList.push('h-5 w-5');
71
+ }
72
+
73
+ return classList;
74
+ });
75
+ </script>