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

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 (272) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/core/types/index.ts +4 -8
  3. package/dist/core/types/index.d.ts +5 -8
  4. package/dist/core/types/index.d.ts.map +1 -1
  5. package/dist/framework.js +231 -218
  6. package/dist/{index-YPa3sZmi.js → index-6afjoxl_.js} +1 -1
  7. package/dist/{index-B0gk_mcS.js → index-BbQdOYmi.js} +1 -1
  8. package/dist/{index-CJmhp9vS.js → index-BrkL9UJR.js} +1 -1
  9. package/dist/{index-CgCz4CyH.js → index-BrmiwSoL.js} +1 -1
  10. package/dist/{index-D2jOZZjY.js → index-C2fcXLd3.js} +1 -1
  11. package/dist/{index-F3Hq-uIf.js → index-CUGEM4hi.js} +1 -1
  12. package/dist/{index-DAPeO06N.js → index-D0rhsYYW.js} +1 -1
  13. package/dist/{index-cnzEckQv.js → index-D8jMD-EZ.js} +1 -1
  14. package/dist/{index-iKZHcZzW.js → index-DQP89JB7.js} +1 -1
  15. package/dist/{index-BzXuUqVu.js → index-DaD28rcu.js} +1 -1
  16. package/dist/{index-uJMg_eoD.js → index-Df8tA8qI.js} +1 -1
  17. package/dist/{index-sB8jPoQD.js → index-Dg25Tarq.js} +1 -1
  18. package/dist/{index-KsWKxMp0.js → index-DrL4GDih.js} +1 -1
  19. package/dist/{index-CimbhNJz.js → index-DrxadmGH.js} +1 -1
  20. package/dist/{index-52C01JSh.js → index-DulPT6l3.js} +1 -1
  21. package/dist/{index-C8ZFV-LP.js → index-Y1Vd-H3g.js} +34754 -34242
  22. package/dist/{index-Dr0Jm59E.js → index-lQO4lsVu.js} +1 -1
  23. package/dist/index.css +1 -1
  24. package/dist/index.d.ts +1 -0
  25. package/dist/index.d.ts.map +1 -1
  26. package/dist/locales/en.json +1 -0
  27. package/dist/shared/components/app-bar-button/app-bar-button.vue.d.ts.map +1 -1
  28. package/dist/shared/components/app-switcher/components/vc-app-switcher/vc-app-switcher.vue.d.ts.map +1 -1
  29. package/dist/shared/components/blade-navigation/components/vc-blade-navigation/vc-blade-navigation.vue.d.ts.map +1 -1
  30. package/dist/shared/components/blade-navigation/components/vc-blade-view/vc-blade-view.d.ts +15 -1
  31. package/dist/shared/components/blade-navigation/components/vc-blade-view/vc-blade-view.d.ts.map +1 -1
  32. package/dist/shared/components/generic-dropdown/generic-dropdown.vue.d.ts +110 -0
  33. package/dist/shared/components/generic-dropdown/generic-dropdown.vue.d.ts.map +1 -0
  34. package/dist/shared/components/generic-dropdown/index.d.ts +2 -0
  35. package/dist/shared/components/generic-dropdown/index.d.ts.map +1 -0
  36. package/dist/shared/components/index.d.ts +2 -0
  37. package/dist/shared/components/index.d.ts.map +1 -1
  38. package/dist/shared/components/language-selector/language-selector.vue.d.ts.map +1 -1
  39. package/dist/shared/components/menu-item/index.d.ts +2 -0
  40. package/dist/shared/components/menu-item/index.d.ts.map +1 -0
  41. package/dist/shared/components/menu-item/menu-item.vue.d.ts +57 -0
  42. package/dist/shared/components/menu-item/menu-item.vue.d.ts.map +1 -0
  43. package/dist/shared/components/notification-dropdown/notification-dropdown.vue.d.ts.map +1 -1
  44. package/dist/shared/components/notification-template/index.d.ts +0 -6
  45. package/dist/shared/components/notification-template/index.d.ts.map +1 -1
  46. package/dist/shared/components/notification-template/notification-template.vue.d.ts +2 -2
  47. package/dist/shared/components/notification-template/notification-template.vue.d.ts.map +1 -1
  48. package/dist/shared/components/sidebar/sidebar.vue.d.ts +1 -0
  49. package/dist/shared/components/sidebar/sidebar.vue.d.ts.map +1 -1
  50. package/dist/shared/components/theme-selector/theme-selector.vue.d.ts.map +1 -1
  51. package/dist/shared/components/user-dropdown-button/_internal/user-actions.vue.d.ts +21 -0
  52. package/dist/shared/components/user-dropdown-button/_internal/user-actions.vue.d.ts.map +1 -0
  53. package/dist/shared/components/user-dropdown-button/_internal/user-info.vue.d.ts +17 -0
  54. package/dist/shared/components/user-dropdown-button/_internal/user-info.vue.d.ts.map +1 -0
  55. package/dist/shared/components/user-dropdown-button/_internal/user-sidebar.vue.d.ts +25 -0
  56. package/dist/shared/components/user-dropdown-button/_internal/user-sidebar.vue.d.ts.map +1 -0
  57. package/dist/shared/components/user-dropdown-button/composables/useUserActions.d.ts +3921 -0
  58. package/dist/shared/components/user-dropdown-button/composables/useUserActions.d.ts.map +1 -0
  59. package/dist/shared/components/user-dropdown-button/index.d.ts +5 -5
  60. package/dist/shared/components/user-dropdown-button/user-dropdown-button.vue.d.ts +4 -4
  61. package/dist/shared/components/user-dropdown-button/user-dropdown-button.vue.d.ts.map +1 -1
  62. package/dist/shared/modules/dynamic/components/fields/Button.d.ts +0 -6
  63. package/dist/shared/modules/dynamic/components/fields/Button.d.ts.map +1 -1
  64. package/dist/shared/modules/dynamic/components/fields/Card.d.ts +0 -6
  65. package/dist/shared/modules/dynamic/components/fields/Card.d.ts.map +1 -1
  66. package/dist/shared/modules/dynamic/components/fields/Checkbox.d.ts +0 -6
  67. package/dist/shared/modules/dynamic/components/fields/Checkbox.d.ts.map +1 -1
  68. package/dist/shared/modules/dynamic/components/fields/ContentField.d.ts +0 -6
  69. package/dist/shared/modules/dynamic/components/fields/ContentField.d.ts.map +1 -1
  70. package/dist/shared/modules/dynamic/components/fields/CustomComponent.d.ts +0 -6
  71. package/dist/shared/modules/dynamic/components/fields/CustomComponent.d.ts.map +1 -1
  72. package/dist/shared/modules/dynamic/components/fields/DynamicProperty.d.ts +0 -6
  73. package/dist/shared/modules/dynamic/components/fields/DynamicProperty.d.ts.map +1 -1
  74. package/dist/shared/modules/dynamic/components/fields/EditorField.d.ts +0 -6
  75. package/dist/shared/modules/dynamic/components/fields/EditorField.d.ts.map +1 -1
  76. package/dist/shared/modules/dynamic/components/fields/Fieldset.d.ts +0 -6
  77. package/dist/shared/modules/dynamic/components/fields/Fieldset.d.ts.map +1 -1
  78. package/dist/shared/modules/dynamic/components/fields/GalleryField.d.ts +0 -6
  79. package/dist/shared/modules/dynamic/components/fields/GalleryField.d.ts.map +1 -1
  80. package/dist/shared/modules/dynamic/components/fields/ImageField.d.ts +0 -6
  81. package/dist/shared/modules/dynamic/components/fields/ImageField.d.ts.map +1 -1
  82. package/dist/shared/modules/dynamic/components/fields/InputCurrency.d.ts +0 -6
  83. package/dist/shared/modules/dynamic/components/fields/InputCurrency.d.ts.map +1 -1
  84. package/dist/shared/modules/dynamic/components/fields/InputField.d.ts +0 -6
  85. package/dist/shared/modules/dynamic/components/fields/InputField.d.ts.map +1 -1
  86. package/dist/shared/modules/dynamic/components/fields/MultivalueField.d.ts +0 -6
  87. package/dist/shared/modules/dynamic/components/fields/MultivalueField.d.ts.map +1 -1
  88. package/dist/shared/modules/dynamic/components/fields/RadioButtonGroup.d.ts +0 -6
  89. package/dist/shared/modules/dynamic/components/fields/RadioButtonGroup.d.ts.map +1 -1
  90. package/dist/shared/modules/dynamic/components/fields/RatingField.d.ts +0 -6
  91. package/dist/shared/modules/dynamic/components/fields/RatingField.d.ts.map +1 -1
  92. package/dist/shared/modules/dynamic/components/fields/SelectField.d.ts +0 -6
  93. package/dist/shared/modules/dynamic/components/fields/SelectField.d.ts.map +1 -1
  94. package/dist/shared/modules/dynamic/components/fields/StatusField.d.ts +0 -6
  95. package/dist/shared/modules/dynamic/components/fields/StatusField.d.ts.map +1 -1
  96. package/dist/shared/modules/dynamic/components/fields/SwitchField.d.ts +0 -6
  97. package/dist/shared/modules/dynamic/components/fields/SwitchField.d.ts.map +1 -1
  98. package/dist/shared/modules/dynamic/components/fields/Table.d.ts +0 -6
  99. package/dist/shared/modules/dynamic/components/fields/Table.d.ts.map +1 -1
  100. package/dist/shared/modules/dynamic/components/fields/TextareaField.d.ts +0 -6
  101. package/dist/shared/modules/dynamic/components/fields/TextareaField.d.ts.map +1 -1
  102. package/dist/shared/modules/dynamic/components/fields/VideoField.d.ts +0 -6
  103. package/dist/shared/modules/dynamic/components/fields/VideoField.d.ts.map +1 -1
  104. package/dist/shared/modules/dynamic/components/fields/props.d.ts +0 -6
  105. package/dist/shared/modules/dynamic/components/fields/props.d.ts.map +1 -1
  106. package/dist/shared/modules/dynamic/components/fields/storybook/Button.stories.d.ts +0 -18
  107. package/dist/shared/modules/dynamic/components/fields/storybook/Button.stories.d.ts.map +1 -1
  108. package/dist/shared/modules/dynamic/components/fields/storybook/Card.stories.d.ts +0 -18
  109. package/dist/shared/modules/dynamic/components/fields/storybook/Card.stories.d.ts.map +1 -1
  110. package/dist/shared/modules/dynamic/components/fields/storybook/Checkbox.stories.d.ts +0 -18
  111. package/dist/shared/modules/dynamic/components/fields/storybook/Checkbox.stories.d.ts.map +1 -1
  112. package/dist/shared/modules/dynamic/components/fields/storybook/ContentField.stories.d.ts +0 -18
  113. package/dist/shared/modules/dynamic/components/fields/storybook/ContentField.stories.d.ts.map +1 -1
  114. package/dist/shared/modules/dynamic/components/fields/storybook/EditorField.stories.d.ts +0 -18
  115. package/dist/shared/modules/dynamic/components/fields/storybook/EditorField.stories.d.ts.map +1 -1
  116. package/dist/shared/modules/dynamic/components/fields/storybook/Fieldset.stories.d.ts +0 -18
  117. package/dist/shared/modules/dynamic/components/fields/storybook/Fieldset.stories.d.ts.map +1 -1
  118. package/dist/shared/modules/dynamic/components/fields/storybook/GalleryField.stories.d.ts +0 -18
  119. package/dist/shared/modules/dynamic/components/fields/storybook/GalleryField.stories.d.ts.map +1 -1
  120. package/dist/shared/modules/dynamic/components/fields/storybook/ImageField.stories.d.ts +0 -18
  121. package/dist/shared/modules/dynamic/components/fields/storybook/ImageField.stories.d.ts.map +1 -1
  122. package/dist/shared/modules/dynamic/components/fields/storybook/InputCurrency.stories.d.ts +0 -18
  123. package/dist/shared/modules/dynamic/components/fields/storybook/InputCurrency.stories.d.ts.map +1 -1
  124. package/dist/shared/modules/dynamic/components/fields/storybook/InputField.stories.d.ts +0 -18
  125. package/dist/shared/modules/dynamic/components/fields/storybook/InputField.stories.d.ts.map +1 -1
  126. package/dist/shared/modules/dynamic/components/fields/storybook/MultivalueField.stories.d.ts +0 -18
  127. package/dist/shared/modules/dynamic/components/fields/storybook/MultivalueField.stories.d.ts.map +1 -1
  128. package/dist/shared/modules/dynamic/components/fields/storybook/RadioButtonGroup.stories.d.ts +0 -18
  129. package/dist/shared/modules/dynamic/components/fields/storybook/RadioButtonGroup.stories.d.ts.map +1 -1
  130. package/dist/shared/modules/dynamic/components/fields/storybook/RatingField.stories.d.ts +0 -18
  131. package/dist/shared/modules/dynamic/components/fields/storybook/RatingField.stories.d.ts.map +1 -1
  132. package/dist/shared/modules/dynamic/components/fields/storybook/SelectField.stories.d.ts +0 -18
  133. package/dist/shared/modules/dynamic/components/fields/storybook/SelectField.stories.d.ts.map +1 -1
  134. package/dist/shared/modules/dynamic/components/fields/storybook/StatusField.stories.d.ts +0 -18
  135. package/dist/shared/modules/dynamic/components/fields/storybook/StatusField.stories.d.ts.map +1 -1
  136. package/dist/shared/modules/dynamic/components/fields/storybook/TextareaField.stories.d.ts +0 -18
  137. package/dist/shared/modules/dynamic/components/fields/storybook/TextareaField.stories.d.ts.map +1 -1
  138. package/dist/shared/modules/dynamic/components/fields/storybook/VideoField.stories.d.ts +0 -18
  139. package/dist/shared/modules/dynamic/components/fields/storybook/VideoField.stories.d.ts.map +1 -1
  140. package/dist/shared/modules/dynamic/components/fields/storybook/pages/DynamicRender.d.ts +0 -18
  141. package/dist/shared/modules/dynamic/components/fields/storybook/pages/DynamicRender.d.ts.map +1 -1
  142. package/dist/shared/modules/dynamic/pages/dynamic-blade-form.vue.d.ts +0 -12
  143. package/dist/shared/modules/dynamic/pages/dynamic-blade-form.vue.d.ts.map +1 -1
  144. package/dist/shared/modules/dynamic/pages/dynamic-blade-list.vue.d.ts +0 -12
  145. package/dist/shared/modules/dynamic/pages/dynamic-blade-list.vue.d.ts.map +1 -1
  146. package/dist/shared/pages/InvitePage/components/invite/index.d.ts +8 -8
  147. package/dist/shared/pages/ResetPasswordPage/components/reset-password/index.d.ts +8 -8
  148. package/dist/tailwind.config.d.ts +1 -1
  149. package/dist/tsconfig.tsbuildinfo +1 -1
  150. package/dist/ui/components/atoms/vc-button/vc-button.stories.d.ts +156 -156
  151. package/dist/ui/components/atoms/vc-button/vc-button.vue.d.ts +2 -1
  152. package/dist/ui/components/atoms/vc-button/vc-button.vue.d.ts.map +1 -1
  153. package/dist/ui/components/atoms/vc-icon/icons/AppWindowIcon.vue.d.ts +18 -0
  154. package/dist/ui/components/atoms/vc-icon/icons/AppWindowIcon.vue.d.ts.map +1 -0
  155. package/dist/ui/components/atoms/vc-icon/icons/ArrowLeftIcon.vue.d.ts +18 -0
  156. package/dist/ui/components/atoms/vc-icon/icons/ArrowLeftIcon.vue.d.ts.map +1 -0
  157. package/dist/ui/components/atoms/vc-icon/icons/ArrowRightIcon.vue.d.ts +18 -0
  158. package/dist/ui/components/atoms/vc-icon/icons/ArrowRightIcon.vue.d.ts.map +1 -0
  159. package/dist/ui/components/atoms/vc-icon/icons/BellIcon.vue.d.ts +18 -0
  160. package/dist/ui/components/atoms/vc-icon/icons/BellIcon.vue.d.ts.map +1 -0
  161. package/dist/ui/components/atoms/vc-icon/icons/CircleDotsIcon.vue.d.ts +18 -0
  162. package/dist/ui/components/atoms/vc-icon/icons/CircleDotsIcon.vue.d.ts.map +1 -0
  163. package/dist/ui/components/atoms/vc-icon/icons/CrossSignIcon.vue.d.ts +18 -0
  164. package/dist/ui/components/atoms/vc-icon/icons/CrossSignIcon.vue.d.ts.map +1 -0
  165. package/dist/ui/components/atoms/vc-icon/icons/LogoutIcon.vue.d.ts +18 -0
  166. package/dist/ui/components/atoms/vc-icon/icons/LogoutIcon.vue.d.ts.map +1 -0
  167. package/dist/ui/components/atoms/vc-icon/icons/MenuBurgerIcon.vue.d.ts +18 -0
  168. package/dist/ui/components/atoms/vc-icon/icons/MenuBurgerIcon.vue.d.ts.map +1 -0
  169. package/dist/ui/components/atoms/vc-icon/icons/MinusSignIcon.vue.d.ts +18 -0
  170. package/dist/ui/components/atoms/vc-icon/icons/MinusSignIcon.vue.d.ts.map +1 -0
  171. package/dist/ui/components/atoms/vc-icon/icons/PlusSignIcon.vue.d.ts +18 -0
  172. package/dist/ui/components/atoms/vc-icon/icons/PlusSignIcon.vue.d.ts.map +1 -0
  173. package/dist/ui/components/atoms/vc-icon/icons/SettingsBoltIcon.vue.d.ts +18 -0
  174. package/dist/ui/components/atoms/vc-icon/icons/SettingsBoltIcon.vue.d.ts.map +1 -0
  175. package/dist/ui/components/atoms/vc-icon/icons/index.d.ts +12 -0
  176. package/dist/ui/components/atoms/vc-icon/icons/index.d.ts.map +1 -0
  177. package/dist/ui/components/atoms/vc-icon/index.d.ts +1 -0
  178. package/dist/ui/components/atoms/vc-icon/index.d.ts.map +1 -1
  179. package/dist/ui/components/atoms/vc-icon/vc-icon.stories.d.ts +3 -3
  180. package/dist/ui/components/atoms/vc-icon/vc-icon.vue.d.ts +3 -2
  181. package/dist/ui/components/atoms/vc-icon/vc-icon.vue.d.ts.map +1 -1
  182. package/dist/ui/components/atoms/vc-status/vc-status.vue.d.ts.map +1 -1
  183. package/dist/ui/components/atoms/vc-tooltip/vc-tooltip.vue.d.ts +4 -0
  184. package/dist/ui/components/atoms/vc-tooltip/vc-tooltip.vue.d.ts.map +1 -1
  185. package/dist/ui/components/molecules/vc-editor/vc-editor.stories.d.ts +996 -0
  186. package/dist/ui/components/molecules/vc-editor/vc-editor.stories.d.ts.map +1 -1
  187. package/dist/ui/components/molecules/vc-editor/vc-editor.vue.d.ts +332 -0
  188. package/dist/ui/components/molecules/vc-editor/vc-editor.vue.d.ts.map +1 -1
  189. package/dist/ui/components/molecules/vc-pagination/vc-pagination.vue.d.ts.map +1 -1
  190. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/vc-app-bar.vue.d.ts +3 -1
  191. package/dist/ui/components/organisms/vc-app/_internal/vc-app-bar/vc-app-bar.vue.d.ts.map +1 -1
  192. 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
  193. package/dist/ui/components/organisms/vc-app/_internal/vc-app-menu/vc-app-menu.vue.d.ts.map +1 -1
  194. package/dist/ui/components/organisms/vc-app/composables/useToolbarSlots.d.ts +5 -0
  195. package/dist/ui/components/organisms/vc-app/composables/useToolbarSlots.d.ts.map +1 -0
  196. package/dist/ui/components/organisms/vc-app/vc-app.stories.d.ts +16 -106
  197. package/dist/ui/components/organisms/vc-app/vc-app.stories.d.ts.map +1 -1
  198. package/dist/ui/components/organisms/vc-app/vc-app.vue.d.ts +16 -106
  199. package/dist/ui/components/organisms/vc-app/vc-app.vue.d.ts.map +1 -1
  200. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-header/vc-blade-header.vue.d.ts +0 -2
  201. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-header/vc-blade-header.vue.d.ts.map +1 -1
  202. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-button/vc-blade-toolbar-button.vue.d.ts +0 -3
  203. 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
  204. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/vc-blade-toolbar.vue.d.ts +13 -2
  205. package/dist/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/vc-blade-toolbar.vue.d.ts.map +1 -1
  206. package/dist/ui/components/organisms/vc-blade/vc-blade.stories.d.ts +0 -16
  207. package/dist/ui/components/organisms/vc-blade/vc-blade.stories.d.ts.map +1 -1
  208. package/dist/ui/components/organisms/vc-blade/vc-blade.vue.d.ts +0 -2
  209. package/dist/ui/components/organisms/vc-blade/vc-blade.vue.d.ts.map +1 -1
  210. package/dist/ui/components/organisms/vc-table/_internal/vc-table-filter/vc-table-filter.vue.d.ts.map +1 -1
  211. package/dist/ui/components/organisms/vc-table/_internal/vc-table-mobile-item/vc-table-mobile-item.vue.d.ts +3 -3
  212. package/dist/ui/components/organisms/vc-table/_internal/vc-table-mobile-item/vc-table-mobile-item.vue.d.ts.map +1 -1
  213. package/dist/ui/components/organisms/vc-table/vc-table.stories.d.ts +30 -30
  214. package/dist/ui/components/organisms/vc-table/vc-table.vue.d.ts +6 -6
  215. package/dist/ui/components/organisms/vc-table/vc-table.vue.d.ts.map +1 -1
  216. package/package.json +9 -6
  217. package/shared/components/app-bar-button/app-bar-button.vue +62 -45
  218. package/shared/components/app-switcher/components/vc-app-switcher/vc-app-switcher.vue +31 -134
  219. package/shared/components/blade-navigation/components/vc-blade-navigation/vc-blade-navigation.vue +8 -7
  220. package/shared/components/blade-navigation/components/vc-blade-view/vc-blade-view.ts +16 -4
  221. package/shared/components/change-password/change-password.vue +2 -1
  222. package/shared/components/generic-dropdown/generic-dropdown.vue +171 -0
  223. package/shared/components/generic-dropdown/index.ts +1 -0
  224. package/shared/components/index.ts +2 -0
  225. package/shared/components/language-selector/language-selector.vue +29 -64
  226. package/shared/components/menu-item/index.ts +1 -0
  227. package/shared/components/menu-item/menu-item.vue +111 -0
  228. package/shared/components/notification-dropdown/notification-dropdown.vue +21 -72
  229. package/shared/components/notification-template/notification-template.vue +23 -34
  230. package/shared/components/sidebar/sidebar.vue +16 -1
  231. package/shared/components/theme-selector/theme-selector.vue +34 -76
  232. package/shared/components/user-dropdown-button/_internal/user-actions.vue +68 -0
  233. package/shared/components/user-dropdown-button/_internal/user-info.vue +74 -0
  234. package/shared/components/user-dropdown-button/_internal/user-sidebar.vue +73 -0
  235. package/shared/components/user-dropdown-button/composables/useUserActions.ts +56 -0
  236. package/shared/components/user-dropdown-button/user-dropdown-button.vue +69 -271
  237. package/tailwind.config.ts +1 -1
  238. package/ui/components/atoms/vc-badge/vc-badge.vue +10 -9
  239. package/ui/components/atoms/vc-button/vc-button.vue +2 -2
  240. package/ui/components/atoms/vc-card/vc-card.vue +4 -7
  241. package/ui/components/atoms/vc-icon/icons/AppWindowIcon.vue +32 -0
  242. package/ui/components/atoms/vc-icon/icons/ArrowLeftIcon.vue +24 -0
  243. package/ui/components/atoms/vc-icon/icons/ArrowRightIcon.vue +24 -0
  244. package/ui/components/atoms/vc-icon/icons/BellIcon.vue +29 -0
  245. package/ui/components/atoms/vc-icon/icons/CircleDotsIcon.vue +41 -0
  246. package/ui/components/atoms/vc-icon/icons/CrossSignIcon.vue +24 -0
  247. package/ui/components/atoms/vc-icon/icons/LogoutIcon.vue +24 -0
  248. package/ui/components/atoms/vc-icon/icons/MenuBurgerIcon.vue +24 -0
  249. package/ui/components/atoms/vc-icon/icons/MinusSignIcon.vue +24 -0
  250. package/ui/components/atoms/vc-icon/icons/PlusSignIcon.vue +24 -0
  251. package/ui/components/atoms/vc-icon/icons/SettingsBoltIcon.vue +31 -0
  252. package/ui/components/atoms/vc-icon/icons/index.ts +11 -0
  253. package/ui/components/atoms/vc-icon/index.ts +1 -0
  254. package/ui/components/atoms/vc-icon/vc-icon.vue +33 -3
  255. package/ui/components/atoms/vc-status/vc-status.vue +17 -4
  256. package/ui/components/atoms/vc-tooltip/vc-tooltip.vue +22 -7
  257. package/ui/components/atoms/vc-widget/vc-widget.vue +31 -22
  258. package/ui/components/molecules/vc-pagination/vc-pagination.vue +9 -17
  259. package/ui/components/organisms/vc-app/_internal/vc-app-bar/vc-app-bar.vue +196 -33
  260. package/ui/components/organisms/vc-app/_internal/vc-app-menu/_internal/vc-app-menu-item/_internal/vc-app-menu-link.vue +47 -47
  261. package/ui/components/organisms/vc-app/_internal/vc-app-menu/vc-app-menu.vue +5 -29
  262. package/ui/components/organisms/vc-app/composables/useToolbarSlots.ts +37 -0
  263. package/ui/components/organisms/vc-app/vc-app.vue +87 -70
  264. package/ui/components/organisms/vc-blade/_internal/vc-blade-header/vc-blade-header.vue +17 -17
  265. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/_internal/vc-blade-toolbar-button/vc-blade-toolbar-button.vue +9 -69
  266. package/ui/components/organisms/vc-blade/_internal/vc-blade-toolbar/vc-blade-toolbar.vue +199 -31
  267. package/ui/components/organisms/vc-blade/vc-blade.stories.ts +1 -1
  268. package/ui/components/organisms/vc-blade/vc-blade.vue +129 -38
  269. package/ui/components/organisms/vc-table/_internal/vc-table-base-header/vc-table-base-header.vue +2 -2
  270. package/ui/components/organisms/vc-table/_internal/vc-table-cell/vc-table-cell.vue +1 -1
  271. package/ui/components/organisms/vc-table/_internal/vc-table-filter/vc-table-filter.vue +34 -23
  272. package/ui/components/organisms/vc-table/vc-table.vue +44 -29
