sprintify-ui 0.1.17 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (395) hide show
  1. package/README.md +228 -229
  2. package/dist/sprintify-ui.es.js +15738 -13373
  3. package/dist/style.css +1 -1
  4. package/dist/tailwindcss/index.js +306 -306
  5. package/dist/types/src/components/BaseActionItem.vue.d.ts +33 -33
  6. package/dist/types/src/components/BaseActionItemButton.vue.d.ts +32 -29
  7. package/dist/types/src/components/BaseAddressForm.vue.d.ts +71 -81
  8. package/dist/types/src/components/BaseAlert.vue.d.ts +51 -51
  9. package/dist/types/src/components/BaseApp.vue.d.ts +9 -9
  10. package/dist/types/src/components/BaseAppDialogs.vue.d.ts +14 -14
  11. package/dist/types/src/components/BaseAppNotifications.vue.d.ts +2 -2
  12. package/dist/types/src/components/BaseAutocomplete.vue.d.ts +237 -232
  13. package/dist/types/src/components/BaseAutocompleteDrawer.vue.d.ts +91 -90
  14. package/dist/types/src/components/BaseAutocompleteFetch.vue.d.ts +210 -213
  15. package/dist/types/src/components/BaseAvatar.vue.d.ts +52 -52
  16. package/dist/types/src/components/BaseAvatarGroup.vue.d.ts +43 -43
  17. package/dist/types/src/components/BaseBadge.vue.d.ts +53 -50
  18. package/dist/types/src/components/BaseBelongsTo.vue.d.ts +216 -219
  19. package/dist/types/src/components/BaseBoolean.vue.d.ts +15 -15
  20. package/dist/types/src/components/BaseBreadcrumbs.vue.d.ts +14 -14
  21. package/dist/types/src/components/BaseButton.vue.d.ts +23 -23
  22. package/dist/types/src/components/BaseButtonGroup.vue.d.ts +143 -143
  23. package/dist/types/src/components/BaseCard.vue.d.ts +21 -21
  24. package/dist/types/src/components/BaseCardRow.vue.d.ts +16 -16
  25. package/dist/types/src/components/BaseCharacterCounter.vue.d.ts +49 -49
  26. package/dist/types/src/components/BaseClickOutside.vue.d.ts +26 -26
  27. package/dist/types/src/components/BaseClipboard.vue.d.ts +21 -21
  28. package/dist/types/src/components/BaseColor.vue.d.ts +80 -80
  29. package/dist/types/src/components/BaseContainer.vue.d.ts +34 -34
  30. package/dist/types/src/components/BaseCounter.vue.d.ts +42 -42
  31. package/dist/types/src/components/BaseCropper.vue.d.ts +59 -57
  32. package/dist/types/src/components/BaseCropperModal.vue.d.ts +27 -27
  33. package/dist/types/src/components/BaseDataIterator.vue.d.ts +212 -212
  34. package/dist/types/src/components/BaseDataIteratorSectionBox.vue.d.ts +23 -23
  35. package/dist/types/src/components/BaseDataIteratorSectionButton.vue.d.ts +20 -20
  36. package/dist/types/src/components/BaseDataIteratorSectionColumns.vue.d.ts +637 -665
  37. package/dist/types/src/components/BaseDataIteratorSectionModal.vue.d.ts +29 -29
  38. package/dist/types/src/components/BaseDataTable.vue.d.ts +385 -383
  39. package/dist/types/src/components/BaseDataTableRowAction.vue.d.ts +18 -18
  40. package/dist/types/src/components/BaseDatePicker.vue.d.ts +87 -84
  41. package/dist/types/src/components/BaseDateSelect.vue.d.ts +70 -70
  42. package/dist/types/src/components/BaseDescriptionList.vue.d.ts +9 -9
  43. package/dist/types/src/components/BaseDescriptionListItem.vue.d.ts +10 -10
  44. package/dist/types/src/components/BaseDialog.vue.d.ts +60 -60
  45. package/dist/types/src/components/BaseDisplayRelativeTime.vue.d.ts +68 -68
  46. package/dist/types/src/components/BaseDraggable.vue.d.ts +34 -34
  47. package/dist/types/src/components/BaseDropdown.vue.d.ts +65 -62
  48. package/dist/types/src/components/BaseDropdownAutocomplete.vue.d.ts +132 -132
  49. package/dist/types/src/components/BaseField.vue.d.ts +58 -58
  50. package/dist/types/src/components/BaseFieldI18n.vue.d.ts +93 -96
  51. package/dist/types/src/components/BaseFilePicker.vue.d.ts +62 -59
  52. package/dist/types/src/components/BaseFilePickerCrop.vue.d.ts +60 -57
  53. package/dist/types/src/components/BaseFileUploader.vue.d.ts +112 -85
  54. package/dist/types/src/components/BaseForm.vue.d.ts +134 -131
  55. package/dist/types/src/components/BaseHasMany.vue.d.ts +149 -152
  56. package/dist/types/src/components/BaseHeader.vue.d.ts +83 -80
  57. package/dist/types/src/components/BaseIconPicker.vue.d.ts +41 -38
  58. package/dist/types/src/components/BaseInput.vue.d.ts +169 -169
  59. package/dist/types/src/components/BaseInputError.vue.d.ts +9 -9
  60. package/dist/types/src/components/BaseInputLabel.vue.d.ts +43 -43
  61. package/dist/types/src/components/BaseInputPercent.vue.d.ts +133 -133
  62. package/dist/types/src/components/BaseLayoutNotificationDropdown.vue.d.ts +36 -36
  63. package/dist/types/src/components/BaseLayoutNotificationItem.vue.d.ts +16 -16
  64. package/dist/types/src/components/BaseLayoutNotificationItemContent.vue.d.ts +18 -18
  65. package/dist/types/src/components/BaseLayoutSidebar.vue.d.ts +51 -51
  66. package/dist/types/src/components/BaseLayoutSidebarConfigurable.vue.d.ts +87 -87
  67. package/dist/types/src/components/BaseLayoutStacked.vue.d.ts +23 -23
  68. package/dist/types/src/components/BaseLayoutStackedConfigurable.vue.d.ts +78 -78
  69. package/dist/types/src/components/BaseLoadingCover.vue.d.ts +96 -96
  70. package/dist/types/src/components/BaseMediaGallery.vue.d.ts +64 -64
  71. package/dist/types/src/components/BaseMediaGalleryItem.vue.d.ts +45 -45
  72. package/dist/types/src/components/BaseMediaItem.vue.d.ts +27 -27
  73. package/dist/types/src/components/BaseMediaLibrary.vue.d.ts +190 -172
  74. package/dist/types/src/components/BaseMediaList.vue.d.ts +47 -47
  75. package/dist/types/src/components/BaseMediaListItem.vue.d.ts +47 -47
  76. package/dist/types/src/components/BaseMediaPictures.vue.d.ts +55 -55
  77. package/dist/types/src/components/BaseMediaPicturesItem.vue.d.ts +54 -54
  78. package/dist/types/src/components/BaseMediaPreview.vue.d.ts +36 -36
  79. package/dist/types/src/components/BaseMenu.vue.d.ts +68 -68
  80. package/dist/types/src/components/BaseMenuItem.vue.d.ts +61 -61
  81. package/dist/types/src/components/BaseModalCenter.vue.d.ts +80 -79
  82. package/dist/types/src/components/BaseModalSide.vue.d.ts +62 -61
  83. package/dist/types/src/components/BaseNavbar.vue.d.ts +38 -35
  84. package/dist/types/src/components/BaseNavbarItem.vue.d.ts +26 -26
  85. package/dist/types/src/components/BaseNavbarItemContent.vue.d.ts +60 -60
  86. package/dist/types/src/components/BaseNavbarSideItem.vue.d.ts +44 -44
  87. package/dist/types/src/components/BaseNavbarSideItemContent.vue.d.ts +60 -60
  88. package/dist/types/src/components/BaseNumber.vue.d.ts +125 -125
  89. package/dist/types/src/components/BasePagination.vue.d.ts +35 -35
  90. package/dist/types/src/components/BasePanel.vue.d.ts +31 -31
  91. package/dist/types/src/components/BasePassword.vue.d.ts +62 -62
  92. package/dist/types/src/components/BaseProgressCircle.vue.d.ts +37 -37
  93. package/dist/types/src/components/BaseRadioGroup.vue.d.ts +105 -105
  94. package/dist/types/src/components/BaseReadMore.vue.d.ts +21 -21
  95. package/dist/types/src/components/BaseRichText.vue.d.ts +92 -92
  96. package/dist/types/src/components/BaseSelect.vue.d.ts +98 -97
  97. package/dist/types/src/components/BaseShortcut.vue.d.ts +86 -86
  98. package/dist/types/src/components/BaseSideNavigation.vue.d.ts +36 -33
  99. package/dist/types/src/components/BaseSideNavigationItem.vue.d.ts +46 -43
  100. package/dist/types/src/components/BaseSkeleton.vue.d.ts +31 -30
  101. package/dist/types/src/components/BaseStatistic.vue.d.ts +56 -56
  102. package/dist/types/src/components/BaseStepper.vue.d.ts +16 -16
  103. package/dist/types/src/components/BaseStepperItem.vue.d.ts +51 -51
  104. package/dist/types/src/components/BaseSwitch.vue.d.ts +87 -87
  105. package/dist/types/src/components/BaseSystemAlert.vue.d.ts +52 -52
  106. package/dist/types/src/components/BaseTabItem.vue.d.ts +46 -43
  107. package/dist/types/src/components/BaseTable.vue.d.ts +212 -212
  108. package/dist/types/src/components/BaseTableColumn.vue.d.ts +174 -174
  109. package/dist/types/src/components/BaseTabs.vue.d.ts +36 -33
  110. package/dist/types/src/components/BaseTagAutocomplete.vue.d.ts +209 -204
  111. package/dist/types/src/components/BaseTagAutocompleteFetch.vue.d.ts +141 -144
  112. package/dist/types/src/components/BaseTextarea.vue.d.ts +98 -98
  113. package/dist/types/src/components/BaseTextareaAutoresize.vue.d.ts +108 -98
  114. package/dist/types/src/components/BaseTimeline.vue.d.ts +14 -14
  115. package/dist/types/src/components/BaseTimelineItem.vue.d.ts +14 -14
  116. package/dist/types/src/components/SlotComponent.d.ts +43 -43
  117. package/dist/types/src/components/index.d.ts +93 -93
  118. package/dist/types/src/composables/breakpoints.d.ts +27 -27
  119. package/dist/types/src/composables/clickOutside.d.ts +8 -8
  120. package/dist/types/src/composables/field.d.ts +19 -19
  121. package/dist/types/src/composables/hasOptions.d.ts +7 -7
  122. package/dist/types/src/composables/mediaQuery.d.ts +2 -2
  123. package/dist/types/src/composables/modal.d.ts +6 -6
  124. package/dist/types/src/composables/paginatedData.d.ts +7 -7
  125. package/dist/types/src/constants/MyConstants.d.ts +1 -1
  126. package/dist/types/src/constants/index.d.ts +2 -2
  127. package/dist/types/src/i18n/index.d.ts +1 -1
  128. package/dist/types/src/index.d.ts +220 -220
  129. package/dist/types/src/stores/dialogs.d.ts +9 -9
  130. package/dist/types/src/stores/i18n.d.ts +5 -5
  131. package/dist/types/src/stores/notifications.d.ts +10 -10
  132. package/dist/types/src/stores/systemAlerts.d.ts +9 -9
  133. package/dist/types/src/svg/BaseEmptyState.vue.d.ts +2 -2
  134. package/dist/types/src/svg/BaseSpinnerLarge.vue.d.ts +2 -2
  135. package/dist/types/src/svg/BaseSpinnerSmall.vue.d.ts +2 -2
  136. package/dist/types/src/types/Color.d.ts +9 -9
  137. package/dist/types/src/types/Country.d.ts +4 -4
  138. package/dist/types/src/types/ImagePickerResult.d.ts +5 -5
  139. package/dist/types/src/types/Media.d.ts +9 -9
  140. package/dist/types/src/types/Notification.d.ts +8 -8
  141. package/dist/types/src/types/Region.d.ts +5 -5
  142. package/dist/types/src/types/Status.d.ts +5 -5
  143. package/dist/types/src/types/StepperItem.d.ts +7 -7
  144. package/dist/types/src/types/TimelineItem.d.ts +8 -8
  145. package/dist/types/src/types/UploadedFile.d.ts +10 -10
  146. package/dist/types/src/types/User.d.ts +6 -6
  147. package/dist/types/src/types/index.d.ts +218 -218
  148. package/dist/types/src/utils/blob.d.ts +3 -3
  149. package/dist/types/src/utils/colors.d.ts +13 -13
  150. package/dist/types/src/utils/cropper/avatar.d.ts +5 -5
  151. package/dist/types/src/utils/cropper/cover.d.ts +5 -5
  152. package/dist/types/src/utils/cropper/presetInterface.d.ts +7 -7
  153. package/dist/types/src/utils/cropper/presets.d.ts +6 -6
  154. package/dist/types/src/utils/fileSizeFormat.d.ts +1 -1
  155. package/dist/types/src/utils/fileValidations.d.ts +2 -2
  156. package/dist/types/src/utils/index.d.ts +6 -6
  157. package/dist/types/src/utils/resizeImageFromURI.d.ts +1 -1
  158. package/dist/types/src/utils/scrollPreventer.d.ts +3 -3
  159. package/dist/types/src/utils/toHumanList.d.ts +1 -1
  160. package/package.json +138 -139
  161. package/src/assets/form.css +6 -6
  162. package/src/assets/main.css +35 -35
  163. package/src/assets/tailwind.css +2 -2
  164. package/src/components/BaseActionItem.vue +63 -63
  165. package/src/components/BaseActionItemButton.vue +75 -75
  166. package/src/components/BaseAddressForm.stories.js +103 -103
  167. package/src/components/BaseAddressForm.vue +353 -353
  168. package/src/components/BaseAlert.stories.js +52 -52
  169. package/src/components/BaseAlert.vue +152 -152
  170. package/src/components/BaseApp.vue +16 -16
  171. package/src/components/BaseAppDialogs.vue +124 -124
  172. package/src/components/BaseAppNotifications.vue +73 -73
  173. package/src/components/BaseAutocomplete.stories.js +236 -236
  174. package/src/components/BaseAutocomplete.vue +514 -514
  175. package/src/components/BaseAutocompleteDrawer.vue +354 -354
  176. package/src/components/BaseAutocompleteFetch.stories.js +224 -224
  177. package/src/components/BaseAutocompleteFetch.vue +277 -277
  178. package/src/components/BaseAvatar.stories.js +39 -39
  179. package/src/components/BaseAvatar.vue +120 -120
  180. package/src/components/BaseAvatarGroup.stories.js +71 -71
  181. package/src/components/BaseAvatarGroup.vue +148 -148
  182. package/src/components/BaseBadge.stories.js +124 -124
  183. package/src/components/BaseBadge.vue +79 -79
  184. package/src/components/BaseBelongsTo.stories.js +223 -223
  185. package/src/components/BaseBelongsTo.vue +184 -184
  186. package/src/components/BaseBoolean.stories.js +35 -35
  187. package/src/components/BaseBoolean.vue +26 -26
  188. package/src/components/BaseBreadcrumbs.stories.js +45 -45
  189. package/src/components/BaseBreadcrumbs.vue +98 -98
  190. package/src/components/BaseButton.stories.js +88 -88
  191. package/src/components/BaseButton.vue +39 -39
  192. package/src/components/BaseButtonGroup.stories.js +86 -85
  193. package/src/components/BaseButtonGroup.vue +147 -147
  194. package/src/components/BaseCard.stories.js +61 -61
  195. package/src/components/BaseCard.vue +49 -49
  196. package/src/components/BaseCardRow.vue +34 -34
  197. package/src/components/BaseCharacterCounter.stories.js +30 -30
  198. package/src/components/BaseCharacterCounter.vue +61 -61
  199. package/src/components/BaseClickOutside.vue +37 -37
  200. package/src/components/BaseClipboard.stories.js +31 -31
  201. package/src/components/BaseClipboard.vue +96 -96
  202. package/src/components/BaseColor.stories.js +46 -46
  203. package/src/components/BaseColor.vue +151 -151
  204. package/src/components/BaseContainer.stories.js +34 -34
  205. package/src/components/BaseContainer.vue +50 -50
  206. package/src/components/BaseCounter.stories.js +47 -47
  207. package/src/components/BaseCounter.vue +82 -82
  208. package/src/components/BaseCropper.stories.js +113 -113
  209. package/src/components/BaseCropper.vue +446 -446
  210. package/src/components/BaseCropperModal.stories.js +54 -54
  211. package/src/components/BaseCropperModal.vue +140 -140
  212. package/src/components/BaseDataIterator.stories.js +197 -197
  213. package/src/components/BaseDataIterator.vue +784 -777
  214. package/src/components/BaseDataIteratorSectionBox.vue +33 -33
  215. package/src/components/BaseDataIteratorSectionButton.vue +40 -40
  216. package/src/components/BaseDataIteratorSectionColumns.vue +67 -67
  217. package/src/components/BaseDataIteratorSectionModal.vue +41 -41
  218. package/src/components/BaseDataTable.stories.js +341 -341
  219. package/src/components/BaseDataTable.vue +724 -724
  220. package/src/components/BaseDataTableRowAction.vue +28 -28
  221. package/src/components/BaseDatePicker.stories.js +130 -130
  222. package/src/components/BaseDatePicker.vue +374 -374
  223. package/src/components/BaseDateSelect.stories.js +47 -47
  224. package/src/components/BaseDateSelect.vue +209 -209
  225. package/src/components/BaseDescriptionList.stories.js +35 -35
  226. package/src/components/BaseDescriptionList.vue +13 -13
  227. package/src/components/BaseDescriptionListItem.vue +47 -47
  228. package/src/components/BaseDialog.stories.js +51 -51
  229. package/src/components/BaseDialog.vue +119 -119
  230. package/src/components/BaseDisplayRelativeTime.stories.js +59 -59
  231. package/src/components/BaseDisplayRelativeTime.vue +120 -120
  232. package/src/components/BaseDraggable.vue +71 -71
  233. package/src/components/BaseDropdown.stories.js +210 -210
  234. package/src/components/BaseDropdown.vue +269 -269
  235. package/src/components/BaseDropdownAutocomplete.stories.js +187 -187
  236. package/src/components/BaseDropdownAutocomplete.vue +232 -230
  237. package/src/components/BaseField.vue +109 -109
  238. package/src/components/BaseFieldI18n.stories.js +38 -38
  239. package/src/components/BaseFieldI18n.vue +162 -162
  240. package/src/components/BaseFilePicker.stories.js +78 -78
  241. package/src/components/BaseFilePicker.vue +132 -132
  242. package/src/components/BaseFilePickerCrop.stories.js +134 -134
  243. package/src/components/BaseFilePickerCrop.vue +127 -127
  244. package/src/components/BaseFileUploader.stories.js +84 -84
  245. package/src/components/BaseFileUploader.vue +163 -163
  246. package/src/components/BaseForm.stories.js +48 -48
  247. package/src/components/BaseForm.vue +324 -323
  248. package/src/components/BaseHasMany.stories.js +189 -189
  249. package/src/components/BaseHasMany.vue +125 -125
  250. package/src/components/BaseHeader.stories.js +127 -127
  251. package/src/components/BaseHeader.vue +188 -188
  252. package/src/components/BaseIconPicker.stories.js +22 -22
  253. package/src/components/BaseIconPicker.vue +215 -215
  254. package/src/components/BaseInput.stories.js +151 -151
  255. package/src/components/BaseInput.vue +266 -266
  256. package/src/components/BaseInputError.vue +7 -7
  257. package/src/components/BaseInputLabel.stories.js +36 -36
  258. package/src/components/BaseInputLabel.vue +72 -72
  259. package/src/components/BaseInputPercent.stories.js +50 -50
  260. package/src/components/BaseInputPercent.vue +123 -123
  261. package/src/components/BaseLayoutNotificationDropdown.vue +144 -144
  262. package/src/components/BaseLayoutNotificationItem.vue +43 -43
  263. package/src/components/BaseLayoutNotificationItemContent.vue +27 -27
  264. package/src/components/BaseLayoutSidebar.vue +219 -219
  265. package/src/components/BaseLayoutSidebarConfigurable.stories.js +166 -166
  266. package/src/components/BaseLayoutSidebarConfigurable.vue +167 -167
  267. package/src/components/BaseLayoutStacked.vue +52 -52
  268. package/src/components/BaseLayoutStackedConfigurable.stories.js +109 -109
  269. package/src/components/BaseLayoutStackedConfigurable.vue +141 -141
  270. package/src/components/BaseLoadingCover.stories.js +55 -55
  271. package/src/components/BaseLoadingCover.vue +101 -94
  272. package/src/components/BaseMediaGallery.vue +93 -93
  273. package/src/components/BaseMediaGalleryItem.vue +92 -92
  274. package/src/components/BaseMediaItem.stories.js +41 -41
  275. package/src/components/BaseMediaItem.vue +71 -71
  276. package/src/components/BaseMediaLibrary.stories.js +262 -262
  277. package/src/components/BaseMediaLibrary.vue +313 -313
  278. package/src/components/BaseMediaList.vue +68 -68
  279. package/src/components/BaseMediaListItem.vue +172 -172
  280. package/src/components/BaseMediaPictures.vue +64 -64
  281. package/src/components/BaseMediaPicturesItem.vue +94 -94
  282. package/src/components/BaseMediaPreview.stories.js +72 -72
  283. package/src/components/BaseMediaPreview.vue +106 -106
  284. package/src/components/BaseMenu.stories.js +125 -125
  285. package/src/components/BaseMenu.vue +137 -129
  286. package/src/components/BaseMenuItem.vue +107 -107
  287. package/src/components/BaseModalCenter.stories.js +68 -68
  288. package/src/components/BaseModalCenter.vue +131 -125
  289. package/src/components/BaseModalSide.stories.js +55 -55
  290. package/src/components/BaseModalSide.vue +122 -116
  291. package/src/components/BaseNavbar.stories.js +151 -151
  292. package/src/components/BaseNavbar.vue +91 -91
  293. package/src/components/BaseNavbarItem.vue +49 -49
  294. package/src/components/BaseNavbarItemContent.vue +86 -86
  295. package/src/components/BaseNavbarSideItem.vue +111 -111
  296. package/src/components/BaseNavbarSideItemContent.vue +104 -104
  297. package/src/components/BaseNumber.stories.js +66 -66
  298. package/src/components/BaseNumber.vue +366 -366
  299. package/src/components/BasePagination.stories.js +35 -35
  300. package/src/components/BasePagination.vue +266 -266
  301. package/src/components/BasePanel.stories.js +56 -56
  302. package/src/components/BasePanel.vue +39 -39
  303. package/src/components/BasePassword.stories.js +41 -41
  304. package/src/components/BasePassword.vue +88 -88
  305. package/src/components/BaseProgressCircle.stories.js +27 -27
  306. package/src/components/BaseProgressCircle.vue +77 -77
  307. package/src/components/BaseRadioGroup.stories.js +88 -88
  308. package/src/components/BaseRadioGroup.vue +122 -122
  309. package/src/components/BaseReadMore.stories.js +30 -30
  310. package/src/components/BaseReadMore.vue +73 -73
  311. package/src/components/BaseRichText.stories.js +102 -102
  312. package/src/components/BaseRichText.vue +183 -183
  313. package/src/components/BaseSelect.stories.js +118 -118
  314. package/src/components/BaseSelect.vue +220 -220
  315. package/src/components/BaseShortcut.stories.js +102 -102
  316. package/src/components/BaseShortcut.vue +105 -105
  317. package/src/components/BaseSideNavigation.stories.js +80 -80
  318. package/src/components/BaseSideNavigation.vue +29 -29
  319. package/src/components/BaseSideNavigationItem.vue +92 -92
  320. package/src/components/BaseSkeleton.stories.js +36 -36
  321. package/src/components/BaseSkeleton.vue +40 -24
  322. package/src/components/BaseStatistic.stories.js +51 -51
  323. package/src/components/BaseStatistic.vue +98 -98
  324. package/src/components/BaseStepper.stories.js +94 -94
  325. package/src/components/BaseStepper.vue +69 -69
  326. package/src/components/BaseStepperItem.stories.js +65 -65
  327. package/src/components/BaseStepperItem.vue +149 -149
  328. package/src/components/BaseSwitch.stories.js +131 -131
  329. package/src/components/BaseSwitch.vue +209 -209
  330. package/src/components/BaseSystemAlert.stories.js +63 -63
  331. package/src/components/BaseSystemAlert.vue +86 -86
  332. package/src/components/BaseTabItem.vue +93 -93
  333. package/src/components/BaseTable.vue +880 -880
  334. package/src/components/BaseTableColumn.vue +124 -124
  335. package/src/components/BaseTabs.stories.js +85 -85
  336. package/src/components/BaseTabs.vue +73 -73
  337. package/src/components/BaseTagAutocomplete.stories.js +258 -258
  338. package/src/components/BaseTagAutocomplete.vue +429 -428
  339. package/src/components/BaseTagAutocompleteFetch.stories.js +185 -185
  340. package/src/components/BaseTagAutocompleteFetch.vue +206 -206
  341. package/src/components/BaseTextarea.stories.js +43 -43
  342. package/src/components/BaseTextarea.vue +87 -87
  343. package/src/components/BaseTextareaAutoresize.stories.js +87 -58
  344. package/src/components/BaseTextareaAutoresize.vue +146 -140
  345. package/src/components/BaseTimeline.stories.js +53 -53
  346. package/src/components/BaseTimeline.vue +29 -29
  347. package/src/components/BaseTimelineItem.stories.js +78 -78
  348. package/src/components/BaseTimelineItem.vue +79 -79
  349. package/src/components/SlotComponent.ts +37 -37
  350. package/src/components/index.ts +188 -188
  351. package/src/composables/breakpoints.ts +94 -94
  352. package/src/composables/clickOutside.ts +80 -80
  353. package/src/composables/field.ts +117 -117
  354. package/src/composables/hasOptions.ts +68 -68
  355. package/src/composables/mediaQuery.ts +42 -42
  356. package/src/composables/modal.ts +73 -73
  357. package/src/composables/paginatedData.ts +65 -65
  358. package/src/constants/MyConstants.ts +1 -1
  359. package/src/constants/index.ts +5 -5
  360. package/src/env.d.ts +15 -15
  361. package/src/i18n/index.ts +60 -60
  362. package/src/index.ts +111 -111
  363. package/src/lang/en.json +87 -87
  364. package/src/lang/fr.json +87 -87
  365. package/src/stores/dialogs.ts +45 -45
  366. package/src/stores/i18n.ts +14 -14
  367. package/src/stores/notifications.ts +47 -47
  368. package/src/stores/systemAlerts.ts +33 -33
  369. package/src/svg/BaseEmptyState.vue +34 -34
  370. package/src/svg/BaseSpinnerLarge.vue +47 -47
  371. package/src/svg/BaseSpinnerSmall.vue +9 -9
  372. package/src/types/Color.ts +9 -9
  373. package/src/types/Country.ts +4 -4
  374. package/src/types/ImagePickerResult.ts +5 -5
  375. package/src/types/Media.ts +10 -10
  376. package/src/types/Notification.ts +10 -10
  377. package/src/types/Region.ts +5 -5
  378. package/src/types/Status.ts +5 -5
  379. package/src/types/StepperItem.ts +8 -8
  380. package/src/types/TimelineItem.ts +8 -8
  381. package/src/types/UploadedFile.ts +11 -11
  382. package/src/types/User.ts +7 -7
  383. package/src/types/index.ts +267 -267
  384. package/src/utils/blob.ts +30 -30
  385. package/src/utils/colors.ts +200 -200
  386. package/src/utils/cropper/avatar.ts +33 -33
  387. package/src/utils/cropper/cover.ts +41 -41
  388. package/src/utils/cropper/presetInterface.ts +16 -16
  389. package/src/utils/cropper/presets.ts +7 -7
  390. package/src/utils/fileSizeFormat.ts +15 -15
  391. package/src/utils/fileValidations.ts +26 -26
  392. package/src/utils/index.ts +16 -16
  393. package/src/utils/resizeImageFromURI.ts +118 -118
  394. package/src/utils/scrollPreventer.ts +11 -11
  395. package/src/utils/toHumanList.ts +20 -20
