@vc-shell/framework 1.0.341 → 1.1.0-alpha.10

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 (920) hide show
  1. package/CHANGELOG.md +15 -2
  2. package/core/api/platform.ts +9883 -9883
  3. package/core/composables/index.ts +11 -7
  4. package/core/composables/useApiClient/index.ts +22 -22
  5. package/core/composables/useAppBarMobileButtons/index.ts +17 -0
  6. package/core/composables/useAppBarWidget/index.ts +19 -0
  7. package/core/composables/useBeforeUnload/index.ts +25 -25
  8. package/core/composables/useDashboard/index.ts +19 -0
  9. package/core/composables/useFunctions/debounce.ts +16 -16
  10. package/core/composables/useFunctions/delay.ts +4 -4
  11. package/core/composables/useFunctions/index.ts +21 -21
  12. package/core/composables/useFunctions/once.ts +12 -12
  13. package/core/composables/useFunctions/sleep.ts +4 -4
  14. package/core/composables/useFunctions/throttle.ts +14 -14
  15. package/core/composables/useGlobalSearch/index.ts +19 -0
  16. package/core/composables/useKeyboardNavigation/index.ts +211 -0
  17. package/core/composables/useLanguages/index.ts +78 -78
  18. package/core/composables/useLoading/index.ts +9 -9
  19. package/core/composables/useMenuService/index.ts +15 -105
  20. package/core/composables/useSettingsMenu/index.ts +23 -0
  21. package/core/composables/useTheme/index.ts +62 -61
  22. package/core/composables/useWidgets/index.ts +20 -0
  23. package/core/constants/index.ts +2 -0
  24. package/core/directives/autofocus/index.ts +9 -9
  25. package/core/directives/loading/index.ts +30 -1
  26. package/core/directives/loading/styles.css +36 -7
  27. package/core/plugins/i18n/index.ts +11 -11
  28. package/core/plugins/modularity/index.ts +32 -30
  29. package/core/plugins/modularity/loader.ts +2 -1
  30. package/core/plugins/moment/humanize.ts +74 -74
  31. package/core/plugins/moment/index.ts +1 -1
  32. package/core/plugins/permissions/index.ts +10 -10
  33. package/core/plugins/validation/index.ts +1 -1
  34. package/core/plugins/validation/rules.ts +145 -145
  35. package/core/services/app-bar-menu-service.ts +87 -0
  36. package/core/services/app-bar-mobile-buttons-service.ts +57 -0
  37. package/core/services/dashboard-service.ts +121 -0
  38. package/core/services/global-search-service.ts +36 -0
  39. package/core/services/menu-service.ts +235 -0
  40. package/core/services/settings-menu-service.ts +75 -0
  41. package/core/services/widget-service.ts +147 -0
  42. package/core/types/index.ts +33 -18
  43. package/core/types/widget.ts +15 -0
  44. package/core/utilities/camelToSnake.ts +7 -7
  45. package/core/utilities/camelize.ts +5 -5
  46. package/core/utilities/generateId.ts +3 -3
  47. package/core/utilities/kebabToCamel.ts +7 -7
  48. package/dist/{asn1-DF4fnRHj.js → asn1-jKiBa2Ya.js} +20 -18
  49. package/dist/{clike-l4mx49Q1.js → clike-BUuHEmgZ.js} +0 -1
  50. package/dist/{cobol-CJVkMW0i.js → cobol-BlTKFDRj.js} +0 -1
  51. package/dist/core/composables/index.d.ts +11 -7
  52. package/dist/core/composables/index.d.ts.map +1 -1
  53. package/dist/core/composables/useAppBarMobileButtons/index.d.ts +3 -0
  54. package/dist/core/composables/useAppBarMobileButtons/index.d.ts.map +1 -0
  55. package/dist/core/composables/useAppBarWidget/index.d.ts +5 -0
  56. package/dist/core/composables/useAppBarWidget/index.d.ts.map +1 -0
  57. package/dist/core/composables/useDashboard/index.d.ts +5 -0
  58. package/dist/core/composables/useDashboard/index.d.ts.map +1 -0
  59. package/dist/core/composables/useGlobalSearch/index.d.ts +4 -0
  60. package/dist/core/composables/useGlobalSearch/index.d.ts.map +1 -0
  61. package/dist/core/composables/useKeyboardNavigation/index.d.ts +24 -0
  62. package/dist/core/composables/useKeyboardNavigation/index.d.ts.map +1 -0
  63. package/dist/core/composables/useMenuService/index.d.ts +4 -10
  64. package/dist/core/composables/useMenuService/index.d.ts.map +1 -1
  65. package/dist/core/composables/useSettingsMenu/index.d.ts +5 -0
  66. package/dist/core/composables/useSettingsMenu/index.d.ts.map +1 -0
  67. package/dist/core/composables/useTheme/index.d.ts.map +1 -1
  68. package/dist/core/composables/useWidgets/index.d.ts +5 -0
  69. package/dist/core/composables/useWidgets/index.d.ts.map +1 -0
  70. package/dist/core/constants/index.d.ts +1 -0
  71. package/dist/core/constants/index.d.ts.map +1 -1
  72. package/dist/core/directives/loading/index.d.ts.map +1 -1
  73. package/dist/core/plugins/modularity/index.d.ts +7 -7
  74. package/dist/core/plugins/modularity/index.d.ts.map +1 -1
  75. package/dist/core/plugins/modularity/loader.d.ts.map +1 -1
  76. package/dist/core/services/app-bar-menu-service.d.ts +29 -0
  77. package/dist/core/services/app-bar-menu-service.d.ts.map +1 -0
  78. package/dist/core/services/app-bar-mobile-buttons-service.d.ts +24 -0
  79. package/dist/core/services/app-bar-mobile-buttons-service.d.ts.map +1 -0
  80. package/dist/core/services/dashboard-service.d.ts +33 -0
  81. package/dist/core/services/dashboard-service.d.ts.map +1 -0
  82. package/dist/core/services/global-search-service.d.ts +10 -0
  83. package/dist/core/services/global-search-service.d.ts.map +1 -0
  84. package/dist/core/services/menu-service.d.ts +17 -0
  85. package/dist/core/services/menu-service.d.ts.map +1 -0
  86. package/dist/core/services/settings-menu-service.d.ts +25 -0
  87. package/dist/core/services/settings-menu-service.d.ts.map +1 -0
  88. package/dist/core/services/widget-service.d.ts +39 -0
  89. package/dist/core/services/widget-service.d.ts.map +1 -0
  90. package/dist/core/types/index.d.ts +33 -17
  91. package/dist/core/types/index.d.ts.map +1 -1
  92. package/dist/core/types/widget.d.ts +12 -0
  93. package/dist/core/types/widget.d.ts.map +1 -0
  94. package/dist/{dockerfile-CFG_IPGn.js → dockerfile-DIy8NleC.js} +1 -1
  95. package/dist/{factor-DJHfQ4a1.js → factor-DDOC7X6P.js} +1 -1
  96. package/dist/framework.js +282 -224
  97. package/dist/{haxe-pdDS1aE8.js → haxe-70NVW1pR.js} +1 -1
  98. package/dist/index-Bi0kJi5Z.js +137 -0
  99. package/dist/{index-YvFwPxsI.js → index-C21NKea4.js} +9 -9
  100. package/dist/{index-CV4fOhK1.js → index-C9n6vRCl.js} +6 -6
  101. package/dist/{index-Dho4-wXM.js → index-CBdNNVCt.js} +8 -8
  102. package/dist/{index-n48DzlNW.js → index-CNEtPeAi.js} +9 -9
  103. package/dist/index-CPkPLIZF.js +243 -0
  104. package/dist/{index-CT72nbMk.js → index-CUwa-7vt.js} +10 -10
  105. package/dist/{index-bAD1-blW.js → index-ClEfeR5e.js} +7 -7
  106. package/dist/{index-BON_eF-3.js → index-CtUvgwL1.js} +9 -9
  107. package/dist/{index-wsG2MecP.js → index-D7TQzX3d.js} +7 -7
  108. package/dist/{index-Ce86fM2z.js → index-DSYfAsS3.js} +95775 -92179
  109. package/dist/{index-Dcdjgpoe.js → index-Dg1vmmpj.js} +5 -5
  110. package/dist/{index-DSefVRVC.js → index-Dzz7ZfO9.js} +19 -19
  111. package/dist/index-dZEaziXz.js +607 -0
  112. package/dist/{index-Ck9pr8TI.js → index-kg3-UkAr.js} +16 -16
  113. package/dist/{index-BXTIkfHT.js → index-vc0H8rq-.js} +42 -42
  114. package/dist/index-vegt24rG.js +308 -0
  115. package/dist/index.css +1 -1
  116. package/dist/index.d.ts +9 -0
  117. package/dist/index.d.ts.map +1 -1
  118. package/dist/injection-keys.d.ts +46 -0
  119. package/dist/injection-keys.d.ts.map +1 -0
  120. package/dist/{javascript-CWGekh08.js → javascript-WMWNx-Vj.js} +1 -1
  121. package/dist/{livescript-CE_BxZmN.js → livescript-CanGTf8u.js} +25 -25
  122. package/dist/locales/de.json +8 -2
  123. package/dist/locales/en.json +6 -1
  124. package/dist/{mllike-1yy7Y7jE.js → mllike-BSnXJBGA.js} +0 -3
  125. package/dist/{nsis-BtA0qkjU.js → nsis-fePjrhq7.js} +1 -1
  126. package/dist/{pascal-ixanSKUz.js → pascal-De0D6mP7.js} +1 -1
  127. package/dist/{pug-CW1q1xhQ.js → pug-BqUR2bBq.js} +1 -1
  128. package/dist/shared/components/app-switcher/components/vc-app-switcher/vc-app-switcher.vue.d.ts.map +1 -1
  129. package/dist/shared/components/blade-navigation/components/vc-blade-navigation/_internal/vc-mobile-back-button.vue.d.ts +19 -0
  130. package/dist/shared/components/blade-navigation/components/vc-blade-navigation/_internal/vc-mobile-back-button.vue.d.ts.map +1 -0
  131. package/dist/shared/components/blade-navigation/components/vc-blade-navigation/vc-blade-navigation.vue.d.ts.map +1 -1
  132. package/dist/shared/components/blade-navigation/components/vc-blade-view/vc-blade-view.d.ts +32 -2
  133. package/dist/shared/components/blade-navigation/components/vc-blade-view/vc-blade-view.d.ts.map +1 -1
  134. package/dist/shared/components/blade-navigation/composables/useBladeNavigation/index.d.ts +5 -1
  135. package/dist/shared/components/blade-navigation/composables/useBladeNavigation/index.d.ts.map +1 -1
  136. package/dist/shared/components/blade-navigation/types/index.d.ts +9 -0
  137. package/dist/shared/components/blade-navigation/types/index.d.ts.map +1 -1
  138. package/dist/shared/components/change-password-button/change-password-button.vue.d.ts +3 -0
  139. package/dist/shared/components/change-password-button/change-password-button.vue.d.ts.map +1 -0
  140. package/dist/shared/components/change-password-button/index.d.ts +2 -0
  141. package/dist/shared/components/change-password-button/index.d.ts.map +1 -0
  142. package/dist/shared/components/dashboard-widget-card/dashboard-widget-card.vue.d.ts +25 -0
  143. package/dist/shared/components/dashboard-widget-card/dashboard-widget-card.vue.d.ts.map +1 -0
  144. package/dist/shared/components/dashboard-widget-card/index.d.ts +2 -0
  145. package/dist/shared/components/dashboard-widget-card/index.d.ts.map +1 -0
  146. package/dist/shared/components/draggable-dashboard/DraggableDashboard.vue.d.ts +8 -0
  147. package/dist/shared/components/draggable-dashboard/DraggableDashboard.vue.d.ts.map +1 -0
  148. package/dist/shared/components/draggable-dashboard/_internal/DashboardWidget.vue.d.ts +20 -0
  149. package/dist/shared/components/draggable-dashboard/_internal/DashboardWidget.vue.d.ts.map +1 -0
  150. package/dist/shared/components/draggable-dashboard/composables/useCellSizeCalculator.d.ts +25 -0
  151. package/dist/shared/components/draggable-dashboard/composables/useCellSizeCalculator.d.ts.map +1 -0
  152. package/dist/shared/components/draggable-dashboard/composables/useCollisionDetection.d.ts +27 -0
  153. package/dist/shared/components/draggable-dashboard/composables/useCollisionDetection.d.ts.map +1 -0
  154. package/dist/shared/components/draggable-dashboard/composables/useDashboardDragAndDrop.d.ts +376 -0
  155. package/dist/shared/components/draggable-dashboard/composables/useDashboardDragAndDrop.d.ts.map +1 -0
  156. package/dist/shared/components/draggable-dashboard/composables/useDashboardGrid.d.ts +20 -0
  157. package/dist/shared/components/draggable-dashboard/composables/useDashboardGrid.d.ts.map +1 -0
  158. package/dist/shared/components/draggable-dashboard/composables/useDragClone.d.ts +15 -0
  159. package/dist/shared/components/draggable-dashboard/composables/useDragClone.d.ts.map +1 -0
  160. package/dist/shared/components/draggable-dashboard/composables/useEventCoordinates.d.ts +33 -0
  161. package/dist/shared/components/draggable-dashboard/composables/useEventCoordinates.d.ts.map +1 -0
  162. package/dist/shared/components/draggable-dashboard/composables/useGridPosition.d.ts +57 -0
  163. package/dist/shared/components/draggable-dashboard/composables/useGridPosition.d.ts.map +1 -0
  164. package/dist/shared/components/draggable-dashboard/composables/useGridSystem.d.ts +22 -0
  165. package/dist/shared/components/draggable-dashboard/composables/useGridSystem.d.ts.map +1 -0
  166. package/dist/shared/components/draggable-dashboard/composables/useLayoutPersistence.d.ts +19 -0
  167. package/dist/shared/components/draggable-dashboard/composables/useLayoutPersistence.d.ts.map +1 -0
  168. package/dist/shared/components/draggable-dashboard/composables/useResizeObserver.d.ts +18 -0
  169. package/dist/shared/components/draggable-dashboard/composables/useResizeObserver.d.ts.map +1 -0
  170. package/dist/shared/components/draggable-dashboard/composables/useWidgetLayout.d.ts +14 -0
  171. package/dist/shared/components/draggable-dashboard/composables/useWidgetLayout.d.ts.map +1 -0
  172. package/dist/shared/components/draggable-dashboard/composables/useWidgetStyles.d.ts +21 -0
  173. package/dist/shared/components/draggable-dashboard/composables/useWidgetStyles.d.ts.map +1 -0
  174. package/dist/shared/components/draggable-dashboard/index.d.ts +2 -0
  175. package/dist/shared/components/draggable-dashboard/index.d.ts.map +1 -0
  176. package/dist/shared/components/draggable-dashboard/types.d.ts +84 -0
  177. package/dist/shared/components/draggable-dashboard/types.d.ts.map +1 -0
  178. package/dist/shared/components/generic-dropdown/generic-dropdown.vue.d.ts +132 -0
  179. package/dist/shared/components/generic-dropdown/generic-dropdown.vue.d.ts.map +1 -0
  180. package/dist/shared/components/generic-dropdown/index.d.ts +2 -0
  181. package/dist/shared/components/generic-dropdown/index.d.ts.map +1 -0
  182. package/dist/shared/components/index.d.ts +4 -1
  183. package/dist/shared/components/index.d.ts.map +1 -1
  184. package/dist/shared/components/language-selector/language-selector.vue.d.ts.map +1 -1
  185. package/dist/shared/components/logout-button/index.d.ts +2 -0
  186. package/dist/shared/components/logout-button/index.d.ts.map +1 -0
  187. package/dist/shared/components/logout-button/logout-button.vue.d.ts +3 -0
  188. package/dist/shared/components/logout-button/logout-button.vue.d.ts.map +1 -0
  189. package/dist/shared/components/notification-dropdown/_internal/notification/index.d.ts +2 -0
  190. package/dist/shared/components/notification-dropdown/_internal/notification/index.d.ts.map +1 -0
  191. package/dist/shared/components/notification-dropdown/notification-dropdown.vue.d.ts.map +1 -1
  192. package/dist/shared/components/notification-template/index.d.ts +4 -31
  193. package/dist/shared/components/notification-template/index.d.ts.map +1 -1
  194. package/dist/shared/components/notification-template/notification-template.vue.d.ts +4 -14
  195. package/dist/shared/components/notification-template/notification-template.vue.d.ts.map +1 -1
  196. package/dist/shared/components/notifications/components/notification-container/index.d.ts +1 -1
  197. package/dist/shared/components/notifications/components/notification-container/index.d.ts.map +1 -1
  198. package/dist/shared/components/settings-menu/index.d.ts +2 -0
  199. package/dist/shared/components/settings-menu/index.d.ts.map +1 -0
  200. package/dist/shared/components/settings-menu/settings-menu.vue.d.ts +3 -0
  201. package/dist/shared/components/settings-menu/settings-menu.vue.d.ts.map +1 -0
  202. package/dist/shared/components/settings-menu-item/index.d.ts +2 -0
  203. package/dist/shared/components/settings-menu-item/index.d.ts.map +1 -0
  204. package/dist/shared/components/{app-bar-button/app-bar-button.vue.d.ts → settings-menu-item/settings-menu-item.vue.d.ts} +26 -25
  205. package/dist/shared/components/settings-menu-item/settings-menu-item.vue.d.ts.map +1 -0
  206. package/dist/shared/components/sidebar/sidebar.vue.d.ts +7 -2
  207. package/dist/shared/components/sidebar/sidebar.vue.d.ts.map +1 -1
  208. package/dist/shared/components/theme-selector/theme-selector.vue.d.ts.map +1 -1
  209. package/dist/shared/components/user-dropdown-button/_internal/user-info.vue.d.ts +18 -0
  210. package/dist/shared/components/user-dropdown-button/_internal/user-info.vue.d.ts.map +1 -0
  211. package/dist/shared/components/user-dropdown-button/_internal/user-sidebar.vue.d.ts +23 -0
  212. package/dist/shared/components/user-dropdown-button/_internal/user-sidebar.vue.d.ts.map +1 -0
  213. package/dist/shared/components/user-dropdown-button/index.d.ts +9 -25
  214. package/dist/shared/components/user-dropdown-button/index.d.ts.map +1 -1
  215. package/dist/shared/components/user-dropdown-button/user-dropdown-button.vue.d.ts +1 -18
  216. package/dist/shared/components/user-dropdown-button/user-dropdown-button.vue.d.ts.map +1 -1
  217. package/dist/shared/composables/useMenuExpanded.d.ts +7 -0
  218. package/dist/shared/composables/useMenuExpanded.d.ts.map +1 -0
  219. package/dist/shared/modules/assets/index.d.ts.map +1 -1
  220. package/dist/shared/modules/assets-manager/components/assets-manager/assets-manager.vue.d.ts.map +1 -1
  221. package/dist/shared/modules/assets-manager/components/assets-manager/index.d.ts +16 -16
  222. package/dist/shared/modules/dynamic/components/fields/Button.d.ts +1 -7
  223. package/dist/shared/modules/dynamic/components/fields/Button.d.ts.map +1 -1
  224. package/dist/shared/modules/dynamic/components/fields/Card.d.ts +1 -7
  225. package/dist/shared/modules/dynamic/components/fields/Card.d.ts.map +1 -1
  226. package/dist/shared/modules/dynamic/components/fields/Checkbox.d.ts +1 -7
  227. package/dist/shared/modules/dynamic/components/fields/Checkbox.d.ts.map +1 -1
  228. package/dist/shared/modules/dynamic/components/fields/ContentField.d.ts +1 -7
  229. package/dist/shared/modules/dynamic/components/fields/ContentField.d.ts.map +1 -1
  230. package/dist/shared/modules/dynamic/components/fields/CustomComponent.d.ts +1 -7
  231. package/dist/shared/modules/dynamic/components/fields/CustomComponent.d.ts.map +1 -1
  232. package/dist/shared/modules/dynamic/components/fields/DynamicProperty.d.ts +1 -7
  233. package/dist/shared/modules/dynamic/components/fields/DynamicProperty.d.ts.map +1 -1
  234. package/dist/shared/modules/dynamic/components/fields/EditorField.d.ts +1 -7
  235. package/dist/shared/modules/dynamic/components/fields/EditorField.d.ts.map +1 -1
  236. package/dist/shared/modules/dynamic/components/fields/Fieldset.d.ts +1 -7
  237. package/dist/shared/modules/dynamic/components/fields/Fieldset.d.ts.map +1 -1
  238. package/dist/shared/modules/dynamic/components/fields/GalleryField.d.ts +1 -7
  239. package/dist/shared/modules/dynamic/components/fields/GalleryField.d.ts.map +1 -1
  240. package/dist/shared/modules/dynamic/components/fields/ImageField.d.ts +1 -7
  241. package/dist/shared/modules/dynamic/components/fields/ImageField.d.ts.map +1 -1
  242. package/dist/shared/modules/dynamic/components/fields/InputCurrency.d.ts +1 -7
  243. package/dist/shared/modules/dynamic/components/fields/InputCurrency.d.ts.map +1 -1
  244. package/dist/shared/modules/dynamic/components/fields/InputField.d.ts +1 -7
  245. package/dist/shared/modules/dynamic/components/fields/InputField.d.ts.map +1 -1
  246. package/dist/shared/modules/dynamic/components/fields/MultivalueField.d.ts +1 -7
  247. package/dist/shared/modules/dynamic/components/fields/MultivalueField.d.ts.map +1 -1
  248. package/dist/shared/modules/dynamic/components/fields/RadioButtonGroup.d.ts +1 -7
  249. package/dist/shared/modules/dynamic/components/fields/RadioButtonGroup.d.ts.map +1 -1
  250. package/dist/shared/modules/dynamic/components/fields/RatingField.d.ts +1 -7
  251. package/dist/shared/modules/dynamic/components/fields/RatingField.d.ts.map +1 -1
  252. package/dist/shared/modules/dynamic/components/fields/SelectField.d.ts +1 -7
  253. package/dist/shared/modules/dynamic/components/fields/SelectField.d.ts.map +1 -1
  254. package/dist/shared/modules/dynamic/components/fields/StatusField.d.ts +1 -7
  255. package/dist/shared/modules/dynamic/components/fields/StatusField.d.ts.map +1 -1
  256. package/dist/shared/modules/dynamic/components/fields/SwitchField.d.ts +1 -7
  257. package/dist/shared/modules/dynamic/components/fields/SwitchField.d.ts.map +1 -1
  258. package/dist/shared/modules/dynamic/components/fields/Table.d.ts +1 -7
  259. package/dist/shared/modules/dynamic/components/fields/Table.d.ts.map +1 -1
  260. package/dist/shared/modules/dynamic/components/fields/TextareaField.d.ts +1 -7
  261. package/dist/shared/modules/dynamic/components/fields/TextareaField.d.ts.map +1 -1
  262. package/dist/shared/modules/dynamic/components/fields/VideoField.d.ts +1 -7
  263. package/dist/shared/modules/dynamic/components/fields/VideoField.d.ts.map +1 -1
  264. package/dist/shared/modules/dynamic/components/fields/props.d.ts +1 -7
  265. package/dist/shared/modules/dynamic/components/fields/props.d.ts.map +1 -1
  266. package/dist/shared/modules/dynamic/components/fields/storybook/Button.stories.d.ts +3 -62
  267. package/dist/shared/modules/dynamic/components/fields/storybook/Button.stories.d.ts.map +1 -1
  268. package/dist/shared/modules/dynamic/components/fields/storybook/Card.stories.d.ts +3 -21
  269. package/dist/shared/modules/dynamic/components/fields/storybook/Card.stories.d.ts.map +1 -1
  270. package/dist/shared/modules/dynamic/components/fields/storybook/Checkbox.stories.d.ts +3 -21
  271. package/dist/shared/modules/dynamic/components/fields/storybook/Checkbox.stories.d.ts.map +1 -1
  272. package/dist/shared/modules/dynamic/components/fields/storybook/ContentField.stories.d.ts +3 -21
  273. package/dist/shared/modules/dynamic/components/fields/storybook/ContentField.stories.d.ts.map +1 -1
  274. package/dist/shared/modules/dynamic/components/fields/storybook/EditorField.stories.d.ts +3 -21
  275. package/dist/shared/modules/dynamic/components/fields/storybook/EditorField.stories.d.ts.map +1 -1
  276. package/dist/shared/modules/dynamic/components/fields/storybook/Fieldset.stories.d.ts +3 -21
  277. package/dist/shared/modules/dynamic/components/fields/storybook/Fieldset.stories.d.ts.map +1 -1
  278. package/dist/shared/modules/dynamic/components/fields/storybook/GalleryField.stories.d.ts +3 -21
  279. package/dist/shared/modules/dynamic/components/fields/storybook/GalleryField.stories.d.ts.map +1 -1
  280. package/dist/shared/modules/dynamic/components/fields/storybook/ImageField.stories.d.ts +3 -21
  281. package/dist/shared/modules/dynamic/components/fields/storybook/ImageField.stories.d.ts.map +1 -1
  282. package/dist/shared/modules/dynamic/components/fields/storybook/InputCurrency.stories.d.ts +3 -21
  283. package/dist/shared/modules/dynamic/components/fields/storybook/InputCurrency.stories.d.ts.map +1 -1
  284. package/dist/shared/modules/dynamic/components/fields/storybook/InputField.stories.d.ts +3 -21
  285. package/dist/shared/modules/dynamic/components/fields/storybook/InputField.stories.d.ts.map +1 -1
  286. package/dist/shared/modules/dynamic/components/fields/storybook/MultivalueField.stories.d.ts +3 -21
  287. package/dist/shared/modules/dynamic/components/fields/storybook/MultivalueField.stories.d.ts.map +1 -1
  288. package/dist/shared/modules/dynamic/components/fields/storybook/RadioButtonGroup.stories.d.ts +3 -21
  289. package/dist/shared/modules/dynamic/components/fields/storybook/RadioButtonGroup.stories.d.ts.map +1 -1
  290. package/dist/shared/modules/dynamic/components/fields/storybook/RatingField.stories.d.ts +3 -21
  291. package/dist/shared/modules/dynamic/components/fields/storybook/RatingField.stories.d.ts.map +1 -1
  292. package/dist/shared/modules/dynamic/components/fields/storybook/SelectField.stories.d.ts +3 -21
  293. package/dist/shared/modules/dynamic/components/fields/storybook/SelectField.stories.d.ts.map +1 -1
  294. package/dist/shared/modules/dynamic/components/fields/storybook/StatusField.stories.d.ts +3 -21
  295. package/dist/shared/modules/dynamic/components/fields/storybook/StatusField.stories.d.ts.map +1 -1
  296. package/dist/shared/modules/dynamic/components/fields/storybook/TextareaField.stories.d.ts +3 -21
  297. package/dist/shared/modules/dynamic/components/fields/storybook/TextareaField.stories.d.ts.map +1 -1
  298. package/dist/shared/modules/dynamic/components/fields/storybook/VideoField.stories.d.ts +3 -21
  299. package/dist/shared/modules/dynamic/components/fields/storybook/VideoField.stories.d.ts.map +1 -1
  300. package/dist/shared/modules/dynamic/components/fields/storybook/common/templates.d.ts +1 -1
  301. package/dist/shared/modules/dynamic/components/fields/storybook/common/templates.d.ts.map +1 -1
  302. package/dist/shared/modules/dynamic/components/fields/storybook/pages/DynamicRender.d.ts +3 -21
  303. package/dist/shared/modules/dynamic/components/fields/storybook/pages/DynamicRender.d.ts.map +1 -1
  304. package/dist/shared/modules/dynamic/composables/useFilterBuilder/index.d.ts.map +1 -1
  305. package/dist/shared/modules/dynamic/pages/dynamic-blade-form.vue.d.ts +2 -14
  306. package/dist/shared/modules/dynamic/pages/dynamic-blade-form.vue.d.ts.map +1 -1
  307. package/dist/shared/modules/dynamic/pages/dynamic-blade-list.vue.d.ts +4 -41
  308. package/dist/shared/modules/dynamic/pages/dynamic-blade-list.vue.d.ts.map +1 -1
  309. package/dist/shared/modules/dynamic/types/index.d.ts +5 -0
  310. package/dist/shared/modules/dynamic/types/index.d.ts.map +1 -1
  311. package/dist/shared/pages/InvitePage/components/invite/index.d.ts +10 -10
  312. package/dist/shared/pages/ResetPasswordPage/components/reset-password/index.d.ts +10 -10
  313. package/dist/{simple-mode-HGTvdazT.js → simple-mode-B0dvCdAA.js} +15 -14
  314. package/dist/{sql-uoWIYwDX.js → sql-mMre1Bo3.js} +0 -2
  315. package/dist/tailwind.config.d.ts +1 -81
  316. package/dist/tailwind.config.d.ts.map +1 -1
  317. package/dist/tsconfig.tsbuildinfo +1 -1
  318. package/dist/{ttcn-DmjTzZb6.js → ttcn-Bsa4sfRm.js} +20 -22
  319. package/dist/{ttcn-cfg-B2U3U7dn.js → ttcn-cfg-Bac_acMi.js} +15 -17
  320. package/dist/ui/components/atoms/vc-badge/vc-badge.vue.d.ts.map +1 -1
  321. package/dist/ui/components/atoms/vc-button/vc-button.stories.d.ts +266 -831
  322. package/dist/ui/components/atoms/vc-button/vc-button.stories.d.ts.map +1 -1
  323. package/dist/ui/components/atoms/vc-button/vc-button.vue.d.ts +20 -3
  324. package/dist/ui/components/atoms/vc-button/vc-button.vue.d.ts.map +1 -1
  325. package/dist/ui/components/atoms/vc-card/index.d.ts +2 -0
  326. package/dist/ui/components/atoms/vc-card/index.d.ts.map +1 -1
  327. package/dist/ui/components/atoms/vc-card/vc-card.stories.d.ts +36 -24
  328. package/dist/ui/components/atoms/vc-card/vc-card.stories.d.ts.map +1 -1
  329. package/dist/ui/components/atoms/vc-card/vc-card.vue.d.ts +2 -0
  330. package/dist/ui/components/atoms/vc-card/vc-card.vue.d.ts.map +1 -1
  331. package/dist/ui/components/atoms/vc-icon/icons/AppWindowIcon.vue.d.ts +18 -0
  332. package/dist/ui/components/atoms/vc-icon/icons/AppWindowIcon.vue.d.ts.map +1 -0
  333. package/dist/ui/components/atoms/vc-icon/icons/ArrowLeftIcon.vue.d.ts +18 -0
  334. package/dist/ui/components/atoms/vc-icon/icons/ArrowLeftIcon.vue.d.ts.map +1 -0
  335. package/dist/ui/components/atoms/vc-icon/icons/ArrowRightIcon.vue.d.ts +18 -0
  336. package/dist/ui/components/atoms/vc-icon/icons/ArrowRightIcon.vue.d.ts.map +1 -0
  337. package/dist/ui/components/atoms/vc-icon/icons/BellIcon.vue.d.ts +18 -0
  338. package/dist/ui/components/atoms/vc-icon/icons/BellIcon.vue.d.ts.map +1 -0
  339. package/dist/ui/components/atoms/vc-icon/icons/ChevronDownIcon.vue.d.ts +18 -0
  340. package/dist/ui/components/atoms/vc-icon/icons/ChevronDownIcon.vue.d.ts.map +1 -0
  341. package/dist/ui/components/atoms/vc-icon/icons/ChevronLeftIcon.vue.d.ts +18 -0
  342. package/dist/ui/components/atoms/vc-icon/icons/ChevronLeftIcon.vue.d.ts.map +1 -0
  343. package/dist/ui/components/atoms/vc-icon/icons/ChevronRightIcon.vue.d.ts +18 -0
  344. package/dist/ui/components/atoms/vc-icon/icons/ChevronRightIcon.vue.d.ts.map +1 -0
  345. package/dist/ui/components/atoms/vc-icon/icons/ChevronUpIcon.vue.d.ts +18 -0
  346. package/dist/ui/components/atoms/vc-icon/icons/ChevronUpIcon.vue.d.ts.map +1 -0
  347. package/dist/ui/components/atoms/vc-icon/icons/CircleDotsIcon.vue.d.ts +18 -0
  348. package/dist/ui/components/atoms/vc-icon/icons/CircleDotsIcon.vue.d.ts.map +1 -0
  349. package/dist/ui/components/atoms/vc-icon/icons/CrossSignIcon.vue.d.ts +18 -0
  350. package/dist/ui/components/atoms/vc-icon/icons/CrossSignIcon.vue.d.ts.map +1 -0
  351. package/dist/ui/components/atoms/vc-icon/icons/DoubleArrowLeftIcon.vue.d.ts +18 -0
  352. package/dist/ui/components/atoms/vc-icon/icons/DoubleArrowLeftIcon.vue.d.ts.map +1 -0
  353. package/dist/ui/components/atoms/vc-icon/icons/DoubleArrowRightIcon.vue.d.ts +18 -0
  354. package/dist/ui/components/atoms/vc-icon/icons/DoubleArrowRightIcon.vue.d.ts.map +1 -0
  355. package/dist/ui/components/atoms/vc-icon/icons/FulfillmentCentersIcon.vue.d.ts +18 -0
  356. package/dist/ui/components/atoms/vc-icon/icons/FulfillmentCentersIcon.vue.d.ts.map +1 -0
  357. package/dist/ui/components/atoms/vc-icon/icons/GridDotsIcon.vue.d.ts +18 -0
  358. package/dist/ui/components/atoms/vc-icon/icons/GridDotsIcon.vue.d.ts.map +1 -0
  359. package/dist/ui/components/atoms/vc-icon/icons/LogoutIcon.vue.d.ts +18 -0
  360. package/dist/ui/components/atoms/vc-icon/icons/LogoutIcon.vue.d.ts.map +1 -0
  361. package/dist/ui/components/atoms/vc-icon/icons/MenuBurgerIcon.vue.d.ts +18 -0
  362. package/dist/ui/components/atoms/vc-icon/icons/MenuBurgerIcon.vue.d.ts.map +1 -0
  363. package/dist/ui/components/atoms/vc-icon/icons/MinusSignIcon.vue.d.ts +18 -0
  364. package/dist/ui/components/atoms/vc-icon/icons/MinusSignIcon.vue.d.ts.map +1 -0
  365. package/dist/ui/components/atoms/vc-icon/icons/OffersIcon.vue.d.ts +18 -0
  366. package/dist/ui/components/atoms/vc-icon/icons/OffersIcon.vue.d.ts.map +1 -0
  367. package/dist/ui/components/atoms/vc-icon/icons/OrdersIcon.vue.d.ts +18 -0
  368. package/dist/ui/components/atoms/vc-icon/icons/OrdersIcon.vue.d.ts.map +1 -0
  369. package/dist/ui/components/atoms/vc-icon/icons/PeopleIcon.vue.d.ts +18 -0
  370. package/dist/ui/components/atoms/vc-icon/icons/PeopleIcon.vue.d.ts.map +1 -0
  371. package/dist/ui/components/atoms/vc-icon/icons/PlusSignIcon.vue.d.ts +18 -0
  372. package/dist/ui/components/atoms/vc-icon/icons/PlusSignIcon.vue.d.ts.map +1 -0
  373. package/dist/ui/components/atoms/vc-icon/icons/ProductsIcon.vue.d.ts +18 -0
  374. package/dist/ui/components/atoms/vc-icon/icons/ProductsIcon.vue.d.ts.map +1 -0
  375. package/dist/ui/components/atoms/vc-icon/icons/ProfileIcon.vue.d.ts +18 -0
  376. package/dist/ui/components/atoms/vc-icon/icons/ProfileIcon.vue.d.ts.map +1 -0
  377. package/dist/ui/components/atoms/vc-icon/icons/SearchIcon.vue.d.ts +18 -0
  378. package/dist/ui/components/atoms/vc-icon/icons/SearchIcon.vue.d.ts.map +1 -0
  379. package/dist/ui/components/atoms/vc-icon/icons/SettingsBoltIcon.vue.d.ts +18 -0
  380. package/dist/ui/components/atoms/vc-icon/icons/SettingsBoltIcon.vue.d.ts.map +1 -0
  381. package/dist/ui/components/atoms/vc-icon/icons/ShoppingCardIcon.vue.d.ts +18 -0
  382. package/dist/ui/components/atoms/vc-icon/icons/ShoppingCardIcon.vue.d.ts.map +1 -0
  383. package/dist/ui/components/atoms/vc-icon/icons/VendorSwitchIcon.vue.d.ts +18 -0
  384. package/dist/ui/components/atoms/vc-icon/icons/VendorSwitchIcon.vue.d.ts.map +1 -0
  385. package/dist/ui/components/atoms/vc-icon/icons/VertDotsIcon.vue.d.ts +18 -0
  386. package/dist/ui/components/atoms/vc-icon/icons/VertDotsIcon.vue.d.ts.map +1 -0
  387. package/dist/ui/components/atoms/vc-icon/icons/index.d.ts +28 -0
  388. package/dist/ui/components/atoms/vc-icon/icons/index.d.ts.map +1 -0
  389. package/dist/ui/components/atoms/vc-icon/index.d.ts +1 -0
  390. package/dist/ui/components/atoms/vc-icon/index.d.ts.map +1 -1
  391. package/dist/ui/components/atoms/vc-icon/vc-icon.stories.d.ts +3 -3
  392. package/dist/ui/components/atoms/vc-icon/vc-icon.vue.d.ts +3 -2
  393. package/dist/ui/components/atoms/vc-icon/vc-icon.vue.d.ts.map +1 -1
  394. package/dist/ui/components/atoms/vc-label/vc-label.stories.d.ts +9 -0
  395. package/dist/ui/components/atoms/vc-label/vc-label.stories.d.ts.map +1 -1
  396. package/dist/ui/components/atoms/vc-label/vc-label.vue.d.ts +1 -0
  397. package/dist/ui/components/atoms/vc-label/vc-label.vue.d.ts.map +1 -1
  398. package/dist/ui/components/atoms/vc-skeleton/vc-skeleton.vue.d.ts +35 -0
  399. package/dist/ui/components/atoms/vc-skeleton/vc-skeleton.vue.d.ts.map +1 -0
  400. package/dist/ui/components/atoms/vc-status/vc-status.stories.d.ts +15 -0
  401. package/dist/ui/components/atoms/vc-status/vc-status.stories.d.ts.map +1 -1
  402. package/dist/ui/components/atoms/vc-status/vc-status.vue.d.ts +7 -0
  403. package/dist/ui/components/atoms/vc-status/vc-status.vue.d.ts.map +1 -1
  404. package/dist/ui/components/atoms/vc-tooltip/vc-tooltip.vue.d.ts +4 -0
  405. package/dist/ui/components/atoms/vc-tooltip/vc-tooltip.vue.d.ts.map +1 -1
  406. package/dist/ui/components/atoms/vc-widget/index.d.ts +6 -0
  407. package/dist/ui/components/atoms/vc-widget/index.d.ts.map +1 -1
  408. package/dist/ui/components/atoms/vc-widget/vc-widget.stories.d.ts +6 -0
  409. package/dist/ui/components/atoms/vc-widget/vc-widget.stories.d.ts.map +1 -1
  410. package/dist/ui/components/atoms/vc-widget/vc-widget.vue.d.ts +1 -3
  411. package/dist/ui/components/atoms/vc-widget/vc-widget.vue.d.ts.map +1 -1
  412. package/dist/ui/components/index.d.ts +1 -0
  413. package/dist/ui/components/index.d.ts.map +1 -1
  414. package/dist/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs.stories.d.ts +67 -33
  415. package/dist/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs.stories.d.ts.map +1 -1
  416. package/dist/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs.vue.d.ts +25 -11
  417. package/dist/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs.vue.d.ts.map +1 -1
  418. package/dist/ui/components/molecules/vc-checkbox/index.d.ts +21 -4
  419. package/dist/ui/components/molecules/vc-checkbox/index.d.ts.map +1 -1
  420. package/dist/ui/components/molecules/vc-checkbox/vc-checkbox.stories.d.ts +210 -40
  421. package/dist/ui/components/molecules/vc-checkbox/vc-checkbox.stories.d.ts.map +1 -1
  422. package/dist/ui/components/molecules/vc-checkbox/vc-checkbox.vue.d.ts +10 -4
  423. package/dist/ui/components/molecules/vc-checkbox/vc-checkbox.vue.d.ts.map +1 -1
  424. package/dist/ui/components/molecules/vc-editor/vc-editor.stories.d.ts +996 -0
  425. package/dist/ui/components/molecules/vc-editor/vc-editor.stories.d.ts.map +1 -1
  426. package/dist/ui/components/molecules/vc-editor/vc-editor.vue.d.ts +332 -0
  427. package/dist/ui/components/molecules/vc-editor/vc-editor.vue.d.ts.map +1 -1
  428. package/dist/ui/components/molecules/vc-field/vc-field.stories.d.ts +3 -3
  429. package/dist/ui/components/molecules/vc-field/vc-field.vue.d.ts +1 -1
  430. package/dist/ui/components/molecules/vc-file-upload/vc-file-upload.stories.d.ts +12 -12
  431. package/dist/ui/components/molecules/vc-input/vc-input.stories.d.ts +24 -24
  432. package/dist/ui/components/molecules/vc-input/vc-input.vue.d.ts +1 -1
  433. package/dist/ui/components/molecules/vc-input/vc-input.vue.d.ts.map +1 -1
  434. package/dist/ui/components/molecules/vc-input-currency/vc-input-currency.stories.d.ts +18 -18
  435. package/dist/ui/components/molecules/vc-input-currency/vc-input-currency.vue.d.ts.map +1 -1
  436. package/dist/ui/components/molecules/vc-multivalue/vc-multivalue.stories.d.ts +84 -84
  437. package/dist/ui/components/molecules/vc-multivalue/vc-multivalue.vue.d.ts +12 -12
  438. package/dist/ui/components/molecules/vc-multivalue/vc-multivalue.vue.d.ts.map +1 -1
  439. package/dist/ui/components/molecules/vc-pagination/vc-pagination.vue.d.ts.map +1 -1
  440. package/dist/ui/components/molecules/vc-select/vc-select.stories.d.ts +240 -240
  441. package/dist/ui/components/molecules/vc-select/vc-select.vue.d.ts +24 -24
  442. package/dist/ui/components/molecules/vc-select/vc-select.vue.d.ts.map +1 -1
  443. package/dist/ui/components/molecules/vc-slider/index.d.ts +9 -9
  444. package/dist/ui/components/molecules/vc-slider/vc-slider.stories.d.ts +9 -9
  445. package/dist/ui/components/molecules/vc-textarea/vc-textarea.stories.d.ts +63 -0
  446. package/dist/ui/components/molecules/vc-textarea/vc-textarea.stories.d.ts.map +1 -1
  447. package/dist/ui/components/molecules/vc-textarea/vc-textarea.vue.d.ts +1 -0
  448. package/dist/ui/components/molecules/vc-textarea/vc-textarea.vue.d.ts.map +1 -1
  449. package/dist/ui/components/organisms/vc-app/_internal/composables/useAppMenuState.d.ts +19 -0
  450. package/dist/ui/components/organisms/vc-app/_internal/composables/useAppMenuState.d.ts.map +1 -0
  451. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarContent.vue.d.ts +25 -0
  452. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarContent.vue.d.ts.map +1 -0
  453. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarHeader.vue.d.ts +32 -0
  454. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarHeader.vue.d.ts.map +1 -0
  455. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarMobileActions.vue.d.ts +17 -0
  456. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarMobileActions.vue.d.ts.map +1 -0
  457. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarOverlay.vue.d.ts +30 -0
  458. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarOverlay.vue.d.ts.map +1 -0
  459. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarWidgetItem.vue.d.ts +50 -0
  460. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarWidgetItem.vue.d.ts.map +1 -0
  461. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarWidgetsMenu.vue.d.ts +3 -0
  462. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarWidgetsMenu.vue.d.ts.map +1 -0
  463. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/MenuSidebar.vue.d.ts +40 -0
  464. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/MenuSidebar.vue.d.ts.map +1 -0
  465. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/composables/useAppBarMobileActions.d.ts +9 -0
  466. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/composables/useAppBarMobileActions.d.ts.map +1 -0
  467. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/composables/useAppBarWidgets.d.ts +8 -0
  468. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/composables/useAppBarWidgets.d.ts.map +1 -0
  469. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/composables/useToggleableContent.d.ts +23 -0
  470. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/composables/useToggleableContent.d.ts.map +1 -0
  471. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/vc-app-bar.vue.d.ts +6 -16
  472. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/vc-app-bar.vue.d.ts.map +1 -1
  473. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/_internal/vc-app-menu-link.vue.d.ts +3 -2
  474. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/_internal/vc-app-menu-link.vue.d.ts.map +1 -1
  475. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/vc-app-menu-item.vue.d.ts +2 -1
  476. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/vc-app-menu-item.vue.d.ts.map +1 -1
  477. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/vc-app-menu.vue.d.ts +3 -12
  478. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/vc-app-menu.vue.d.ts.map +1 -1
  479. package/dist/ui/components/organisms/vc-app/vc-app.stories.d.ts +13 -199
  480. package/dist/ui/components/organisms/vc-app/vc-app.stories.d.ts.map +1 -1
  481. package/dist/ui/components/organisms/vc-app/vc-app.vue.d.ts +5 -197
  482. package/dist/ui/components/organisms/vc-app/vc-app.vue.d.ts.map +1 -1
  483. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-header/vc-blade-header.vue.d.ts +1 -2
  484. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-header/vc-blade-header.vue.d.ts.map +1 -1
  485. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/_internal/vc-blade-toolbar-button/vc-blade-toolbar-base-button.vue.d.ts +48 -0
  486. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/_internal/vc-blade-toolbar-button/vc-blade-toolbar-base-button.vue.d.ts.map +1 -0
  487. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/{vc-blade-toolbar-button → vc-blade-toolbar-buttons/_internal/vc-blade-toolbar-button}/vc-blade-toolbar-button.vue.d.ts +10 -4
  488. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/_internal/vc-blade-toolbar-button/vc-blade-toolbar-button.vue.d.ts.map +1 -0
  489. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/_internal/vc-blade-toolbar-button/vc-blade-toolbar-circle-button.vue.d.ts +40 -0
  490. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/_internal/vc-blade-toolbar-button/vc-blade-toolbar-circle-button.vue.d.ts.map +1 -0
  491. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/desktop/vc-blade-toolbar-desktop.vue.d.ts +19 -0
  492. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/desktop/vc-blade-toolbar-desktop.vue.d.ts.map +1 -0
  493. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/mobile/vc-blade-toolbar-mobile.vue.d.ts +17 -0
  494. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/mobile/vc-blade-toolbar-mobile.vue.d.ts.map +1 -0
  495. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/vc-blade-toolbar-buttons.vue.d.ts +19 -0
  496. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/vc-blade-toolbar-buttons.vue.d.ts.map +1 -0
  497. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/vc-blade-toolbar.vue.d.ts +9 -2
  498. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/vc-blade-toolbar.vue.d.ts.map +1 -1
  499. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/_internal/index.d.ts +3 -0
  500. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/_internal/index.d.ts.map +1 -0
  501. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/_internal/vc-widget-container-desktop.vue.d.ts +16 -0
  502. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/_internal/vc-widget-container-desktop.vue.d.ts.map +1 -0
  503. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/_internal/vc-widget-container-mobile.vue.d.ts +16 -0
  504. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/_internal/vc-widget-container-mobile.vue.d.ts.map +1 -0
  505. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/vc-widget-container.vue.d.ts +15 -0
  506. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/vc-widget-container.vue.d.ts.map +1 -0
  507. package/dist/ui/components/organisms/vc-blade/vc-blade.stories.d.ts +2 -16
  508. package/dist/ui/components/organisms/vc-blade/vc-blade.stories.d.ts.map +1 -1
  509. package/dist/ui/components/organisms/vc-blade/vc-blade.vue.d.ts +56 -2
  510. package/dist/ui/components/organisms/vc-blade/vc-blade.vue.d.ts.map +1 -1
  511. package/dist/ui/components/organisms/vc-dynamic-property/vc-dynamic-property.vue.d.ts +3 -3
  512. package/dist/ui/components/organisms/vc-dynamic-property/vc-dynamic-property.vue.d.ts.map +1 -1
  513. package/dist/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.vue.d.ts +2 -2
  514. package/dist/ui/components/organisms/vc-gallery/vc-gallery.stories.d.ts +13 -13
  515. package/dist/ui/components/organisms/vc-gallery/vc-gallery.vue.d.ts +1 -1
  516. package/dist/ui/components/organisms/vc-table/_internal/vc-table-base-header/vc-table-base-header.vue.d.ts.map +1 -1
  517. package/dist/ui/components/organisms/vc-table/_internal/vc-table-cell/vc-table-cell.vue.d.ts +3 -2
  518. package/dist/ui/components/organisms/vc-table/_internal/vc-table-cell/vc-table-cell.vue.d.ts.map +1 -1
  519. package/dist/ui/components/organisms/vc-table/_internal/vc-table-column-switcher/vc-table-column-switcher.vue.d.ts +2 -1
  520. package/dist/ui/components/organisms/vc-table/_internal/vc-table-column-switcher/vc-table-column-switcher.vue.d.ts.map +1 -1
  521. package/dist/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-body/vc-table-body.vue.d.ts +218 -0
  522. package/dist/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-body/vc-table-body.vue.d.ts.map +1 -0
  523. package/dist/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-columns-header/vc-table-columns-header.vue.d.ts +118 -0
  524. package/dist/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-columns-header/vc-table-columns-header.vue.d.ts.map +1 -0
  525. package/dist/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-row/vc-table-row.vue.d.ts +236 -0
  526. package/dist/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-row/vc-table-row.vue.d.ts.map +1 -0
  527. package/dist/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-select-all-header/vc-table-select-all-header.vue.d.ts +24 -0
  528. package/dist/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-select-all-header/vc-table-select-all-header.vue.d.ts.map +1 -0
  529. package/dist/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/vc-table-desktop-view.vue.d.ts +314 -0
  530. package/dist/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/vc-table-desktop-view.vue.d.ts.map +1 -0
  531. package/dist/ui/components/organisms/vc-table/_internal/vc-table-empty/vc-table-empty.vue.d.ts +1 -1
  532. package/dist/ui/components/organisms/vc-table/_internal/vc-table-empty/vc-table-empty.vue.d.ts.map +1 -1
  533. package/dist/ui/components/organisms/vc-table/_internal/vc-table-filter/vc-table-filter.vue.d.ts.map +1 -1
  534. package/dist/ui/components/organisms/vc-table/_internal/vc-table-footer/vc-table-footer.vue.d.ts +32 -0
  535. package/dist/ui/components/organisms/vc-table/_internal/vc-table-footer/vc-table-footer.vue.d.ts.map +1 -0
  536. package/dist/ui/components/organisms/vc-table/_internal/vc-table-header/vc-table-header.vue.d.ts +66 -0
  537. package/dist/ui/components/organisms/vc-table/_internal/vc-table-header/vc-table-header.vue.d.ts.map +1 -0
  538. package/dist/ui/components/organisms/vc-table/_internal/vc-table-mobile-item/vc-table-mobile-item.vue.d.ts +6 -13
  539. package/dist/ui/components/organisms/vc-table/_internal/vc-table-mobile-item/vc-table-mobile-item.vue.d.ts.map +1 -1
  540. package/dist/ui/components/organisms/vc-table/_internal/vc-table-mobile-view/vc-table-mobile-view.vue.d.ts +229 -0
  541. package/dist/ui/components/organisms/vc-table/_internal/vc-table-mobile-view/vc-table-mobile-view.vue.d.ts.map +1 -0
  542. package/dist/ui/components/organisms/vc-table/_internal/vc-table-select-all/vc-table-select-all.vue.d.ts +38 -0
  543. package/dist/ui/components/organisms/vc-table/_internal/vc-table-select-all/vc-table-select-all.vue.d.ts.map +1 -0
  544. package/dist/ui/components/organisms/vc-table/composables/useTableActions.d.ts +17 -0
  545. package/dist/ui/components/organisms/vc-table/composables/useTableActions.d.ts.map +1 -0
  546. package/dist/ui/components/organisms/vc-table/composables/useTableColumnReorder.d.ts +407 -0
  547. package/dist/ui/components/organisms/vc-table/composables/useTableColumnReorder.d.ts.map +1 -0
  548. package/dist/ui/components/organisms/vc-table/composables/useTableColumnResize.d.ts +9 -0
  549. package/dist/ui/components/organisms/vc-table/composables/useTableColumnResize.d.ts.map +1 -0
  550. package/dist/ui/components/organisms/vc-table/composables/useTableRowReorder.d.ts +16 -0
  551. package/dist/ui/components/organisms/vc-table/composables/useTableRowReorder.d.ts.map +1 -0
  552. package/dist/ui/components/organisms/vc-table/composables/useTableSelection.d.ts +23 -0
  553. package/dist/ui/components/organisms/vc-table/composables/useTableSelection.d.ts.map +1 -0
  554. package/dist/ui/components/organisms/vc-table/composables/useTableState.d.ts +20 -0
  555. package/dist/ui/components/organisms/vc-table/composables/useTableState.d.ts.map +1 -0
  556. package/dist/ui/components/organisms/vc-table/composables/useTableSwipe.d.ts +12 -0
  557. package/dist/ui/components/organisms/vc-table/composables/useTableSwipe.d.ts.map +1 -0
  558. package/dist/ui/components/organisms/vc-table/vc-table.stories.d.ts +105 -735
  559. package/dist/ui/components/organisms/vc-table/vc-table.stories.d.ts.map +1 -1
  560. package/dist/ui/components/organisms/vc-table/vc-table.vue.d.ts +41 -135
  561. package/dist/ui/components/organisms/vc-table/vc-table.vue.d.ts.map +1 -1
  562. package/dist/ui/composables/useVisibleElements.d.ts +19 -0
  563. package/dist/ui/composables/useVisibleElements.d.ts.map +1 -0
  564. package/dist/{xquery-xQxle02u.js → xquery-BUQdORAS.js} +72 -76
  565. package/package.json +16 -6
  566. package/shared/components/app-switcher/components/vc-app-switcher/index.ts +1 -1
  567. package/shared/components/app-switcher/components/vc-app-switcher/vc-app-switcher.vue +30 -135
  568. package/shared/components/blade-navigation/components/vc-blade-navigation/_internal/vc-mobile-back-button.vue +77 -0
  569. package/shared/components/blade-navigation/components/vc-blade-navigation/vc-blade-navigation.vue +23 -10
  570. package/shared/components/blade-navigation/components/vc-blade-view/vc-blade-view.ts +30 -6
  571. package/shared/components/blade-navigation/composables/useBladeNavigation/index.ts +9 -1
  572. package/shared/components/blade-navigation/types/index.ts +10 -0
  573. package/shared/components/change-password/change-password.vue +3 -2
  574. package/shared/components/change-password-button/change-password-button.vue +20 -0
  575. package/shared/components/change-password-button/index.ts +1 -0
  576. package/shared/components/dashboard-widget-card/dashboard-widget-card.vue +67 -0
  577. package/shared/components/dashboard-widget-card/index.ts +1 -0
  578. package/shared/components/draggable-dashboard/DraggableDashboard.vue +332 -0
  579. package/shared/components/draggable-dashboard/_internal/DashboardWidget.vue +117 -0
  580. package/shared/components/draggable-dashboard/composables/useCellSizeCalculator.ts +121 -0
  581. package/shared/components/draggable-dashboard/composables/useCollisionDetection.ts +219 -0
  582. package/shared/components/draggable-dashboard/composables/useDashboardDragAndDrop.ts +342 -0
  583. package/shared/components/draggable-dashboard/composables/useDashboardGrid.ts +104 -0
  584. package/shared/components/draggable-dashboard/composables/useDragClone.ts +97 -0
  585. package/shared/components/draggable-dashboard/composables/useEventCoordinates.ts +91 -0
  586. package/shared/components/draggable-dashboard/composables/useGridPosition.ts +150 -0
  587. package/shared/components/draggable-dashboard/composables/useGridSystem.ts +169 -0
  588. package/shared/components/draggable-dashboard/composables/useLayoutPersistence.ts +89 -0
  589. package/shared/components/draggable-dashboard/composables/useResizeObserver.ts +105 -0
  590. package/shared/components/draggable-dashboard/composables/useWidgetLayout.ts +264 -0
  591. package/shared/components/draggable-dashboard/composables/useWidgetStyles.ts +120 -0
  592. package/shared/components/draggable-dashboard/index.ts +1 -0
  593. package/shared/components/draggable-dashboard/types.ts +96 -0
  594. package/shared/components/error-interceptor/interceptor.ts +44 -44
  595. package/shared/components/generic-dropdown/generic-dropdown.vue +219 -0
  596. package/shared/components/generic-dropdown/index.ts +1 -0
  597. package/shared/components/index.ts +4 -1
  598. package/shared/components/language-selector/language-selector.vue +56 -65
  599. package/shared/components/logout-button/index.ts +1 -0
  600. package/shared/components/logout-button/logout-button.vue +27 -0
  601. package/shared/components/notification-dropdown/_internal/notification/index.ts +1 -0
  602. package/shared/components/notification-dropdown/notification-dropdown.vue +27 -85
  603. package/shared/components/notification-template/notification-template.vue +26 -61
  604. package/shared/components/notifications/styles/index.scss +10 -10
  605. package/shared/components/settings-menu/index.ts +1 -0
  606. package/shared/components/settings-menu/settings-menu.vue +25 -0
  607. package/shared/components/settings-menu-item/index.ts +1 -0
  608. package/shared/components/settings-menu-item/settings-menu-item.vue +136 -0
  609. package/shared/components/sidebar/sidebar.vue +81 -42
  610. package/shared/components/theme-selector/theme-selector.vue +55 -66
  611. package/shared/components/user-dropdown-button/_internal/user-info.vue +95 -0
  612. package/shared/components/user-dropdown-button/_internal/user-sidebar.vue +48 -0
  613. package/shared/components/user-dropdown-button/user-dropdown-button.vue +74 -290
  614. package/shared/composables/useMenuExpanded.ts +40 -0
  615. package/shared/modules/assets/components/assets-details/assets-details.vue +2 -2
  616. package/shared/modules/assets/index.ts +0 -1
  617. package/shared/modules/assets-manager/components/assets-manager/assets-manager.vue +0 -1
  618. package/shared/modules/dynamic/components/FIELD_MAP.ts +53 -53
  619. package/shared/modules/dynamic/components/SchemaRender.ts +102 -102
  620. package/shared/modules/dynamic/components/factories.ts +244 -244
  621. package/shared/modules/dynamic/components/fields/Button.ts +44 -44
  622. package/shared/modules/dynamic/components/fields/Card.ts +119 -119
  623. package/shared/modules/dynamic/components/fields/Checkbox.ts +53 -53
  624. package/shared/modules/dynamic/components/fields/ContentField.ts +33 -33
  625. package/shared/modules/dynamic/components/fields/CustomComponent.ts +29 -29
  626. package/shared/modules/dynamic/components/fields/DynamicProperty.ts +141 -141
  627. package/shared/modules/dynamic/components/fields/EditorField.ts +46 -46
  628. package/shared/modules/dynamic/components/fields/Fieldset.ts +65 -65
  629. package/shared/modules/dynamic/components/fields/GalleryField.ts +161 -161
  630. package/shared/modules/dynamic/components/fields/ImageField.ts +35 -35
  631. package/shared/modules/dynamic/components/fields/InputCurrency.ts +79 -79
  632. package/shared/modules/dynamic/components/fields/InputField.ts +81 -81
  633. package/shared/modules/dynamic/components/fields/MultivalueField.ts +68 -68
  634. package/shared/modules/dynamic/components/fields/RadioButtonGroup.ts +82 -82
  635. package/shared/modules/dynamic/components/fields/RatingField.ts +28 -28
  636. package/shared/modules/dynamic/components/fields/SelectField.ts +72 -72
  637. package/shared/modules/dynamic/components/fields/StatusField.ts +110 -110
  638. package/shared/modules/dynamic/components/fields/SwitchField.ts +29 -29
  639. package/shared/modules/dynamic/components/fields/Table.ts +1 -2
  640. package/shared/modules/dynamic/components/fields/TextareaField.ts +46 -46
  641. package/shared/modules/dynamic/components/fields/ValidationField.ts +54 -54
  642. package/shared/modules/dynamic/components/fields/VideoField.ts +30 -30
  643. package/shared/modules/dynamic/components/fields/props.ts +39 -39
  644. package/shared/modules/dynamic/components/fields/storybook/Button.stories.ts +2 -63
  645. package/shared/modules/dynamic/components/fields/storybook/Card.stories.ts +1 -2
  646. package/shared/modules/dynamic/components/fields/storybook/Checkbox.stories.ts +185 -185
  647. package/shared/modules/dynamic/components/fields/storybook/ContentField.stories.ts +245 -245
  648. package/shared/modules/dynamic/components/fields/storybook/EditorField.stories.ts +192 -192
  649. package/shared/modules/dynamic/components/fields/storybook/Fieldset.stories.ts +347 -347
  650. package/shared/modules/dynamic/components/fields/storybook/GalleryField.stories.ts +239 -239
  651. package/shared/modules/dynamic/components/fields/storybook/ImageField.stories.ts +186 -186
  652. package/shared/modules/dynamic/components/fields/storybook/InputCurrency.stories.ts +281 -281
  653. package/shared/modules/dynamic/components/fields/storybook/InputField.stories.ts +312 -312
  654. package/shared/modules/dynamic/components/fields/storybook/MultivalueField.stories.ts +361 -361
  655. package/shared/modules/dynamic/components/fields/storybook/RadioButtonGroup.stories.ts +224 -224
  656. package/shared/modules/dynamic/components/fields/storybook/RatingField.stories.ts +131 -131
  657. package/shared/modules/dynamic/components/fields/storybook/SelectField.stories.ts +666 -666
  658. package/shared/modules/dynamic/components/fields/storybook/StatusField.stories.ts +202 -202
  659. package/shared/modules/dynamic/components/fields/storybook/SwitchField.stories.ts +178 -178
  660. package/shared/modules/dynamic/components/fields/storybook/TextareaField.stories.ts +203 -203
  661. package/shared/modules/dynamic/components/fields/storybook/VideoField.stories.ts +92 -92
  662. package/shared/modules/dynamic/components/fields/storybook/common/args.ts +130 -130
  663. package/shared/modules/dynamic/components/fields/storybook/common/templates.ts +1 -1
  664. package/shared/modules/dynamic/components/index.ts +4 -4
  665. package/shared/modules/dynamic/composables/index.ts +4 -4
  666. package/shared/modules/dynamic/composables/useDynamicViewsUtils/index.ts +46 -46
  667. package/shared/modules/dynamic/composables/useFilterBuilder/index.ts +31 -22
  668. package/shared/modules/dynamic/composables/useTableTemplates/index.ts +67 -67
  669. package/shared/modules/dynamic/composables/useToolbarReducer/index.ts +70 -70
  670. package/shared/modules/dynamic/factories/base/useDetailsFactory.ts +144 -144
  671. package/shared/modules/dynamic/factories/base/useListFactory.ts +68 -68
  672. package/shared/modules/dynamic/factories/index.ts +4 -4
  673. package/shared/modules/dynamic/factories/types/index.ts +229 -229
  674. package/shared/modules/dynamic/helpers/getters.ts +12 -12
  675. package/shared/modules/dynamic/helpers/methodHandler.ts +22 -22
  676. package/shared/modules/dynamic/helpers/nodeBuilder.ts +1 -1
  677. package/shared/modules/dynamic/helpers/override.ts +153 -153
  678. package/shared/modules/dynamic/helpers/safeIn.ts +6 -6
  679. package/shared/modules/dynamic/helpers/setters.ts +24 -24
  680. package/shared/modules/dynamic/helpers/unrefNested.ts +14 -14
  681. package/shared/modules/dynamic/helpers/unwrapInterpolation.ts +16 -16
  682. package/shared/modules/dynamic/pages/dynamic-blade-form.vue +69 -31
  683. package/shared/modules/dynamic/pages/dynamic-blade-list.vue +169 -202
  684. package/shared/modules/dynamic/types/index.ts +5 -0
  685. package/shared/pages/ChangePasswordPage/components/change-password/index.ts +3 -3
  686. package/shared/pages/ChangePasswordPage/components/index.ts +1 -1
  687. package/shared/pages/ChangePasswordPage/index.ts +1 -1
  688. package/shared/pages/ChangePasswordPage/plugin.ts +4 -4
  689. package/shared/pages/InvitePage/components/index.ts +1 -1
  690. package/shared/pages/InvitePage/components/invite/Invite.vue +216 -216
  691. package/shared/pages/InvitePage/components/invite/index.ts +3 -3
  692. package/shared/pages/InvitePage/index.ts +1 -1
  693. package/shared/pages/InvitePage/plugin.ts +4 -4
  694. package/shared/pages/LoginPage/components/index.ts +1 -1
  695. package/shared/pages/LoginPage/components/login/Login.vue +1 -3
  696. package/shared/pages/LoginPage/components/login/index.ts +3 -3
  697. package/shared/pages/LoginPage/index.ts +1 -1
  698. package/shared/pages/LoginPage/plugin.ts +4 -4
  699. package/shared/pages/ResetPasswordPage/components/index.ts +1 -1
  700. package/shared/pages/ResetPasswordPage/components/reset-password/ResetPassword.vue +1 -1
  701. package/shared/pages/ResetPasswordPage/components/reset-password/index.ts +3 -3
  702. package/shared/pages/ResetPasswordPage/index.ts +1 -1
  703. package/shared/pages/ResetPasswordPage/plugin.ts +4 -4
  704. package/shared/pages/index.ts +4 -4
  705. package/shared/pages/plugin.ts +4 -4
  706. package/shared/utilities/assets.ts +42 -42
  707. package/shared/utilities/vueUtils.ts +50 -50
  708. package/tailwind.config.ts +5 -4
  709. package/ui/components/atoms/vc-badge/index.ts +1 -1
  710. package/ui/components/atoms/vc-badge/vc-badge.stories.ts +53 -53
  711. package/ui/components/atoms/vc-badge/vc-badge.vue +32 -15
  712. package/ui/components/atoms/vc-button/vc-button.stories.ts +1 -16
  713. package/ui/components/atoms/vc-button/vc-button.vue +80 -66
  714. package/ui/components/atoms/vc-card/index.ts +3 -3
  715. package/ui/components/atoms/vc-card/vc-card.stories.ts +1 -1
  716. package/ui/components/atoms/vc-card/vc-card.vue +18 -16
  717. package/ui/components/atoms/vc-col/index.ts +1 -1
  718. package/ui/components/atoms/vc-col/vc-col.stories.ts +22 -22
  719. package/ui/components/atoms/vc-col/vc-col.vue +29 -29
  720. package/ui/components/atoms/vc-container/index.ts +10 -10
  721. package/ui/components/atoms/vc-container/vc-container.stories.ts +29 -29
  722. package/ui/components/atoms/vc-hint/index.ts +10 -10
  723. package/ui/components/atoms/vc-hint/vc-hint.stories.ts +23 -23
  724. package/ui/components/atoms/vc-hint/vc-hint.vue +1 -1
  725. package/ui/components/atoms/vc-icon/icons/AppWindowIcon.vue +15 -0
  726. package/ui/components/atoms/vc-icon/icons/ArrowLeftIcon.vue +20 -0
  727. package/ui/components/atoms/vc-icon/icons/ArrowRightIcon.vue +13 -0
  728. package/ui/components/atoms/vc-icon/icons/BellIcon.vue +14 -0
  729. package/ui/components/atoms/vc-icon/icons/ChevronDownIcon.vue +13 -0
  730. package/ui/components/atoms/vc-icon/icons/ChevronLeftIcon.vue +13 -0
  731. package/ui/components/atoms/vc-icon/icons/ChevronRightIcon.vue +13 -0
  732. package/ui/components/atoms/vc-icon/icons/ChevronUpIcon.vue +13 -0
  733. package/ui/components/atoms/vc-icon/icons/CircleDotsIcon.vue +16 -0
  734. package/ui/components/atoms/vc-icon/icons/CrossSignIcon.vue +20 -0
  735. package/ui/components/atoms/vc-icon/icons/DoubleArrowLeftIcon.vue +14 -0
  736. package/ui/components/atoms/vc-icon/icons/DoubleArrowRightIcon.vue +14 -0
  737. package/ui/components/atoms/vc-icon/icons/FulfillmentCentersIcon.vue +27 -0
  738. package/ui/components/atoms/vc-icon/icons/GridDotsIcon.vue +22 -0
  739. package/ui/components/atoms/vc-icon/icons/LogoutIcon.vue +13 -0
  740. package/ui/components/atoms/vc-icon/icons/MenuBurgerIcon.vue +20 -0
  741. package/ui/components/atoms/vc-icon/icons/MinusSignIcon.vue +14 -0
  742. package/ui/components/atoms/vc-icon/icons/OffersIcon.vue +23 -0
  743. package/ui/components/atoms/vc-icon/icons/OrdersIcon.vue +19 -0
  744. package/ui/components/atoms/vc-icon/icons/PeopleIcon.vue +21 -0
  745. package/ui/components/atoms/vc-icon/icons/PlusSignIcon.vue +20 -0
  746. package/ui/components/atoms/vc-icon/icons/ProductsIcon.vue +23 -0
  747. package/ui/components/atoms/vc-icon/icons/ProfileIcon.vue +18 -0
  748. package/ui/components/atoms/vc-icon/icons/SearchIcon.vue +14 -0
  749. package/ui/components/atoms/vc-icon/icons/SettingsBoltIcon.vue +21 -0
  750. package/ui/components/atoms/vc-icon/icons/ShoppingCardIcon.vue +16 -0
  751. package/ui/components/atoms/vc-icon/icons/VendorSwitchIcon.vue +26 -0
  752. package/ui/components/atoms/vc-icon/icons/VertDotsIcon.vue +19 -0
  753. package/ui/components/atoms/vc-icon/icons/index.ts +27 -0
  754. package/ui/components/atoms/vc-icon/index.ts +1 -0
  755. package/ui/components/atoms/vc-icon/vc-icon.vue +62 -10
  756. package/ui/components/atoms/vc-image/index.ts +1 -1
  757. package/ui/components/atoms/vc-image/vc-image.stories.ts +85 -85
  758. package/ui/components/atoms/vc-image/vc-image.vue +1 -1
  759. package/ui/components/atoms/vc-label/index.ts +1 -1
  760. package/ui/components/atoms/vc-label/vc-label.stories.ts +31 -31
  761. package/ui/components/atoms/vc-label/vc-label.vue +12 -1
  762. package/ui/components/atoms/vc-link/index.ts +10 -10
  763. package/ui/components/atoms/vc-link/vc-link.stories.ts +37 -37
  764. package/ui/components/atoms/vc-link/vc-link.vue +54 -54
  765. package/ui/components/atoms/vc-loading/index.ts +3 -3
  766. package/ui/components/atoms/vc-loading/vc-loading.stories.ts +18 -18
  767. package/ui/components/atoms/vc-loading/vc-loading.vue +58 -58
  768. package/ui/components/atoms/vc-progress/index.ts +10 -10
  769. package/ui/components/atoms/vc-progress/vc-progress.stories.ts +30 -30
  770. package/ui/components/atoms/vc-progress/vc-progress.vue +1 -1
  771. package/ui/components/atoms/vc-row/index.ts +1 -1
  772. package/ui/components/atoms/vc-row/vc-row.stories.ts +20 -20
  773. package/ui/components/atoms/vc-row/vc-row.vue +22 -22
  774. package/ui/components/atoms/vc-skeleton/vc-skeleton.vue +51 -0
  775. package/ui/components/atoms/vc-status/index.ts +1 -1
  776. package/ui/components/atoms/vc-status/vc-status.stories.ts +85 -85
  777. package/ui/components/atoms/vc-status/vc-status.vue +64 -17
  778. package/ui/components/atoms/vc-status-icon/index.ts +1 -1
  779. package/ui/components/atoms/vc-switch/index.ts +1 -1
  780. package/ui/components/atoms/vc-switch/vc-switch.vue +5 -7
  781. package/ui/components/atoms/vc-tooltip/index.ts +1 -1
  782. package/ui/components/atoms/vc-tooltip/vc-tooltip.vue +28 -13
  783. package/ui/components/atoms/vc-video/index.ts +1 -1
  784. package/ui/components/atoms/vc-video/vc-video.stories.ts +19 -19
  785. package/ui/components/atoms/vc-widget/index.ts +3 -3
  786. package/ui/components/atoms/vc-widget/vc-widget.stories.ts +20 -20
  787. package/ui/components/atoms/vc-widget/vc-widget.vue +86 -59
  788. package/ui/components/index.ts +2 -0
  789. package/ui/components/molecules/index.ts +16 -16
  790. package/ui/components/molecules/vc-breadcrumbs/_internal/vc-breadcrumbs-item/vc-breadcrumbs-item.vue +89 -92
  791. package/ui/components/molecules/vc-breadcrumbs/index.ts +1 -1
  792. package/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs.stories.ts +43 -43
  793. package/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs.vue +157 -121
  794. package/ui/components/molecules/vc-checkbox/index.ts +3 -3
  795. package/ui/components/molecules/vc-checkbox/vc-checkbox.stories.ts +84 -84
  796. package/ui/components/molecules/vc-checkbox/vc-checkbox.vue +185 -119
  797. package/ui/components/molecules/vc-editor/index.ts +1 -1
  798. package/ui/components/molecules/vc-editor/vc-editor.stories.ts +29 -29
  799. package/ui/components/molecules/vc-editor/vc-editor.vue +33 -3
  800. package/ui/components/molecules/vc-field/_internal/vc-field-type/vc-field-type.vue +96 -96
  801. package/ui/components/molecules/vc-field/index.ts +1 -1
  802. package/ui/components/molecules/vc-field/vc-field.stories.ts +114 -114
  803. package/ui/components/molecules/vc-field/vc-field.vue +1 -1
  804. package/ui/components/molecules/vc-file-upload/index.ts +1 -1
  805. package/ui/components/molecules/vc-file-upload/vc-file-upload.stories.ts +39 -39
  806. package/ui/components/molecules/vc-file-upload/vc-file-upload.vue +2 -2
  807. package/ui/components/molecules/vc-form/index.ts +10 -10
  808. package/ui/components/molecules/vc-form/vc-form.stories.ts +25 -25
  809. package/ui/components/molecules/vc-form/vc-form.vue +5 -5
  810. package/ui/components/molecules/vc-input/index.ts +1 -1
  811. package/ui/components/molecules/vc-input/vc-input.stories.ts +165 -165
  812. package/ui/components/molecules/vc-input/vc-input.vue +57 -13
  813. package/ui/components/molecules/vc-input-currency/index.ts +1 -1
  814. package/ui/components/molecules/vc-input-currency/vc-input-currency.stories.ts +83 -83
  815. package/ui/components/molecules/vc-input-currency/vc-input-currency.vue +20 -0
  816. package/ui/components/molecules/vc-multivalue/index.ts +1 -1
  817. package/ui/components/molecules/vc-multivalue/vc-multivalue.stories.ts +120 -120
  818. package/ui/components/molecules/vc-multivalue/vc-multivalue.vue +69 -16
  819. package/ui/components/molecules/vc-notification/index.ts +1 -1
  820. package/ui/components/molecules/vc-notification/vc-notification.vue +1 -1
  821. package/ui/components/molecules/vc-pagination/index.ts +3 -3
  822. package/ui/components/molecules/vc-pagination/vc-pagination.stories.ts +24 -24
  823. package/ui/components/molecules/vc-pagination/vc-pagination.vue +48 -110
  824. package/ui/components/molecules/vc-radio-button/index.ts +1 -1
  825. package/ui/components/molecules/vc-radio-button/vc-radio-button.stories.ts +97 -97
  826. package/ui/components/molecules/vc-radio-button/vc-radio-button.vue +13 -8
  827. package/ui/components/molecules/vc-rating/index.ts +1 -1
  828. package/ui/components/molecules/vc-rating/vc-rating.stories.ts +59 -59
  829. package/ui/components/molecules/vc-select/index.ts +1 -1
  830. package/ui/components/molecules/vc-select/vc-select.stories.ts +685 -685
  831. package/ui/components/molecules/vc-select/vc-select.vue +81 -25
  832. package/ui/components/molecules/vc-slider/index.ts +13 -13
  833. package/ui/components/molecules/vc-slider/vc-slider.stories.ts +61 -61
  834. package/ui/components/molecules/vc-slider/vc-slider.vue +118 -118
  835. package/ui/components/molecules/vc-textarea/index.ts +1 -1
  836. package/ui/components/molecules/vc-textarea/vc-textarea.stories.ts +53 -53
  837. package/ui/components/molecules/vc-textarea/vc-textarea.vue +37 -8
  838. package/ui/components/organisms/index.ts +7 -7
  839. package/ui/components/organisms/vc-app/_internal/composables/useAppMenuState.ts +97 -0
  840. package/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarContent.vue +48 -0
  841. package/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarHeader.vue +173 -0
  842. package/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarMobileActions.vue +102 -0
  843. package/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarOverlay.vue +90 -0
  844. package/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarWidgetItem.vue +163 -0
  845. package/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/AppBarWidgetsMenu.vue +110 -0
  846. package/ui/components/organisms/vc-app/_internal/vc-app-bar/_internal/MenuSidebar.vue +172 -0
  847. package/ui/components/organisms/vc-app/_internal/vc-app-bar/composables/useAppBarMobileActions.ts +51 -0
  848. package/ui/components/organisms/vc-app/_internal/vc-app-bar/composables/useAppBarWidgets.ts +27 -0
  849. package/ui/components/organisms/vc-app/_internal/vc-app-bar/composables/useToggleableContent.ts +66 -0
  850. package/ui/components/organisms/vc-app/_internal/vc-app-bar/vc-app-bar.vue +373 -146
  851. package/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/_internal/vc-app-menu-link.vue +188 -120
  852. package/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/vc-app-menu-item.vue +2 -2
  853. package/ui/components/organisms/vc-app/_internal/vc-app-menu/vc-app-menu.vue +86 -131
  854. package/ui/components/organisms/vc-app/vc-app.stories.ts +214 -214
  855. package/ui/components/organisms/vc-app/vc-app.vue +135 -97
  856. package/ui/components/organisms/vc-blade/_internal/vc-blade-header/vc-blade-header.vue +139 -90
  857. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/_internal/vc-blade-toolbar-button/vc-blade-toolbar-base-button.vue +136 -0
  858. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/{vc-blade-toolbar-button → vc-blade-toolbar-buttons/_internal/vc-blade-toolbar-button}/vc-blade-toolbar-button.vue +62 -86
  859. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/_internal/vc-blade-toolbar-button/vc-blade-toolbar-circle-button.vue +101 -0
  860. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/desktop/vc-blade-toolbar-desktop.vue +182 -0
  861. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/mobile/vc-blade-toolbar-mobile.vue +146 -0
  862. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-buttons/vc-blade-toolbar-buttons.vue +32 -0
  863. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/vc-blade-toolbar.vue +30 -48
  864. package/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/_internal/index.ts +2 -0
  865. package/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/_internal/vc-widget-container-desktop.vue +96 -0
  866. package/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/_internal/vc-widget-container-mobile.vue +184 -0
  867. package/ui/components/organisms/vc-blade/_internal/vc-blade-widget-container/vc-widget-container.vue +113 -0
  868. package/ui/components/organisms/vc-blade/index.ts +1 -1
  869. package/ui/components/organisms/vc-blade/vc-blade.stories.ts +83 -83
  870. package/ui/components/organisms/vc-blade/vc-blade.vue +177 -117
  871. package/ui/components/organisms/vc-dynamic-property/index.ts +1 -1
  872. package/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.vue +163 -163
  873. package/ui/components/organisms/vc-gallery/_internal/vc-gallery-preview/vc-gallery-preview.vue +1 -1
  874. package/ui/components/organisms/vc-gallery/index.ts +1 -1
  875. package/ui/components/organisms/vc-gallery/vc-gallery.stories.ts +91 -91
  876. package/ui/components/organisms/vc-gallery/vc-gallery.vue +348 -348
  877. package/ui/components/organisms/vc-login-form/index.ts +1 -1
  878. package/ui/components/organisms/vc-popup/index.ts +3 -3
  879. package/ui/components/organisms/vc-popup/vc-popup.vue +3 -3
  880. package/ui/components/organisms/vc-table/_internal/vc-table-add-new/vc-table-add-new.vue +63 -63
  881. package/ui/components/organisms/vc-table/_internal/vc-table-base-header/vc-table-base-header.vue +21 -17
  882. package/ui/components/organisms/vc-table/_internal/vc-table-cell/vc-table-cell.vue +8 -7
  883. package/ui/components/organisms/vc-table/_internal/vc-table-column-switcher/vc-table-column-switcher.vue +4 -3
  884. package/ui/components/organisms/vc-table/_internal/vc-table-counter/vc-table-counter.vue +4 -3
  885. package/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-body/vc-table-body.vue +133 -0
  886. package/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-columns-header/vc-table-columns-header.vue +250 -0
  887. package/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-row/vc-table-row.vue +238 -0
  888. package/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/_internal/vc-table-select-all-header/vc-table-select-all-header.vue +54 -0
  889. package/ui/components/organisms/vc-table/_internal/vc-table-desktop-view/vc-table-desktop-view.vue +214 -0
  890. package/ui/components/organisms/vc-table/_internal/vc-table-empty/vc-table-empty.vue +2 -7
  891. package/ui/components/organisms/vc-table/_internal/vc-table-filter/vc-table-filter.vue +84 -45
  892. package/ui/components/organisms/vc-table/_internal/vc-table-footer/vc-table-footer.vue +62 -0
  893. package/ui/components/organisms/vc-table/_internal/vc-table-header/vc-table-header.vue +160 -0
  894. package/ui/components/organisms/vc-table/_internal/vc-table-mobile-item/vc-table-mobile-item.vue +47 -69
  895. package/ui/components/organisms/vc-table/_internal/vc-table-mobile-view/vc-table-mobile-view.vue +386 -0
  896. package/ui/components/organisms/vc-table/_internal/vc-table-select-all/vc-table-select-all.vue +118 -0
  897. package/ui/components/organisms/vc-table/composables/useTableActions.ts +56 -0
  898. package/ui/components/organisms/vc-table/composables/useTableColumnReorder.ts +255 -0
  899. package/ui/components/organisms/vc-table/composables/useTableColumnResize.ts +147 -0
  900. package/ui/components/organisms/vc-table/composables/useTableRowReorder.ts +175 -0
  901. package/ui/components/organisms/vc-table/composables/useTableSelection.ts +118 -0
  902. package/ui/components/organisms/vc-table/composables/useTableState.ts +230 -0
  903. package/ui/components/organisms/vc-table/composables/useTableSwipe.ts +32 -0
  904. package/ui/components/organisms/vc-table/index.ts +1 -1
  905. package/ui/components/organisms/vc-table/vc-table.stories.ts +214 -214
  906. package/ui/components/organisms/vc-table/vc-table.vue +288 -1311
  907. package/ui/composables/useVisibleElements.ts +148 -0
  908. package/dist/index-DK6ijkM9.js +0 -598
  909. package/dist/index-DiJJUsG2.js +0 -243
  910. package/dist/index-PaekRinB.js +0 -312
  911. package/dist/index-lnO7rLKk.js +0 -135
  912. package/dist/shared/components/app-bar-button/app-bar-button.vue.d.ts.map +0 -1
  913. package/dist/shared/components/app-bar-button/index.d.ts +0 -2
  914. package/dist/shared/components/app-bar-button/index.d.ts.map +0 -1
  915. package/dist/shared/components/blade-navigation/injectionKeys.d.ts +0 -4
  916. package/dist/shared/components/blade-navigation/injectionKeys.d.ts.map +0 -1
  917. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-button/vc-blade-toolbar-button.vue.d.ts.map +0 -1
  918. package/shared/components/app-bar-button/app-bar-button.vue +0 -169
  919. package/shared/components/app-bar-button/index.ts +0 -1
  920. package/shared/components/blade-navigation/injectionKeys.ts +0 -4
