@vc-shell/framework 1.1.0-alpha.1 → 1.1.0-alpha.2

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