@vc-shell/framework 1.2.4-beta.4 → 1.2.4-beta.5
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-B-g_a-7F.js +123 -0
- package/dist/DashboardDonutChart-AktPFUNo.js +89 -0
- package/dist/DashboardLineChart-BQKqRFhM.js +125 -0
- package/dist/GridstackDashboard-BXqCpiMw.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-DVyGELzS.js +33689 -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 +10 -2
- package/dist/locales/en.json +10 -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-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/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/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 +220 -45
- package/dist/ui/components/organisms/vc-table/VcDataTable.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/components/ColumnFilter.vue.d.ts.map +1 -1
- package/dist/ui/components/organisms/vc-table/components/DataTableBody.vue.d.ts +19 -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 +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/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 +3 -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-BtJrxrBg.js +848 -0
- package/dist/vc-editor.css +1 -0
- package/dist/vc-slider-sUKMaKnc.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 +1 -1
- 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/ForgotPasswordPage/components/forgot-password/ForgotPassword.vue +1 -1
- package/shared/pages/LoginPage/components/login/Login.vue +93 -75
- 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 +31 -37
- 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 +2 -1
- 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/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 +95 -40
- package/ui/components/organisms/vc-table/VcDataTable.vue +146 -49
- 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/components/ColumnFilter.vue +29 -15
- package/ui/components/organisms/vc-table/components/DataTableBody.vue +26 -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/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/TableGroupRow.vue +8 -8
- package/ui/components/organisms/vc-table/components/TableHead.vue +2 -2
- package/ui/components/organisms/vc-table/components/TableRow.vue +6 -5
- 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 +3 -1
- 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
|
@@ -178,6 +178,17 @@ const handlePointerDownOutside = (e: PointerEvent) => {
|
|
|
178
178
|
return;
|
|
179
179
|
}
|
|
180
180
|
}
|
|
181
|
+
// Handle teleported child dropdowns (e.g. VcSelect dropdown inside this panel).
|
|
182
|
+
// VcSelect teleports its dropdown to <body>, so it's outside our DOM tree.
|
|
183
|
+
// We identify ownership via the ARIA contract: the dropdown has id="listboxId"
|
|
184
|
+
// and the trigger inside our panel has aria-controls="listboxId".
|
|
185
|
+
const selectDropdown = target.closest?.(".vc-select__dropdown");
|
|
186
|
+
if (selectDropdown && floatingRef.value) {
|
|
187
|
+
const listboxId = selectDropdown.getAttribute("id");
|
|
188
|
+
if (listboxId && floatingRef.value.querySelector(`[aria-controls="${listboxId}"]`)) {
|
|
189
|
+
return;
|
|
190
|
+
}
|
|
191
|
+
}
|
|
181
192
|
close();
|
|
182
193
|
};
|
|
183
194
|
|
|
@@ -20,26 +20,20 @@
|
|
|
20
20
|
<script lang="ts" setup>
|
|
21
21
|
import { VcIcon } from "@ui/components/atoms";
|
|
22
22
|
|
|
23
|
-
|
|
24
|
-
icon:
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
disabled: {
|
|
33
|
-
type: Boolean,
|
|
34
|
-
default: false,
|
|
35
|
-
},
|
|
36
|
-
ariaLabel: {
|
|
37
|
-
type: String,
|
|
38
|
-
default: undefined,
|
|
39
|
-
},
|
|
23
|
+
interface Props {
|
|
24
|
+
icon: string;
|
|
25
|
+
active?: boolean;
|
|
26
|
+
disabled?: boolean;
|
|
27
|
+
ariaLabel?: string;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
withDefaults(defineProps<Props>(), {
|
|
31
|
+
disabled: false,
|
|
40
32
|
});
|
|
41
33
|
|
|
42
|
-
defineEmits
|
|
34
|
+
defineEmits<{
|
|
35
|
+
action: [];
|
|
36
|
+
}>();
|
|
43
37
|
</script>
|
|
44
38
|
|
|
45
39
|
<style lang="scss">
|
|
@@ -54,7 +48,7 @@ defineEmits(["action"]);
|
|
|
54
48
|
--vc-button-bg-active: var(--primary-100);
|
|
55
49
|
--vc-button-bg-disabled: transparent;
|
|
56
50
|
--vc-button-border-radius: 6px;
|
|
57
|
-
--vc-editor-focus-ring-color:
|
|
51
|
+
--vc-editor-focus-ring-color: color-mix(in srgb, var(--primary-500) 30%, transparent);
|
|
58
52
|
}
|
|
59
53
|
|
|
60
54
|
.vc-editor-button {
|
|
@@ -1,6 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
import { defineAsyncComponent } from "vue";
|
|
2
|
+
|
|
3
|
+
type VcEditorComponent = typeof import("./vc-editor.vue")["default"];
|
|
4
|
+
|
|
5
|
+
export const VcEditor = defineAsyncComponent({
|
|
6
|
+
loader: () => import("./vc-editor.vue"),
|
|
7
|
+
delay: 200,
|
|
8
|
+
timeout: 10000,
|
|
9
|
+
suspensible: false,
|
|
10
|
+
}) as VcEditorComponent;
|
|
11
|
+
export type {
|
|
12
|
+
CustomToolbarButton,
|
|
13
|
+
CustomToolbarDropdown,
|
|
14
|
+
CustomToolbarItem,
|
|
15
|
+
} from "./_internal/toolbar-types";
|
|
@@ -176,7 +176,8 @@ import { format } from "prettier/standalone";
|
|
|
176
176
|
import * as prettierPluginHtml from "prettier/parser-html";
|
|
177
177
|
// eslint-disable-next-line import/no-named-as-default
|
|
178
178
|
import DOMPurify from "dompurify";
|
|
179
|
-
import { VcLabel
|
|
179
|
+
import { VcLabel } from "@ui/components/atoms/vc-label";
|
|
180
|
+
import { VcHint } from "@ui/components/atoms/vc-hint";
|
|
180
181
|
import VcEditorToolbar from "@ui/components/molecules/vc-editor/_internal/vc-editor-toolbar.vue";
|
|
181
182
|
import VcEditorButton from "@ui/components/molecules/vc-editor/_internal/vc-editor-button.vue";
|
|
182
183
|
import type { CustomToolbarItem } from "@ui/components/molecules/vc-editor/_internal/toolbar-types";
|
|
@@ -452,11 +453,18 @@ function toggleSideBySideView() {
|
|
|
452
453
|
editorMode.value = editorMode.value === "split" ? "editor" : "split";
|
|
453
454
|
}
|
|
454
455
|
|
|
456
|
+
// Guard flag: prevents emitting update:modelValue when content is set
|
|
457
|
+
// programmatically from prop watcher (e.g., language switch), not from user input.
|
|
458
|
+
let settingContentFromProp = false;
|
|
459
|
+
|
|
455
460
|
const editor = useEditor({
|
|
456
461
|
content: props.modelValue,
|
|
457
462
|
editable: !props.disabled,
|
|
458
463
|
extensions: extensions.value,
|
|
459
464
|
onUpdate: ({ editor: tipTapEditor }) => {
|
|
465
|
+
// Skip emit when content was set programmatically from prop change
|
|
466
|
+
if (settingContentFromProp) return;
|
|
467
|
+
|
|
460
468
|
// Always output in Markdown by default, unless HTML is detected
|
|
461
469
|
const output =
|
|
462
470
|
detectedType.value === "html"
|
|
@@ -489,7 +497,9 @@ watch(
|
|
|
489
497
|
: (editor.value.storage as any).markdown?.getMarkdown?.() || editor.value.getHTML();
|
|
490
498
|
|
|
491
499
|
if (editorContent !== value) {
|
|
500
|
+
settingContentFromProp = true;
|
|
492
501
|
editor.value.commands.setContent(value || "");
|
|
502
|
+
settingContentFromProp = false;
|
|
493
503
|
}
|
|
494
504
|
},
|
|
495
505
|
);
|
|
@@ -562,7 +572,7 @@ async function handleImageSelection(event: Event) {
|
|
|
562
572
|
--vc-editor-background-disabled: var(--neutrals-200);
|
|
563
573
|
--vc-editor-focus-border: var(--primary-500);
|
|
564
574
|
--vc-editor-focus-shadow: var(--primary-500);
|
|
565
|
-
--vc-editor-focus-ring-color:
|
|
575
|
+
--vc-editor-focus-ring-color: color-mix(in srgb, var(--primary-500) 30%, transparent);
|
|
566
576
|
--vc-editor-error-border: var(--danger-500);
|
|
567
577
|
--vc-editor-error-text: var(--danger-500);
|
|
568
578
|
--vc-editor-error-ring-color: rgba(239, 68, 68, 0.2);
|
|
@@ -819,17 +829,5 @@ async function handleImageSelection(event: Event) {
|
|
|
819
829
|
}
|
|
820
830
|
}
|
|
821
831
|
|
|
822
|
-
.slide-up-enter-active,
|
|
823
|
-
.slide-up-leave-active {
|
|
824
|
-
@apply tw-transition-all tw-duration-[250ms] tw-ease-out;
|
|
825
|
-
}
|
|
826
|
-
|
|
827
|
-
.slide-up-enter-from {
|
|
828
|
-
@apply tw-opacity-0 tw-translate-y-[5px];
|
|
829
|
-
}
|
|
830
|
-
|
|
831
|
-
.slide-up-leave-to {
|
|
832
|
-
@apply tw-opacity-0 tw--translate-y-[5px];
|
|
833
|
-
}
|
|
834
832
|
}
|
|
835
833
|
</style>
|
|
@@ -21,7 +21,7 @@
|
|
|
21
21
|
<template v-if="type === 'date-ago'">
|
|
22
22
|
<div class="vc-field-type">
|
|
23
23
|
<div class="vc-field-type__text-wrap">
|
|
24
|
-
<p class="vc-field-type__text">{{ value instanceof Date ? (
|
|
24
|
+
<p class="vc-field-type__text">{{ value instanceof Date ? (formatDateRelative(value) ?? "N/A") : value }}</p>
|
|
25
25
|
</div>
|
|
26
26
|
</div>
|
|
27
27
|
</template>
|
|
@@ -56,7 +56,7 @@
|
|
|
56
56
|
</template>
|
|
57
57
|
|
|
58
58
|
<script lang="ts" setup>
|
|
59
|
-
import
|
|
59
|
+
import { formatDateRelative } from "@core/utilities/date";
|
|
60
60
|
|
|
61
61
|
export interface Props {
|
|
62
62
|
type: "text" | "date" | "date-ago" | "link" | "email";
|
|
@@ -42,7 +42,8 @@
|
|
|
42
42
|
|
|
43
43
|
<script lang="ts" setup>
|
|
44
44
|
import { ref } from "vue";
|
|
45
|
-
import { VcLabel
|
|
45
|
+
import { VcLabel } from "@ui/components/atoms/vc-label";
|
|
46
|
+
import { VcCol } from "@ui/components/atoms/vc-col";
|
|
46
47
|
import VcFieldType from "@ui/components/molecules/vc-field/_internal/vc-field-type/vc-field-type.vue";
|
|
47
48
|
|
|
48
49
|
export interface Props {
|
|
@@ -2,8 +2,6 @@ import type { Meta, StoryObj } from "@storybook/vue3-vite";
|
|
|
2
2
|
import { VcFileUpload } from "@ui/components/molecules/vc-file-upload";
|
|
3
3
|
import { ref } from "vue";
|
|
4
4
|
|
|
5
|
-
const VARIANT = ["gallery", "file-upload"];
|
|
6
|
-
|
|
7
5
|
/**
|
|
8
6
|
* `VcFileUpload` is a component for uploading files with support for
|
|
9
7
|
* drag-and-drop and browsing from file system.
|
|
@@ -13,7 +11,6 @@ const meta = {
|
|
|
13
11
|
component: VcFileUpload,
|
|
14
12
|
tags: ["autodocs"],
|
|
15
13
|
args: {
|
|
16
|
-
variant: "gallery",
|
|
17
14
|
loading: false,
|
|
18
15
|
accept: ".jpg, .png, .jpeg, .webp, .heic, .svg",
|
|
19
16
|
multiple: false,
|
|
@@ -21,16 +18,6 @@ const meta = {
|
|
|
21
18
|
icon: "material-cloud_upload",
|
|
22
19
|
},
|
|
23
20
|
argTypes: {
|
|
24
|
-
variant: {
|
|
25
|
-
description: "Display mode for the file upload component",
|
|
26
|
-
control: "radio",
|
|
27
|
-
options: VARIANT,
|
|
28
|
-
table: {
|
|
29
|
-
category: "Appearance",
|
|
30
|
-
type: { summary: VARIANT.join(" | ") },
|
|
31
|
-
defaultValue: { summary: "gallery" },
|
|
32
|
-
},
|
|
33
|
-
},
|
|
34
21
|
onUpload: {
|
|
35
22
|
description: "Event emitted when files are uploaded",
|
|
36
23
|
table: {
|
|
@@ -102,11 +89,40 @@ const meta = {
|
|
|
102
89
|
defaultValue: { summary: "undefined" },
|
|
103
90
|
},
|
|
104
91
|
},
|
|
92
|
+
disabled: {
|
|
93
|
+
description: "Whether the file upload is disabled",
|
|
94
|
+
control: "boolean",
|
|
95
|
+
table: {
|
|
96
|
+
category: "State",
|
|
97
|
+
type: { summary: "boolean" },
|
|
98
|
+
defaultValue: { summary: "false" },
|
|
99
|
+
},
|
|
100
|
+
},
|
|
101
|
+
required: {
|
|
102
|
+
description: "Whether the field is required",
|
|
103
|
+
control: "boolean",
|
|
104
|
+
table: {
|
|
105
|
+
category: "Validation",
|
|
106
|
+
type: { summary: "boolean" },
|
|
107
|
+
defaultValue: { summary: "false" },
|
|
108
|
+
},
|
|
109
|
+
},
|
|
105
110
|
error: {
|
|
106
|
-
description: "
|
|
111
|
+
description: "External error flag (also available as slot)",
|
|
112
|
+
control: "boolean",
|
|
113
|
+
table: {
|
|
114
|
+
category: "Validation",
|
|
115
|
+
type: { summary: "boolean" },
|
|
116
|
+
defaultValue: { summary: "false" },
|
|
117
|
+
},
|
|
118
|
+
},
|
|
119
|
+
errorMessage: {
|
|
120
|
+
description: "Error message text — also sets error state when truthy",
|
|
121
|
+
control: "text",
|
|
107
122
|
table: {
|
|
108
|
-
category: "
|
|
109
|
-
type: { summary: "
|
|
123
|
+
category: "Validation",
|
|
124
|
+
type: { summary: "string" },
|
|
125
|
+
defaultValue: { summary: "undefined" },
|
|
110
126
|
},
|
|
111
127
|
},
|
|
112
128
|
},
|
|
@@ -116,7 +132,7 @@ const meta = {
|
|
|
116
132
|
component: `
|
|
117
133
|
The VcFileUpload component provides functionality for uploading files with the following features:
|
|
118
134
|
|
|
119
|
-
-
|
|
135
|
+
- Full-width layout, sized by its container
|
|
120
136
|
- Support for drag and drop file uploads
|
|
121
137
|
- File type filtering through the accept property
|
|
122
138
|
- Multiple file upload support
|
|
@@ -130,7 +146,6 @@ The VcFileUpload component provides functionality for uploading files with the f
|
|
|
130
146
|
\`\`\`vue
|
|
131
147
|
<template>
|
|
132
148
|
<VcFileUpload
|
|
133
|
-
variant="gallery"
|
|
134
149
|
accept=".jpg, .png"
|
|
135
150
|
:multiple="true"
|
|
136
151
|
@upload="handleUpload"
|
|
@@ -154,13 +169,10 @@ export default meta;
|
|
|
154
169
|
type Story = StoryObj<typeof meta>;
|
|
155
170
|
|
|
156
171
|
/**
|
|
157
|
-
*
|
|
158
|
-
* and grid layouts.
|
|
172
|
+
* Default full-width upload area, sized by its container.
|
|
159
173
|
*/
|
|
160
|
-
export const
|
|
161
|
-
args: {
|
|
162
|
-
variant: "gallery",
|
|
163
|
-
},
|
|
174
|
+
export const Default: Story = {
|
|
175
|
+
args: {},
|
|
164
176
|
render: (args) => ({
|
|
165
177
|
components: { VcFileUpload },
|
|
166
178
|
setup() {
|
|
@@ -185,13 +197,11 @@ export const Gallery: Story = {
|
|
|
185
197
|
};
|
|
186
198
|
|
|
187
199
|
/**
|
|
188
|
-
*
|
|
189
|
-
*
|
|
200
|
+
* Full-width upload area constrained by a max-width container,
|
|
201
|
+
* suitable for form integrations.
|
|
190
202
|
*/
|
|
191
203
|
export const FileUpload: Story = {
|
|
192
|
-
args: {
|
|
193
|
-
variant: "file-upload",
|
|
194
|
-
},
|
|
204
|
+
args: {},
|
|
195
205
|
render: (args) => ({
|
|
196
206
|
components: { VcFileUpload },
|
|
197
207
|
setup() {
|
|
@@ -221,7 +231,6 @@ export const FileUpload: Story = {
|
|
|
221
231
|
*/
|
|
222
232
|
export const Loading: Story = {
|
|
223
233
|
args: {
|
|
224
|
-
variant: "gallery",
|
|
225
234
|
loading: true,
|
|
226
235
|
},
|
|
227
236
|
render: (args) => ({
|
|
@@ -253,7 +262,6 @@ export const Loading: Story = {
|
|
|
253
262
|
*/
|
|
254
263
|
export const RestrictedFileTypes: Story = {
|
|
255
264
|
args: {
|
|
256
|
-
variant: "file-upload",
|
|
257
265
|
accept: ".pdf, .doc, .docx",
|
|
258
266
|
},
|
|
259
267
|
render: (args) => ({
|
|
@@ -285,7 +293,6 @@ export const RestrictedFileTypes: Story = {
|
|
|
285
293
|
*/
|
|
286
294
|
export const MultipleFiles: Story = {
|
|
287
295
|
args: {
|
|
288
|
-
variant: "file-upload",
|
|
289
296
|
multiple: true,
|
|
290
297
|
},
|
|
291
298
|
render: (args) => ({
|
|
@@ -322,7 +329,6 @@ export const MultipleFiles: Story = {
|
|
|
322
329
|
*/
|
|
323
330
|
export const CustomText: Story = {
|
|
324
331
|
args: {
|
|
325
|
-
variant: "gallery",
|
|
326
332
|
customText: {
|
|
327
333
|
dragHere: "Drop your files here",
|
|
328
334
|
browse: "Select files",
|
|
@@ -352,12 +358,10 @@ export const CustomText: Story = {
|
|
|
352
358
|
};
|
|
353
359
|
|
|
354
360
|
/**
|
|
355
|
-
* You can show error messages using the error slot.
|
|
361
|
+
* You can show custom error messages using the error slot.
|
|
356
362
|
*/
|
|
357
|
-
export const
|
|
358
|
-
args: {
|
|
359
|
-
variant: "file-upload",
|
|
360
|
-
},
|
|
363
|
+
export const WithErrorSlot: Story = {
|
|
364
|
+
args: {},
|
|
361
365
|
render: (args) => ({
|
|
362
366
|
components: { VcFileUpload },
|
|
363
367
|
setup() {
|
|
@@ -392,12 +396,56 @@ export const WithError: Story = {
|
|
|
392
396
|
}),
|
|
393
397
|
};
|
|
394
398
|
|
|
399
|
+
/**
|
|
400
|
+
* The component can be disabled, preventing all interactions.
|
|
401
|
+
*/
|
|
402
|
+
export const Disabled: Story = {
|
|
403
|
+
args: {
|
|
404
|
+
disabled: true,
|
|
405
|
+
},
|
|
406
|
+
render: (args) => ({
|
|
407
|
+
components: { VcFileUpload },
|
|
408
|
+
setup() {
|
|
409
|
+
return { args };
|
|
410
|
+
},
|
|
411
|
+
template: `
|
|
412
|
+
<div class="tw-p-4 tw-max-w-md">
|
|
413
|
+
<VcFileUpload
|
|
414
|
+
v-bind="args"
|
|
415
|
+
/>
|
|
416
|
+
</div>
|
|
417
|
+
`,
|
|
418
|
+
}),
|
|
419
|
+
};
|
|
420
|
+
|
|
421
|
+
/**
|
|
422
|
+
* Error state can be driven by the errorMessage prop (from IFormFieldProps),
|
|
423
|
+
* in addition to vee-validate rules or the error slot.
|
|
424
|
+
*/
|
|
425
|
+
export const WithErrorMessage: Story = {
|
|
426
|
+
args: {
|
|
427
|
+
errorMessage: "Maximum file size exceeded (5 MB)",
|
|
428
|
+
},
|
|
429
|
+
render: (args) => ({
|
|
430
|
+
components: { VcFileUpload },
|
|
431
|
+
setup() {
|
|
432
|
+
return { args };
|
|
433
|
+
},
|
|
434
|
+
template: `
|
|
435
|
+
<div class="tw-p-4 tw-max-w-md">
|
|
436
|
+
<VcFileUpload
|
|
437
|
+
v-bind="args"
|
|
438
|
+
/>
|
|
439
|
+
</div>
|
|
440
|
+
`,
|
|
441
|
+
}),
|
|
442
|
+
};
|
|
443
|
+
|
|
395
444
|
/**
|
|
396
445
|
* You can customize the icon displayed in the upload area.
|
|
397
446
|
*/
|
|
398
447
|
export const CustomIcon: Story = {
|
|
399
448
|
args: {
|
|
400
|
-
variant: "gallery",
|
|
401
449
|
icon: "bi-file-earmark-upload",
|
|
402
450
|
},
|
|
403
451
|
render: (args) => ({
|
|
@@ -1,17 +1,15 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div
|
|
3
3
|
class="vc-file-upload__container"
|
|
4
|
-
:class="{ 'vc-file-upload__container--error': !!
|
|
4
|
+
:class="{ 'vc-file-upload__container--error': !!resolvedErrorMessage }"
|
|
5
5
|
>
|
|
6
6
|
<div
|
|
7
7
|
v-loading="loading"
|
|
8
8
|
class="vc-file-upload__drop-zone"
|
|
9
|
-
:class="
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
},
|
|
14
|
-
]"
|
|
9
|
+
:class="{
|
|
10
|
+
'vc-file-upload__drop-zone--dragging': isDragging,
|
|
11
|
+
'vc-file-upload__drop-zone--disabled': resolvedDisabled,
|
|
12
|
+
}"
|
|
15
13
|
@drop.stop.prevent="onDrop"
|
|
16
14
|
@drag.stop.prevent
|
|
17
15
|
@dragstart.stop.prevent
|
|
@@ -20,9 +18,11 @@
|
|
|
20
18
|
@dragenter.stop.prevent
|
|
21
19
|
@dragleave.stop.prevent="dragLeave"
|
|
22
20
|
role="button"
|
|
23
|
-
tabindex="0"
|
|
21
|
+
:tabindex="resolvedDisabled ? -1 : 0"
|
|
24
22
|
:aria-label="customText?.dragHere || 'Upload files'"
|
|
25
23
|
:aria-describedby="ariaDescribedBy"
|
|
24
|
+
:aria-disabled="resolvedDisabled || undefined"
|
|
25
|
+
:aria-required="ariaRequired"
|
|
26
26
|
@keydown.enter="toggleUploader"
|
|
27
27
|
@keydown.space.prevent="toggleUploader"
|
|
28
28
|
>
|
|
@@ -50,7 +50,8 @@
|
|
|
50
50
|
hidden
|
|
51
51
|
:accept="accept"
|
|
52
52
|
:multiple="multiple"
|
|
53
|
-
:name="
|
|
53
|
+
:name="resolvedName"
|
|
54
|
+
:disabled="resolvedDisabled"
|
|
54
55
|
@change="upload"
|
|
55
56
|
/>
|
|
56
57
|
</div>
|
|
@@ -58,14 +59,14 @@
|
|
|
58
59
|
name="slide-up"
|
|
59
60
|
mode="out-in"
|
|
60
61
|
>
|
|
61
|
-
<div v-if="
|
|
62
|
+
<div v-if="resolvedErrorMessage">
|
|
62
63
|
<slot name="error">
|
|
63
64
|
<VcHint
|
|
64
65
|
:id="errorId"
|
|
65
66
|
class="vc-file-upload__error"
|
|
66
67
|
:error="true"
|
|
67
68
|
>
|
|
68
|
-
{{
|
|
69
|
+
{{ resolvedErrorMessage }}
|
|
69
70
|
</VcHint>
|
|
70
71
|
</slot>
|
|
71
72
|
</div>
|
|
@@ -74,19 +75,21 @@
|
|
|
74
75
|
</template>
|
|
75
76
|
<!-- eslint-disable @typescript-eslint/no-explicit-any -->
|
|
76
77
|
<script lang="ts" setup>
|
|
77
|
-
import {
|
|
78
|
+
import { ref, unref, computed } from "vue";
|
|
78
79
|
import { useField } from "vee-validate";
|
|
79
|
-
import { VcIcon
|
|
80
|
+
import { VcIcon } from "@ui/components/atoms/vc-icon";
|
|
81
|
+
import { VcLink } from "@ui/components/atoms/vc-link";
|
|
82
|
+
import { VcHint } from "@ui/components/atoms/vc-hint";
|
|
80
83
|
import { useI18n } from "vue-i18n";
|
|
81
84
|
import { IValidationRules } from "@core/types";
|
|
85
|
+
import { useFormField } from "@ui/composables/useFormField";
|
|
86
|
+
import type { IFormFieldProps } from "@ui/types/form-field";
|
|
82
87
|
|
|
83
|
-
export interface Props {
|
|
84
|
-
variant?: "gallery" | "file-upload";
|
|
88
|
+
export interface Props extends IFormFieldProps {
|
|
85
89
|
loading?: boolean;
|
|
86
90
|
accept?: string;
|
|
87
91
|
multiple?: boolean;
|
|
88
92
|
rules?: keyof IValidationRules | IValidationRules;
|
|
89
|
-
name?: string;
|
|
90
93
|
icon?: string;
|
|
91
94
|
customText?: {
|
|
92
95
|
dragHere: string;
|
|
@@ -99,7 +102,6 @@ export interface Emits {
|
|
|
99
102
|
}
|
|
100
103
|
|
|
101
104
|
const props = withDefaults(defineProps<Props>(), {
|
|
102
|
-
variant: "gallery",
|
|
103
105
|
accept: ".jpg, .png, .jpeg, .webp, .heic, .svg",
|
|
104
106
|
name: "Gallery",
|
|
105
107
|
icon: "lucide-cloud-upload",
|
|
@@ -112,25 +114,46 @@ defineSlots<{
|
|
|
112
114
|
|
|
113
115
|
const { t } = useI18n({ useScope: "global" });
|
|
114
116
|
|
|
115
|
-
const
|
|
117
|
+
const {
|
|
118
|
+
fieldId,
|
|
119
|
+
errorId,
|
|
120
|
+
resolvedDisabled,
|
|
121
|
+
resolvedName,
|
|
122
|
+
ariaRequired,
|
|
123
|
+
groupContext,
|
|
124
|
+
} = useFormField(props);
|
|
125
|
+
|
|
116
126
|
const internalRules = unref(props.rules) || "";
|
|
117
127
|
const isDragging = ref(false);
|
|
118
128
|
|
|
119
|
-
const { errorMessage, handleChange, validate } = useField(
|
|
120
|
-
`${props.name === "Gallery" ?
|
|
129
|
+
const { errorMessage: veeErrorMessage, handleChange, validate } = useField(
|
|
130
|
+
`${props.name === "Gallery" ? fieldId.value : props.name}`,
|
|
121
131
|
internalRules as IValidationRules,
|
|
122
132
|
);
|
|
123
133
|
|
|
124
|
-
const
|
|
134
|
+
const resolvedErrorMessage = computed(
|
|
135
|
+
() => props.errorMessage || veeErrorMessage.value,
|
|
136
|
+
);
|
|
125
137
|
|
|
126
|
-
const uid = useId();
|
|
127
|
-
const errorId = computed(() => `vc-file-upload-${uid}-error`);
|
|
128
138
|
const ariaDescribedBy = computed(() => {
|
|
129
|
-
|
|
130
|
-
|
|
139
|
+
const ids = new Set<string>();
|
|
140
|
+
|
|
141
|
+
if (groupContext?.describedBy.value) {
|
|
142
|
+
groupContext.describedBy.value.split(/\s+/).forEach((id) => ids.add(id));
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
if (resolvedErrorMessage.value) {
|
|
146
|
+
ids.add(errorId.value);
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
return ids.size ? Array.from(ids).join(" ") : undefined;
|
|
131
150
|
});
|
|
132
151
|
|
|
152
|
+
const uploader = ref<HTMLInputElement | null>(null);
|
|
153
|
+
|
|
133
154
|
const upload = async (event: Event) => {
|
|
155
|
+
if (resolvedDisabled.value) return;
|
|
156
|
+
|
|
134
157
|
await handleChange(event.target);
|
|
135
158
|
|
|
136
159
|
const isValid = await validate();
|
|
@@ -146,6 +169,7 @@ const upload = async (event: Event) => {
|
|
|
146
169
|
};
|
|
147
170
|
|
|
148
171
|
function toggleUploader() {
|
|
172
|
+
if (resolvedDisabled.value) return;
|
|
149
173
|
if (uploader.value) {
|
|
150
174
|
uploader.value.value = "";
|
|
151
175
|
uploader.value.click();
|
|
@@ -153,6 +177,7 @@ function toggleUploader() {
|
|
|
153
177
|
}
|
|
154
178
|
|
|
155
179
|
function onDrop(event: DragEvent) {
|
|
180
|
+
if (resolvedDisabled.value) return;
|
|
156
181
|
dragLeave();
|
|
157
182
|
const fileList = event.dataTransfer?.files;
|
|
158
183
|
|
|
@@ -162,6 +187,7 @@ function onDrop(event: DragEvent) {
|
|
|
162
187
|
}
|
|
163
188
|
|
|
164
189
|
function dragOver() {
|
|
190
|
+
if (resolvedDisabled.value) return;
|
|
165
191
|
isDragging.value = true;
|
|
166
192
|
}
|
|
167
193
|
|
|
@@ -197,26 +223,22 @@ function dragLeave() {
|
|
|
197
223
|
}
|
|
198
224
|
|
|
199
225
|
&__drop-zone {
|
|
200
|
-
@apply tw-relative tw-h-40 tw-box-border tw-border tw-border-dashed tw-p-4 tw-flex tw-flex-col tw-items-center tw-justify-center
|
|
226
|
+
@apply tw-relative tw-w-full tw-h-40 tw-box-border tw-border tw-border-dashed tw-p-4 tw-flex tw-flex-col tw-items-center tw-justify-center
|
|
201
227
|
tw-border-[color:var(--file-upload-border-color)]
|
|
202
228
|
tw-rounded-[var(--file-upload-border-radius)]
|
|
203
229
|
tw-transition-[color,border-color,box-shadow] tw-duration-200
|
|
204
230
|
tw-bg-[color:var(--file-upload-background-color)]
|
|
205
231
|
tw-outline-none;
|
|
206
232
|
|
|
207
|
-
&--gallery {
|
|
208
|
-
@apply tw-w-40 tw-h-40;
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
&--file-upload {
|
|
212
|
-
@apply tw-w-full;
|
|
213
|
-
}
|
|
214
|
-
|
|
215
233
|
&--dragging {
|
|
216
234
|
@apply tw-bg-[color:var(--file-upload-drag-bg)] tw-border-solid tw-cursor-copy
|
|
217
235
|
tw-border-[color:var(--file-upload-border-color-dragover)];
|
|
218
236
|
}
|
|
219
237
|
|
|
238
|
+
&--disabled {
|
|
239
|
+
@apply tw-opacity-50 tw-pointer-events-none tw-cursor-default;
|
|
240
|
+
}
|
|
241
|
+
|
|
220
242
|
&:hover {
|
|
221
243
|
@apply tw-border-[color:var(--file-upload-border-color-hover)];
|
|
222
244
|
}
|
|
@@ -245,17 +267,5 @@ function dragLeave() {
|
|
|
245
267
|
@apply tw-mt-1 [--hint-error-color:var(--file-upload-error-color)];
|
|
246
268
|
}
|
|
247
269
|
|
|
248
|
-
.slide-up-enter-active,
|
|
249
|
-
.slide-up-leave-active {
|
|
250
|
-
@apply tw-transition-all tw-duration-[250ms] tw-ease-out;
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
.slide-up-enter-from {
|
|
254
|
-
@apply tw-opacity-0 tw-translate-y-[5px];
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
.slide-up-leave-to {
|
|
258
|
-
@apply tw-opacity-0 tw--translate-y-[5px];
|
|
259
|
-
}
|
|
260
270
|
}
|
|
261
271
|
</style>
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { afterEach, describe, expect, it } from "vitest";
|
|
2
|
+
import { mount, VueWrapper } from "@vue/test-utils";
|
|
3
|
+
import axe from "axe-core";
|
|
4
|
+
import VcInput from "@ui/components/molecules/vc-input/vc-input.vue";
|
|
5
|
+
|
|
6
|
+
describe("VcInput a11y", () => {
|
|
7
|
+
let wrapper: VueWrapper;
|
|
8
|
+
|
|
9
|
+
afterEach(() => {
|
|
10
|
+
wrapper?.unmount();
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
const mountInput = (props: Record<string, unknown> = {}) => {
|
|
14
|
+
wrapper = mount(VcInput as any, {
|
|
15
|
+
props: { modelValue: "", ...props },
|
|
16
|
+
global: {
|
|
17
|
+
stubs: {
|
|
18
|
+
VcIcon: true,
|
|
19
|
+
VcLabel: false,
|
|
20
|
+
VcHint: false,
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
attachTo: document.body,
|
|
24
|
+
});
|
|
25
|
+
return wrapper;
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
it("has no a11y violations with label", async () => {
|
|
29
|
+
const w = mountInput({ label: "Username" });
|
|
30
|
+
const results = await axe.run(w.element as HTMLElement);
|
|
31
|
+
expect(results).toHaveNoViolations();
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
it("has no a11y violations with placeholder", async () => {
|
|
35
|
+
const w = mountInput({ label: "Email", placeholder: "you@example.com" });
|
|
36
|
+
const results = await axe.run(w.element as HTMLElement);
|
|
37
|
+
expect(results).toHaveNoViolations();
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
it("has no a11y violations in error state", async () => {
|
|
41
|
+
const w = mountInput({ label: "Email", error: true, errorMessage: "Required field" });
|
|
42
|
+
const results = await axe.run(w.element as HTMLElement);
|
|
43
|
+
expect(results).toHaveNoViolations();
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
it("has no a11y violations when disabled", async () => {
|
|
47
|
+
const w = mountInput({ label: "Email", disabled: true });
|
|
48
|
+
const results = await axe.run(w.element as HTMLElement);
|
|
49
|
+
expect(results).toHaveNoViolations();
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
it("has no a11y violations when required", async () => {
|
|
53
|
+
const w = mountInput({ label: "Email", required: true });
|
|
54
|
+
const results = await axe.run(w.element as HTMLElement);
|
|
55
|
+
expect(results).toHaveNoViolations();
|
|
56
|
+
});
|
|
57
|
+
});
|