@@ -1,407 +1,157 @@
1
1
  <template>
2
2
  <div
3
- v-loading:1000="unref(loading) || columnsInit"
3
+ v-loading:49="unref(loading) || columnsInit"
4
4
  class="vc-table"
5
5
  >
6
- <div
7
- v-if="multiselect && $isMobile.value && (selection.length > 0 || allSelected) && !noHeaderCheckbox"
8
- class="vc-table__multiselect-mobile"
6
+ <VcTableSelectAll
7
+ :multiselect="multiselect"
8
+ :selection="selection"
9
+ :all-selected="allSelected"
10
+ :total-count="totalCount"
11
+ :header-checkbox="headerCheckbox"
12
+ :select-all="selectAll"
13
+ :show-selection-choice="showSelectionChoice"
14
+ @update:selection="selection = $event"
15
+ @update:all-selected="allSelected = $event"
16
+ @update:header-checkbox="headerCheckbox = $event"
17
+ @select:all="handleSelectAll"
18
+ />
19
+ <VcTableHeader
20
+ :has-header-slot="!!$slots.header"
21
+ :header="header"
22
+ :columns-init="columnsInit"
23
+ :search-value="searchValue"
24
+ :active-filter-count="activeFilterCount"
25
+ :search-placeholder="searchPlaceholder"
26
+ :disable-filter="disableFilter"
27
+ :expanded="expanded"
28
+ @search:change="emit('search:change', $event)"
9
29
  >
