@vc-shell/framework 1.2.4-beta.4 → 1.2.4-beta.6
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.
- package/core/composables/index.ts +3 -0
- package/core/composables/useAssets/index.ts +1 -1
- package/core/composables/useAsync/index.test.ts +137 -0
- package/core/composables/useAsync/index.ts +55 -1
- package/core/composables/useBladeRegistry/index.ts +1 -1
- package/core/composables/useBreadcrumbs/index.ts +1 -1
- package/core/composables/useConnectionStatus/index.ts +48 -0
- package/core/composables/useDynamicProperties/index.ts +29 -5
- package/core/composables/useKeyboardNavigation/index.ts +5 -0
- package/core/composables/useMenuService/index.ts +2 -1
- package/core/composables/useSidebarState/index.ts +1 -1
- package/core/composables/useUser/index.ts +30 -4
- package/core/composables/useUser/useUser.test.ts +155 -0
- package/core/composables/useUserManagement/index.ts +1 -1
- package/core/composables/useWebVitals/index.ts +40 -0
- package/core/interceptors/index.ts +72 -15
- package/core/plugins/ai-agent/components/_internal/VcAiAgentHeader.vue +1 -1
- package/core/plugins/ai-agent/components/_internal/VcAiAgentIframe.vue +1 -1
- package/core/plugins/global-error-handler/index.ts +81 -0
- package/core/plugins/index.ts +0 -1
- package/core/plugins/modularity/index.ts +3 -2
- package/core/plugins/modularity/loader.ts +22 -2
- package/core/plugins/permissions/index.ts +1 -1
- package/core/plugins/signalR/index.ts +19 -0
- package/core/services/app-bar-mobile-buttons-service.ts +1 -0
- package/core/services/menu-service.test.ts +193 -0
- package/core/services/menu-service.ts +140 -191
- package/core/services/toolbar-service.ts +1 -1
- package/core/services/widget-service.ts +1 -1
- package/core/types/index.ts +3 -3
- package/core/utilities/date/convertMomentFormat.test.ts +60 -0
- package/core/utilities/date/convertMomentFormat.ts +30 -0
- package/core/utilities/date/formatDate.test.ts +60 -0
- package/core/utilities/date/formatDate.ts +31 -0
- package/core/utilities/date/index.ts +3 -0
- package/core/utilities/date/resolveLocale.test.ts +44 -0
- package/core/utilities/date/resolveLocale.ts +41 -0
- package/core/utilities/index.ts +5 -0
- package/core/utilities/pendingErrorNotifications.ts +64 -0
- package/dist/DashboardBarChart-BzfKkUke.js +123 -0
- package/dist/DashboardDonutChart-CWfe85Xq.js +89 -0
- package/dist/DashboardLineChart-kdA8VnrR.js +125 -0
- package/dist/GridstackDashboard-CGHYkReX.js +131 -0
- package/dist/GridstackDashboard.css +1 -0
- package/dist/chart-utils-BTs6UFaZ.js +83 -0
- package/dist/core/composables/index.d.ts +1 -0
- package/dist/core/composables/index.d.ts.map +1 -1
- package/dist/core/composables/useAssets/index.d.ts +1 -1
- package/dist/core/composables/useAssets/index.d.ts.map +1 -1
- package/dist/core/composables/useAsync/index.d.ts +18 -1
- package/dist/core/composables/useAsync/index.d.ts.map +1 -1
- package/dist/core/composables/useAsync/index.test.d.ts +2 -0
- package/dist/core/composables/useAsync/index.test.d.ts.map +1 -0
- package/dist/core/composables/useBladeRegistry/index.d.ts +1 -1
- package/dist/core/composables/useBladeRegistry/index.d.ts.map +1 -1
- package/dist/core/composables/useBreadcrumbs/index.d.ts +1 -1
- package/dist/core/composables/useBreadcrumbs/index.d.ts.map +1 -1
- package/dist/core/composables/useConnectionStatus/index.d.ts +7 -0
- package/dist/core/composables/useConnectionStatus/index.d.ts.map +1 -0
- package/dist/core/composables/useDynamicProperties/index.d.ts.map +1 -1
- package/dist/core/composables/useKeyboardNavigation/index.d.ts.map +1 -1
- package/dist/core/composables/useMenuService/index.d.ts +2 -2
- package/dist/core/composables/useMenuService/index.d.ts.map +1 -1
- package/dist/core/composables/useUser/index.d.ts +1 -1
- package/dist/core/composables/useUser/index.d.ts.map +1 -1
- package/dist/core/composables/useUser/useUser.test.d.ts +2 -0
- package/dist/core/composables/useUser/useUser.test.d.ts.map +1 -0
- package/dist/core/composables/useUserManagement/index.d.ts +1 -1
- package/dist/core/composables/useUserManagement/index.d.ts.map +1 -1
- package/dist/core/composables/useWebVitals/index.d.ts +14 -0
- package/dist/core/composables/useWebVitals/index.d.ts.map +1 -0
- package/dist/core/interceptors/index.d.ts.map +1 -1
- package/dist/core/plugins/global-error-handler/index.d.ts +3 -0
- package/dist/core/plugins/global-error-handler/index.d.ts.map +1 -0
- package/dist/core/plugins/index.d.ts +0 -1
- package/dist/core/plugins/index.d.ts.map +1 -1
- package/dist/core/plugins/modularity/index.d.ts +1 -1
- package/dist/core/plugins/modularity/index.d.ts.map +1 -1
- package/dist/core/plugins/modularity/loader.d.ts.map +1 -1
- package/dist/core/plugins/signalR/index.d.ts +1 -0
- package/dist/core/plugins/signalR/index.d.ts.map +1 -1
- package/dist/core/services/app-bar-mobile-buttons-service.d.ts +1 -0
- package/dist/core/services/app-bar-mobile-buttons-service.d.ts.map +1 -1
- package/dist/core/services/menu-service.d.ts +8 -0
- package/dist/core/services/menu-service.d.ts.map +1 -1
- package/dist/core/services/toolbar-service.d.ts +1 -1
- package/dist/core/services/toolbar-service.d.ts.map +1 -1
- package/dist/core/services/widget-service.d.ts +1 -1
- package/dist/core/services/widget-service.d.ts.map +1 -1
- package/dist/core/types/index.d.ts +3 -3
- package/dist/core/types/index.d.ts.map +1 -1
- package/dist/core/utilities/date/convertMomentFormat.d.ts +2 -0
- package/dist/core/utilities/date/convertMomentFormat.d.ts.map +1 -0
- package/dist/core/utilities/date/convertMomentFormat.test.d.ts +2 -0
- package/dist/core/utilities/date/convertMomentFormat.test.d.ts.map +1 -0
- package/dist/core/utilities/date/formatDate.d.ts +5 -0
- package/dist/core/utilities/date/formatDate.d.ts.map +1 -0
- package/dist/core/utilities/date/formatDate.test.d.ts +2 -0
- package/dist/core/utilities/date/formatDate.test.d.ts.map +1 -0
- package/dist/core/utilities/date/index.d.ts +4 -0
- package/dist/core/utilities/date/index.d.ts.map +1 -0
- package/dist/core/utilities/date/resolveLocale.d.ts +4 -0
- package/dist/core/utilities/date/resolveLocale.d.ts.map +1 -0
- package/dist/core/utilities/date/resolveLocale.test.d.ts +2 -0
- package/dist/core/utilities/date/resolveLocale.test.d.ts.map +1 -0
- package/dist/core/utilities/index.d.ts +2 -0
- package/dist/core/utilities/index.d.ts.map +1 -1
- package/dist/core/utilities/pendingErrorNotifications.d.ts +23 -0
- package/dist/core/utilities/pendingErrorNotifications.d.ts.map +1 -0
- package/dist/framework.js +462 -33786
- package/dist/index-tgmgQAD9.js +33730 -0
- package/dist/index.css +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/injection-keys.d.ts +13 -4
- package/dist/injection-keys.d.ts.map +1 -1
- package/dist/locales/de.json +12 -2
- package/dist/locales/en.json +12 -2
- package/dist/shared/components/blade-navigation/components/vc-blade-navigation/_internal/vc-mobile-back-button.vue.d.ts.map +1 -1
- package/dist/shared/components/blade-navigation/components/vc-blade-slot/vc-blade-slot.vue.d.ts.map +1 -1
- package/dist/shared/components/blade-navigation/types/index.d.ts +4 -4
- package/dist/shared/components/blade-navigation/types/index.d.ts.map +1 -1
- package/dist/shared/components/change-password/change-password.vue.d.ts.map +1 -1
- package/dist/shared/components/common/popup/vc-popup-base.vue.d.ts +50 -0
- package/dist/shared/components/common/popup/vc-popup-base.vue.d.ts.map +1 -0
- package/dist/shared/components/common/popup/vc-popup-error.vue.d.ts.map +1 -1
- package/dist/shared/components/common/popup/vc-popup-info.vue.d.ts.map +1 -1
- package/dist/shared/components/common/popup/vc-popup-warning.vue.d.ts.map +1 -1
- package/dist/shared/components/dashboard-charts/index.d.ts +6 -3
- package/dist/shared/components/dashboard-charts/index.d.ts.map +1 -1
- package/dist/shared/components/draggable-dashboard/DraggableDashboard.vue.d.ts.map +1 -1
- package/dist/shared/components/error-interceptor/interceptor.d.ts +1 -1
- package/dist/shared/components/error-interceptor/interceptor.d.ts.map +1 -1
- package/dist/shared/components/generic-dropdown/index.d.ts.map +1 -1
- package/dist/shared/components/multilanguage-selector/multilanguage-selector.vue.d.ts +1 -1
- package/dist/shared/components/multilanguage-selector/multilanguage-selector.vue.d.ts.map +1 -1
- package/dist/shared/components/notification-dropdown/notification-dropdown.vue.d.ts.map +1 -1
- package/dist/shared/components/notifications/components/notification-container/index.d.ts +6 -17
- package/dist/shared/components/notifications/components/notification-container/index.d.ts.map +1 -1
- package/dist/shared/components/notifications/composables/useContainer/index.d.ts +0 -9
- package/dist/shared/components/notifications/composables/useContainer/index.d.ts.map +1 -1
- package/dist/shared/components/notifications/core/notification.d.ts +0 -1
- package/dist/shared/components/notifications/core/notification.d.ts.map +1 -1
- package/dist/shared/components/notifications/types/index.d.ts +2 -2
- package/dist/shared/components/notifications/types/index.d.ts.map +1 -1
- package/dist/shared/components/popup-handler/composables/usePopup/index.d.ts +1 -1
- package/dist/shared/components/popup-handler/composables/usePopup/index.d.ts.map +1 -1
- package/dist/shared/components/settings-menu-item/settings-menu-item.vue.d.ts.map +1 -1
- package/dist/shared/components/sign-in/external-provider.vue.d.ts.map +1 -1
- package/dist/shared/components/user-dropdown-button/_internal/user-info.vue.d.ts.map +1 -1
- package/dist/shared/components/user-dropdown-button/_internal/user-sidebar.vue.d.ts +2 -2
- package/dist/shared/composables/useModificationTracker/index.d.ts.map +1 -1
- package/dist/shared/modules/assets/components/assets-details/assets-details.vue.d.ts +1 -1
- package/dist/shared/modules/assets/components/assets-details/assets-details.vue.d.ts.map +1 -1
- package/dist/shared/modules/assets-manager/components/assets-manager/assets-manager.vue.d.ts +2 -2
- package/dist/shared/modules/assets-manager/components/assets-manager/assets-manager.vue.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/components/SchemaRender.d.ts +12 -12
- package/dist/shared/modules/dynamic/components/factories.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/components/fields/Fieldset.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/components/fields/GalleryField.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/components/fields/RadioButtonGroup.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/composables/useFilterBuilder/index.d.ts +1 -1
- package/dist/shared/modules/dynamic/composables/useFilterBuilder/index.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/composables/useToolbarReducer/index.d.ts +1 -1
- package/dist/shared/modules/dynamic/composables/useToolbarReducer/index.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/factories/base/useDetailsFactory.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/factories/base/useListFactory.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/factories/types/index.d.ts +4 -3
- package/dist/shared/modules/dynamic/factories/types/index.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/index.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/pages/dynamic-blade-form.vue.d.ts +10 -10
- package/dist/shared/modules/dynamic/pages/dynamic-blade-form.vue.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/pages/dynamic-blade-list.vue.d.ts +11 -11
- package/dist/shared/modules/dynamic/pages/dynamic-blade-list.vue.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/types/index.d.ts +12 -2
- package/dist/shared/modules/dynamic/types/index.d.ts.map +1 -1
- package/dist/shared/modules/dynamic/types/models.d.ts +19 -1
- package/dist/shared/modules/dynamic/types/models.d.ts.map +1 -1
- package/dist/shared/pages/LoginPage/components/login/Login.vue.d.ts +1 -0
- package/dist/shared/pages/LoginPage/components/login/Login.vue.d.ts.map +1 -1
- package/dist/shared/pages/_storybook-helpers.d.ts +11 -0
- package/dist/shared/pages/_storybook-helpers.d.ts.map +1 -0
- package/dist/tailwind.config.d.ts.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/ui/components/atoms/vc-badge/vc-badge.vue.d.ts +2 -2
- package/dist/ui/components/atoms/vc-badge/vc-badge.vue.d.ts.map +1 -1
- package/dist/ui/components/atoms/vc-banner/vc-banner.vue.d.ts +19 -5
- package/dist/ui/components/atoms/vc-banner/vc-banner.vue.d.ts.map +1 -1
- package/dist/ui/components/atoms/vc-button/vc-button.a11y.test.d.ts +2 -0
- package/dist/ui/components/atoms/vc-button/vc-button.a11y.test.d.ts.map +1 -0
- package/dist/ui/components/atoms/vc-button/vc-button.test.d.ts +2 -0
- package/dist/ui/components/atoms/vc-button/vc-button.test.d.ts.map +1 -0
- package/dist/ui/components/atoms/vc-button/vc-button.vue.d.ts +1 -1
- package/dist/ui/components/atoms/vc-button/vc-button.vue.d.ts.map +1 -1
- package/dist/ui/components/atoms/vc-icon/vc-material-icon.vue.d.ts +1 -1
- package/dist/ui/components/atoms/vc-icon/vc-material-icon.vue.d.ts.map +1 -1
- package/dist/ui/components/atoms/vc-label/vc-label.vue.d.ts.map +1 -1
- package/dist/ui/components/atoms/vc-loading/vc-loading.vue.d.ts.map +1 -1
- package/dist/ui/components/atoms/vc-progress/vc-progress.vue.d.ts +1 -1
- package/dist/ui/components/atoms/vc-progress/vc-progress.vue.d.ts.map +1 -1
- package/dist/ui/components/atoms/vc-skeleton/vc-skeleton.vue.d.ts +8 -0
- package/dist/ui/components/atoms/vc-skeleton/vc-skeleton.vue.d.ts.map +1 -1
- package/dist/ui/components/atoms/vc-tooltip/vc-tooltip.vue.d.ts +2 -2
- package/dist/ui/components/atoms/vc-tooltip/vc-tooltip.vue.d.ts.map +1 -1
- package/dist/ui/components/atoms/vc-video/vc-video.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/index.d.ts +0 -1
- package/dist/ui/components/molecules/index.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-accordion/_internal/vc-accordion-item/vc-accordion-item.vue.d.ts +1 -1
- package/dist/ui/components/molecules/vc-accordion/_internal/vc-accordion-item/vc-accordion-item.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-breadcrumbs/_internal/vc-breadcrumbs-item/vc-breadcrumbs-item.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-checkbox/vc-checkbox.a11y.test.d.ts +2 -0
- package/dist/ui/components/molecules/vc-checkbox/vc-checkbox.a11y.test.d.ts.map +1 -0
- package/dist/ui/components/molecules/vc-checkbox/vc-checkbox.test.d.ts +2 -0
- package/dist/ui/components/molecules/vc-checkbox/vc-checkbox.test.d.ts.map +1 -0
- package/dist/ui/components/molecules/vc-checkbox/vc-checkbox.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-checkbox-group/vc-checkbox-group.vue.d.ts +1 -1
- package/dist/ui/components/molecules/vc-checkbox-group/vc-checkbox-group.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-color-input/vc-color-input.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-date-picker/vc-date-picker.vue.d.ts +1 -1
- package/dist/ui/components/molecules/vc-date-picker/vc-date-picker.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-dropdown/_internal/VcDropdownItem.vue.d.ts +1 -1
- package/dist/ui/components/molecules/vc-dropdown/_internal/VcDropdownItem.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-dropdown/vc-dropdown.vue.d.ts +1 -1
- package/dist/ui/components/molecules/vc-dropdown/vc-dropdown.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-dropdown-panel/vc-dropdown-panel.vue.d.ts +3 -3
- package/dist/ui/components/molecules/vc-dropdown-panel/vc-dropdown-panel.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-editor/_internal/vc-editor-button.vue.d.ts +11 -41
- package/dist/ui/components/molecules/vc-editor/_internal/vc-editor-button.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-editor/index.d.ts +3 -2
- package/dist/ui/components/molecules/vc-editor/index.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-editor/vc-editor.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-field/vc-field.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-file-upload/vc-file-upload.vue.d.ts +2 -4
- package/dist/ui/components/molecules/vc-file-upload/vc-file-upload.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-input/vc-input.a11y.test.d.ts +2 -0
- package/dist/ui/components/molecules/vc-input/vc-input.a11y.test.d.ts.map +1 -0
- package/dist/ui/components/molecules/vc-input/vc-input.test.d.ts +2 -0
- package/dist/ui/components/molecules/vc-input/vc-input.test.d.ts.map +1 -0
- package/dist/ui/components/molecules/vc-input/vc-input.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-input-currency/vc-input-currency.vue.d.ts +18 -87
- package/dist/ui/components/molecules/vc-input-currency/vc-input-currency.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-input-dropdown/index.d.ts +0 -1
- package/dist/ui/components/molecules/vc-input-dropdown/index.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-input-dropdown/vc-input-dropdown.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-input-group/vc-input-group.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-multivalue/_internal/MultivalueDropdown.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-multivalue/_internal/MultivalueTrigger.vue.d.ts +1 -0
- package/dist/ui/components/molecules/vc-multivalue/_internal/MultivalueTrigger.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-multivalue/composables/useMultivalueDropdown.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-multivalue/vc-multivalue.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-radio-button/vc-radio-button.vue.d.ts +2 -3
- package/dist/ui/components/molecules/vc-radio-button/vc-radio-button.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-radio-group/vc-radio-group.vue.d.ts +1 -1
- package/dist/ui/components/molecules/vc-radio-group/vc-radio-group.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-rating/vc-rating.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-select/_internal/SelectDropdown.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-select/_internal/SelectTrigger.vue.d.ts +1 -0
- package/dist/ui/components/molecules/vc-select/_internal/SelectTrigger.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-select/vc-select.test.d.ts +2 -0
- package/dist/ui/components/molecules/vc-select/vc-select.test.d.ts.map +1 -0
- package/dist/ui/components/molecules/vc-select/vc-select.vue.d.ts +0 -5
- package/dist/ui/components/molecules/vc-select/vc-select.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-slider/index.d.ts +5 -3
- package/dist/ui/components/molecules/vc-slider/index.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-switch/vc-switch.vue.d.ts +2 -3
- package/dist/ui/components/molecules/vc-switch/vc-switch.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-textarea/vc-textarea.a11y.test.d.ts +2 -0
- package/dist/ui/components/molecules/vc-textarea/vc-textarea.a11y.test.d.ts.map +1 -0
- package/dist/ui/components/molecules/vc-textarea/vc-textarea.vue.d.ts.map +1 -1
- package/dist/ui/components/molecules/vc-toast/vc-toast.vue.d.ts +7 -0
- package/dist/ui/components/molecules/vc-toast/vc-toast.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/index.d.ts +1 -0
- package/dist/ui/components/organisms/index.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/app-bar/components/AppBarMobileActions.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/app-bar/components/AppBarOverlay.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/app-bar/components/AppHubContent.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/app-bar/components/MenuSidebar.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/app-bar/composables/useAppHub.d.ts +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/app-bar/composables/useAppHub.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/layouts/DesktopLayout.vue.d.ts +3 -3
- package/dist/ui/components/organisms/vc-app/_internal/layouts/DesktopLayout.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/layouts/MobileLayout.test.d.ts +2 -0
- package/dist/ui/components/organisms/vc-app/_internal/layouts/MobileLayout.test.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-app/_internal/layouts/MobileLayout.vue.d.ts +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/layouts/MobileLayout.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/menu/VcAppMenu.test.d.ts +2 -0
- package/dist/ui/components/organisms/vc-app/_internal/menu/VcAppMenu.test.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-app/_internal/menu/VcAppMenu.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/menu/VcAppMenuItem.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/_internal/sidebar/SidebarHeader.vue.d.ts +9 -3
- package/dist/ui/components/organisms/vc-app/_internal/sidebar/SidebarHeader.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/composables/useShellBootstrap.d.ts +1 -1
- package/dist/ui/components/organisms/vc-app/composables/useShellBootstrap.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-app/vc-app.vue.d.ts.map +1 -1
- package/dist/ui/components/{atoms/vc-icon/vc-icon-test.vue.d.ts → organisms/vc-blade/_internal/BladeContentSkeleton.vue.d.ts} +1 -1
- package/dist/ui/components/organisms/vc-blade/_internal/BladeContentSkeleton.vue.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-blade/_internal/BladeHeader.vue.d.ts.map +1 -1
- package/dist/ui/components/{atoms/vc-icon/vc-icon-examples.vue.d.ts → organisms/vc-blade/_internal/BladeHeaderSkeleton.vue.d.ts} +1 -1
- package/dist/ui/components/organisms/vc-blade/_internal/BladeHeaderSkeleton.vue.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-blade/_internal/BladeStatusBanners.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-blade/_internal/BladeToolbarSkeleton.vue.d.ts +3 -0
- package/dist/ui/components/organisms/vc-blade/_internal/BladeToolbarSkeleton.vue.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-blade/_internal/composables/useBladeError.d.ts +4 -5
- package/dist/ui/components/organisms/vc-blade/_internal/composables/useBladeError.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-blade/_internal/composables/useToolbarRegistration.d.ts +1 -1
- package/dist/ui/components/organisms/vc-blade/_internal/composables/useToolbarRegistration.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-blade/_internal/toolbar/ToolbarBaseButton.vue.d.ts +1 -1
- package/dist/ui/components/organisms/vc-blade/_internal/toolbar/ToolbarMobile.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-blade/_internal/widgets/WidgetContainerDesktop.vue.d.ts +1 -1
- package/dist/ui/components/organisms/vc-blade/_internal/widgets/WidgetContainerDesktop.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-blade/_internal/widgets/WidgetContainerMobile.vue.d.ts +1 -1
- package/dist/ui/components/organisms/vc-blade/_internal/widgets/WidgetContainerMobile.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-blade/vc-blade.vue.d.ts +3 -1
- package/dist/ui/components/organisms/vc-blade/vc-blade.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-dynamic-property/vc-dynamic-property.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.test.d.ts +2 -0
- package/dist/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.test.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.vue.d.ts +15 -18
- package/dist/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-gallery/_internal/vc-gallery-preview/vc-gallery-preview.vue.d.ts +1 -1
- package/dist/ui/components/organisms/vc-gallery/_internal/vc-gallery-preview/vc-gallery-preview.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-gallery/composables/index.d.ts +5 -0
- package/dist/ui/components/organisms/vc-gallery/composables/index.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useGalleryPreview.d.ts +6 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useGalleryPreview.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useGalleryReorder.d.ts +23 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useGalleryReorder.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useGalleryReorder.test.d.ts +2 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useGalleryReorder.test.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useGalleryUpload.d.ts +10 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useGalleryUpload.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useGalleryUpload.test.d.ts +2 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useGalleryUpload.test.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useImageLoad.d.ts +8 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useImageLoad.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useImageLoad.test.d.ts +2 -0
- package/dist/ui/components/organisms/vc-gallery/composables/useImageLoad.test.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-gallery/index.d.ts +2 -0
- package/dist/ui/components/organisms/vc-gallery/index.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-gallery/vc-gallery.actions.test.d.ts +2 -0
- package/dist/ui/components/organisms/vc-gallery/vc-gallery.actions.test.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-gallery/vc-gallery.vue.d.ts +77 -16
- package/dist/ui/components/organisms/vc-gallery/vc-gallery.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-image-upload/index.d.ts +2 -0
- package/dist/ui/components/organisms/vc-image-upload/index.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-image-upload/vc-image-upload.vue.d.ts +35 -0
- package/dist/ui/components/organisms/vc-image-upload/vc-image-upload.vue.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-popup/vc-popup.vue.d.ts +14 -4
- package/dist/ui/components/organisms/vc-popup/vc-popup.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-sidebar/vc-sidebar.vue.d.ts +2 -2
- package/dist/ui/components/organisms/vc-sidebar/vc-sidebar.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/VcDataTable.vue.d.ts +223 -45
- package/dist/ui/components/organisms/vc-table/VcDataTable.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/VcTableAdapter.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/_internal/vc-table-cell/vc-table-cell.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/_internal/vc-table-counter/vc-table-counter.vue.d.ts +1 -1
- package/dist/ui/components/organisms/vc-table/_internal/vc-table-counter/vc-table-counter.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/base/BaseVcDataTable.d.ts +9 -1
- package/dist/ui/components/organisms/vc-table/base/BaseVcDataTable.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/ColumnFilter.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/DataTableBody.vue.d.ts +26 -9
- package/dist/ui/components/organisms/vc-table/components/DataTableBody.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/DataTableRow.vue.d.ts +3 -1
- package/dist/ui/components/organisms/vc-table/components/DataTableRow.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/GlobalFiltersPanel.vue.d.ts +7 -2
- package/dist/ui/components/organisms/vc-table/components/GlobalFiltersPanel.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/TableAddRowButton.vue.d.ts +1 -1
- package/dist/ui/components/organisms/vc-table/components/TableAddRowButton.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/TableEmpty.vue.d.ts +7 -9
- package/dist/ui/components/organisms/vc-table/components/TableEmpty.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/TableRow.vue.d.ts +4 -0
- package/dist/ui/components/organisms/vc-table/components/TableRow.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/TableRowActions.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/TableSearchHeader.vue.d.ts +1 -1
- package/dist/ui/components/organisms/vc-table/components/TableSearchHeader.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/VcColumn.vue.d.ts +4 -4
- package/dist/ui/components/organisms/vc-table/components/_internal/TableSkeletonRows.vue.d.ts +17 -0
- package/dist/ui/components/organisms/vc-table/components/_internal/TableSkeletonRows.vue.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-table/components/cells/CellDate.vue.d.ts +1 -1
- package/dist/ui/components/organisms/vc-table/components/cells/CellDate.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/mobile/DataTableMobileCard.vue.d.ts +3 -3
- package/dist/ui/components/organisms/vc-table/components/mobile/DataTableMobileView.vue.d.ts +3 -3
- package/dist/ui/components/organisms/vc-table/composables/useDataProcessing.d.ts +1 -1
- package/dist/ui/components/organisms/vc-table/composables/useDataProcessing.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/composables/useTableEditing.d.ts +1 -1
- package/dist/ui/components/organisms/vc-table/composables/useTableEditing.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/composables/useTableExpansion.d.ts +1 -1
- package/dist/ui/components/organisms/vc-table/composables/useTableExpansion.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/composables/useTableFilter.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/composables/useTableFilter.test.d.ts +2 -0
- package/dist/ui/components/organisms/vc-table/composables/useTableFilter.test.d.ts.map +1 -0
- package/dist/ui/components/organisms/vc-table/composables/useTableRowGrouping.d.ts +1 -1
- package/dist/ui/components/organisms/vc-table/composables/useTableRowGrouping.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/composables/useTableSelectionV2.d.ts +1 -1
- package/dist/ui/components/organisms/vc-table/composables/useTableSelectionV2.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/keys.d.ts +12 -1
- package/dist/ui/components/organisms/vc-table/keys.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/types.d.ts +24 -1
- package/dist/ui/components/organisms/vc-table/types.d.ts.map +1 -1
- package/dist/ui/composables/index.d.ts +1 -0
- package/dist/ui/composables/index.d.ts.map +1 -1
- package/dist/ui/composables/useCollapsible.d.ts +27 -0
- package/dist/ui/composables/useCollapsible.d.ts.map +1 -0
- package/dist/ui/composables/useFormField.d.ts +1 -0
- package/dist/ui/composables/useFormField.d.ts.map +1 -1
- package/dist/ui/types/index.d.ts +1 -1
- package/dist/ui/types/index.d.ts.map +1 -1
- package/dist/vc-editor-BNrG1GAG.js +848 -0
- package/dist/vc-editor.css +1 -0
- package/dist/vc-slider-Ce0X1_1m.js +83 -0
- package/dist/vc-slider.css +1 -0
- package/dist/{vendor-cheerio-BcTJMzyu.js → vendor-cheerio-3JDxU-TZ.js} +6 -6
- package/dist/{vendor-cheerio-select-sLyWsUb6.js → vendor-cheerio-select-B7cQ9HP4.js} +3 -3
- package/dist/{vendor-css-select-DtZUShJh.js → vendor-css-select-CaVL4gMJ.js} +1 -1
- package/dist/{vendor-date-fns-Bbji1B6n.js → vendor-date-fns-BKO3x1R1.js} +856 -762
- package/dist/{vendor-dom-serializer-BbVuF1MQ.js → vendor-dom-serializer-Sk3xHhQk.js} +1 -1
- package/dist/{vendor-domhandler-BVR67j0z.js → vendor-domhandler-Kufn9M_V.js} +2 -2
- package/dist/{vendor-domutils-DhLr70Dk.js → vendor-domutils-o2IJSx7k.js} +2 -2
- package/dist/{vendor-entities-J86Og8IU.js → vendor-entities-CCReaWqU.js} +2 -2
- package/dist/vendor-floating-ui-core-BoHdh92a.js +432 -0
- package/dist/vendor-floating-ui-dom-BvVXFZ4B.js +398 -0
- package/dist/vendor-floating-ui-utils-CidJRIm2.js +257 -0
- package/dist/{vendor-floating-ui-vue--bdH-HF5.js → vendor-floating-ui-vue-sCrhit51.js} +2 -2
- package/dist/{vendor-htmlparser2-DOGAmM6C.js → vendor-htmlparser2-nRkKyNhl.js} +2 -2
- package/dist/{vendor-lodash-es-CzE4FJw2.js → vendor-lodash-es-B5DE282z.js} +14 -16
- package/dist/{vendor-lucide-vue-next-m0L4DzUL.js → vendor-lucide-vue-next-DadL7o0S.js} +8563 -8573
- package/dist/{vendor-markdown-it-DdaObR1P.js → vendor-markdown-it-pxD-Y9qk.js} +13 -10
- package/dist/{vendor-microsoft-applicationinsights-analytics-js-DQheg2jT.js → vendor-microsoft-applicationinsights-analytics-js-DFu_cVaY.js} +5 -5
- package/dist/{vendor-microsoft-applicationinsights-cfgsync-js-B9Mn84BU.js → vendor-microsoft-applicationinsights-cfgsync-js-DRQLN2Ue.js} +6 -6
- package/dist/{vendor-microsoft-applicationinsights-channel-js-BuJeAYY2.js → vendor-microsoft-applicationinsights-channel-js-BIJDcP3D.js} +6 -6
- package/dist/{vendor-microsoft-applicationinsights-common-RIQBFrw5.js → vendor-microsoft-applicationinsights-common-CJjmnDMb.js} +3 -3
- package/dist/{vendor-microsoft-applicationinsights-core-js-KDX0EIdd.js → vendor-microsoft-applicationinsights-core-js-BOc_o46i.js} +4 -4
- package/dist/{vendor-microsoft-applicationinsights-dependencies-js-BZbdJERa.js → vendor-microsoft-applicationinsights-dependencies-js-DDz502id.js} +5 -5
- package/dist/{vendor-microsoft-applicationinsights-properties-js-DWXnzqoT.js → vendor-microsoft-applicationinsights-properties-js-9aDWHwXJ.js} +5 -5
- package/dist/{vendor-microsoft-applicationinsights-shims-DKvw2C8l.js → vendor-microsoft-applicationinsights-shims-Dton8Vqy.js} +1 -1
- package/dist/{vendor-microsoft-applicationinsights-web-CvYf2SnW.js → vendor-microsoft-applicationinsights-web-DTa5YN-h.js} +10 -10
- package/dist/{vendor-microsoft-dynamicproto-js-BqPecdaw.js → vendor-microsoft-dynamicproto-js-89GEKjvR.js} +1 -1
- package/dist/{vendor-nevware21-ts-async-CO9QBh90.js → vendor-nevware21-ts-async-D4qa7g-U.js} +1 -1
- package/dist/{vendor-nevware21-ts-utils-DbCMkHfb.js → vendor-nevware21-ts-utils-DII8jruI.js} +154 -154
- package/dist/{vendor-parse5-htmlparser2-tree-adapter-DBkuDq0i.js → vendor-parse5-htmlparser2-tree-adapter-BUDJ887-.js} +1 -1
- package/dist/{vendor-prosemirror-commands-Bv4ChObl.js → vendor-prosemirror-commands-Dml_M5TN.js} +2 -2
- package/dist/{vendor-prosemirror-dropcursor-kF5UKNFM.js → vendor-prosemirror-dropcursor-BpoETgOQ.js} +2 -2
- package/dist/{vendor-prosemirror-gapcursor-BWPM93Bm.js → vendor-prosemirror-gapcursor-VVbNCx01.js} +3 -3
- package/dist/{vendor-prosemirror-history-CQYKHz3u.js → vendor-prosemirror-history-CZUb2jWK.js} +2 -2
- package/dist/{vendor-prosemirror-keymap-CAfQyvJ7.js → vendor-prosemirror-keymap-D5bacBom.js} +1 -1
- package/dist/{vendor-prosemirror-markdown-BMtperlo.js → vendor-prosemirror-markdown-C-c5VoFH.js} +2 -2
- package/dist/{vendor-prosemirror-schema-list-BNJkECdS.js → vendor-prosemirror-schema-list-BZ-Z46DO.js} +1 -1
- package/dist/{vendor-prosemirror-state-IeimrELV.js → vendor-prosemirror-state-DYjHje5i.js} +1 -1
- package/dist/{vendor-prosemirror-tables-oGHIV2UK.js → vendor-prosemirror-tables-CjY-gm1w.js} +4 -4
- package/dist/{vendor-prosemirror-transform-BUjWd5Tb.js → vendor-prosemirror-transform-6xBwIzbI.js} +4 -4
- package/dist/{vendor-prosemirror-view-CR-PD0KM.js → vendor-prosemirror-view-CzBOGIAq.js} +74 -74
- package/dist/{vendor-tiptap-core-CO_R-tjR.js → vendor-tiptap-core-BNrmxwcD.js} +516 -480
- package/dist/{vendor-tiptap-extension-blockquote-D2qy65Cv.js → vendor-tiptap-extension-blockquote-DBYgJvrA.js} +1 -1
- package/dist/{vendor-tiptap-extension-bold-CvJ9mT2Y.js → vendor-tiptap-extension-bold-BaDsyhkA.js} +1 -1
- package/dist/{vendor-tiptap-extension-code-1VjHBs98.js → vendor-tiptap-extension-code-DmMmyuE8.js} +1 -1
- package/dist/{vendor-tiptap-extension-code-block-BNnP9_pH.js → vendor-tiptap-extension-code-block-Cryhc4vR.js} +2 -2
- package/dist/{vendor-tiptap-extension-document-BajSIg0p.js → vendor-tiptap-extension-document-DTFkPYG-.js} +1 -1
- package/dist/{vendor-tiptap-extension-hard-break-BuNoB9-C.js → vendor-tiptap-extension-hard-break-DLmFSWL4.js} +1 -1
- package/dist/{vendor-tiptap-extension-heading-B392LUT7.js → vendor-tiptap-extension-heading-DlpNyZOc.js} +1 -1
- package/dist/{vendor-tiptap-extension-horizontal-rule-CSUTT0Bp.js → vendor-tiptap-extension-horizontal-rule-CI2nC7l5.js} +2 -2
- package/dist/{vendor-tiptap-extension-image-nFs2jKXm.js → vendor-tiptap-extension-image-g6grWBFQ.js} +1 -1
- package/dist/{vendor-tiptap-extension-italic-0bly_CE-.js → vendor-tiptap-extension-italic-DsMLQC-Z.js} +1 -1
- package/dist/{vendor-tiptap-extension-link-BLDvJ5vV.js → vendor-tiptap-extension-link-CF-euSmX.js} +71 -68
- package/dist/{vendor-tiptap-extension-list-B5MwE2sJ.js → vendor-tiptap-extension-list-DA57LKdr.js} +5 -5
- package/dist/{vendor-tiptap-extension-paragraph-CUsfJ4Fl.js → vendor-tiptap-extension-paragraph-CrvWamNP.js} +1 -1
- package/dist/vendor-tiptap-extension-placeholder-DVCL5REL.js +1 -0
- package/dist/{vendor-tiptap-extension-strike-C01BR5iR.js → vendor-tiptap-extension-strike-caeBdU8d.js} +1 -1
- package/dist/{vendor-tiptap-extension-table-DUnnRxVi.js → vendor-tiptap-extension-table-DBQupXqd.js} +8 -8
- package/dist/vendor-tiptap-extension-table-cell-A6UIxsTF.js +1 -0
- package/dist/vendor-tiptap-extension-table-header-A6UIxsTF.js +1 -0
- package/dist/vendor-tiptap-extension-table-row-A6UIxsTF.js +1 -0
- package/dist/{vendor-tiptap-extension-text-D-4QmCkc.js → vendor-tiptap-extension-text-CYaZSxyC.js} +1 -1
- package/dist/{vendor-tiptap-extension-text-style-DhnW0qQ-.js → vendor-tiptap-extension-text-style-C8Uqg46V.js} +1 -1
- package/dist/{vendor-tiptap-extension-underline-BNolmm6B.js → vendor-tiptap-extension-underline-Ct9ZgKsw.js} +1 -1
- package/dist/{vendor-tiptap-extensions-DLb_szZD.js → vendor-tiptap-extensions-Dg7-f1Pi.js} +89 -83
- package/dist/{vendor-tiptap-markdown-Bw1CDyaN.js → vendor-tiptap-markdown-DDkltz0i.js} +4 -4
- package/dist/vendor-tiptap-pm-BbD2LeB7.js +1 -0
- package/dist/{vendor-tiptap-starter-kit-C8ruVG5b.js → vendor-tiptap-starter-kit-C1nkrZcr.js} +17 -17
- package/dist/{vendor-tiptap-vue-3-BzCAEeCs.js → vendor-tiptap-vue-3-B3dwsJj3.js} +1 -1
- package/dist/{vendor-truncate-html-FnN2i7S3.js → vendor-truncate-html-C77Epb-R.js} +1 -1
- package/dist/{vendor-vue3-application-insights-D3zyAvES.js → vendor-vue3-application-insights-BmJCYUcp.js} +2 -2
- package/dist/{vendor-vuepic-vue-datepicker-BbcXj_x6.js → vendor-vuepic-vue-datepicker-CaZ_qpJp.js} +1 -1
- package/dist/{vendor-vueuse-components-Cz0NKocY.js → vendor-vueuse-components-jqShV_Fz.js} +5 -5
- package/dist/{vendor-vueuse-core-SHmW__tV.js → vendor-vueuse-core-D-DKRsy5.js} +8 -7
- package/dist/{vendor-vueuse-shared-CN4sb53h.js → vendor-vueuse-shared-Ch7WD-uK.js} +7 -7
- package/dist/vendor-web-vitals-vrpLO1bu.js +207 -0
- package/dist/vitest-axe.setup.d.ts +10 -0
- package/dist/vitest-axe.setup.d.ts.map +1 -0
- package/package.json +7 -6
- package/shared/components/app-switcher/components/vc-app-switcher/vc-app-switcher.vue +1 -1
- package/shared/components/app-switcher/composables/useAppSwitcher/index.ts +1 -1
- package/shared/components/blade-navigation/components/vc-blade-navigation/_internal/vc-mobile-back-button.vue +2 -1
- package/shared/components/blade-navigation/components/vc-blade-slot/vc-blade-slot.vue +143 -138
- package/shared/components/blade-navigation/types/index.ts +4 -4
- package/shared/components/change-password/change-password.vue +5 -1
- package/shared/components/change-password-button/change-password-button.stories.ts +1 -1
- package/shared/components/common/popup/vc-popup-base.vue +133 -0
- package/shared/components/common/popup/vc-popup-error.vue +6 -23
- package/shared/components/common/popup/vc-popup-info.vue +6 -23
- package/shared/components/common/popup/vc-popup-warning.vue +9 -25
- package/shared/components/dashboard-charts/index.ts +27 -3
- package/shared/components/dashboard-widget-card/dashboard-widget-card.stories.ts +1 -1
- package/shared/components/draggable-dashboard/DraggableDashboard.vue +8 -2
- package/shared/components/error-interceptor/interceptor.ts +25 -3
- package/shared/components/generic-dropdown/generic-dropdown.vue +1 -1
- package/shared/components/language-selector/language-selector.vue +1 -1
- package/shared/components/multilanguage-selector/multilanguage-selector.stories.ts +3 -3
- package/shared/components/multilanguage-selector/multilanguage-selector.vue +117 -15
- package/shared/components/notification-dropdown/notification-dropdown.vue +2 -1
- package/shared/components/notifications/components/notification-container/index.ts +60 -14
- package/shared/components/notifications/composables/useContainer/index.ts +17 -132
- package/shared/components/notifications/core/notification.ts +3 -55
- package/shared/components/notifications/styles/index.scss +51 -89
- package/shared/components/notifications/types/index.ts +2 -4
- package/shared/components/popup-handler/components/vc-popup-container/vc-popup-container.vue +2 -2
- package/shared/components/popup-handler/composables/usePopup/index.ts +80 -77
- package/shared/components/settings-menu-item/settings-menu-item.stories.ts +2 -1
- package/shared/components/settings-menu-item/settings-menu-item.vue +2 -1
- package/shared/components/sidebar/sidebar.vue +1 -1
- package/shared/components/sign-in/external-provider.vue +2 -1
- package/shared/components/theme-selector/theme-selector.vue +1 -1
- package/shared/components/user-dropdown-button/_internal/user-info.vue +27 -14
- package/shared/components/user-dropdown-button/_internal/user-sidebar.vue +2 -2
- package/shared/components/user-dropdown-button/user-dropdown-button.stories.ts +1 -1
- package/shared/components/user-dropdown-button/user-dropdown-button.vue +2 -2
- package/shared/composables/useExternalWidgets.ts +2 -2
- package/shared/composables/useModificationTracker/index.ts +20 -3
- package/shared/modules/assets/components/assets-details/assets-details.vue +8 -3
- package/shared/modules/assets-manager/components/assets-manager/assets-manager.vue +4 -3
- package/shared/modules/dynamic/components/SchemaRender.ts +1 -1
- package/shared/modules/dynamic/components/factories.ts +242 -244
- package/shared/modules/dynamic/components/fields/Fieldset.ts +66 -65
- package/shared/modules/dynamic/components/fields/GalleryField.ts +3 -2
- package/shared/modules/dynamic/components/fields/MultivalueField.ts +68 -68
- package/shared/modules/dynamic/components/fields/RadioButtonGroup.ts +83 -82
- package/shared/modules/dynamic/components/fields/SelectField.ts +72 -72
- package/shared/modules/dynamic/components/fields/StatusField.ts +110 -110
- package/shared/modules/dynamic/composables/useFilterBuilder/index.ts +6 -2
- package/shared/modules/dynamic/composables/useToolbarReducer/index.ts +1 -1
- package/shared/modules/dynamic/factories/base/useDetailsFactory.ts +2 -1
- package/shared/modules/dynamic/factories/base/useListFactory.ts +2 -1
- package/shared/modules/dynamic/factories/types/index.ts +4 -3
- package/shared/modules/dynamic/helpers/nodeBuilder.ts +1 -1
- package/shared/modules/dynamic/index.ts +2 -1
- package/shared/modules/dynamic/pages/dynamic-blade-form.vue +13 -11
- package/shared/modules/dynamic/pages/dynamic-blade-list.vue +5 -4
- package/shared/modules/dynamic/types/index.ts +13 -15
- package/shared/modules/dynamic/types/models.ts +19 -21
- package/shared/pages/ChangePasswordPage/components/change-password/change-password.stories.ts +44 -0
- package/shared/pages/ForgotPasswordPage/components/forgot-password/ForgotPassword.vue +1 -1
- package/shared/pages/ForgotPasswordPage/components/forgot-password/forgot-password.stories.ts +38 -0
- package/shared/pages/InvitePage/components/invite/invite.stories.ts +64 -0
- package/shared/pages/LoginPage/components/login/Login.vue +93 -75
- package/shared/pages/LoginPage/components/login/login.stories.ts +52 -0
- package/shared/pages/ResetPasswordPage/components/reset-password/reset-password.stories.ts +64 -0
- package/shared/pages/_storybook-helpers.ts +71 -0
- package/tailwind.config.ts +2 -21
- package/ui/components/atoms/vc-banner/vc-banner.stories.ts +259 -0
- package/ui/components/atoms/vc-banner/vc-banner.vue +168 -101
- package/ui/components/atoms/vc-button/vc-button-group.vue +7 -7
- package/ui/components/atoms/vc-button/vc-button.a11y.test.ts +46 -0
- package/ui/components/atoms/vc-button/vc-button.test.ts +75 -0
- package/ui/components/atoms/vc-button/vc-button.vue +33 -17
- package/ui/components/atoms/vc-card/vc-card.stories.ts +3 -1
- package/ui/components/atoms/vc-card/vc-card.vue +3 -3
- package/ui/components/atoms/vc-col/vc-col.stories.ts +1 -1
- package/ui/components/atoms/vc-container/vc-container.vue +4 -4
- package/ui/components/atoms/vc-icon/composables/use-icon.ts +2 -2
- package/ui/components/atoms/vc-icon/vc-icon.stories.ts +0 -20
- package/ui/components/atoms/vc-icon/vc-icon.vue +22 -22
- package/ui/components/atoms/vc-label/vc-label.vue +4 -3
- package/ui/components/atoms/vc-link/vc-link.vue +1 -1
- package/ui/components/atoms/vc-loading/vc-loading.vue +28 -28
- package/ui/components/atoms/vc-row/vc-row.stories.ts +2 -2
- package/ui/components/atoms/vc-row/vc-row.vue +1 -1
- package/ui/components/atoms/vc-scrollable-container/vc-scrollable-container.vue +1 -1
- package/ui/components/atoms/vc-skeleton/vc-skeleton.stories.ts +89 -8
- package/ui/components/atoms/vc-skeleton/vc-skeleton.vue +54 -8
- package/ui/components/atoms/vc-status/vc-status.vue +8 -8
- package/ui/components/atoms/vc-status-icon/vc-status-icon.vue +1 -1
- package/ui/components/atoms/vc-tooltip/vc-tooltip.vue +1 -1
- package/ui/components/atoms/vc-video/vc-video.vue +2 -1
- package/ui/components/atoms/vc-widget/vc-widget.stories.ts +1 -1
- package/ui/components/molecules/index.ts +0 -1
- package/ui/components/molecules/vc-accordion/_internal/vc-accordion-item/vc-accordion-item.vue +12 -43
- package/ui/components/molecules/vc-breadcrumbs/_internal/vc-breadcrumbs-item/vc-breadcrumbs-item.vue +23 -19
- package/ui/components/molecules/vc-checkbox/vc-checkbox.a11y.test.ts +39 -0
- package/ui/components/molecules/vc-checkbox/vc-checkbox.test.ts +75 -0
- package/ui/components/molecules/vc-checkbox/vc-checkbox.vue +47 -34
- package/ui/components/molecules/vc-color-input/vc-color-input.vue +18 -28
- package/ui/components/molecules/vc-date-picker/vc-date-picker.vue +16 -28
- package/ui/components/molecules/vc-dropdown/vc-dropdown.vue +7 -1
- package/ui/components/molecules/vc-dropdown-panel/vc-dropdown-panel.vue +11 -0
- package/ui/components/molecules/vc-editor/_internal/vc-editor-button.vue +13 -19
- package/ui/components/molecules/vc-editor/index.ts +15 -6
- package/ui/components/molecules/vc-editor/vc-editor.vue +12 -14
- package/ui/components/molecules/vc-field/_internal/vc-field-type/vc-field-type.vue +2 -2
- package/ui/components/molecules/vc-field/vc-field.vue +2 -1
- package/ui/components/molecules/vc-file-upload/vc-file-upload.stories.ts +87 -39
- package/ui/components/molecules/vc-file-upload/vc-file-upload.vue +56 -46
- package/ui/components/molecules/vc-input/vc-input.a11y.test.ts +57 -0
- package/ui/components/molecules/vc-input/vc-input.stories.ts +2 -1
- package/ui/components/molecules/vc-input/vc-input.test.ts +114 -0
- package/ui/components/molecules/vc-input/vc-input.vue +36 -58
- package/ui/components/molecules/vc-input-currency/vc-input-currency.vue +18 -87
- package/ui/components/molecules/vc-input-dropdown/index.ts +0 -1
- package/ui/components/molecules/vc-input-dropdown/vc-input-dropdown.vue +2 -1
- package/ui/components/molecules/vc-input-group/vc-input-group.vue +2 -13
- package/ui/components/molecules/vc-multivalue/_internal/MultivalueDropdown.vue +2 -2
- package/ui/components/molecules/vc-multivalue/_internal/MultivalueTrigger.vue +207 -204
- package/ui/components/molecules/vc-multivalue/composables/useMultivalueDropdown.ts +3 -0
- package/ui/components/molecules/vc-multivalue/vc-multivalue.vue +22 -33
- package/ui/components/molecules/vc-pagination/vc-pagination.vue +11 -11
- package/ui/components/molecules/vc-radio-button/vc-radio-button.vue +10 -16
- package/ui/components/molecules/vc-rating/vc-rating.vue +2 -1
- package/ui/components/molecules/vc-select/_internal/SelectDropdown.vue +199 -198
- package/ui/components/molecules/vc-select/_internal/SelectTrigger.vue +301 -290
- package/ui/components/molecules/vc-select/vc-select.test.ts +89 -0
- package/ui/components/molecules/vc-select/vc-select.vue +32 -38
- package/ui/components/molecules/vc-slider/index.ts +21 -13
- package/ui/components/molecules/vc-slider/vc-slider.stories.ts +2 -1
- package/ui/components/molecules/vc-slider/vc-slider.vue +1 -1
- package/ui/components/molecules/vc-switch/vc-switch.vue +19 -15
- package/ui/components/molecules/vc-textarea/vc-textarea.a11y.test.ts +44 -0
- package/ui/components/molecules/vc-textarea/vc-textarea.vue +15 -23
- package/ui/components/molecules/vc-toast/vc-toast.vue +390 -109
- package/ui/components/organisms/index.ts +5 -4
- package/ui/components/organisms/vc-app/_internal/app-bar/components/AppBarMobileActions.vue +44 -28
- package/ui/components/organisms/vc-app/_internal/app-bar/components/AppBarOverlay.vue +1 -1
- package/ui/components/organisms/vc-app/_internal/app-bar/components/AppBarWidgetsMenu.vue +2 -2
- package/ui/components/organisms/vc-app/_internal/app-bar/components/AppHubContent.vue +28 -13
- package/ui/components/organisms/vc-app/_internal/app-bar/components/AppHubPopover.vue +1 -1
- package/ui/components/organisms/vc-app/_internal/app-bar/components/MenuSidebar.vue +5 -32
- package/ui/components/organisms/vc-app/_internal/app-bar/composables/useAppBarWidgets.ts +1 -1
- package/ui/components/organisms/vc-app/_internal/app-bar/composables/useAppHub.ts +7 -3
- package/ui/components/organisms/vc-app/_internal/layouts/DesktopLayout.vue +32 -0
- package/ui/components/organisms/vc-app/_internal/layouts/MobileLayout.test.ts +151 -0
- package/ui/components/organisms/vc-app/_internal/layouts/MobileLayout.vue +442 -38
- package/ui/components/organisms/vc-app/_internal/menu/VcAppMenu.test.ts +43 -0
- package/ui/components/organisms/vc-app/_internal/menu/VcAppMenu.vue +3 -3
- package/ui/components/organisms/vc-app/_internal/menu/VcAppMenuGroup.vue +1 -1
- package/ui/components/organisms/vc-app/_internal/menu/VcAppMenuItem.vue +216 -215
- package/ui/components/organisms/vc-app/_internal/sidebar/SidebarCollapseButton.vue +1 -1
- package/ui/components/organisms/vc-app/_internal/sidebar/SidebarContent.vue +2 -2
- package/ui/components/organisms/vc-app/_internal/sidebar/SidebarHeader.vue +93 -36
- package/ui/components/organisms/vc-app/composables/useShellBootstrap.test.ts +3 -14
- package/ui/components/organisms/vc-app/composables/useShellBootstrap.ts +3 -16
- package/ui/components/organisms/vc-app/composables/useShellLifecycle.ts +1 -1
- package/ui/components/organisms/vc-app/composables/useShellNavigation.ts +1 -1
- package/ui/components/organisms/vc-app/vc-app-shell.stories.ts +12 -4
- package/ui/components/organisms/vc-app/vc-app.vue +23 -6
- package/ui/components/organisms/vc-blade/_internal/BladeContentSkeleton.vue +113 -0
- package/ui/components/organisms/vc-blade/_internal/BladeHeader.vue +2 -2
- package/ui/components/organisms/vc-blade/_internal/BladeHeaderSkeleton.vue +52 -0
- package/ui/components/organisms/vc-blade/_internal/BladeStatusBanners.vue +195 -78
- package/ui/components/organisms/vc-blade/_internal/BladeToolbarSkeleton.vue +34 -0
- package/ui/components/organisms/vc-blade/_internal/composables/useBladeError.ts +13 -33
- package/ui/components/organisms/vc-blade/_internal/composables/useToolbarRegistration.ts +4 -2
- package/ui/components/organisms/vc-blade/_internal/toolbar/ToolbarBaseButton.vue +1 -1
- package/ui/components/organisms/vc-blade/_internal/toolbar/ToolbarDesktop.vue +1 -1
- package/ui/components/organisms/vc-blade/_internal/toolbar/ToolbarMobile.vue +18 -22
- package/ui/components/organisms/vc-blade/_internal/widgets/WidgetContainer.vue +1 -1
- package/ui/components/organisms/vc-blade/_internal/widgets/WidgetContainerDesktop.vue +10 -2
- package/ui/components/organisms/vc-blade/_internal/widgets/WidgetContainerMobile.vue +2 -2
- package/ui/components/organisms/vc-blade/_internal/widgets/WidgetDropdownItem.vue +1 -1
- package/ui/components/organisms/vc-blade/vc-blade.stories.ts +77 -0
- package/ui/components/organisms/vc-blade/vc-blade.vue +92 -56
- package/ui/components/organisms/vc-dynamic-property/vc-dynamic-property.vue +8 -5
- package/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.test.ts +48 -0
- package/ui/components/organisms/vc-gallery/_internal/vc-gallery-item/vc-gallery-item.vue +184 -103
- package/ui/components/organisms/vc-gallery/_internal/vc-gallery-preview/vc-gallery-preview.vue +266 -81
- package/ui/components/organisms/vc-gallery/composables/index.ts +4 -0
- package/ui/components/organisms/vc-gallery/composables/useGalleryPreview.ts +26 -0
- package/ui/components/organisms/vc-gallery/composables/useGalleryReorder.test.ts +73 -0
- package/ui/components/organisms/vc-gallery/composables/useGalleryReorder.ts +183 -0
- package/ui/components/organisms/vc-gallery/composables/useGalleryUpload.test.ts +89 -0
- package/ui/components/organisms/vc-gallery/composables/useGalleryUpload.ts +43 -0
- package/ui/components/organisms/vc-gallery/composables/useImageLoad.test.ts +34 -0
- package/ui/components/organisms/vc-gallery/composables/useImageLoad.ts +26 -0
- package/ui/components/organisms/vc-gallery/index.ts +2 -0
- package/ui/components/organisms/vc-gallery/vc-gallery.actions.test.ts +76 -0
- package/ui/components/organisms/vc-gallery/vc-gallery.stories.ts +76 -68
- package/ui/components/organisms/vc-gallery/vc-gallery.vue +322 -246
- package/ui/components/organisms/vc-image-upload/index.ts +1 -0
- package/ui/components/organisms/vc-image-upload/vc-image-upload.stories.ts +47 -0
- package/ui/components/organisms/vc-image-upload/vc-image-upload.vue +251 -0
- package/ui/components/organisms/vc-popup/vc-popup.stories.ts +106 -0
- package/ui/components/organisms/vc-popup/vc-popup.vue +96 -42
- package/ui/components/organisms/vc-sidebar/vc-sidebar.vue +12 -10
- package/ui/components/organisms/vc-table/VcDataTable.vue +203 -59
- package/ui/components/organisms/vc-table/VcTableAdapter.vue +31 -84
- package/ui/components/organisms/vc-table/_internal/vc-table-cell/vc-table-cell.vue +3 -3
- package/ui/components/organisms/vc-table/_internal/vc-table-column-switcher/vc-table-column-switcher.vue +1 -1
- package/ui/components/organisms/vc-table/_internal/vc-table-filter/vc-table-filter.vue +1 -1
- package/ui/components/organisms/vc-table/base/BaseVcDataTable.ts +10 -0
- package/ui/components/organisms/vc-table/components/ColumnFilter.vue +29 -15
- package/ui/components/organisms/vc-table/components/DataTableBody.vue +36 -8
- package/ui/components/organisms/vc-table/components/DataTableCellRenderer.vue +2 -2
- package/ui/components/organisms/vc-table/components/DataTableHeader.vue +7 -7
- package/ui/components/organisms/vc-table/components/DataTableRow.vue +3 -0
- package/ui/components/organisms/vc-table/components/GlobalFiltersButton.vue +1 -1
- package/ui/components/organisms/vc-table/components/GlobalFiltersPanel.vue +116 -4
- package/ui/components/organisms/vc-table/components/TableActions.vue +1 -1
- package/ui/components/organisms/vc-table/components/TableColumnSwitcher.vue +1 -1
- package/ui/components/organisms/vc-table/components/TableEmpty.vue +18 -12
- package/ui/components/organisms/vc-table/components/TableGroupRow.vue +8 -8
- package/ui/components/organisms/vc-table/components/TableHead.vue +2 -2
- package/ui/components/organisms/vc-table/components/TableRow.vue +11 -6
- package/ui/components/organisms/vc-table/components/TableRowActions.vue +27 -10
- package/ui/components/organisms/vc-table/components/TableSelectAllBar.vue +5 -5
- package/ui/components/organisms/vc-table/components/_internal/TableSkeletonRows.vue +110 -0
- package/ui/components/organisms/vc-table/components/cells/CellDate.vue +4 -6
- package/ui/components/organisms/vc-table/components/cells/CellDateAgo.vue +2 -2
- package/ui/components/organisms/vc-table/components/mobile/MobileCellRenderer.vue +2 -2
- package/ui/components/organisms/vc-table/composables/useDataProcessing.ts +1 -1
- package/ui/components/organisms/vc-table/composables/useTableEditing.ts +1 -1
- package/ui/components/organisms/vc-table/composables/useTableExpansion.ts +1 -1
- package/ui/components/organisms/vc-table/composables/useTableFilter.test.ts +43 -0
- package/ui/components/organisms/vc-table/composables/useTableFilter.ts +12 -2
- package/ui/components/organisms/vc-table/composables/useTableRowGrouping.ts +1 -1
- package/ui/components/organisms/vc-table/composables/useTableSelectionV2.ts +1 -1
- package/ui/components/organisms/vc-table/keys.ts +14 -1
- package/ui/components/organisms/vc-table/types.ts +25 -1
- package/ui/components/organisms/vc-table/vc-data-table.stories.ts +205 -0
- package/ui/composables/index.ts +1 -0
- package/ui/composables/useCollapsible.ts +73 -0
- package/ui/composables/useFormField.ts +3 -0
- package/ui/types/index.ts +1 -1
- package/core/plugins/moment/humanize.ts +0 -74
- package/core/plugins/moment/index.ts +0 -1
- package/core/plugins/moment/moment.ts +0 -29
- package/dist/core/plugins/moment/humanize.d.ts +0 -3
- package/dist/core/plugins/moment/humanize.d.ts.map +0 -1
- package/dist/core/plugins/moment/index.d.ts +0 -2
- package/dist/core/plugins/moment/index.d.ts.map +0 -1
- package/dist/core/plugins/moment/moment.d.ts +0 -13
- package/dist/core/plugins/moment/moment.d.ts.map +0 -1
- package/dist/ui/components/atoms/vc-icon/vc-icon-examples.vue.d.ts.map +0 -1
- package/dist/ui/components/atoms/vc-icon/vc-icon-test.vue.d.ts.map +0 -1
- package/dist/ui/components/molecules/vc-paginator/index.d.ts +0 -4
- package/dist/ui/components/molecules/vc-paginator/index.d.ts.map +0 -1
- package/dist/ui/components/molecules/vc-paginator/vc-paginator.vue.d.ts +0 -73
- package/dist/ui/components/molecules/vc-paginator/vc-paginator.vue.d.ts.map +0 -1
- package/dist/ui/components/organisms/vc-table/composables/useDataTableOrchestrator.d.ts +0 -173
- package/dist/ui/components/organisms/vc-table/composables/useDataTableOrchestrator.d.ts.map +0 -1
- package/dist/vendor-d3-chord-l0sNRNKZ.js +0 -1
- package/dist/vendor-d3-drag-l0sNRNKZ.js +0 -1
- package/dist/vendor-d3-force-l0sNRNKZ.js +0 -1
- package/dist/vendor-d3-geo-l0sNRNKZ.js +0 -1
- package/dist/vendor-d3-geo-projection-l0sNRNKZ.js +0 -1
- package/dist/vendor-d3-hierarchy-l0sNRNKZ.js +0 -1
- package/dist/vendor-d3-quadtree-l0sNRNKZ.js +0 -1
- package/dist/vendor-d3-sankey-l0sNRNKZ.js +0 -1
- package/dist/vendor-elkjs-l0sNRNKZ.js +0 -1
- package/dist/vendor-emotion-weak-memoize-l0sNRNKZ.js +0 -1
- package/dist/vendor-floating-ui-core-Dj2ULpEE.js +0 -428
- package/dist/vendor-floating-ui-dom-DC_tF7jX.js +0 -397
- package/dist/vendor-floating-ui-utils-0qz4b9vE.js +0 -259
- package/dist/vendor-kdbush-l0sNRNKZ.js +0 -1
- package/dist/vendor-leaflet-l0sNRNKZ.js +0 -1
- package/dist/vendor-lodash-l0sNRNKZ.js +0 -1
- package/dist/vendor-maplibre-gl-l0sNRNKZ.js +0 -1
- package/dist/vendor-moment-DMLRxgRE.js +0 -2589
- package/dist/vendor-supercluster-l0sNRNKZ.js +0 -1
- package/dist/vendor-tanstack-virtual-core-l0sNRNKZ.js +0 -1
- package/dist/vendor-three-l0sNRNKZ.js +0 -1
- package/dist/vendor-tiptap-extension-placeholder-uPw8yyv1.js +0 -1
- package/dist/vendor-tiptap-extension-table-cell-CzgB8j33.js +0 -1
- package/dist/vendor-tiptap-extension-table-header-CzgB8j33.js +0 -1
- package/dist/vendor-tiptap-extension-table-row-CzgB8j33.js +0 -1
- package/dist/vendor-tiptap-pm-5ylZKocv.js +0 -1
- package/dist/vendor-topojson-client-l0sNRNKZ.js +0 -1
- package/dist/vendor-tslib-l0sNRNKZ.js +0 -1
- package/dist/vendor-unovis-dagre-layout-l0sNRNKZ.js +0 -1
- package/dist/vendor-unovis-graphlibrary-l0sNRNKZ.js +0 -1
- package/ui/components/atoms/vc-icon/vc-icon-examples.vue +0 -544
- package/ui/components/atoms/vc-icon/vc-icon-test.vue +0 -416
- package/ui/components/molecules/vc-paginator/index.ts +0 -4
- package/ui/components/molecules/vc-paginator/vc-paginator.vue +0 -379
- package/ui/components/organisms/vc-table/composables/useDataTableOrchestrator.ts +0 -516
|
@@ -1,158 +1,225 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div
|
|
3
3
|
class="vc-banner"
|
|
4
|
-
:class="[
|
|
5
|
-
|
|
6
|
-
|
|
4
|
+
:class="[
|
|
5
|
+
`vc-banner--${normalizedVariant}`,
|
|
6
|
+
{
|
|
7
|
+
'vc-banner--title-only': isTitleOnly,
|
|
8
|
+
'vc-banner--collapsed': isCollapsed,
|
|
9
|
+
},
|
|
10
|
+
]"
|
|
11
|
+
:role="normalizedVariant === 'danger' || normalizedVariant === 'warning' ? 'alert' : 'region'"
|
|
12
|
+
:aria-label="normalizedVariant === 'danger' ? 'Error' : normalizedVariant === 'warning' ? 'Warning' : 'Information'"
|
|
7
13
|
>
|
|
8
|
-
<
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
<div class="vc-
|
|
18
|
-
<
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
'vc-banner__content--collapsed': !isExpanded,
|
|
27
|
-
'vc-banner__content--expanded': isExpanded,
|
|
28
|
-
},
|
|
29
|
-
]"
|
|
30
|
-
>
|
|
14
|
+
<VcIcon
|
|
15
|
+
v-if="icon"
|
|
16
|
+
:icon="icon"
|
|
17
|
+
:size="iconSize"
|
|
18
|
+
:variant="iconVariant"
|
|
19
|
+
class="vc-banner__icon"
|
|
20
|
+
aria-hidden="true"
|
|
21
|
+
/>
|
|
22
|
+
<div class="vc-banner__body">
|
|
23
|
+
<div v-if="hasTitle" class="vc-banner__title">
|
|
24
|
+
<slot name="title"></slot>
|
|
25
|
+
</div>
|
|
26
|
+
<div
|
|
27
|
+
v-if="hasContent"
|
|
28
|
+
class="vc-banner__content-wrapper"
|
|
29
|
+
:style="wrapperStyle"
|
|
30
|
+
>
|
|
31
|
+
<div ref="contentRef" class="vc-banner__content">
|
|
31
32
|
<slot name="default"></slot>
|
|
32
33
|
</div>
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
34
|
+
</div>
|
|
35
|
+
<div v-if="showTrigger" class="vc-banner__trigger">
|
|
36
|
+
<slot
|
|
37
|
+
name="trigger"
|
|
38
|
+
:is-expanded="isExpanded"
|
|
39
|
+
:toggle="toggle"
|
|
40
|
+
>
|
|
41
|
+
<button
|
|
42
|
+
type="button"
|
|
43
|
+
class="vc-banner__trigger-button"
|
|
44
|
+
:aria-expanded="isExpanded"
|
|
45
|
+
@click="toggle"
|
|
38
46
|
>
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
size="sm"
|
|
43
|
-
:aria-expanded="isExpanded"
|
|
44
|
-
@click="toggle"
|
|
45
|
-
>
|
|
46
|
-
{{ isExpanded ? $t("COMPONENTS.ATOMS.VC_BANNER.SHOW_LESS") : $t("COMPONENTS.ATOMS.VC_BANNER.SHOW_MORE") }}
|
|
47
|
-
</VcButton>
|
|
48
|
-
</slot>
|
|
49
|
-
</div>
|
|
47
|
+
{{ isExpanded ? $t("COMPONENTS.ATOMS.VC_BANNER.SHOW_LESS") : $t("COMPONENTS.ATOMS.VC_BANNER.SHOW_MORE") }}
|
|
48
|
+
</button>
|
|
49
|
+
</slot>
|
|
50
50
|
</div>
|
|
51
51
|
</div>
|
|
52
52
|
</div>
|
|
53
53
|
</template>
|
|
54
|
+
|
|
54
55
|
<!-- eslint-disable @typescript-eslint/no-explicit-any -->
|
|
55
56
|
<script lang="ts" setup>
|
|
56
|
-
import {
|
|
57
|
-
import { VcIcon } from "
|
|
58
|
-
|
|
59
|
-
// TODO: Add to docs
|
|
57
|
+
import { computed, useSlots } from "vue";
|
|
58
|
+
import { VcIcon } from "@ui/components/atoms/vc-icon";
|
|
59
|
+
import { useCollapsible } from "@ui/composables/useCollapsible";
|
|
60
60
|
|
|
61
|
-
type
|
|
61
|
+
export type CurrentBannerVariant = "info" | "warning" | "danger" | "success";
|
|
62
|
+
/**
|
|
63
|
+
* @deprecated Use current variants: "info" | "warning" | "danger" | "success".
|
|
64
|
+
*/
|
|
65
|
+
export type LegacyBannerVariant = "light-danger" | "info-dark" | "primary";
|
|
66
|
+
export type BannerVariant = CurrentBannerVariant | LegacyBannerVariant;
|
|
62
67
|
|
|
63
68
|
export interface Props {
|
|
64
|
-
|
|
69
|
+
/**
|
|
70
|
+
* @deprecated Legacy variants ("light-danger", "info-dark", "primary") are supported for backward compatibility
|
|
71
|
+
* and mapped to modern variants ("danger", "info", "info").
|
|
72
|
+
*/
|
|
73
|
+
variant?: BannerVariant;
|
|
65
74
|
icon?: string;
|
|
66
75
|
iconSize?: InstanceType<typeof VcIcon>["$props"]["size"];
|
|
67
76
|
iconVariant?: InstanceType<typeof VcIcon>["$props"]["variant"];
|
|
77
|
+
collapsedHeight?: number;
|
|
68
78
|
}
|
|
69
79
|
|
|
70
80
|
defineSlots<{
|
|
71
81
|
title: (props: any) => any;
|
|
72
82
|
default: (props: any) => any;
|
|
73
|
-
trigger: (props:
|
|
83
|
+
trigger: (props: { isExpanded: boolean; toggle: () => void }) => any;
|
|
74
84
|
}>();
|
|
75
85
|
|
|
76
86
|
const props = withDefaults(defineProps<Props>(), {
|
|
77
87
|
variant: "info",
|
|
78
|
-
iconSize: "
|
|
88
|
+
iconSize: "l",
|
|
89
|
+
collapsedHeight: 100,
|
|
79
90
|
});
|
|
80
91
|
|
|
81
|
-
|
|
82
|
-
const
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
const isExpanded = ref(false);
|
|
86
|
-
const hasOverflow = ref(false);
|
|
87
|
-
|
|
88
|
-
const toggle = () => {
|
|
89
|
-
isExpanded.value = !isExpanded.value;
|
|
90
|
-
};
|
|
92
|
+
const slots = useSlots();
|
|
93
|
+
const { contentRef, isExpanded, hasOverflow, wrapperStyle, toggle } = useCollapsible({
|
|
94
|
+
collapsedHeight: props.collapsedHeight,
|
|
95
|
+
});
|
|
91
96
|
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
97
|
+
function normalizeVariant(variant: BannerVariant): CurrentBannerVariant {
|
|
98
|
+
switch (variant) {
|
|
99
|
+
case "light-danger":
|
|
100
|
+
return "danger";
|
|
101
|
+
case "info-dark":
|
|
102
|
+
case "primary":
|
|
103
|
+
return "info";
|
|
104
|
+
default:
|
|
105
|
+
return variant;
|
|
95
106
|
}
|
|
96
|
-
}
|
|
107
|
+
}
|
|
97
108
|
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
109
|
+
const normalizedVariant = computed<CurrentBannerVariant>(() => normalizeVariant(props.variant));
|
|
110
|
+
const hasTitle = computed(() => Boolean(slots.title));
|
|
111
|
+
const hasContent = computed(() => Boolean(slots.default));
|
|
112
|
+
const isTitleOnly = computed(() => hasTitle.value && !hasContent.value);
|
|
113
|
+
const showTrigger = computed(() => hasContent.value && hasOverflow.value);
|
|
114
|
+
const isCollapsed = computed(() => showTrigger.value && !isExpanded.value);
|
|
115
|
+
|
|
116
|
+
if (import.meta.env?.DEV) {
|
|
117
|
+
if (props.variant === "light-danger" || props.variant === "info-dark" || props.variant === "primary") {
|
|
118
|
+
console.warn(
|
|
119
|
+
`[VcBanner] variant "${props.variant}" is deprecated. Use "${normalizeVariant(props.variant)}" instead.`,
|
|
120
|
+
);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
101
123
|
</script>
|
|
102
124
|
|
|
103
125
|
<style lang="scss">
|
|
104
|
-
:
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
--
|
|
108
|
-
|
|
109
|
-
|
|
126
|
+
@use "sass:map";
|
|
127
|
+
|
|
128
|
+
$banner-variants: (
|
|
129
|
+
info: (bg: var(--neutrals-50), border: var(--info-100), accent: var(--info-500)),
|
|
130
|
+
warning: (bg: var(--neutrals-50), border: var(--warning-100), accent: var(--warning-500)),
|
|
131
|
+
danger: (bg: var(--neutrals-50), border: var(--danger-100), accent: var(--danger-500)),
|
|
132
|
+
success: (bg: var(--neutrals-50), border: var(--success-100), accent: var(--success-500)),
|
|
133
|
+
);
|
|
110
134
|
|
|
111
135
|
.vc-banner {
|
|
112
|
-
@apply tw-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
}
|
|
136
|
+
@apply tw-relative tw-flex tw-items-start tw-gap-3 tw-overflow-hidden tw-rounded-md tw-border tw-border-solid tw-py-3 tw-pr-3 tw-pl-4;
|
|
137
|
+
--vc-banner-accent: var(--info-500);
|
|
138
|
+
|
|
139
|
+
&::before {
|
|
140
|
+
content: "";
|
|
141
|
+
@apply tw-absolute tw-left-0 tw-top-0 tw-bottom-0;
|
|
142
|
+
width: 3px;
|
|
143
|
+
background-color: var(--vc-banner-accent);
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
@each $name, $colors in $banner-variants {
|
|
147
|
+
&.vc-banner--#{$name} {
|
|
148
|
+
--vc-banner-accent: #{map.get($colors, accent)};
|
|
149
|
+
background-color: #{map.get($colors, bg)};
|
|
150
|
+
border-color: #{map.get($colors, border)};
|
|
125
151
|
}
|
|
126
152
|
}
|
|
127
153
|
|
|
128
|
-
|
|
129
|
-
@apply tw-
|
|
154
|
+
&.vc-banner--title-only {
|
|
155
|
+
@apply tw-items-center;
|
|
156
|
+
|
|
157
|
+
.vc-banner__icon {
|
|
158
|
+
@apply tw-mt-0;
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
&__icon {
|
|
163
|
+
@apply tw-mt-0.5 tw-shrink-0;
|
|
164
|
+
color: var(--vc-banner-accent);
|
|
130
165
|
}
|
|
131
166
|
|
|
132
|
-
&
|
|
133
|
-
@apply tw-flex tw-flex-
|
|
167
|
+
&__body {
|
|
168
|
+
@apply tw-flex tw-flex-col tw-min-w-0 tw-flex-1;
|
|
134
169
|
}
|
|
135
170
|
|
|
136
171
|
&__title {
|
|
137
|
-
@apply tw-font-
|
|
172
|
+
@apply tw-text-sm tw-font-medium tw-leading-5;
|
|
173
|
+
color: var(--neutrals-900);
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
&__content-wrapper {
|
|
177
|
+
@apply tw-relative tw-overflow-hidden;
|
|
178
|
+
transition: max-height 0.28s cubic-bezier(0.22, 1, 0.36, 1);
|
|
179
|
+
will-change: max-height;
|
|
180
|
+
|
|
181
|
+
&::after {
|
|
182
|
+
content: "";
|
|
183
|
+
@apply tw-pointer-events-none tw-absolute tw-bottom-0 tw-left-0 tw-right-0 tw-h-8;
|
|
184
|
+
background: linear-gradient(to bottom, rgb(250 250 250 / 0), var(--neutrals-50));
|
|
185
|
+
opacity: 0;
|
|
186
|
+
transition: opacity 0.2s ease;
|
|
187
|
+
}
|
|
138
188
|
}
|
|
139
189
|
|
|
140
190
|
&__content {
|
|
141
|
-
@apply tw-
|
|
142
|
-
|
|
191
|
+
@apply tw-text-sm tw-leading-5;
|
|
192
|
+
color: var(--neutrals-700);
|
|
193
|
+
}
|
|
143
194
|
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
}
|
|
195
|
+
&__title + &__content-wrapper {
|
|
196
|
+
@apply tw-mt-0.5;
|
|
197
|
+
}
|
|
148
198
|
|
|
149
|
-
|
|
150
|
-
|
|
199
|
+
&.vc-banner--collapsed {
|
|
200
|
+
.vc-banner__content-wrapper::after {
|
|
201
|
+
opacity: 1;
|
|
151
202
|
}
|
|
152
203
|
}
|
|
153
204
|
|
|
154
|
-
&
|
|
155
|
-
@apply tw-
|
|
205
|
+
&__trigger {
|
|
206
|
+
@apply tw-mt-1;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
&__trigger-button {
|
|
210
|
+
@apply tw-inline-flex tw-cursor-pointer tw-items-center tw-border-0 tw-bg-transparent tw-p-0 tw-text-sm tw-font-medium tw-leading-5;
|
|
211
|
+
color: var(--vc-banner-accent);
|
|
212
|
+
transition: color 0.15s ease;
|
|
213
|
+
|
|
214
|
+
&:hover {
|
|
215
|
+
@apply tw-underline;
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
&:focus-visible {
|
|
219
|
+
outline: 2px solid var(--vc-banner-accent);
|
|
220
|
+
outline-offset: 2px;
|
|
221
|
+
border-radius: 2px;
|
|
222
|
+
}
|
|
156
223
|
}
|
|
157
224
|
}
|
|
158
225
|
</style>
|
|
@@ -30,9 +30,9 @@ provide(ButtonGroupKey, {
|
|
|
30
30
|
const groupClass = computed(() => [
|
|
31
31
|
"vc-button-group",
|
|
32
32
|
{
|
|
33
|
-
"vc-button-
|
|
34
|
-
"vc-button-
|
|
35
|
-
"vc-button-
|
|
33
|
+
"vc-button-group--horizontal": props.orientation === "horizontal",
|
|
34
|
+
"vc-button-group--vertical": props.orientation === "vertical",
|
|
35
|
+
"vc-button-group--attached": props.attached,
|
|
36
36
|
},
|
|
37
37
|
]);
|
|
38
38
|
</script>
|
|
@@ -41,18 +41,18 @@ const groupClass = computed(() => [
|
|
|
41
41
|
.vc-button-group {
|
|
42
42
|
@apply tw-inline-flex tw-gap-2;
|
|
43
43
|
|
|
44
|
-
|
|
44
|
+
&--vertical {
|
|
45
45
|
@apply tw-flex-col;
|
|
46
46
|
}
|
|
47
47
|
|
|
48
48
|
// Attached mode — buttons touch, shared borders, connected radii
|
|
49
49
|
// Selectors use `> *` to handle both direct .vc-button children
|
|
50
50
|
// and wrapped buttons (e.g. inside VcTooltip or other wrappers).
|
|
51
|
-
|
|
51
|
+
&--attached {
|
|
52
52
|
@apply tw-gap-0;
|
|
53
53
|
|
|
54
54
|
// Horizontal attached
|
|
55
|
-
&.vc-button-
|
|
55
|
+
&.vc-button-group--horizontal {
|
|
56
56
|
// All buttons inside lose rounding
|
|
57
57
|
.vc-button {
|
|
58
58
|
@apply tw-rounded-none;
|
|
@@ -77,7 +77,7 @@ const groupClass = computed(() => [
|
|
|
77
77
|
}
|
|
78
78
|
|
|
79
79
|
// Vertical attached
|
|
80
|
-
&.vc-button-
|
|
80
|
+
&.vc-button-group--vertical {
|
|
81
81
|
.vc-button {
|
|
82
82
|
@apply tw-rounded-none;
|
|
83
83
|
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { afterEach, describe, expect, it } from "vitest";
|
|
2
|
+
import { mount, VueWrapper } from "@vue/test-utils";
|
|
3
|
+
import axe from "axe-core";
|
|
4
|
+
import VcButton from "@ui/components/atoms/vc-button/vc-button.vue";
|
|
5
|
+
|
|
6
|
+
describe("VcButton a11y", () => {
|
|
7
|
+
let wrapper: VueWrapper;
|
|
8
|
+
|
|
9
|
+
afterEach(() => {
|
|
10
|
+
wrapper?.unmount();
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
const mountButton = (props: Record<string, unknown> = {}, slots: Record<string, string> = {}) => {
|
|
14
|
+
wrapper = mount(VcButton as any, {
|
|
15
|
+
props,
|
|
16
|
+
slots,
|
|
17
|
+
global: { stubs: { VcIcon: true } },
|
|
18
|
+
attachTo: document.body,
|
|
19
|
+
});
|
|
20
|
+
return wrapper;
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
it("has no a11y violations with text content", async () => {
|
|
24
|
+
const w = mountButton({}, { default: "Submit" });
|
|
25
|
+
const results = await axe.run(w.element as HTMLElement);
|
|
26
|
+
expect(results).toHaveNoViolations();
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
it("has no a11y violations when disabled", async () => {
|
|
30
|
+
const w = mountButton({ disabled: true }, { default: "Disabled" });
|
|
31
|
+
const results = await axe.run(w.element as HTMLElement);
|
|
32
|
+
expect(results).toHaveNoViolations();
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
it("has no a11y violations when loading", async () => {
|
|
36
|
+
const w = mountButton({ loading: true }, { default: "Loading" });
|
|
37
|
+
const results = await axe.run(w.element as HTMLElement);
|
|
38
|
+
expect(results).toHaveNoViolations();
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
it("has no a11y violations for icon-only button with aria-label", async () => {
|
|
42
|
+
const w = mountButton({ ariaLabel: "Add item", icon: "lucide-plus" });
|
|
43
|
+
const results = await axe.run(w.element as HTMLElement);
|
|
44
|
+
expect(results).toHaveNoViolations();
|
|
45
|
+
});
|
|
46
|
+
});
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import { mount } from "@vue/test-utils";
|
|
3
|
+
import VcButton from "@ui/components/atoms/vc-button/vc-button.vue";
|
|
4
|
+
|
|
5
|
+
describe("VcButton", () => {
|
|
6
|
+
const mountButton = (props: Record<string, unknown> = {}, slots: Record<string, string> = {}) =>
|
|
7
|
+
mount(VcButton as any, {
|
|
8
|
+
props,
|
|
9
|
+
slots,
|
|
10
|
+
global: { stubs: { VcIcon: true } },
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
it("renders a native button element", () => {
|
|
14
|
+
const wrapper = mountButton({}, { default: "Click me" });
|
|
15
|
+
expect(wrapper.find("button").exists()).toBe(true);
|
|
16
|
+
expect(wrapper.text()).toContain("Click me");
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
it("defaults to type=button", () => {
|
|
20
|
+
const wrapper = mountButton();
|
|
21
|
+
expect(wrapper.find("button").attributes("type")).toBe("button");
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
it("sets disabled when disabled prop is true", () => {
|
|
25
|
+
const wrapper = mountButton({ disabled: true });
|
|
26
|
+
expect(wrapper.find("button").attributes("disabled")).toBeDefined();
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
it("sets disabled when loading prop is true", () => {
|
|
30
|
+
const wrapper = mountButton({ loading: true });
|
|
31
|
+
expect(wrapper.find("button").attributes("disabled")).toBeDefined();
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
it("sets aria-busy when loading", () => {
|
|
35
|
+
const wrapper = mountButton({ loading: true });
|
|
36
|
+
expect(wrapper.find("button").attributes("aria-busy")).toBe("true");
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
it("does not set aria-busy when not loading", () => {
|
|
40
|
+
const wrapper = mountButton();
|
|
41
|
+
expect(wrapper.find("button").attributes("aria-busy")).toBeUndefined();
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
it("forwards ariaLabel prop", () => {
|
|
45
|
+
const wrapper = mountButton({ ariaLabel: "Submit form" });
|
|
46
|
+
expect(wrapper.find("button").attributes("aria-label")).toBe("Submit form");
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
it("emits click on button click", async () => {
|
|
50
|
+
const wrapper = mountButton({}, { default: "Go" });
|
|
51
|
+
await wrapper.find("button").trigger("click");
|
|
52
|
+
expect(wrapper.emitted("click")).toHaveLength(1);
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
it("does not emit click when disabled", async () => {
|
|
56
|
+
const wrapper = mountButton({ disabled: true }, { default: "Go" });
|
|
57
|
+
await wrapper.find("button").trigger("click");
|
|
58
|
+
expect(wrapper.emitted("click")).toBeUndefined();
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
it("applies variant class", () => {
|
|
62
|
+
const wrapper = mountButton({ variant: "danger" }, { default: "Delete" });
|
|
63
|
+
expect(wrapper.find("button").classes()).toContain("vc-button-danger");
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
it("sets aria-pressed when selected", () => {
|
|
67
|
+
const w = mountButton({ selected: true });
|
|
68
|
+
expect(w.find("button").attributes("aria-pressed")).toBe("true");
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
it("does not set aria-pressed when not selected", () => {
|
|
72
|
+
const w = mountButton({});
|
|
73
|
+
expect(w.find("button").attributes("aria-pressed")).toBeUndefined();
|
|
74
|
+
});
|
|
75
|
+
});
|
|
@@ -5,6 +5,7 @@
|
|
|
5
5
|
:disabled="disabled || loading"
|
|
6
6
|
:aria-label="ariaLabel"
|
|
7
7
|
:aria-busy="loading || undefined"
|
|
8
|
+
:aria-pressed="selected || undefined"
|
|
8
9
|
@click="onClick"
|
|
9
10
|
>
|
|
10
11
|
<!-- Loading: spinner replaces icon; shown inline next to text -->
|
|
@@ -86,11 +87,11 @@ const buttonClass = computed(() => {
|
|
|
86
87
|
"vc-button",
|
|
87
88
|
{
|
|
88
89
|
[`vc-button-${props.variant}`]: props.variant,
|
|
89
|
-
[`vc-
|
|
90
|
-
"vc-
|
|
91
|
-
"vc-
|
|
92
|
-
"vc-
|
|
93
|
-
"vc-
|
|
90
|
+
[`vc-button--${effectiveSize.value}`]: effectiveSize.value,
|
|
91
|
+
"vc-button--selected": props.selected,
|
|
92
|
+
"vc-button--text": props.text,
|
|
93
|
+
"vc-button--disabled": props.disabled || props.loading,
|
|
94
|
+
"vc-button--loading": props.loading,
|
|
94
95
|
},
|
|
95
96
|
];
|
|
96
97
|
});
|
|
@@ -223,11 +224,26 @@ function onClick(e: Event): void {
|
|
|
223
224
|
$variants: primary, secondary, danger, warning, success, info, outline, ghost, link;
|
|
224
225
|
|
|
225
226
|
.vc-button {
|
|
227
|
+
position: relative;
|
|
228
|
+
|
|
229
|
+
// Expand touch target to 44px minimum for WCAG 2.5.8 compliance
|
|
230
|
+
// Uses ::after pseudo-element to extend hit area without affecting visual size
|
|
231
|
+
&::after {
|
|
232
|
+
content: "";
|
|
233
|
+
position: absolute;
|
|
234
|
+
inset: 50% auto auto 50%;
|
|
235
|
+
transform: translate(-50%, -50%);
|
|
236
|
+
min-width: 44px;
|
|
237
|
+
min-height: 44px;
|
|
238
|
+
width: 100%;
|
|
239
|
+
height: 100%;
|
|
240
|
+
}
|
|
241
|
+
|
|
226
242
|
&__icon + &__title {
|
|
227
243
|
@apply tw-ml-2 tw-text-left;
|
|
228
244
|
}
|
|
229
245
|
|
|
230
|
-
|
|
246
|
+
&--loading {
|
|
231
247
|
@apply tw-cursor-wait #{!important};
|
|
232
248
|
}
|
|
233
249
|
|
|
@@ -259,7 +275,7 @@ $variants: primary, secondary, danger, warning, success, info, outline, ghost, l
|
|
|
259
275
|
}
|
|
260
276
|
|
|
261
277
|
// text modifier — ghost-like appearance (backward compat)
|
|
262
|
-
&.vc-
|
|
278
|
+
&.vc-button--text {
|
|
263
279
|
@apply tw-border-none tw-bg-transparent
|
|
264
280
|
tw-text-[color:var(--button-#{$variant}-background-color)]
|
|
265
281
|
hover:tw-text-[color:var(--button-#{$variant}-background-color-hover)]
|
|
@@ -273,31 +289,31 @@ $variants: primary, secondary, danger, warning, success, info, outline, ghost, l
|
|
|
273
289
|
}
|
|
274
290
|
}
|
|
275
291
|
|
|
276
|
-
&.vc-
|
|
292
|
+
&.vc-button--selected {
|
|
277
293
|
@apply tw-bg-[color:var(--button-#{$variant}-background-color-hover)];
|
|
278
294
|
|
|
279
|
-
&.vc-
|
|
295
|
+
&.vc-button--text {
|
|
280
296
|
@apply tw-bg-[color:var(--button-#{$variant}-background-color-hover)] tw-bg-opacity-[0.07] tw-p-1;
|
|
281
297
|
}
|
|
282
298
|
}
|
|
283
299
|
|
|
284
300
|
// Size: sm — h-8 px-3 text-xs (no vertical padding)
|
|
285
|
-
&.vc-
|
|
301
|
+
&.vc-button--sm {
|
|
286
302
|
@apply tw-h-[var(--button-sm-height)] tw-px-[var(--button-sm-padding-hor)] tw-py-0 tw-text-xs #{!important};
|
|
287
303
|
}
|
|
288
304
|
|
|
289
305
|
// Size: default — h-9 px-4 py-2
|
|
290
|
-
&.vc-
|
|
306
|
+
&.vc-button--default {
|
|
291
307
|
@apply tw-h-[var(--button-default-height)] tw-py-[var(--button-default-padding-vert)] tw-px-[var(--button-default-padding-hor)] tw-text-sm tw-leading-4;
|
|
292
308
|
}
|
|
293
309
|
|
|
294
310
|
// Size: lg — h-10 px-6 (no vertical padding)
|
|
295
|
-
&.vc-
|
|
311
|
+
&.vc-button--lg {
|
|
296
312
|
@apply tw-h-[var(--button-lg-height)] tw-px-[var(--button-lg-padding-hor)] tw-py-0 tw-text-sm tw-leading-4 #{!important};
|
|
297
313
|
}
|
|
298
314
|
|
|
299
315
|
// Size: icon — h-9 w-9 square
|
|
300
|
-
&.vc-
|
|
316
|
+
&.vc-button--icon {
|
|
301
317
|
@apply tw-h-[var(--button-icon-size)] tw-w-[var(--button-icon-size)] tw-p-0 #{!important};
|
|
302
318
|
}
|
|
303
319
|
|
|
@@ -308,17 +324,17 @@ $variants: primary, secondary, danger, warning, success, info, outline, ghost, l
|
|
|
308
324
|
}
|
|
309
325
|
|
|
310
326
|
// Special hover overrides for structural variants (bg change, not just opacity)
|
|
311
|
-
&.vc-button-secondary:hover:not(:disabled):not(.vc-
|
|
327
|
+
&.vc-button-secondary:hover:not(:disabled):not(.vc-button--text) {
|
|
312
328
|
@apply tw-opacity-100 tw-bg-[color:var(--button-secondary-background-color-hover)]
|
|
313
329
|
tw-border-[color:var(--button-secondary-border-color-hover)];
|
|
314
330
|
}
|
|
315
331
|
|
|
316
|
-
&.vc-button-outline:hover:not(:disabled):not(.vc-
|
|
332
|
+
&.vc-button-outline:hover:not(:disabled):not(.vc-button--text) {
|
|
317
333
|
@apply tw-opacity-100 tw-bg-[color:var(--button-outline-background-color-hover)]
|
|
318
334
|
tw-border-[color:var(--button-outline-border-color-hover)];
|
|
319
335
|
}
|
|
320
336
|
|
|
321
|
-
&.vc-button-ghost:hover:not(:disabled):not(.vc-
|
|
337
|
+
&.vc-button-ghost:hover:not(:disabled):not(.vc-button--text) {
|
|
322
338
|
@apply tw-opacity-100 tw-bg-[color:var(--button-ghost-background-color-hover)];
|
|
323
339
|
}
|
|
324
340
|
|
|
@@ -326,7 +342,7 @@ $variants: primary, secondary, danger, warning, success, info, outline, ghost, l
|
|
|
326
342
|
// Link variant: no padding, no min-height — behaves like inline text
|
|
327
343
|
@apply tw-p-0 tw-h-auto tw-min-h-0 #{!important};
|
|
328
344
|
|
|
329
|
-
&:hover:not(:disabled):not(.vc-
|
|
345
|
+
&:hover:not(:disabled):not(.vc-button--text) {
|
|
330
346
|
@apply tw-opacity-100;
|
|
331
347
|
|
|
332
348
|
// Underline only on text, not icon — prevents split underline with icon+text
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import type { Meta, StoryObj } from "@storybook/vue3-vite";
|
|
2
2
|
import { VcCard } from ".";
|
|
3
|
-
import { VcInput
|
|
3
|
+
import { VcInput } from "@ui/components/molecules/vc-input";
|
|
4
|
+
import { VcCol } from "@ui/components/atoms/vc-col";
|
|
5
|
+
import { VcButton } from "@ui/components/atoms/vc-button";
|
|
4
6
|
|
|
5
7
|
/**
|
|
6
8
|
* `VcCard` is a container component that provides a bordered and styled section with
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div
|
|
3
3
|
class="vc-card"
|
|
4
|
-
:class="[{ 'vc-
|
|
4
|
+
:class="[{ 'vc-card--collapsable': isCollapsable }, `vc-card--${variant}`]"
|
|
5
5
|
>
|
|
6
6
|
<div
|
|
7
7
|
v-if="header"
|
|
@@ -161,7 +161,7 @@ $variants: success, danger;
|
|
|
161
161
|
@apply tw-flex tw-items-center;
|
|
162
162
|
}
|
|
163
163
|
|
|
164
|
-
|
|
164
|
+
&--collapsable &__header {
|
|
165
165
|
@apply tw-cursor-pointer tw-select-none;
|
|
166
166
|
|
|
167
167
|
&:hover {
|
|
@@ -204,7 +204,7 @@ $variants: success, danger;
|
|
|
204
204
|
}
|
|
205
205
|
|
|
206
206
|
@each $variant in $variants {
|
|
207
|
-
|
|
207
|
+
&--#{$variant} {
|
|
208
208
|
.vc-card__header {
|
|
209
209
|
@apply tw-bg-[color:var(--card-header-background-#{$variant})];
|
|
210
210
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { Meta, StoryObj } from "@storybook/vue3-vite";
|
|
2
2
|
import { VcCol } from "@ui/components/atoms/vc-col";
|
|
3
3
|
import { VcRow } from "@ui/components/atoms/vc-row";
|
|
4
|
-
import { VcImage } from "@ui/components";
|
|
4
|
+
import { VcImage } from "@ui/components/atoms/vc-image";
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
7
|
* `VcCol` is a layout component that creates a vertical column for content.
|