sprintify-ui 0.10.65 → 0.10.66

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 (416) hide show
  1. package/README.md +266 -266
  2. package/dist/{BaseCkeditor-D6D4FPEb.js → BaseCkeditor-B4PbYw6a.js} +2 -2
  3. package/dist/sprintify-ui.es.js +3324 -3461
  4. package/dist/style.css +3 -3
  5. package/dist/tailwindcss/button.js +260 -260
  6. package/dist/tailwindcss/index.js +21 -21
  7. package/dist/tailwindcss/input.js +22 -22
  8. package/dist/tailwindcss/overlay.js +12 -12
  9. package/dist/tailwindcss/table.js +91 -91
  10. package/dist/tailwindcss/theme.js +52 -52
  11. package/dist/types/components/BaseActionButtons.vue.d.ts +1 -1
  12. package/dist/types/components/BaseActionItem.vue.d.ts +7 -10
  13. package/dist/types/components/BaseAddressForm.vue.d.ts +1 -1
  14. package/dist/types/components/BaseAlert.vue.d.ts +24 -11
  15. package/dist/types/components/BaseApp.vue.d.ts +14 -12
  16. package/dist/types/components/BaseAssign.vue.d.ts +1 -1
  17. package/dist/types/components/BaseAutocomplete.vue.d.ts +665 -455
  18. package/dist/types/components/BaseAutocompleteDrawer.vue.d.ts +119 -24
  19. package/dist/types/components/BaseAutocompleteFetch.vue.d.ts +1033 -412
  20. package/dist/types/components/BaseAvatarGroup.vue.d.ts +1 -1
  21. package/dist/types/components/BaseBadge.vue.d.ts +23 -11
  22. package/dist/types/components/BaseBelongsTo.vue.d.ts +998 -411
  23. package/dist/types/components/BaseBelongsToFetch.vue.d.ts +754 -371
  24. package/dist/types/components/BaseBoolean.vue.d.ts +1 -1
  25. package/dist/types/components/BaseBreadcrumbs.vue.d.ts +1 -1
  26. package/dist/types/components/BaseButton.vue.d.ts +78 -16
  27. package/dist/types/components/BaseButtonGroup.vue.d.ts +166 -15
  28. package/dist/types/components/BaseCard.vue.d.ts +26 -12
  29. package/dist/types/components/BaseCardRow.vue.d.ts +20 -11
  30. package/dist/types/components/BaseCharacterCounter.vue.d.ts +1 -1
  31. package/dist/types/components/BaseClipboard.vue.d.ts +45 -13
  32. package/dist/types/components/BaseCollapse.vue.d.ts +41 -20
  33. package/dist/types/components/BaseContainer.vue.d.ts +16 -11
  34. package/dist/types/components/BaseCounter.vue.d.ts +1 -1
  35. package/dist/types/components/BaseCropper.vue.d.ts +55 -30
  36. package/dist/types/components/BaseDataIterator.vue.d.ts +43 -42
  37. package/dist/types/components/BaseDataIteratorSectionBox.vue.d.ts +15 -12
  38. package/dist/types/components/BaseDataIteratorSectionColumns.vue.d.ts +1 -1
  39. package/dist/types/components/BaseDataIteratorSectionModal.vue.d.ts +19 -10
  40. package/dist/types/components/BaseDataTable.vue.d.ts +2090 -738
  41. package/dist/types/components/BaseDataTableTemplate.vue.d.ts +576 -100
  42. package/dist/types/components/BaseDatePicker.vue.d.ts +1 -1
  43. package/dist/types/components/BaseDateSelect.vue.d.ts +1 -1
  44. package/dist/types/components/BaseDescriptionList.vue.d.ts +12 -12
  45. package/dist/types/components/BaseDescriptionListItem.vue.d.ts +16 -15
  46. package/dist/types/components/BaseDialog.vue.d.ts +114 -413
  47. package/dist/types/components/BaseDisplayRelativeTime.vue.d.ts +55 -13
  48. package/dist/types/components/BaseDraggable.vue.d.ts +25 -16
  49. package/dist/types/components/BaseDropdown.vue.d.ts +155 -17
  50. package/dist/types/components/BaseDropdownAutocomplete.vue.d.ts +131 -16
  51. package/dist/types/components/BaseField.vue.d.ts +103 -12
  52. package/dist/types/components/BaseFieldI18n.vue.d.ts +1 -1
  53. package/dist/types/components/BaseFilePicker.vue.d.ts +35 -16
  54. package/dist/types/components/BaseFilePickerCrop.vue.d.ts +87 -42
  55. package/dist/types/components/BaseFileUploader.vue.d.ts +195 -29
  56. package/dist/types/components/BaseForm.vue.d.ts +161 -20
  57. package/dist/types/components/BaseGantt.vue.d.ts +1130 -409
  58. package/dist/types/components/BaseHasMany.vue.d.ts +590 -347
  59. package/dist/types/components/BaseHasManyFetch.vue.d.ts +602 -251
  60. package/dist/types/components/BaseHeader.vue.d.ts +1 -1
  61. package/dist/types/components/BaseIconPicker.vue.d.ts +1 -1
  62. package/dist/types/components/BaseInputError.vue.d.ts +23 -11
  63. package/dist/types/components/BaseJsonReaderItem.vue.d.ts +1 -1
  64. package/dist/types/components/BaseLayoutNotificationItemContent.vue.d.ts +1 -1
  65. package/dist/types/components/BaseLayoutSidebar.vue.d.ts +124 -16
  66. package/dist/types/components/BaseLayoutSidebarConfigurable.vue.d.ts +115 -13
  67. package/dist/types/components/BaseLayoutStacked.vue.d.ts +69 -22
  68. package/dist/types/components/BaseLayoutStackedConfigurable.vue.d.ts +120 -10
  69. package/dist/types/components/BaseLazy.vue.d.ts +20 -15
  70. package/dist/types/components/BaseMediaGallery.vue.d.ts +1 -1
  71. package/dist/types/components/BaseMediaGalleryItem.vue.d.ts +1 -1
  72. package/dist/types/components/BaseMediaItem.vue.d.ts +1 -1
  73. package/dist/types/components/BaseMediaLibrary.vue.d.ts +234 -34
  74. package/dist/types/components/BaseMediaListItem.vue.d.ts +1 -1
  75. package/dist/types/components/BaseMediaPicturesItem.vue.d.ts +1 -1
  76. package/dist/types/components/BaseMenu.vue.d.ts +233 -30
  77. package/dist/types/components/BaseMenuItem.vue.d.ts +1 -1
  78. package/dist/types/components/BaseModalCenter.vue.d.ts +88 -12
  79. package/dist/types/components/BaseModalSide.vue.d.ts +85 -12
  80. package/dist/types/components/BaseNavbar.vue.d.ts +88 -22
  81. package/dist/types/components/BaseNavbarItem.vue.d.ts +1 -1
  82. package/dist/types/components/BaseNavbarItemContent.vue.d.ts +1 -1
  83. package/dist/types/components/BaseNavbarSideItem.vue.d.ts +1 -1
  84. package/dist/types/components/BaseNavbarSideItemContent.vue.d.ts +1 -1
  85. package/dist/types/components/BasePagination.vue.d.ts +1 -1
  86. package/dist/types/components/BaseRadioGroup.vue.d.ts +113 -13
  87. package/dist/types/components/BaseReadMore.vue.d.ts +31 -12
  88. package/dist/types/components/BaseRichText.vue.d.ts +1 -1
  89. package/dist/types/components/BaseSelect.vue.d.ts +149 -12
  90. package/dist/types/components/BaseShortcut.vue.d.ts +1 -1
  91. package/dist/types/components/BaseSideNavigation.vue.d.ts +11 -12
  92. package/dist/types/components/BaseSideNavigationItem.vue.d.ts +22 -13
  93. package/dist/types/components/BaseSkeleton.vue.d.ts +3 -3
  94. package/dist/types/components/BaseStepper.vue.d.ts +1 -1
  95. package/dist/types/components/BaseSwitch.vue.d.ts +122 -13
  96. package/dist/types/components/BaseSystemAlert.vue.d.ts +58 -11
  97. package/dist/types/components/BaseTabItem.vue.d.ts +35 -18
  98. package/dist/types/components/BaseTable.vue.d.ts +29 -14
  99. package/dist/types/components/BaseTableBody.vue.d.ts +9 -12
  100. package/dist/types/components/BaseTableCell.vue.d.ts +40 -15
  101. package/dist/types/components/BaseTableColumn.vue.d.ts +3 -3
  102. package/dist/types/components/BaseTableHead.vue.d.ts +14 -12
  103. package/dist/types/components/BaseTableHeader.vue.d.ts +46 -17
  104. package/dist/types/components/BaseTableRow.vue.d.ts +40 -13
  105. package/dist/types/components/BaseTabs.vue.d.ts +21 -15
  106. package/dist/types/components/BaseTagAutocomplete.vue.d.ts +602 -203
  107. package/dist/types/components/BaseTagAutocompleteFetch.vue.d.ts +807 -348
  108. package/dist/types/components/BaseTextareaAutoresize.vue.d.ts +1 -1
  109. package/dist/types/components/BaseTimeline.vue.d.ts +1 -1
  110. package/dist/types/components/BaseTimelineItem.vue.d.ts +1 -1
  111. package/dist/types/components/BaseToast.vue.d.ts +1 -1
  112. package/dist/types/components/BaseTooltip.vue.d.ts +41 -15
  113. package/dist/types/components/BaseUniqueCode.vue.d.ts +1 -1
  114. package/dist/types/stories/PageInputSizes.vue.d.ts +1 -1
  115. package/dist/types/stories/PageShow.vue.d.ts +1 -1
  116. package/dist/types/svg/BaseEmptyState.vue.d.ts +1 -1
  117. package/dist/types/svg/BaseSpinnerSmall.vue.d.ts +1 -1
  118. package/package.json +135 -135
  119. package/src/assets/base-cropper.css +61 -61
  120. package/src/assets/base-date-picker.css +4 -4
  121. package/src/assets/base-rich-text.css +270 -270
  122. package/src/assets/base-spinner.css +18 -18
  123. package/src/assets/base-tabs.css +4 -4
  124. package/src/assets/base-time-picker.css +9 -9
  125. package/src/assets/flatpickr.css +247 -247
  126. package/src/assets/form.css +6 -6
  127. package/src/assets/google-pac.css +25 -25
  128. package/src/assets/main.css +56 -56
  129. package/src/assets/tailwind.css +2 -2
  130. package/src/changelog.mdx +6 -6
  131. package/src/components/BaseActionButtons.vue +76 -76
  132. package/src/components/BaseActionItem.vue +80 -80
  133. package/src/components/BaseActionItemButton.vue +75 -75
  134. package/src/components/BaseAddressForm.stories.js +114 -114
  135. package/src/components/BaseAddressForm.vue +382 -382
  136. package/src/components/BaseAlert.stories.js +75 -75
  137. package/src/components/BaseAlert.vue +101 -101
  138. package/src/components/BaseApp.vue +16 -16
  139. package/src/components/BaseAppDialogs.vue +126 -126
  140. package/src/components/BaseAppSnackbars.vue +40 -40
  141. package/src/components/BaseAssign.mdx +98 -98
  142. package/src/components/BaseAssign.stories.js +78 -78
  143. package/src/components/BaseAssign.vue +366 -366
  144. package/src/components/BaseAutocomplete.stories.js +243 -243
  145. package/src/components/BaseAutocomplete.vue +603 -603
  146. package/src/components/BaseAutocompleteDrawer.vue +386 -386
  147. package/src/components/BaseAutocompleteFetch.stories.js +224 -224
  148. package/src/components/BaseAutocompleteFetch.vue +314 -314
  149. package/src/components/BaseAvatar.stories.js +39 -39
  150. package/src/components/BaseAvatar.vue +164 -164
  151. package/src/components/BaseAvatarGroup.stories.js +71 -71
  152. package/src/components/BaseAvatarGroup.vue +148 -148
  153. package/src/components/BaseBadge.stories.js +130 -130
  154. package/src/components/BaseBadge.vue +97 -97
  155. package/src/components/BaseBelongsTo.stories.js +220 -220
  156. package/src/components/BaseBelongsTo.vue +164 -164
  157. package/src/components/BaseBelongsToFetch.stories.js +223 -223
  158. package/src/components/BaseBelongsToFetch.vue +213 -213
  159. package/src/components/BaseBoolean.stories.js +35 -35
  160. package/src/components/BaseBoolean.vue +26 -26
  161. package/src/components/BaseBreadcrumbs.stories.js +50 -50
  162. package/src/components/BaseBreadcrumbs.vue +109 -109
  163. package/src/components/BaseButton.stories.js +126 -126
  164. package/src/components/BaseButton.vue +279 -279
  165. package/src/components/BaseButtonGroup.stories.js +114 -114
  166. package/src/components/BaseButtonGroup.vue +193 -193
  167. package/src/components/BaseCard.stories.js +63 -63
  168. package/src/components/BaseCard.vue +49 -49
  169. package/src/components/BaseCardRow.vue +53 -53
  170. package/src/components/BaseCharacterCounter.stories.js +30 -30
  171. package/src/components/BaseCharacterCounter.vue +64 -64
  172. package/src/components/BaseCkeditor.vue +154 -154
  173. package/src/components/BaseClipboard.stories.js +55 -55
  174. package/src/components/BaseClipboard.vue +105 -105
  175. package/src/components/BaseCollapse.stories.js +168 -168
  176. package/src/components/BaseCollapse.vue +98 -98
  177. package/src/components/BaseColor.stories.js +66 -66
  178. package/src/components/BaseColor.vue +155 -155
  179. package/src/components/BaseContainer.stories.js +34 -34
  180. package/src/components/BaseContainer.vue +64 -64
  181. package/src/components/BaseCounter.stories.js +47 -47
  182. package/src/components/BaseCounter.vue +83 -83
  183. package/src/components/BaseCropper.stories.js +113 -113
  184. package/src/components/BaseCropper.vue +390 -390
  185. package/src/components/BaseCropperModal.stories.js +54 -54
  186. package/src/components/BaseCropperModal.vue +143 -143
  187. package/src/components/BaseDataIterator.stories.js +292 -292
  188. package/src/components/BaseDataIterator.vue +986 -986
  189. package/src/components/BaseDataIteratorSectionBox.vue +36 -36
  190. package/src/components/BaseDataIteratorSectionButton.vue +42 -42
  191. package/src/components/BaseDataIteratorSectionColumns.vue +150 -150
  192. package/src/components/BaseDataIteratorSectionModal.vue +41 -41
  193. package/src/components/BaseDataTable.stories.js +393 -393
  194. package/src/components/BaseDataTable.vue +966 -966
  195. package/src/components/BaseDataTableRowAction.vue +70 -70
  196. package/src/components/BaseDataTableTemplate.vue +831 -838
  197. package/src/components/BaseDatePicker.stories.js +166 -166
  198. package/src/components/BaseDatePicker.vue +372 -372
  199. package/src/components/BaseDateSelect.stories.js +68 -68
  200. package/src/components/BaseDateSelect.vue +222 -222
  201. package/src/components/BaseDescriptionList.stories.js +35 -35
  202. package/src/components/BaseDescriptionList.vue +13 -13
  203. package/src/components/BaseDescriptionListItem.vue +47 -47
  204. package/src/components/BaseDialog.stories.js +95 -95
  205. package/src/components/BaseDialog.vue +221 -221
  206. package/src/components/BaseDisplayRelativeTime.stories.js +47 -47
  207. package/src/components/BaseDisplayRelativeTime.vue +126 -126
  208. package/src/components/BaseDraggable.stories.js +34 -34
  209. package/src/components/BaseDraggable.vue +111 -111
  210. package/src/components/BaseDropdown.stories.js +164 -164
  211. package/src/components/BaseDropdown.vue +74 -74
  212. package/src/components/BaseDropdownAutocomplete.stories.js +208 -208
  213. package/src/components/BaseDropdownAutocomplete.vue +203 -203
  214. package/src/components/BaseField.vue +151 -151
  215. package/src/components/BaseFieldI18n.stories.js +37 -37
  216. package/src/components/BaseFieldI18n.vue +170 -170
  217. package/src/components/BaseFilePicker.stories.js +84 -84
  218. package/src/components/BaseFilePicker.vue +163 -163
  219. package/src/components/BaseFilePickerCrop.stories.js +135 -135
  220. package/src/components/BaseFilePickerCrop.vue +130 -130
  221. package/src/components/BaseFileUploader.stories.js +101 -101
  222. package/src/components/BaseFileUploader.vue +185 -185
  223. package/src/components/BaseForm.mdx +87 -87
  224. package/src/components/BaseForm.stories.js +133 -133
  225. package/src/components/BaseForm.vue +372 -372
  226. package/src/components/BaseGantt.stories.js +145 -145
  227. package/src/components/BaseGantt.vue +384 -384
  228. package/src/components/BaseHasMany.stories.js +211 -211
  229. package/src/components/BaseHasMany.vue +135 -135
  230. package/src/components/BaseHasManyFetch.stories.js +278 -278
  231. package/src/components/BaseHasManyFetch.vue +222 -222
  232. package/src/components/BaseHeader.stories.js +137 -137
  233. package/src/components/BaseHeader.vue +141 -141
  234. package/src/components/BaseIconPicker.stories.js +22 -22
  235. package/src/components/BaseIconPicker.vue +225 -225
  236. package/src/components/BaseInput.stories.js +202 -202
  237. package/src/components/BaseInput.vue +402 -402
  238. package/src/components/BaseInputError.vue +39 -39
  239. package/src/components/BaseInputLabel.stories.js +36 -36
  240. package/src/components/BaseInputLabel.vue +83 -83
  241. package/src/components/BaseInputPercent.stories.js +66 -66
  242. package/src/components/BaseInputPercent.vue +139 -139
  243. package/src/components/BaseJsonReader.stories.js +120 -120
  244. package/src/components/BaseJsonReader.vue +51 -51
  245. package/src/components/BaseJsonReaderItem.vue +119 -119
  246. package/src/components/BaseLayoutNotificationDropdown.vue +153 -153
  247. package/src/components/BaseLayoutNotificationItem.vue +53 -53
  248. package/src/components/BaseLayoutNotificationItemContent.vue +41 -41
  249. package/src/components/BaseLayoutSidebar.vue +300 -300
  250. package/src/components/BaseLayoutSidebarConfigurable.stories.js +217 -217
  251. package/src/components/BaseLayoutSidebarConfigurable.vue +202 -202
  252. package/src/components/BaseLayoutStacked.vue +78 -78
  253. package/src/components/BaseLayoutStackedConfigurable.stories.js +181 -181
  254. package/src/components/BaseLayoutStackedConfigurable.vue +196 -196
  255. package/src/components/BaseLazy.stories.js +59 -59
  256. package/src/components/BaseLazy.vue +80 -80
  257. package/src/components/BaseLoadingCover.stories.js +55 -55
  258. package/src/components/BaseLoadingCover.vue +101 -101
  259. package/src/components/BaseMediaGallery.vue +96 -96
  260. package/src/components/BaseMediaGalleryItem.vue +101 -101
  261. package/src/components/BaseMediaItem.stories.js +41 -41
  262. package/src/components/BaseMediaItem.vue +80 -80
  263. package/src/components/BaseMediaLibrary.stories.js +267 -267
  264. package/src/components/BaseMediaLibrary.vue +357 -357
  265. package/src/components/BaseMediaList.vue +67 -67
  266. package/src/components/BaseMediaListItem.vue +213 -213
  267. package/src/components/BaseMediaPictures.vue +64 -64
  268. package/src/components/BaseMediaPicturesItem.vue +100 -100
  269. package/src/components/BaseMediaPreview.stories.js +72 -72
  270. package/src/components/BaseMediaPreview.vue +106 -106
  271. package/src/components/BaseMenu.stories.js +134 -134
  272. package/src/components/BaseMenu.vue +187 -187
  273. package/src/components/BaseMenuItem.vue +177 -177
  274. package/src/components/BaseModalCenter.stories.js +68 -68
  275. package/src/components/BaseModalCenter.vue +128 -128
  276. package/src/components/BaseModalSide.stories.js +61 -61
  277. package/src/components/BaseModalSide.vue +130 -130
  278. package/src/components/BaseNavbar.stories.js +152 -152
  279. package/src/components/BaseNavbar.vue +191 -191
  280. package/src/components/BaseNavbarItem.vue +108 -108
  281. package/src/components/BaseNavbarItemContent.vue +124 -124
  282. package/src/components/BaseNavbarSideItem.vue +187 -187
  283. package/src/components/BaseNavbarSideItemContent.vue +126 -126
  284. package/src/components/BasePagination.stories.js +35 -35
  285. package/src/components/BasePagination.vue +266 -266
  286. package/src/components/BasePanel.stories.js +56 -56
  287. package/src/components/BasePanel.vue +42 -42
  288. package/src/components/BasePassword.stories.js +80 -80
  289. package/src/components/BasePassword.vue +87 -87
  290. package/src/components/BaseProgressCircle.stories.js +27 -27
  291. package/src/components/BaseProgressCircle.vue +80 -80
  292. package/src/components/BaseRadioGroup.stories.js +87 -87
  293. package/src/components/BaseRadioGroup.vue +124 -124
  294. package/src/components/BaseReadMore.stories.js +30 -30
  295. package/src/components/BaseReadMore.vue +73 -73
  296. package/src/components/BaseRichText.stories.js +90 -90
  297. package/src/components/BaseRichText.vue +87 -87
  298. package/src/components/BaseScrollColumn.vue +128 -128
  299. package/src/components/BaseSelect.stories.js +151 -151
  300. package/src/components/BaseSelect.vue +241 -241
  301. package/src/components/BaseShortcut.stories.js +100 -100
  302. package/src/components/BaseShortcut.vue +114 -114
  303. package/src/components/BaseSideNavigation.stories.js +85 -85
  304. package/src/components/BaseSideNavigation.vue +32 -32
  305. package/src/components/BaseSideNavigationItem.vue +99 -99
  306. package/src/components/BaseSkeleton.stories.js +36 -36
  307. package/src/components/BaseSkeleton.vue +40 -40
  308. package/src/components/BaseStatistic.stories.js +51 -51
  309. package/src/components/BaseStatistic.vue +98 -98
  310. package/src/components/BaseStepper.stories.js +94 -94
  311. package/src/components/BaseStepper.vue +72 -72
  312. package/src/components/BaseStepperItem.stories.js +65 -65
  313. package/src/components/BaseStepperItem.vue +149 -149
  314. package/src/components/BaseSwitch.stories.js +133 -133
  315. package/src/components/BaseSwitch.vue +228 -226
  316. package/src/components/BaseSystemAlert.stories.js +63 -63
  317. package/src/components/BaseSystemAlert.vue +89 -89
  318. package/src/components/BaseTabItem.vue +192 -192
  319. package/src/components/BaseTable.stories.js +214 -214
  320. package/src/components/BaseTable.vue +111 -111
  321. package/src/components/BaseTableBody.vue +14 -14
  322. package/src/components/BaseTableCell.vue +204 -204
  323. package/src/components/BaseTableColumn.vue +140 -140
  324. package/src/components/BaseTableHead.vue +38 -38
  325. package/src/components/BaseTableHeader.vue +139 -139
  326. package/src/components/BaseTableRow.vue +197 -197
  327. package/src/components/BaseTabs.stories.js +165 -165
  328. package/src/components/BaseTabs.vue +203 -203
  329. package/src/components/BaseTagAutocomplete.stories.js +271 -271
  330. package/src/components/BaseTagAutocomplete.vue +565 -565
  331. package/src/components/BaseTagAutocompleteFetch.stories.js +211 -211
  332. package/src/components/BaseTagAutocompleteFetch.vue +237 -237
  333. package/src/components/BaseTextarea.stories.js +81 -81
  334. package/src/components/BaseTextarea.vue +138 -138
  335. package/src/components/BaseTextareaAutoresize.stories.js +125 -125
  336. package/src/components/BaseTextareaAutoresize.vue +187 -187
  337. package/src/components/BaseTimePicker.stories.js +68 -68
  338. package/src/components/BaseTimePicker.vue +379 -379
  339. package/src/components/BaseTimeline.stories.js +55 -55
  340. package/src/components/BaseTimeline.vue +38 -38
  341. package/src/components/BaseTimelineItem.stories.js +77 -77
  342. package/src/components/BaseTimelineItem.vue +90 -90
  343. package/src/components/BaseToast.stories.js +50 -50
  344. package/src/components/BaseToast.vue +43 -43
  345. package/src/components/BaseTooltip.stories.js +65 -65
  346. package/src/components/BaseTooltip.vue +93 -93
  347. package/src/components/BaseUniqueCode.stories.js +36 -36
  348. package/src/components/BaseUniqueCode.vue +183 -183
  349. package/src/components/SlotComponent.ts +37 -37
  350. package/src/components/index.ts +222 -222
  351. package/src/composables/breakpoints.ts +94 -94
  352. package/src/composables/clickOutside.ts +80 -80
  353. package/src/composables/field.ts +156 -156
  354. package/src/composables/hasOptions.ts +86 -86
  355. package/src/composables/inputSize.ts +35 -35
  356. package/src/composables/isLastColumn.ts +30 -30
  357. package/src/composables/mediaQuery.ts +42 -42
  358. package/src/composables/modal.ts +73 -73
  359. package/src/composables/paginatedData.ts +76 -76
  360. package/src/composables/tooltip.ts +84 -84
  361. package/src/constants/MyConstants.ts +1 -1
  362. package/src/constants/index.ts +5 -5
  363. package/src/env.d.ts +15 -15
  364. package/src/i18n/index.ts +60 -60
  365. package/src/index.ts +138 -138
  366. package/src/lang/en.json +101 -101
  367. package/src/lang/fr.json +101 -101
  368. package/src/services/gantt/format.ts +133 -133
  369. package/src/services/gantt/timescale.ts +250 -250
  370. package/src/services/gantt/types.ts +81 -81
  371. package/src/services/table/classes.ts +37 -37
  372. package/src/services/table/customKeyActions.ts +2 -2
  373. package/src/services/table/types.ts +27 -27
  374. package/src/stores/dialogs.ts +48 -48
  375. package/src/stores/i18n.ts +14 -14
  376. package/src/stores/snackbars.ts +47 -47
  377. package/src/stores/systemAlerts.ts +32 -32
  378. package/src/stories/InputSizes.stories.js +21 -21
  379. package/src/stories/List.stories.js +136 -136
  380. package/src/stories/PageInputSizes.vue +228 -228
  381. package/src/stories/PageShow.vue +423 -423
  382. package/src/stories/Show.stories.js +21 -21
  383. package/src/svg/BaseEmptyState.vue +38 -38
  384. package/src/svg/BaseSpinnerLarge.vue +40 -40
  385. package/src/svg/BaseSpinnerSmall.vue +13 -13
  386. package/src/types/Color.ts +9 -9
  387. package/src/types/Country.ts +4 -4
  388. package/src/types/ImagePickerResult.ts +5 -5
  389. package/src/types/Media.ts +10 -10
  390. package/src/types/Notification.ts +11 -11
  391. package/src/types/Region.ts +5 -5
  392. package/src/types/Status.ts +5 -5
  393. package/src/types/StepperItem.ts +8 -8
  394. package/src/types/ToolbarOption.ts +1 -1
  395. package/src/types/UploadedFile.ts +11 -11
  396. package/src/types/User.ts +7 -7
  397. package/src/types/index.ts +302 -302
  398. package/src/utils/blob.ts +30 -30
  399. package/src/utils/colors.ts +239 -239
  400. package/src/utils/cropper/avatar.ts +33 -33
  401. package/src/utils/cropper/cover.ts +41 -41
  402. package/src/utils/cropper/presetInterface.ts +16 -16
  403. package/src/utils/cropper/presets.ts +7 -7
  404. package/src/utils/deepIncludes.ts +76 -76
  405. package/src/utils/fileSizeFormat.ts +15 -15
  406. package/src/utils/fileValidations.ts +26 -26
  407. package/src/utils/getApiData.ts +11 -11
  408. package/src/utils/index.ts +18 -18
  409. package/src/utils/resizeImageFromURI.ts +118 -118
  410. package/src/utils/scrollPreventer.ts +11 -11
  411. package/src/utils/sizeBehaviors.ts +3 -3
  412. package/src/utils/sizes.ts +38 -38
  413. package/src/utils/slots.ts +12 -12
  414. package/src/utils/storage.ts +36 -36
  415. package/src/utils/toHumanList.ts +20 -20
  416. package/src/utils/uuid.ts +7 -7