10
- <div class="vc-table__select-all-bar">
11
- <div class="vc-table__select-all-content">
12
- <div class="vc-table__select-all-checkbox">
13
- <VcCheckbox
14
- v-model="headerCheckbox"
15
- class="vc-table__select-all-checkbox__checkbox"
16
- size="m"
17
- @click.stop
18
- >
19
- {{ $t("COMPONENTS.ORGANISMS.VC_TABLE.SELECT_ALL_TRUNCATED") }}
20
- </VcCheckbox>
21
- {{ $t("COMPONENTS.ORGANISMS.VC_TABLE.SELECTED") }}: {{ allSelected ? totalCount : selection.length }}
22
- </div>
23
-
24
- <VcButton
25
- text
26
- @click="
27
- () => {
28
- selection = [];
29
- allSelected = false;
30
- }
31
- "
32
- >
33
- {{ $t("COMPONENTS.ORGANISMS.VC_TABLE.CANCEL") }}
34
- </VcButton>
35
- </div>
36
- </div>
37
- <div
38
- v-if="selectAll && showSelectionChoice"
39
- class="vc-table__select-all-choice"
30
+ <template #header="slotProps">
31
+ <slot
32
+ name="header"
33
+ v-bind="slotProps"
34
+ />
35
+ </template>
36
+ <template
37
+ v-if="$slots.filters"
38
+ #filters="slotProps"
40
39
  >