@@ -0,0 +1,68 @@
1
+ <template>
2
+ <div class="vc-user-actions">
3
+ <div class="vc-user-actions__trigger">
4
+ <div class="vc-user-actions__buttons">
5
+ <button
6
+ v-for="(item, i) in profileMenu"
7
+ :key="`action_btn_${i}`"
8
+ class="vc-user-actions__btn"
9
+ @click="$emit('action:click', item)"
10
+ >
11
+ <VcIcon
12
+ v-if="item.icon"
13
+ :icon="item.icon"
14
+ size="l"
15
+ />
16
+ </button>
17
+ </div>
18
+ </div>
19
+ </div>
20
+ </template>
21
+
22
+ <script lang="ts" setup>
23
+ import { VcIcon } from "../../../../ui/components";
24
+ import type { IMenuItem } from "../../../../core/types";
25
+
26
+ defineProps<{
27
+ profileMenu: IMenuItem[];
28
+ }>();
29
+
30
+ defineEmits<{
31
+ (e: "action:click", item: IMenuItem): void;
32
+ }>();
33
+ </script>
34
+
35
+ <style lang="scss">
36
+ .vc-user-actions {
37
+ @apply tw-relative tw-h-full;
38
+
39
+ &__trigger {
40
+ @apply tw-absolute tw-right-0 tw-top-0 tw-h-full tw-w-1 tw-bg-[--user-dropdown-button-bg];
41
+ }
42
+
43
+ &__buttons {
44
+ @apply tw-flex tw-absolute tw-right-0 tw-top-0 tw-h-full tw-translate-x-full;
45
+ transition: transform 0.3s ease;
46
+ }
47
+
48
+ &__btn {
49
+ @apply tw-w-12 tw-h-full tw-flex tw-items-center tw-justify-center tw-text-[color:var(--user-dropdown-button-icon-color)];
50
+
51
+ &:nth-child(1) {
52
+ @apply tw-bg-[--user-dropdown-button-bg];
53
+
54
+ &:hover {
55
+ @apply tw-bg-[--user-dropdown-button-bg-hover];
56
+ }
57
+ }
58
+
59
+ &:nth-child(2) {
60
+ @apply tw-bg-[--user-dropdown-button-bg-logout];
61
+
62
+ &:hover {
63
+ @apply tw-bg-[--user-dropdown-button-bg-logout-hover];
64
+ }
65
+ }
66
+ }
67
+ }
68
+ </style>
@@ -0,0 +1,74 @@
1
+ <template>
2
+ <div class="vc-user-info">
3
+ <div
4
+ v-if="avatarUrl"
5
+ class="vc-user-info__avatar"
6
+ :style="imageHandler"
7
+ ></div>
8
+ <VcIcon
9
+ v-else
10
+ icon="fas fa-user-circle"
11
+ size="xxl"
12
+ class="vc-user-info__icon"
13
+ />
14
+ <div class="vc-user-info__info">
15
+ <div class="vc-user-info__name">
16
+ {{ name || (user && "fullName" in user && user.fullName) || user?.userName }}
17
+ </div>
18
+ <div class="vc-user-info__role">
19
+ {{
20
+ (role && $t(`SHELL.USER.ROLE.${role}`)) || (user?.isAdministrator ? $t("SHELL.USER.ROLE.ADMINISTRATOR") : "")
21
+ }}
22
+ </div>
23
+ </div>
24
+ </div>
25
+ </template>
26
+
27
+ <script lang="ts" setup>
28
+ import { computed } from "vue";
29
+ import { useUser } from "../../../../core/composables";
30
+ import { VcIcon } from "../../../../ui/components";
31
+
32
+ export interface Props {
33
+ avatarUrl?: string;
34
+ name?: string;
35
+ role?: string;
36
+ }
37
+
38
+ const props = defineProps<Props>();
39
+ const { user } = useUser();
40
+
41
+ const imageHandler = computed(() => {
42
+ if (props.avatarUrl) {
43
+ return `background-image: url(${CSS.escape(props.avatarUrl)})`;
44
+ }
45
+ return undefined;
46
+ });
47
+ </script>
48
+
49
+ <style lang="scss">
50
+ .vc-user-info {
51
+ @apply tw-flex tw-items-center tw-gap-3;
52
+
53
+ &__avatar {
54
+ @apply tw-rounded-full tw-overflow-hidden tw-w-[34px] tw-h-[34px] tw-bg-[color:var(--user-dropdown-account-info-role-color)]
55
+ tw-bg-cover tw-bg-center tw-shrink-0;
56
+ }
57
+
58
+ &__icon {
59
+ @apply tw-text-[color:var(--user-dropdown-button-color)];
60
+ }
61
+
62
+ &__info {
63
+ @apply tw-grow tw-basis-0 tw-overflow-hidden;
64
+ }
65
+
66
+ &__name {
67
+ @apply tw-text-sm tw-text-[color:var(--user-dropdown-account-info-name-color)] tw-max-w-[250px] tw-truncate;
68
+ }
69
+
70
+ &__role {
71
+ @apply tw-text-sm tw-text-[color:var(--user-dropdown-account-info-role-color)];
72
+ }
73
+ }
74
+ </style>
@@ -0,0 +1,73 @@
1
+ <template>
2
+ <Sidebar
3
+ :is-expanded="isOpened"
4
+ position="left"
5
+ render="always"
6
+ :title="$t('SHELL.ACCOUNT.SETTINGS')"
7
+ @close="$emit('update:isOpened', false)"
8
+ >
9
+ <template #content>
10
+ <div
11
+ v-if="menuItems && isOpened"
12
+ class="vc-user-sidebar__menu"
13
+ @click.stop="$emit('update:isOpened', false)"
14
+ >
15
+ <!-- Render components separately -->
16
+ <template
17
+ v-for="(item, i) in renderContentItems"
18
+ :key="`render_${i}`"
19
+ >
20
+ <component :is="item.component" />
21
+ </template>
22
+
23
+ <!-- Regular menu items -->
24
+ <template
25
+ v-for="(item, i) in regularMenuItems"
26
+ :key="`menu_${i}`"
27
+ >
28
+ <SettingsMenuItem
29
+ :icon="item.icon"
30
+ :title="$t(item.title as string)"
31
+ @click="$emit('item:click', item)"
32
+ />
33
+ </template>
34
+ </div>
35
+ </template>
36
+ </Sidebar>
37
+ </template>
38
+
39
+ <script lang="ts" setup>
40
+ import { computed } from "vue";
41
+ import { Sidebar } from "../../sidebar";
42
+ import { IMenuItem } from "../../../../core/types";
43
+ import { SettingsMenuItem } from "../../menu-item";
44
+
45
+ const props = defineProps<{
46
+ isOpened: boolean;
47
+ menuItems: IMenuItem[];
48
+ }>();
49
+
50
+ defineEmits<{
51
+ (e: "update:isOpened", value: boolean): void;
52
+ (e: "item:click", item: IMenuItem): void;
53
+ }>();
54
+
55
+ // Separate menu items into components and regular items
56
+ const renderContentItems = computed(() => props.menuItems.filter((item) => item.component));
57
+
58
+ const regularMenuItems = computed(() => props.menuItems.filter((item) => !item.component));
59
+ </script>
60
+
61
+ <style lang="scss">
62
+ .vc-user-sidebar {
63
+ &__menu {
64
+ @apply tw-w-full tw-flex tw-flex-col;
65
+ }
66
+
67
+ .vc-app_mobile & {
68
+ &__menu {
69
+ @apply tw-static tw-shadow-none #{!important};
70
+ }
71
+ }
72
+ }
73
+ </style>
@@ -0,0 +1,56 @@
1
+ import { ref, computed } from "vue";
2
+ import { useI18n } from "vue-i18n";
3
+ import { useUser } from "../../../../core/composables";
4
+ import { useRouter } from "vue-router";
5
+ import { useBladeNavigation } from "../..";
6
+ import { usePopup } from "../../popup-handler/composables/usePopup";
7
+ import { ChangePassword } from "../../change-password";
8
+ import type { IMenuItem } from "../../../../core/types";
9
+ import { LogoutIcon, SettingsBoltIcon } from "../../../../ui/components/atoms/vc-icon/icons";
10
+
11
+ export function useUserActions() {
12
+ const { t } = useI18n({ useScope: "global" });
13
+ const { signOut } = useUser();
14
+ const router = useRouter();
15
+ const { closeBlade } = useBladeNavigation();
16
+ const { open } = usePopup({ component: ChangePassword });
17
+
18
+ const signOutButton = ref<IMenuItem>({
19
+ title: computed(() => t("SHELL.ACCOUNT.LOGOUT")),
20
+ icon: LogoutIcon,
21
+ async clickHandler() {
22
+ const isPrevented = await closeBlade(0);
23
+ if (!isPrevented) {
24
+ await signOut();
25
+ router.push({ name: "Login" });
26
+ }
27
+ },
28
+ });
29
+
30
+ const changePasswordButton = ref<IMenuItem>({
31
+ title: computed(() => t("SHELL.ACCOUNT.CHANGE_PASSWORD")),
32
+ icon: SettingsBoltIcon,
33
+ clickHandler() {
34
+ open();
35
+ },
36
+ });
37
+
38
+ const settingsButton = ref<IMenuItem>({
39
+ title: computed(() => t("SHELL.ACCOUNT.SETTINGS")),
40
+ icon: SettingsBoltIcon,
41
+ clickHandler() {
42
+ return true;
43
+ },
44
+ });
45
+
46
+ const profileMenu = ref([settingsButton.value]);
47
+ const defaultMenuItems = ref([changePasswordButton.value, signOutButton.value]);
48
+
49
+ return {
50
+ profileMenu,
51
+ defaultMenuItems,
52
+ signOutButton,
53
+ changePasswordButton,
54
+ settingsButton,
55
+ };
56
+ }
@@ -1,197 +1,66 @@
1
1
  <template>