@@ -1,357 +1,357 @@
1
- <template>
2
- <div>
3
- <BaseFileUploader
4
- :component="pickerComponent"
5
- :max-size="maxSize"
6
- :disabled="disabledInternal"
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
- @start="onStart"
15
- @success="onSuccess"
16
- @fail="onFail"
17
- @end="onEnd"
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="disabledInternal"
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="disabledInternal"
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="disabledInternal"
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="disabledInternal"
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 { useSnackbarsStore } from '@/stores/snackbars';
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 snackbars = useSnackbarsStore();
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
- 'start',
200
- 'success',
201
- 'fail',
202
- '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
- function invalidModelValue() {
216
- if (props.modelValue == null) {
217
- return true;
218
- }
219
- if (props.modelValue == undefined) {
220
- return true;
221
- }
222
- if (!isArray(props.modelValue)) {
223
- return true;
224
- }
225
- return false;
226
- }
227
-
228
- const normalizedModelValue = computed<MediaLibraryPayload>(() => {
229
- if (invalidModelValue()) {
230
- return [];
231
- }
232
-
233
- return props.modelValue as MediaLibraryPayload;
234
- });
235
-
236
- if (invalidModelValue()) {
237
- sync(normalizedModelValue.value);
238
- }
239
-
240
- // Validations
241
-
242
- const normalizedMax = computed(() => {
243
- if (props.max == null) {
244
- return 100;
245
- }
246
-
247
- return props.max;
248
- });
249
-
250
- const maxFileText = computed(() => {
251
- return t('sui.you_can_upload_up_to_n_files', {
252
- count: normalizedMax.value,
253
- });
254
- });
255
-
256
- const maxFileSize = computed(() => {
257
- return capitalize(t('sui.up_to_x', { x: fileSizeFormat(props.maxSize) }));
258
- });
259
-
260
- // Upload
261
-
262
- const syncingFiles = ref(false);
263
-
264
- function onSuccess(files: UploadedFile[]) {
265
-
266
- if (files.length == 0) {
267
- return;
268
- }
269
-
270
- syncingFiles.value = true;
271
-
272
- let modelValue = cloneDeep(normalizedModelValue.value);
273
-
274
- for (const file of files) {
275
-
276
-
277
- if (
278
- normalizedMax.value &&
279
- modelValue.length >= normalizedMax.value &&
280
- normalizedMax.value > 1
281
- ) {
282
- snackbars.push({
283
- title: t('sui.whoops'),
284
- text: t('sui.you_can_upload_up_to_n_files', {
285
- count: normalizedMax.value,
286
- }),
287
- color: 'danger',
288
- });
289
-
290
- break;
291
- }
292
-
293
- if (normalizedMax.value == 1) {
294
- // Remove everything...
295
- modelValue = [];
296
- }
297
-
298
- modelValue.push(file);
299
- }
300
-
301
- sync(modelValue);
302
-
303
- syncingFiles.value = false;
304
-
305
- emit('success', files);
306
- }
307
-
308
- // Disabled
309
-
310
- const disabledInternal = computed(() => {
311
- return props.disabled || syncingFiles.value;
312
- });
313
-
314
-
315
- // Remove
316
-
317
- function promptRemove(index: number, length = 1) {
318
- dialogs.push({
319
- title: t('sui.remove_file'),
320
- message: t('sui.remove_file_description'),
321
- color: 'warning',
322
- onConfirm() {
323
- removeByIndex(index, length);
324
- },
325
- });
326
- }
327
-
328
- function removeByIndex(index: number, length = 1) {
329
- const modelValue = cloneDeep(normalizedModelValue.value);
330
-
331
- modelValue.splice(index, length);
332
-
333
- sync(modelValue);
334
- }
335
-
336
- // Sync
337
-
338
- function sync(modelValue: MediaLibraryPayload) {
339
- emitUpdate(modelValue);
340
- }
341
-
342
- // Events
343
-
344
- function onStart(event: unknown) {
345
- emit('start', event);
346
- disableForm();
347
- }
348
-
349
- function onFail(event: unknown) {
350
- emit('fail', event);
351
- }
352
-
353
- function onEnd(event: unknown) {
354
- emit('end', event);
355
- enableForm();
356
- }
357
- </script>
1
+ <template>
2
+ <div>
3
+ <BaseFileUploader
4
+ :component="pickerComponent"
5
+ :max-size="maxSize"
6
+ :disabled="disabledInternal"
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
+ @start="onStart"
15
+ @success="onSuccess"
16
+ @fail="onFail"
17
+ @end="onEnd"
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="disabledInternal"
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="disabledInternal"
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="disabledInternal"
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="disabledInternal"
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 { useSnackbarsStore } from '@/stores/snackbars';
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 snackbars = useSnackbarsStore();
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
+ 'start',
200
+ 'success',
201
+ 'fail',
202
+ '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
+ function invalidModelValue() {
216
+ if (props.modelValue == null) {
217
+ return true;
218
+ }
219
+ if (props.modelValue == undefined) {
220
+ return true;
221
+ }
222
+ if (!isArray(props.modelValue)) {
223
+ return true;
224
+ }
225
+ return false;
226
+ }
227
+
228
+ const normalizedModelValue = computed<MediaLibraryPayload>(() => {
229
+ if (invalidModelValue()) {
230
+ return [];
231
+ }
232
+
233
+ return props.modelValue as MediaLibraryPayload;
234
+ });
235
+
236
+ if (invalidModelValue()) {
237
+ sync(normalizedModelValue.value);
238
+ }
239
+
240
+ // Validations
241
+
242
+ const normalizedMax = computed(() => {
243
+ if (props.max == null) {
244
+ return 100;
245
+ }
246
+
247
+ return props.max;
248
+ });
249
+
250
+ const maxFileText = computed(() => {
251
+ return t('sui.you_can_upload_up_to_n_files', {
252
+ count: normalizedMax.value,
253
+ });
254
+ });
255
+
256
+ const maxFileSize = computed(() => {
257
+ return capitalize(t('sui.up_to_x', { x: fileSizeFormat(props.maxSize) }));
258
+ });
259
+
260
+ // Upload
261
+
262
+ const syncingFiles = ref(false);
263
+
264
+ function onSuccess(files: UploadedFile[]) {
265
+
266
+ if (files.length == 0) {
267
+ return;
268
+ }
269
+
270
+ syncingFiles.value = true;
271
+
272
+ let modelValue = cloneDeep(normalizedModelValue.value);
273
+
274
+ for (const file of files) {
275
+
276
+
277
+ if (
278
+ normalizedMax.value &&
279
+ modelValue.length >= normalizedMax.value &&
280
+ normalizedMax.value > 1
281
+ ) {
282
+ snackbars.push({
283
+ title: t('sui.whoops'),
284
+ text: t('sui.you_can_upload_up_to_n_files', {
285
+ count: normalizedMax.value,
286
+ }),
287
+ color: 'danger',
288
+ });
289
+
290
+ break;
291
+ }
292
+
293
+ if (normalizedMax.value == 1) {
294
+ // Remove everything...
295
+ modelValue = [];
296
+ }
297
+
298
+ modelValue.push(file);
299
+ }
300
+
301
+ sync(modelValue);
302
+
303
+ syncingFiles.value = false;
304
+
305
+ emit('success', files);
306
+ }
307
+
308
+ // Disabled
309
+
310
+ const disabledInternal = computed(() => {
311
+ return props.disabled || syncingFiles.value;
312
+ });
313
+
314
+
315
+ // Remove
316
+
317
+ function promptRemove(index: number, length = 1) {
318
+ dialogs.push({
319
+ title: t('sui.remove_file'),
320
+ message: t('sui.remove_file_description'),
321
+ color: 'warning',
322
+ onConfirm() {
323
+ removeByIndex(index, length);
324
+ },
325
+ });
326
+ }
327
+
328
+ function removeByIndex(index: number, length = 1) {
329
+ const modelValue = cloneDeep(normalizedModelValue.value);
330
+
331
+ modelValue.splice(index, length);
332
+
333
+ sync(modelValue);
334
+ }
335
+
336
+ // Sync
337
+
338
+ function sync(modelValue: MediaLibraryPayload) {
339
+ emitUpdate(modelValue);
340
+ }
341
+
342
+ // Events
343
+
344
+ function onStart(event: unknown) {
345
+ emit('start', event);
346
+ disableForm();
347
+ }
348
+
349
+ function onFail(event: unknown) {
350
+ emit('fail', event);
351
+ }
352
+
353
+ function onEnd(event: unknown) {
354
+ emit('end', event);
355
+ enableForm();
356
+ }
357
+ </script>