41
- <div class="vc-table__select-all-choice__content">
42
- <div>
43
- {{
44
- allSelected
45
- ? t("COMPONENTS.ORGANISMS.VC_TABLE.ALL_SELECTED")
46
- : t("COMPONENTS.ORGANISMS.VC_TABLE.CURRENT_PAGE_SELECTED")
47
- }}
48
- <VcButton
49
- text
50
- class="vc-table__select-all-choice__button"
51
- @click="handleSelectAll"
52
- >
53
- {{
54
- allSelected ? t("COMPONENTS.ORGANISMS.VC_TABLE.CANCEL") : t("COMPONENTS.ORGANISMS.VC_TABLE.SELECT_ALL")
55
- }}
56
- </VcButton>
57
- </div>
58
- </div>
59
- </div>
60
- </div>
61
-
62
- <!-- Header slot with filter and searchbar -->
63
- <slot
64
- v-else-if="
65
- ($slots['header'] || header) && (!columnsInit || searchValue || searchValue === '' || activeFilterCount)
66
- "
67
- name="header"
68
- :header="headerComponent"
69
- >
70
- <headerComponent></headerComponent>
71
- </slot>
72
-
40
+ <slot
41
+ name="filters"
42
+ v-bind="slotProps"
43
+ />
44
+ </template>
45
+ </VcTableHeader>
73
46
  <div class="vc-table__content">