@@ -1,323 +1,324 @@
1
- <template>
2
- <form ref="form" class="relative" @submit.prevent="submit()">
3
- <slot
4
- :errors="errors"
5
- :loading="loading"
6
- :disabled="disabled"
7
- :submit="submit"
8
- />
9
-
10
- <transition
11
- enter-active-class="transition duration-100 ease-out"
12
- enter-from-class="opacity-0"
13
- enter-to-class="opacity-100"
14
- leave-active-class="transition duration-200 ease-in"
15
- leave-from-class="opacity-100"
16
- leave-to-class="opacity-0"
17
- >
18
- <slot v-if="loading" name="loading">
19
- <div
20
- class="absolute inset-0 flex h-full w-full items-center justify-center"
21
- >
22
- <div
23
- class="absolute inset-0 h-full w-full opacity-80"
24
- :class="loadingMaskClass"
25
- />
26
- <svg
27
- class="relative h-6 w-6 animate-spin text-blue-600"
28
- viewBox="0 0 24 24"
29
- >
30
- <path
31
- fill="currentColor"
32
- d="M12,4V2A10,10 0 0,0 2,12H4A8,8 0 0,1 12,4Z"
33
- />
34
- </svg>
35
- </div>
36
- </slot>
37
- </transition>
38
- </form>
39
- </template>
40
-
41
- <script lang="ts" setup>
42
- import { PropType } from 'vue';
43
- import { serialize } from 'object-to-formdata';
44
- import { Method, DataFormat } from '@/types';
45
- import { AxiosError, AxiosInstance, AxiosResponse } from 'axios';
46
- import { config, useNotificationsStore } from '@/index';
47
- import { get, isArray } from 'lodash';
48
- import { t } from '@/i18n';
49
-
50
- const notifications = useNotificationsStore();
51
-
52
- type NextFunction = () => void;
53
-
54
- const props = defineProps({
55
- url: {
56
- required: true,
57
- type: String,
58
- },
59
- method: {
60
- required: true,
61
- type: String as PropType<Method>,
62
- validator: (value: string) => {
63
- return Object.values(Method).includes(value as Method);
64
- },
65
- },
66
- data: {
67
- required: true,
68
- type: Object as PropType<Record<string, any>>,
69
- },
70
- axiosInstance: {
71
- default: null,
72
- type: Object as PropType<AxiosInstance | null>,
73
- },
74
- format: {
75
- type: String as PropType<DataFormat>,
76
- default: DataFormat.json,
77
- validator: (value: string) => {
78
- return Object.values(DataFormat).includes(value as DataFormat);
79
- },
80
- },
81
- beforeSubmit: {
82
- default: (next: NextFunction) => {
83
- next();
84
- },
85
- type: Function as PropType<(next: NextFunction) => void>,
86
- },
87
- successHandler: {
88
- default: undefined,
89
- type: Function as PropType<(response: any) => void>,
90
- },
91
- errorHandler: {
92
- default: (error: AxiosError) => {
93
- error;
94
- },
95
- type: Function as PropType<(error: AxiosError) => void>,
96
- },
97
- loadingMaskClass: {
98
- default: 'bg-white',
99
- type: String,
100
- },
101
- showNotificationOnError: {
102
- default: true,
103
- type: Boolean,
104
- },
105
- showNotificationOnSuccess: {
106
- default: true,
107
- type: Boolean,
108
- },
109
- });
110
-
111
- const emit = defineEmits(['error', 'success']);
112
-
113
- const form = ref<null | HTMLFormElement>(null);
114
- const loading = ref(false);
115
- const errors = ref<Record<string, string[]>>({});
116
-
117
- const httpClient = computed((): AxiosInstance => {
118
- if (props.axiosInstance) {
119
- return props.axiosInstance;
120
- }
121
-
122
- return config.http;
123
- });
124
-
125
- const htmlFormElement = computed((): HTMLFormElement | null => {
126
- return form.value;
127
- });
128
-
129
- const hasErrors = computed((): boolean => {
130
- return Object.keys(errors.value).length > 0;
131
- });
132
-
133
- const elementWithError = computed((): HTMLElement | null => {
134
- if (!hasErrors.value) {
135
- return null;
136
- }
137
-
138
- const keys = Object.keys(errors.value);
139
-
140
- for (let i = 0; i < keys.length; i++) {
141
- const name = keys[i];
142
- const element = findElementByName(name);
143
- if (element) {
144
- return element;
145
- }
146
- }
147
-
148
- return null;
149
- });
150
-
151
- function findElementByName(name: string): HTMLElement | null {
152
- let el = htmlFormElement.value?.querySelector(`[name='${name}']`) as
153
- | HTMLElement
154
- | undefined;
155
- if (el) {
156
- return el;
157
- }
158
-
159
- el = htmlFormElement.value?.querySelector(`[data-name='${name}']`) as
160
- | HTMLElement
161
- | undefined;
162
-
163
- if (el) {
164
- return el;
165
- }
166
-
167
- return null;
168
- }
169
-
170
- function submit() {
171
- props.beforeSubmit(query);
172
- }
173
-
174
- function query() {
175
- if (loading.value) {
176
- return;
177
- }
178
-
179
- loading.value = true;
180
-
181
- let method = props.method as Method;
182
- let data = props.data;
183
- let headers = { 'Content-Type': 'application/json' };
184
-
185
- if (props.format == 'formData') {
186
- method = Method.post;
187
-
188
- data = serialize(props.data, {
189
- nullsAsUndefineds: false,
190
- booleansAsIntegers: true,
191
- allowEmptyArrays: true,
192
- });
193
-
194
- if (props.method !== Method.post) {
195
- data.append('_method', props.method);
196
- }
197
-
198
- headers = {
199
- 'Content-Type': 'multipart/form-data',
200
- };
201
- }
202
-
203
- httpClient.value[method](props.url, data, { headers: headers })
204
- .then((response: AxiosResponse) => {
205
- loading.value = false;
206
-
207
- errors.value = {};
208
-
209
- successHandler(response);
210
-
211
- emit('success', response);
212
- })
213
- .catch((error: AxiosError<AxiosResponse<any>>) => {
214
- console.error(error);
215
-
216
- loading.value = false;
217
-
218
- if (error.response && error.response.status == 422) {
219
- loadErrors(error);
220
- }
221
-
222
- props.errorHandler(error);
223
-
224
- const errorMessage = get(error, 'response.data.message', null);
225
-
226
- if (props.showNotificationOnError && errorMessage) {
227
- notifications.push({
228
- color: 'danger',
229
- title: t('sui.error'),
230
- text: errorMessage,
231
- });
232
- }
233
-
234
- emit('error', error);
235
- });
236
- }
237
-
238
- function successHandler(response: AxiosResponse<any, any>) {
239
- if (props.successHandler) {
240
- props.successHandler(response);
241
- } else {
242
- const message = response.data.message ?? ('' as string);
243
-
244
- if (!message) {
245
- return;
246
- }
247
-
248
- if (props.showNotificationOnSuccess) {
249
- notifications.push({
250
- color: 'success',
251
- title: t('sui.success'),
252
- text: message,
253
- });
254
- }
255
- }
256
- }
257
-
258
- function loadErrors(error: AxiosError): void {
259
- errors.value = error?.response?.data.errors ?? {};
260
-
261
- if (elementWithError.value) {
262
- elementWithError.value.scrollIntoView({
263
- behavior: 'smooth',
264
- block: 'center',
265
- });
266
- }
267
- }
268
-
269
- function getErrorMessageByName(name: string): string | null {
270
- if (!errors.value[name]) {
271
- return null;
272
- }
273
-
274
- if (!isArray(errors.value[name])) {
275
- return null;
276
- }
277
-
278
- if (errors.value[name].length == 0) {
279
- return null;
280
- }
281
-
282
- return errors.value[name][0];
283
- }
284
-
285
- function clearErrors(name = null): void {
286
- if (name == null) {
287
- errors.value = {};
288
- } else {
289
- delete errors.value[name];
290
- }
291
- }
292
-
293
- const disablingFields = reactive(new Set<string>());
294
-
295
- function disabledForm(uuid: string) {
296
- disablingFields.add(uuid);
297
- }
298
-
299
- function enableForm(uuid: string) {
300
- disablingFields.delete(uuid);
301
- }
302
-
303
- const disabled = computed((): boolean => {
304
- return disablingFields.size > 0;
305
- });
306
-
307
- provide('form:errors', readonly(errors));
308
- provide('form:getErrorMessageByName', getErrorMessageByName);
309
- provide('form:clearErrors', clearErrors);
310
-
311
- provide('form:disabled', readonly(disabled));
312
- provide('form:enable', enableForm);
313
- provide('form:disable', disabledForm);
314
-
315
- defineExpose({
316
- submit,
317
- errors,
318
- hasErrors,
319
- clearErrors,
320
- disabled,
321
- loading,
322
- });
323
- </script>
1
+ <template>
2
+ <form ref="form" class="relative" @submit.prevent="submit()">
3
+ <slot
4
+ :errors="errors"
5
+ :loading="loading"
6
+ :disabled="disabled"
7
+ :submit="submit"
8
+ />
9
+
10
+ <transition
11
+ enter-active-class="transition duration-100 ease-out"
12
+ enter-from-class="opacity-0"
13
+ enter-to-class="opacity-100"
14
+ leave-active-class="transition duration-200 ease-in"
15
+ leave-from-class="opacity-100"
16
+ leave-to-class="opacity-0"
17
+ >
18
+ <slot v-if="loading" name="loading">
19
+ <div
20
+ class="absolute inset-0 flex h-full w-full items-center justify-center"
21
+ >
22
+ <div
23
+ class="absolute inset-0 h-full w-full"
24
+ :class="twMerge('bg-white opacity-80', twLoadingMask)"
25
+ />
26
+ <svg
27
+ class="relative h-6 w-6 animate-spin text-blue-600"
28
+ viewBox="0 0 24 24"
29
+ >
30
+ <path
31
+ fill="currentColor"
32
+ d="M12,4V2A10,10 0 0,0 2,12H4A8,8 0 0,1 12,4Z"
33
+ />
34
+ </svg>
35
+ </div>
36
+ </slot>
37
+ </transition>
38
+ </form>
39
+ </template>
40
+
41
+ <script lang="ts" setup>
42
+ import { PropType } from 'vue';
43
+ import { serialize } from 'object-to-formdata';
44
+ import { Method, DataFormat } from '@/types';
45
+ import { AxiosError, AxiosInstance, AxiosResponse } from 'axios';
46
+ import { config, useNotificationsStore } from '@/index';
47
+ import { get, isArray } from 'lodash';
48
+ import { t } from '@/i18n';
49
+ import { twMerge } from 'tailwind-merge';
50
+
51
+ const notifications = useNotificationsStore();
52
+
53
+ type NextFunction = () => void;
54
+
55
+ const props = defineProps({
56
+ url: {
57
+ required: true,
58
+ type: String,
59
+ },
60
+ method: {
61
+ required: true,
62
+ type: String as PropType<Method>,
63
+ validator: (value: string) => {
64
+ return Object.values(Method).includes(value as Method);
65
+ },
66
+ },
67
+ data: {
68
+ required: true,
69
+ type: Object as PropType<Record<string, any>>,
70
+ },
71
+ axiosInstance: {
72
+ default: null,
73
+ type: Object as PropType<AxiosInstance | null>,
74
+ },
75
+ format: {
76
+ type: String as PropType<DataFormat>,
77
+ default: DataFormat.json,
78
+ validator: (value: string) => {
79
+ return Object.values(DataFormat).includes(value as DataFormat);
80
+ },
81
+ },
82
+ beforeSubmit: {
83
+ default: (next: NextFunction) => {
84
+ next();
85
+ },
86
+ type: Function as PropType<(next: NextFunction) => void>,
87
+ },
88
+ successHandler: {
89
+ default: undefined,
90
+ type: Function as PropType<(response: any) => void>,
91
+ },
92
+ errorHandler: {
93
+ default: (error: AxiosError) => {
94
+ error;
95
+ },
96
+ type: Function as PropType<(error: AxiosError) => void>,
97
+ },
98
+ twLoadingMask: {
99
+ default: '',
100
+ type: String,
101
+ },
102
+ showNotificationOnError: {
103
+ default: true,
104
+ type: Boolean,
105
+ },
106
+ showNotificationOnSuccess: {
107
+ default: true,
108
+ type: Boolean,
109
+ },
110
+ });
111
+
112
+ const emit = defineEmits(['error', 'success']);
113
+
114
+ const form = ref<null | HTMLFormElement>(null);
115
+ const loading = ref(false);
116
+ const errors = ref<Record<string, string[]>>({});
117
+
118
+ const httpClient = computed((): AxiosInstance => {
119
+ if (props.axiosInstance) {
120
+ return props.axiosInstance;
121
+ }
122
+
123
+ return config.http;
124
+ });
125
+
126
+ const htmlFormElement = computed((): HTMLFormElement | null => {
127
+ return form.value;
128
+ });
129
+
130
+ const hasErrors = computed((): boolean => {
131
+ return Object.keys(errors.value).length > 0;
132
+ });
133
+
134
+ const elementWithError = computed((): HTMLElement | null => {
135
+ if (!hasErrors.value) {
136
+ return null;
137
+ }
138
+
139
+ const keys = Object.keys(errors.value);
140
+
141
+ for (let i = 0; i < keys.length; i++) {
142
+ const name = keys[i];
143
+ const element = findElementByName(name);
144
+ if (element) {
145
+ return element;
146
+ }
147
+ }
148
+
149
+ return null;
150
+ });
151
+
152
+ function findElementByName(name: string): HTMLElement | null {
153
+ let el = htmlFormElement.value?.querySelector(`[name='${name}']`) as
154
+ | HTMLElement
155
+ | undefined;
156
+ if (el) {
157
+ return el;
158
+ }
159
+
160
+ el = htmlFormElement.value?.querySelector(`[data-name='${name}']`) as
161
+ | HTMLElement
162
+ | undefined;
163
+
164
+ if (el) {
165
+ return el;
166
+ }
167
+
168
+ return null;
169
+ }
170
+
171
+ function submit() {
172
+ props.beforeSubmit(query);
173
+ }
174
+
175
+ function query() {
176
+ if (loading.value) {
177
+ return;
178
+ }
179
+
180
+ loading.value = true;
181
+
182
+ let method = props.method as Method;
183
+ let data = props.data;
184
+ let headers = { 'Content-Type': 'application/json' };
185
+
186
+ if (props.format == 'formData') {
187
+ method = Method.post;
188
+
189
+ data = serialize(props.data, {
190
+ nullsAsUndefineds: false,
191
+ booleansAsIntegers: true,
192
+ allowEmptyArrays: true,
193
+ });
194
+
195
+ if (props.method !== Method.post) {
196
+ data.append('_method', props.method);
197
+ }
198
+
199
+ headers = {
200
+ 'Content-Type': 'multipart/form-data',
201
+ };
202
+ }
203
+
204
+ httpClient.value[method](props.url, data, { headers: headers })
205
+ .then((response: AxiosResponse) => {
206
+ loading.value = false;
207
+
208
+ errors.value = {};
209
+
210
+ successHandler(response);
211
+
212
+ emit('success', response);
213
+ })
214
+ .catch((error: AxiosError<AxiosResponse<any>>) => {
215
+ console.error(error);
216
+
217
+ loading.value = false;
218
+
219
+ if (error.response && error.response.status == 422) {
220
+ loadErrors(error);
221
+ }
222
+
223
+ props.errorHandler(error);
224
+
225
+ const errorMessage = get(error, 'response.data.message', null);
226
+
227
+ if (props.showNotificationOnError && errorMessage) {
228
+ notifications.push({
229
+ color: 'danger',
230
+ title: t('sui.error'),
231
+ text: errorMessage,
232
+ });
233
+ }
234
+
235
+ emit('error', error);
236
+ });
237
+ }
238
+
239
+ function successHandler(response: AxiosResponse<any, any>) {
240
+ if (props.successHandler) {
241
+ props.successHandler(response);
242
+ } else {
243
+ const message = response.data.message ?? ('' as string);
244
+
245
+ if (!message) {
246
+ return;
247
+ }
248
+
249
+ if (props.showNotificationOnSuccess) {
250
+ notifications.push({
251
+ color: 'success',
252
+ title: t('sui.success'),
253
+ text: message,
254
+ });
255
+ }
256
+ }
257
+ }
258
+
259
+ function loadErrors(error: AxiosError): void {
260
+ errors.value = error?.response?.data.errors ?? {};
261
+
262
+ if (elementWithError.value) {
263
+ elementWithError.value.scrollIntoView({
264
+ behavior: 'smooth',
265
+ block: 'center',
266
+ });
267
+ }
268
+ }
269
+
270
+ function getErrorMessageByName(name: string): string | null {
271
+ if (!errors.value[name]) {
272
+ return null;
273
+ }
274
+
275
+ if (!isArray(errors.value[name])) {
276
+ return null;
277
+ }
278
+
279
+ if (errors.value[name].length == 0) {
280
+ return null;
281
+ }
282
+
283
+ return errors.value[name][0];
284
+ }
285
+
286
+ function clearErrors(name = null): void {
287
+ if (name == null) {
288
+ errors.value = {};
289
+ } else {
290
+ delete errors.value[name];
291
+ }
292
+ }
293
+
294
+ const disablingFields = reactive(new Set<string>());
295
+
296
+ function disabledForm(uuid: string) {
297
+ disablingFields.add(uuid);
298
+ }
299
+
300
+ function enableForm(uuid: string) {
301
+ disablingFields.delete(uuid);
302
+ }
303
+
304
+ const disabled = computed((): boolean => {
305
+ return disablingFields.size > 0;
306
+ });
307
+
308
+ provide('form:errors', readonly(errors));
309
+ provide('form:getErrorMessageByName', getErrorMessageByName);
310
+ provide('form:clearErrors', clearErrors);
311
+
312
+ provide('form:disabled', readonly(disabled));
313
+ provide('form:enable', enableForm);
314
+ provide('form:disable', disabledForm);
315
+
316
+ defineExpose({
317
+ submit,
318
+ errors,
319
+ hasErrors,
320
+ clearErrors,
321
+ disabled,
322
+ loading,
323
+ });
324
+ </script>