@vef-framework/starter 1.0.134 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README +15 -0
- package/dist/cjs/components/access-denied/access-denied-icon.cjs +210 -0
- package/dist/cjs/components/access-denied/index.cjs +47 -0
- package/dist/cjs/components/app/index.cjs +47 -0
- package/dist/cjs/components/app/props.cjs +3 -0
- package/dist/cjs/components/base-layout/index.cjs +45 -0
- package/dist/cjs/components/base-layout/props.cjs +3 -0
- package/dist/cjs/components/base-layout/styles.cjs +57 -0
- package/dist/cjs/components/base-layout/use-base-layout.cjs +41 -0
- package/dist/cjs/components/crud/components/action-button-group.cjs +20 -0
- package/dist/cjs/components/crud/components/index.cjs +20 -0
- package/dist/cjs/components/crud/components/main.cjs +57 -0
- package/dist/cjs/components/crud/components/mutation-holder.cjs +40 -0
- package/dist/cjs/components/crud/components/operation-button-group.cjs +22 -0
- package/dist/cjs/components/crud/components/scene-form.cjs +84 -0
- package/dist/cjs/components/crud/components/selection-indicator.cjs +83 -0
- package/dist/cjs/components/crud/components/toolbar-actions.cjs +19 -0
- package/dist/cjs/components/crud/components/toolbar.cjs +38 -0
- package/dist/cjs/components/crud/event.cjs +12 -0
- package/dist/cjs/components/crud/helpers.cjs +26 -0
- package/dist/cjs/components/crud/hooks/index.cjs +14 -0
- package/dist/cjs/components/crud/hooks/use-query-observer.cjs +37 -0
- package/dist/cjs/components/crud/hooks/use-search-values.cjs +12 -0
- package/dist/cjs/components/crud/hooks/use-selected-rows.cjs +12 -0
- package/dist/cjs/components/crud/index.cjs +46 -0
- package/dist/cjs/components/crud/props.cjs +3 -0
- package/dist/cjs/components/crud/store.cjs +93 -0
- package/dist/cjs/components/crud/styles.cjs +34 -0
- package/dist/cjs/components/crud-page/index.cjs +19 -0
- package/dist/cjs/components/crud-page/props.cjs +3 -0
- package/dist/cjs/components/error/error-icon.cjs +179 -0
- package/dist/cjs/components/error/index.cjs +69 -0
- package/dist/cjs/components/flex-card/index.cjs +18 -0
- package/dist/cjs/components/flex-card/props.cjs +3 -0
- package/dist/cjs/components/flex-card/styles.cjs +26 -0
- package/dist/cjs/components/form-drawer/components/form-actions.cjs +38 -0
- package/dist/cjs/components/form-drawer/components/index.cjs +10 -0
- package/dist/cjs/components/form-drawer/index.cjs +112 -0
- package/dist/cjs/components/form-modal/components/form-actions.cjs +38 -0
- package/dist/cjs/components/form-modal/components/index.cjs +10 -0
- package/dist/cjs/components/form-modal/index.cjs +88 -0
- package/dist/cjs/components/index.cjs +45 -0
- package/dist/cjs/components/layout/components/footer.cjs +27 -0
- package/dist/cjs/components/layout/components/header/boy-icon.cjs +20 -0
- package/dist/cjs/components/layout/components/header/breadcrumb-navigation.cjs +90 -0
- package/dist/cjs/components/layout/components/header/color-scheme.cjs +40 -0
- package/dist/cjs/components/layout/components/header/fullscreen.cjs +23 -0
- package/dist/cjs/components/layout/components/header/girl-icon.cjs +21 -0
- package/dist/cjs/components/layout/components/header/index.cjs +88 -0
- package/dist/cjs/components/layout/components/header/menu-burger.cjs +24 -0
- package/dist/cjs/components/layout/components/header/menu-fold-left-icon.cjs +20 -0
- package/dist/cjs/components/layout/components/header/menu-unfold-left-icon.cjs +20 -0
- package/dist/cjs/components/layout/components/header/search.cjs +22 -0
- package/dist/cjs/components/layout/components/header/theme-config.cjs +23 -0
- package/dist/cjs/components/layout/components/header/user-avatar.cjs +86 -0
- package/dist/cjs/components/layout/components/honeycomb-pattern.cjs +39 -0
- package/dist/cjs/components/layout/components/index.cjs +20 -0
- package/dist/cjs/components/layout/components/logo.cjs +60 -0
- package/dist/cjs/components/layout/components/menu.cjs +95 -0
- package/dist/cjs/components/layout/components/search/index.cjs +79 -0
- package/dist/cjs/components/layout/components/search/keyboard-arrow-down-icon.cjs +15 -0
- package/dist/cjs/components/layout/components/search/keyboard-arrow-up-icon.cjs +15 -0
- package/dist/cjs/components/layout/components/search/keyboard-control-icon.cjs +15 -0
- package/dist/cjs/components/layout/components/search/keyboard-esc-icon.cjs +15 -0
- package/dist/cjs/components/layout/components/search/keyboard-help.cjs +46 -0
- package/dist/cjs/components/layout/components/search/keyboard-return-icon.cjs +15 -0
- package/dist/cjs/components/layout/components/search/keyboard-shift-icon.cjs +15 -0
- package/dist/cjs/components/layout/components/search/keyboard.cjs +32 -0
- package/dist/cjs/components/layout/components/search/letter-s-icon.cjs +15 -0
- package/dist/cjs/components/layout/components/search/search-result-item.cjs +69 -0
- package/dist/cjs/components/layout/components/search/search-result.cjs +135 -0
- package/dist/cjs/components/layout/components/sidebar.cjs +54 -0
- package/dist/cjs/components/layout/components/tabs/context-menu.cjs +96 -0
- package/dist/cjs/components/layout/components/tabs/index.cjs +40 -0
- package/dist/cjs/components/layout/components/tabs/main-content-maximum.cjs +23 -0
- package/dist/cjs/components/layout/components/tabs/reload.cjs +21 -0
- package/dist/cjs/components/layout/components/tabs/tab-item.cjs +84 -0
- package/dist/cjs/components/layout/components/tabs/tab-list.cjs +91 -0
- package/dist/cjs/components/layout/components/tabs/tabs-container.cjs +85 -0
- package/dist/cjs/components/layout/components/theme-config/color-scheme-switcher.cjs +49 -0
- package/dist/cjs/components/layout/components/theme-config/color-scheme.cjs +57 -0
- package/dist/cjs/components/layout/components/theme-config/config-item.cjs +27 -0
- package/dist/cjs/components/layout/components/theme-config/index.cjs +59 -0
- package/dist/cjs/components/layout/components/theme-config/menu-layout-card.cjs +75 -0
- package/dist/cjs/components/layout/components/theme-config/menu-layout.cjs +33 -0
- package/dist/cjs/components/layout/components/theme-config/operations.cjs +22 -0
- package/dist/cjs/components/layout/components/theme-config/theme-color-picker.cjs +33 -0
- package/dist/cjs/components/layout/components/theme-config/theme-colors.cjs +29 -0
- package/dist/cjs/components/layout/hooks/index.cjs +14 -0
- package/dist/cjs/components/layout/hooks/use-color-scheme-updater.cjs +72 -0
- package/dist/cjs/components/layout/hooks/use-menu-navigate.cjs +29 -0
- package/dist/cjs/components/layout/hooks/use-tab-navigate.cjs +39 -0
- package/dist/cjs/components/layout/index.cjs +81 -0
- package/dist/cjs/components/layout/props.cjs +3 -0
- package/dist/cjs/components/layout/store.cjs +23 -0
- package/dist/cjs/components/layout/styles.cjs +16 -0
- package/dist/cjs/components/login/icon-login.cjs +149 -0
- package/dist/cjs/components/login/index.cjs +162 -0
- package/dist/cjs/components/login/payload.cjs +3 -0
- package/dist/cjs/components/login/props.cjs +3 -0
- package/dist/cjs/components/login/styles.cjs +97 -0
- package/dist/cjs/components/login/welcome-messages.cjs +135 -0
- package/dist/cjs/components/logo-icon/index.cjs +22 -0
- package/dist/cjs/components/logo-icon/props.cjs +3 -0
- package/dist/cjs/components/n-progress/components/bar.cjs +53 -0
- package/dist/cjs/components/n-progress/components/container.cjs +25 -0
- package/dist/cjs/components/n-progress/components/index.cjs +12 -0
- package/dist/cjs/components/n-progress/event.cjs +10 -0
- package/dist/cjs/components/n-progress/index.cjs +34 -0
- package/dist/cjs/components/not-found/index.cjs +47 -0
- package/dist/cjs/components/not-found/not-found-icon.cjs +205 -0
- package/dist/cjs/components/page/index.cjs +58 -0
- package/dist/cjs/components/page/props.cjs +3 -0
- package/dist/cjs/components/page/scroll-content.cjs +65 -0
- package/dist/cjs/components/page/styles.cjs +86 -0
- package/dist/cjs/components/page/use-page-key.cjs +22 -0
- package/dist/cjs/components/page/viewport-context.cjs +19 -0
- package/dist/cjs/components/pro-search/components/advanced-search-toggler.cjs +23 -0
- package/dist/cjs/components/pro-search/components/advanced-search.cjs +30 -0
- package/dist/cjs/components/pro-search/components/index.cjs +14 -0
- package/dist/cjs/components/pro-search/components/search-actions.cjs +36 -0
- package/dist/cjs/components/pro-search/index.cjs +70 -0
- package/dist/cjs/components/pro-search/styles.cjs +65 -0
- package/dist/cjs/components/pro-table/components/index.cjs +17 -0
- package/dist/cjs/components/pro-table/components/operation-button-group.cjs +22 -0
- package/dist/cjs/components/pro-table/components/ref.cjs +24 -0
- package/dist/cjs/components/pro-table/components/table-subscriber.cjs +25 -0
- package/dist/cjs/components/pro-table/components/table-summary.cjs +15 -0
- package/dist/cjs/components/pro-table/components/table-title.cjs +15 -0
- package/dist/cjs/components/pro-table/components/table.cjs +132 -0
- package/dist/cjs/components/pro-table/context.cjs +15 -0
- package/dist/cjs/components/pro-table/event.cjs +12 -0
- package/dist/cjs/components/pro-table/hooks/index.cjs +12 -0
- package/dist/cjs/components/pro-table/hooks/use-row-selection.cjs +43 -0
- package/dist/cjs/components/pro-table/hooks/use-table-columns.cjs +60 -0
- package/dist/cjs/components/pro-table/index.cjs +53 -0
- package/dist/cjs/components/pro-table/store.cjs +40 -0
- package/dist/cjs/components/router-provider/context.cjs +15 -0
- package/dist/cjs/components/router-provider/index.cjs +29 -0
- package/dist/cjs/components/router-provider/props.cjs +3 -0
- package/dist/cjs/components/theme-config-provider/global-style.cjs +20 -0
- package/dist/cjs/components/theme-config-provider/index.cjs +19 -0
- package/dist/cjs/components/theme-config-provider/use-color-mode-effect.cjs +35 -0
- package/dist/cjs/components/theme-config-provider/use-theme-config.cjs +73 -0
- package/dist/cjs/constants/event.cjs +8 -0
- package/dist/cjs/constants/index.cjs +23 -0
- package/dist/cjs/constants/router.cjs +18 -0
- package/dist/cjs/constants/storage.cjs +10 -0
- package/dist/cjs/constants/symbols.cjs +10 -0
- package/dist/cjs/helpers/api.cjs +50 -0
- package/dist/cjs/helpers/app-version.cjs +227 -0
- package/dist/cjs/helpers/app.cjs +37 -0
- package/dist/cjs/helpers/auth.cjs +24 -0
- package/dist/cjs/helpers/event.cjs +24 -0
- package/dist/cjs/helpers/index.cjs +25 -0
- package/dist/cjs/helpers/query.cjs +27 -0
- package/dist/cjs/helpers/router.cjs +110 -0
- package/dist/cjs/hooks/index.cjs +10 -0
- package/dist/cjs/hooks/use-route-full-path.cjs +32 -0
- package/dist/cjs/index.cjs +83 -0
- package/dist/cjs/routes/access-denied.cjs +31 -0
- package/dist/cjs/routes/index.cjs +16 -0
- package/dist/cjs/routes/layout.cjs +140 -0
- package/dist/cjs/routes/login.cjs +41 -0
- package/dist/cjs/routes/root.cjs +35 -0
- package/dist/cjs/stores/app.cjs +25 -0
- package/dist/cjs/stores/index.cjs +14 -0
- package/dist/cjs/stores/tab.cjs +101 -0
- package/dist/cjs/stores/theme.cjs +32 -0
- package/dist/es/components/access-denied/access-denied-icon.js +206 -0
- package/dist/es/components/access-denied/index.js +43 -0
- package/dist/es/components/app/index.js +43 -0
- package/dist/es/components/app/props.js +1 -0
- package/dist/es/components/base-layout/index.js +41 -0
- package/dist/es/components/base-layout/props.js +1 -0
- package/dist/es/components/base-layout/styles.js +47 -0
- package/dist/es/components/base-layout/use-base-layout.js +37 -0
- package/dist/es/components/crud/components/action-button-group.js +16 -0
- package/dist/es/components/crud/components/index.js +7 -0
- package/dist/es/components/crud/components/main.js +53 -0
- package/dist/es/components/crud/components/mutation-holder.js +36 -0
- package/dist/es/components/crud/components/operation-button-group.js +18 -0
- package/dist/es/components/crud/components/scene-form.js +80 -0
- package/dist/es/components/crud/components/selection-indicator.js +79 -0
- package/dist/es/components/crud/components/toolbar-actions.js +15 -0
- package/dist/es/components/crud/components/toolbar.js +34 -0
- package/dist/es/components/crud/event.js +8 -0
- package/dist/es/components/crud/helpers.js +22 -0
- package/dist/es/components/crud/hooks/index.js +4 -0
- package/dist/es/components/crud/hooks/use-query-observer.js +33 -0
- package/dist/es/components/crud/hooks/use-search-values.js +8 -0
- package/dist/es/components/crud/hooks/use-selected-rows.js +8 -0
- package/dist/es/components/crud/index.js +41 -0
- package/dist/es/components/crud/props.js +1 -0
- package/dist/es/components/crud/store.js +87 -0
- package/dist/es/components/crud/styles.js +28 -0
- package/dist/es/components/crud-page/index.js +15 -0
- package/dist/es/components/crud-page/props.js +1 -0
- package/dist/es/components/error/error-icon.js +175 -0
- package/dist/es/components/error/index.js +65 -0
- package/dist/es/components/flex-card/index.js +14 -0
- package/dist/es/components/flex-card/props.js +1 -0
- package/dist/es/components/flex-card/styles.js +22 -0
- package/dist/es/components/form-drawer/components/form-actions.js +34 -0
- package/dist/es/components/form-drawer/components/index.js +2 -0
- package/dist/es/components/form-drawer/index.js +108 -0
- package/dist/es/components/form-modal/components/form-actions.js +34 -0
- package/dist/es/components/form-modal/components/index.js +2 -0
- package/dist/es/components/form-modal/index.js +84 -0
- package/dist/es/components/index.js +20 -0
- package/dist/es/components/layout/components/footer.js +23 -0
- package/dist/es/components/layout/components/header/boy-icon.js +16 -0
- package/dist/es/components/layout/components/header/breadcrumb-navigation.js +86 -0
- package/dist/es/components/layout/components/header/color-scheme.js +36 -0
- package/dist/es/components/layout/components/header/fullscreen.js +19 -0
- package/dist/es/components/layout/components/header/girl-icon.js +17 -0
- package/dist/es/components/layout/components/header/index.js +84 -0
- package/dist/es/components/layout/components/header/menu-burger.js +20 -0
- package/dist/es/components/layout/components/header/menu-fold-left-icon.js +16 -0
- package/dist/es/components/layout/components/header/menu-unfold-left-icon.js +16 -0
- package/dist/es/components/layout/components/header/search.js +18 -0
- package/dist/es/components/layout/components/header/theme-config.js +19 -0
- package/dist/es/components/layout/components/header/user-avatar.js +82 -0
- package/dist/es/components/layout/components/honeycomb-pattern.js +35 -0
- package/dist/es/components/layout/components/index.js +7 -0
- package/dist/es/components/layout/components/logo.js +56 -0
- package/dist/es/components/layout/components/menu.js +91 -0
- package/dist/es/components/layout/components/search/index.js +75 -0
- package/dist/es/components/layout/components/search/keyboard-arrow-down-icon.js +11 -0
- package/dist/es/components/layout/components/search/keyboard-arrow-up-icon.js +11 -0
- package/dist/es/components/layout/components/search/keyboard-control-icon.js +11 -0
- package/dist/es/components/layout/components/search/keyboard-esc-icon.js +11 -0
- package/dist/es/components/layout/components/search/keyboard-help.js +42 -0
- package/dist/es/components/layout/components/search/keyboard-return-icon.js +11 -0
- package/dist/es/components/layout/components/search/keyboard-shift-icon.js +11 -0
- package/dist/es/components/layout/components/search/keyboard.js +28 -0
- package/dist/es/components/layout/components/search/letter-s-icon.js +11 -0
- package/dist/es/components/layout/components/search/search-result-item.js +65 -0
- package/dist/es/components/layout/components/search/search-result.js +131 -0
- package/dist/es/components/layout/components/sidebar.js +50 -0
- package/dist/es/components/layout/components/tabs/context-menu.js +92 -0
- package/dist/es/components/layout/components/tabs/index.js +36 -0
- package/dist/es/components/layout/components/tabs/main-content-maximum.js +19 -0
- package/dist/es/components/layout/components/tabs/reload.js +17 -0
- package/dist/es/components/layout/components/tabs/tab-item.js +80 -0
- package/dist/es/components/layout/components/tabs/tab-list.js +87 -0
- package/dist/es/components/layout/components/tabs/tabs-container.js +81 -0
- package/dist/es/components/layout/components/theme-config/color-scheme-switcher.js +45 -0
- package/dist/es/components/layout/components/theme-config/color-scheme.js +53 -0
- package/dist/es/components/layout/components/theme-config/config-item.js +23 -0
- package/dist/es/components/layout/components/theme-config/index.js +55 -0
- package/dist/es/components/layout/components/theme-config/menu-layout-card.js +71 -0
- package/dist/es/components/layout/components/theme-config/menu-layout.js +29 -0
- package/dist/es/components/layout/components/theme-config/operations.js +18 -0
- package/dist/es/components/layout/components/theme-config/theme-color-picker.js +29 -0
- package/dist/es/components/layout/components/theme-config/theme-colors.js +25 -0
- package/dist/es/components/layout/hooks/index.js +4 -0
- package/dist/es/components/layout/hooks/use-color-scheme-updater.js +68 -0
- package/dist/es/components/layout/hooks/use-menu-navigate.js +25 -0
- package/dist/es/components/layout/hooks/use-tab-navigate.js +35 -0
- package/dist/es/components/layout/index.js +77 -0
- package/dist/es/components/layout/props.js +1 -0
- package/dist/es/components/layout/store.js +18 -0
- package/dist/es/components/layout/styles.js +12 -0
- package/dist/es/components/login/icon-login.js +145 -0
- package/dist/es/components/login/index.js +158 -0
- package/dist/es/components/login/payload.js +1 -0
- package/dist/es/components/login/props.js +1 -0
- package/dist/es/components/login/styles.js +85 -0
- package/dist/es/components/login/welcome-messages.js +130 -0
- package/dist/es/components/logo-icon/index.js +18 -0
- package/dist/es/components/logo-icon/props.js +1 -0
- package/dist/es/components/n-progress/components/bar.js +49 -0
- package/dist/es/components/n-progress/components/container.js +21 -0
- package/dist/es/components/n-progress/components/index.js +3 -0
- package/dist/es/components/n-progress/event.js +6 -0
- package/dist/es/components/n-progress/index.js +29 -0
- package/dist/es/components/not-found/index.js +43 -0
- package/dist/es/components/not-found/not-found-icon.js +201 -0
- package/dist/es/components/page/index.js +53 -0
- package/dist/es/components/page/props.js +1 -0
- package/dist/es/components/page/scroll-content.js +61 -0
- package/dist/es/components/page/styles.js +73 -0
- package/dist/es/components/page/use-page-key.js +18 -0
- package/dist/es/components/page/viewport-context.js +14 -0
- package/dist/es/components/pro-search/components/advanced-search-toggler.js +19 -0
- package/dist/es/components/pro-search/components/advanced-search.js +26 -0
- package/dist/es/components/pro-search/components/index.js +4 -0
- package/dist/es/components/pro-search/components/search-actions.js +32 -0
- package/dist/es/components/pro-search/index.js +66 -0
- package/dist/es/components/pro-search/styles.js +57 -0
- package/dist/es/components/pro-table/components/index.js +5 -0
- package/dist/es/components/pro-table/components/operation-button-group.js +18 -0
- package/dist/es/components/pro-table/components/ref.js +20 -0
- package/dist/es/components/pro-table/components/table-subscriber.js +21 -0
- package/dist/es/components/pro-table/components/table-summary.js +11 -0
- package/dist/es/components/pro-table/components/table-title.js +11 -0
- package/dist/es/components/pro-table/components/table.js +127 -0
- package/dist/es/components/pro-table/context.js +10 -0
- package/dist/es/components/pro-table/event.js +8 -0
- package/dist/es/components/pro-table/hooks/index.js +3 -0
- package/dist/es/components/pro-table/hooks/use-row-selection.js +39 -0
- package/dist/es/components/pro-table/hooks/use-table-columns.js +56 -0
- package/dist/es/components/pro-table/index.js +49 -0
- package/dist/es/components/pro-table/store.js +34 -0
- package/dist/es/components/router-provider/context.js +10 -0
- package/dist/es/components/router-provider/index.js +25 -0
- package/dist/es/components/router-provider/props.js +1 -0
- package/dist/es/components/theme-config-provider/global-style.js +16 -0
- package/dist/es/components/theme-config-provider/index.js +15 -0
- package/dist/es/components/theme-config-provider/use-color-mode-effect.js +31 -0
- package/dist/es/components/theme-config-provider/use-theme-config.js +69 -0
- package/dist/es/constants/event.js +4 -0
- package/dist/es/constants/index.js +5 -0
- package/dist/es/constants/router.js +9 -0
- package/dist/es/constants/storage.js +5 -0
- package/dist/es/constants/symbols.js +5 -0
- package/dist/es/helpers/api.js +46 -0
- package/dist/es/helpers/app-version.js +223 -0
- package/dist/es/helpers/app.js +33 -0
- package/dist/es/helpers/auth.js +20 -0
- package/dist/es/helpers/event.js +18 -0
- package/dist/es/helpers/index.js +8 -0
- package/dist/es/helpers/query.js +22 -0
- package/dist/es/helpers/router.js +106 -0
- package/dist/es/hooks/index.js +2 -0
- package/dist/es/hooks/use-route-full-path.js +28 -0
- package/dist/es/index.js +36 -0
- package/dist/es/routes/access-denied.js +27 -0
- package/dist/es/routes/index.js +5 -0
- package/dist/es/routes/layout.js +136 -0
- package/dist/es/routes/login.js +37 -0
- package/dist/es/routes/root.js +31 -0
- package/dist/es/stores/app.js +21 -0
- package/dist/es/stores/index.js +4 -0
- package/dist/es/stores/tab.js +97 -0
- package/dist/es/stores/theme.js +28 -0
- package/dist/types/components/access-denied/access-denied-icon.d.ts +2 -0
- package/dist/types/components/access-denied/index.d.ts +1 -0
- package/dist/types/components/app/index.d.ts +4 -0
- package/dist/types/components/app/props.d.ts +21 -0
- package/dist/types/components/base-layout/index.d.ts +3 -0
- package/dist/types/components/base-layout/props.d.ts +70 -0
- package/dist/types/components/base-layout/styles.d.ts +8 -0
- package/dist/types/components/base-layout/use-base-layout.d.ts +9 -0
- package/dist/types/components/crud/components/action-button-group.d.ts +8 -0
- package/dist/types/components/crud/components/index.d.ts +6 -0
- package/dist/types/components/crud/components/main.d.ts +6 -0
- package/dist/types/components/crud/components/mutation-holder.d.ts +10 -0
- package/dist/types/components/crud/components/operation-button-group.d.ts +8 -0
- package/dist/types/components/crud/components/scene-form.d.ts +7 -0
- package/dist/types/components/crud/components/selection-indicator.d.ts +6 -0
- package/dist/types/components/crud/components/toolbar-actions.d.ts +6 -0
- package/dist/types/components/crud/components/toolbar.d.ts +8 -0
- package/dist/types/components/crud/event.d.ts +3 -0
- package/dist/types/components/crud/helpers.d.ts +18 -0
- package/dist/types/components/crud/hooks/index.d.ts +3 -0
- package/dist/types/components/crud/hooks/use-query-observer.d.ts +11 -0
- package/dist/types/components/crud/hooks/use-search-values.d.ts +2 -0
- package/dist/types/components/crud/hooks/use-selected-rows.d.ts +2 -0
- package/dist/types/components/crud/index.d.ts +7 -0
- package/dist/types/components/crud/props.d.ts +153 -0
- package/dist/types/components/crud/store.d.ts +145 -0
- package/dist/types/components/crud/styles.d.ts +4 -0
- package/dist/types/components/crud/types.d.ts +48 -0
- package/dist/types/components/crud-page/index.d.ts +3 -0
- package/dist/types/components/crud-page/props.d.ts +20 -0
- package/dist/types/components/error/error-icon.d.ts +2 -0
- package/dist/types/components/error/index.d.ts +2 -0
- package/dist/types/components/error/props.d.ts +6 -0
- package/dist/types/components/flex-card/index.d.ts +3 -0
- package/dist/types/components/flex-card/props.d.ts +3 -0
- package/dist/types/components/flex-card/styles.d.ts +2 -0
- package/dist/types/components/form-drawer/components/form-actions.d.ts +18 -0
- package/dist/types/components/form-drawer/components/index.d.ts +1 -0
- package/dist/types/components/form-drawer/index.d.ts +5 -0
- package/dist/types/components/form-drawer/props.d.ts +70 -0
- package/dist/types/components/form-modal/components/form-actions.d.ts +18 -0
- package/dist/types/components/form-modal/components/index.d.ts +1 -0
- package/dist/types/components/form-modal/index.d.ts +5 -0
- package/dist/types/components/form-modal/props.d.ts +66 -0
- package/dist/types/components/index.d.ts +19 -0
- package/dist/types/components/layout/components/footer.d.ts +1 -0
- package/dist/types/components/layout/components/header/boy-icon.d.ts +2 -0
- package/dist/types/components/layout/components/header/breadcrumb-navigation.d.ts +2 -0
- package/dist/types/components/layout/components/header/color-scheme.d.ts +5 -0
- package/dist/types/components/layout/components/header/fullscreen.d.ts +5 -0
- package/dist/types/components/layout/components/header/girl-icon.d.ts +2 -0
- package/dist/types/components/layout/components/header/index.d.ts +5 -0
- package/dist/types/components/layout/components/header/menu-burger.d.ts +5 -0
- package/dist/types/components/layout/components/header/menu-fold-left-icon.d.ts +2 -0
- package/dist/types/components/layout/components/header/menu-unfold-left-icon.d.ts +2 -0
- package/dist/types/components/layout/components/header/search.d.ts +5 -0
- package/dist/types/components/layout/components/header/theme-config.d.ts +5 -0
- package/dist/types/components/layout/components/header/user-avatar.d.ts +6 -0
- package/dist/types/components/layout/components/honeycomb-pattern.d.ts +1 -0
- package/dist/types/components/layout/components/index.d.ts +6 -0
- package/dist/types/components/layout/components/logo.d.ts +8 -0
- package/dist/types/components/layout/components/menu.d.ts +7 -0
- package/dist/types/components/layout/components/search/index.d.ts +1 -0
- package/dist/types/components/layout/components/search/keyboard-arrow-down-icon.d.ts +2 -0
- package/dist/types/components/layout/components/search/keyboard-arrow-up-icon.d.ts +2 -0
- package/dist/types/components/layout/components/search/keyboard-control-icon.d.ts +2 -0
- package/dist/types/components/layout/components/search/keyboard-esc-icon.d.ts +2 -0
- package/dist/types/components/layout/components/search/keyboard-help.d.ts +1 -0
- package/dist/types/components/layout/components/search/keyboard-return-icon.d.ts +2 -0
- package/dist/types/components/layout/components/search/keyboard-shift-icon.d.ts +2 -0
- package/dist/types/components/layout/components/search/keyboard.d.ts +6 -0
- package/dist/types/components/layout/components/search/letter-s-icon.d.ts +2 -0
- package/dist/types/components/layout/components/search/search-result-item.d.ts +8 -0
- package/dist/types/components/layout/components/search/search-result.d.ts +5 -0
- package/dist/types/components/layout/components/sidebar.d.ts +6 -0
- package/dist/types/components/layout/components/tabs/context-menu.d.ts +6 -0
- package/dist/types/components/layout/components/tabs/index.d.ts +1 -0
- package/dist/types/components/layout/components/tabs/main-content-maximum.d.ts +5 -0
- package/dist/types/components/layout/components/tabs/reload.d.ts +5 -0
- package/dist/types/components/layout/components/tabs/tab-item.d.ts +10 -0
- package/dist/types/components/layout/components/tabs/tab-list.d.ts +1 -0
- package/dist/types/components/layout/components/tabs/tabs-container.d.ts +1 -0
- package/dist/types/components/layout/components/theme-config/color-scheme-switcher.d.ts +1 -0
- package/dist/types/components/layout/components/theme-config/color-scheme.d.ts +1 -0
- package/dist/types/components/layout/components/theme-config/config-item.d.ts +7 -0
- package/dist/types/components/layout/components/theme-config/index.d.ts +1 -0
- package/dist/types/components/layout/components/theme-config/menu-layout-card.d.ts +7 -0
- package/dist/types/components/layout/components/theme-config/menu-layout.d.ts +1 -0
- package/dist/types/components/layout/components/theme-config/operations.d.ts +1 -0
- package/dist/types/components/layout/components/theme-config/theme-color-picker.d.ts +6 -0
- package/dist/types/components/layout/components/theme-config/theme-colors.d.ts +1 -0
- package/dist/types/components/layout/hooks/index.d.ts +3 -0
- package/dist/types/components/layout/hooks/use-color-scheme-updater.d.ts +13 -0
- package/dist/types/components/layout/hooks/use-menu-navigate.d.ts +7 -0
- package/dist/types/components/layout/hooks/use-tab-navigate.d.ts +11 -0
- package/dist/types/components/layout/index.d.ts +3 -0
- package/dist/types/components/layout/props.d.ts +28 -0
- package/dist/types/components/layout/store.d.ts +17 -0
- package/dist/types/components/layout/styles.d.ts +2 -0
- package/dist/types/components/login/icon-login.d.ts +2 -0
- package/dist/types/components/login/index.d.ts +4 -0
- package/dist/types/components/login/payload.d.ts +45 -0
- package/dist/types/components/login/props.d.ts +27 -0
- package/dist/types/components/login/styles.d.ts +10 -0
- package/dist/types/components/login/welcome-messages.d.ts +11 -0
- package/dist/types/components/logo-icon/index.d.ts +3 -0
- package/dist/types/components/logo-icon/props.d.ts +10 -0
- package/dist/types/components/n-progress/components/bar.d.ts +5 -0
- package/dist/types/components/n-progress/components/container.d.ts +7 -0
- package/dist/types/components/n-progress/components/index.d.ts +2 -0
- package/dist/types/components/n-progress/event.d.ts +7 -0
- package/dist/types/components/n-progress/index.d.ts +2 -0
- package/dist/types/components/not-found/index.d.ts +1 -0
- package/dist/types/components/not-found/not-found-icon.d.ts +2 -0
- package/dist/types/components/page/index.d.ts +4 -0
- package/dist/types/components/page/props.d.ts +51 -0
- package/dist/types/components/page/scroll-content.d.ts +8 -0
- package/dist/types/components/page/styles.d.ts +11 -0
- package/dist/types/components/page/use-page-key.d.ts +1 -0
- package/dist/types/components/page/viewport-context.d.ts +7 -0
- package/dist/types/components/pro-search/components/advanced-search-toggler.d.ts +7 -0
- package/dist/types/components/pro-search/components/advanced-search.d.ts +6 -0
- package/dist/types/components/pro-search/components/index.d.ts +3 -0
- package/dist/types/components/pro-search/components/search-actions.d.ts +22 -0
- package/dist/types/components/pro-search/index.d.ts +5 -0
- package/dist/types/components/pro-search/props.d.ts +66 -0
- package/dist/types/components/pro-search/styles.d.ts +6 -0
- package/dist/types/components/pro-table/components/index.d.ts +4 -0
- package/dist/types/components/pro-table/components/operation-button-group.d.ts +7 -0
- package/dist/types/components/pro-table/components/ref.d.ts +3 -0
- package/dist/types/components/pro-table/components/table-subscriber.d.ts +9 -0
- package/dist/types/components/pro-table/components/table-summary.d.ts +7 -0
- package/dist/types/components/pro-table/components/table-title.d.ts +7 -0
- package/dist/types/components/pro-table/components/table.d.ts +6 -0
- package/dist/types/components/pro-table/context.d.ts +3 -0
- package/dist/types/components/pro-table/event.d.ts +16 -0
- package/dist/types/components/pro-table/hooks/index.d.ts +2 -0
- package/dist/types/components/pro-table/hooks/use-row-selection.d.ts +12 -0
- package/dist/types/components/pro-table/hooks/use-table-columns.d.ts +11 -0
- package/dist/types/components/pro-table/index.d.ts +11 -0
- package/dist/types/components/pro-table/props.d.ts +118 -0
- package/dist/types/components/pro-table/store.d.ts +35 -0
- package/dist/types/components/pro-table/types.d.ts +86 -0
- package/dist/types/components/router-provider/context.d.ts +6 -0
- package/dist/types/components/router-provider/index.d.ts +5 -0
- package/dist/types/components/router-provider/props.d.ts +7 -0
- package/dist/types/components/theme-config-provider/global-style.d.ts +2 -0
- package/dist/types/components/theme-config-provider/index.d.ts +2 -0
- package/dist/types/components/theme-config-provider/use-color-mode-effect.d.ts +1 -0
- package/dist/types/components/theme-config-provider/use-theme-config.d.ts +2 -0
- package/dist/types/constants/event.d.ts +4 -0
- package/dist/types/constants/index.d.ts +4 -0
- package/dist/types/constants/router.d.ts +24 -0
- package/dist/types/constants/storage.d.ts +8 -0
- package/dist/types/constants/symbols.d.ts +8 -0
- package/dist/types/helpers/api.d.ts +9 -0
- package/dist/types/helpers/app-version.d.ts +88 -0
- package/dist/types/helpers/app.d.ts +24 -0
- package/dist/types/helpers/auth.d.ts +7 -0
- package/dist/types/helpers/event.d.ts +16 -0
- package/dist/types/helpers/index.d.ts +7 -0
- package/dist/types/helpers/query.d.ts +33 -0
- package/dist/types/helpers/router.d.ts +28 -0
- package/dist/types/hooks/index.d.ts +1 -0
- package/dist/types/hooks/use-route-full-path.d.ts +6 -0
- package/dist/types/index.d.ts +6 -0
- package/dist/types/models/index.d.ts +1 -0
- package/dist/types/routes/access-denied.d.ts +13 -0
- package/dist/types/routes/index.d.ts +4 -0
- package/dist/types/routes/layout.d.ts +25 -0
- package/dist/types/routes/login.d.ts +18 -0
- package/dist/types/routes/root.d.ts +13 -0
- package/dist/types/stores/app.d.ts +38 -0
- package/dist/types/stores/index.d.ts +6 -0
- package/dist/types/stores/tab.d.ts +73 -0
- package/dist/types/stores/theme.d.ts +46 -0
- package/dist/types/types/api.d.ts +67 -0
- package/dist/types/types/common.d.ts +81 -0
- package/dist/types/types/index.d.ts +3 -0
- package/dist/types/types/router.d.ts +9 -0
- package/package.json +61 -44
- package/README.md +0 -25
- package/cjs/api.cjs +0 -2
- package/cjs/app.cjs +0 -2
- package/cjs/components/index.cjs +0 -2
- package/cjs/components/vef-access-denied-page/index.cjs +0 -2
- package/cjs/components/vef-access-denied-page/props.cjs +0 -2
- package/cjs/components/vef-app/index.cjs +0 -2
- package/cjs/components/vef-app/props.cjs +0 -2
- package/cjs/components/vef-dev-assistant/index.cjs +0 -31
- package/cjs/components/vef-dev-assistant/props.cjs +0 -2
- package/cjs/components/vef-error-page/index.cjs +0 -2
- package/cjs/components/vef-error-page/props.cjs +0 -2
- package/cjs/components/vef-login-page/index.cjs +0 -2
- package/cjs/components/vef-login-page/props.cjs +0 -2
- package/cjs/components/vef-not-found-page/index.cjs +0 -2
- package/cjs/components/vef-not-found-page/props.cjs +0 -2
- package/cjs/components/vef-router-provider/index.cjs +0 -2
- package/cjs/components/vef-router-provider/props.cjs +0 -2
- package/cjs/constants.cjs +0 -2
- package/cjs/helper.cjs +0 -2
- package/cjs/index.cjs +0 -2
- package/cjs/router.cjs +0 -2
- package/cjs/routes/access-denied.cjs +0 -2
- package/cjs/routes/index.cjs +0 -2
- package/cjs/routes/layout.cjs +0 -2
- package/cjs/routes/login.cjs +0 -2
- package/cjs/routes/root.cjs +0 -2
- package/cjs/store.cjs +0 -2
- package/esm/api.js +0 -2
- package/esm/app.js +0 -2
- package/esm/components/index.js +0 -2
- package/esm/components/vef-access-denied-page/index.js +0 -2
- package/esm/components/vef-access-denied-page/props.js +0 -2
- package/esm/components/vef-app/index.js +0 -2
- package/esm/components/vef-app/props.js +0 -2
- package/esm/components/vef-dev-assistant/index.js +0 -31
- package/esm/components/vef-dev-assistant/props.js +0 -2
- package/esm/components/vef-error-page/index.js +0 -2
- package/esm/components/vef-error-page/props.js +0 -2
- package/esm/components/vef-login-page/index.js +0 -2
- package/esm/components/vef-login-page/props.js +0 -2
- package/esm/components/vef-not-found-page/index.js +0 -2
- package/esm/components/vef-not-found-page/props.js +0 -2
- package/esm/components/vef-router-provider/index.js +0 -2
- package/esm/components/vef-router-provider/props.js +0 -2
- package/esm/constants.js +0 -2
- package/esm/helper.js +0 -2
- package/esm/index.js +0 -2
- package/esm/router.js +0 -2
- package/esm/routes/access-denied.js +0 -2
- package/esm/routes/index.js +0 -2
- package/esm/routes/layout.js +0 -2
- package/esm/routes/login.js +0 -2
- package/esm/routes/root.js +0 -2
- package/esm/store.js +0 -2
- package/types/api.d.ts +0 -9
- package/types/app.d.ts +0 -15
- package/types/components/index.d.ts +0 -7
- package/types/components/vef-access-denied-page/index.d.ts +0 -4
- package/types/components/vef-access-denied-page/props.d.ts +0 -5
- package/types/components/vef-app/index.d.ts +0 -4
- package/types/components/vef-app/props.d.ts +0 -7
- package/types/components/vef-dev-assistant/index.d.ts +0 -4
- package/types/components/vef-dev-assistant/props.d.ts +0 -5
- package/types/components/vef-error-page/index.d.ts +0 -4
- package/types/components/vef-error-page/props.d.ts +0 -6
- package/types/components/vef-login-page/index.d.ts +0 -4
- package/types/components/vef-login-page/props.d.ts +0 -7
- package/types/components/vef-not-found-page/index.d.ts +0 -4
- package/types/components/vef-not-found-page/props.d.ts +0 -6
- package/types/components/vef-router-provider/index.d.ts +0 -4
- package/types/components/vef-router-provider/props.d.ts +0 -16
- package/types/constants.d.ts +0 -24
- package/types/helper.d.ts +0 -9
- package/types/index.d.ts +0 -8
- package/types/router.d.ts +0 -23
- package/types/routes/access-denied.d.ts +0 -9
- package/types/routes/index.d.ts +0 -4
- package/types/routes/layout.d.ts +0 -33
- package/types/routes/login.d.ts +0 -27
- package/types/routes/root.d.ts +0 -7
- package/types/store.d.ts +0 -34
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { css } from '@emotion/react';
|
|
4
|
+
import { globalCssVars, ScrollArea } from '@vef-framework/components';
|
|
5
|
+
import { clsx } from '@vef-framework/core';
|
|
6
|
+
import { useIsomorphicEffect } from '@vef-framework/hooks';
|
|
7
|
+
import { useRef, useState, useCallback } from 'react';
|
|
8
|
+
import { TabList } from './tab-list.js';
|
|
9
|
+
|
|
10
|
+
const tabsWrapperStyle = /* @__PURE__ */ css({
|
|
11
|
+
flex: "auto",
|
|
12
|
+
"&.shadow-right::after": {
|
|
13
|
+
content: "''",
|
|
14
|
+
position: "absolute",
|
|
15
|
+
top: 0,
|
|
16
|
+
bottom: 0,
|
|
17
|
+
right: 0,
|
|
18
|
+
width: "10px",
|
|
19
|
+
boxShadow: "inset -10px 0 8px -8px var(--vef-color-split)",
|
|
20
|
+
transition: `box-shadow ${globalCssVars.motionDurationMid} ease`,
|
|
21
|
+
pointerEvents: "none"
|
|
22
|
+
},
|
|
23
|
+
"&.shadow-left::before": {
|
|
24
|
+
content: "''",
|
|
25
|
+
position: "absolute",
|
|
26
|
+
top: 0,
|
|
27
|
+
bottom: 0,
|
|
28
|
+
left: 0,
|
|
29
|
+
width: "10px",
|
|
30
|
+
boxShadow: "inset 10px 0 8px -8px var(--vef-color-split)",
|
|
31
|
+
transition: `box-shadow ${globalCssVars.motionDurationMid} ease`,
|
|
32
|
+
pointerEvents: "none"
|
|
33
|
+
}
|
|
34
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RhYnMvdGFicy1jb250YWluZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVd5QiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90YWJzL3RhYnMtY29udGFpbmVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUG9zaXRpb24gfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuaW1wb3J0IHR5cGUgeyBNYXliZVVuZGVmaW5lZCB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9zaGFyZWRcIjtcblxuaW1wb3J0IHsgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgeyBnbG9iYWxDc3NWYXJzLCBTY3JvbGxBcmVhIH0gZnJvbSBcIkB2ZWYtZnJhbWV3b3JrL2NvbXBvbmVudHNcIjtcbmltcG9ydCB7IGNsc3ggfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29yZVwiO1xuaW1wb3J0IHsgdXNlSXNvbW9ycGhpY0VmZmVjdCB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9ob29rc1wiO1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tIFwicmVhY3RcIjtcblxuaW1wb3J0IHsgVGFiTGlzdCB9IGZyb20gXCIuL3RhYi1saXN0XCI7XG5cbmNvbnN0IHRhYnNXcmFwcGVyU3R5bGUgPSBjc3Moe1xuICBmbGV4OiBcImF1dG9cIixcbiAgXCImLnNoYWRvdy1yaWdodDo6YWZ0ZXJcIjoge1xuICAgIGNvbnRlbnQ6IFwiJydcIixcbiAgICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxuICAgIHRvcDogMCxcbiAgICBib3R0b206IDAsXG4gICAgcmlnaHQ6IDAsXG4gICAgd2lkdGg6IFwiMTBweFwiLFxuICAgIGJveFNoYWRvdzogXCJpbnNldCAtMTBweCAwIDhweCAtOHB4IHZhcigtLXZlZi1jb2xvci1zcGxpdClcIixcbiAgICB0cmFuc2l0aW9uOiBgYm94LXNoYWRvdyAke2dsb2JhbENzc1ZhcnMubW90aW9uRHVyYXRpb25NaWR9IGVhc2VgLFxuICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiXG4gIH0sXG4gIFwiJi5zaGFkb3ctbGVmdDo6YmVmb3JlXCI6IHtcbiAgICBjb250ZW50OiBcIicnXCIsXG4gICAgcG9zaXRpb246IFwiYWJzb2x1dGVcIixcbiAgICB0b3A6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIGxlZnQ6IDAsXG4gICAgd2lkdGg6IFwiMTBweFwiLFxuICAgIGJveFNoYWRvdzogXCJpbnNldCAxMHB4IDAgOHB4IC04cHggdmFyKC0tdmVmLWNvbG9yLXNwbGl0KVwiLFxuICAgIHRyYW5zaXRpb246IGBib3gtc2hhZG93ICR7Z2xvYmFsQ3NzVmFycy5tb3Rpb25EdXJhdGlvbk1pZH0gZWFzZWAsXG4gICAgcG9pbnRlckV2ZW50czogXCJub25lXCJcbiAgfVxufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBUYWJzQ29udGFpbmVyKCkge1xuICBjb25zdCB0YWJzQ29udGFpbmVyUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcbiAgY29uc3QgaXNPdmVyZmxvd1JlZiA9IHVzZVJlZihmYWxzZSk7XG4gIGNvbnN0IG92ZXJmbG93V2lkdGhSZWYgPSB1c2VSZWYoMCk7XG4gIGNvbnN0IFtyb290Q2xhc3NOYW1lLCBzZXRSb290Q2xhc3NOYW1lXSA9IHVzZVN0YXRlPE1heWJlVW5kZWZpbmVkPHN0cmluZz4+KCk7XG5cbiAgLy8gVXBkYXRlIG92ZXJmbG93IHN0YXRlIGFuZCBzaGFkb3cgY2xhc3Nlc1xuICBjb25zdCB1cGRhdGVPdmVyZmxvd1N0YXRlID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIGlmICh0YWJzQ29udGFpbmVyUmVmLmN1cnJlbnQpIHtcbiAgICAgIGNvbnN0IGNvbnRhaW5lckVsID0gdGFic0NvbnRhaW5lclJlZi5jdXJyZW50O1xuICAgICAgb3ZlcmZsb3dXaWR0aFJlZi5jdXJyZW50ID0gY29udGFpbmVyRWwuc2Nyb2xsV2lkdGggLSBjb250YWluZXJFbC5jbGllbnRXaWR0aDtcbiAgICAgIGlzT3ZlcmZsb3dSZWYuY3VycmVudCA9IG92ZXJmbG93V2lkdGhSZWYuY3VycmVudCA+IDA7XG4gICAgICBjb25zdCB7IHNjcm9sbExlZnQgfSA9IGNvbnRhaW5lckVsO1xuXG4gICAgICBzZXRSb290Q2xhc3NOYW1lKGNsc3goe1xuICAgICAgICBcInNoYWRvdy1sZWZ0XCI6IHNjcm9sbExlZnQgPiAwLFxuICAgICAgICBcInNoYWRvdy1yaWdodFwiOiBzY3JvbGxMZWZ0IDwgb3ZlcmZsb3dXaWR0aFJlZi5jdXJyZW50XG4gICAgICB9KSk7XG4gICAgfVxuICB9LCBbXSk7XG5cbiAgdXNlSXNvbW9ycGhpY0VmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgY29udGFpbmVyRWwgPSB0YWJzQ29udGFpbmVyUmVmLmN1cnJlbnQ7XG5cbiAgICBpZiAoIWNvbnRhaW5lckVsKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgLy8gSW5pdGlhbCBjYWxjdWxhdGlvblxuICAgIHVwZGF0ZU92ZXJmbG93U3RhdGUoKTtcblxuICAgIC8vIENyZWF0ZSBSZXNpemVPYnNlcnZlciB0byB3YXRjaCBmb3IgY29udGFpbmVyIHNpemUgY2hhbmdlc1xuICAgIGNvbnN0IHJlc2l6ZU9ic2VydmVyID0gbmV3IFJlc2l6ZU9ic2VydmVyKCgpID0+IHtcbiAgICAgIHVwZGF0ZU92ZXJmbG93U3RhdGUoKTtcbiAgICB9KTtcblxuICAgIHJlc2l6ZU9ic2VydmVyLm9ic2VydmUoY29udGFpbmVyRWwpO1xuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIHJlc2l6ZU9ic2VydmVyLmRpc2Nvbm5lY3QoKTtcbiAgICB9O1xuICB9LCBbdXBkYXRlT3ZlcmZsb3dTdGF0ZV0pO1xuXG4gIGNvbnN0IGhhbmRsZVNjcm9sbFBvc2l0aW9uQ2hhbmdlID0gdXNlQ2FsbGJhY2soKHsgeCB9OiBQb3NpdGlvbikgPT4ge1xuICAgIGlmIChpc092ZXJmbG93UmVmLmN1cnJlbnQpIHtcbiAgICAgIHNldFJvb3RDbGFzc05hbWUoY2xzeCh7XG4gICAgICAgIFwic2hhZG93LWxlZnRcIjogeCA+IDAsXG4gICAgICAgIFwic2hhZG93LXJpZ2h0XCI6IHggPCBvdmVyZmxvd1dpZHRoUmVmLmN1cnJlbnRcbiAgICAgIH0pKTtcbiAgICB9XG4gIH0sIFtdKTtcblxuICByZXR1cm4gKFxuICAgIDxTY3JvbGxBcmVhXG4gICAgICBjbGFzc05hbWU9e3Jvb3RDbGFzc05hbWV9XG4gICAgICBjc3M9e3RhYnNXcmFwcGVyU3R5bGV9XG4gICAgICBzY3JvbGxiYXJQYWRkaW5nPXsxfVxuICAgICAgc2Nyb2xsYmFyU2l6ZT17NX1cbiAgICAgIHR5cGU9XCJzY3JvbGxcIlxuICAgICAgdmlld3BvcnRSZWY9e3RhYnNDb250YWluZXJSZWZ9XG4gICAgICBvblNjcm9sbFBvc2l0aW9uQ2hhbmdlPXtoYW5kbGVTY3JvbGxQb3NpdGlvbkNoYW5nZX1cbiAgICA+XG4gICAgICA8VGFiTGlzdCAvPlxuICAgIDwvU2Nyb2xsQXJlYT5cbiAgKTtcbn1cbiJdfQ== */");
|
|
35
|
+
function TabsContainer() {
|
|
36
|
+
const tabsContainerRef = useRef(null);
|
|
37
|
+
const isOverflowRef = useRef(false);
|
|
38
|
+
const overflowWidthRef = useRef(0);
|
|
39
|
+
const [rootClassName, setRootClassName] = useState();
|
|
40
|
+
const updateOverflowState = useCallback(() => {
|
|
41
|
+
if (tabsContainerRef.current) {
|
|
42
|
+
const containerEl = tabsContainerRef.current;
|
|
43
|
+
overflowWidthRef.current = containerEl.scrollWidth - containerEl.clientWidth;
|
|
44
|
+
isOverflowRef.current = overflowWidthRef.current > 0;
|
|
45
|
+
const {
|
|
46
|
+
scrollLeft
|
|
47
|
+
} = containerEl;
|
|
48
|
+
setRootClassName(clsx({
|
|
49
|
+
"shadow-left": scrollLeft > 0,
|
|
50
|
+
"shadow-right": scrollLeft < overflowWidthRef.current
|
|
51
|
+
}));
|
|
52
|
+
}
|
|
53
|
+
}, []);
|
|
54
|
+
useIsomorphicEffect(() => {
|
|
55
|
+
const containerEl = tabsContainerRef.current;
|
|
56
|
+
if (!containerEl) {
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
updateOverflowState();
|
|
60
|
+
const resizeObserver = new ResizeObserver(() => {
|
|
61
|
+
updateOverflowState();
|
|
62
|
+
});
|
|
63
|
+
resizeObserver.observe(containerEl);
|
|
64
|
+
return () => {
|
|
65
|
+
resizeObserver.disconnect();
|
|
66
|
+
};
|
|
67
|
+
}, [updateOverflowState]);
|
|
68
|
+
const handleScrollPositionChange = useCallback(({
|
|
69
|
+
x
|
|
70
|
+
}) => {
|
|
71
|
+
if (isOverflowRef.current) {
|
|
72
|
+
setRootClassName(clsx({
|
|
73
|
+
"shadow-left": x > 0,
|
|
74
|
+
"shadow-right": x < overflowWidthRef.current
|
|
75
|
+
}));
|
|
76
|
+
}
|
|
77
|
+
}, []);
|
|
78
|
+
return /* @__PURE__ */ jsx(ScrollArea, { className: rootClassName, css: tabsWrapperStyle, scrollbarPadding: 1, scrollbarSize: 5, type: "scroll", viewportRef: tabsContainerRef, onScrollPositionChange: handleScrollPositionChange, children: /* @__PURE__ */ jsx(TabList, {}) });
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
export { TabsContainer };
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { css } from '@emotion/react';
|
|
4
|
+
import { globalCssVars, Center, Icon, Segmented } from '@vef-framework/components';
|
|
5
|
+
import { SunIcon, MoonIcon, SunMoon } from 'lucide-react';
|
|
6
|
+
import { useRef } from 'react';
|
|
7
|
+
import '../../../../stores/index.js';
|
|
8
|
+
import '../../hooks/index.js';
|
|
9
|
+
import { useThemeStore } from '../../../../stores/theme.js';
|
|
10
|
+
import { useColorSchemeUpdater } from '../../hooks/use-color-scheme-updater.js';
|
|
11
|
+
|
|
12
|
+
const itemStyle = /* @__PURE__ */ css({
|
|
13
|
+
height: `calc(${globalCssVars.controlHeight} - var(--vef-segmented-track-padding) * 2)`,
|
|
14
|
+
width: "64px"
|
|
15
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9jb2xvci1zY2hlbWUtc3dpdGNoZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVlrQiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90aGVtZS1jb25maWcvY29sb3Itc2NoZW1lLXN3aXRjaGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUG9zaXRpb24sIFNlZ21lbnRlZE9wdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmltcG9ydCB0eXBlIHsgQ29sb3JTY2hlbWUgfSBmcm9tIFwiLi4vLi4vLi4vLi4vc3RvcmVzXCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgQ2VudGVyLCBnbG9iYWxDc3NWYXJzLCBJY29uLCBTZWdtZW50ZWQgfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuaW1wb3J0IHsgTW9vbkljb24sIFN1bkljb24sIFN1bk1vb24gfSBmcm9tIFwibHVjaWRlLXJlYWN0XCI7XG5pbXBvcnQgeyB1c2VSZWYgfSBmcm9tIFwicmVhY3RcIjtcblxuaW1wb3J0IHsgdXNlVGhlbWVTdG9yZSB9IGZyb20gXCIuLi8uLi8uLi8uLi9zdG9yZXNcIjtcbmltcG9ydCB7IHVzZUNvbG9yU2NoZW1lVXBkYXRlciB9IGZyb20gXCIuLi8uLi9ob29rc1wiO1xuXG5jb25zdCBpdGVtU3R5bGUgPSBjc3Moe1xuICBoZWlnaHQ6IGBjYWxjKCR7Z2xvYmFsQ3NzVmFycy5jb250cm9sSGVpZ2h0fSAtIHZhcigtLXZlZi1zZWdtZW50ZWQtdHJhY2stcGFkZGluZykgKiAyKWAsXG4gIHdpZHRoOiBcIjY0cHhcIlxufSk7XG5cbmNvbnN0IG9wdGlvbnM6IFNlZ21lbnRlZE9wdGlvbltdID0gW1xuICB7XG4gICAgbGFiZWw6IChcbiAgICAgIDxDZW50ZXIgY3NzPXtpdGVtU3R5bGV9PlxuICAgICAgICA8SWNvbiBjb21wb25lbnQ9e1N1bkljb259IC8+XG4gICAgICA8L0NlbnRlcj5cbiAgICApLFxuICAgIHZhbHVlOiBcImxpZ2h0XCJcbiAgfSxcbiAge1xuICAgIGxhYmVsOiAoXG4gICAgICA8Q2VudGVyIGNzcz17aXRlbVN0eWxlfT5cbiAgICAgICAgPEljb24gY29tcG9uZW50PXtNb29uSWNvbn0gLz5cbiAgICAgIDwvQ2VudGVyPlxuICAgICksXG4gICAgdmFsdWU6IFwiZGFya1wiXG4gIH0sXG4gIHtcbiAgICBsYWJlbDogKFxuICAgICAgPENlbnRlciBjc3M9e2l0ZW1TdHlsZX0+XG4gICAgICAgIDxJY29uIGNvbXBvbmVudD17U3VuTW9vbn0gLz5cbiAgICAgIDwvQ2VudGVyPlxuICAgICksXG4gICAgdmFsdWU6IFwic3lzdGVtXCJcbiAgfVxuXTtcblxuZXhwb3J0IGZ1bmN0aW9uIENvbG9yU2NoZW1lU3dpdGNoZXIoKSB7XG4gIGNvbnN0IGNvbG9yU2NoZW1lID0gdXNlVGhlbWVTdG9yZShzdGF0ZSA9PiBzdGF0ZS5jb2xvclNjaGVtZSk7XG4gIGNvbnN0IHsgdXBkYXRlQ29sb3JTY2hlbWUgfSA9IHVzZUNvbG9yU2NoZW1lVXBkYXRlcigpO1xuICBjb25zdCBwb3NpdGlvblJlZiA9IHVzZVJlZjxQb3NpdGlvbj4oe1xuICAgIHg6IHdpbmRvdy5pbm5lcldpZHRoIC8gMixcbiAgICB5OiB3aW5kb3cuaW5uZXJIZWlnaHQgLyAyXG4gIH0pO1xuXG4gIHJldHVybiAoXG4gICAgPFNlZ21lbnRlZFxuICAgICAgb3B0aW9ucz17b3B0aW9uc31cbiAgICAgIHZhbHVlPXtjb2xvclNjaGVtZX1cbiAgICAgIG9uQ2hhbmdlPXt2YWx1ZSA9PiB7XG4gICAgICAgIHVwZGF0ZUNvbG9yU2NoZW1lKHZhbHVlIGFzIENvbG9yU2NoZW1lLCBwb3NpdGlvblJlZi5jdXJyZW50KTtcbiAgICAgIH19XG4gICAgICBvbkNsaWNrPXtldmVudCA9PiB7XG4gICAgICAgIHBvc2l0aW9uUmVmLmN1cnJlbnQgPSB7XG4gICAgICAgICAgeDogZXZlbnQuY2xpZW50WCxcbiAgICAgICAgICB5OiBldmVudC5jbGllbnRZXG4gICAgICAgIH07XG4gICAgICB9fVxuICAgIC8+XG4gICk7XG59XG4iXX0= */");
|
|
16
|
+
const options = [{
|
|
17
|
+
label: /* @__PURE__ */ jsx(Center, { css: itemStyle, children: /* @__PURE__ */ jsx(Icon, { component: SunIcon }) }),
|
|
18
|
+
value: "light"
|
|
19
|
+
}, {
|
|
20
|
+
label: /* @__PURE__ */ jsx(Center, { css: itemStyle, children: /* @__PURE__ */ jsx(Icon, { component: MoonIcon }) }),
|
|
21
|
+
value: "dark"
|
|
22
|
+
}, {
|
|
23
|
+
label: /* @__PURE__ */ jsx(Center, { css: itemStyle, children: /* @__PURE__ */ jsx(Icon, { component: SunMoon }) }),
|
|
24
|
+
value: "system"
|
|
25
|
+
}];
|
|
26
|
+
function ColorSchemeSwitcher() {
|
|
27
|
+
const colorScheme = useThemeStore((state) => state.colorScheme);
|
|
28
|
+
const {
|
|
29
|
+
updateColorScheme
|
|
30
|
+
} = useColorSchemeUpdater();
|
|
31
|
+
const positionRef = useRef({
|
|
32
|
+
x: window.innerWidth / 2,
|
|
33
|
+
y: window.innerHeight / 2
|
|
34
|
+
});
|
|
35
|
+
return /* @__PURE__ */ jsx(Segmented, { options, value: colorScheme, onChange: (value) => {
|
|
36
|
+
updateColorScheme(value, positionRef.current);
|
|
37
|
+
}, onClick: (event) => {
|
|
38
|
+
positionRef.current = {
|
|
39
|
+
x: event.clientX,
|
|
40
|
+
y: event.clientY
|
|
41
|
+
};
|
|
42
|
+
} });
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export { ColorSchemeSwitcher };
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { jsxs, jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { css } from '@emotion/react';
|
|
4
|
+
import { globalCssVars, Center, Switch } from '@vef-framework/components';
|
|
5
|
+
import { useShallow } from '@vef-framework/core';
|
|
6
|
+
import '../../../../stores/index.js';
|
|
7
|
+
import { ColorSchemeSwitcher } from './color-scheme-switcher.js';
|
|
8
|
+
import { ConfigItem } from './config-item.js';
|
|
9
|
+
import { useThemeStore } from '../../../../stores/theme.js';
|
|
10
|
+
|
|
11
|
+
const wrapperStyle = /* @__PURE__ */ css({
|
|
12
|
+
display: "flex",
|
|
13
|
+
flexDirection: "column",
|
|
14
|
+
gap: globalCssVars.spacingMd
|
|
15
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9jb2xvci1zY2hlbWUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFxQiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90aGVtZS1jb25maWcvY29sb3Itc2NoZW1lLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgQ2VudGVyLCBnbG9iYWxDc3NWYXJzLCBTd2l0Y2ggfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuaW1wb3J0IHsgdXNlU2hhbGxvdyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb3JlXCI7XG5cbmltcG9ydCB7IHVzZVRoZW1lU3RvcmUgfSBmcm9tIFwiLi4vLi4vLi4vLi4vc3RvcmVzXCI7XG5pbXBvcnQgeyBDb2xvclNjaGVtZVN3aXRjaGVyIH0gZnJvbSBcIi4vY29sb3Itc2NoZW1lLXN3aXRjaGVyXCI7XG5pbXBvcnQgeyBDb25maWdJdGVtIH0gZnJvbSBcIi4vY29uZmlnLWl0ZW1cIjtcblxuY29uc3Qgd3JhcHBlclN0eWxlID0gY3NzKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gIGdhcDogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nTWRcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gQ29sb3JTY2hlbWUoKSB7XG4gIGNvbnN0IHtcbiAgICBpc0dyYXlzY2FsZU1vZGUsXG4gICAgaXNDb2xvckJsaW5kTW9kZSxcbiAgICBpc01lbnVBY2NvcmRpb25Nb2RlXG4gIH0gPSB1c2VUaGVtZVN0b3JlKFxuICAgIHVzZVNoYWxsb3coXG4gICAgICBzdGF0ZSA9PiB7XG4gICAgICAgIGNvbnN0IHtcbiAgICAgICAgICBpc0dyYXlzY2FsZU1vZGUsXG4gICAgICAgICAgaXNDb2xvckJsaW5kTW9kZSxcbiAgICAgICAgICBpc01lbnVBY2NvcmRpb25Nb2RlXG4gICAgICAgIH0gPSBzdGF0ZTtcblxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIGlzR3JheXNjYWxlTW9kZSxcbiAgICAgICAgICBpc0NvbG9yQmxpbmRNb2RlLFxuICAgICAgICAgIGlzTWVudUFjY29yZGlvbk1vZGVcbiAgICAgICAgfTtcbiAgICAgIH1cbiAgICApXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17d3JhcHBlclN0eWxlfT5cbiAgICAgIDxDZW50ZXI+XG4gICAgICAgIDxDb2xvclNjaGVtZVN3aXRjaGVyIC8+XG4gICAgICA8L0NlbnRlcj5cblxuICAgICAgPENvbmZpZ0l0ZW0gbGFiZWw9XCLngbDluqbmqKHlvI9cIj5cbiAgICAgICAgPFN3aXRjaFxuICAgICAgICAgIGNoZWNrZWQ9e2lzR3JheXNjYWxlTW9kZX1cbiAgICAgICAgICBvbkNoYW5nZT17XG4gICAgICAgICAgICB2YWx1ZSA9PiB7XG4gICAgICAgICAgICAgIHVzZVRoZW1lU3RvcmUuc2V0U3RhdGUoc3RhdGUgPT4ge1xuICAgICAgICAgICAgICAgIHN0YXRlLmlzR3JheXNjYWxlTW9kZSA9IHZhbHVlO1xuICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L0NvbmZpZ0l0ZW0+XG5cbiAgICAgIDxDb25maWdJdGVtIGxhYmVsPVwi6Imy5byx5qih5byPXCI+XG4gICAgICAgIDxTd2l0Y2hcbiAgICAgICAgICBjaGVja2VkPXtpc0NvbG9yQmxpbmRNb2RlfVxuICAgICAgICAgIG9uQ2hhbmdlPXtcbiAgICAgICAgICAgIHZhbHVlID0+IHtcbiAgICAgICAgICAgICAgdXNlVGhlbWVTdG9yZS5zZXRTdGF0ZShzdGF0ZSA9PiB7XG4gICAgICAgICAgICAgICAgc3RhdGUuaXNDb2xvckJsaW5kTW9kZSA9IHZhbHVlO1xuICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L0NvbmZpZ0l0ZW0+XG5cbiAgICAgIDxDb25maWdJdGVtIGxhYmVsPVwi6I+c5Y2V5omL6aOO55C05qih5byPXCI+XG4gICAgICAgIDxTd2l0Y2hcbiAgICAgICAgICBjaGVja2VkPXtpc01lbnVBY2NvcmRpb25Nb2RlfVxuICAgICAgICAgIG9uQ2hhbmdlPXtcbiAgICAgICAgICAgIHZhbHVlID0+IHtcbiAgICAgICAgICAgICAgdXNlVGhlbWVTdG9yZS5zZXRTdGF0ZShzdGF0ZSA9PiB7XG4gICAgICAgICAgICAgICAgc3RhdGUuaXNNZW51QWNjb3JkaW9uTW9kZSA9IHZhbHVlO1xuICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L0NvbmZpZ0l0ZW0+XG4gICAgPC9kaXY+XG4gICk7XG59XG4iXX0= */");
|
|
16
|
+
function ColorScheme() {
|
|
17
|
+
const {
|
|
18
|
+
isGrayscaleMode,
|
|
19
|
+
isColorBlindMode,
|
|
20
|
+
isMenuAccordionMode
|
|
21
|
+
} = useThemeStore(useShallow((state) => {
|
|
22
|
+
const {
|
|
23
|
+
isGrayscaleMode: isGrayscaleMode2,
|
|
24
|
+
isColorBlindMode: isColorBlindMode2,
|
|
25
|
+
isMenuAccordionMode: isMenuAccordionMode2
|
|
26
|
+
} = state;
|
|
27
|
+
return {
|
|
28
|
+
isGrayscaleMode: isGrayscaleMode2,
|
|
29
|
+
isColorBlindMode: isColorBlindMode2,
|
|
30
|
+
isMenuAccordionMode: isMenuAccordionMode2
|
|
31
|
+
};
|
|
32
|
+
}));
|
|
33
|
+
return /* @__PURE__ */ jsxs("div", { css: wrapperStyle, children: [
|
|
34
|
+
/* @__PURE__ */ jsx(Center, { children: /* @__PURE__ */ jsx(ColorSchemeSwitcher, {}) }),
|
|
35
|
+
/* @__PURE__ */ jsx(ConfigItem, { label: "灰度模式", children: /* @__PURE__ */ jsx(Switch, { checked: isGrayscaleMode, onChange: (value) => {
|
|
36
|
+
useThemeStore.setState((state) => {
|
|
37
|
+
state.isGrayscaleMode = value;
|
|
38
|
+
});
|
|
39
|
+
} }) }),
|
|
40
|
+
/* @__PURE__ */ jsx(ConfigItem, { label: "色弱模式", children: /* @__PURE__ */ jsx(Switch, { checked: isColorBlindMode, onChange: (value) => {
|
|
41
|
+
useThemeStore.setState((state) => {
|
|
42
|
+
state.isColorBlindMode = value;
|
|
43
|
+
});
|
|
44
|
+
} }) }),
|
|
45
|
+
/* @__PURE__ */ jsx(ConfigItem, { label: "菜单手风琴模式", children: /* @__PURE__ */ jsx(Switch, { checked: isMenuAccordionMode, onChange: (value) => {
|
|
46
|
+
useThemeStore.setState((state) => {
|
|
47
|
+
state.isMenuAccordionMode = value;
|
|
48
|
+
});
|
|
49
|
+
} }) })
|
|
50
|
+
] });
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
export { ColorScheme };
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { jsxs, jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { css } from '@emotion/react';
|
|
4
|
+
import { globalCssVars } from '@vef-framework/components';
|
|
5
|
+
|
|
6
|
+
const itemStyle = /* @__PURE__ */ css({
|
|
7
|
+
display: "flex",
|
|
8
|
+
alignItems: "center",
|
|
9
|
+
justifyContent: "space-between",
|
|
10
|
+
columnGap: globalCssVars.spacingXs
|
|
11
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9jb25maWctaXRlbS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVWtCIiwiZmlsZSI6Ii9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9jb25maWctaXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFByb3BzV2l0aENoaWxkcmVuLCBSZWFjdE5vZGUgfSBmcm9tIFwicmVhY3RcIjtcblxuaW1wb3J0IHsgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgeyBnbG9iYWxDc3NWYXJzIH0gZnJvbSBcIkB2ZWYtZnJhbWV3b3JrL2NvbXBvbmVudHNcIjtcblxuaW50ZXJmYWNlIENvbmZpZ0l0ZW1Qcm9wcyBleHRlbmRzIFByb3BzV2l0aENoaWxkcmVuIHtcbiAgY2xhc3NOYW1lPzogc3RyaW5nO1xuICBsYWJlbDogUmVhY3ROb2RlO1xufVxuXG5jb25zdCBpdGVtU3R5bGUgPSBjc3Moe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbiAganVzdGlmeUNvbnRlbnQ6IFwic3BhY2UtYmV0d2VlblwiLFxuICBjb2x1bW5HYXA6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ1hzXG59KTtcblxuZXhwb3J0IGZ1bmN0aW9uIENvbmZpZ0l0ZW0oe1xuICBjbGFzc05hbWUsXG4gIGxhYmVsLFxuICBjaGlsZHJlblxufTogQ29uZmlnSXRlbVByb3BzKSB7XG4gIHJldHVybiAoXG4gICAgPGRpdiBjbGFzc05hbWU9e2NsYXNzTmFtZX0gY3NzPXtpdGVtU3R5bGV9PlxuICAgICAgPHNwYW4+XG4gICAgICAgIHtsYWJlbH1cbiAgICAgIDwvc3Bhbj5cblxuICAgICAge2NoaWxkcmVufVxuICAgIDwvZGl2PlxuICApO1xufVxuIl19 */");
|
|
12
|
+
function ConfigItem({
|
|
13
|
+
className,
|
|
14
|
+
label,
|
|
15
|
+
children
|
|
16
|
+
}) {
|
|
17
|
+
return /* @__PURE__ */ jsxs("div", { className, css: itemStyle, children: [
|
|
18
|
+
/* @__PURE__ */ jsx("span", { children: label }),
|
|
19
|
+
children
|
|
20
|
+
] });
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export { ConfigItem };
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { jsx, jsxs } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { css, ClassNames } from '@emotion/react';
|
|
4
|
+
import { globalCssVars, Drawer, ScrollArea, Divider } from '@vef-framework/components';
|
|
5
|
+
import '../../../../stores/index.js';
|
|
6
|
+
import { ColorScheme } from './color-scheme.js';
|
|
7
|
+
import { MenuLayout } from './menu-layout.js';
|
|
8
|
+
import { Operations } from './operations.js';
|
|
9
|
+
import { ThemeColors } from './theme-colors.js';
|
|
10
|
+
import { useThemeStore } from '../../../../stores/theme.js';
|
|
11
|
+
|
|
12
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
13
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
14
|
+
}
|
|
15
|
+
const drawerBodyStyle = process.env.NODE_ENV === "production" ? {
|
|
16
|
+
name: "1hcx8jb",
|
|
17
|
+
styles: "padding:0"
|
|
18
|
+
} : {
|
|
19
|
+
name: "1hcx8jb",
|
|
20
|
+
styles: "padding:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBU3dCIiwiZmlsZSI6Ii9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDbGFzc05hbWVzLCBjc3MgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB7IERpdmlkZXIsIERyYXdlciwgZ2xvYmFsQ3NzVmFycywgU2Nyb2xsQXJlYSB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmltcG9ydCB7IHVzZVRoZW1lU3RvcmUgfSBmcm9tIFwiLi4vLi4vLi4vLi4vc3RvcmVzXCI7XG5pbXBvcnQgeyBDb2xvclNjaGVtZSB9IGZyb20gXCIuL2NvbG9yLXNjaGVtZVwiO1xuaW1wb3J0IHsgTWVudUxheW91dCB9IGZyb20gXCIuL21lbnUtbGF5b3V0XCI7XG5pbXBvcnQgeyBPcGVyYXRpb25zIH0gZnJvbSBcIi4vb3BlcmF0aW9uc1wiO1xuaW1wb3J0IHsgVGhlbWVDb2xvcnMgfSBmcm9tIFwiLi90aGVtZS1jb2xvcnNcIjtcblxuY29uc3QgZHJhd2VyQm9keVN0eWxlID0gY3NzKHtcbiAgcGFkZGluZzogMFxufSk7XG5jb25zdCBjb250ZW50U3R5bGUgPSBjc3Moe1xuICBoZWlnaHQ6IFwiMTAwJVwiLFxuICBwYWRkaW5nSW5saW5lOiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdTbSxcbiAgcGFkZGluZ0Jsb2NrU3RhcnQ6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ1hzLFxuICBwYWRkaW5nQmxvY2tFbmQ6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ0xnXG59KTtcblxuY29uc3QgY29udGFpbmVyU3R5bGUgPSBjc3Moe1xuICBwYWRkaW5nSW5saW5lOiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdYc1xufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBUaGVtZUNvbmZpZygpIHtcbiAgY29uc3QgaXNUaGVtZUNvbmZpZ1Zpc2libGUgPSB1c2VUaGVtZVN0b3JlKHN0YXRlID0+IHN0YXRlLmlzVGhlbWVDb25maWdWaXNpYmxlKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZSA9ICgpID0+IHtcbiAgICB1c2VUaGVtZVN0b3JlLnNldFN0YXRlKHN0YXRlID0+IHtcbiAgICAgIHN0YXRlLmlzVGhlbWVDb25maWdWaXNpYmxlID0gZmFsc2U7XG4gICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Q2xhc3NOYW1lcz5cbiAgICAgIHsoeyBjc3MgfSkgPT4gKFxuICAgICAgICA8RHJhd2VyXG4gICAgICAgICAgY2xvc2FibGU9e3sgcGxhY2VtZW50OiBcImVuZFwiIH19XG4gICAgICAgICAgb3Blbj17aXNUaGVtZUNvbmZpZ1Zpc2libGV9XG4gICAgICAgICAgdGl0bGU9XCLkuLvpopjphY3nva5cIlxuICAgICAgICAgIGNsYXNzTmFtZXM9e3tcbiAgICAgICAgICAgIGJvZHk6IGNzcyhkcmF3ZXJCb2R5U3R5bGUpXG4gICAgICAgICAgfX1cbiAgICAgICAgICBmb290ZXI9e1xuICAgICAgICAgICAgPE9wZXJhdGlvbnMgLz5cbiAgICAgICAgICB9XG4gICAgICAgICAgb25DbG9zZT17aGFuZGxlQ2xvc2V9XG4gICAgICAgID5cbiAgICAgICAgICA8U2Nyb2xsQXJlYVxuICAgICAgICAgICAgY2xhc3NOYW1lPXtjc3MoY29udGVudFN0eWxlKX1cbiAgICAgICAgICAgIHZpZXdwb3J0Q2xhc3NOYW1lPXtjc3MoY29udGFpbmVyU3R5bGUpfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxEaXZpZGVyPuS4u+mimOaooeW8jzwvRGl2aWRlcj5cbiAgICAgICAgICAgIDxDb2xvclNjaGVtZSAvPlxuICAgICAgICAgICAgPERpdmlkZXI+6I+c5Y2V5biD5bGAPC9EaXZpZGVyPlxuICAgICAgICAgICAgPE1lbnVMYXlvdXQgLz5cbiAgICAgICAgICAgIDxEaXZpZGVyPuS4u+mimOminOiJsjwvRGl2aWRlcj5cbiAgICAgICAgICAgIDxUaGVtZUNvbG9ycyAvPlxuICAgICAgICAgIDwvU2Nyb2xsQXJlYT5cbiAgICAgICAgPC9EcmF3ZXI+XG4gICAgICApfVxuICAgIDwvQ2xhc3NOYW1lcz5cbiAgKTtcbn1cbiJdfQ== */",
|
|
21
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
22
|
+
};
|
|
23
|
+
const contentStyle = /* @__PURE__ */ css({
|
|
24
|
+
height: "100%",
|
|
25
|
+
paddingInline: globalCssVars.spacingSm,
|
|
26
|
+
paddingBlockStart: globalCssVars.spacingXs,
|
|
27
|
+
paddingBlockEnd: globalCssVars.spacingLg
|
|
28
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWXFCIiwiZmlsZSI6Ii9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDbGFzc05hbWVzLCBjc3MgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB7IERpdmlkZXIsIERyYXdlciwgZ2xvYmFsQ3NzVmFycywgU2Nyb2xsQXJlYSB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmltcG9ydCB7IHVzZVRoZW1lU3RvcmUgfSBmcm9tIFwiLi4vLi4vLi4vLi4vc3RvcmVzXCI7XG5pbXBvcnQgeyBDb2xvclNjaGVtZSB9IGZyb20gXCIuL2NvbG9yLXNjaGVtZVwiO1xuaW1wb3J0IHsgTWVudUxheW91dCB9IGZyb20gXCIuL21lbnUtbGF5b3V0XCI7XG5pbXBvcnQgeyBPcGVyYXRpb25zIH0gZnJvbSBcIi4vb3BlcmF0aW9uc1wiO1xuaW1wb3J0IHsgVGhlbWVDb2xvcnMgfSBmcm9tIFwiLi90aGVtZS1jb2xvcnNcIjtcblxuY29uc3QgZHJhd2VyQm9keVN0eWxlID0gY3NzKHtcbiAgcGFkZGluZzogMFxufSk7XG5jb25zdCBjb250ZW50U3R5bGUgPSBjc3Moe1xuICBoZWlnaHQ6IFwiMTAwJVwiLFxuICBwYWRkaW5nSW5saW5lOiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdTbSxcbiAgcGFkZGluZ0Jsb2NrU3RhcnQ6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ1hzLFxuICBwYWRkaW5nQmxvY2tFbmQ6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ0xnXG59KTtcblxuY29uc3QgY29udGFpbmVyU3R5bGUgPSBjc3Moe1xuICBwYWRkaW5nSW5saW5lOiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdYc1xufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBUaGVtZUNvbmZpZygpIHtcbiAgY29uc3QgaXNUaGVtZUNvbmZpZ1Zpc2libGUgPSB1c2VUaGVtZVN0b3JlKHN0YXRlID0+IHN0YXRlLmlzVGhlbWVDb25maWdWaXNpYmxlKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZSA9ICgpID0+IHtcbiAgICB1c2VUaGVtZVN0b3JlLnNldFN0YXRlKHN0YXRlID0+IHtcbiAgICAgIHN0YXRlLmlzVGhlbWVDb25maWdWaXNpYmxlID0gZmFsc2U7XG4gICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Q2xhc3NOYW1lcz5cbiAgICAgIHsoeyBjc3MgfSkgPT4gKFxuICAgICAgICA8RHJhd2VyXG4gICAgICAgICAgY2xvc2FibGU9e3sgcGxhY2VtZW50OiBcImVuZFwiIH19XG4gICAgICAgICAgb3Blbj17aXNUaGVtZUNvbmZpZ1Zpc2libGV9XG4gICAgICAgICAgdGl0bGU9XCLkuLvpopjphY3nva5cIlxuICAgICAgICAgIGNsYXNzTmFtZXM9e3tcbiAgICAgICAgICAgIGJvZHk6IGNzcyhkcmF3ZXJCb2R5U3R5bGUpXG4gICAgICAgICAgfX1cbiAgICAgICAgICBmb290ZXI9e1xuICAgICAgICAgICAgPE9wZXJhdGlvbnMgLz5cbiAgICAgICAgICB9XG4gICAgICAgICAgb25DbG9zZT17aGFuZGxlQ2xvc2V9XG4gICAgICAgID5cbiAgICAgICAgICA8U2Nyb2xsQXJlYVxuICAgICAgICAgICAgY2xhc3NOYW1lPXtjc3MoY29udGVudFN0eWxlKX1cbiAgICAgICAgICAgIHZpZXdwb3J0Q2xhc3NOYW1lPXtjc3MoY29udGFpbmVyU3R5bGUpfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxEaXZpZGVyPuS4u+mimOaooeW8jzwvRGl2aWRlcj5cbiAgICAgICAgICAgIDxDb2xvclNjaGVtZSAvPlxuICAgICAgICAgICAgPERpdmlkZXI+6I+c5Y2V5biD5bGAPC9EaXZpZGVyPlxuICAgICAgICAgICAgPE1lbnVMYXlvdXQgLz5cbiAgICAgICAgICAgIDxEaXZpZGVyPuS4u+mimOminOiJsjwvRGl2aWRlcj5cbiAgICAgICAgICAgIDxUaGVtZUNvbG9ycyAvPlxuICAgICAgICAgIDwvU2Nyb2xsQXJlYT5cbiAgICAgICAgPC9EcmF3ZXI+XG4gICAgICApfVxuICAgIDwvQ2xhc3NOYW1lcz5cbiAgKTtcbn1cbiJdfQ== */");
|
|
29
|
+
const containerStyle = /* @__PURE__ */ css({
|
|
30
|
+
paddingInline: globalCssVars.spacingXs
|
|
31
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJ1QiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90aGVtZS1jb25maWcvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2xhc3NOYW1lcywgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgeyBEaXZpZGVyLCBEcmF3ZXIsIGdsb2JhbENzc1ZhcnMsIFNjcm9sbEFyZWEgfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuXG5pbXBvcnQgeyB1c2VUaGVtZVN0b3JlIH0gZnJvbSBcIi4uLy4uLy4uLy4uL3N0b3Jlc1wiO1xuaW1wb3J0IHsgQ29sb3JTY2hlbWUgfSBmcm9tIFwiLi9jb2xvci1zY2hlbWVcIjtcbmltcG9ydCB7IE1lbnVMYXlvdXQgfSBmcm9tIFwiLi9tZW51LWxheW91dFwiO1xuaW1wb3J0IHsgT3BlcmF0aW9ucyB9IGZyb20gXCIuL29wZXJhdGlvbnNcIjtcbmltcG9ydCB7IFRoZW1lQ29sb3JzIH0gZnJvbSBcIi4vdGhlbWUtY29sb3JzXCI7XG5cbmNvbnN0IGRyYXdlckJvZHlTdHlsZSA9IGNzcyh7XG4gIHBhZGRpbmc6IDBcbn0pO1xuY29uc3QgY29udGVudFN0eWxlID0gY3NzKHtcbiAgaGVpZ2h0OiBcIjEwMCVcIixcbiAgcGFkZGluZ0lubGluZTogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nU20sXG4gIHBhZGRpbmdCbG9ja1N0YXJ0OiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdYcyxcbiAgcGFkZGluZ0Jsb2NrRW5kOiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdMZ1xufSk7XG5cbmNvbnN0IGNvbnRhaW5lclN0eWxlID0gY3NzKHtcbiAgcGFkZGluZ0lubGluZTogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nWHNcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gVGhlbWVDb25maWcoKSB7XG4gIGNvbnN0IGlzVGhlbWVDb25maWdWaXNpYmxlID0gdXNlVGhlbWVTdG9yZShzdGF0ZSA9PiBzdGF0ZS5pc1RoZW1lQ29uZmlnVmlzaWJsZSk7XG5cbiAgY29uc3QgaGFuZGxlQ2xvc2UgPSAoKSA9PiB7XG4gICAgdXNlVGhlbWVTdG9yZS5zZXRTdGF0ZShzdGF0ZSA9PiB7XG4gICAgICBzdGF0ZS5pc1RoZW1lQ29uZmlnVmlzaWJsZSA9IGZhbHNlO1xuICAgIH0pO1xuICB9O1xuXG4gIHJldHVybiAoXG4gICAgPENsYXNzTmFtZXM+XG4gICAgICB7KHsgY3NzIH0pID0+IChcbiAgICAgICAgPERyYXdlclxuICAgICAgICAgIGNsb3NhYmxlPXt7IHBsYWNlbWVudDogXCJlbmRcIiB9fVxuICAgICAgICAgIG9wZW49e2lzVGhlbWVDb25maWdWaXNpYmxlfVxuICAgICAgICAgIHRpdGxlPVwi5Li76aKY6YWN572uXCJcbiAgICAgICAgICBjbGFzc05hbWVzPXt7XG4gICAgICAgICAgICBib2R5OiBjc3MoZHJhd2VyQm9keVN0eWxlKVxuICAgICAgICAgIH19XG4gICAgICAgICAgZm9vdGVyPXtcbiAgICAgICAgICAgIDxPcGVyYXRpb25zIC8+XG4gICAgICAgICAgfVxuICAgICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlfVxuICAgICAgICA+XG4gICAgICAgICAgPFNjcm9sbEFyZWFcbiAgICAgICAgICAgIGNsYXNzTmFtZT17Y3NzKGNvbnRlbnRTdHlsZSl9XG4gICAgICAgICAgICB2aWV3cG9ydENsYXNzTmFtZT17Y3NzKGNvbnRhaW5lclN0eWxlKX1cbiAgICAgICAgICA+XG4gICAgICAgICAgICA8RGl2aWRlcj7kuLvpopjmqKHlvI88L0RpdmlkZXI+XG4gICAgICAgICAgICA8Q29sb3JTY2hlbWUgLz5cbiAgICAgICAgICAgIDxEaXZpZGVyPuiPnOWNleW4g+WxgDwvRGl2aWRlcj5cbiAgICAgICAgICAgIDxNZW51TGF5b3V0IC8+XG4gICAgICAgICAgICA8RGl2aWRlcj7kuLvpopjpopzoibI8L0RpdmlkZXI+XG4gICAgICAgICAgICA8VGhlbWVDb2xvcnMgLz5cbiAgICAgICAgICA8L1Njcm9sbEFyZWE+XG4gICAgICAgIDwvRHJhd2VyPlxuICAgICAgKX1cbiAgICA8L0NsYXNzTmFtZXM+XG4gICk7XG59XG4iXX0= */");
|
|
32
|
+
function ThemeConfig() {
|
|
33
|
+
const isThemeConfigVisible = useThemeStore((state) => state.isThemeConfigVisible);
|
|
34
|
+
const handleClose = () => {
|
|
35
|
+
useThemeStore.setState((state) => {
|
|
36
|
+
state.isThemeConfigVisible = false;
|
|
37
|
+
});
|
|
38
|
+
};
|
|
39
|
+
return /* @__PURE__ */ jsx(ClassNames, { children: ({
|
|
40
|
+
css: css2
|
|
41
|
+
}) => /* @__PURE__ */ jsx(Drawer, { closable: {
|
|
42
|
+
placement: "end"
|
|
43
|
+
}, open: isThemeConfigVisible, title: "主题配置", classNames: {
|
|
44
|
+
body: css2(drawerBodyStyle)
|
|
45
|
+
}, footer: /* @__PURE__ */ jsx(Operations, {}), onClose: handleClose, children: /* @__PURE__ */ jsxs(ScrollArea, { className: css2(contentStyle), viewportClassName: css2(containerStyle), children: [
|
|
46
|
+
/* @__PURE__ */ jsx(Divider, { children: "主题模式" }),
|
|
47
|
+
/* @__PURE__ */ jsx(ColorScheme, {}),
|
|
48
|
+
/* @__PURE__ */ jsx(Divider, { children: "菜单布局" }),
|
|
49
|
+
/* @__PURE__ */ jsx(MenuLayout, {}),
|
|
50
|
+
/* @__PURE__ */ jsx(Divider, { children: "主题颜色" }),
|
|
51
|
+
/* @__PURE__ */ jsx(ThemeColors, {})
|
|
52
|
+
] }) }) });
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
export { ThemeConfig };
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { jsxs, jsx, Fragment } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { css } from '@emotion/react';
|
|
4
|
+
import { globalCssVars } from '@vef-framework/components';
|
|
5
|
+
|
|
6
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
7
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
8
|
+
}
|
|
9
|
+
const cardStyle = /* @__PURE__ */ css({
|
|
10
|
+
cursor: "pointer",
|
|
11
|
+
display: "flex",
|
|
12
|
+
height: "68px",
|
|
13
|
+
width: "96px",
|
|
14
|
+
gap: "6px",
|
|
15
|
+
padding: "6px",
|
|
16
|
+
border: `2px solid transparent`,
|
|
17
|
+
borderRadius: globalCssVars.borderRadius,
|
|
18
|
+
boxShadow: globalCssVars.shadowSm,
|
|
19
|
+
transition: `border-color ${globalCssVars.motionDurationMid} ease`,
|
|
20
|
+
"&:hover": {
|
|
21
|
+
borderColor: globalCssVars.colorPrimary
|
|
22
|
+
},
|
|
23
|
+
"&.selected": {
|
|
24
|
+
borderColor: globalCssVars.colorPrimary
|
|
25
|
+
},
|
|
26
|
+
".dark &": {
|
|
27
|
+
boxShadow: "0 1px 3px 0 rgb(255 255 255 / 0.3), 0 1px 2px -1px rgb(255 255 255 / 0.3)"
|
|
28
|
+
}
|
|
29
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9tZW51LWxheW91dC1jYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVa0IiLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGhlbWUtY29uZmlnL21lbnUtbGF5b3V0LWNhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPcmllbnRhdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmludGVyZmFjZSBNZW51TGF5b3V0Q2FyZFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8XCJkaXZcIj4ge1xuICBtb2RlOiBPcmllbnRhdGlvbjtcbn1cblxuY29uc3QgY2FyZFN0eWxlID0gY3NzKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGhlaWdodDogXCI2OHB4XCIsXG4gIHdpZHRoOiBcIjk2cHhcIixcbiAgZ2FwOiBcIjZweFwiLFxuICBwYWRkaW5nOiBcIjZweFwiLFxuICBib3JkZXI6IGAycHggc29saWQgdHJhbnNwYXJlbnRgLFxuICBib3JkZXJSYWRpdXM6IGdsb2JhbENzc1ZhcnMuYm9yZGVyUmFkaXVzLFxuICBib3hTaGFkb3c6IGdsb2JhbENzc1ZhcnMuc2hhZG93U20sXG4gIHRyYW5zaXRpb246IGBib3JkZXItY29sb3IgJHtnbG9iYWxDc3NWYXJzLm1vdGlvbkR1cmF0aW9uTWlkfSBlYXNlYCxcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCImLnNlbGVjdGVkXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCIuZGFyayAmXCI6IHtcbiAgICBib3hTaGFkb3c6IFwiMCAxcHggM3B4IDAgcmdiKDI1NSAyNTUgMjU1IC8gMC4zKSwgMCAxcHggMnB4IC0xcHggcmdiKDI1NSAyNTUgMjU1IC8gMC4zKVwiXG4gIH1cbn0pO1xuXG5jb25zdCBsYXlvdXRTdHlsZSA9IHtcbiAgaGVhZGVyOiBjc3Moe1xuICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIGhlaWdodDogXCIxNnB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeSxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIG1haW46IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTIwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIHdyYXBwZXI6IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICBnYXA6IFwiNnB4XCJcbiAgfSksXG4gIHNpZGViYXI6IGNzcyh7XG4gICAgd2lkdGg6IFwiMThweFwiLFxuICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTMwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSlcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBNZW51TGF5b3V0Q2FyZCh7IG1vZGUsIC4uLnByb3BzIH06IE1lbnVMYXlvdXRDYXJkUHJvcHMpIHtcbiAgY29uc3QgYm9keSA9IChcbiAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUud3JhcHBlcn0+XG4gICAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUuaGVhZGVyfSAvPlxuICAgICAgPGRpdiBjc3M9e2xheW91dFN0eWxlLm1haW59IC8+XG4gICAgPC9kaXY+XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17Y2FyZFN0eWxlfSB7Li4ucHJvcHN9PlxuICAgICAge1xuICAgICAgICBtb2RlID09PSBcImhvcml6b250YWxcIlxuICAgICAgICAgID8gYm9keVxuICAgICAgICAgIDogKFxuICAgICAgICAgICAgICA8PlxuICAgICAgICAgICAgICAgIDxkaXYgY3NzPXtsYXlvdXRTdHlsZS5zaWRlYmFyfSAvPlxuICAgICAgICAgICAgICAgIHtib2R5fVxuICAgICAgICAgICAgICA8Lz5cbiAgICAgICAgICAgIClcbiAgICAgIH1cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdfQ== */");
|
|
30
|
+
const layoutStyle = {
|
|
31
|
+
header: /* @__PURE__ */ css({
|
|
32
|
+
flex: "none",
|
|
33
|
+
height: "16px",
|
|
34
|
+
backgroundColor: globalCssVars.colorPrimary,
|
|
35
|
+
borderRadius: "4px"
|
|
36
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9tZW51LWxheW91dC1jYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQ1UiLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGhlbWUtY29uZmlnL21lbnUtbGF5b3V0LWNhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPcmllbnRhdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmludGVyZmFjZSBNZW51TGF5b3V0Q2FyZFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8XCJkaXZcIj4ge1xuICBtb2RlOiBPcmllbnRhdGlvbjtcbn1cblxuY29uc3QgY2FyZFN0eWxlID0gY3NzKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGhlaWdodDogXCI2OHB4XCIsXG4gIHdpZHRoOiBcIjk2cHhcIixcbiAgZ2FwOiBcIjZweFwiLFxuICBwYWRkaW5nOiBcIjZweFwiLFxuICBib3JkZXI6IGAycHggc29saWQgdHJhbnNwYXJlbnRgLFxuICBib3JkZXJSYWRpdXM6IGdsb2JhbENzc1ZhcnMuYm9yZGVyUmFkaXVzLFxuICBib3hTaGFkb3c6IGdsb2JhbENzc1ZhcnMuc2hhZG93U20sXG4gIHRyYW5zaXRpb246IGBib3JkZXItY29sb3IgJHtnbG9iYWxDc3NWYXJzLm1vdGlvbkR1cmF0aW9uTWlkfSBlYXNlYCxcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCImLnNlbGVjdGVkXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCIuZGFyayAmXCI6IHtcbiAgICBib3hTaGFkb3c6IFwiMCAxcHggM3B4IDAgcmdiKDI1NSAyNTUgMjU1IC8gMC4zKSwgMCAxcHggMnB4IC0xcHggcmdiKDI1NSAyNTUgMjU1IC8gMC4zKVwiXG4gIH1cbn0pO1xuXG5jb25zdCBsYXlvdXRTdHlsZSA9IHtcbiAgaGVhZGVyOiBjc3Moe1xuICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIGhlaWdodDogXCIxNnB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeSxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIG1haW46IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTIwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIHdyYXBwZXI6IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICBnYXA6IFwiNnB4XCJcbiAgfSksXG4gIHNpZGViYXI6IGNzcyh7XG4gICAgd2lkdGg6IFwiMThweFwiLFxuICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTMwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSlcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBNZW51TGF5b3V0Q2FyZCh7IG1vZGUsIC4uLnByb3BzIH06IE1lbnVMYXlvdXRDYXJkUHJvcHMpIHtcbiAgY29uc3QgYm9keSA9IChcbiAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUud3JhcHBlcn0+XG4gICAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUuaGVhZGVyfSAvPlxuICAgICAgPGRpdiBjc3M9e2xheW91dFN0eWxlLm1haW59IC8+XG4gICAgPC9kaXY+XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17Y2FyZFN0eWxlfSB7Li4ucHJvcHN9PlxuICAgICAge1xuICAgICAgICBtb2RlID09PSBcImhvcml6b250YWxcIlxuICAgICAgICAgID8gYm9keVxuICAgICAgICAgIDogKFxuICAgICAgICAgICAgICA8PlxuICAgICAgICAgICAgICAgIDxkaXYgY3NzPXtsYXlvdXRTdHlsZS5zaWRlYmFyfSAvPlxuICAgICAgICAgICAgICAgIHtib2R5fVxuICAgICAgICAgICAgICA8Lz5cbiAgICAgICAgICAgIClcbiAgICAgIH1cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdfQ== */"),
|
|
37
|
+
main: /* @__PURE__ */ css({
|
|
38
|
+
flex: "auto",
|
|
39
|
+
backgroundColor: globalCssVars.colorPrimary200,
|
|
40
|
+
borderRadius: "4px"
|
|
41
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9tZW51LWxheW91dC1jYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q1EiLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGhlbWUtY29uZmlnL21lbnUtbGF5b3V0LWNhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPcmllbnRhdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmludGVyZmFjZSBNZW51TGF5b3V0Q2FyZFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8XCJkaXZcIj4ge1xuICBtb2RlOiBPcmllbnRhdGlvbjtcbn1cblxuY29uc3QgY2FyZFN0eWxlID0gY3NzKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGhlaWdodDogXCI2OHB4XCIsXG4gIHdpZHRoOiBcIjk2cHhcIixcbiAgZ2FwOiBcIjZweFwiLFxuICBwYWRkaW5nOiBcIjZweFwiLFxuICBib3JkZXI6IGAycHggc29saWQgdHJhbnNwYXJlbnRgLFxuICBib3JkZXJSYWRpdXM6IGdsb2JhbENzc1ZhcnMuYm9yZGVyUmFkaXVzLFxuICBib3hTaGFkb3c6IGdsb2JhbENzc1ZhcnMuc2hhZG93U20sXG4gIHRyYW5zaXRpb246IGBib3JkZXItY29sb3IgJHtnbG9iYWxDc3NWYXJzLm1vdGlvbkR1cmF0aW9uTWlkfSBlYXNlYCxcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCImLnNlbGVjdGVkXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCIuZGFyayAmXCI6IHtcbiAgICBib3hTaGFkb3c6IFwiMCAxcHggM3B4IDAgcmdiKDI1NSAyNTUgMjU1IC8gMC4zKSwgMCAxcHggMnB4IC0xcHggcmdiKDI1NSAyNTUgMjU1IC8gMC4zKVwiXG4gIH1cbn0pO1xuXG5jb25zdCBsYXlvdXRTdHlsZSA9IHtcbiAgaGVhZGVyOiBjc3Moe1xuICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIGhlaWdodDogXCIxNnB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeSxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIG1haW46IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTIwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIHdyYXBwZXI6IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICBnYXA6IFwiNnB4XCJcbiAgfSksXG4gIHNpZGViYXI6IGNzcyh7XG4gICAgd2lkdGg6IFwiMThweFwiLFxuICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTMwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSlcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBNZW51TGF5b3V0Q2FyZCh7IG1vZGUsIC4uLnByb3BzIH06IE1lbnVMYXlvdXRDYXJkUHJvcHMpIHtcbiAgY29uc3QgYm9keSA9IChcbiAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUud3JhcHBlcn0+XG4gICAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUuaGVhZGVyfSAvPlxuICAgICAgPGRpdiBjc3M9e2xheW91dFN0eWxlLm1haW59IC8+XG4gICAgPC9kaXY+XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17Y2FyZFN0eWxlfSB7Li4ucHJvcHN9PlxuICAgICAge1xuICAgICAgICBtb2RlID09PSBcImhvcml6b250YWxcIlxuICAgICAgICAgID8gYm9keVxuICAgICAgICAgIDogKFxuICAgICAgICAgICAgICA8PlxuICAgICAgICAgICAgICAgIDxkaXYgY3NzPXtsYXlvdXRTdHlsZS5zaWRlYmFyfSAvPlxuICAgICAgICAgICAgICAgIHtib2R5fVxuICAgICAgICAgICAgICA8Lz5cbiAgICAgICAgICAgIClcbiAgICAgIH1cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdfQ== */"),
|
|
42
|
+
wrapper: process.env.NODE_ENV === "production" ? {
|
|
43
|
+
name: "8xclx9",
|
|
44
|
+
styles: "flex:auto;display:flex;flex-direction:column;gap:6px"
|
|
45
|
+
} : {
|
|
46
|
+
name: "8xclx9",
|
|
47
|
+
styles: "flex:auto;display:flex;flex-direction:column;gap:6px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9tZW51LWxheW91dC1jYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0Q1ciLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGhlbWUtY29uZmlnL21lbnUtbGF5b3V0LWNhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPcmllbnRhdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmludGVyZmFjZSBNZW51TGF5b3V0Q2FyZFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8XCJkaXZcIj4ge1xuICBtb2RlOiBPcmllbnRhdGlvbjtcbn1cblxuY29uc3QgY2FyZFN0eWxlID0gY3NzKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGhlaWdodDogXCI2OHB4XCIsXG4gIHdpZHRoOiBcIjk2cHhcIixcbiAgZ2FwOiBcIjZweFwiLFxuICBwYWRkaW5nOiBcIjZweFwiLFxuICBib3JkZXI6IGAycHggc29saWQgdHJhbnNwYXJlbnRgLFxuICBib3JkZXJSYWRpdXM6IGdsb2JhbENzc1ZhcnMuYm9yZGVyUmFkaXVzLFxuICBib3hTaGFkb3c6IGdsb2JhbENzc1ZhcnMuc2hhZG93U20sXG4gIHRyYW5zaXRpb246IGBib3JkZXItY29sb3IgJHtnbG9iYWxDc3NWYXJzLm1vdGlvbkR1cmF0aW9uTWlkfSBlYXNlYCxcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCImLnNlbGVjdGVkXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCIuZGFyayAmXCI6IHtcbiAgICBib3hTaGFkb3c6IFwiMCAxcHggM3B4IDAgcmdiKDI1NSAyNTUgMjU1IC8gMC4zKSwgMCAxcHggMnB4IC0xcHggcmdiKDI1NSAyNTUgMjU1IC8gMC4zKVwiXG4gIH1cbn0pO1xuXG5jb25zdCBsYXlvdXRTdHlsZSA9IHtcbiAgaGVhZGVyOiBjc3Moe1xuICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIGhlaWdodDogXCIxNnB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeSxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIG1haW46IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTIwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIHdyYXBwZXI6IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICBnYXA6IFwiNnB4XCJcbiAgfSksXG4gIHNpZGViYXI6IGNzcyh7XG4gICAgd2lkdGg6IFwiMThweFwiLFxuICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTMwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSlcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBNZW51TGF5b3V0Q2FyZCh7IG1vZGUsIC4uLnByb3BzIH06IE1lbnVMYXlvdXRDYXJkUHJvcHMpIHtcbiAgY29uc3QgYm9keSA9IChcbiAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUud3JhcHBlcn0+XG4gICAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUuaGVhZGVyfSAvPlxuICAgICAgPGRpdiBjc3M9e2xheW91dFN0eWxlLm1haW59IC8+XG4gICAgPC9kaXY+XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17Y2FyZFN0eWxlfSB7Li4ucHJvcHN9PlxuICAgICAge1xuICAgICAgICBtb2RlID09PSBcImhvcml6b250YWxcIlxuICAgICAgICAgID8gYm9keVxuICAgICAgICAgIDogKFxuICAgICAgICAgICAgICA8PlxuICAgICAgICAgICAgICAgIDxkaXYgY3NzPXtsYXlvdXRTdHlsZS5zaWRlYmFyfSAvPlxuICAgICAgICAgICAgICAgIHtib2R5fVxuICAgICAgICAgICAgICA8Lz5cbiAgICAgICAgICAgIClcbiAgICAgIH1cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdfQ== */",
|
|
48
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
49
|
+
},
|
|
50
|
+
sidebar: /* @__PURE__ */ css({
|
|
51
|
+
width: "18px",
|
|
52
|
+
height: "100%",
|
|
53
|
+
backgroundColor: globalCssVars.colorPrimary300,
|
|
54
|
+
borderRadius: "4px"
|
|
55
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9tZW51LWxheW91dC1jYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRFciLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGhlbWUtY29uZmlnL21lbnUtbGF5b3V0LWNhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPcmllbnRhdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmludGVyZmFjZSBNZW51TGF5b3V0Q2FyZFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8XCJkaXZcIj4ge1xuICBtb2RlOiBPcmllbnRhdGlvbjtcbn1cblxuY29uc3QgY2FyZFN0eWxlID0gY3NzKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGhlaWdodDogXCI2OHB4XCIsXG4gIHdpZHRoOiBcIjk2cHhcIixcbiAgZ2FwOiBcIjZweFwiLFxuICBwYWRkaW5nOiBcIjZweFwiLFxuICBib3JkZXI6IGAycHggc29saWQgdHJhbnNwYXJlbnRgLFxuICBib3JkZXJSYWRpdXM6IGdsb2JhbENzc1ZhcnMuYm9yZGVyUmFkaXVzLFxuICBib3hTaGFkb3c6IGdsb2JhbENzc1ZhcnMuc2hhZG93U20sXG4gIHRyYW5zaXRpb246IGBib3JkZXItY29sb3IgJHtnbG9iYWxDc3NWYXJzLm1vdGlvbkR1cmF0aW9uTWlkfSBlYXNlYCxcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCImLnNlbGVjdGVkXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCIuZGFyayAmXCI6IHtcbiAgICBib3hTaGFkb3c6IFwiMCAxcHggM3B4IDAgcmdiKDI1NSAyNTUgMjU1IC8gMC4zKSwgMCAxcHggMnB4IC0xcHggcmdiKDI1NSAyNTUgMjU1IC8gMC4zKVwiXG4gIH1cbn0pO1xuXG5jb25zdCBsYXlvdXRTdHlsZSA9IHtcbiAgaGVhZGVyOiBjc3Moe1xuICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIGhlaWdodDogXCIxNnB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeSxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIG1haW46IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTIwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIHdyYXBwZXI6IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICBnYXA6IFwiNnB4XCJcbiAgfSksXG4gIHNpZGViYXI6IGNzcyh7XG4gICAgd2lkdGg6IFwiMThweFwiLFxuICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTMwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSlcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBNZW51TGF5b3V0Q2FyZCh7IG1vZGUsIC4uLnByb3BzIH06IE1lbnVMYXlvdXRDYXJkUHJvcHMpIHtcbiAgY29uc3QgYm9keSA9IChcbiAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUud3JhcHBlcn0+XG4gICAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUuaGVhZGVyfSAvPlxuICAgICAgPGRpdiBjc3M9e2xheW91dFN0eWxlLm1haW59IC8+XG4gICAgPC9kaXY+XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17Y2FyZFN0eWxlfSB7Li4ucHJvcHN9PlxuICAgICAge1xuICAgICAgICBtb2RlID09PSBcImhvcml6b250YWxcIlxuICAgICAgICAgID8gYm9keVxuICAgICAgICAgIDogKFxuICAgICAgICAgICAgICA8PlxuICAgICAgICAgICAgICAgIDxkaXYgY3NzPXtsYXlvdXRTdHlsZS5zaWRlYmFyfSAvPlxuICAgICAgICAgICAgICAgIHtib2R5fVxuICAgICAgICAgICAgICA8Lz5cbiAgICAgICAgICAgIClcbiAgICAgIH1cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdfQ== */")
|
|
56
|
+
};
|
|
57
|
+
function MenuLayoutCard({
|
|
58
|
+
mode,
|
|
59
|
+
...props
|
|
60
|
+
}) {
|
|
61
|
+
const body = /* @__PURE__ */ jsxs("div", { css: layoutStyle.wrapper, children: [
|
|
62
|
+
/* @__PURE__ */ jsx("div", { css: layoutStyle.header }),
|
|
63
|
+
/* @__PURE__ */ jsx("div", { css: layoutStyle.main })
|
|
64
|
+
] });
|
|
65
|
+
return /* @__PURE__ */ jsx("div", { css: cardStyle, ...props, children: mode === "horizontal" ? body : /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
66
|
+
/* @__PURE__ */ jsx("div", { css: layoutStyle.sidebar }),
|
|
67
|
+
body
|
|
68
|
+
] }) });
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
export { MenuLayoutCard };
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { jsxs, jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { Center, Tooltip } from '@vef-framework/components';
|
|
4
|
+
import { clsx } from '@vef-framework/core';
|
|
5
|
+
import '../../../../stores/index.js';
|
|
6
|
+
import { MenuLayoutCard } from './menu-layout-card.js';
|
|
7
|
+
import { useThemeStore } from '../../../../stores/theme.js';
|
|
8
|
+
|
|
9
|
+
function MenuLayout() {
|
|
10
|
+
const menuLayout = useThemeStore((state) => state.menuLayout);
|
|
11
|
+
return /* @__PURE__ */ jsxs(Center, { gap: "large", children: [
|
|
12
|
+
/* @__PURE__ */ jsx(Tooltip, { placement: "bottom", title: "垂直菜单模式", children: /* @__PURE__ */ jsx(MenuLayoutCard, { mode: "vertical", className: clsx({
|
|
13
|
+
selected: menuLayout === "vertical"
|
|
14
|
+
}), onClick: () => {
|
|
15
|
+
useThemeStore.setState((state) => {
|
|
16
|
+
state.menuLayout = "vertical";
|
|
17
|
+
});
|
|
18
|
+
} }) }),
|
|
19
|
+
/* @__PURE__ */ jsx(Tooltip, { placement: "bottom", title: "水平菜单模式", children: /* @__PURE__ */ jsx(MenuLayoutCard, { mode: "horizontal", className: clsx({
|
|
20
|
+
selected: menuLayout === "horizontal"
|
|
21
|
+
}), onClick: () => {
|
|
22
|
+
useThemeStore.setState((state) => {
|
|
23
|
+
state.menuLayout = "horizontal";
|
|
24
|
+
});
|
|
25
|
+
} }) })
|
|
26
|
+
] });
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export { MenuLayout };
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { Button, showSuccessMessage, Icon } from '@vef-framework/components';
|
|
4
|
+
import { RefreshCwIcon } from 'lucide-react';
|
|
5
|
+
import '../../../../stores/index.js';
|
|
6
|
+
import { useThemeStore } from '../../../../stores/theme.js';
|
|
7
|
+
|
|
8
|
+
function Operations() {
|
|
9
|
+
return /* @__PURE__ */ jsx(Button, { block: true, danger: true, icon: /* @__PURE__ */ jsx(Icon, { component: RefreshCwIcon }), onClick: () => {
|
|
10
|
+
useThemeStore.setState({
|
|
11
|
+
...useThemeStore.getInitialState(),
|
|
12
|
+
isThemeConfigVisible: true
|
|
13
|
+
}, true);
|
|
14
|
+
showSuccessMessage("主题配置已重置成功");
|
|
15
|
+
}, children: "重置配置" });
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export { Operations };
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { ColorPicker } from '@vef-framework/components';
|
|
4
|
+
import { useDidUpdate } from '@vef-framework/hooks';
|
|
5
|
+
import { useState, useTransition } from 'react';
|
|
6
|
+
import '../../../../stores/index.js';
|
|
7
|
+
import { useThemeStore } from '../../../../stores/theme.js';
|
|
8
|
+
|
|
9
|
+
function ThemeColorPicker({
|
|
10
|
+
color
|
|
11
|
+
}) {
|
|
12
|
+
const currentValue = useThemeStore((state) => state.colors[color]);
|
|
13
|
+
const [localValue, setLocalValue] = useState(currentValue);
|
|
14
|
+
useDidUpdate(() => {
|
|
15
|
+
setLocalValue(currentValue);
|
|
16
|
+
}, [currentValue]);
|
|
17
|
+
const [_, startTransition] = useTransition();
|
|
18
|
+
return /* @__PURE__ */ jsx(ColorPicker, { arrow: false, format: "hex", value: localValue, onChange: (value) => {
|
|
19
|
+
setLocalValue(value.toHexString());
|
|
20
|
+
}, onChangeComplete: (value) => {
|
|
21
|
+
startTransition(() => {
|
|
22
|
+
useThemeStore.setState((state) => {
|
|
23
|
+
state.colors[color] = value.toHexString();
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
} });
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export { ThemeColorPicker };
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { css } from '@emotion/react';
|
|
4
|
+
import { globalCssVars, semanticColors } from '@vef-framework/components';
|
|
5
|
+
import { ConfigItem } from './config-item.js';
|
|
6
|
+
import { ThemeColorPicker } from './theme-color-picker.js';
|
|
7
|
+
|
|
8
|
+
const wrapperStyle = /* @__PURE__ */ css({
|
|
9
|
+
display: "flex",
|
|
10
|
+
flexDirection: "column",
|
|
11
|
+
gap: globalCssVars.spacingSm
|
|
12
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy90aGVtZS1jb2xvcnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFxQiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90aGVtZS1jb25maWcvdGhlbWUtY29sb3JzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU2VtYW50aWNDb2xvciB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycywgc2VtYW50aWNDb2xvcnMgfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuXG5pbXBvcnQgeyBDb25maWdJdGVtIH0gZnJvbSBcIi4vY29uZmlnLWl0ZW1cIjtcbmltcG9ydCB7IFRoZW1lQ29sb3JQaWNrZXIgfSBmcm9tIFwiLi90aGVtZS1jb2xvci1waWNrZXJcIjtcblxuY29uc3Qgd3JhcHBlclN0eWxlID0gY3NzKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gIGdhcDogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nU21cbn0pO1xuXG5jb25zdCBzZW1hbnRpY0NvbG9yTGFiZWxzOiBSZWNvcmQ8U2VtYW50aWNDb2xvciwgc3RyaW5nPiA9IHtcbiAgcHJpbWFyeTogXCLkuLvoibJcIixcbiAgaW5mbzogXCLkv6Hmga/oibJcIixcbiAgc3VjY2VzczogXCLmiJDlip/oibJcIixcbiAgd2FybmluZzogXCLorablkYroibJcIixcbiAgZXJyb3I6IFwi6ZSZ6K+v6ImyXCJcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBUaGVtZUNvbG9ycygpIHtcbiAgY29uc3QgaXRlbXMgPSBzZW1hbnRpY0NvbG9ycy5tYXAoY29sb3IgPT4gKFxuICAgIDxDb25maWdJdGVtXG4gICAgICBrZXk9e2NvbG9yfVxuICAgICAgbGFiZWw9e3NlbWFudGljQ29sb3JMYWJlbHNbY29sb3JdfVxuICAgID5cbiAgICAgIDxUaGVtZUNvbG9yUGlja2VyIGNvbG9yPXtjb2xvcn0gLz5cbiAgICA8L0NvbmZpZ0l0ZW0+XG4gICkpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdiBjc3M9e3dyYXBwZXJTdHlsZX0+XG4gICAgICB7aXRlbXN9XG4gICAgPC9kaXY+XG4gICk7XG59XG4iXX0= */");
|
|
13
|
+
const semanticColorLabels = {
|
|
14
|
+
primary: "主色",
|
|
15
|
+
info: "信息色",
|
|
16
|
+
success: "成功色",
|
|
17
|
+
warning: "警告色",
|
|
18
|
+
error: "错误色"
|
|
19
|
+
};
|
|
20
|
+
function ThemeColors() {
|
|
21
|
+
const items = semanticColors.map((color) => /* @__PURE__ */ jsx(ConfigItem, { label: semanticColorLabels[color], children: /* @__PURE__ */ jsx(ThemeColorPicker, { color }) }, color));
|
|
22
|
+
return /* @__PURE__ */ jsx("div", { css: wrapperStyle, children: items });
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export { ThemeColors };
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
export { useColorSchemeUpdater } from './use-color-scheme-updater.js';
|
|
3
|
+
export { useMenuNavigate } from './use-menu-navigate.js';
|
|
4
|
+
export { useTabNavigate } from './use-tab-navigate.js';
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { useReducedMotion, useColorScheme } from '@vef-framework/hooks';
|
|
3
|
+
import '../../../stores/index.js';
|
|
4
|
+
import { useThemeStore } from '../../../stores/theme.js';
|
|
5
|
+
|
|
6
|
+
function getNextColorScheme(colorScheme) {
|
|
7
|
+
return colorScheme === "system" ? "light" : colorScheme === "light" ? "dark" : "system";
|
|
8
|
+
}
|
|
9
|
+
function removeColorSchemeTransitionClass() {
|
|
10
|
+
document.documentElement.classList.remove("color-scheme-transition");
|
|
11
|
+
}
|
|
12
|
+
function useColorSchemeUpdater() {
|
|
13
|
+
const currentColorScheme = useThemeStore((state) => state.colorScheme);
|
|
14
|
+
const reducedMotion = useReducedMotion(false, {
|
|
15
|
+
getInitialValueInEffect: false
|
|
16
|
+
});
|
|
17
|
+
const systemColorScheme = useColorScheme("light", {
|
|
18
|
+
getInitialValueInEffect: false
|
|
19
|
+
});
|
|
20
|
+
function updateColorSchemeInternal(colorScheme) {
|
|
21
|
+
useThemeStore.setState((state) => {
|
|
22
|
+
state.colorScheme = colorScheme;
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
function updateColorScheme(nextColorScheme, position, isLoop = false) {
|
|
26
|
+
if (reducedMotion) {
|
|
27
|
+
updateColorSchemeInternal(nextColorScheme);
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
if (isLoop && (currentColorScheme === "system" && systemColorScheme === "light" || currentColorScheme === "dark" && systemColorScheme === "dark")) {
|
|
31
|
+
updateColorSchemeInternal(nextColorScheme);
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
if (!isLoop && (nextColorScheme === "system" && currentColorScheme === systemColorScheme || currentColorScheme === "system" && nextColorScheme === systemColorScheme)) {
|
|
35
|
+
updateColorSchemeInternal(nextColorScheme);
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
document.documentElement.classList.add("color-scheme-transition");
|
|
39
|
+
const transition = document.startViewTransition(() => {
|
|
40
|
+
updateColorSchemeInternal(nextColorScheme);
|
|
41
|
+
});
|
|
42
|
+
const {
|
|
43
|
+
x,
|
|
44
|
+
y
|
|
45
|
+
} = position;
|
|
46
|
+
const radius = Math.hypot(Math.max(x, window.innerWidth - x), Math.max(y, window.innerHeight - y));
|
|
47
|
+
const isDarken = nextColorScheme === "dark" || nextColorScheme === "system" && systemColorScheme === "dark";
|
|
48
|
+
transition.ready.then(() => {
|
|
49
|
+
const animation = document.documentElement.animate({
|
|
50
|
+
clipPath: [`circle(0px at ${x}px ${y}px)`, `circle(${radius}px at ${x}px ${y}px)`]
|
|
51
|
+
}, {
|
|
52
|
+
duration: 800,
|
|
53
|
+
easing: "ease-out",
|
|
54
|
+
direction: isDarken ? "normal" : "reverse",
|
|
55
|
+
pseudoElement: isDarken ? "::view-transition-new(root)" : "::view-transition-old(root)"
|
|
56
|
+
});
|
|
57
|
+
animation.addEventListener("cancel", removeColorSchemeTransitionClass);
|
|
58
|
+
animation.addEventListener("remove", removeColorSchemeTransitionClass);
|
|
59
|
+
});
|
|
60
|
+
transition.finished.then(removeColorSchemeTransitionClass);
|
|
61
|
+
}
|
|
62
|
+
return {
|
|
63
|
+
getNextColorScheme,
|
|
64
|
+
updateColorScheme
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
export { useColorSchemeUpdater };
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
|
|
2
|
+
import { useNavigate } from '@tanstack/react-router';
|
|
3
|
+
import { isPlainObject } from '@vef-framework/shared';
|
|
4
|
+
import { useCallback } from 'react';
|
|
5
|
+
|
|
6
|
+
function useMenuNavigate() {
|
|
7
|
+
const navigate = useNavigate();
|
|
8
|
+
return useCallback(({
|
|
9
|
+
path,
|
|
10
|
+
meta
|
|
11
|
+
}) => {
|
|
12
|
+
const {
|
|
13
|
+
params,
|
|
14
|
+
search
|
|
15
|
+
} = meta ?? {};
|
|
16
|
+
return navigate({
|
|
17
|
+
to: path,
|
|
18
|
+
params: isPlainObject(params) ? params : void 0,
|
|
19
|
+
search: isPlainObject(search) ? search : void 0,
|
|
20
|
+
viewTransition: false
|
|
21
|
+
});
|
|
22
|
+
}, [navigate]);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export { useMenuNavigate };
|