74
47
  <!-- Table scroll container -->
75
48
  <VcContainer
76
49
  ref="scrollContainer"
77
50
  :no-padding="true"
78
- class="vc-table__mobile-view"
51
+ class="vc-table__scroll-container"
79
52
  :use-ptr="selection.length === 0 ? pullToReload : undefined"
80
53
  @scroll:ptr="$emit('scroll:ptr')"
81
54
  >
82
55
  <!-- Mobile table view -->
83
- <template v-if="$isMobile.value">
84
- <div
85
- v-if="items && items.length && !columnsInit"
86
- class="vc-table__mobile-items"
87
- >
88
- <VcTableMobileItem
89
- v-for="(item, i) in items"
90
- :key="i"
91
- :index="i"
92
- :items="items"
93
- :action-builder="itemActionBuilder"
94
- :disabled-selection="disabledSelection"
95
- :swiping-item="mobileSwipeItem"
96
- :selection="selection"
97
- :is-selected="isSelected(item)"
98
- @click="$emit('itemClick', item)"
99
- @swipe-start="handleSwipe"
100
- @select="multiselect ? rowCheckbox(item) : undefined"
101
- >
102
- <slot
103
- name="mobile-item"
104
- :item="item"
105
- >
106
- <mobileTemplateRenderer
107
- :item="item"
108
- :index="i"
109
- />
110
- </slot>
111
- </VcTableMobileItem>
112
- </div>
113
- <div
114
- v-else
115
- class="vc-table__mobile-empty"
56
+ <VcTableMobileView
57
+ v-if="$isMobile.value"
58
+ :items="items"
59
+ :columns="columns"
60
+ :item-action-builder="itemActionBuilder"
61
+ :multiselect="multiselect"
62
+ :disabled-selection="disabledSelection"
63
+ :selection="selection"
64
+ :is-selected="isSelected"
65
+ :row-checkbox="rowCheckbox"
66
+ :editing="editing"
67
+ :columns-init="columnsInit"
68
+ :search-value="searchValue"
69
+ :active-filter-count="activeFilterCount"
70
+ :notfound="notfound"
71
+ :empty="empty"
72
+ @item-click="$emit('itemClick', $event)"
73
+ @on-edit-complete="$emit('onEditComplete', $event)"
74
+ @on-cell-blur="$emit('onCellBlur', $event)"
75
+ >
76
+ <template
77
+ v-for="slot in slotNames"
78
+ :key="slot"
79
+ #[slot]="slotProps"
116
80
  >
117
- <!-- Empty table view -->
118
- <VcTableEmpty
119
- :items="items"
120
- :columns-init="columnsInit"
121
- :search-value="searchValue"
122
- :active-filter-count="activeFilterCount"
123
- :notfound="notfound"
124
- :empty="empty"
125
- >
126
- <template #notfound>
127
- <slot name="notfound"></slot>
128
- </template>
129
- <template #empty>
130
- <slot name="empty"></slot>
131
- </template>
132
- </VcTableEmpty>
133
- </div>
134
- </template>
81
+ <slot
82
+ :name="slot"
83
+ v-bind="slotProps"
84
+ />
85
+ </template>
86
+ </VcTableMobileView>
135
87
 
136
88
  <!-- Desktop table view -->
137
- <div
89
+ <VcTableDesktopView
138
90
  v-else
139
- ref="tableRef"
140
- class="vc-table__desktop-table"
141
- :class="{
142
- 'vc-table__empty': !items || !items.length,
143
- 'vc-table__multiselect': multiselect,
144
- }"
91
+ :items="items"
92
+ :filtered-cols="filteredCols"
93
+ :multiselect="multiselect"
94
+ :header-checkbox="headerCheckbox"
95
+ :is-header-hover="isHeaderHover"
96
+ :expanded="expanded"
97
+ :editing="editing"
98
+ :sort-field="sortField"
99
+ :sort-direction="sortDirection"
100
+ :resizable-columns="resizableColumns"
101
+ :internal-columns-sorted="internalColumnsSorted"
102
+ :state-key="stateKey"
103
+ :select-all="selectAll"
104
+ :show-selection-choice="showSelectionChoice"
105
+ :all-selected="allSelected"
106
+ :selection="selection"
107
+ :is-selected="isSelected"
108
+ :disabled-selection="disabledSelection"
109
+ :columns-init="columnsInit"
110
+ :selected-item-id="selectedItemId"
111
+ :reorderable-rows="reorderableRows"
112
+ :enable-item-actions="enableItemActions"
113
+ :item-action-builder="itemActionBuilder"
114
+ :item-actions="itemActions"
115
+ :selected-row-index="selectedRowIndex"
116
+ :has-click-listener="hasClickListener"
117
+ :search-value="searchValue"
118
+ :active-filter-count="activeFilterCount"
119
+ :notfound="notfound"
120
+ :empty="empty"
121
+ :row-checkbox="rowCheckbox"
122
+ :reorderable-columns="reorderableColumns"
123
+ :internal-columns="internalColumns"
124
+ @item-click="$emit('itemClick', $event)"
125
+ @on-edit-complete="$emit('onEditComplete', $event)"
126
+ @on-cell-blur="$emit('onCellBlur', $event)"
127
+ @header-mouse-over="handleHeaderMouseOver"
128
+ @column-switcher="handleColumnSwitcher"
129
+ @header-click="handleHeaderClick"
130
+ @select-all="handleSelectAll"
131
+ @column-reorder="saveState"
132
+ @column-resize="saveState"
133
+ @row:reorder="$emit('row:reorder', $event)"
134
+ @show-actions="showActions"
135
+ @close-actions="closeActions"
136
+ @toggle-column="toggleColumn"
137
+ @update:header-checkbox="
138
+ (event: boolean) => {
139
+ headerCheckbox = event;
140
+ }
141
+ "
145
142
  >
146
- <div
147
- v-if="filteredCols.length"
148
- class="vc-table__header"
149
- @mouseenter="handleHeaderMouseOver(true)"
150
- @mouseleave="handleHeaderMouseOver(false)"
143
+ <template
144
+ v-for="slot in slotNames"
145
+ :key="slot"
146
+ #[slot]="slotProps"
151
147
  >
