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