2
- <AppBarButtonTemplate
3
- position="bottom-start"
4
- :before-open="beforeOpen"
5
- :title="user?.userName"
6
- >
7
- <template #button="{ opened }">
8
- <template v-if="$isDesktop.value">
9
- <div
10
- class="vc-user-dropdown-button"
11
- :class="{
12
- 'vc-user-dropdown-button--active': opened,
13
- 'vc-user-dropdown-button--auto-width': disabled,
14
- 'vc-user-dropdown-button--mobile': $isMobile.value,
15
- }"
16
- >
17
- <div
18
- class="vc-user-dropdown-button__wrap"
19
- :class="{
20
- 'vc-user-dropdown-button__wrap--active': opened,
21
- }"
22
- >
23
- <div
24
- v-if="avatarUrl"
25
- class="vc-user-dropdown-button__avatar"
26
- :style="imageHandler"
27
- ></div>
28
- <VcIcon
29
- v-else
30
- icon="fas fa-user-circle"
31
- size="xxl"
32
- class="vc-user-dropdown-button__icon"
33
- />
34
- <div class="vc-user-dropdown-button__info">
35
- <div class="vc-user-dropdown-button__name">
36
- {{ name || (user && "fullName" in user && user.fullName) || user?.userName }}
37
- </div>
38
- <div class="vc-user-dropdown-button__role">
39
- {{
40
- (role && $t(`SHELL.USER.ROLE.${role}`)) ||
41
- (user?.isAdministrator ? $t("SHELL.USER.ROLE.ADMINISTRATOR") : "")
42
- }}
43
- </div>
44
- </div>
45
- <div
46
- v-if="!disabled && menu && menu.length"
47
- class="vc-user-dropdown-button__chevron"
48
- >
49
- <VcIcon
50
- icon="fas fa-chevron-down"
51
- size="xl"
52
- ></VcIcon>
53
- </div>
54
- </div>
55
- </div>
56
- </template>
57
- <template v-else>
58
- <div class="vc-user-dropdown-button__button">
59
- <div
60
- v-if="avatarUrl"
61
- class="vc-user-dropdown-button__avatar"
62
- :style="imageHandler"
63
- ></div>
64
- <VcIcon
65
- v-else
66
- icon="fas fa-user-circle"
67
- size="xxl"
68
- class="vc-user-dropdown-button__icon"
69
- />
70
- </div>
71
- </template>
72
- </template>
73
- <template #dropdown-content="{ opened, toggle }">
74
- <Sidebar
75
- :is-expanded="$isMobile.value ? opened : false"
76
- position="right"
77
- render="mobile"
78
- @close="toggle"
2
+ <div>
3
+ <div
4
+ class="vc-user-dropdown-button"
5
+ :class="{
6
+ 'vc-user-dropdown-button--active': false,
7
+ 'vc-user-dropdown-button--auto-width': disabled,
8
+ 'vc-user-dropdown-button--mobile': $isMobile.value,
9
+ }"
10
+ >
11
+ <div
12
+ class="vc-user-dropdown-button__wrap"
13
+ :class="{
14
+ 'vc-user-dropdown-button__wrap--active': false,
15
+ }"
79
16
  >