152
- <div class="vc-table__header-row">
153
- <div
154
- v-if="multiselect && items && items.length"
155
- class="vc-table__header-checkbox"
156
- >
157
- <div class="vc-table__header-checkbox__content">
158
- <VcCheckbox
159
- v-if="!noHeaderCheckbox"
160
- v-model="headerCheckbox"
161
- size="m"
162
- @click.stop
163
- ></VcCheckbox>
164
- </div>
165
- <div class="vc-table__header-checkbox__resizer"></div>
166
- </div>
167
- <div
168
- v-for="(item, index) in filteredCols"
169
- :id="item.id"
170
- :key="item.id"
171
- class="vc-table__header-cell"
172
- :class="[
173
- {
174
- 'vc-table__header-cell--sortable': item.sortable,
175
- 'vc-table__header-cell--last': index === filteredCols.length - 1,
176
- },
177
- item.align ? tableAlignment[item.align as keyof typeof tableAlignment] : '',
178
- ]"
179
- :style="{ maxWidth: item.width, width: item.width }"
180
- @mousedown="onColumnHeaderMouseDown"
181
- @dragstart="onColumnHeaderDragStart($event, item)"
182
- @dragover="onColumnHeaderDragOver"
183
- @dragleave="onColumnHeaderDragLeave"
184
- @drop="onColumnHeaderDrop($event, item)"
185
- @click="handleHeaderClick(item)"
186
- >
187
- <div class="vc-table__header-cell__content">
188
- <div class="vc-table__header-cell__title">
189
- <span
190
- v-if="editing && item.rules?.required"
191
- class="vc-table__header-cell__required"
192
- >*</span
193
- >
194
- <slot :name="`header_${item.id}`">{{ item.title }}</slot>
195
- </div>
196
- <div
197
- v-if="sortField === item.id"
198
- class="vc-table__header-cell__sort-icon"
199
- >
200
- <VcIcon
201
- size="xs"
202
- :icon="`fas fa-caret-${sortDirection === 'DESC' ? 'down' : 'up'}`"
203
- ></VcIcon>
204
- </div>
205
- <div
206
- v-else
207
- class="vc-table__header-cell__sort-icons"
208
- >
209
- <VcIcon
210
- size="xs"
211
- icon="fas fa-caret-up"
212
- ></VcIcon>
213
- <VcIcon
214
- size="xs"
215
- icon="fas fa-caret-down"
216
- ></VcIcon>
217
- </div>
218
- </div>
219
- <div
220
- class="vc-table__header-cell__resizer"
221
- :class="{
222
- 'vc-table__header-cell__resizer--cursor': props.resizableColumns,
223
- }"
224
- @mousedown="handleMouseDown($event, item)"
225
- ></div>
226
- </div>
227
-
228
- <div
229
- v-if="isHeaderHover && props.expanded"
230
- class="vc-table__column-switcher"
231
- >
232
- <VcTableColumnSwitcher
233
- :items="internalColumnsSorted"
234
- :state-key="stateKey"
235
- @change="toggleColumn"
236
- @on-active="handleColumnSwitcher"
237
- ></VcTableColumnSwitcher>
238
- </div>
239
- </div>
240
-
241
- <div
242
- ref="resizer"
243
- class="vc-table__resizer"
244
- ></div>
245
- <div
246
- ref="reorderRef"
247
- class="vc-table__reorder-ref"
248
- ></div>
249
- </div>
250
- <div
251
- v-if="selectAll && showSelectionChoice"
252
- class="vc-table__select-all-footer"
253
- >
254
- <div class="vc-table__select-all-footer__content">
255
- <div>
256
- {{
257
- allSelected
258
- ? t("COMPONENTS.ORGANISMS.VC_TABLE.ALL_SELECTED")
259
- : t("COMPONENTS.ORGANISMS.VC_TABLE.CURRENT_PAGE_SELECTED")
260
- }}
261
- <VcButton
262
- text
263
- class="vc-table__select-all-footer__button"
264
- @click="handleSelectAll"
265
- >
266
- {{
267
- allSelected
268
- ? t("COMPONENTS.ORGANISMS.VC_TABLE.CANCEL")
269
- : t("COMPONENTS.ORGANISMS.VC_TABLE.SELECT_ALL")
270
- }}
271
- </VcButton>
272
- </div>
273
- </div>
274
- </div>
275
- <div
276
- v-if="items && items.length && !columnsInit"
277
- ref="tableBody"
278
- class="vc-table__body"
279
- >
280
- <div
281
- v-for="(item, itemIndex) in items"
282
- :key="(typeof item === 'object' && 'id' in item && item.id) || itemIndex"
283
- class="vc-table__body-row"
284
- :class="{
285
- 'vc-table__body-row--odd': itemIndex % 2 === 0,
286
- 'vc-table__body-row--clickable': hasClickListener,
287
- 'vc-table__body-row--even': itemIndex % 2 === 1,
288
- 'vc-table__body-row--selected':
289
- typeof item === 'object' && 'id' in item && item.id ? toValue(selectedItemId) === item.id : false,
290
- 'vc-table__body-row--selection': selection && selection.length && selection.includes(item),
291
- }"
292
- @click="$emit('itemClick', item)"
293
- @mouseleave="closeActions"
294
- @mousedown="onRowMouseDown"
295
- @dragstart="onRowDragStart($event, item)"
296
- @dragover="onRowDragOver($event, item)"
297
- @dragleave="onRowDragLeave"
298
- @dragend="onRowDragEnd"
299
- @drop="onRowDrop"
300
- @mouseover="showActions(itemIndex)"
301
- >
302
- <div
303
- v-if="multiselect && typeof item === 'object'"
304
- class="vc-table__body-row-checkbox"
305
- @click.stop
306
- >
307
- <div class="vc-table__body-row-checkbox-content">
308
- <VcCheckbox
309
- :model-value="isSelected(item)"
310
- size="m"
311
- :disabled="disabledSelection.includes(item)"
312
- @update:model-value="rowCheckbox(item)"
313
- ></VcCheckbox>
314
- </div>
315
- <div class="vc-table__body-row-checkbox-resizer"></div>
316
- </div>
317
- <div
318
- v-for="cell in filteredCols"
319
- :id="`${(typeof item === 'object' && 'id' in item && item.id) || itemIndex}_${cell.id}`"
320
- :key="`${(typeof item === 'object' && 'id' in item && item.id) || itemIndex}_${cell.id}`"
321
- class="vc-table__body-cell"
322
- :class="[cell.class]"
323
- :style="{ maxWidth: cell.width, width: cell.width }"
324
- >
325
- <div class="vc-table__body-cell__content">
326
- <slot
327
- :name="`item_${cell.id}`"
328
- :item="item"
329
- :cell="cell"
330
- :index="itemIndex"
331
- >
332
- <VcTableCell
333
- :item="item as TableItem"
334
- :cell="cell as ITableColumns"
335
- :index="itemIndex"
336
- :editing="editing"
337
- @update="$emit('onEditComplete', { event: $event, index: itemIndex })"
338
- @blur="$emit('onCellBlur', $event)"
339
- ></VcTableCell>
340
- </slot>
341
- </div>
342
- </div>
343
- <div
344
- v-if="
345
- enableItemActions && itemActionBuilder && typeof item === 'object' && selectedRowIndex === itemIndex
346
- "
347
- class="vc-table__body-actions"
348
- :class="{
349
- 'vc-table__body-actions--hover': hasClickListener,
350
- 'vc-table__body-actions--selected':
351
- hasClickListener && selection && selection.length && selection.includes(item),
352
- }"
353
- @click.stop
354
- >
355
- <div class="vc-table__body-actions-content">
356
- <div
357
- v-for="(itemAction, i) in itemActions[itemIndex]"
358
- :key="i"
359
- class="vc-table__body-actions-item"
360
- @click.stop="itemAction.clickHandler(item, itemIndex)"
361
- >
362
- <VcTooltip
363
- placement="bottom"
364
- :offset="{
365
- mainAxis: 5,
366
- }"
367
- >
368
- <VcIcon
369
- :icon="itemAction.icon"
370
- size="m"
371
- />
372
- <template #tooltip>
373
- <div class="vc-table__body-actions-tooltip">
374
- {{ itemAction.title }}
375
- </div>
376
- </template>
377
- </VcTooltip>
378
- </div>
379
- </div>
380
- </div>
381
- </div>
382
- </div>
383
- <div
384
- v-else
385
- class="vc-table__body-empty"
386
- >
387
- <!-- Empty table view -->
388
- <VcTableEmpty
389
- :items="items"
390
- :columns-init="columnsInit"
391
- :search-value="searchValue"
392
- :active-filter-count="activeFilterCount"
393
- :notfound="notfound"
394
- :empty="empty"
395
- >
396
- <template #notfound>
397
- <slot name="notfound"></slot>
398
- </template>
399
- <template #empty>
400
- <slot name="empty"></slot>
401
- </template>
402
- </VcTableEmpty>
403
- </div>
404
- </div>
148
+ <slot
149
+ :name="slot"
150
+ v-bind="slotProps"
151
+ />
152
+ </template>
153
+ </VcTableDesktopView>
154
+
405
155
  <VcTableAddNew
406
156
  :editing="editing"
407
157
  :add-new-row-button="addNewRowButton"
@@ -410,75 +160,43 @@
410
160
  </VcContainer>
411
161
  </div>
412
162
 
413
- <!-- Table footer -->
414
- <slot
163
+ <VcTableFooter
415
164
  v-if="($slots['footer'] || footer) && items && items.length && !columnsInit"
416
- name="footer"
417
- >
418
- <div
419
- class="vc-table__footer"
420
- :class="{
421
- 'vc-table__footer--mobile': $isMobile.value,
422
- 'vc-table__footer--desktop': $isDesktop.value,
423
- }"
424
- >
425
- <!-- Table pagination -->
426
- <VcPagination
427
- :expanded="expanded"
428
- :pages="pages"
429
- :current-page="currentPage"
430
- :variant="paginationVariant"
431
- @item-click="
432
- (event) => {
433
- //scroll table to top
434
- tableBody?.scrollTo(0, 0);
435
- $emit('paginationClick', event);
436
- }
437
- "
438
- ></VcPagination>
439
-
440
- <!-- Table counter -->
441
- <VcTableCounter
442
- :label="totalLabel || $t('COMPONENTS.ORGANISMS.VC_TABLE.TOTALS')"
443
- :value="totalCount"
444
- ></VcTableCounter>
445
- </div>
446
- </slot>
165
+ :total-label="totalLabel"
166
+ :total-count="totalCount"
167
+ :expanded="expanded"
168
+ :pages="pages"
169
+ :current-page="currentPage"
170
+ :pagination-variant="paginationVariant"
171
+ @item-click="
172
+ (event: number) => {
173
+ //scroll table to top
174
+ tableBody?.scrollTo(0, 0);
175
+ $emit('paginationClick', event);
176
+ }
177
+ "
178
+ ></VcTableFooter>
447
179
  </div>
448
180
  </template>
449
181
 
450
182
  <!-- eslint-disable @typescript-eslint/no-explicit-any -->
451
183
  <script lang="ts" setup generic="T extends TableItem | string">
452
- import { useCurrentElement, useLocalStorage } from "@vueuse/core";
453
- import {
454
- MaybeRef,
455
- Ref,
456
- computed,
457
- h,
458
- onBeforeUnmount,
459
- ref,
460
- toValue,
461
- unref,
462
- watch,
463
- getCurrentInstance,
464
- shallowRef,
465
- useSlots,
466
- VNode,
467
- } from "vue";
468
- import { useI18n } from "vue-i18n";
469
- import { VcButton, VcCheckbox, VcContainer, VcIcon, VcPagination, VcLabel } from "./../../";
184
+ import { MaybeRef, Ref, computed, ref, unref, watch, getCurrentInstance, VNode, useSlots, toRefs } from "vue";
185
+ import { VcContainer, VcPagination } from "./../../";
470
186
  import { IActionBuilderResult, ITableColumns } from "./../../../../core/types";
471
- import VcTableCell from "./_internal/vc-table-cell/vc-table-cell.vue";
472
- import VcTableColumnSwitcher from "./_internal/vc-table-column-switcher/vc-table-column-switcher.vue";
473
- import VcTableCounter from "./_internal/vc-table-counter/vc-table-counter.vue";
474
- import VcTableMobileItem from "./_internal/vc-table-mobile-item/vc-table-mobile-item.vue";
475
- import VcTableBaseHeader from "./_internal/vc-table-base-header/vc-table-base-header.vue";
476
187
  import * as _ from "lodash-es";
477
188
  import "core-js/actual/array/to-spliced";
478
189
  import "core-js/actual/array/to-sorted";
479
190
  import VcTableAddNew from "./_internal/vc-table-add-new/vc-table-add-new.vue";
480
- import VcTableEmpty from "./_internal/vc-table-empty/vc-table-empty.vue";
481
191
  import type { ComponentProps } from "vue-component-type-helpers";
192
+ import { useTableSelection } from "./composables/useTableSelection";
193
+ import { useTableState } from "./composables/useTableState";
194
+ import { useTableActions } from "./composables/useTableActions";
195
+ import VcTableMobileView from "./_internal/vc-table-mobile-view/vc-table-mobile-view.vue";
196
+ import VcTableDesktopView from "./_internal/vc-table-desktop-view/vc-table-desktop-view.vue";
197
+ import VcTableHeader from "./_internal/vc-table-header/vc-table-header.vue";
198
+ import VcTableSelectAll from "./_internal/vc-table-select-all/vc-table-select-all.vue";
199
+ import VcTableFooter from "./_internal/vc-table-footer/vc-table-footer.vue";
482
200
 
483
201
  export interface StatusImage {
484
202
  image?: string;
@@ -498,7 +216,7 @@ export type TableColPartial = Partial<
498
216
  }
499
217
  >;
500
218
 
