@vc-shell/framework 1.0.327 → 1.0.328-0

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