@vc-shell/framework 1.0.69 → 1.0.71

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 (468) hide show
  1. package/CHANGELOG.md +72 -0
  2. package/core/api/platform.ts +2762 -2225
  3. package/core/composables/index.ts +1 -0
  4. package/core/composables/useMenuComposer/index.ts +25 -0
  5. package/core/composables/useNotifications/index.ts +25 -31
  6. package/core/composables/useUser/index.ts +176 -10
  7. package/core/directives/index.ts +0 -1
  8. package/core/plugins/index.ts +1 -1
  9. package/core/plugins/modularity/index.ts +8 -1
  10. package/core/plugins/signalR/index.ts +32 -0
  11. package/core/types/index.ts +56 -17
  12. package/dist/core/api/platform.d.ts +1005 -931
  13. package/dist/core/api/platform.d.ts.map +1 -1
  14. package/dist/core/composables/index.d.ts +1 -0
  15. package/dist/core/composables/index.d.ts.map +1 -1
  16. package/dist/core/composables/useMenuComposer/index.d.ts +12 -0
  17. package/dist/core/composables/useMenuComposer/index.d.ts.map +1 -0
  18. package/dist/core/composables/useNotifications/index.d.ts +4 -6
  19. package/dist/core/composables/useNotifications/index.d.ts.map +1 -1
  20. package/dist/core/composables/useUser/index.d.ts +18 -1
  21. package/dist/core/composables/useUser/index.d.ts.map +1 -1
  22. package/dist/core/directives/autofocus/index.d.ts +1 -1
  23. package/dist/core/directives/autofocus/index.d.ts.map +1 -1
  24. package/dist/core/directives/index.d.ts +0 -1
  25. package/dist/core/directives/index.d.ts.map +1 -1
  26. package/dist/core/directives/loading/index.d.ts +1 -1
  27. package/dist/core/directives/loading/index.d.ts.map +1 -1
  28. package/dist/core/directives/permissions/index.d.ts +1 -1
  29. package/dist/core/directives/permissions/index.d.ts.map +1 -1
  30. package/dist/core/plugins/index.d.ts +1 -1
  31. package/dist/core/plugins/index.d.ts.map +1 -1
  32. package/dist/core/plugins/modularity/index.d.ts +1 -1
  33. package/dist/core/plugins/modularity/index.d.ts.map +1 -1
  34. package/dist/core/plugins/signalR/index.d.ts +4 -0
  35. package/dist/core/plugins/signalR/index.d.ts.map +1 -0
  36. package/dist/core/types/index.d.ts +46 -20
  37. package/dist/core/types/index.d.ts.map +1 -1
  38. package/dist/framework.mjs +31824 -29372
  39. package/dist/index.css +1 -1
  40. package/dist/index.d.ts +3 -1
  41. package/dist/index.d.ts.map +1 -1
  42. package/dist/injectionSymbols.d.ts +6 -0
  43. package/dist/injectionSymbols.d.ts.map +1 -0
  44. package/dist/shared/components/app-switcher/components/vc-app-switcher/index.d.ts +1 -3
  45. package/dist/shared/components/app-switcher/components/vc-app-switcher/index.d.ts.map +1 -1
  46. package/dist/shared/components/app-switcher/components/vc-app-switcher/vc-app-switcher.vue.d.ts +6 -3
  47. package/dist/shared/components/app-switcher/components/vc-app-switcher/vc-app-switcher.vue.d.ts.map +1 -1
  48. package/dist/shared/components/app-switcher/composables/useAppSwitcher/index.d.ts +1 -1
  49. package/dist/shared/components/app-switcher/composables/useAppSwitcher/index.d.ts.map +1 -1
  50. package/dist/shared/components/blade-navigation/components/vc-blade-navigation/index.d.ts +13 -456
  51. package/dist/shared/components/blade-navigation/components/vc-blade-navigation/index.d.ts.map +1 -1
  52. package/dist/shared/components/blade-navigation/components/vc-blade-navigation/vc-blade-navigation.vue.d.ts +19 -454
  53. package/dist/shared/components/blade-navigation/components/vc-blade-navigation/vc-blade-navigation.vue.d.ts.map +1 -1
  54. package/dist/shared/components/blade-navigation/composables/useBladeNavigation/index.d.ts +3 -4
  55. package/dist/shared/components/blade-navigation/composables/useBladeNavigation/index.d.ts.map +1 -1
  56. package/dist/shared/components/blade-navigation/index.d.ts +1 -9
  57. package/dist/shared/components/blade-navigation/index.d.ts.map +1 -1
  58. package/dist/shared/components/blade-navigation/plugin.d.ts +13 -0
  59. package/dist/shared/components/blade-navigation/plugin.d.ts.map +1 -0
  60. package/dist/shared/components/blade-navigation/types/index.d.ts +53 -26
  61. package/dist/shared/components/blade-navigation/types/index.d.ts.map +1 -1
  62. package/dist/shared/components/change-password/change-password.vue.d.ts +7 -0
  63. package/dist/shared/components/change-password/change-password.vue.d.ts.map +1 -0
  64. package/dist/shared/components/change-password/index.d.ts +11 -0
  65. package/dist/shared/components/change-password/index.d.ts.map +1 -0
  66. package/dist/{core/plugins → shared/components}/error-interceptor/index.d.ts +53 -15
  67. package/dist/shared/components/error-interceptor/index.d.ts.map +1 -0
  68. package/dist/{core/plugins → shared/components}/error-interceptor/interceptor.d.ts +1 -1
  69. package/dist/shared/components/error-interceptor/interceptor.d.ts.map +1 -0
  70. package/dist/shared/components/index.d.ts +9 -0
  71. package/dist/shared/components/index.d.ts.map +1 -0
  72. package/dist/shared/components/language-selector/index.d.ts +55 -0
  73. package/dist/shared/components/language-selector/index.d.ts.map +1 -0
  74. package/dist/shared/components/language-selector/language-selector.vue.d.ts +45 -0
  75. package/dist/shared/components/language-selector/language-selector.vue.d.ts.map +1 -0
  76. package/dist/shared/components/notifications/components/notification-container/index.d.ts +13 -13
  77. package/dist/shared/components/notifications/components/notification-container/index.d.ts.map +1 -1
  78. package/dist/shared/components/notifications/core/notification.d.ts.map +1 -1
  79. package/dist/shared/components/notifications/index.d.ts +0 -9
  80. package/dist/shared/components/notifications/index.d.ts.map +1 -1
  81. package/dist/shared/components/notifications/types/index.d.ts +3 -1
  82. package/dist/shared/components/notifications/types/index.d.ts.map +1 -1
  83. package/dist/shared/components/popup-handler/components/index.d.ts +2 -0
  84. package/dist/shared/components/popup-handler/components/index.d.ts.map +1 -0
  85. package/dist/shared/components/popup-handler/components/vc-popup-container/index.d.ts +2 -0
  86. package/dist/shared/components/popup-handler/components/vc-popup-container/index.d.ts.map +1 -0
  87. package/dist/shared/components/popup-handler/components/vc-popup-container/vc-popup-container.vue.d.ts +3 -0
  88. package/dist/shared/components/popup-handler/components/vc-popup-container/vc-popup-container.vue.d.ts.map +1 -0
  89. package/dist/shared/components/popup-handler/composables/index.d.ts +2 -0
  90. package/dist/shared/components/popup-handler/composables/index.d.ts.map +1 -0
  91. package/dist/shared/components/popup-handler/composables/usePopup/index.d.ts +12 -0
  92. package/dist/shared/components/popup-handler/composables/usePopup/index.d.ts.map +1 -0
  93. package/dist/shared/components/popup-handler/index.d.ts +16 -0
  94. package/dist/shared/components/popup-handler/index.d.ts.map +1 -0
  95. package/dist/shared/components/popup-handler/plugin.d.ts +6 -0
  96. package/dist/shared/components/popup-handler/plugin.d.ts.map +1 -0
  97. package/dist/shared/components/popup-handler/types/index.d.ts +26 -0
  98. package/dist/shared/components/popup-handler/types/index.d.ts.map +1 -0
  99. package/dist/shared/components/popup-handler/utils/index.d.ts +3 -0
  100. package/dist/shared/components/popup-handler/utils/index.d.ts.map +1 -0
  101. package/dist/shared/components/user-dropdown-button/index.d.ts +43 -0
  102. package/dist/shared/components/user-dropdown-button/index.d.ts.map +1 -0
  103. package/dist/shared/components/user-dropdown-button/user-dropdown-button.vue.d.ts +33 -0
  104. package/dist/shared/components/user-dropdown-button/user-dropdown-button.vue.d.ts.map +1 -0
  105. package/dist/shared/index.d.ts +3 -5
  106. package/dist/shared/index.d.ts.map +1 -1
  107. package/dist/shared/locales/index.d.ts +3 -0
  108. package/dist/shared/locales/index.d.ts.map +1 -0
  109. package/dist/shared/modules/assets/components/assets-details/assets-details.vue.d.ts +13 -11
  110. package/dist/shared/modules/assets/components/assets-details/assets-details.vue.d.ts.map +1 -1
  111. package/dist/shared/modules/assets/components/assets-details/index.d.ts +25 -123
  112. package/dist/shared/modules/assets/components/assets-details/index.d.ts.map +1 -1
  113. package/dist/shared/modules/assets-manager/components/assets-manager/assets-manager.vue.d.ts +15 -18
  114. package/dist/shared/modules/assets-manager/components/assets-manager/assets-manager.vue.d.ts.map +1 -1
  115. package/dist/shared/modules/assets-manager/components/assets-manager/index.d.ts +30 -150
  116. package/dist/shared/modules/assets-manager/components/assets-manager/index.d.ts.map +1 -1
  117. package/dist/shared/modules/index.d.ts +3 -0
  118. package/dist/shared/modules/index.d.ts.map +1 -0
  119. package/dist/shared/pages/InvitePage/components/index.d.ts +2 -0
  120. package/dist/shared/pages/InvitePage/components/index.d.ts.map +1 -0
  121. package/dist/shared/pages/InvitePage/components/invite/Invite.vue.d.ts +33 -0
  122. package/dist/shared/pages/InvitePage/components/invite/Invite.vue.d.ts.map +1 -0
  123. package/dist/shared/pages/InvitePage/components/invite/index.d.ts +32 -0
  124. package/dist/shared/pages/InvitePage/components/invite/index.d.ts.map +1 -0
  125. package/dist/shared/pages/InvitePage/index.d.ts +5 -0
  126. package/dist/shared/pages/InvitePage/index.d.ts.map +1 -0
  127. package/dist/shared/pages/InvitePage/locales/index.d.ts +3 -0
  128. package/dist/shared/pages/InvitePage/locales/index.d.ts.map +1 -0
  129. package/dist/shared/pages/LoginPage/components/index.d.ts +2 -0
  130. package/dist/shared/pages/LoginPage/components/index.d.ts.map +1 -0
  131. package/dist/shared/pages/LoginPage/components/login/Login.vue.d.ts +17 -0
  132. package/dist/shared/pages/LoginPage/components/login/Login.vue.d.ts.map +1 -0
  133. package/dist/shared/pages/LoginPage/components/login/index.d.ts +28 -0
  134. package/dist/shared/pages/LoginPage/components/login/index.d.ts.map +1 -0
  135. package/dist/shared/pages/LoginPage/index.d.ts +3 -0
  136. package/dist/shared/pages/LoginPage/index.d.ts.map +1 -0
  137. package/dist/shared/pages/LoginPage/locales/index.d.ts +3 -0
  138. package/dist/shared/pages/LoginPage/locales/index.d.ts.map +1 -0
  139. package/dist/shared/pages/LoginPage/plugin.d.ts +6 -0
  140. package/dist/shared/pages/LoginPage/plugin.d.ts.map +1 -0
  141. package/dist/shared/pages/ResetPasswordPage/components/index.d.ts +2 -0
  142. package/dist/shared/pages/ResetPasswordPage/components/index.d.ts.map +1 -0
  143. package/dist/shared/pages/ResetPasswordPage/components/reset-password/ResetPassword.vue.d.ts +33 -0
  144. package/dist/shared/pages/ResetPasswordPage/components/reset-password/ResetPassword.vue.d.ts.map +1 -0
  145. package/dist/shared/pages/ResetPasswordPage/components/reset-password/index.d.ts +32 -0
  146. package/dist/shared/pages/ResetPasswordPage/components/reset-password/index.d.ts.map +1 -0
  147. package/dist/shared/pages/ResetPasswordPage/index.d.ts +5 -0
  148. package/dist/shared/pages/ResetPasswordPage/index.d.ts.map +1 -0
  149. package/dist/shared/pages/ResetPasswordPage/locales/index.d.ts +3 -0
  150. package/dist/shared/pages/ResetPasswordPage/locales/index.d.ts.map +1 -0
  151. package/dist/shared/pages/index.d.ts +10 -0
  152. package/dist/shared/pages/index.d.ts.map +1 -0
  153. package/dist/tsconfig.tsbuildinfo +1 -1
  154. package/dist/typings/index.d.ts +8 -0
  155. package/dist/typings/index.d.ts.map +1 -0
  156. package/dist/ui/components/atoms/vc-badge/index.d.ts +56 -19
  157. package/dist/ui/components/atoms/vc-badge/index.d.ts.map +1 -1
  158. package/dist/ui/components/atoms/vc-badge/vc-badge.vue.d.ts +2 -2
  159. package/dist/ui/components/atoms/vc-badge/vc-badge.vue.d.ts.map +1 -1
  160. package/dist/ui/components/atoms/vc-button/index.d.ts +103 -49
  161. package/dist/ui/components/atoms/vc-button/index.d.ts.map +1 -1
  162. package/dist/ui/components/atoms/vc-button/vc-button.vue.d.ts +17 -11
  163. package/dist/ui/components/atoms/vc-button/vc-button.vue.d.ts.map +1 -1
  164. package/dist/ui/components/atoms/vc-card/index.d.ts +66 -44
  165. package/dist/ui/components/atoms/vc-card/index.d.ts.map +1 -1
  166. package/dist/ui/components/atoms/vc-card/vc-card.vue.d.ts +8 -6
  167. package/dist/ui/components/atoms/vc-card/vc-card.vue.d.ts.map +1 -1
  168. package/dist/ui/components/atoms/vc-checkbox/index.d.ts +74 -48
  169. package/dist/ui/components/atoms/vc-checkbox/index.d.ts.map +1 -1
  170. package/dist/ui/components/atoms/vc-checkbox/vc-checkbox.vue.d.ts +8 -5
  171. package/dist/ui/components/atoms/vc-checkbox/vc-checkbox.vue.d.ts.map +1 -1
  172. package/dist/ui/components/atoms/vc-col/index.d.ts +54 -19
  173. package/dist/ui/components/atoms/vc-col/index.d.ts.map +1 -1
  174. package/dist/ui/components/atoms/vc-col/vc-col.vue.d.ts +7 -4
  175. package/dist/ui/components/atoms/vc-col/vc-col.vue.d.ts.map +1 -1
  176. package/dist/ui/components/atoms/vc-container/index.d.ts +56 -19
  177. package/dist/ui/components/atoms/vc-container/index.d.ts.map +1 -1
  178. package/dist/ui/components/atoms/vc-container/vc-container.vue.d.ts +2 -2
  179. package/dist/ui/components/atoms/vc-container/vc-container.vue.d.ts.map +1 -1
  180. package/dist/ui/components/atoms/vc-hint/index.d.ts +53 -8
  181. package/dist/ui/components/atoms/vc-hint/index.d.ts.map +1 -1
  182. package/dist/ui/components/atoms/vc-hint/vc-hint.vue.d.ts +2 -2
  183. package/dist/ui/components/atoms/vc-hint/vc-hint.vue.d.ts.map +1 -1
  184. package/dist/ui/components/atoms/vc-icon/index.d.ts +4 -8
  185. package/dist/ui/components/atoms/vc-icon/index.d.ts.map +1 -1
  186. package/dist/ui/components/atoms/vc-icon/vc-icon.vue.d.ts +7 -4
  187. package/dist/ui/components/atoms/vc-icon/vc-icon.vue.d.ts.map +1 -1
  188. package/dist/ui/components/atoms/vc-image/index.d.ts +17 -23
  189. package/dist/ui/components/atoms/vc-image/index.d.ts.map +1 -1
  190. package/dist/ui/components/atoms/vc-image/vc-image.vue.d.ts +8 -5
  191. package/dist/ui/components/atoms/vc-image/vc-image.vue.d.ts.map +1 -1
  192. package/dist/ui/components/atoms/vc-info-row/index.d.ts +10 -12
  193. package/dist/ui/components/atoms/vc-info-row/index.d.ts.map +1 -1
  194. package/dist/ui/components/atoms/vc-info-row/vc-info-row.vue.d.ts +7 -4
  195. package/dist/ui/components/atoms/vc-info-row/vc-info-row.vue.d.ts.map +1 -1
  196. package/dist/ui/components/atoms/vc-label/index.d.ts +56 -23
  197. package/dist/ui/components/atoms/vc-label/index.d.ts.map +1 -1
  198. package/dist/ui/components/atoms/vc-label/vc-label.vue.d.ts +8 -5
  199. package/dist/ui/components/atoms/vc-label/vc-label.vue.d.ts.map +1 -1
  200. package/dist/ui/components/atoms/vc-link/index.d.ts +56 -20
  201. package/dist/ui/components/atoms/vc-link/index.d.ts.map +1 -1
  202. package/dist/ui/components/atoms/vc-link/vc-link.vue.d.ts +2 -2
  203. package/dist/ui/components/atoms/vc-link/vc-link.vue.d.ts.map +1 -1
  204. package/dist/ui/components/atoms/vc-loading/index.d.ts +1 -1
  205. package/dist/ui/components/atoms/vc-loading/index.d.ts.map +1 -1
  206. package/dist/ui/components/atoms/vc-loading/vc-loading.vue.d.ts +1 -1
  207. package/dist/ui/components/atoms/vc-loading/vc-loading.vue.d.ts.map +1 -1
  208. package/dist/ui/components/atoms/vc-progress/index.d.ts +54 -27
  209. package/dist/ui/components/atoms/vc-progress/index.d.ts.map +1 -1
  210. package/dist/ui/components/atoms/vc-progress/vc-progress.vue.d.ts +6 -3
  211. package/dist/ui/components/atoms/vc-progress/vc-progress.vue.d.ts.map +1 -1
  212. package/dist/ui/components/atoms/vc-row/index.d.ts +53 -8
  213. package/dist/ui/components/atoms/vc-row/index.d.ts.map +1 -1
  214. package/dist/ui/components/atoms/vc-row/vc-row.vue.d.ts +2 -2
  215. package/dist/ui/components/atoms/vc-row/vc-row.vue.d.ts.map +1 -1
  216. package/dist/ui/components/atoms/vc-status/index.d.ts +61 -36
  217. package/dist/ui/components/atoms/vc-status/index.d.ts.map +1 -1
  218. package/dist/ui/components/atoms/vc-status/vc-status.vue.d.ts +8 -5
  219. package/dist/ui/components/atoms/vc-status/vc-status.vue.d.ts.map +1 -1
  220. package/dist/ui/components/atoms/vc-status-icon/index.d.ts +1 -1
  221. package/dist/ui/components/atoms/vc-status-icon/index.d.ts.map +1 -1
  222. package/dist/ui/components/atoms/vc-status-icon/vc-status-icon.vue.d.ts +1 -1
  223. package/dist/ui/components/atoms/vc-status-icon/vc-status-icon.vue.d.ts.map +1 -1
  224. package/dist/ui/components/atoms/vc-switch/index.d.ts +1 -1
  225. package/dist/ui/components/atoms/vc-switch/index.d.ts.map +1 -1
  226. package/dist/ui/components/atoms/vc-switch/vc-switch.vue.d.ts +1 -1
  227. package/dist/ui/components/atoms/vc-switch/vc-switch.vue.d.ts.map +1 -1
  228. package/dist/ui/components/atoms/vc-widget/index.d.ts +1 -1
  229. package/dist/ui/components/atoms/vc-widget/index.d.ts.map +1 -1
  230. package/dist/ui/components/atoms/vc-widget/vc-widget.vue.d.ts +1 -1
  231. package/dist/ui/components/atoms/vc-widget/vc-widget.vue.d.ts.map +1 -1
  232. package/dist/ui/components/index.d.ts +2 -0
  233. package/dist/ui/components/index.d.ts.map +1 -1
  234. package/dist/ui/components/molecules/vc-breadcrumbs/_internal/vc-breadcrumbs-item/vc-breadcrumbs-item.vue.d.ts +3 -3
  235. package/dist/ui/components/molecules/vc-breadcrumbs/_internal/vc-breadcrumbs-item/vc-breadcrumbs-item.vue.d.ts.map +1 -1
  236. package/dist/ui/components/molecules/vc-breadcrumbs/index.d.ts +1 -3
  237. package/dist/ui/components/molecules/vc-breadcrumbs/index.d.ts.map +1 -1
  238. package/dist/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs.vue.d.ts +6 -3
  239. package/dist/ui/components/molecules/vc-breadcrumbs/vc-breadcrumbs.vue.d.ts.map +1 -1
  240. package/dist/ui/components/molecules/vc-code-editor/index.d.ts +79 -65
  241. package/dist/ui/components/molecules/vc-code-editor/index.d.ts.map +1 -1
  242. package/dist/ui/components/molecules/vc-code-editor/vc-code-editor.vue.d.ts +7 -4
  243. package/dist/ui/components/molecules/vc-code-editor/vc-code-editor.vue.d.ts.map +1 -1
  244. package/dist/ui/components/molecules/vc-editor/index.d.ts +80 -69
  245. package/dist/ui/components/molecules/vc-editor/index.d.ts.map +1 -1
  246. package/dist/ui/components/molecules/vc-editor/vc-editor.vue.d.ts +7 -4
  247. package/dist/ui/components/molecules/vc-editor/vc-editor.vue.d.ts.map +1 -1
  248. package/dist/ui/components/molecules/vc-file-upload/index.d.ts +77 -65
  249. package/dist/ui/components/molecules/vc-file-upload/index.d.ts.map +1 -1
  250. package/dist/ui/components/molecules/vc-file-upload/vc-file-upload.vue.d.ts +7 -4
  251. package/dist/ui/components/molecules/vc-file-upload/vc-file-upload.vue.d.ts.map +1 -1
  252. package/dist/ui/components/molecules/vc-form/index.d.ts +53 -8
  253. package/dist/ui/components/molecules/vc-form/index.d.ts.map +1 -1
  254. package/dist/ui/components/molecules/vc-form/vc-form.vue.d.ts +2 -2
  255. package/dist/ui/components/molecules/vc-form/vc-form.vue.d.ts.map +1 -1
  256. package/dist/ui/components/molecules/vc-input/index.d.ts +116 -128
  257. package/dist/ui/components/molecules/vc-input/index.d.ts.map +1 -1
  258. package/dist/ui/components/molecules/vc-input/vc-input.vue.d.ts +17 -13
  259. package/dist/ui/components/molecules/vc-input/vc-input.vue.d.ts.map +1 -1
  260. package/dist/ui/components/molecules/vc-input-currency/index.d.ts +125 -137
  261. package/dist/ui/components/molecules/vc-input-currency/index.d.ts.map +1 -1
  262. package/dist/ui/components/molecules/vc-input-currency/vc-input-currency.vue.d.ts +9 -8
  263. package/dist/ui/components/molecules/vc-input-currency/vc-input-currency.vue.d.ts.map +1 -1
  264. package/dist/ui/components/molecules/vc-notification/index.d.ts +1 -1
  265. package/dist/ui/components/molecules/vc-notification/index.d.ts.map +1 -1
  266. package/dist/ui/components/molecules/vc-notification/vc-notification.vue.d.ts +1 -1
  267. package/dist/ui/components/molecules/vc-notification/vc-notification.vue.d.ts.map +1 -1
  268. package/dist/ui/components/molecules/vc-pagination/index.d.ts +7 -11
  269. package/dist/ui/components/molecules/vc-pagination/index.d.ts.map +1 -1
  270. package/dist/ui/components/molecules/vc-pagination/vc-pagination.vue.d.ts +6 -3
  271. package/dist/ui/components/molecules/vc-pagination/vc-pagination.vue.d.ts.map +1 -1
  272. package/dist/ui/components/molecules/vc-rating/index.d.ts +73 -55
  273. package/dist/ui/components/molecules/vc-rating/index.d.ts.map +1 -1
  274. package/dist/ui/components/molecules/vc-rating/vc-rating.vue.d.ts +8 -5
  275. package/dist/ui/components/molecules/vc-rating/vc-rating.vue.d.ts.map +1 -1
  276. package/dist/ui/components/molecules/vc-select/index.d.ts +188 -584
  277. package/dist/ui/components/molecules/vc-select/index.d.ts.map +1 -1
  278. package/dist/ui/components/molecules/vc-select/vc-select.vue.d.ts +643 -119
  279. package/dist/ui/components/molecules/vc-select/vc-select.vue.d.ts.map +1 -1
  280. package/dist/ui/components/molecules/vc-slider/index.d.ts +70 -55
  281. package/dist/ui/components/molecules/vc-slider/index.d.ts.map +1 -1
  282. package/dist/ui/components/molecules/vc-slider/vc-slider.vue.d.ts +10 -7
  283. package/dist/ui/components/molecules/vc-slider/vc-slider.vue.d.ts.map +1 -1
  284. package/dist/ui/components/molecules/vc-textarea/index.d.ts +80 -68
  285. package/dist/ui/components/molecules/vc-textarea/index.d.ts.map +1 -1
  286. package/dist/ui/components/molecules/vc-textarea/vc-textarea.vue.d.ts +7 -4
  287. package/dist/ui/components/molecules/vc-textarea/vc-textarea.vue.d.ts.map +1 -1
  288. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/vc-app-bar.vue.d.ts +21 -7
  289. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/vc-app-bar.vue.d.ts.map +1 -1
  290. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/_internal/vc-app-menu-link.vue.d.ts +8 -17
  291. 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
  292. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/vc-app-menu-item.vue.d.ts +20 -37
  293. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/vc-app-menu-item.vue.d.ts.map +1 -1
  294. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/vc-app-menu.vue.d.ts +20 -13
  295. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/vc-app-menu.vue.d.ts.map +1 -1
  296. package/dist/ui/components/organisms/vc-app/index.d.ts +138 -160
  297. package/dist/ui/components/organisms/vc-app/index.d.ts.map +1 -1
  298. package/dist/ui/components/organisms/vc-app/vc-app.vue.d.ts +23 -24
  299. package/dist/ui/components/organisms/vc-app/vc-app.vue.d.ts.map +1 -1
  300. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-header/vc-blade-header.vue.d.ts +4 -4
  301. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-header/vc-blade-header.vue.d.ts.map +1 -1
  302. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-button/vc-blade-toolbar-button.vue.d.ts +8 -5
  303. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-button/vc-blade-toolbar-button.vue.d.ts.map +1 -1
  304. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/vc-blade-toolbar.vue.d.ts +7 -4
  305. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/vc-blade-toolbar.vue.d.ts.map +1 -1
  306. package/dist/ui/components/organisms/vc-blade/index.d.ts +90 -129
  307. package/dist/ui/components/organisms/vc-blade/index.d.ts.map +1 -1
  308. package/dist/ui/components/organisms/vc-blade/vc-blade.vue.d.ts +11 -15
  309. package/dist/ui/components/organisms/vc-blade/vc-blade.vue.d.ts.map +1 -1
  310. package/dist/ui/components/organisms/vc-dynamic-property/index.d.ts +3 -5
  311. package/dist/ui/components/organisms/vc-dynamic-property/index.d.ts.map +1 -1
  312. package/dist/ui/components/organisms/vc-dynamic-property/vc-dynamic-property.vue.d.ts +6 -3
  313. package/dist/ui/components/organisms/vc-dynamic-property/vc-dynamic-property.vue.d.ts.map +1 -1
  314. package/dist/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.vue.d.ts +7 -4
  315. package/dist/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.vue.d.ts.map +1 -1
  316. package/dist/ui/components/organisms/vc-gallery/_internal/vc-gallery-preview/vc-gallery-preview.vue.d.ts +18 -7
  317. package/dist/ui/components/organisms/vc-gallery/_internal/vc-gallery-preview/vc-gallery-preview.vue.d.ts.map +1 -1
  318. package/dist/ui/components/organisms/vc-gallery/index.d.ts +37 -52
  319. package/dist/ui/components/organisms/vc-gallery/index.d.ts.map +1 -1
  320. package/dist/ui/components/organisms/vc-gallery/vc-gallery.vue.d.ts +8 -8
  321. package/dist/ui/components/organisms/vc-gallery/vc-gallery.vue.d.ts.map +1 -1
  322. package/dist/ui/components/organisms/vc-login-form/index.d.ts +62 -31
  323. package/dist/ui/components/organisms/vc-login-form/index.d.ts.map +1 -1
  324. package/dist/ui/components/organisms/vc-login-form/vc-login-form.vue.d.ts +7 -4
  325. package/dist/ui/components/organisms/vc-login-form/vc-login-form.vue.d.ts.map +1 -1
  326. package/dist/ui/components/organisms/vc-notification-dropdown/_internal/notification/notification.vue.d.ts +32 -0
  327. package/dist/ui/components/organisms/vc-notification-dropdown/_internal/notification/notification.vue.d.ts.map +1 -0
  328. package/dist/ui/components/organisms/vc-notification-dropdown/index.d.ts +44 -0
  329. package/dist/ui/components/organisms/vc-notification-dropdown/index.d.ts.map +1 -0
  330. package/dist/ui/components/organisms/vc-notification-dropdown/vc-notification-dropdown.vue.d.ts +22 -0
  331. package/dist/ui/components/organisms/vc-notification-dropdown/vc-notification-dropdown.vue.d.ts.map +1 -0
  332. package/dist/ui/components/organisms/vc-notification-template/index.d.ts +135 -0
  333. package/dist/ui/components/organisms/vc-notification-template/index.d.ts.map +1 -0
  334. package/dist/ui/components/organisms/vc-notification-template/vc-notification-template.vue.d.ts +24 -0
  335. package/dist/ui/components/organisms/vc-notification-template/vc-notification-template.vue.d.ts.map +1 -0
  336. package/dist/ui/components/organisms/vc-popup/_internal/vc-popup-error/vc-popup-error.vue.d.ts +17 -0
  337. package/dist/ui/components/organisms/vc-popup/_internal/vc-popup-error/vc-popup-error.vue.d.ts.map +1 -0
  338. package/dist/ui/components/organisms/vc-popup/_internal/vc-popup-warning/vc-popup-warning.vue.d.ts +20 -0
  339. package/dist/ui/components/organisms/vc-popup/_internal/vc-popup-warning/vc-popup-warning.vue.d.ts.map +1 -0
  340. package/dist/ui/components/organisms/vc-popup/index.d.ts +87 -42
  341. package/dist/ui/components/organisms/vc-popup/index.d.ts.map +1 -1
  342. package/dist/ui/components/organisms/vc-popup/vc-popup.vue.d.ts +16 -6
  343. package/dist/ui/components/organisms/vc-popup/vc-popup.vue.d.ts.map +1 -1
  344. package/dist/ui/components/organisms/vc-table/_internal/vc-table-cell/vc-table-cell.vue.d.ts +1 -1
  345. package/dist/ui/components/organisms/vc-table/_internal/vc-table-cell/vc-table-cell.vue.d.ts.map +1 -1
  346. package/dist/ui/components/organisms/vc-table/_internal/vc-table-column-switcher/vc-table-column-switcher.vue.d.ts +6 -3
  347. package/dist/ui/components/organisms/vc-table/_internal/vc-table-column-switcher/vc-table-column-switcher.vue.d.ts.map +1 -1
  348. package/dist/ui/components/organisms/vc-table/_internal/vc-table-counter/vc-table-counter.vue.d.ts +6 -3
  349. package/dist/ui/components/organisms/vc-table/_internal/vc-table-counter/vc-table-counter.vue.d.ts.map +1 -1
  350. package/dist/ui/components/organisms/vc-table/_internal/vc-table-filter/vc-table-filter.vue.d.ts +10 -6
  351. package/dist/ui/components/organisms/vc-table/_internal/vc-table-filter/vc-table-filter.vue.d.ts.map +1 -1
  352. package/dist/ui/components/organisms/vc-table/_internal/vc-table-mobile-item/vc-table-mobile-item.vue.d.ts +48 -47
  353. package/dist/ui/components/organisms/vc-table/_internal/vc-table-mobile-item/vc-table-mobile-item.vue.d.ts.map +1 -1
  354. package/dist/ui/components/organisms/vc-table/index.d.ts +205 -661
  355. package/dist/ui/components/organisms/vc-table/index.d.ts.map +1 -1
  356. package/dist/ui/components/organisms/vc-table/vc-table.vue.d.ts +186 -135
  357. package/dist/ui/components/organisms/vc-table/vc-table.vue.d.ts.map +1 -1
  358. package/dist/ui/types/index.d.ts +2 -0
  359. package/dist/ui/types/index.d.ts.map +1 -1
  360. package/package.json +25 -22
  361. package/shared/components/app-switcher/components/vc-app-switcher/vc-app-switcher.vue +3 -2
  362. package/shared/components/app-switcher/composables/useAppSwitcher/index.ts +5 -3
  363. package/shared/components/blade-navigation/components/vc-blade-navigation/vc-blade-navigation.vue +26 -34
  364. package/shared/components/blade-navigation/composables/useBladeNavigation/index.ts +104 -69
  365. package/shared/components/blade-navigation/index.ts +1 -12
  366. package/shared/components/blade-navigation/plugin.ts +33 -0
  367. package/shared/components/blade-navigation/types/index.ts +59 -36
  368. package/shared/components/change-password/change-password.vue +167 -0
  369. package/shared/components/change-password/index.ts +10 -0
  370. package/{core/plugins → shared/components}/error-interceptor/interceptor.ts +1 -1
  371. package/shared/components/index.ts +8 -0
  372. package/shared/components/language-selector/index.ts +10 -0
  373. package/shared/components/language-selector/language-selector.vue +60 -0
  374. package/shared/components/notifications/composables/useContainer/index.ts +2 -2
  375. package/shared/components/notifications/core/notification.ts +3 -3
  376. package/shared/components/notifications/index.ts +0 -11
  377. package/shared/components/notifications/types/index.ts +4 -1
  378. package/shared/components/popup-handler/components/index.ts +1 -0
  379. package/shared/components/popup-handler/components/vc-popup-container/index.ts +3 -0
  380. package/shared/components/popup-handler/components/vc-popup-container/vc-popup-container.vue +25 -0
  381. package/shared/components/popup-handler/composables/index.ts +1 -0
  382. package/shared/components/popup-handler/composables/usePopup/index.ts +129 -0
  383. package/shared/components/popup-handler/index.ts +19 -0
  384. package/shared/components/popup-handler/plugin.ts +24 -0
  385. package/shared/components/popup-handler/types/index.ts +28 -0
  386. package/shared/components/popup-handler/utils/index.ts +9 -0
  387. package/shared/components/user-dropdown-button/index.ts +10 -0
  388. package/shared/components/user-dropdown-button/user-dropdown-button.vue +124 -0
  389. package/shared/index.ts +14 -8
  390. package/shared/locales/en.json +35 -0
  391. package/shared/locales/index.ts +2 -0
  392. package/shared/modules/assets/components/assets-details/assets-details.vue +12 -16
  393. package/shared/modules/assets-manager/components/assets-manager/assets-manager.vue +32 -35
  394. package/shared/modules/index.ts +2 -0
  395. package/shared/pages/InvitePage/components/index.ts +1 -0
  396. package/shared/pages/InvitePage/components/invite/Invite.vue +172 -0
  397. package/shared/pages/InvitePage/components/invite/index.ts +3 -0
  398. package/shared/pages/InvitePage/index.ts +7 -0
  399. package/shared/pages/InvitePage/locales/en.json +31 -0
  400. package/shared/pages/InvitePage/locales/index.ts +2 -0
  401. package/shared/pages/LoginPage/components/index.ts +1 -0
  402. package/shared/pages/LoginPage/components/login/Login.vue +283 -0
  403. package/shared/pages/LoginPage/components/login/index.ts +3 -0
  404. package/shared/pages/LoginPage/index.ts +2 -0
  405. package/shared/pages/LoginPage/locales/en.json +36 -0
  406. package/shared/pages/LoginPage/locales/index.ts +2 -0
  407. package/shared/pages/LoginPage/plugin.ts +17 -0
  408. package/shared/pages/ResetPasswordPage/components/index.ts +1 -0
  409. package/shared/pages/ResetPasswordPage/components/reset-password/ResetPassword.vue +166 -0
  410. package/shared/pages/ResetPasswordPage/components/reset-password/index.ts +3 -0
  411. package/shared/pages/ResetPasswordPage/index.ts +7 -0
  412. package/shared/pages/ResetPasswordPage/locales/en.json +28 -0
  413. package/shared/pages/ResetPasswordPage/locales/index.ts +2 -0
  414. package/shared/pages/index.ts +12 -0
  415. package/ui/components/atoms/vc-button/vc-button.vue +110 -144
  416. package/ui/components/atoms/vc-card/vc-card.vue +2 -2
  417. package/ui/components/atoms/vc-info-row/vc-info-row.vue +2 -2
  418. package/ui/components/atoms/vc-label/vc-label.vue +1 -1
  419. package/ui/components/atoms/vc-loading/vc-loading.vue +1 -1
  420. package/ui/components/atoms/vc-switch/vc-switch.vue +1 -1
  421. package/ui/components/index.ts +2 -0
  422. package/ui/components/molecules/vc-code-editor/vc-code-editor.vue +3 -3
  423. package/ui/components/molecules/vc-editor/vc-editor.vue +3 -3
  424. package/ui/components/molecules/vc-file-upload/vc-file-upload.vue +2 -2
  425. package/ui/components/molecules/vc-input/vc-input.vue +17 -17
  426. package/ui/components/molecules/vc-input-currency/vc-input-currency.vue +8 -8
  427. package/ui/components/molecules/vc-notification/vc-notification.vue +1 -1
  428. package/ui/components/molecules/vc-rating/vc-rating.vue +1 -1
  429. package/ui/components/molecules/vc-select/index.ts +1 -86
  430. package/ui/components/molecules/vc-select/vc-select.stories.ts +1 -1
  431. package/ui/components/molecules/vc-select/vc-select.vue +276 -198
  432. package/ui/components/molecules/vc-slider/vc-slider.vue +3 -3
  433. package/ui/components/molecules/vc-textarea/vc-textarea.vue +2 -2
  434. package/ui/components/organisms/vc-app/_internal/vc-app-bar/vc-app-bar.vue +21 -16
  435. package/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/_internal/vc-app-menu-link.vue +5 -9
  436. package/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/vc-app-menu-item.vue +21 -31
  437. package/ui/components/organisms/vc-app/_internal/vc-app-menu/vc-app-menu.vue +22 -16
  438. package/ui/components/organisms/vc-app/vc-app.vue +24 -24
  439. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-button/vc-blade-toolbar-button.vue +10 -13
  440. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/vc-blade-toolbar.vue +4 -4
  441. package/ui/components/organisms/vc-blade/vc-blade.vue +32 -47
  442. package/ui/components/organisms/vc-dynamic-property/vc-dynamic-property.vue +84 -84
  443. package/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.vue +3 -3
  444. package/ui/components/organisms/vc-gallery/_internal/vc-gallery-preview/vc-gallery-preview.vue +9 -3
  445. package/ui/components/organisms/vc-gallery/vc-gallery.vue +27 -23
  446. package/ui/components/organisms/vc-login-form/vc-login-form.stories.ts +1 -1
  447. package/ui/components/organisms/vc-notification-dropdown/_internal/notification/notification.vue +63 -0
  448. package/ui/components/organisms/vc-notification-dropdown/index.ts +3 -0
  449. package/ui/components/organisms/vc-notification-dropdown/vc-notification-dropdown.vue +125 -0
  450. package/ui/components/organisms/vc-notification-template/index.ts +3 -0
  451. package/ui/components/organisms/vc-notification-template/vc-notification-template.vue +33 -0
  452. package/ui/components/organisms/vc-popup/_internal/vc-popup-error/vc-popup-error.vue +28 -0
  453. package/ui/components/organisms/vc-popup/_internal/vc-popup-warning/vc-popup-warning.vue +33 -0
  454. package/ui/components/organisms/vc-popup/vc-popup.vue +62 -7
  455. package/ui/components/organisms/vc-table/_internal/vc-table-column-switcher/vc-table-column-switcher.vue +6 -6
  456. package/ui/components/organisms/vc-table/_internal/vc-table-filter/vc-table-filter.vue +10 -13
  457. package/ui/components/organisms/vc-table/_internal/vc-table-mobile-item/vc-table-mobile-item.vue +27 -24
  458. package/ui/components/organisms/vc-table/index.ts +1 -17
  459. package/ui/components/organisms/vc-table/vc-table.stories.ts +1 -1
  460. package/ui/components/organisms/vc-table/vc-table.vue +163 -148
  461. package/ui/locales/en.json +21 -10
  462. package/ui/types/index.ts +2 -0
  463. package/core/directives/click-outside/index.ts +0 -21
  464. package/dist/core/directives/click-outside/index.d.ts +0 -3
  465. package/dist/core/directives/click-outside/index.d.ts.map +0 -1
  466. package/dist/core/plugins/error-interceptor/index.d.ts.map +0 -1
  467. package/dist/core/plugins/error-interceptor/interceptor.d.ts.map +0 -1
  468. /package/{core/plugins → shared/components}/error-interceptor/index.ts +0 -0
