sprintify-ui 0.2.18 → 0.2.21

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 (405) hide show
  1. package/README.md +244 -244
  2. package/dist/sprintify-ui.es.js +7675 -7686
  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 +40 -40
  6. package/dist/types/src/components/BaseActionItemButton.vue.d.ts +25 -25
  7. package/dist/types/src/components/BaseAddressForm.vue.d.ts +84 -84
  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 -237
  13. package/dist/types/src/components/BaseAutocompleteDrawer.vue.d.ts +91 -91
  14. package/dist/types/src/components/BaseAutocompleteFetch.vue.d.ts +210 -210
  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 +54 -54
  18. package/dist/types/src/components/BaseBelongsTo.vue.d.ts +216 -216
  19. package/dist/types/src/components/BaseBoolean.vue.d.ts +10 -10
  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 +76 -76
  32. package/dist/types/src/components/BaseCropperModal.vue.d.ts +28 -28
  33. package/dist/types/src/components/BaseDataIterator.vue.d.ts +212 -212
  34. package/dist/types/src/components/BaseDataIteratorSectionBox.vue.d.ts +20 -20
  35. package/dist/types/src/components/BaseDataIteratorSectionButton.vue.d.ts +17 -17
  36. package/dist/types/src/components/BaseDataIteratorSectionColumns.vue.d.ts +637 -637
  37. package/dist/types/src/components/BaseDataIteratorSectionModal.vue.d.ts +32 -32
  38. package/dist/types/src/components/BaseDataTable.vue.d.ts +385 -385
  39. package/dist/types/src/components/BaseDataTableRowAction.vue.d.ts +21 -21
  40. package/dist/types/src/components/BaseDatePicker.vue.d.ts +124 -124
  41. package/dist/types/src/components/BaseDateSelect.vue.d.ts +79 -79
  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 +49 -49
  47. package/dist/types/src/components/BaseDropdown.vue.d.ts +65 -65
  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 -93
  51. package/dist/types/src/components/BaseFilePicker.vue.d.ts +72 -63
  52. package/dist/types/src/components/BaseFilePickerCrop.vue.d.ts +63 -63
  53. package/dist/types/src/components/BaseFileUploader.vue.d.ts +144 -133
  54. package/dist/types/src/components/BaseForm.vue.d.ts +134 -134
  55. package/dist/types/src/components/BaseGantt.vue.d.ts +425 -425
  56. package/dist/types/src/components/BaseHasMany.vue.d.ts +149 -149
  57. package/dist/types/src/components/BaseHeader.vue.d.ts +98 -98
  58. package/dist/types/src/components/BaseIconPicker.vue.d.ts +34 -34
  59. package/dist/types/src/components/BaseInput.vue.d.ts +174 -174
  60. package/dist/types/src/components/BaseInputError.vue.d.ts +9 -9
  61. package/dist/types/src/components/BaseInputLabel.vue.d.ts +43 -43
  62. package/dist/types/src/components/BaseInputPercent.vue.d.ts +138 -138
  63. package/dist/types/src/components/BaseLayoutNotificationDropdown.vue.d.ts +36 -36
  64. package/dist/types/src/components/BaseLayoutNotificationItem.vue.d.ts +16 -16
  65. package/dist/types/src/components/BaseLayoutNotificationItemContent.vue.d.ts +21 -21
  66. package/dist/types/src/components/BaseLayoutSidebar.vue.d.ts +51 -51
  67. package/dist/types/src/components/BaseLayoutSidebarConfigurable.vue.d.ts +87 -87
  68. package/dist/types/src/components/BaseLayoutStacked.vue.d.ts +23 -23
  69. package/dist/types/src/components/BaseLayoutStackedConfigurable.vue.d.ts +78 -78
  70. package/dist/types/src/components/BaseLoadingCover.vue.d.ts +96 -96
  71. package/dist/types/src/components/BaseMediaGallery.vue.d.ts +64 -64
  72. package/dist/types/src/components/BaseMediaGalleryItem.vue.d.ts +45 -45
  73. package/dist/types/src/components/BaseMediaItem.vue.d.ts +27 -27
  74. package/dist/types/src/components/BaseMediaLibrary.vue.d.ts +199 -190
  75. package/dist/types/src/components/BaseMediaList.vue.d.ts +47 -47
  76. package/dist/types/src/components/BaseMediaListItem.vue.d.ts +47 -47
  77. package/dist/types/src/components/BaseMediaPictures.vue.d.ts +55 -55
  78. package/dist/types/src/components/BaseMediaPicturesItem.vue.d.ts +54 -54
  79. package/dist/types/src/components/BaseMediaPreview.vue.d.ts +36 -36
  80. package/dist/types/src/components/BaseMenu.vue.d.ts +68 -68
  81. package/dist/types/src/components/BaseMenuItem.vue.d.ts +61 -61
  82. package/dist/types/src/components/BaseModalCenter.vue.d.ts +80 -80
  83. package/dist/types/src/components/BaseModalSide.vue.d.ts +62 -62
  84. package/dist/types/src/components/BaseNavbar.vue.d.ts +38 -38
  85. package/dist/types/src/components/BaseNavbarItem.vue.d.ts +26 -26
  86. package/dist/types/src/components/BaseNavbarItemContent.vue.d.ts +60 -60
  87. package/dist/types/src/components/BaseNavbarSideItem.vue.d.ts +44 -44
  88. package/dist/types/src/components/BaseNavbarSideItemContent.vue.d.ts +60 -60
  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 +67 -67
  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 -98
  97. package/dist/types/src/components/BaseShortcut.vue.d.ts +86 -86
  98. package/dist/types/src/components/BaseSideNavigation.vue.d.ts +21 -21
  99. package/dist/types/src/components/BaseSideNavigationItem.vue.d.ts +41 -41
  100. package/dist/types/src/components/BaseSkeleton.vue.d.ts +31 -31
  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 +41 -41
  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 +21 -21
  110. package/dist/types/src/components/BaseTagAutocomplete.vue.d.ts +209 -209
  111. package/dist/types/src/components/BaseTagAutocompleteFetch.vue.d.ts +141 -141
  112. package/dist/types/src/components/BaseTextarea.vue.d.ts +103 -103
  113. package/dist/types/src/components/BaseTextareaAutoresize.vue.d.ts +113 -113
  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/BaseUniqueCode.vue.d.ts +33 -33
  117. package/dist/types/src/components/SlotComponent.d.ts +43 -43
  118. package/dist/types/src/components/index.d.ts +96 -96
  119. package/dist/types/src/composables/breakpoints.d.ts +27 -27
  120. package/dist/types/src/composables/clickOutside.d.ts +8 -8
  121. package/dist/types/src/composables/field.d.ts +19 -19
  122. package/dist/types/src/composables/hasOptions.d.ts +7 -7
  123. package/dist/types/src/composables/mediaQuery.d.ts +2 -2
  124. package/dist/types/src/composables/modal.d.ts +6 -6
  125. package/dist/types/src/composables/paginatedData.d.ts +7 -7
  126. package/dist/types/src/constants/MyConstants.d.ts +1 -1
  127. package/dist/types/src/constants/index.d.ts +2 -2
  128. package/dist/types/src/i18n/index.d.ts +1 -1
  129. package/dist/types/src/index.d.ts +222 -222
  130. package/dist/types/src/services/gantt/format.d.ts +24 -24
  131. package/dist/types/src/services/gantt/timescale.d.ts +26 -26
  132. package/dist/types/src/services/gantt/types.d.ts +67 -67
  133. package/dist/types/src/stores/dialogs.d.ts +9 -9
  134. package/dist/types/src/stores/i18n.d.ts +5 -5
  135. package/dist/types/src/stores/notifications.d.ts +10 -10
  136. package/dist/types/src/stores/systemAlerts.d.ts +9 -9
  137. package/dist/types/src/svg/BaseEmptyState.vue.d.ts +2 -2
  138. package/dist/types/src/svg/BaseSpinnerLarge.vue.d.ts +2 -2
  139. package/dist/types/src/svg/BaseSpinnerSmall.vue.d.ts +2 -2
  140. package/dist/types/src/types/Color.d.ts +9 -9
  141. package/dist/types/src/types/Country.d.ts +4 -4
  142. package/dist/types/src/types/ImagePickerResult.d.ts +5 -5
  143. package/dist/types/src/types/Media.d.ts +9 -9
  144. package/dist/types/src/types/Notification.d.ts +8 -8
  145. package/dist/types/src/types/Region.d.ts +5 -5
  146. package/dist/types/src/types/Status.d.ts +5 -5
  147. package/dist/types/src/types/StepperItem.d.ts +7 -7
  148. package/dist/types/src/types/TimelineItem.d.ts +8 -8
  149. package/dist/types/src/types/UploadedFile.d.ts +10 -10
  150. package/dist/types/src/types/User.d.ts +6 -6
  151. package/dist/types/src/types/index.d.ts +218 -218
  152. package/dist/types/src/utils/blob.d.ts +3 -3
  153. package/dist/types/src/utils/colors.d.ts +13 -13
  154. package/dist/types/src/utils/cropper/avatar.d.ts +5 -5
  155. package/dist/types/src/utils/cropper/cover.d.ts +5 -5
  156. package/dist/types/src/utils/cropper/presetInterface.d.ts +7 -7
  157. package/dist/types/src/utils/cropper/presets.d.ts +6 -6
  158. package/dist/types/src/utils/fileSizeFormat.d.ts +1 -1
  159. package/dist/types/src/utils/fileValidations.d.ts +2 -2
  160. package/dist/types/src/utils/index.d.ts +6 -6
  161. package/dist/types/src/utils/resizeImageFromURI.d.ts +1 -1
  162. package/dist/types/src/utils/scrollPreventer.d.ts +3 -3
  163. package/dist/types/src/utils/toHumanList.d.ts +1 -1
  164. package/package.json +139 -136
  165. package/src/assets/flatpickr.css +243 -243
  166. package/src/assets/form.css +6 -6
  167. package/src/assets/main.css +36 -36
  168. package/src/assets/tailwind.css +2 -2
  169. package/src/components/BaseActionItem.vue +68 -68
  170. package/src/components/BaseActionItemButton.vue +75 -75
  171. package/src/components/BaseAddressForm.stories.js +103 -103
  172. package/src/components/BaseAddressForm.vue +354 -354
  173. package/src/components/BaseAlert.stories.js +52 -52
  174. package/src/components/BaseAlert.vue +158 -158
  175. package/src/components/BaseApp.vue +16 -16
  176. package/src/components/BaseAppDialogs.vue +124 -124
  177. package/src/components/BaseAppNotifications.vue +76 -76
  178. package/src/components/BaseAutocomplete.stories.js +236 -236
  179. package/src/components/BaseAutocomplete.vue +523 -523
  180. package/src/components/BaseAutocompleteDrawer.vue +372 -372
  181. package/src/components/BaseAutocompleteFetch.stories.js +224 -224
  182. package/src/components/BaseAutocompleteFetch.vue +288 -288
  183. package/src/components/BaseAvatar.stories.js +39 -39
  184. package/src/components/BaseAvatar.vue +120 -120
  185. package/src/components/BaseAvatarGroup.stories.js +71 -71
  186. package/src/components/BaseAvatarGroup.vue +148 -148
  187. package/src/components/BaseBadge.stories.js +124 -124
  188. package/src/components/BaseBadge.vue +78 -78
  189. package/src/components/BaseBelongsTo.stories.js +223 -223
  190. package/src/components/BaseBelongsTo.vue +193 -193
  191. package/src/components/BaseBoolean.stories.js +35 -35
  192. package/src/components/BaseBoolean.vue +26 -26
  193. package/src/components/BaseBreadcrumbs.stories.js +45 -45
  194. package/src/components/BaseBreadcrumbs.vue +104 -104
  195. package/src/components/BaseButton.stories.js +88 -88
  196. package/src/components/BaseButton.vue +46 -46
  197. package/src/components/BaseButtonGroup.stories.js +86 -86
  198. package/src/components/BaseButtonGroup.vue +150 -150
  199. package/src/components/BaseCard.stories.js +61 -61
  200. package/src/components/BaseCard.vue +49 -49
  201. package/src/components/BaseCardRow.vue +34 -34
  202. package/src/components/BaseCharacterCounter.stories.js +30 -30
  203. package/src/components/BaseCharacterCounter.vue +64 -64
  204. package/src/components/BaseClickOutside.vue +37 -37
  205. package/src/components/BaseClipboard.stories.js +31 -31
  206. package/src/components/BaseClipboard.vue +99 -99
  207. package/src/components/BaseColor.stories.js +46 -46
  208. package/src/components/BaseColor.vue +154 -154
  209. package/src/components/BaseContainer.stories.js +34 -34
  210. package/src/components/BaseContainer.vue +50 -50
  211. package/src/components/BaseCounter.stories.js +47 -47
  212. package/src/components/BaseCounter.vue +82 -82
  213. package/src/components/BaseCropper.stories.js +113 -113
  214. package/src/components/BaseCropper.vue +458 -458
  215. package/src/components/BaseCropperModal.stories.js +54 -54
  216. package/src/components/BaseCropperModal.vue +143 -143
  217. package/src/components/BaseDataIterator.stories.js +197 -197
  218. package/src/components/BaseDataIterator.vue +802 -802
  219. package/src/components/BaseDataIteratorSectionBox.vue +36 -36
  220. package/src/components/BaseDataIteratorSectionButton.vue +42 -42
  221. package/src/components/BaseDataIteratorSectionColumns.vue +70 -70
  222. package/src/components/BaseDataIteratorSectionModal.vue +41 -41
  223. package/src/components/BaseDataTable.stories.js +341 -341
  224. package/src/components/BaseDataTable.vue +747 -747
  225. package/src/components/BaseDataTableRowAction.vue +34 -34
  226. package/src/components/BaseDatePicker.stories.js +130 -130
  227. package/src/components/BaseDatePicker.vue +296 -296
  228. package/src/components/BaseDateSelect.stories.js +47 -47
  229. package/src/components/BaseDateSelect.vue +241 -241
  230. package/src/components/BaseDescriptionList.stories.js +35 -35
  231. package/src/components/BaseDescriptionList.vue +13 -13
  232. package/src/components/BaseDescriptionListItem.vue +47 -47
  233. package/src/components/BaseDialog.stories.js +51 -51
  234. package/src/components/BaseDialog.vue +119 -119
  235. package/src/components/BaseDisplayRelativeTime.stories.js +59 -59
  236. package/src/components/BaseDisplayRelativeTime.vue +123 -123
  237. package/src/components/BaseDraggable.vue +71 -71
  238. package/src/components/BaseDropdown.stories.js +210 -210
  239. package/src/components/BaseDropdown.vue +280 -280
  240. package/src/components/BaseDropdownAutocomplete.stories.js +187 -187
  241. package/src/components/BaseDropdownAutocomplete.vue +236 -236
  242. package/src/components/BaseField.vue +112 -112
  243. package/src/components/BaseFieldI18n.stories.js +38 -38
  244. package/src/components/BaseFieldI18n.vue +170 -170
  245. package/src/components/BaseFilePicker.stories.js +84 -78
  246. package/src/components/BaseFilePicker.vue +166 -136
  247. package/src/components/BaseFilePickerCrop.stories.js +135 -134
  248. package/src/components/BaseFilePickerCrop.vue +130 -130
  249. package/src/components/BaseFileUploader.stories.js +90 -84
  250. package/src/components/BaseFileUploader.vue +174 -163
  251. package/src/components/BaseForm.stories.js +48 -46
  252. package/src/components/BaseForm.vue +331 -331
  253. package/src/components/BaseGantt.stories.js +133 -133
  254. package/src/components/BaseGantt.vue +336 -336
  255. package/src/components/BaseHasMany.stories.js +189 -189
  256. package/src/components/BaseHasMany.vue +137 -137
  257. package/src/components/BaseHeader.stories.js +127 -127
  258. package/src/components/BaseHeader.vue +191 -191
  259. package/src/components/BaseIconPicker.stories.js +22 -22
  260. package/src/components/BaseIconPicker.vue +225 -225
  261. package/src/components/BaseInput.stories.js +167 -167
  262. package/src/components/BaseInput.vue +264 -264
  263. package/src/components/BaseInputError.vue +7 -7
  264. package/src/components/BaseInputLabel.stories.js +36 -36
  265. package/src/components/BaseInputLabel.vue +75 -75
  266. package/src/components/BaseInputPercent.stories.js +65 -65
  267. package/src/components/BaseInputPercent.vue +139 -139
  268. package/src/components/BaseLayoutNotificationDropdown.vue +150 -150
  269. package/src/components/BaseLayoutNotificationItem.vue +53 -53
  270. package/src/components/BaseLayoutNotificationItemContent.vue +30 -30
  271. package/src/components/BaseLayoutSidebar.vue +236 -236
  272. package/src/components/BaseLayoutSidebarConfigurable.stories.js +166 -166
  273. package/src/components/BaseLayoutSidebarConfigurable.vue +181 -181
  274. package/src/components/BaseLayoutStacked.vue +52 -52
  275. package/src/components/BaseLayoutStackedConfigurable.stories.js +109 -109
  276. package/src/components/BaseLayoutStackedConfigurable.vue +158 -158
  277. package/src/components/BaseLoadingCover.stories.js +55 -55
  278. package/src/components/BaseLoadingCover.vue +101 -101
  279. package/src/components/BaseMediaGallery.vue +96 -96
  280. package/src/components/BaseMediaGalleryItem.vue +101 -101
  281. package/src/components/BaseMediaItem.stories.js +41 -41
  282. package/src/components/BaseMediaItem.vue +80 -80
  283. package/src/components/BaseMediaLibrary.stories.js +267 -262
  284. package/src/components/BaseMediaLibrary.vue +323 -318
  285. package/src/components/BaseMediaList.vue +68 -68
  286. package/src/components/BaseMediaListItem.vue +181 -181
  287. package/src/components/BaseMediaPictures.vue +64 -64
  288. package/src/components/BaseMediaPicturesItem.vue +100 -100
  289. package/src/components/BaseMediaPreview.stories.js +72 -72
  290. package/src/components/BaseMediaPreview.vue +106 -106
  291. package/src/components/BaseMenu.stories.js +125 -125
  292. package/src/components/BaseMenu.vue +165 -165
  293. package/src/components/BaseMenuItem.vue +118 -118
  294. package/src/components/BaseModalCenter.stories.js +68 -68
  295. package/src/components/BaseModalCenter.vue +134 -134
  296. package/src/components/BaseModalSide.stories.js +55 -55
  297. package/src/components/BaseModalSide.vue +122 -122
  298. package/src/components/BaseNavbar.stories.js +151 -151
  299. package/src/components/BaseNavbar.vue +91 -91
  300. package/src/components/BaseNavbarItem.vue +49 -49
  301. package/src/components/BaseNavbarItemContent.vue +97 -97
  302. package/src/components/BaseNavbarSideItem.vue +114 -114
  303. package/src/components/BaseNavbarSideItemContent.vue +111 -111
  304. package/src/components/BasePagination.stories.js +35 -35
  305. package/src/components/BasePagination.vue +266 -266
  306. package/src/components/BasePanel.stories.js +56 -56
  307. package/src/components/BasePanel.vue +42 -42
  308. package/src/components/BasePassword.stories.js +57 -57
  309. package/src/components/BasePassword.vue +107 -107
  310. package/src/components/BaseProgressCircle.stories.js +27 -27
  311. package/src/components/BaseProgressCircle.vue +80 -80
  312. package/src/components/BaseRadioGroup.stories.js +88 -88
  313. package/src/components/BaseRadioGroup.vue +125 -125
  314. package/src/components/BaseReadMore.stories.js +30 -30
  315. package/src/components/BaseReadMore.vue +73 -73
  316. package/src/components/BaseRichText.stories.js +102 -102
  317. package/src/components/BaseRichText.vue +182 -182
  318. package/src/components/BaseSelect.stories.js +118 -118
  319. package/src/components/BaseSelect.vue +224 -224
  320. package/src/components/BaseShortcut.stories.js +102 -102
  321. package/src/components/BaseShortcut.vue +112 -112
  322. package/src/components/BaseSideNavigation.stories.js +80 -80
  323. package/src/components/BaseSideNavigation.vue +32 -32
  324. package/src/components/BaseSideNavigationItem.vue +95 -95
  325. package/src/components/BaseSkeleton.stories.js +36 -36
  326. package/src/components/BaseSkeleton.vue +40 -40
  327. package/src/components/BaseStatistic.stories.js +51 -51
  328. package/src/components/BaseStatistic.vue +109 -109
  329. package/src/components/BaseStepper.stories.js +94 -94
  330. package/src/components/BaseStepper.vue +72 -72
  331. package/src/components/BaseStepperItem.stories.js +65 -65
  332. package/src/components/BaseStepperItem.vue +149 -149
  333. package/src/components/BaseSwitch.stories.js +130 -130
  334. package/src/components/BaseSwitch.vue +215 -215
  335. package/src/components/BaseSystemAlert.stories.js +63 -63
  336. package/src/components/BaseSystemAlert.vue +89 -89
  337. package/src/components/BaseTabItem.vue +96 -96
  338. package/src/components/BaseTable.vue +890 -890
  339. package/src/components/BaseTableColumn.vue +124 -124
  340. package/src/components/BaseTabs.stories.js +85 -85
  341. package/src/components/BaseTabs.vue +73 -73
  342. package/src/components/BaseTagAutocomplete.stories.js +258 -258
  343. package/src/components/BaseTagAutocomplete.vue +438 -438
  344. package/src/components/BaseTagAutocompleteFetch.stories.js +185 -185
  345. package/src/components/BaseTagAutocompleteFetch.vue +220 -220
  346. package/src/components/BaseTextarea.stories.js +58 -58
  347. package/src/components/BaseTextarea.vue +103 -103
  348. package/src/components/BaseTextareaAutoresize.stories.js +102 -102
  349. package/src/components/BaseTextareaAutoresize.vue +166 -166
  350. package/src/components/BaseTimeline.stories.js +53 -53
  351. package/src/components/BaseTimeline.vue +35 -35
  352. package/src/components/BaseTimelineItem.stories.js +78 -78
  353. package/src/components/BaseTimelineItem.vue +79 -79
  354. package/src/components/BaseUniqueCode.stories.js +36 -36
  355. package/src/components/BaseUniqueCode.vue +183 -183
  356. package/src/components/SlotComponent.ts +37 -37
  357. package/src/components/index.ts +194 -194
  358. package/src/composables/breakpoints.ts +94 -94
  359. package/src/composables/clickOutside.ts +80 -80
  360. package/src/composables/field.ts +117 -117
  361. package/src/composables/hasOptions.ts +68 -68
  362. package/src/composables/mediaQuery.ts +42 -42
  363. package/src/composables/modal.ts +73 -73
  364. package/src/composables/paginatedData.ts +65 -65
  365. package/src/constants/MyConstants.ts +1 -1
  366. package/src/constants/index.ts +5 -5
  367. package/src/env.d.ts +15 -15
  368. package/src/i18n/index.ts +60 -60
  369. package/src/index.ts +111 -111
  370. package/src/lang/en.json +1 -1
  371. package/src/lang/fr.json +1 -1
  372. package/src/services/gantt/format.ts +113 -113
  373. package/src/services/gantt/timescale.ts +242 -242
  374. package/src/services/gantt/types.ts +74 -74
  375. package/src/stores/dialogs.ts +45 -45
  376. package/src/stores/i18n.ts +14 -14
  377. package/src/stores/notifications.ts +47 -47
  378. package/src/stores/systemAlerts.ts +33 -33
  379. package/src/svg/BaseEmptyState.vue +38 -38
  380. package/src/svg/BaseSpinnerLarge.vue +59 -59
  381. package/src/svg/BaseSpinnerSmall.vue +15 -15
  382. package/src/types/Color.ts +9 -9
  383. package/src/types/Country.ts +4 -4
  384. package/src/types/ImagePickerResult.ts +5 -5
  385. package/src/types/Media.ts +10 -10
  386. package/src/types/Notification.ts +10 -10
  387. package/src/types/Region.ts +5 -5
  388. package/src/types/Status.ts +5 -5
  389. package/src/types/StepperItem.ts +8 -8
  390. package/src/types/TimelineItem.ts +8 -8
  391. package/src/types/UploadedFile.ts +11 -11
  392. package/src/types/User.ts +7 -7
  393. package/src/types/index.ts +267 -267
  394. package/src/utils/blob.ts +30 -30
  395. package/src/utils/colors.ts +200 -200
  396. package/src/utils/cropper/avatar.ts +33 -33
  397. package/src/utils/cropper/cover.ts +41 -41
  398. package/src/utils/cropper/presetInterface.ts +16 -16
  399. package/src/utils/cropper/presets.ts +7 -7
  400. package/src/utils/fileSizeFormat.ts +15 -15
  401. package/src/utils/fileValidations.ts +26 -26
  402. package/src/utils/index.ts +16 -16
  403. package/src/utils/resizeImageFromURI.ts +118 -118
  404. package/src/utils/scrollPreventer.ts +11 -11
  405. package/src/utils/toHumanList.ts +20 -20