501
- defineSlots<{
219
+ export interface TableSlots<T> {
502
220
  header: (props: { header: VNode }) => any;
503
221
  filters: (args: { closePanel: () => void }) => any;
504
222
  "mobile-item": (args: { item: T }) => any;
@@ -507,7 +225,9 @@ defineSlots<{
507
225
  notfound: (props: any) => any;
508
226
  empty: (props: any) => any;
509
227
  footer: (props: any) => any;
510
- }>();
228
+ }
229
+
230
+ defineSlots<TableSlots<T>>();
511
231
 
512
232
  const props = withDefaults(
513
233
  defineProps<{
@@ -579,192 +299,84 @@ const emit = defineEmits<{
579
299
  (e: "onCellBlur", args: { row: number | undefined; field: string }): void;
580
300
  }>();
581
301
 
582
- const { t } = useI18n({ useScope: "global" });
583
302
  const instance = getCurrentInstance();
584
- const slots = useSlots();
303
+
304
+ const { items, columns, stateKey, columnSelector, expanded, selectionItems } = toRefs(props);
585
305
 
586
306
  // template refs
587
- const reorderRef = ref<HTMLElement | null>();
588
- const tableRef = ref<HTMLElement | null>();
589
307
  const tableBody = ref<HTMLElement | null>();
308
+ const scrollContainer = ref<typeof VcContainer>();
590
309
 
591
- // event listeners
592
- let columnResizeListener: ((...args: any[]) => any) | null = null;
593
- let columnResizeEndListener: ((...args: any[]) => any) | null = null;
594
-
595
- const selection = ref<T[]>([]) as Ref<T[]>;
596
- const allSelected = ref(false);
310
+ const slots = useSlots();
597
311
 
598
- const selectedRowIndex = shallowRef();
312
+ const slotNames = Object.keys(slots) as unknown;
313
+
314
+ const {
315
+ selection,
316
+ allSelected,
317
+ disabledSelection,
318
+ headerCheckbox,
319
+ showSelectionChoice,
320
+ isSelected,
321
+ handleSelectAll,
322
+ rowCheckbox,
323
+ } = useTableSelection<T>({
324
+ items,
325
+ disableItemCheckbox: props.disableItemCheckbox,
326
+ totalCount: props.totalCount,
327
+ onSelectionChanged: (values) => emit("selectionChanged", values),
328
+ onSelectAll: (value) => emit("select:all", value),
329
+ });
599
330
 
600
- const scrollContainer = ref<typeof VcContainer>();
331
+ const { itemActions, selectedRowIndex, calculateActions, showActions, closeActions } = useTableActions({
332
+ enableItemActions: props.enableItemActions,
333
+ itemActionBuilder: props.itemActionBuilder,
334
+ });
601
335
 
602
- const itemActions: Ref<IActionBuilderResult[][]> = ref([]);
603
- const disabledSelection: Ref<T[]> = ref([]);
604
- const mobileSwipeItem = ref<string>();
605
- const columnResizing = ref(false);
606
- const resizeColumnElement = ref<TableColPartial>();
607
- const nextColumn = ref<TableColPartial>();
608
- const lastResize = ref<number>();
609
- const table = useCurrentElement();
610
- const resizer = ref();
611
336
  const isHeaderHover = ref(false);
612
337
  const columnSwitcherActive = ref(false);
613
- const state = useLocalStorage<TableColPartial[]>("VC_TABLE_STATE_" + props.stateKey?.toUpperCase(), []);
614
- const internalColumns: Ref<TableColPartial[]> = ref([]);
615
- const draggedColumn = ref();
616
- const draggedElement = ref<HTMLElement>();
617
- const dropPosition = ref();
618
- const columnsInit = ref(true);
619
- // const isHovered = ref(undefined) as Ref<{ item: T; state: boolean } | undefined>;
620
-
621
- // row reordering variables
622
- const draggedRow = ref<T>();
623
- const rowDragged = ref(false);
624
- const droppedRowIndex = ref<number>();
625
- const draggedRowIndex = ref<number>();
626
-
627
- onBeforeUnmount(() => {
628
- unbindColumnResizeEvents();
338
+
339
+ const {
340
+ internalColumns,
341
+ columnsInit,
342
+ internalColumnsSorted,
343
+ filteredCols,
344
+ saveState,
345
+ toggleColumn,
346
+ initializeColumns,
347
+ } = useTableState({
348
+ stateKey,
349
+ columnSelector,
350
+ expanded,
629
351
  });
630
352
 
631
353
  const sortDirection = computed(() => {
632
354
  const entry = props.sort?.split(":");
633
- return entry && entry.length === 2 && entry[1];
355
+ return (entry && entry.length === 2 && entry[1]) || "";
634
356
  });
635
357
 
636
358
  const sortField = computed(() => {
637
359
  const entry = props.sort?.split(":");
638
- return entry && entry.length === 2 && entry[0];
360
+ return (entry && entry.length === 2 && entry[0]) || "";
639
361
  });
640
362
 
641
363
  const hasClickListener = typeof instance?.vnode.props?.["onItemClick"] === "function";
642
364
 
643
- // const renderCellSlot = ({ item, cell, index }: { item: T; cell: ITableColumns; index: number }) => {
644
- // const isSlotExist = slots[`item_${cell.id}`];
645
-
646
- // const isFirstCell = filteredCols.value.indexOf(cell) === 0;
647
-
648
- // const isRowSelected = isSelected(item);
649
-
650
- // const checkboxComponent = h(
651
- // "div",
652
- // {
653
- // class: "tw-absolute tw-z-10 tw-top-0 tw-bottom-0 tw-left-[20px] tw-right-0 tw-flex tw-items-center",
654
- // },
655
- // h(VcCheckbox, {
656
- // class: "",
657
- // size: "m",
658
- // modelValue: isSelected(item),
659
- // onClick: (e: Event) => e.stopPropagation(),
660
- // onMouseover: () => (isHovered.value = { state: true, item: item }),
661
- // onMouseout: () => (isHovered.value = { state: false, item: item }),
662
- // "onUpdate:modelValue": () => {
663
- // rowCheckbox(item);
664
- // },
665
- // }),
666
- // );
667
-
668
- // const checkboxVisibilityHandler =
669
- // !props.editing &&
670
- // props.multiselect &&
671
- // props.items &&
672
- // props.items.length &&
673
- // ((isFirstCell && selectedRowIndex.value === index) || (isRowSelected && isFirstCell));
674
-
675
- // return h("div", { class: "" }, [
676
- // checkboxVisibilityHandler ? checkboxComponent : undefined,
677
- // h(
678
- // "div",
679
- // {
680
- // class: checkboxVisibilityHandler
681
- // ? isHovered.value?.item === item && isHovered.value.state
682
- // ? "tw-opacity-5"
683
- // : "tw-opacity-15"
684
- // : "",
685
- // },
686
- // !isSlotExist
687
- // ? h(VcTableCell, {
688
- // cell,
689
-
690
- // item: item as TableItem,
691
- // index,
692
- // editing: props.editing,
693
- // onUpdate: (event) => {
694
- // emit("onEditComplete", { event, index });
695
- // },
696
- // onBlur: (event) => emit("onCellBlur", event),
697
- // })
698
- // : slots[`item_${cell.id}`]?.({ item, cell, index }),
699
- // ),
700
- // ]);
701
- // };
702
-
703
- // const calculateElWidth = (id: string) => {
704
- // const el = document.getElementById(id);
705
- // return el ? el.offsetWidth : 0;
706
- // };
707
-
708
- const headerComponent = () =>
709
- h(
710
- VcTableBaseHeader,
711
- {
712
- searchValue: props.searchValue,
713
- searchPlaceholder: props.searchPlaceholder,
714
- activeFilterCount: props.activeFilterCount,
715
- expanded: props.expanded,
716
- "onSearch:change": (value: string) => emit("search:change", value),
717
- disableFilter: props.disableFilter,
718
- },
719
- slots.filters
720
- ? {
721
- filters: () => {
722
- return slots.filters?.({ closePanel: () => {} });
723
- },
724
- }
725
- : undefined,
726
- );
727
-
728
- const allColumns = ref([]) as Ref<TableColPartial[]>;
729
-
730
- const mobileTemplateRenderer = ({ item, index }: { item: TableItem | string; index: number }) => {
731
- return h(
732
- "div",
733
- {
734
- class: "vc-table__mobile-items-renderer",
735
- },
736
- props.columns.map((x) => {
737
- return h("div", { class: "tw-grow tw-w-[33%] tw-ml-3 tw-truncate", key: `mobile-view-item-${index}` }, [
738
- h(VcLabel, { class: "tw-mb-1 tw-truncate", required: x?.rules?.required }, () => toValue(x.title)),
739
- slots[`item_${x.id}`]
740
- ? slots[`item_${x.id}`]?.({ item, cell: x, index })
741
- : [
742
- typeof item === "object"
743
- ? h(VcTableCell, {
744
- cell: { ...x, class: "!tw-justify-start " },
745
- item,
746
- key: `mobile-view-cell-${index}`,
747
- class: "tw-mb-4",
748
- editing: props.editing,
749
- index,
750
- onUpdate: (event) => {
751
- emit("onEditComplete", { event: event, index });
752
- },
753
- onBlur: (event) => emit("onCellBlur", event),
754
- })
755
- : undefined,
756
- ],
757
- ]);
758
- }),
759
- );
760
- };
365
+ watch(
366
+ () => items.value,
367
+ (newVal) => {
368
+ scrollContainer.value?.scrollTop();
369
+ calculateActions(newVal);
370
+ },
371
+ { deep: true, immediate: true },
372
+ );
761
373
 
762
374
  watch(
763
- () => props.selectionItems,
375
+ () => selectionItems.value,
764
376
  (newVal) => {
765
377
  if (newVal) {
766
378
  if (!newVal?.length) return;
767
- selection.value = _.merge(selection.value, newVal);
379
+ selection.value = _.merge([], selection.value, newVal) as T[];
768
380
  }
769
381
  },
770
382
  {
@@ -773,145 +385,13 @@ watch(
773
385
  );
774
386
 
775
387
  watch(
776
- [() => props.items, () => props.columns],
388
+ [() => items.value, () => columns.value],
777
389
  ([newValItems, newValCols]) => {
778
- let predefinedCols: ITableColumns[] = [];
779
- let otherCols: ITableColumns[] = [];
780
-
781
- // Helper function to process columns
782
- const processColumns = (columns: ITableColumns[], predefined: boolean, defaultVisible: boolean) =>
783
- columns.map((item) => ({
784
- ...item,
785
- predefined,
786
- visible: typeof item.visible !== "undefined" ? item.visible : defaultVisible,
787
- }));
788
-
789
- // Process predefined columns
790
- if (newValCols && newValCols.length) {
791
- predefinedCols = processColumns(newValCols, true, true);
792
- }
793
-
794
- if (props.columnSelector === "auto") {
795
- // Generate columns automatically from items
796
- if (newValItems && newValItems.length) {
797
- const itemKeys = Object.keys(newValItems[0]);
798
- otherCols = itemKeys.map((key) => ({
799
- id: key,
800
- title: key.replace(/([A-Z])/g, " $1").replace(/^./, (str) => str.toUpperCase()),
801
- visible: false,
802
- predefined: false,
803
- }));
804
- }
805
-
806
- // Combine columns and restore state
807
- allColumns.value = _.unionBy(predefinedCols, otherCols, "id");
808
- restoreState(predefinedCols);
809
- } else if (props.columnSelector === "defined") {
810
- allColumns.value = predefinedCols;
811
- restoreState(predefinedCols);
812
- } else {
813
- // Get columns from columnSelector
814
- const getDefinedColumns = (): ITableColumns[] => {
815
- if (typeof props.columnSelector === "function") {
816
- return props.columnSelector();
817
- }
818
- return toValue(props.columnSelector) as ITableColumns[];
819
- };
820
-
821
- const definedCols = processColumns(getDefinedColumns(), false, false);
822
-
823
- // Combine columns and restore state
824
- allColumns.value = _.unionBy(predefinedCols, definedCols, "id");
825
- restoreState(allColumns.value);
826
- }
827
-
828
- columnsInit.value = false;
829
- },
830
- { deep: true, immediate: true },
831
- );
832
-
833
- const internalColumnsSorted = computed(() => {
834
- // alphabetical order
835
- return internalColumns.value /* @ts-expect-error - toSorted is not parsed correctly by ts */
836
- .toSorted((a, b) => {
837
- if (a && b && a.title && b.title) {
838
- return toValue(a.title).localeCompare(toValue(b.title));
839
- }
840
- return 0;
841
- });
842
- });
843
-
844
- const tableAlignment = {
845
- start: "tw-justify-start",
846
- end: "tw-justify-end",
847
- center: "tw-justify-center",
848
- between: "tw-justify-between",
849
- around: "tw-justify-around",
850
- evenly: "tw-justify-evenly",
851
- };
852
-
853
- const headerCheckbox = computed({
854
- get() {
855
- return props.items && props.items.length
856
- ? selection.value.length ===
857
- props.items.length -
858
- (disabledSelection.value.length !== props.items.length ? disabledSelection.value.length : 0)
859
- : false;
860
- },
861
- set(checked: boolean) {
862
- let _selected: T[] = [];
863
-
864
- if (checked) {
865
- _selected = props.items.filter((x) => !disabledSelection.value.includes(x));
866
- }
867
-
868
- selection.value = _selected;
869
- allSelected.value = false;
870
- },
871
- });
872
-
873
- const filteredCols = computed(() => {
874
- return internalColumns.value.filter((x) => {
875
- if (x.visible === false) {
876
- return false;
877
- }
878
- if (!props.expanded) {
879
- return x.alwaysVisible;
880
- }
881
- return x;
882
- });
883
- });
884
-
885
- const showSelectionChoice = computed(() => selection.value.length === props.items.length && props.pages > 1);
886
-
887
- watch(
888
- () => props.items,
889
- (newVal) => {
890
- scrollContainer.value?.scrollTop();
891
-
892
- calculateActions(newVal);
893
- handleMultiselect(newVal);
894
-
895
- selection.value = selection.value.filter((selection) => newVal.includes(selection));
390
+ initializeColumns(newValCols, newValItems);
896
391
  },
897
392
  { deep: true, immediate: true },
898
393
  );
899
394
 
900
- watch(
901
- () => selection.value,
902
- (newVal) => {
903
- emit("selectionChanged", newVal);
904
- },
905
- { deep: true },
906
- );
907
-
908
- watch(
909
- () => allSelected.value,
910
- (newVal) => {
911
- emit("select:all", newVal);
912
- },
913
- );
914
-
915
395
  function handleHeaderMouseOver(state: boolean) {
916
396
  if (columnSwitcherActive.value) {
917
397
  return;
@@ -927,575 +407,46 @@ function handleColumnSwitcher(state: boolean) {
927
407
  }
928
408
  }
929
409
 
930
- function handleSelectAll() {
931
- allSelected.value = !allSelected.value;
932
-
933
- if (!allSelected.value) {
934
- selection.value = [];
935
- return;
936
- }
937
- }
938
-
939
- function isSelected(item: T) {
940
- return !!selection.value.find((x) => _.isEqual(x, item));
941
- }
942
-
943
- function rowCheckbox(item: T) {
944
- const clear = item;
945
-
946
- // const index = props.items.findIndex((x) => _.isEqual(x, clear));
947
-
948
- if (disabledSelection.value.includes(item)) {
949
- return;
950
- }
951
-
952
- const isExist = selection.value.find((x) => _.isEqual(x, clear));
953
-
954
- if (isExist) {
955
- selection.value = selection.value.filter((x) => !_.isEqual(x, clear));
956
- } else {
957
- selection.value.push(clear);
958
- }
959
- }
960
-
961
- function showActions(index: number) {
962
- if (typeof props.items[index] === "object") {
963
- selectedRowIndex.value = index;
964
- }
965
- }
966
-
967
- async function calculateActions(items: T[]) {
968
- if (props.enableItemActions && typeof props.itemActionBuilder === "function") {
969
- const populatedItems: IActionBuilderResult[][] = [];
970
- for (let index = 0; index < items.length; index++) {
971
- if (typeof items[index] === "object") {
972
- const elementWithActions = await props.itemActionBuilder(items[index]);
973
- if (elementWithActions) {
974
- populatedItems.push(elementWithActions);
975
- }
976
- }
977
- }
978
- itemActions.value = populatedItems;
979
- }
980
- }
981
-
982
- async function handleMultiselect(items: T[]) {
983
- if (props.multiselect && props.disableItemCheckbox && typeof props.disableItemCheckbox === "function") {
984
- const disabledMultiselect = [];
985
- for (let index = 0; index < items.length; index++) {
986
- if (typeof items[index] === "object") {
987
- const element = await props.disableItemCheckbox(items[index]);
988
-
989
- if (element) {
990
- disabledMultiselect.push(items[index]);
991
- }
992
- }
993
- }
994
- disabledSelection.value = disabledMultiselect as T[];
995
- }
996
- }
997
-
998
- function closeActions() {
999
- selectedRowIndex.value = undefined;
1000
- }
1001
-
1002
- function handleSwipe(id: string) {
1003
- mobileSwipeItem.value = id;
1004
- }
1005
-
1006
410
  function handleHeaderClick(item: TableColPartial) {
1007
411
  const cleanCol = item;
1008
412
  delete cleanCol.predefined;
1009
413
  emit("headerClick", cleanCol as ITableColumns);
1010
414
  }
1011
-
1012
- function handleMouseDown(e: MouseEvent, item: TableColPartial) {
1013
- if (props.resizableColumns) {
1014
- const containerLeft = getOffset(table.value as HTMLElement).left;
1015
- resizeColumnElement.value = item;
1016
- columnResizing.value = true;
1017
- lastResize.value = e.pageX - containerLeft + (table.value as HTMLDivElement).scrollLeft;
1018
-
1019
- bindColumnResizeEvents();
1020
- }
1021
- }
1022
-
1023
- function bindColumnResizeEvents() {
1024
- if (!columnResizeListener) {
1025
- columnResizeListener = document.addEventListener("mousemove", (event: MouseEvent) => {
1026
- if (columnResizing.value) {
1027
- onColumnResize(event);
1028
- }
1029
- }) as unknown as typeof document.addEventListener;
1030
- }
1031
- if (!columnResizeEndListener) {
1032
- columnResizeEndListener = document.addEventListener("mouseup", () => {
1033
- if (columnResizing.value) {
1034
- columnResizing.value = false;
1035
- onColumnResizeEnd();
1036
- }
1037
- }) as unknown as typeof document.addEventListener;
1038
- }
1039
- }
1040
-
1041
- function unbindColumnResizeEvents() {
1042
- if (columnResizeListener) {
1043
- document.removeEventListener("document", columnResizeListener);
1044
- columnResizeListener = null;
1045
- }
1046
- if (columnResizeEndListener) {
1047
- document.removeEventListener("document", columnResizeEndListener);
1048
- columnResizeEndListener = null;
1049
- }
1050
- }
1051
-
1052
- function onColumnResize(event: MouseEvent) {
1053
- if (columnResizing.value) {
1054
- const containerLeft = getOffset(table.value as HTMLElement).left;
1055
-
1056
- resizer.value.style.top = 0 + "px";
1057
- const leftOffset = event.pageX - containerLeft + (table.value as HTMLDivElement).scrollLeft;
1058
- resizer.value.style.left =
1059
- Math.min(leftOffset, (table.value as HTMLDivElement).offsetWidth - resizer.value.offsetWidth - 70) + "px";
1060
- resizer.value.style.display = "block";
1061
- }
1062
- }
1063
-
1064
- function getOffset(element: HTMLElement) {
1065
- if (!element.getClientRects().length) {
1066
- return { top: 0, left: 0 };
1067
- }
1068
-
1069
- const rect = element.getBoundingClientRect();
1070
- const win = element.ownerDocument.defaultView;
1071
- return {
1072
- top: rect.top + ((win && win.scrollY) ?? 0),
1073
- left: rect.left + ((win && win.scrollX) ?? 0),
1074
- };
1075
- }
1076
-
1077
- function onColumnResizeEnd() {
1078
- const delta = resizer.value.offsetLeft - (lastResize.value ?? 0);
1079
-
1080
- const columnElement: HTMLElement | null = (table.value as HTMLDivElement).querySelector(
1081
- `#${resizeColumnElement.value?.id}`,
1082
- );
1083
-
1084
- if (columnElement) {
1085
- const columnWidth = columnElement.offsetWidth;
1086
- const newColumnWidth = columnWidth + delta;
1087
-
1088
- const minWidth = 15;
1089
-
1090
- if (columnWidth + delta > parseInt(minWidth.toString(), 10) && resizeColumnElement.value) {
1091
- nextColumn.value = filteredCols.value[filteredCols.value.indexOf(resizeColumnElement.value) + 1];
1092
-
1093
- if (nextColumn.value) {
1094
- const nextColElement = (table.value as HTMLDivElement).querySelector(`#${nextColumn.value.id}`);
1095
-
1096
- const nextColumnWidth = (nextColElement as HTMLElement).offsetWidth - delta;
1097
-
1098
- if (newColumnWidth > 15 && nextColumnWidth > 15) {
1099
- resizeTableCells(newColumnWidth, nextColumnWidth);
1100
- }
1101
- } else {
1102
- if (newColumnWidth > 15) {
1103
- resizeColumnElement.value.width = newColumnWidth + "px";
1104
- }
1105
- }
1106
- }
1107
- resizer.value.style.display = "none";
1108
-
1109
- unbindColumnResizeEvents();
1110
-
1111
- saveState();
1112
- }
1113
- }
1114
-
1115
- function resizeTableCells(newColumnWidth: number, nextColumnWidth: number) {
1116
- const colIndex = internalColumns.value.findIndex((col) => col.id === resizeColumnElement.value?.id);
1117
- const widths: number[] = [];
1118
- const tableHeaders = (table.value as HTMLDivElement)?.querySelectorAll(
1119
- ".vc-table__header-cell",
1120
- ) as NodeListOf<HTMLElement>;
1121
- tableHeaders.forEach((header) => widths.push(header.offsetWidth));
1122
-
1123
- internalColumns.value.forEach((col, index) => {
1124
- col.width = widths[index] + "px";
1125
- });
1126
-
1127
- widths.forEach((width, index) => {
1128
- const colWidth =
1129
- index === colIndex ? newColumnWidth : nextColumnWidth && index === colIndex + 1 ? nextColumnWidth : width;
1130
-
1131
- internalColumns.value[index].width = colWidth + "px";
1132
- });
1133
- }
1134
-
1135
- function onColumnHeaderDragStart(event: DragEvent, item: TableColPartial) {
1136
- if (columnResizing.value) {
1137
- event.preventDefault();
1138
- return;
1139
- }
1140
-
1141
- draggedColumn.value = item;
1142
- draggedElement.value = event.target as HTMLElement;
1143
- if (event.dataTransfer) {
1144
- event.dataTransfer.setData("text", "reorder");
1145
- }
1146
- }
1147
-
1148
- function findParentHeader(element: HTMLElement) {
1149
- if (element.classList.contains("vc-table__header-cell")) {
1150
- return element;
1151
- } else {
1152
- let parent = element.parentElement;
1153
-
1154
- while (parent && !parent.classList.contains("vc-table__header-cell")) {
1155
- parent = parent.parentElement;
1156
- if (!parent) break;
1157
- }
1158
-
1159
- return parent;
1160
- }
1161
- }
1162
-
1163
- function onColumnHeaderDragOver(event: DragEvent) {
1164
- const dropHeader = findParentHeader(event.target as HTMLElement);
1165
-
1166
- if (props.reorderableColumns && draggedColumn.value && dropHeader) {
1167
- event.preventDefault();
1168
- const containerOffset = getOffset(table.value as HTMLElement);
1169
- const dropHeaderOffset = getOffset(dropHeader);
1170
-
1171
- if (draggedElement.value !== dropHeader && reorderRef.value && tableRef.value) {
1172
- const targetLeft = dropHeaderOffset.left - containerOffset.left;
1173
- const columnCenter = dropHeaderOffset.left + dropHeader.offsetWidth / 2;
1174
-
1175
- reorderRef.value.style.top = dropHeaderOffset.top - getOffset(tableRef.value).top + "px";
1176
-
1177
- if (event.pageX > columnCenter) {
1178
- reorderRef.value.style.left = targetLeft + dropHeader.offsetWidth - 5 + "px";
1179
-
1180
- dropPosition.value = 1;
1181
- } else {
1182
- reorderRef.value.style.left = targetLeft - 5 + "px";
1183
- dropPosition.value = -1;
1184
- }
1185
-
1186
- reorderRef.value.style.display = "block";
1187
- }
1188
- }
1189
- }
1190
- function onColumnHeaderDragLeave(event: DragEvent) {
1191
- if (props.reorderableColumns && draggedColumn.value) {
1192
- event.preventDefault();
1193
-
1194
- if (reorderRef.value != undefined) {
1195
- reorderRef.value.style.display = "none";
1196
- }
1197
- }
1198
- }
1199
-
1200
- function onColumnHeaderDrop(event: DragEvent, item: TableColPartial) {
1201
- event.preventDefault();
1202
-
1203
- if (draggedColumn.value) {
1204
- const dragIndex = internalColumns.value.indexOf(draggedColumn.value);
1205
- const dropIndex = internalColumns.value.indexOf(item);
1206
-
1207
- let allowDrop = dragIndex !== dropIndex;
1208
-
1209
- if (
1210
- allowDrop &&
1211
- ((dropIndex - dragIndex === 1 && dropPosition.value === -1) ||
1212
- (dropIndex - dragIndex === -1 && dropPosition.value === 1))
1213
- ) {
1214
- allowDrop = false;
1215
- }
1216
-
1217
- if (allowDrop) {
1218
- reorderArray(internalColumns.value, dragIndex, dropIndex);
1219
-
1220
- saveState();
1221
- }
1222
-
1223
- if (reorderRef.value) {
1224
- reorderRef.value.style.display = "none";
1225
- }
1226
- if (draggedElement.value) {
1227
- draggedElement.value.draggable = false;
1228
- }
1229
- draggedColumn.value = null;
1230
- dropPosition.value = null;
1231
- }
1232
- }
1233
-
1234
- function saveState() {
1235
- console.debug("[@vc-shell/framework#vc-table.vue] - Save state");
1236
-
1237
- const colsClone = _.cloneDeep(internalColumns.value);
1238
- state.value = colsClone.map((col) => _.pick(col, "id", "visible", "width", "predefined"));
1239
- }
1240
-
1241
- function restoreState(predefinedColumns: TableColPartial[] = []) {
1242
- const storedState = state.value;
1243
-
1244
- if (!storedState?.length) {
1245
- internalColumns.value = allColumns.value;
1246
- return;
1247
- }
1248
-
1249
- const predefinedMap = new Map(predefinedColumns.map((col) => [col.id, col]));
1250
- const mergedColumns: TableColPartial[] = storedState
1251
- .map((storedCol) => {
1252
- const predefinedCol = predefinedMap.get(storedCol.id);
1253
- return mergeColumns(storedCol, predefinedCol);
1254
- })
1255
- .filter((col) => col.title);
1256
-
1257
- // add predefined columns that are not in stored state
1258
- predefinedColumns.forEach((predefinedCol) => {
1259
- if (!mergedColumns.find((col) => col.id === predefinedCol.id)) {
1260
- mergedColumns.push({ ...predefinedCol, visible: true, predefined: true });
1261
- }
1262
- });
1263
-
1264
- // add other columns to mergedColumns from allColumns array without duplicates
1265
- allColumns.value.forEach((col) => {
1266
- if (!mergedColumns.find((c) => c.id === col.id)) {
1267
- mergedColumns.push(col as TableColPartial);
1268
- }
1269
- });
1270
-
1271
- resetRemovedColumns(storedState, predefinedMap, mergedColumns);
1272
-
1273
- setTitles(mergedColumns);
1274
-
1275
- allColumns.value = [...mergedColumns];
1276
- internalColumns.value = allColumns.value;
1277
-
1278
- saveState();
1279
- }
1280
-
1281
- function mergeColumns(storedCol: TableColPartial, predefinedCol: TableColPartial | undefined) {
1282
- if (predefinedCol) {
1283
- if (predefinedCol.predefined && !storedCol.predefined) {
1284
- return { ...predefinedCol, predefined: true };
1285
- } else {
1286
- return {
1287
- ...predefinedCol,
1288
- visible: storedCol.visible,
1289
- width: storedCol.width,
1290
- title: predefinedCol.title || storedCol.title || "",
1291
- };
1292
- }
1293
- } else {
1294
- return { ...storedCol, predefined: false };
1295
- }
1296
- }
1297
-
1298
- function resetRemovedColumns(
1299
- storedState: TableColPartial[],
1300
- predefinedMap: Map<string | undefined, TableColPartial>,
1301
- mergedColumns: TableColPartial[],
1302
- ) {
1303
- storedState.forEach((storedCol) => {
1304
- if (storedCol.predefined && !predefinedMap.has(storedCol.id)) {
1305
- const existingColumnIndex = mergedColumns.findIndex((col) => col.id === storedCol.id);
1306
- if (existingColumnIndex !== -1) {
1307
- mergedColumns[existingColumnIndex] = {
1308
- ...mergedColumns[existingColumnIndex],
1309
- visible: false,
1310
- width: undefined,
1311
- predefined: false,
1312
- };
1313
- }
1314
- }
1315
- });
1316
- }
1317
-
1318
- function setTitles(mergedColumns: TableColPartial[]) {
1319
- mergedColumns.forEach((col) => {
1320
- if (!col.title) {
1321
- const originalColumn = allColumns.value.find((c) => c.id === col.id);
1322
- if (originalColumn) {
1323
- col.title = originalColumn.title;
1324
- }
1325
- }
1326
- });
1327
- }
1328
-
1329
- function reorderArray(value: unknown[], from: number, to: number) {
1330
- if (value && from !== to) {
1331
- if (to >= value.length) {
1332
- to %= value.length;
1333
- from %= value.length;
1334
- }
1335
-
1336
- value.splice(to, 0, value.splice(from, 1)[0]);
1337
- }
1338
- }
1339
-
1340
- function onColumnHeaderMouseDown(event: MouseEvent) {
1341
- if (props.reorderableColumns) {
1342
- (event.currentTarget as HTMLElement).draggable = true;
1343
- }
1344
- }
1345
-
1346
- function toggleColumn(item: ITableColumns) {
1347
- // if item is not in internalColumns, add it
1348
- if (!internalColumns.value.find((x) => x.id === item.id)) {
1349
- internalColumns.value.push(item);
1350
- } else {
1351
- // internalColumns.value = internalColumns.value.filter((x) => x.id !== item.id);
1352
- }
1353
- if (item) {
1354
- internalColumns.value = internalColumns.value.map((x) => {
1355
- if (x.id === item.id) {
1356
- x = item;
1357
- }
1358
- return x;
1359
- });
1360
- }
1361
-
1362
- saveState();
1363
- }
1364
-
1365
- function onRowMouseDown(event: MouseEvent) {
1366
- if (props.reorderableRows) {
1367
- (event.currentTarget as HTMLElement).draggable = true;
1368
- }
1369
- }
1370
-
1371
- function onRowDragStart(event: DragEvent, item: T) {
1372
- if (!props.reorderableRows) {
1373
- return;
1374
- }
1375
- rowDragged.value = true;
1376
- draggedRow.value = item;
1377
- draggedRowIndex.value = props.items.indexOf(item);
1378
- if (event.dataTransfer) {
1379
- event.dataTransfer.setData("text", "row-reorder");
1380
- }
1381
- }
1382
-
1383
- function onRowDragOver(event: DragEvent, item: T) {
1384
- if (!props.reorderableRows) {
1385
- return;
1386
- }
1387
- const index = props.items.indexOf(item);
1388
-
1389
- if (rowDragged.value && draggedRow.value !== item) {
1390
- const rowElement = event.currentTarget as HTMLElement;
1391
- const rowY = getOffset(rowElement).top;
1392
- const pageY = event.pageY;
1393
- const rowMidY = rowY + rowElement.offsetHeight / 2;
1394
- const previousRowElement = rowElement.previousElementSibling;
1395
-
1396
- if (pageY < rowMidY) {
1397
- rowElement.classList.remove("vc-table__drag-row-bottom");
1398
- droppedRowIndex.value = index;
1399
-
1400
- if (previousRowElement) {
1401
- previousRowElement.classList.add("vc-table__drag-row-bottom");
1402
- } else {
1403
- rowElement.classList.add("vc-table__drag-row-top");
1404
- }
1405
- } else {
1406
- if (previousRowElement) {
1407
- previousRowElement.classList.remove("vc-table__drag-row-bottom");
1408
- } else {
1409
- rowElement.classList.add("vc-table__drag-row-top");
1410
- }
1411
- droppedRowIndex.value = index + 1;
1412
- rowElement.classList.add("vc-table__drag-row-bottom");
1413
- }
1414
-
1415
- event.preventDefault();
1416
- }
1417
- }
1418
-
1419
- function onRowDragLeave(event: DragEvent) {
1420
- event.preventDefault();
1421
-
1422
- const rowElement = event.currentTarget as HTMLElement;
1423
- const previousRowElement = rowElement.previousElementSibling;
1424
-
1425
- if (previousRowElement) {
1426
- previousRowElement.classList.remove("vc-table__drag-row-bottom");
1427
- }
1428
-
1429
- rowElement.classList.remove("vc-table__drag-row-top");
1430
- rowElement.classList.remove("vc-table__drag-row-bottom");
1431
- }
1432
-
1433
- function onRowDragEnd(event: DragEvent) {
1434
- rowDragged.value = false;
1435
- draggedRowIndex.value = undefined;
1436
- droppedRowIndex.value = undefined;
1437
- (event.currentTarget as HTMLElement).draggable = false;
1438
- }
1439
-
1440
- function onRowDrop(event: DragEvent) {
1441
- if (droppedRowIndex.value !== undefined && draggedRowIndex.value !== undefined) {
1442
- const dropIndex =
1443
- draggedRowIndex.value > droppedRowIndex.value
1444
- ? droppedRowIndex.value
1445
- : droppedRowIndex.value === 0
1446
- ? 0
1447
- : droppedRowIndex.value - 1;
1448
-
1449
- const processedItems = [...props.items];
1450
-
1451
- reorderArray(processedItems, draggedRowIndex.value, dropIndex);
1452
-
1453
- emit("row:reorder", {
1454
- dragIndex: draggedRowIndex.value,
1455
- dropIndex: dropIndex,
1456
- value: processedItems as T[],
1457
- });
1458
- }
1459
-
1460
- // cleanup
1461
- onRowDragLeave(event);
1462
- onRowDragEnd(event as DragEvent & { currentTarget?: { draggable: boolean } });
1463
- event.preventDefault();
1464
- }
1465
415
  </script>
1466
416
 
1467
417
  <style lang="scss">
1468
418
  :root {
1469
- --table-border-color: var(--base-border-color, var(--neutrals-200));
1470
- --table-select-all-border-color: var(--base-border-color, var(--neutrals-200));
1471
- --table-header-bg: var(--neutrals-50);
1472
- --table-header-border-color: var(--base-border-color, var(--neutrals-200));
1473
- --table-header-border: inset 0px 1px 0px var(--table-header-border-color),
1474
- inset 0px -1px 0px var(--table-header-border-color);
1475
- --table-header-text-color: var(--secondary-700);
1476
- --table-resizer-color: var(--base-border-color, var(--neutrals-200));
419
+ --table-border-color: var(--neutrals-200);
420
+ --table-select-all-border-color: var(--neutrals-200);
421
+ --table-header-bg: var(--primary-50);
422
+ --table-header-border-color: var(--neutrals-200);
423
+ --table-header-border:
424
+ inset 0px 1px 0px var(--table-header-border-color), inset 0px -1px 0px var(--table-header-border-color);
425
+ --table-header-text-color: var(--secondary-950);
426
+ --table-resizer-color: var(--neutrals-200);
1477
427
  --table-reorder-color: var(--primary-400);
1478
428
  --table-select-all-bg: var(--primary-100);
1479
- --table-row-bg-hover: var(--primary-50);
429
+ --table-row-bg-hover: var(--primary-100);
1480
430
  --table-row-bg-odd: var(--additional-50);
1481
431
  --table-row-bg-even: var(--neutrals-50);
1482
- --table-row-hover: var(--primary-50);
432
+ --table-row-hover: var(--primary-100);
1483
433
  --table-row-bg-selected: var(--primary-100);
1484
- --table-actions-bg: var(--neutrals-100);
1485
- --table-actions-bg-hover: var(--primary-50);
434
+ --table-actions-bg: var(--primary-100);
435
+ --table-actions-bg-hover: var(--primary-100);
1486
436
  --table-actions-bg-hover-selected-item: var(--primary-100);
1487
437
  --table-actions-text-color: var(--neutrals-600);
1488
438
  --table-actions-tooltip-text: var(--neutrals-600);
1489
439
  --table-actions-icon-color: var(--primary-500);
1490
440
  --table-actions-icon-color-hover: var(--primary-600);
1491
441
  --table-footer-bg: var(--neutrals-50);
1492
- --table-footer-border-color: var(--base-border-color, var(--neutrals-200));
442
+ --table-footer-border-color: var(--neutrals-200);
1493
443
  --table-row-drag-color: var(--primary-400);
1494
444
  --table-row-drag-shadow: inset 0 -2px 0 0 var(--table-row-drag-color);
1495
445
  --table-actions-color-danger: var(--danger-500);
1496
446
  --table-actions-color-success: var(--success-500);
1497
447
  --table-mobile-border-color: var(--secondary-200);
1498
- --table-text-color: var(--base-text-color, var(--neutrals-950));
448
+ --table-text-color: var(--neutrals-950);
449
+ --table-sort-icon-color: var(--neutrals-400);
1499
450
  }
1500
451
 
1501
452
  $variants: (
@@ -1505,7 +456,7 @@ $variants: (
1505
456
 
1506
457
  .vc-table {
1507
458
  @apply tw-relative tw-overflow-hidden tw-flex tw-flex-col tw-grow tw-basis-0 tw-border-solid tw-border-t-0;
1508
- @apply tw-flex-auto #{!important};
459
+ @apply tw-flex-auto;
1509
460
  border-color: var(--table-border-color);
1510
461
 
1511
462
  &__multiselect-mobile {
@@ -1544,6 +495,10 @@ $variants: (
1544
495
  @apply tw-flex tw-relative tw-overflow-hidden tw-grow;
1545
496
  }
1546
497
 
498
+ &__scroll-container {
499
+ @apply tw-grow tw-basis-0 tw-relative;
500
+ }
501
+
1547
502
  &__mobile-view {
1548
503
  @apply tw-grow tw-basis-0 tw-relative;
1549
504
  .vc-container__inner {
@@ -1552,7 +507,7 @@ $variants: (
1552
507
  }
1553
508
 
1554
509
  &__mobile-items {
1555
- @apply tw-flex-grow tw-flex tw-flex-col tw-h-max [width:-webkit-fill-available];
510
+ @apply tw-flex-grow tw-flex tw-flex-col tw-h-max [width:-webkit-fill-available] [width:-moz-available];
1556
511
  }
1557
512
 
1558
513
  &__mobile-empty {
@@ -1563,13 +518,17 @@ $variants: (
1563
518
  @apply tw-relative tw-box-border tw-w-full tw-h-full tw-flex tw-flex-col;
1564
519
  }
1565
520
 
521
+ &__header {
522
+ @apply tw-relative;
523
+ }
524
+
1566
525
  &__header-row {
1567
- @apply tw-flex tw-flex-row [box-shadow:var(--table-header-border)];
526
+ @apply tw-flex tw-flex-row [box-shadow:var(--table-header-border)] tw-bg-[--table-header-bg];
1568
527
  }
1569
528
 
1570
529
  &__header-checkbox {
1571
- @apply tw-flex-1 tw-flex tw-items-center tw-justify-center tw-w-9 tw-max-w-9 tw-min-w-9 tw-bg-[--table-header-bg] [box-shadow:var(--table-header-border)] tw-shadow-none tw-box-border tw-sticky tw-top-0 tw-select-none tw-overflow-hidden tw-z-[1];
1572
- @apply tw-border-0 #{!important};
530
+ @apply tw-flex-1 tw-flex tw-items-center tw-justify-center tw-w-9 tw-max-w-9 tw-min-w-9 tw-bg-[--table-header-bg] tw-box-border tw-sticky tw-top-0 tw-select-none tw-overflow-hidden tw-z-[1];
531
+ @apply tw-border-0;
1573
532
  }
1574
533
 
1575
534
  &__header-checkbox__content {
@@ -1581,8 +540,8 @@ $variants: (
1581
540
  }
1582
541
 
1583
542
  &__header-cell {
1584
- @apply tw-flex-1 tw-flex tw-items-center tw-h-10 tw-bg-[--table-header-bg] [box-shadow:var(--table-header-border)] tw-box-border tw-sticky tw-top-0 tw-select-none tw-overflow-hidden tw-z-[1];
1585
- @apply tw-border-0 #{!important};
543
+ @apply tw-flex-1 tw-flex tw-items-center tw-h-[60px] tw-bg-[--table-header-bg] tw-box-border tw-sticky tw-top-0 tw-select-none tw-overflow-hidden tw-z-[1];
544
+ @apply tw-border-0;
1586
545
  }
1587
546
 
1588
547
  &__header-cell--sortable {
@@ -1599,7 +558,7 @@ $variants: (
1599
558
  }
1600
559
 
1601
560
  &__header-cell__content {
1602
- @apply tw-flex tw-items-center tw-flex-nowrap tw-truncate tw-px-3 tw-font-bold tw-text-sm tw-text-[color:var(--table-header-text-color)];
561
+ @apply tw-flex tw-items-center tw-flex-nowrap tw-truncate tw-px-3 tw-font-semibold tw-text-sm tw-text-[color:var(--table-header-text-color)] tw-leading-5;
1603
562
  }
1604
563
 
1605
564
  &__header-cell__title {
@@ -1611,11 +570,11 @@ $variants: (
1611
570
  }
1612
571
 
1613
572
  &__header-cell__sort-icon {
1614
- @apply tw-ml-1;
573
+ @apply tw-ml-1 tw-text-[color:var(--table-sort-icon-color)];
1615
574
  }
1616
575
 
1617
576
  &__header-cell__sort-icons {
1618
- @apply tw-flex tw-flex-col tw-ml-1 tw-invisible;
577
+ @apply tw-flex tw-flex-col tw-ml-1 tw-invisible tw-text-[color:var(--table-sort-icon-color)];
1619
578
  }
1620
579
 
1621
580
  &__header-cell__resizer {
@@ -1656,14 +615,29 @@ $variants: (
1656
615
 
1657
616
  &__body-row {
1658
617
  @apply tw-flex tw-w-full tw-h-14 tw-min-h-14 tw-relative;
1659
-
1660
- &:hover {
1661
- .vc-table__body-actions--hover {
1662
- @apply tw-bg-[--table-actions-bg-hover];
618
+ position: relative;
619
+
620
+ &.vc-table__drag-row-bottom {
621
+ &::after {
622
+ content: "";
623
+ position: absolute;
624
+ bottom: 0;
625
+ left: 0;
626
+ right: 0;
627
+ height: 2px;
628
+ background-color: var(--table-row-drag-color);
1663
629
  }
630
+ }
1664
631
 
1665
- .vc-table__body-actions--selected {
1666
- @apply tw-bg-[--table-actions-bg-hover-selected-item];
632
+ &.vc-table__drag-row-top {
633
+ &::before {
634
+ content: "";
635
+ position: absolute;
636
+ top: 0;
637
+ left: 0;
638
+ right: 0;
639
+ height: 2px;
640
+ background-color: var(--table-row-drag-color);
1667
641
  }
1668
642
  }
1669
643
  }
@@ -1681,11 +655,11 @@ $variants: (
1681
655
  }
1682
656
 
1683
657
  &__body-row--selected {
1684
- @apply tw-bg-[--table-row-hover] hover:tw-bg-[--table-row-hover] #{!important};
658
+ @apply tw-bg-[--table-row-hover] hover:tw-bg-[--table-row-hover];
1685
659
  }
1686
660
 
1687
661
  &__body-row--selection {
1688
- @apply hover:tw-bg-[--table-row-bg-selected] tw-bg-[--table-row-bg-selected] #{!important};
662
+ @apply hover:tw-bg-[--table-row-bg-selected] tw-bg-[--table-row-bg-selected];
1689
663
  }
1690
664
 
1691
665
  &__body-row-checkbox {
@@ -1728,25 +702,13 @@ $variants: (
1728
702
  @apply tw-overflow-auto tw-flex tw-flex-col tw-flex-auto;
1729
703
  }
1730
704
 
1731
- &__footer {
1732
- @apply tw-bg-[--table-footer-bg] tw-border-t tw-border-solid tw-border-[--table-footer-border-color] tw-flex-shrink-0 tw-flex tw-items-center tw-justify-between;
1733
- }
1734
-
1735
- &__footer--mobile {
1736
- @apply tw-py-2 tw-px-4;
1737
- }
1738
-
1739
- &__footer--desktop {
1740
- @apply tw-p-4;
1741
- }
1742
-
1743
705
  /* Drag row styles */
1744
706
  &__drag-row-bottom {
1745
- box-shadow: var(--table-row-drag-shadow);
707
+ box-shadow: inset 0 -2px 0 0 var(--table-row-drag-color);
1746
708
  }
1747
709
 
1748
710
  &__drag-row-top {
1749
- box-shadow: var(--table-row-drag-shadow);
711
+ box-shadow: inset 0 2px 0 0 var(--table-row-drag-color);
1750
712
  }
1751
713
 
1752
714
  /* Tooltip arrow styles */
@@ -1772,4 +734,19 @@ $variants: (
1772
734
  @apply tw-border-b tw-border-solid tw-border-[--table-mobile-border-color] tw-p-3 tw-gap-2 tw-flex tw-flex-wrap;
1773
735
  }
1774
736
  }
737
+
738
+ .table-header-enter-active,
739
+ .table-header-leave-active {
740
+ @apply tw-transition-all tw-duration-200 tw-ease-in-out;
741
+ }
742
+
743
+ .table-header-enter-from,
744
+ .table-header-leave-to {
745
+ @apply tw-opacity-0 tw-transform tw-translate-y-[-30px];
746
+ }
747
+
748
+ .table-header-enter-to,
749
+ .table-header-leave-from {
750
+ @apply tw-opacity-100 tw-transform tw-translate-y-0;
751
+ }
1775
752
  </style>