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
@@ -1,166 +1,166 @@
1
- import { DateTime } from 'luxon';
2
- import PageDashboard from '../../.storybook/components/PageDashboard.vue';
3
- import BaseLayoutSidebarConfigurable from './BaseLayoutSidebarConfigurable.vue';
4
-
5
- export default {
6
- title: 'Layout/BaseLayoutSidebarConfigurable',
7
- component: BaseLayoutSidebarConfigurable,
8
- parameters: {
9
- layout: 'fullscreen',
10
- },
11
- args: {
12
- user: {
13
- email: 'jane@witify.io',
14
- first_name: 'Jane',
15
- last_name: 'Doe',
16
- full_name: 'Jane Doe',
17
- avatar_url:
18
- 'https://images.unsplash.com/photo-1494790108377-be9c29b29330??auto=format&fit=crop&w=200&h=200&q=80&g=face',
19
- },
20
- menu: [
21
- {
22
- title: 'General',
23
- actions: [
24
- {
25
- label: 'Dashboard',
26
- to: '/',
27
- icon: 'heroicons:home-20-solid',
28
- },
29
- {
30
- label: 'Articles',
31
- to: '/articles',
32
- icon: 'heroicons:document-text-solid',
33
- count: 3134,
34
- actions: [
35
- {
36
- label: 'Articles',
37
- to: '/articles/1',
38
- },
39
- {
40
- label: 'Videos',
41
- to: '/articles/2',
42
- },
43
- {
44
- label: 'Training',
45
- to: '/articles/3',
46
- },
47
- {
48
- label: 'Archived',
49
- to: '/articles/4',
50
- },
51
- ],
52
- },
53
-
54
- {
55
- label: 'Users',
56
- to: '/users',
57
- icon: 'heroicons:users-solid',
58
- },
59
- ],
60
- },
61
- {
62
- title: 'Settings',
63
- actions: [
64
- {
65
- label: 'Account',
66
- to: '/account',
67
- icon: 'heroicons:cog-solid',
68
- },
69
- {
70
- label: 'Logout',
71
- action: logout,
72
- icon: 'heroicons:arrow-left-on-rectangle-solid',
73
- },
74
- ],
75
- },
76
- ],
77
- userMenu: [
78
- {
79
- label: 'Dashboard',
80
- to: '/',
81
- icon: 'heroicons:home-solid',
82
- },
83
- {
84
- label: 'Settings',
85
- to: '/account',
86
- icon: 'heroicons:cog-solid',
87
- },
88
- {
89
- label: 'Logout',
90
- action: logout,
91
- icon: 'heroicons:arrow-left-on-rectangle-20-solid',
92
- },
93
- ],
94
- notifications: {
95
- footerTo: '/',
96
- footerLabel: 'See all notifications',
97
- items: [
98
- {
99
- id: '1',
100
- text: 'You have a new message',
101
- created_at: DateTime.now().minus({ second: 1 }).toISO(),
102
- },
103
- {
104
- id: '2',
105
- text: 'Your inbox is now full. Please empty your inbox before it goes bang.',
106
- to: '/',
107
- created_at: '2022-01-01T00:00:00',
108
- },
109
- ],
110
- },
111
- },
112
- };
113
-
114
- async function logout() {
115
- alert('logout');
116
- }
117
-
118
- const Template = (args) => ({
119
- components: {
120
- BaseLayoutSidebarConfigurable,
121
- PageDashboard,
122
- },
123
- setup() {
124
- return { args };
125
- },
126
- template: `
127
- <BaseLayoutSidebarConfigurable v-bind="args">
128
- <div class="py-10 bg-slate-50">
129
- <PageDashboard />
130
- </div>
131
- </BaseLayoutSidebarConfigurable>
132
- `,
133
- });
134
-
135
- export const Light = Template.bind({});
136
- Light.args = {
137
- dark: false,
138
- logoUrl: 'https://sprintify.witify.io/img/logo/logo-side.svg',
139
- };
140
-
141
- export const Dark = Template.bind({});
142
- Dark.args = {
143
- dark: true,
144
- logoUrl: 'https://sprintify.witify.io/img/logo/logo-side-dark.svg',
145
- };
146
-
147
- export const SizeXS = Template.bind({});
148
- SizeXS.args = {
149
- size: 'xs',
150
- dark: true,
151
- logoUrl: 'https://sprintify.witify.io/img/logo/logo-side-dark.svg',
152
- };
153
-
154
- export const SizeSM = Template.bind({});
155
- SizeSM.args = {
156
- size: 'sm',
157
- dark: true,
158
- logoUrl: 'https://sprintify.witify.io/img/logo/logo-side-dark.svg',
159
- };
160
-
161
- export const SizeMD = Template.bind({});
162
- SizeMD.args = {
163
- size: 'md',
164
- dark: true,
165
- logoUrl: 'https://sprintify.witify.io/img/logo/logo-side-dark.svg',
166
- };
1
+ import { DateTime } from 'luxon';
2
+ import PageDashboard from '../../.storybook/components/PageDashboard.vue';
3
+ import BaseLayoutSidebarConfigurable from './BaseLayoutSidebarConfigurable.vue';
4
+
5
+ export default {
6
+ title: 'Layout/BaseLayoutSidebarConfigurable',
7
+ component: BaseLayoutSidebarConfigurable,
8
+ parameters: {
9
+ layout: 'fullscreen',
10
+ },
11
+ args: {
12
+ user: {
13
+ email: 'jane@witify.io',
14
+ first_name: 'Jane',
15
+ last_name: 'Doe',
16
+ full_name: 'Jane Doe',
17
+ avatar_url:
18
+ 'https://images.unsplash.com/photo-1494790108377-be9c29b29330??auto=format&fit=crop&w=200&h=200&q=80&g=face',
19
+ },
20
+ menu: [
21
+ {
22
+ title: 'General',
23
+ actions: [
24
+ {
25
+ label: 'Dashboard',
26
+ to: '/',
27
+ icon: 'heroicons:home-20-solid',
28
+ },
29
+ {
30
+ label: 'Articles',
31
+ to: '/articles',
32
+ icon: 'heroicons:document-text-solid',
33
+ count: 3134,
34
+ actions: [
35
+ {
36
+ label: 'Articles',
37
+ to: '/articles/1',
38
+ },
39
+ {
40
+ label: 'Videos',
41
+ to: '/articles/2',
42
+ },
43
+ {
44
+ label: 'Training',
45
+ to: '/articles/3',
46
+ },
47
+ {
48
+ label: 'Archived',
49
+ to: '/articles/4',
50
+ },
51
+ ],
52
+ },
53
+
54
+ {
55
+ label: 'Users',
56
+ to: '/users',
57
+ icon: 'heroicons:users-solid',
58
+ },
59
+ ],
60
+ },
61
+ {
62
+ title: 'Settings',
63
+ actions: [
64
+ {
65
+ label: 'Account',
66
+ to: '/account',
67
+ icon: 'heroicons:cog-solid',
68
+ },
69
+ {
70
+ label: 'Logout',
71
+ action: logout,
72
+ icon: 'heroicons:arrow-left-on-rectangle-solid',
73
+ },
74
+ ],
75
+ },
76
+ ],
77
+ userMenu: [
78
+ {
79
+ label: 'Dashboard',
80
+ to: '/',
81
+ icon: 'heroicons:home-solid',
82
+ },
83
+ {
84
+ label: 'Settings',
85
+ to: '/account',
86
+ icon: 'heroicons:cog-solid',
87
+ },
88
+ {
89
+ label: 'Logout',
90
+ action: logout,
91
+ icon: 'heroicons:arrow-left-on-rectangle-20-solid',
92
+ },
93
+ ],
94
+ notifications: {
95
+ footerTo: '/',
96
+ footerLabel: 'See all notifications',
97
+ items: [
98
+ {
99
+ id: '1',
100
+ text: 'You have a new message',
101
+ created_at: DateTime.now().minus({ second: 1 }).toISO(),
102
+ },
103
+ {
104
+ id: '2',
105
+ text: 'Your inbox is now full. Please empty your inbox before it goes bang.',
106
+ to: '/',
107
+ created_at: '2022-01-01T00:00:00',
108
+ },
109
+ ],
110
+ },
111
+ },
112
+ };
113
+
114
+ async function logout() {
115
+ alert('logout');
116
+ }
117
+
118
+ const Template = (args) => ({
119
+ components: {
120
+ BaseLayoutSidebarConfigurable,
121
+ PageDashboard,
122
+ },
123
+ setup() {
124
+ return { args };
125
+ },
126
+ template: `
127
+ <BaseLayoutSidebarConfigurable v-bind="args">
128
+ <div class="py-10 bg-slate-50">
129
+ <PageDashboard />
130
+ </div>
131
+ </BaseLayoutSidebarConfigurable>
132
+ `,
133
+ });
134
+
135
+ export const Light = Template.bind({});
136
+ Light.args = {
137
+ dark: false,
138
+ logoUrl: 'https://sprintify.witify.io/img/logo/logo-side.svg',
139
+ };
140
+
141
+ export const Dark = Template.bind({});
142
+ Dark.args = {
143
+ dark: true,
144
+ logoUrl: 'https://sprintify.witify.io/img/logo/logo-side-dark.svg',
145
+ };
146
+
147
+ export const SizeXS = Template.bind({});
148
+ SizeXS.args = {
149
+ size: 'xs',
150
+ dark: true,
151
+ logoUrl: 'https://sprintify.witify.io/img/logo/logo-side-dark.svg',
152
+ };
153
+
154
+ export const SizeSM = Template.bind({});
155
+ SizeSM.args = {
156
+ size: 'sm',
157
+ dark: true,
158
+ logoUrl: 'https://sprintify.witify.io/img/logo/logo-side-dark.svg',
159
+ };
160
+
161
+ export const SizeMD = Template.bind({});
162
+ SizeMD.args = {
163
+ size: 'md',
164
+ dark: true,
165
+ logoUrl: 'https://sprintify.witify.io/img/logo/logo-side-dark.svg',
166
+ };
@@ -1,167 +1,167 @@
1
- <template>
2
- <BaseLayoutSidebar
3
- :app-name="appName"
4
- :logo-url="logoUrl"
5
- :dark="dark"
6
- :size="size"
7
- >
8
- <template #menu>
9
- <div class="px-3 py-6">
10
- <div class="space-y-8">
11
- <div v-for="section in actionSections" :key="section.title">
12
- <h2 v-if="section.title" class="pl-3" :class="sectionTitleClasses">
13
- {{ section.title }}
14
- </h2>
15
- <div>
16
- <div :class="[size == 'md' ? 'space-y-1' : 'space-y-0.5']">
17
- <BaseNavbarSideItem
18
- v-for="item in section.actions"
19
- :key="item.label"
20
- :item="item"
21
- :dark="dark"
22
- :size="size"
23
- />
24
- </div>
25
- </div>
26
- </div>
27
- </div>
28
- </div>
29
- </template>
30
-
31
- <template #navbar>
32
- <div class="flex flex-1 justify-between px-4">
33
- <div class="flex flex-1">
34
- <!-- Good spot for search bar... -->
35
- </div>
36
-
37
- <div class="ml-4 flex items-center md:ml-6">
38
- <!-- Notification dropdown -->
39
- <BaseLayoutNotificationDropdown
40
- v-if="notifications"
41
- :notifications-config="notifications"
42
- class="mr-1 sm:mr-2"
43
- :size="size"
44
- @click="onNotificationClick"
45
- @open="onNotificationOpen"
46
- ></BaseLayoutNotificationDropdown>
47
-
48
- <!-- Profile dropdown -->
49
- <div
50
- class="relative mr-2"
51
- :class="{
52
- 'ml-2': size == 'md',
53
- 'ml-1': size == 'sm',
54
- 'ml-0': size == 'xs',
55
- }"
56
- >
57
- <BaseMenu :items="userMenu" :size="size == 'xs' ? 'xs' : 'sm'">
58
- <template #button="{ open }">
59
- <div
60
- class="flex rounded-md p-1.5 hover:bg-slate-100"
61
- :class="[open ? 'bg-slate-100' : '']"
62
- >
63
- <BaseAvatar :user="user" :size="size" show-details />
64
- </div>
65
- </template>
66
- </BaseMenu>
67
- </div>
68
- </div>
69
- </div>
70
- </template>
71
-
72
- <template #default>
73
- <slot />
74
- </template>
75
- </BaseLayoutSidebar>
76
- </template>
77
-
78
- <script setup lang="ts">
79
- import { User } from '@/types/User';
80
- import { PropType } from 'vue';
81
- import { ActionItem, ActionSection, NotificationsConfig } from '../types';
82
- import BaseAvatar from './BaseAvatar.vue';
83
- import BaseLayoutNotificationDropdown from './BaseLayoutNotificationDropdown.vue';
84
- import BaseLayoutSidebar from './BaseLayoutSidebar.vue';
85
- import BaseMenu from './BaseMenu.vue';
86
- import BaseNavbarSideItem from './BaseNavbarSideItem.vue';
87
-
88
- const emit = defineEmits(['notification:click', 'notification:open']);
89
-
90
- const props = defineProps({
91
- appName: {
92
- default: '',
93
- type: String,
94
- },
95
- logoUrl: {
96
- default: 'https://sprintify.witify.io/img/logo/logo-side-dark.svg',
97
- type: String,
98
- },
99
- menu: {
100
- required: true,
101
- type: Array as PropType<ActionItem[] | ActionSection[]>,
102
- },
103
- userMenu: {
104
- required: true,
105
- type: Array as PropType<ActionItem[]>,
106
- },
107
- user: {
108
- required: true,
109
- type: Object as PropType<User>,
110
- },
111
- notifications: {
112
- default: undefined,
113
- type: Object as PropType<NotificationsConfig>,
114
- },
115
- dark: {
116
- default: false,
117
- type: Boolean,
118
- },
119
- size: {
120
- default: 'md',
121
- type: String as PropType<'xs' | 'sm' | 'md'>,
122
- },
123
- });
124
-
125
- const actionSections = computed((): ActionSection[] => {
126
- const isActionSections = props.menu.length > 0 && 'actions' in props.menu[0];
127
-
128
- if (isActionSections) {
129
- return props.menu as ActionSection[];
130
- }
131
-
132
- return [
133
- {
134
- title: '',
135
- actions: props.menu as ActionItem[],
136
- },
137
- ];
138
- });
139
-
140
- const sectionTitleClasses = computed((): string[] => {
141
- const classList = ['mb-3 font-semibold uppercase tracking-widest'];
142
-
143
- if (props.dark) {
144
- classList.push('text-gray-400');
145
- } else {
146
- classList.push('text-gray-500');
147
- }
148
-
149
- if (props.size === 'xs') {
150
- classList.push('text-[10px]');
151
- } else if (props.size === 'sm') {
152
- classList.push('text-[11px]');
153
- } else if (props.size === 'md') {
154
- classList.push('text-xs');
155
- }
156
-
157
- return classList;
158
- });
159
-
160
- function onNotificationClick(notification: Notification) {
161
- emit('notification:click', notification);
162
- }
163
-
164
- function onNotificationOpen() {
165
- emit('notification:open');
166
- }
167
- </script>
1
+ <template>
2
+ <BaseLayoutSidebar
3
+ :app-name="appName"
4
+ :logo-url="logoUrl"
5
+ :dark="dark"
6
+ :size="size"
7
+ >
8
+ <template #menu>
9
+ <div class="px-3 py-6">
10
+ <div class="space-y-8">
11
+ <div v-for="section in actionSections" :key="section.title">
12
+ <h2 v-if="section.title" class="pl-3" :class="sectionTitleClasses">
13
+ {{ section.title }}
14
+ </h2>
15
+ <div>
16
+ <div :class="[size == 'md' ? 'space-y-1' : 'space-y-0.5']">
17
+ <BaseNavbarSideItem
18
+ v-for="item in section.actions"
19
+ :key="item.label"
20
+ :item="item"
21
+ :dark="dark"
22
+ :size="size"
23
+ />
24
+ </div>
25
+ </div>
26
+ </div>
27
+ </div>
28
+ </div>
29
+ </template>
30
+
31
+ <template #navbar>
32
+ <div class="flex flex-1 justify-between px-4">
33
+ <div class="flex flex-1">
34
+ <!-- Good spot for search bar... -->
35
+ </div>
36
+
37
+ <div class="ml-4 flex items-center md:ml-6">
38
+ <!-- Notification dropdown -->
39
+ <BaseLayoutNotificationDropdown
40
+ v-if="notifications"
41
+ :notifications-config="notifications"
42
+ class="mr-1 sm:mr-2"
43
+ :size="size"
44
+ @click="onNotificationClick"
45
+ @open="onNotificationOpen"
46
+ ></BaseLayoutNotificationDropdown>
47
+
48
+ <!-- Profile dropdown -->
49
+ <div
50
+ class="relative mr-2"
51
+ :class="{
52
+ 'ml-2': size == 'md',
53
+ 'ml-1': size == 'sm',
54
+ 'ml-0': size == 'xs',
55
+ }"
56
+ >
57
+ <BaseMenu :items="userMenu" :size="size == 'xs' ? 'xs' : 'sm'">
58
+ <template #button="{ open }">
59
+ <div
60
+ class="flex rounded-md p-1.5 hover:bg-slate-100"
61
+ :class="[open ? 'bg-slate-100' : '']"
62
+ >
63
+ <BaseAvatar :user="user" :size="size" show-details />
64
+ </div>
65
+ </template>
66
+ </BaseMenu>
67
+ </div>
68
+ </div>
69
+ </div>
70
+ </template>
71
+
72
+ <template #default>
73
+ <slot />
74
+ </template>
75
+ </BaseLayoutSidebar>
76
+ </template>
77
+
78
+ <script setup lang="ts">
79
+ import { User } from '@/types/User';
80
+ import { PropType } from 'vue';
81
+ import { ActionItem, ActionSection, NotificationsConfig } from '../types';
82
+ import BaseAvatar from './BaseAvatar.vue';
83
+ import BaseLayoutNotificationDropdown from './BaseLayoutNotificationDropdown.vue';
84
+ import BaseLayoutSidebar from './BaseLayoutSidebar.vue';
85
+ import BaseMenu from './BaseMenu.vue';
86
+ import BaseNavbarSideItem from './BaseNavbarSideItem.vue';
87
+
88
+ const emit = defineEmits(['notification:click', 'notification:open']);
89
+
90
+ const props = defineProps({
91
+ appName: {
92
+ default: '',
93
+ type: String,
94
+ },
95
+ logoUrl: {
96
+ default: 'https://sprintify.witify.io/img/logo/logo-side-dark.svg',
97
+ type: String,
98
+ },
99
+ menu: {
100
+ required: true,
101
+ type: Array as PropType<ActionItem[] | ActionSection[]>,
102
+ },
103
+ userMenu: {
104
+ required: true,
105
+ type: Array as PropType<ActionItem[]>,
106
+ },
107
+ user: {
108
+ required: true,
109
+ type: Object as PropType<User>,
110
+ },
111
+ notifications: {
112
+ default: undefined,
113
+ type: Object as PropType<NotificationsConfig>,
114
+ },
115
+ dark: {
116
+ default: false,
117
+ type: Boolean,
118
+ },
119
+ size: {
120
+ default: 'md',
121
+ type: String as PropType<'xs' | 'sm' | 'md'>,
122
+ },
123
+ });
124
+
125
+ const actionSections = computed((): ActionSection[] => {
126
+ const isActionSections = props.menu.length > 0 && 'actions' in props.menu[0];
127
+
128
+ if (isActionSections) {
129
+ return props.menu as ActionSection[];
130
+ }
131
+
132
+ return [
133
+ {
134
+ title: '',
135
+ actions: props.menu as ActionItem[],
136
+ },
137
+ ];
138
+ });
139
+
140
+ const sectionTitleClasses = computed((): string[] => {
141
+ const classList = ['mb-3 font-semibold uppercase tracking-widest'];
142
+
143
+ if (props.dark) {
144
+ classList.push('text-gray-400');
145
+ } else {
146
+ classList.push('text-gray-500');
147
+ }
148
+
149
+ if (props.size === 'xs') {
150
+ classList.push('text-[10px]');
151
+ } else if (props.size === 'sm') {
152
+ classList.push('text-[11px]');
153
+ } else if (props.size === 'md') {
154
+ classList.push('text-xs');
155
+ }
156
+
157
+ return classList;
158
+ });
159
+
160
+ function onNotificationClick(notification: Notification) {
161
+ emit('notification:click', notification);
162
+ }
163
+
164
+ function onNotificationOpen() {
165
+ emit('notification:open');
166
+ }
167
+ </script>