@@ -1,318 +1,323 @@
1
- <template>
2
- <div>
3
- <BaseFileUploader
4
- :component="pickerComponent"
5
- :max-size="maxSize"
6
- :disabled="disabled"
7
- class="w-full"
8
- tw-button="w-full"
9
- :accept="accept"
10
- :accepted-extensions="acceptedExtensions"
11
- :url="uploadUrl"
12
- :cropper="pickerComponent == 'BaseFilePickerCrop' ? cropper : undefined"
13
- @upload:start="onUploadStart"
14
- @upload:end="onUploadEnd"
15
- @upload:fail="$emit('upload:fail', $event)"
16
- @upload:success="onUploadSuccess"
17
- >
18
- <template #default="baseFileUploaderProps">
19
- <slot
20
- name="default"
21
- v-bind="baseFileUploaderProps"
22
- :max-size="maxSize"
23
- :max="normalizedMax"
24
- >
25
- <div
26
- class="rounded border border-dashed p-6 duration-150"
27
- :class="[
28
- baseFileUploaderProps.dragging ? 'bg-blue-100' : 'bg-white',
29
- baseFileUploaderProps.disabled
30
- ? 'cursor-not-allowed border-slate-300'
31
- : 'border-slate-300 hover:bg-slate-100',
32
- ]"
33
- >
34
- <div :class="[baseFileUploaderProps.disabled ? 'opacity-30' : '']">
35
- <BaseIcon
36
- icon="heroicons:arrow-up-on-square"
37
- class="mx-auto mb-3 h-6 w-6 text-slate-500"
38
- />
39
- <div class="text-center">
40
- <p class="mb-0 text-sm font-medium leading-tight">
41
- {{ t('sui.drop_or_click_to_upload') }}
42
- </p>
43
-
44
- <div class="mt-1 text-xs leading-tight text-slate-500">
45
- <p v-if="maxFileText">
46
- {{ maxFileText }}
47
- </p>
48
- <p>{{ maxFileSize }}</p>
49
- </div>
50
- </div>
51
- </div>
52
- </div>
53
- </slot>
54
- </template>
55
- </BaseFileUploader>
56
-
57
- <div
58
- v-if="normalizedModelValue.length"
59
- class="mt-5"
60
- >
61
- <slot
62
- :model-value="normalizedModelValue"
63
- name="list"
64
- :disabled="disabled"
65
- :draggable="draggable"
66
- :remove="promptRemove"
67
- @update:model-value="sync"
68
- >
69
- <BaseMediaPictures
70
- v-if="layout == 'images'"
71
- v-bind="listProps"
72
- :model-value="normalizedModelValue"
73
- :disabled="disabled"
74
- :draggable="draggable"
75
- @update:model-value="sync"
76
- @remove="promptRemove($event)"
77
- />
78
-
79
- <BaseMediaList
80
- v-else-if="layout == 'list'"
81
- v-bind="listProps"
82
- :model-value="normalizedModelValue"
83
- :disabled="disabled"
84
- :draggable="draggable"
85
- @update:model-value="sync"
86
- @remove="promptRemove($event)"
87
- />
88
-
89
- <BaseMediaGallery
90
- v-else-if="layout == 'gallery'"
91
- v-bind="listProps"
92
- :model-value="normalizedModelValue"
93
- :disabled="disabled"
94
- :draggable="draggable"
95
- @update:model-value="sync"
96
- @remove="promptRemove($event)"
97
- />
98
- </slot>
99
- </div>
100
- </div>
101
- </template>
102
-
103
- <script lang="ts" setup>
104
- import { PropType } from 'vue';
105
- import { cloneDeep, isArray, capitalize } from 'lodash';
106
- import { UploadedFile } from '@/types/UploadedFile';
107
- import { Media } from '@/types/Media';
108
- import { BaseCropperConfig, MediaLibraryPayload } from '@/types';
109
- import { fileSizeFormat } from '@/utils';
110
- import { useDialogsStore } from '@/stores/dialogs';
111
- import { useNotificationsStore } from '@/stores/notifications';
112
- import BaseFileUploader from './BaseFileUploader.vue';
113
- import { useField } from '@/composables/field';
114
- import { BaseIcon } from '.';
115
- import BaseMediaList from './BaseMediaList.vue';
116
- import BaseMediaPictures from './BaseMediaPictures.vue';
117
- import BaseMediaGallery from './BaseMediaGallery.vue';
118
- import { t } from '@/i18n';
119
-
120
- const dialogs = useDialogsStore();
121
- const notifications = useNotificationsStore();
122
-
123
- const props = defineProps({
124
- modelValue: {
125
- default: undefined,
126
- type: Object as PropType<MediaLibraryPayload>,
127
- },
128
- name: {
129
- default: undefined,
130
- type: String,
131
- },
132
- min: {
133
- type: Number,
134
- default: undefined,
135
- },
136
- max: {
137
- default: undefined,
138
- type: Number,
139
- },
140
- maxSize: {
141
- default: 20 * 1024 * 1024,
142
- type: Number,
143
- },
144
- accept: {
145
- default: undefined,
146
- type: String,
147
- },
148
- acceptedExtensions: {
149
- default: undefined,
150
- type: Array as PropType<string[]>,
151
- },
152
- currentMedia: {
153
- default() {
154
- return [];
155
- },
156
- type: Array as PropType<Media[]>,
157
- },
158
- uploadUrl: {
159
- default: undefined,
160
- type: String,
161
- },
162
- hasError: {
163
- default: false,
164
- type: Boolean,
165
- },
166
- disabled: {
167
- default: false,
168
- type: Boolean,
169
- },
170
- pickerComponent: {
171
- default: 'BaseFilePicker',
172
- type: String as PropType<'BaseFilePicker' | 'BaseFilePickerCrop'>,
173
- },
174
- cropper: {
175
- default: undefined,
176
- type: Object as PropType<BaseCropperConfig | boolean | null>,
177
- },
178
- draggable: {
179
- default: false,
180
- type: Boolean,
181
- },
182
- listProps: {
183
- default: undefined,
184
- type: Object as PropType<Record<string, unknown>>,
185
- },
186
- layout: {
187
- default: 'gallery',
188
- type: String as PropType<'list' | 'images' | 'gallery'>,
189
- },
190
- });
191
-
192
- const emit = defineEmits([
193
- 'update:modelValue',
194
- 'upload:start',
195
- 'upload:success',
196
- 'upload:fail',
197
- 'upload:end',
198
- ]);
199
-
200
- const { emitUpdate, enableForm, disableForm } = useField({
201
- name: computed(() => props.name),
202
- required: computed(() => false),
203
- hasError: computed(() => props.hasError),
204
- emit: emit,
205
- errorType: 'alert',
206
- });
207
-
208
- // Model value normalization
209
-
210
- const normalizedModelValue = computed(() => {
211
- if (!isArray(props.modelValue)) {
212
- return [];
213
- }
214
-
215
- return props.modelValue;
216
- });
217
-
218
- sync(normalizedModelValue.value);
219
-
220
- const numberOfFiles = computed((): number => {
221
- return normalizedModelValue.value.length;
222
- });
223
-
224
- // Validations
225
-
226
- const normalizedMax = computed(() => {
227
- if (props.max == null) {
228
- return 100;
229
- }
230
-
231
- return props.max;
232
- });
233
-
234
- const maxFileText = computed(() => {
235
- return t('sui.you_can_upload_up_to_n_files', {
236
- count: normalizedMax.value,
237
- });
238
- });
239
-
240
- const maxFileSize = computed(() => {
241
- return capitalize(t('sui.up_to_x', { x: fileSizeFormat(props.maxSize) }));
242
- });
243
-
244
- // Upload
245
-
246
- function onUploadSuccess(file: UploadedFile) {
247
- if (file == null) {
248
- return;
249
- }
250
-
251
- if (
252
- normalizedMax.value &&
253
- numberOfFiles.value >= normalizedMax.value &&
254
- normalizedMax.value > 1
255
- ) {
256
- notifications.push({
257
- title: t('sui.whoops'),
258
- text: t('sui.you_can_upload_up_to_n_files', {
259
- count: normalizedMax.value,
260
- }),
261
- color: 'danger',
262
- });
263
- return;
264
- }
265
-
266
- let modelValue = cloneDeep(normalizedModelValue.value);
267
-
268
- if (normalizedMax.value == 1) {
269
- // Remove everything...
270
- modelValue = [];
271
- }
272
-
273
- modelValue.push(file);
274
-
275
- sync(modelValue);
276
-
277
- emit('upload:success', file);
278
- }
279
-
280
- // Remove
281
-
282
- function promptRemove(index: number, length = 1) {
283
- dialogs.push({
284
- title: t('sui.remove_file'),
285
- message: t('sui.remove_file_description'),
286
- color: 'warning',
287
- onConfirm() {
288
- removeByIndex(index, length);
289
- },
290
- });
291
- }
292
-
293
- function removeByIndex(index: number, length = 1) {
294
- const modelValue = cloneDeep(normalizedModelValue.value);
295
-
296
- modelValue.splice(index, length);
297
-
298
- sync(modelValue);
299
- }
300
-
301
- // Sync
302
-
303
- function sync(modelValue: MediaLibraryPayload) {
304
- emitUpdate(modelValue);
305
- }
306
-
307
- // Events
308
-
309
- function onUploadStart(event: any) {
310
- emit('upload:start', event);
311
- disableForm();
312
- }
313
-
314
- function onUploadEnd(event: any) {
315
- emit('upload:end', event);
316
- enableForm();
317
- }
318
- </script>
1
+ <template>
2
+ <div>
3
+ <BaseFileUploader
4
+ :component="pickerComponent"
5
+ :max-size="maxSize"
6
+ :disabled="disabled"
7
+ class="w-full"
8
+ tw-button="w-full"
9
+ :accept="accept"
10
+ :accepted-extensions="acceptedExtensions"
11
+ :url="uploadUrl"
12
+ :multiple="multiple"
13
+ :cropper="pickerComponent == 'BaseFilePickerCrop' ? cropper : undefined"
14
+ @upload:start="onUploadStart"
15
+ @upload:end="onUploadEnd"
16
+ @upload:fail="$emit('upload:fail', $event)"
17
+ @upload:success="onUploadSuccess"
18
+ >
19
+ <template #default="baseFileUploaderProps">
20
+ <slot
21
+ name="default"
22
+ v-bind="baseFileUploaderProps"
23
+ :max-size="maxSize"
24
+ :max="normalizedMax"
25
+ >
26
+ <div
27
+ class="rounded border border-dashed p-6 duration-150"
28
+ :class="[
29
+ baseFileUploaderProps.dragging ? 'bg-blue-100' : 'bg-white',
30
+ baseFileUploaderProps.disabled
31
+ ? 'cursor-not-allowed border-slate-300'
32
+ : 'border-slate-300 hover:bg-slate-100',
33
+ ]"
34
+ >
35
+ <div :class="[baseFileUploaderProps.disabled ? 'opacity-30' : '']">
36
+ <BaseIcon
37
+ icon="heroicons:arrow-up-on-square"
38
+ class="mx-auto mb-3 h-6 w-6 text-slate-500"
39
+ />
40
+ <div class="text-center">
41
+ <p class="mb-0 text-sm font-medium leading-tight">
42
+ {{ t('sui.drop_or_click_to_upload') }}
43
+ </p>
44
+
45
+ <div class="mt-1 text-xs leading-tight text-slate-500">
46
+ <p v-if="maxFileText">
47
+ {{ maxFileText }}
48
+ </p>
49
+ <p>{{ maxFileSize }}</p>
50
+ </div>
51
+ </div>
52
+ </div>
53
+ </div>
54
+ </slot>
55
+ </template>
56
+ </BaseFileUploader>
57
+
58
+ <div
59
+ v-if="normalizedModelValue.length"
60
+ class="mt-5"
61
+ >
62
+ <slot
63
+ :model-value="normalizedModelValue"
64
+ name="list"
65
+ :disabled="disabled"
66
+ :draggable="draggable"
67
+ :remove="promptRemove"
68
+ @update:model-value="sync"
69
+ >
70
+ <BaseMediaPictures
71
+ v-if="layout == 'images'"
72
+ v-bind="listProps"
73
+ :model-value="normalizedModelValue"
74
+ :disabled="disabled"
75
+ :draggable="draggable"
76
+ @update:model-value="sync"
77
+ @remove="promptRemove($event)"
78
+ />
79
+
80
+ <BaseMediaList
81
+ v-else-if="layout == 'list'"
82
+ v-bind="listProps"
83
+ :model-value="normalizedModelValue"
84
+ :disabled="disabled"
85
+ :draggable="draggable"
86
+ @update:model-value="sync"
87
+ @remove="promptRemove($event)"
88
+ />
89
+
90
+ <BaseMediaGallery
91
+ v-else-if="layout == 'gallery'"
92
+ v-bind="listProps"
93
+ :model-value="normalizedModelValue"
94
+ :disabled="disabled"
95
+ :draggable="draggable"
96
+ @update:model-value="sync"
97
+ @remove="promptRemove($event)"
98
+ />
99
+ </slot>
100
+ </div>
101
+ </div>
102
+ </template>
103
+
104
+ <script lang="ts" setup>
105
+ import { PropType } from 'vue';
106
+ import { cloneDeep, isArray, capitalize } from 'lodash';
107
+ import { UploadedFile } from '@/types/UploadedFile';
108
+ import { Media } from '@/types/Media';
109
+ import { BaseCropperConfig, MediaLibraryPayload } from '@/types';
110
+ import { fileSizeFormat } from '@/utils';
111
+ import { useDialogsStore } from '@/stores/dialogs';
112
+ import { useNotificationsStore } from '@/stores/notifications';
113
+ import BaseFileUploader from './BaseFileUploader.vue';
114
+ import { useField } from '@/composables/field';
115
+ import { BaseIcon } from '.';
116
+ import BaseMediaList from './BaseMediaList.vue';
117
+ import BaseMediaPictures from './BaseMediaPictures.vue';
118
+ import BaseMediaGallery from './BaseMediaGallery.vue';
119
+ import { t } from '@/i18n';
120
+
121
+ const dialogs = useDialogsStore();
122
+ const notifications = useNotificationsStore();
123
+
124
+ const props = defineProps({
125
+ modelValue: {
126
+ default: undefined,
127
+ type: Object as PropType<MediaLibraryPayload>,
128
+ },
129
+ name: {
130
+ default: undefined,
131
+ type: String,
132
+ },
133
+ min: {
134
+ type: Number,
135
+ default: undefined,
136
+ },
137
+ max: {
138
+ default: undefined,
139
+ type: Number,
140
+ },
141
+ maxSize: {
142
+ default: 20 * 1024 * 1024,
143
+ type: Number,
144
+ },
145
+ accept: {
146
+ default: undefined,
147
+ type: String,
148
+ },
149
+ acceptedExtensions: {
150
+ default: undefined,
151
+ type: Array as PropType<string[]>,
152
+ },
153
+ currentMedia: {
154
+ default() {
155
+ return [];
156
+ },
157
+ type: Array as PropType<Media[]>,
158
+ },
159
+ uploadUrl: {
160
+ default: undefined,
161
+ type: String,
162
+ },
163
+ hasError: {
164
+ default: false,
165
+ type: Boolean,
166
+ },
167
+ disabled: {
168
+ default: false,
169
+ type: Boolean,
170
+ },
171
+ pickerComponent: {
172
+ default: 'BaseFilePicker',
173
+ type: String as PropType<'BaseFilePicker' | 'BaseFilePickerCrop'>,
174
+ },
175
+ cropper: {
176
+ default: undefined,
177
+ type: Object as PropType<BaseCropperConfig | boolean | null>,
178
+ },
179
+ draggable: {
180
+ default: false,
181
+ type: Boolean,
182
+ },
183
+ multiple: {
184
+ default: false,
185
+ type: Boolean,
186
+ },
187
+ listProps: {
188
+ default: undefined,
189
+ type: Object as PropType<Record<string, unknown>>,
190
+ },
191
+ layout: {
192
+ default: 'gallery',
193
+ type: String as PropType<'list' | 'images' | 'gallery'>,
194
+ },
195
+ });
196
+
197
+ const emit = defineEmits([
198
+ 'update:modelValue',
199
+ 'upload:start',
200
+ 'upload:success',
201
+ 'upload:fail',
202
+ 'upload:end',
203
+ ]);
204
+
205
+ const { emitUpdate, enableForm, disableForm } = useField({
206
+ name: computed(() => props.name),
207
+ required: computed(() => false),
208
+ hasError: computed(() => props.hasError),
209
+ emit: emit,
210
+ errorType: 'alert',
211
+ });
212
+
213
+ // Model value normalization
214
+
215
+ const normalizedModelValue = computed(() => {
216
+ if (!isArray(props.modelValue)) {
217
+ return [];
218
+ }
219
+
220
+ return props.modelValue;
221
+ });
222
+
223
+ sync(normalizedModelValue.value);
224
+
225
+ const numberOfFiles = computed((): number => {
226
+ return normalizedModelValue.value.length;
227
+ });
228
+
229
+ // Validations
230
+
231
+ const normalizedMax = computed(() => {
232
+ if (props.max == null) {
233
+ return 100;
234
+ }
235
+
236
+ return props.max;
237
+ });
238
+
239
+ const maxFileText = computed(() => {
240
+ return t('sui.you_can_upload_up_to_n_files', {
241
+ count: normalizedMax.value,
242
+ });
243
+ });
244
+
245
+ const maxFileSize = computed(() => {
246
+ return capitalize(t('sui.up_to_x', { x: fileSizeFormat(props.maxSize) }));
247
+ });
248
+
249
+ // Upload
250
+
251
+ function onUploadSuccess(file: UploadedFile) {
252
+ if (file == null) {
253
+ return;
254
+ }
255
+
256
+ if (
257
+ normalizedMax.value &&
258
+ numberOfFiles.value >= normalizedMax.value &&
259
+ normalizedMax.value > 1
260
+ ) {
261
+ notifications.push({
262
+ title: t('sui.whoops'),
263
+ text: t('sui.you_can_upload_up_to_n_files', {
264
+ count: normalizedMax.value,
265
+ }),
266
+ color: 'danger',
267
+ });
268
+ return;
269
+ }
270
+
271
+ let modelValue = cloneDeep(normalizedModelValue.value);
272
+
273
+ if (normalizedMax.value == 1) {
274
+ // Remove everything...
275
+ modelValue = [];
276
+ }
277
+
278
+ modelValue.push(file);
279
+
280
+ sync(modelValue);
281
+
282
+ emit('upload:success', file);
283
+ }
284
+
285
+ // Remove
286
+
287
+ function promptRemove(index: number, length = 1) {
288
+ dialogs.push({
289
+ title: t('sui.remove_file'),
290
+ message: t('sui.remove_file_description'),
291
+ color: 'warning',
292
+ onConfirm() {
293
+ removeByIndex(index, length);
294
+ },
295
+ });
296
+ }
297
+
298
+ function removeByIndex(index: number, length = 1) {
299
+ const modelValue = cloneDeep(normalizedModelValue.value);
300
+
301
+ modelValue.splice(index, length);
302
+
303
+ sync(modelValue);
304
+ }
305
+
306
+ // Sync
307
+
308
+ function sync(modelValue: MediaLibraryPayload) {
309
+ emitUpdate(modelValue);
310
+ }
311
+
312
+ // Events
313
+
314
+ function onUploadStart(event: any) {
315
+ emit('upload:start', event);
316
+ disableForm();
317
+ }
318
+
319
+ function onUploadEnd(event: any) {
320
+ emit('upload:end', event);
321
+ enableForm();
322
+ }
323
+ </script>