80
- <template #header="{ header }">
81
- <div class="vc-user-dropdown-button__header-wrap">
82
- <div class="vc-user-dropdown-button__header">
83
- <div
84
- v-if="avatarUrl"
85
- class="vc-user-dropdown-button__avatar"
86
- :style="imageHandler"
87
- ></div>
88
- <VcIcon
89
- v-else
90
- icon="fas fa-user-circle"
91
- size="xxl"
92
- class="vc-user-dropdown-button__icon"
93
- />
94
- <div class="vc-user-dropdown-button__info">
95
- <div class="vc-user-dropdown-button__name">
96
- {{ name || (user && "fullName" in user && user.fullName) || user?.userName }}
97
- </div>
98
- <div class="vc-user-dropdown-button__role">
99
- {{
100
- (role && $t(`SHELL.USER.ROLE.${role}`)) ||
101
- (user?.isAdministrator ? $t("SHELL.USER.ROLE.ADMINISTRATOR") : "")
102
- }}
103
- </div>
104
- </div>
105
- </div>
106
- <component :is="header" />
107
- </div>
108
- </template>
109
- <template #content>
110
- <div
111
- v-if="menu && opened"
112
- class="vc-user-dropdown-button__menu"
113
- @click.stop="toggle"
114
- >
115
- <div
116
- v-for="(item, i) in menu"
117
- :key="`menu_item_${i}`"
118
- class="vc-user-dropdown-button__menu-item"
119
- @click="item.hasOwnProperty('clickHandler') ? item.clickHandler?.() : null"
120
- >
121
- <VcIcon
122
- v-if="item.icon"
123
- :icon="item.icon"
124
- size="l"
125
- class="vc-user-dropdown-button__menu-icon"
126
- ></VcIcon>
127
- <p>{{ item.title }}</p>
128
- </div>
129
- </div>
130
- </template>
131
- </Sidebar>
132
- </template>
133
- </AppBarButtonTemplate>
17
+ <UserInfo
18
+ :avatar-url="avatarUrl"
19
+ :name="name"
20
+ :role="role"
21
+ />
22
+ <UserActions
23
+ :profile-menu="profileMenu"
24
+ @action:click="handleActionClick"
25
+ />
26
+ </div>
27
+ </div>
28
+
29
+ <UserSidebar
30
+ v-model:is-opened="isSidebarOpened"
31
+ :menu-items="menu"
32
+ @item:click="handleMenuItemClick"
33
+ />
34
+ </div>
134
35
  </template>