@@ -0,0 +1,124 @@
1
+ <template>
2
+ <div
3
+ v-on-click-outside="onClose"
4
+ class="user-dropdown-button"
5
+ :class="{
6
+ 'user-dropdown-button_active': accountMenuVisible,
7
+ 'user-dropdown-button_no-pointer': $isMobile.value,
8
+ }"
9
+ @click.stop="toggleAccountMenuVisible"
10
+ >
11
+ <div
12
+ class="user-dropdown-button__avatar"
13
+ :style="{ 'background-image': `url(${avatar})` }"
14
+ ></div>
15
+ <div class="tw-grow tw-basis-0 tw-ml-3 tw-overflow-hidden">
16
+ <div class="user-dropdown-button__name tw-truncate">
17
+ {{ name }}
18
+ </div>
19
+ <div class="user-dropdown-button__role">
20
+ {{ role }}
21
+ </div>
22
+ </div>
23
+ <div
24
+ v-if="menuItems && menuItems.length"
25
+ class="user-dropdown-button__chevron"
26
+ >
27
+ <VcIcon
28
+ icon="fas fa-chevron-down"
29
+ size="xl"
30
+ ></VcIcon>
31
+ </div>
32
+ <div
33
+ v-if="menuItems && accountMenuVisible"
34
+ class="user-dropdown-button__menu"
35
+ @click.stop="accountMenuVisible = false"
36
+ >
37
+ <div
38
+ v-for="(item, i) in menuItems"
39
+ :key="`menu_item_${i}`"
40
+ class="user-dropdown-button__menu-item"
41
+ @click="item.hasOwnProperty('clickHandler') ? item.clickHandler() : null"
42
+ >
43
+ {{ item.title }}
44
+ </div>
45
+ </div>
46
+ </div>
47
+ </template>
48
+
49
+ <script lang="ts" setup>
50
+ import { ref } from "vue";
51
+ import { vOnClickOutside } from "@vueuse/components";
52
+ import { BladeMenu } from "./../../../core/types";
53
+
54
+ export interface Props {
55
+ avatar: string;
56
+ name: string;
57
+ role: string;
58
+ menuItems?: BladeMenu[];
59
+ }
60
+ const props = withDefaults(defineProps<Props>(), {
61
+ menuItems: () => [],
62
+ });
63
+
64
+ const accountMenuVisible = ref(false);
65
+
66
+ const toggleAccountMenuVisible = () => {
67
+ if (props.menuItems && props.menuItems.length) {
68
+ accountMenuVisible.value = !accountMenuVisible.value;
69
+ }
70
+ };
71
+
72
+ const onClose = () => {
73
+ accountMenuVisible.value = false;
74
+ };
75
+ </script>
76
+
77
+ <style lang="scss">
78
+ .user-dropdown-button {
79
+ @apply tw-w-[240px] tw-border-l tw-border-solid tw-border-l-[color:var(--app-bar-divider-color)] tw-px-4 tw-cursor-pointer
80
+ tw-relative tw-flex tw-justify-between tw-items-center tw-h-full;
81
+
82
+ &_no-pointer {
83
+ @apply tw-cursor-default;
84
+ }
85
+
86
+ &:hover,
87
+ &_active {
88
+ @apply tw-bg-[color:var(--app-bar-toolbar-icon-background-hover)];
89
+ }
90
+
91
+ &__avatar {
92
+ @apply tw-rounded-full tw-overflow-hidden tw-w-[34px] tw-h-[34px] tw-bg-[color:var(--app-bar-account-info-role-color)]
93
+ tw-bg-cover tw-bg-center tw-shrink-0;
94
+ }
95
+
96
+ &__name {
97
+ @apply tw-text-base tw-text-[color:var(--app-bar-account-info-name-color)];
98
+ }
99
+
100
+ &__role {
101
+ @apply tw-text-base tw-text-[color:var(--app-bar-account-info-role-color)];
102
+ }
103
+
104
+ &__chevron {
105
+ @apply tw-text-[#7e8e9d] [transition:transform_0.2s_ease] [transition:color_0.2s_ease];
106
+ }
107
+
108
+ &:hover &__chevron {
109
+ @apply tw-text-[color:#34414f];
110
+ }
111
+
112
+ &_active &__chevron {
113
+ @apply -tw-scale-y-100;
114
+ }
115
+
116
+ &__menu {
117
+ @apply tw-absolute -tw-left-px tw-right-0 tw-top-[var(--app-bar-height)] tw-bg-white tw-z-[10000] tw-shadow-[0_-6px_6px_white,1px_1px_22px_rgba(126,142,157,0.2)];
118
+
119
+ &-item {
120
+ @apply tw-p-3 tw-text-lg tw-text-black tw-border-l tw-border-solid tw-border-l-[#eef0f2] tw-border-b tw-border-b-[#eef0f2] tw-bg-white hover:tw-bg-[#eff7fc];
121
+ }
122
+ }
123
+ }
124
+ </style>
package/shared/index.ts CHANGED
@@ -3,22 +3,28 @@ import { AssetsDetailsModule } from "./modules/assets";
3
3
  import { VcAppSwitcherComponent } from "./components/app-switcher";
4
4
  import { VcBladeNavigationComponent } from "./components/blade-navigation";
5
5
  import { AssetsManagerModule } from "./modules/assets-manager";
6
- import { VcNotificationComponent } from "./components/notifications";
6
+ import { VcPopupHandler } from "./components/popup-handler";
7
+ import * as locales from "./locales";
8
+ import { i18n } from "./../core/plugins";
7
9
 
8
10
  export const SharedModule = {
9
11
  install(app: App): void {
12
+ // Load locales
13
+ if (locales) {
14
+ Object.entries(locales).forEach(([key, message]) => {
15
+ i18n.global.mergeLocaleMessage(key, message);
16
+ });
17
+ }
18
+
10
19
  app
11
20
  .use(AssetsDetailsModule)
12
21
  .use(AssetsManagerModule)
13
22
  .use(VcBladeNavigationComponent)
14
23
  .use(VcAppSwitcherComponent)
15
- .use(VcNotificationComponent);
24
+ .use(VcPopupHandler);
16
25
  },
17
26
  };
18
27
 
19
- export * from "./modules/assets";
20
- export * from "./modules/assets-manager";
21
-
22
- export * from "./components/app-switcher";
23
- export * from "./components/blade-navigation";
24
- export * from "./components/notifications";
28
+ export * from "./modules";
29
+ export * from "./components";
30
+ export * from "./pages";
@@ -0,0 +1,35 @@
1
+ {
2
+ "COMPONENTS": {
3
+ "CHANGE_PASSWORD": {
4
+ "TITLE": "Change password",
5
+ "CURRENT_PASSWORD": {
6
+ "LABEL": "Current password",
7
+ "PLACEHOLDER": "Enter password"
8
+ },
9
+ "NEW_PASSWORD": {
10
+ "LABEL": "New password",
11
+ "PLACEHOLDER": "Enter password"
12
+ },
13
+ "CONFIRM_PASSWORD": {
14
+ "LABEL": "Confirm password",
15
+ "PLACEHOLDER": "Confirm password"
16
+ },
17
+ "CANCEL": "Cancel",
18
+ "SAVE": "Update",
19
+ "ERRORS": {
20
+ "Repeat-password": "Passwords are not same",
21
+ "Equal-passwords": "The new password must not match the old one",
22
+ "Invalid-token": "Token is invalid or expired",
23
+ "Password-too-weak": "New password does not comply one or more password security policies:",
24
+ "PasswordTooShort": "Passwords too short",
25
+ "PasswordRequiresUniqueChars": "Passwords must use different characters",
26
+ "PasswordRequiresLower": "Passwords must have at least one lowercase ('a'-'z')",
27
+ "PasswordRequiresUpper": "Passwords must have at least one uppercase ('A'-'Z')",
28
+ "PasswordRequiresDigit": "Passwords must have at least one digit ('0'-'9')",
29
+ "PasswordRequiresNonAlphanumeric": "Passwords must have at least one non alphanumeric character",
30
+ "Incorrect password.": "You entered an incorrect password",
31
+ "You have used this password in the past. Choose another one.": "You have used this password in the past. Choose another one."
32
+ }
33
+ }
34
+ }
35
+ }
@@ -0,0 +1,2 @@
1
+ import * as en from "./en.json";
2
+ export { en };
@@ -4,17 +4,11 @@
4
4
  :subtitle="$t('ASSETS.PAGES.DETAILS.SUBTITLE')"
5
5
  :expanded="expanded"
6
6
  :closable="closable"
7
- :toolbarItems="bladeToolbar"
7
+ :toolbar-items="bladeToolbar"
8
8
  @close="$emit('close:blade')"
9
9
  @expand="$emit('expand:blade')"
10
10
  @collapse="$emit('collapse:blade')"
11
11
  >
12
- <template
13
- v-slot:error
14
- v-if="$slots['error']"
15
- >
16
- <slot name="error"></slot>
17
- </template>
18
12
  <!-- Blade contents -->
19
13
  <div class="tw-flex tw-grow-1 tw-border-t tw-border-solid tw-border-t-[#eaedf3]">
20
14
  <div class="assets-details__content tw-grow tw-basis-0 tw-w-full">
@@ -62,9 +56,9 @@
62
56
  icon="far fa-copy"
63
57
  size="m"
64
58
  class="tw-ml-2"
65
- variant="onlytext"
66
- @click="copyLink(defaultAsset.url)"
59
+ text
67
60
  title="Copy link"
61
+ @click="copyLink(defaultAsset.url)"
68
62
  ></VcButton>
69
63
  </div>
70
64
  </VcCol>
@@ -73,39 +67,39 @@
73
67
  </VcRow>
74
68
 
75
69
  <Field
70
+ v-slot="{ errorMessage, handleChange, errors }"
76
71
  :label="$t('ASSETS.PAGES.DETAILS.FIELDS.NAME.TITLE')"
77
72
  name="asset_name"
78
73
  rules="required"
79
- :modelValue="defaultAsset.name"
80
- v-slot="{ errorMessage, handleChange, errors }"
74
+ :model-value="defaultAsset.name"
81
75
  >
82
76
  <VcInput
77
+ v-model="assetNameClean"
83
78
  class="tw-mb-4"
84
79
  :label="$t('ASSETS.PAGES.DETAILS.FIELDS.NAME.TITLE')"
85
- v-model="assetNameClean"
86
- @update:modelValue="handleChange"
87
80
  clearable
88
81
  required
89
82
  :error="!!errors.length"
90
83
  :error-message="errorMessage"
91
84
  :placeholder="$t('ASSETS.PAGES.DETAILS.FIELDS.NAME.PLACEHOLDER')"
92
85
  :disabled="readonly"
86
+ @update:model-value="handleChange"
93
87
  ></VcInput>
94
88
  </Field>
95
89
  <VcInput
90
+ v-if="assetType === 'Image'"
91
+ v-model="defaultAsset.altText"
96
92
  class="tw-mb-4"
97
93
  :label="$t('ASSETS.PAGES.DETAILS.FIELDS.ALT.TITLE')"
98
- v-model="defaultAsset.altText"
99
94
  clearable
100
95
  :placeholder="$t('ASSETS.PAGES.DETAILS.FIELDS.ALT.PLACEHOLDER')"
101
96
  :tooltip="$t('ASSETS.PAGES.DETAILS.FIELDS.ALT.TOOLTIP')"
102
- v-if="assetType === 'Image'"
103
97
  :disabled="readonly"
104
98
  ></VcInput>
105
99
  <VcTextarea
100
+ v-model="defaultAsset.description"
106
101
  class="tw-mb-4"
107
102
  :label="$t('ASSETS.PAGES.DETAILS.FIELDS.DESCRIPTION.TITLE')"
108
- v-model="defaultAsset.description"
109
103
  :placeholder="$t('ASSETS.PAGES.DETAILS.FIELDS.DESCRIPTION.PLACEHOLDER')"
110
104
  :disabled="readonly"
111
105
  ></VcTextarea>
@@ -139,6 +133,8 @@ export interface Props {
139
133
 
140
134
  export interface Emits {
141
135
  (event: "close:blade"): void;
136
+ (event: "expand:blade"): void;
137
+ (event: "collapse:blade"): void;
142
138
  }
143
139
 
144
140
  const props = withDefaults(defineProps<Props>(), {
@@ -3,18 +3,12 @@
3
3
  :title="$t('ASSETS_MANAGER.TITLE')"
4
4
  :expanded="expanded"
5
5
  :closable="closable"
6
- :toolbarItems="bladeToolbar"
7
- @close="$emit('close:blade')"
6
+ :toolbar-items="bladeToolbar"
8
7
  width="70%"
8
+ @close="$emit('close:blade')"
9
9
  @expand="$emit('expand:blade')"
10
10
  @collapse="$emit('collapse:blade')"
11
11
  >
12
- <template
13
- v-slot:error
14
- v-if="$slots['error']"
15
- >
16
- <slot name="error"></slot>
17
- </template>
18
12
  <div
19
13
  class="tw-relative tw-h-full"
20
14
  @dragover.prevent.stop="dragOver"
@@ -25,20 +19,20 @@
25
19
  <VcTable
26
20
  :columns="columns"
27
21
  :expanded="expanded"
28
- stateKey="assets_manager"
29
- :reorderableRows="!readonly"
22
+ state-key="assets_manager"
23
+ :reorderable-rows="!readonly"
30
24
  :items="defaultAssets"
31
25
  :header="false"
32
26
  :footer="false"
33
- :itemActionBuilder="!readonly && actionBuilder"
27
+ :item-action-builder="!readonly && actionBuilder"
34
28
  :multiselect="!readonly"
35
29
  class="tw-h-full tw-w-full"
36
30
  @item-click="onItemClick"
37
31
  @row:reorder="sortAssets"
38
- @selectionChanged="onSelectionChanged"
32
+ @selection-changed="onSelectionChanged"
39
33
  >
40
34
  <!-- Empty template -->
41
- <template v-slot:empty>
35
+ <template #empty>
42
36
  <div class="tw-w-full tw-h-full tw-box-border tw-flex tw-flex-col tw-items-center tw-justify-center">
43
37
  <VcIcon
44
38
  icon="fas fa-cloud-upload-alt"
@@ -52,14 +46,14 @@
52
46
  </template>
53
47
 
54
48
  <!-- Override size column -->
55
- <template v-slot:item_size="{ item }">
49
+ <template #item_size="{ item }">
56
50
  <div>
57
51
  {{ readableSize(item.size) }}
58
52
  </div>
59
53
  </template>
60
54
 
61
55
  <!-- Override url column -->
62
- <template v-slot:item_url="{ item }">
56
+ <template #item_url="{ item }">
63
57
  <div class="tw-flex tw-items-center tw-justify-center">
64
58
  <template v-if="isImage(item.name)">
65
59
  <VcImage
@@ -80,14 +74,14 @@
80
74
  </template>
81
75
 
82
76
  <!-- Overide order column -->
83
- <template v-slot:item_sortOrder="{ item }">
77
+ <template #item_sortOrder="{ item }">
84
78
  <div>
85
79
  {{ item.sortOrder }}
86
80
  </div>
87
81
  </template>
88
82
 
89
83
  <!-- Mobile -->
90
- <template v-slot:mobile-item="{ item }">
84
+ <template #mobile-item="{ item }">
91
85
  <div class="tw-border-b tw-border-solid tw-border-b-[#e3e7ec] tw-p-3 tw-flex tw-flex-nowrap">
92
86
  <template v-if="isImage(item.name)">
93
87
  <VcImage
@@ -112,19 +106,19 @@
112
106
  </div>
113
107
  <div class="tw-mt-3 tw-w-full tw-flex tw-justify-between">
114
108
  <div class="tw-truncate tw-grow tw-basis-0 tw-mr-2">
115
- <VcHint>{{ $t("ASSETS_MANAGER.TABLE.SIZE") }}</VcHint>
109
+ <VcHint>{{ $t("ASSETS_MANAGER.TABLE.HEADER.SIZE") }}</VcHint>
116
110
  <div class="tw-truncate tw-mt-1">
117
111
  {{ readableSize(item.size) }}
118
112
  </div>
119
113
  </div>
120
114
  <div class="tw-truncate tw-grow tw-basis-0 tw-mr-2">
121
- <VcHint>{{ $t("ASSETS_MANAGER.TABLE.CREATED_DATE") }}</VcHint>
115
+ <VcHint>{{ $t("ASSETS_MANAGER.TABLE.HEADER.CREATED_DATE") }}</VcHint>
122
116
  <div class="tw-truncate tw-mt-1">
123
117
  {{ item.createdDate && moment(item.createdDate).fromNow() }}
124
118
  </div>
125
119
  </div>
126
120
  <div class="tw-truncate tw-grow tw-basis-0 tw-mr-2">
127
- <VcHint>{{ $t("ASSETS_MANAGER.TABLE.SORT_ORDER") }}</VcHint>
121
+ <VcHint>{{ $t("ASSETS_MANAGER.TABLE.HEADER.SORT_ORDER") }}</VcHint>
128
122
  <div class="tw-truncate tw-mt-1">
129
123
  {{ item.sortOrder }}
130
124
  </div>
@@ -140,18 +134,18 @@
140
134
  ref="uploader"
141
135
  type="file"
142
136
  hidden
143
- @change="inputUpload"
144
137
  multiple
145
138
  name="assets_manager"
139
+ @change="inputUpload"
146
140
  />
147
141
  </VcBlade>
148
142
  </template>
149
143
 
150
144
  <script setup lang="ts">
151
145
  import { Asset, IActionBuilderResult, IBladeToolbar, ITableColumns } from "../../../../../core/types";
152
- import { ref, computed, onMounted, shallowRef, unref, watch } from "vue";
146
+ import { ref, computed, onMounted, unref, watch, markRaw } from "vue";
153
147
  import { useI18n } from "vue-i18n";
154
- import { IBladeEvent, IParentCallArgs } from "./../../../../../shared";
148
+ import { IParentCallArgs, useBladeNavigation } from "./../../../../../shared";
155
149
  import moment from "moment";
156
150
  import Assets from "./../../../assets/components/assets-details/assets-details.vue";
157
151
  import { isImage, getFileThumbnail, readableSize } from "./../../../../utilities/assets";
@@ -164,7 +158,7 @@ export interface Props {
164
158
  assets: Asset[];
165
159
  assetsEditHandler: (assets: Asset[]) => Asset[];
166
160
  assetsUploadHandler: (files: FileList) => Promise<Asset[]>;
167
- assetsRemoveHandler: (assets: Asset[]) => Asset[];
161
+ assetsRemoveHandler: (assets: Asset[]) => Promise<Asset[]>;
168
162
  disabled: boolean;
169
163
  };
170
164
  }
@@ -172,7 +166,8 @@ export interface Props {
172
166
  export interface Emits {
173
167
  (event: "parent:call", args: IParentCallArgs): void;
174
168
  (event: "close:blade"): void;
175
- (event: "open:blade", blade: IBladeEvent): void;
169
+ (event: "expand:blade"): void;
170
+ (event: "collapse:blade"): void;
176
171
  }
177
172
 
178
173
  const props = withDefaults(defineProps<Props>(), {
@@ -195,6 +190,8 @@ const readonly = computed(() => props.options.disabled);
195
190
  let assetsCopy;
196
191
  const modified = ref(false);
197
192
 
193
+ const { openBlade } = useBladeNavigation();
194
+
198
195
  const bladeToolbar = ref<IBladeToolbar[]>([
199
196
  {
200
197
  id: "save",
@@ -218,9 +215,9 @@ const bladeToolbar = ref<IBladeToolbar[]>([
218
215
  id: "delete",
219
216
  title: computed(() => t("ASSETS_MANAGER.TOOLBAR.DELETE")),
220
217
  icon: "fas fa-trash",
221
- clickHandler() {
218
+ async clickHandler() {
222
219
  if (props.options.assetsRemoveHandler && typeof props.options.assetsRemoveHandler === "function") {
223
- defaultAssets.value = props.options.assetsRemoveHandler(selectedItems.value);
220
+ defaultAssets.value = await props.options.assetsRemoveHandler(selectedItems.value);
224
221
  }
225
222
  },
226
223
  disabled: computed(() => !selectedItems.value.length || readonly.value),
@@ -338,9 +335,9 @@ async function inputUpload(event: Event) {
338
335
  }
339
336
 
340
337
  function onItemClick(item: Asset) {
341
- emit("open:blade", {
342
- component: shallowRef(Assets),
343
- bladeOptions: {
338
+ openBlade({
339
+ blade: markRaw(Assets),
340
+ options: {
344
341
  asset: unref(item),
345
342
  disabled: readonly.value,
346
343
  assetEditHandler: (asset: Asset) => {
@@ -355,8 +352,8 @@ function onItemClick(item: Asset) {
355
352
  defaultAssets.value = props.options.assetsEditHandler(mutated);
356
353
  }
357
354
  },
358
- assetRemoveHandler: (asset: Asset) => {
359
- defaultAssets.value = props.options.assetsRemoveHandler([asset]);
355
+ assetRemoveHandler: async (asset: Asset) => {
356
+ defaultAssets.value = await props.options.assetsRemoveHandler([asset]);
360
357
  },
361
358
  },
362
359
  });
@@ -367,7 +364,7 @@ const onSelectionChanged = (items: Asset[]) => {
367
364
  };
368
365
 
369
366
  const actionBuilder = (): IActionBuilderResult[] => {
370
- let result = [];
367
+ const result = [];
371
368
 
372
369
  result.push({
373
370
  icon: "fas fa-edit",
@@ -382,8 +379,8 @@ const actionBuilder = (): IActionBuilderResult[] => {
382
379
  title: computed(() => t("ASSETS_MANAGER.TABLE.ACTIONS.DELETE")),
383
380
  variant: "danger",
384
381
  leftActions: true,
385
- clickHandler(item: Asset) {
386
- defaultAssets.value = props.options.assetsRemoveHandler([item]);
382
+ async clickHandler(item: Asset) {
383
+ defaultAssets.value = await props.options.assetsRemoveHandler([item]);
387
384
  selectedItems.value = [];
388
385
  },
389
386
  });
@@ -0,0 +1,2 @@
1
+ export * from "./assets";
2
+ export * from "./assets-manager";
@@ -0,0 +1 @@
1
+ export * from "./invite";
@@ -0,0 +1,172 @@
1
+ <template>
2
+ <div class="vc-app tw-w-full tw-h-full tw-box-border tw-flex tw-flex-col tw-m-0 vc-theme_light">
3
+ <VcLoading
4
+ v-if="loading"
5
+ active
6
+ ></VcLoading>
7
+
8
+ <VcLoginForm
9
+ logo="/assets/logo-white.svg"
10
+ background="/assets/background.jpg"
11
+ :title="$t('INVITATION.TITLE')"
12
+ >
13
+ <VcForm>
14
+ <VcInput
15
+ class="tw-mb-4 tw-mt-1"
16
+ :label="$t('INVITATION.FIELDS.EMAIL.LABEL')"
17
+ :model-value="userName"
18
+ name="username"
19
+ disabled
20
+ ></VcInput>
21
+ <Field
22
+ v-slot="{ field, errorMessage, handleChange, errors }"
23
+ :label="$t('INVITATION.FIELDS.PASSWORD.LABEL')"
24
+ :model-value="form.password"
25
+ rules="required"
26
+ name="password"
27
+ >
28
+ <VcInput
29
+ v-bind="field"
30
+ ref="passwordField"
31
+ v-model="form.password"
32
+ class="tw-mb-4 tw-mt-1"
33
+ :label="$t('INVITATION.FIELDS.PASSWORD.LABEL')"
34
+ :placeholder="$t('INVITATION.FIELDS.PASSWORD.PLACEHOLDER')"
35
+ type="password"
36
+ :disabled="!form.tokenIsValid"
37
+ :error="!!errors.length"
38
+ :error-message="errorMessage"
39
+ required
40
+ @update:model-value="
41
+ (e) => {
42
+ handleChange(e);
43
+ validate();
44
+ }
45
+ "
46
+ ></VcInput>
47
+ </Field>
48
+ <Field
49
+ v-slot="{ field, errorMessage, handleChange, errors }"
50
+ :label="$t('INVITATION.FIELDS.CONFIRM_PASSWORD.LABEL')"
51
+ :model-value="form.confirmPassword"
52
+ rules="required"
53
+ name="confirm_password"
54
+ >
55
+ <VcInput
56
+ v-bind="field"
57
+ ref="confirmPasswordField"
58
+ v-model="form.confirmPassword"
59
+ class="tw-mb-4"
60
+ :label="$t('INVITATION.FIELDS.CONFIRM_PASSWORD.LABEL')"
61
+ :placeholder="$t('INVITATION.FIELDS.CONFIRM_PASSWORD.PLACEHOLDER')"
62
+ :disabled="!form.tokenIsValid"
63
+ type="password"
64
+ :error="!!errors.length"
65
+ :error-message="errorMessage"
66
+ required
67
+ @update:model-value="
68
+ (e) => {
69
+ handleChange(e);
70
+ validate();
71
+ }
72
+ "
73
+ @keyup.enter="acceptInvitation"
74
+ ></VcInput>
75
+ </Field>
76
+ <div class="tw-flex tw-justify-center tw-items-center tw-pt-2">
77
+ <span
78
+ v-if="$isDesktop.value"
79
+ class="tw-grow tw-basis-0"
80
+ ></span>
81
+ <vc-button
82
+ :disabled="loading || !form.isValid || !form.tokenIsValid"
83
+ @click="acceptInvitation"
84
+ >
85
+ {{ $t("INVITATION.ACCEPT_INVITATION") }}
86
+ </vc-button>
87
+ </div>
88
+
89
+ <VcHint
90
+ v-for="error in form.errors"
91
+ :key="error"
92
+ class="tw-mt-3"
93
+ style="color: #f14e4e"
94
+ >
95
+ <!-- TODO: stylizing-->
96
+ {{ $t(`INVITATION.ERRORS.${error}`) }}
97
+ </VcHint>
98
+ </VcForm>
99
+ </VcLoginForm>
100
+ </div>
101
+ </template>
102
+
103
+ <script lang="ts" setup>
104
+ import { reactive, onMounted, computed } from "vue";
105
+ import { useRouter } from "vue-router";
106
+ import { useIsFormValid, Field, useIsFormDirty, useForm } from "vee-validate";
107
+ import { useUser } from "./../../../../../core/composables";
108
+
109
+ useForm({ validateOnMount: false });
110
+
111
+ const props = defineProps({
112
+ userId: {
113
+ type: String,
114
+ default: undefined,
115
+ },
116
+ userName: {
117
+ type: String,
118
+ default: undefined,
119
+ },
120
+ token: {
121
+ type: String,
122
+ default: undefined,
123
+ },
124
+ });
125
+ const { validateToken, validatePassword, resetPasswordByToken, signIn, loading } = useUser();
126
+ const router = useRouter();
127
+ const isFormValid = useIsFormValid();
128
+ const isDirty = useIsFormDirty();
129
+ const form = reactive({
130
+ isValid: false,
131
+ tokenIsValid: false,
132
+ errors: [],
133
+ password: "",
134
+ confirmPassword: "",
135
+ });
136
+
137
+ const isDisabled = computed(() => {
138
+ return !isDirty.value || !isFormValid.value;
139
+ });
140
+
141
+ onMounted(async () => {
142
+ form.tokenIsValid = await validateToken(props.userId, props.token);
143
+ if (!form.tokenIsValid) {
144
+ form.errors.push("Invalid-token");
145
+ }
146
+ });
147
+
148
+ const validate = async () => {
149
+ if (form.tokenIsValid) {
150
+ const errors = (await validatePassword(form.password)).errors;
151
+ form.errors = errors.map((x) => x.code);
152
+ if (form.confirmPassword && form.confirmPassword !== form.password) {
153
+ form.errors.push("Repeat-password");
154
+ }
155
+ form.isValid = form.errors.length == 0 && !isDisabled.value;
156
+ }
157
+ };
158
+
159
+ const acceptInvitation = async () => {
160
+ const result = await resetPasswordByToken(props.userId, form.password, props.token);
161
+ if (result.succeeded) {
162
+ const result = await signIn(props.userName, form.password);
163
+ if (result.succeeded) {
164
+ router.push("/");
165
+ } else {
166
+ form.errors = [result.errorCode];
167
+ }
168
+ } else {
169
+ form.errors = result.errors;
170
+ }
171
+ };
172
+ </script>
@@ -0,0 +1,3 @@
1
+ import _Invite from "./Invite.vue";
2
+
3
+ export const Invite = _Invite as typeof _Invite;