135
36
 
136
37
  <script lang="ts" setup>
137
38
  import { computed, ref } from "vue";
138
- import { useUser } from "../../../core/composables";
139
- import { useRouter } from "vue-router";
140
- import { useI18n } from "vue-i18n";
141
- import { VcIcon } from "../../../ui/components";
142
- import { BladeMenu } from "../../../core/types";
143
- import { usePopup } from "../popup-handler/composables/usePopup";
144
- import { ChangePassword } from "../change-password";
145
- import { useBladeNavigation } from "..";
146
- import { AppBarButtonTemplate } from "./../app-bar-button";
147
- import { Sidebar } from "./../sidebar";
39
+ import type { IMenuItem } from "../../../core/types";
40
+ import { useUserActions } from "./composables/useUserActions";
41
+ import { default as UserInfo } from "./_internal/user-info.vue";
42
+ import { default as UserActions } from "./_internal/user-actions.vue";
43
+ import { default as UserSidebar } from "./_internal/user-sidebar.vue";
44
+ import * as _ from "lodash-es";
148
45
 
149
46
  export interface Props {
150
47
  avatarUrl?: string | undefined;
151
48
  name?: string | undefined;
152
49
  role?: string | undefined;
153
- menuItems?: BladeMenu[];
154
- baseMenuItemsHandler?: (defaultMenuItems: BladeMenu[]) => BladeMenu[];
50
+ menuItems?: IMenuItem[];
51
+ baseMenuItemsHandler?: (defaultMenuItems: IMenuItem[]) => IMenuItem[];
155
52
  disabled?: boolean;
156
53
  }
54
+
157
55
  const props = withDefaults(defineProps<Props>(), {
158
56
  menuItems: () => [],
159
57
  });
160
58
 
161
- const { user, signOut } = useUser();
162
- const router = useRouter();
163
- const { t } = useI18n({ useScope: "global" });
164
-
165
- const { open } = usePopup({
166
- component: ChangePassword,
167
- });
168
- const { closeBlade } = useBladeNavigation();
169
-
170
- const defaultMenuItems = ref([
171
- {
172
- title: computed(() => t("SHELL.ACCOUNT.CHANGE_PASSWORD")),
173
- icon: "fas fa-key",
174
- clickHandler() {
175
- open();
176
- },
177
- },
178
- {
179
- title: computed(() => t("SHELL.ACCOUNT.LOGOUT")),
180
- icon: "fas fa-sign-out-alt",
181
- async clickHandler() {
182
- const isPrevented = await closeBlade(0);
183
-
184
- if (!isPrevented) {
185
- await signOut();
186
- router.push({ name: "Login" });
187
- }
188
- },
189
- },
190
- ]);
59
+ const isSidebarOpened = ref(false);
60
+ const { profileMenu, defaultMenuItems, settingsButton } = useUserActions();
191
61
 
192
62
  const menu = computed(() => {
193
63
  const defaultItems = handleDefaultMenuItems();
194
-
195
64
  if (defaultItems?.length) {
196
65
  return [...props.menuItems, ...defaultItems];
197
66
  }
@@ -205,20 +74,27 @@ function handleDefaultMenuItems() {
205
74
  return defaultMenuItems.value;
206
75
  }
207
76
 
208
- function beforeOpen() {
209
- return !props.disabled && menu.value?.length > 0;
77
+ function handleActionClick(item: IMenuItem) {
78
+ if (_.isEqual(item, settingsButton.value)) {
79
+ isSidebarOpened.value = true;
80
+ return;
81
+ }
82
+ item.clickHandler?.();
210
83
  }
211
84
 
212
- const imageHandler = computed(() => {
213
- if (props.avatarUrl) {
214
- return `background-image: url(${CSS.escape(props.avatarUrl)})`;
215
- }
216
- return undefined;
217
- });
85
+ function handleMenuItemClick(item: IMenuItem) {
86
+ item.clickHandler?.();
87
+ }
218
88
  </script>
219
89
 
220
90
  <style lang="scss">
221
91
  :root {
92
+ --user-dropdown-height: 54px;
93
+ --user-dropdown-button-bg: var(--primary-500);
94
+ --user-dropdown-button-bg-hover: var(--primary-700);
95
+ --user-dropdown-button-bg-logout: var(--danger-500);
96
+ --user-dropdown-button-bg-logout-hover: var(--danger-700);
97
+ --user-dropdown-button-icon-color: var(--additional-50);
222
98
  --user-dropdown-account-info-name-color: var(--base-text-color, var(--neutrals-950));
223
99
  --user-dropdown-account-info-role-color: var(--secondary-600);
224
100
  --user-dropdown-divider-color: var(--base-border-color, var(--neutrals-200));
@@ -226,17 +102,23 @@ const imageHandler = computed(() => {
226
102
  --user-dropdown-button-color: var(--primary-500);
227
103
  --user-dropdown-button-color-hover: var(--primary-700);
228
104
  --user-dropdown-menu-item-bg-hover: var(--primary-50);
229
- --user-dropdown-menu-item-bg: var(--additional-50);
105
+ --user-dropdown-menu-item-bg: transparent;
230
106
  --user-dropdown-menu-text-color: var(--additional-950);
231
107
  --user-dropdown-chevron-color: var(--secondary-600);
232
108
  --user-dropdown-chevron-color-hover: var(--secondary-700);
233
- --user-dropdown-wrap-bg: var(--additional-50);
109
+ --user-dropdown-wrap-bg: var(--neutrals-50);
234
110
  --user-dropdown-button-width: var(--app-bar-button-width);
111
+ --user-dropdown-border-color: var(--neutrals-200);
235
112
  }
236
113
 
237
114
  .vc-user-dropdown-button {
238
- @apply tw-border-l tw-border-solid tw-border-l-[color:var(--user-dropdown-border-color)] tw-cursor-pointer
239
- tw-relative tw-flex tw-h-full tw-flex-col tw-select-none;
115
+ @apply tw-relative tw-flex tw-h-[var(--user-dropdown-height)] tw-flex-col tw-select-none tw-overflow-hidden tw-border-solid tw-border-t tw-border-t-[var(--user-dropdown-border-color)];
116
+
117
+ &:hover {
118
+ .vc-user-actions__buttons {
119
+ @apply tw-translate-x-0;
120
+ }
121
+ }
240
122
 
241
123
  .vc-app_mobile & {
242
124
  @apply tw-w-full #{!important};
@@ -250,92 +132,8 @@ const imageHandler = computed(() => {
250
132
  @apply tw-w-auto;
251
133
  }
252
134
 
253
- &__button {
254
- @apply tw-w-[var(--user-dropdown-button-width)] tw-h-full tw-flex tw-items-center tw-justify-center tw-relative;
255
- }
256
-
257
135
  &__wrap {
258
- @apply tw-flex tw-justify-between tw-items-center tw-flex-auto tw-px-4 tw-bg-[--user-dropdown-wrap-bg] tw-gap-3;
259
- }
260
-
261
- &__header {
262
- @apply tw-flex tw-justify-between tw-items-center tw-px-3 tw-py-3 tw-bg-[--user-dropdown-wrap-bg] tw-gap-3 tw-truncate;
263
- }
264
-
265
- &__header-wrap {
266
- @apply tw-flex tw-justify-between tw-items-center;
267
- }
268
-
269
- &__avatar {
270
- @apply tw-rounded-full tw-overflow-hidden tw-w-[34px] tw-h-[34px] tw-bg-[color:var(--user-dropdown-account-info-role-color)]
271
- tw-bg-cover tw-bg-center tw-shrink-0;
272
- }
273
-
274
- &__icon {
275
- @apply tw-text-[color:var(--user-dropdown-button-color)];
276
- }
277
-
278
- &__info {
279
- @apply tw-grow tw-basis-0 tw-overflow-hidden;
280
- }
281
-
282
- &__name {
283
- @apply tw-text-sm tw-text-[color:var(--user-dropdown-account-info-name-color)] tw-max-w-[250px] tw-truncate;
284
- }
285
-
286
- &__role {
287
- @apply tw-text-sm tw-text-[color:var(--user-dropdown-account-info-role-color)];
288
- }
289
-
290
- &__chevron {
291
- @apply tw-text-[color:var(--user-dropdown-chevron-color)] tw-transition-colors tw-duration-200;
292
- }
293
-
294
- &:hover &__chevron {
295
- @apply tw-text-[color:var(--user-dropdown-chevron-color-hover)];
296
- }
297
-
298
- &--active &__chevron {
299
- @apply -tw-scale-y-100;
300
- }
301
-
302
- &__menu {
303
- @apply tw-w-full;
304
-
305
- &-item {
306
- @apply tw-p-3 tw-text-sm tw-text-[color:var(--user-dropdown-menu-text-color)] tw-border-solid tw-border-b tw-border-b-[color:var(--user-dropdown-divider-color)] tw-bg-[color:var(--user-dropdown-menu-item-bg)] tw-flex tw-flex-row tw-items-center tw-cursor-pointer;
307
- transition: background-color 0.2s;
308
-
309
- &:hover {
310
- @apply tw-bg-[color:var(--user-dropdown-menu-item-bg-hover)];
311
-
312
- .vc-user-dropdown-button__menu-icon {
313
- @apply tw-text-[color:var(--user-dropdown-button-color-hover)];
314
- }
315
- }
316
-
317
- &:last-of-type {
318
- @apply tw-border-b-0;
319
- }
320
- }
321
- }
322
-
323
- &__menu-icon {
324
- @apply tw-mr-3 tw-text-[color:var(--user-dropdown-button-color)];
325
- }
326
-
327
- .vc-app_mobile & {
328
- &__menu {
329
- @apply tw-static tw-shadow-none #{!important};
330
- }
331
-
332
- &__menu-item {
333
- @apply tw-border-none #{!important};
334
- }
335
-
336
- &__wrap--active {
337
- @apply tw-shadow-none;
338
- }
136
+ @apply tw-flex tw-justify-between tw-items-center tw-flex-auto tw-pl-5 tw-bg-[--user-dropdown-wrap-bg] tw-gap-3;
339
137
  }
340
138
  }
341
139
  </style>
@@ -10,7 +10,7 @@ export default {
10
10
  prefix: "tw-",
11
11
  theme: {
12
12
  fontFamily: {
13
- roboto: ["Roboto", "sans-serif"],
13
+ jakarta: ["Plus Jakarta Sans", "sans-serif"],
14
14
  },
15
15
  fontSize: {
16
16
  xxs: [