@vef-framework/starter 1.0.135 → 2.0.2
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 +60 -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,131 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.2 made with ❤️ by Venus | 2025-11-25T15:03:22.856Z */
|
|
2
|
+
import { jsxs, jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { css } from '@emotion/react';
|
|
4
|
+
import { globalCssVars, Empty } from '@vef-framework/components';
|
|
5
|
+
import { AnimatePresence, motion } from '@vef-framework/core';
|
|
6
|
+
import { useHotkeys } from '@vef-framework/hooks';
|
|
7
|
+
import { getPinyinInitials, getPinyin } from '@vef-framework/shared';
|
|
8
|
+
import { useMemo, useState, useEffect } from 'react';
|
|
9
|
+
import '../../../../stores/index.js';
|
|
10
|
+
import '../../hooks/index.js';
|
|
11
|
+
import { useLayoutStore } from '../../store.js';
|
|
12
|
+
import { SearchResultItem } from './search-result-item.js';
|
|
13
|
+
import { useAppStore } from '../../../../stores/app.js';
|
|
14
|
+
import { useMenuNavigate } from '../../hooks/use-menu-navigate.js';
|
|
15
|
+
|
|
16
|
+
const resultStyle = /* @__PURE__ */ css({
|
|
17
|
+
display: "flex",
|
|
18
|
+
flexDirection: "column",
|
|
19
|
+
rowGap: globalCssVars.spacingSm
|
|
20
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3NlYXJjaC9zZWFyY2gtcmVzdWx0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQm9CIiwiZmlsZSI6Ii9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3NlYXJjaC9zZWFyY2gtcmVzdWx0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgV2l0aFBpbnlpbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9zaGFyZWRcIjtcblxuaW1wb3J0IHR5cGUgeyBVc2VyTWVudSB9IGZyb20gXCIuLi8uLi8uLi8uLi90eXBlc1wiO1xuXG5pbXBvcnQgeyBjc3MgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB7IEVtcHR5LCBnbG9iYWxDc3NWYXJzIH0gZnJvbSBcIkB2ZWYtZnJhbWV3b3JrL2NvbXBvbmVudHNcIjtcbmltcG9ydCB7IEFuaW1hdGVQcmVzZW5jZSwgbW90aW9uIH0gZnJvbSBcIkB2ZWYtZnJhbWV3b3JrL2NvcmVcIjtcbmltcG9ydCB7IHVzZUhvdGtleXMgfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvaG9va3NcIjtcbmltcG9ydCB7IGdldFBpbnlpbiwgZ2V0UGlueWluSW5pdGlhbHMgfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvc2hhcmVkXCI7XG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVN0YXRlIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IHVzZUFwcFN0b3JlIH0gZnJvbSBcIi4uLy4uLy4uLy4uL3N0b3Jlc1wiO1xuaW1wb3J0IHsgdXNlTWVudU5hdmlnYXRlIH0gZnJvbSBcIi4uLy4uL2hvb2tzXCI7XG5pbXBvcnQgeyB1c2VMYXlvdXRTdG9yZSB9IGZyb20gXCIuLi8uLi9zdG9yZVwiO1xuaW1wb3J0IHsgU2VhcmNoUmVzdWx0SXRlbSB9IGZyb20gXCIuL3NlYXJjaC1yZXN1bHQtaXRlbVwiO1xuXG5pbnRlcmZhY2UgU2VhcmNoUmVzdWx0UHJvcHMge1xuICBrZXl3b3JkOiBzdHJpbmc7XG59XG5cbnR5cGUgTWVudUl0ZW0gPSBXaXRoUGlueWluPFVzZXJNZW51LCBcIm5hbWVcIj47XG5cbmNvbnN0IHJlc3VsdFN0eWxlID0gY3NzKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gIHJvd0dhcDogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nU21cbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VhcmNoUmVzdWx0KHsga2V5d29yZCB9OiBTZWFyY2hSZXN1bHRQcm9wcykge1xuICBjb25zdCBzZXRJc1NlYXJjaFZpc2libGUgPSB1c2VMYXlvdXRTdG9yZShzdGF0ZSA9PiBzdGF0ZS5zZXRJc1NlYXJjaFZpc2libGUpO1xuICBjb25zdCB1c2VyTWVudU1hcCA9IHVzZUFwcFN0b3JlKHN0YXRlID0+IHN0YXRlLnVzZXJNZW51TWFwKTtcbiAgY29uc3QgbWVudUl0ZW1zID0gdXNlTWVtbyhcbiAgICAoKSA9PiBidWlsZE1lbnVJdGVtcyh1c2VyTWVudU1hcCA/IFsuLi51c2VyTWVudU1hcC52YWx1ZXMoKV0gOiBbXSksXG4gICAgW3VzZXJNZW51TWFwXVxuICApO1xuICBjb25zdCBtYXRjaGVkTWVudUl0ZW1zID0gdXNlTWVtbyhcbiAgICAoKSA9PiBtZW51SXRlbXMuZmlsdGVyKGl0ZW0gPT4gbWF0Y2goaXRlbSwga2V5d29yZCkpLFxuICAgIFttZW51SXRlbXMsIGtleXdvcmRdXG4gICk7XG4gIGNvbnN0IFthY3RpdmVNZW51UGF0aCwgc2V0QWN0aXZlTWVudVBhdGhdID0gdXNlU3RhdGU8c3RyaW5nPigpO1xuXG4gIGNvbnN0IGhhbmRsZU1lbnVTZWxlY3QgPSAob2Zmc2V0OiAxIHwgLTEpID0+IHtcbiAgICBjb25zdCB7IGxlbmd0aCB9ID0gbWF0Y2hlZE1lbnVJdGVtcztcblxuICAgIGlmIChsZW5ndGggPT09IDApIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBpbmRleCA9IG1hdGNoZWRNZW51SXRlbXMuZmluZEluZGV4KGl0ZW0gPT4gaXRlbS5wYXRoID09PSBhY3RpdmVNZW51UGF0aCk7XG5cbiAgICBpZiAoaW5kZXggPT09IC0xKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgbmV3SW5kZXggPSAoaW5kZXggKyBvZmZzZXQgKyBsZW5ndGgpICUgbGVuZ3RoO1xuICAgIHNldEFjdGl2ZU1lbnVQYXRoKG1hdGNoZWRNZW51SXRlbXNbbmV3SW5kZXhdIS5wYXRoKTtcbiAgfTtcblxuICBjb25zdCBuYXZpZ2F0ZSA9IHVzZU1lbnVOYXZpZ2F0ZSgpO1xuICB1c2VIb3RrZXlzKFwiZXNjXCIsICgpID0+IHNldElzU2VhcmNoVmlzaWJsZShmYWxzZSksIHsgZW5hYmxlT25Gb3JtVGFnczogdHJ1ZSB9KTtcbiAgdXNlSG90a2V5cyhcImVudGVyXCIsICgpID0+IHtcbiAgICBpZiAoIWFjdGl2ZU1lbnVQYXRoKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgc2V0SXNTZWFyY2hWaXNpYmxlKGZhbHNlKTtcbiAgICBjb25zdCBtZW51ID0gdXNlck1lbnVNYXA/LmdldChhY3RpdmVNZW51UGF0aCk7XG5cbiAgICBpZiAobWVudSkge1xuICAgICAgbmF2aWdhdGUobWVudSk7XG4gICAgfVxuICB9LCB7IGVuYWJsZU9uRm9ybVRhZ3M6IHRydWUgfSk7XG4gIHVzZUhvdGtleXMoXCJ1cFwiLCAoKSA9PiBoYW5kbGVNZW51U2VsZWN0KC0xKSwgeyBlbmFibGVPbkZvcm1UYWdzOiB0cnVlIH0pO1xuICB1c2VIb3RrZXlzKFwiZG93blwiLCAoKSA9PiBoYW5kbGVNZW51U2VsZWN0KDEpLCB7IGVuYWJsZU9uRm9ybVRhZ3M6IHRydWUgfSk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAobWF0Y2hlZE1lbnVJdGVtcy5sZW5ndGggPiAwKSB7XG4gICAgICBjb25zdCB7IHBhdGggfSA9IG1hdGNoZWRNZW51SXRlbXNbMF0hO1xuXG4gICAgICBzZXRBY3RpdmVNZW51UGF0aChwYXRoKTtcbiAgICB9XG4gIH0sIFttYXRjaGVkTWVudUl0ZW1zXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17cmVzdWx0U3R5bGV9PlxuICAgICAgPEFuaW1hdGVQcmVzZW5jZT5cbiAgICAgICAge21hdGNoZWRNZW51SXRlbXMubWFwKChpdGVtLCBpbmRleCkgPT4gKFxuICAgICAgICAgIDxtb3Rpb24uZGl2XG4gICAgICAgICAgICBrZXk9e2l0ZW0ucGF0aH1cbiAgICAgICAgICAgIGxheW91dFxuICAgICAgICAgICAgYW5pbWF0ZT17eyBvcGFjaXR5OiAxLCB5OiAwIH19XG4gICAgICAgICAgICBpbml0aWFsPXt7IG9wYWNpdHk6IDAsIHk6IDIwIH19XG4gICAgICAgICAgICB0cmFuc2l0aW9uPXt7XG4gICAgICAgICAgICAgIGR1cmF0aW9uOiAwLjMsXG4gICAgICAgICAgICAgIGRlbGF5OiBpbmRleCAqIDAuMDUsXG4gICAgICAgICAgICAgIGVhc2U6IFwiZWFzZU91dFwiXG4gICAgICAgICAgICB9fVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxTZWFyY2hSZXN1bHRJdGVtXG4gICAgICAgICAgICAgIGFjdGl2ZT17YWN0aXZlTWVudVBhdGggPT09IGl0ZW0ucGF0aH1cbiAgICAgICAgICAgICAgaWNvbj17aXRlbS5pY29uID09PSBudWxsID8gdW5kZWZpbmVkIDogaXRlbS5pY29ufVxuICAgICAgICAgICAgICBsYWJlbD17aXRlbS5uYW1lfVxuICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKGFjdGl2ZU1lbnVQYXRoICE9PSBpdGVtLnBhdGgpIHtcbiAgICAgICAgICAgICAgICAgIHNldEFjdGl2ZU1lbnVQYXRoKGl0ZW0ucGF0aCk7XG4gICAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgc2V0SXNTZWFyY2hWaXNpYmxlKGZhbHNlKTtcbiAgICAgICAgICAgICAgICBjb25zdCBtZW51ID0gdXNlck1lbnVNYXA/LmdldChpdGVtLnBhdGgpO1xuXG4gICAgICAgICAgICAgICAgaWYgKG1lbnUpIHtcbiAgICAgICAgICAgICAgICAgIG5hdmlnYXRlKG1lbnUpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9tb3Rpb24uZGl2PlxuICAgICAgICApKX1cbiAgICAgIDwvQW5pbWF0ZVByZXNlbmNlPlxuXG4gICAgICA8QW5pbWF0ZVByZXNlbmNlPlxuICAgICAgICB7bWF0Y2hlZE1lbnVJdGVtcy5sZW5ndGggPT09IDAgJiYgKFxuICAgICAgICAgIDxtb3Rpb24uZGl2XG4gICAgICAgICAgICBrZXk9XCJlbXB0eS1zdGF0ZVwiXG4gICAgICAgICAgICBhbmltYXRlPXt7IG9wYWNpdHk6IDEsIHNjYWxlOiAxIH19XG4gICAgICAgICAgICBpbml0aWFsPXt7IG9wYWNpdHk6IDAsIHNjYWxlOiAwLjk1IH19XG4gICAgICAgICAgICB0cmFuc2l0aW9uPXt7IGR1cmF0aW9uOiAwLjMsIGVhc2U6IFwiZWFzZU91dFwiIH19XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPEVtcHR5XG4gICAgICAgICAgICAgIGRlc2NyaXB0aW9uPXtcbiAgICAgICAgICAgICAgICBrZXl3b3JkXG4gICAgICAgICAgICAgICAgICA/IGDmsqHmnInmib7liLDkuI5cIiR7a2V5d29yZH1cIuebuOWFs+eahOiPnOWNlWBcbiAgICAgICAgICAgICAgICAgIDogXCLor7fovpPlhaXlhbPplK7lrZfmkJzntKJcIlxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvbW90aW9uLmRpdj5cbiAgICAgICAgKX1cbiAgICAgIDwvQW5pbWF0ZVByZXNlbmNlPlxuICAgIDwvZGl2PlxuICApO1xufVxuXG5mdW5jdGlvbiBtYXRjaChtZW51SXRlbTogTWVudUl0ZW0sIGtleXdvcmQ6IHN0cmluZykge1xuICBpZiAoIWtleXdvcmQpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBjb25zdCB7XG4gICAgbmFtZSxcbiAgICBuYW1lUGlueWluLFxuICAgIG5hbWVQaW55aW5Jbml0aWFsc1xuICB9ID0gbWVudUl0ZW07XG5cbiAgcmV0dXJuIG5hbWUuaW5jbHVkZXMoa2V5d29yZCkgfHwgbmFtZVBpbnlpbi5pbmNsdWRlcyhrZXl3b3JkKSB8fCBuYW1lUGlueWluSW5pdGlhbHMuaW5jbHVkZXMoa2V5d29yZCk7XG59XG5cbmZ1bmN0aW9uIGJ1aWxkTWVudUl0ZW1zKG1lbnVzOiByZWFkb25seSBVc2VyTWVudVtdKTogTWVudUl0ZW1bXSB7XG4gIHJldHVybiBtZW51cy5tYXAobWVudSA9PiB7XG4gICAgY29uc3QgeyBuYW1lIH0gPSBtZW51O1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLm1lbnUsXG4gICAgICBuYW1lUGlueWluOiBnZXRQaW55aW4obmFtZSkuam9pbihcIlwiKSxcbiAgICAgIG5hbWVQaW55aW5Jbml0aWFsczogZ2V0UGlueWluSW5pdGlhbHMobmFtZSkuam9pbihcIlwiKVxuICAgIH07XG4gIH0pO1xufVxuIl19 */");
|
|
21
|
+
function SearchResult({
|
|
22
|
+
keyword
|
|
23
|
+
}) {
|
|
24
|
+
const setIsSearchVisible = useLayoutStore((state) => state.setIsSearchVisible);
|
|
25
|
+
const userMenuMap = useAppStore((state) => state.userMenuMap);
|
|
26
|
+
const menuItems = useMemo(() => buildMenuItems(userMenuMap ? [...userMenuMap.values()] : []), [userMenuMap]);
|
|
27
|
+
const matchedMenuItems = useMemo(() => menuItems.filter((item) => match(item, keyword)), [menuItems, keyword]);
|
|
28
|
+
const [activeMenuPath, setActiveMenuPath] = useState();
|
|
29
|
+
const handleMenuSelect = (offset) => {
|
|
30
|
+
const {
|
|
31
|
+
length
|
|
32
|
+
} = matchedMenuItems;
|
|
33
|
+
if (length === 0) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
const index = matchedMenuItems.findIndex((item) => item.path === activeMenuPath);
|
|
37
|
+
if (index === -1) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
const newIndex = (index + offset + length) % length;
|
|
41
|
+
setActiveMenuPath(matchedMenuItems[newIndex].path);
|
|
42
|
+
};
|
|
43
|
+
const navigate = useMenuNavigate();
|
|
44
|
+
useHotkeys("esc", () => setIsSearchVisible(false), {
|
|
45
|
+
enableOnFormTags: true
|
|
46
|
+
});
|
|
47
|
+
useHotkeys("enter", () => {
|
|
48
|
+
if (!activeMenuPath) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
setIsSearchVisible(false);
|
|
52
|
+
const menu = userMenuMap?.get(activeMenuPath);
|
|
53
|
+
if (menu) {
|
|
54
|
+
navigate(menu);
|
|
55
|
+
}
|
|
56
|
+
}, {
|
|
57
|
+
enableOnFormTags: true
|
|
58
|
+
});
|
|
59
|
+
useHotkeys("up", () => handleMenuSelect(-1), {
|
|
60
|
+
enableOnFormTags: true
|
|
61
|
+
});
|
|
62
|
+
useHotkeys("down", () => handleMenuSelect(1), {
|
|
63
|
+
enableOnFormTags: true
|
|
64
|
+
});
|
|
65
|
+
useEffect(() => {
|
|
66
|
+
if (matchedMenuItems.length > 0) {
|
|
67
|
+
const {
|
|
68
|
+
path
|
|
69
|
+
} = matchedMenuItems[0];
|
|
70
|
+
setActiveMenuPath(path);
|
|
71
|
+
}
|
|
72
|
+
}, [matchedMenuItems]);
|
|
73
|
+
return /* @__PURE__ */ jsxs("div", { css: resultStyle, children: [
|
|
74
|
+
/* @__PURE__ */ jsx(AnimatePresence, { children: matchedMenuItems.map((item, index) => /* @__PURE__ */ jsx(motion.div, { layout: true, animate: {
|
|
75
|
+
opacity: 1,
|
|
76
|
+
y: 0
|
|
77
|
+
}, initial: {
|
|
78
|
+
opacity: 0,
|
|
79
|
+
y: 20
|
|
80
|
+
}, transition: {
|
|
81
|
+
duration: 0.3,
|
|
82
|
+
delay: index * 0.05,
|
|
83
|
+
ease: "easeOut"
|
|
84
|
+
}, children: /* @__PURE__ */ jsx(SearchResultItem, { active: activeMenuPath === item.path, icon: item.icon === null ? void 0 : item.icon, label: item.name, onClick: () => {
|
|
85
|
+
if (activeMenuPath !== item.path) {
|
|
86
|
+
setActiveMenuPath(item.path);
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
setIsSearchVisible(false);
|
|
90
|
+
const menu = userMenuMap?.get(item.path);
|
|
91
|
+
if (menu) {
|
|
92
|
+
navigate(menu);
|
|
93
|
+
}
|
|
94
|
+
} }) }, item.path)) }),
|
|
95
|
+
/* @__PURE__ */ jsx(AnimatePresence, { children: matchedMenuItems.length === 0 && /* @__PURE__ */ jsx(motion.div, { animate: {
|
|
96
|
+
opacity: 1,
|
|
97
|
+
scale: 1
|
|
98
|
+
}, initial: {
|
|
99
|
+
opacity: 0,
|
|
100
|
+
scale: 0.95
|
|
101
|
+
}, transition: {
|
|
102
|
+
duration: 0.3,
|
|
103
|
+
ease: "easeOut"
|
|
104
|
+
}, children: /* @__PURE__ */ jsx(Empty, { description: keyword ? `没有找到与"${keyword}"相关的菜单` : "请输入关键字搜索" }) }, "empty-state") })
|
|
105
|
+
] });
|
|
106
|
+
}
|
|
107
|
+
function match(menuItem, keyword) {
|
|
108
|
+
if (!keyword) {
|
|
109
|
+
return false;
|
|
110
|
+
}
|
|
111
|
+
const {
|
|
112
|
+
name,
|
|
113
|
+
namePinyin,
|
|
114
|
+
namePinyinInitials
|
|
115
|
+
} = menuItem;
|
|
116
|
+
return name.includes(keyword) || namePinyin.includes(keyword) || namePinyinInitials.includes(keyword);
|
|
117
|
+
}
|
|
118
|
+
function buildMenuItems(menus) {
|
|
119
|
+
return menus.map((menu) => {
|
|
120
|
+
const {
|
|
121
|
+
name
|
|
122
|
+
} = menu;
|
|
123
|
+
return {
|
|
124
|
+
...menu,
|
|
125
|
+
namePinyin: getPinyin(name).join(""),
|
|
126
|
+
namePinyinInitials: getPinyinInitials(name).join("")
|
|
127
|
+
};
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
export { SearchResult };
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.2 made with ❤️ by Venus | 2025-11-25T15:03:22.856Z */
|
|
2
|
+
import { jsxs, Fragment, jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { ClassNames } from '@emotion/react';
|
|
4
|
+
import { ScrollArea } from '@vef-framework/components';
|
|
5
|
+
import { HoneycombPattern } from './honeycomb-pattern.js';
|
|
6
|
+
import { Logo } from './logo.js';
|
|
7
|
+
import { Menu } from './menu.js';
|
|
8
|
+
|
|
9
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
10
|
+
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).";
|
|
11
|
+
}
|
|
12
|
+
const logoStyle = process.env.NODE_ENV === "production" ? {
|
|
13
|
+
name: "dooaqh",
|
|
14
|
+
styles: "flex:none;height:var(--vef-layout-header-height)"
|
|
15
|
+
} : {
|
|
16
|
+
name: "dooaqh",
|
|
17
|
+
styles: "flex:none;height:var(--vef-layout-header-height)/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3NpZGViYXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWFrQiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy9zaWRlYmFyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgTGF5b3V0UHJvcHMgfSBmcm9tIFwiLi4vcHJvcHNcIjtcblxuaW1wb3J0IHsgQ2xhc3NOYW1lcywgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgeyBTY3JvbGxBcmVhIH0gZnJvbSBcIkB2ZWYtZnJhbWV3b3JrL2NvbXBvbmVudHNcIjtcblxuaW1wb3J0IHsgSG9uZXljb21iUGF0dGVybiB9IGZyb20gXCIuL2hvbmV5Y29tYi1wYXR0ZXJuXCI7XG5pbXBvcnQgeyBMb2dvIH0gZnJvbSBcIi4vbG9nb1wiO1xuaW1wb3J0IHsgTWVudSB9IGZyb20gXCIuL21lbnVcIjtcblxuaW50ZXJmYWNlIFNpZGViYXJQcm9wcyBleHRlbmRzIFBpY2s8TGF5b3V0UHJvcHMsIFwibG9nb1wiIHwgXCJ0aXRsZVwiPiB7XG4gIGlzU2lkZWJhckNvbGxhcHNlZD86IGJvb2xlYW47XG59XG5cbmNvbnN0IGxvZ29TdHlsZSA9IGNzcyh7XG4gIGZsZXg6IFwibm9uZVwiLFxuICBoZWlnaHQ6IFwidmFyKC0tdmVmLWxheW91dC1oZWFkZXItaGVpZ2h0KVwiXG59KTtcblxuY29uc3QgbWVudVdyYXBwZXJTdHlsZSA9IGNzcyh7XG4gIGZsZXg6IFwiYXV0b1wiXG59KTtcblxuY29uc3QgbWVudUNvbnRhaW5lclN0eWxlID0gY3NzKHtcbiAgcGFkZGluZzogXCIycHhcIlxufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBTaWRlYmFyKHtcbiAgaXNTaWRlYmFyQ29sbGFwc2VkLFxuICBsb2dvLFxuICB0aXRsZVxufTogU2lkZWJhclByb3BzKSB7XG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIDxIb25leWNvbWJQYXR0ZXJuIC8+XG5cbiAgICAgIDxMb2dvXG4gICAgICAgIGNzcz17bG9nb1N0eWxlfVxuICAgICAgICBpc1RpdGxlVmlzaWJsZT17IWlzU2lkZWJhckNvbGxhcHNlZH1cbiAgICAgICAgbG9nbz17bG9nb31cbiAgICAgICAgdGl0bGU9e3RpdGxlfVxuICAgICAgLz5cblxuICAgICAgPENsYXNzTmFtZXM+XG4gICAgICAgIHsoeyBjc3MgfSkgPT4gKFxuICAgICAgICAgIDxTY3JvbGxBcmVhXG4gICAgICAgICAgICBjc3M9e21lbnVXcmFwcGVyU3R5bGV9XG4gICAgICAgICAgICBzY3JvbGxiYXJTaXplPXs4fVxuICAgICAgICAgICAgdHlwZT1cInNjcm9sbFwiXG4gICAgICAgICAgICB2aWV3cG9ydENsYXNzTmFtZT17Y3NzKG1lbnVDb250YWluZXJTdHlsZSl9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPE1lbnUgaXNTaWRlYmFyQ29sbGFwc2VkPXtpc1NpZGViYXJDb2xsYXBzZWR9IGxheW91dD1cInZlcnRpY2FsXCIgLz5cbiAgICAgICAgICA8L1Njcm9sbEFyZWE+XG4gICAgICAgICl9XG4gICAgICA8L0NsYXNzTmFtZXM+XG4gICAgPC8+XG4gICk7XG59XG4iXX0= */",
|
|
18
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
19
|
+
};
|
|
20
|
+
const menuWrapperStyle = process.env.NODE_ENV === "production" ? {
|
|
21
|
+
name: "1o3mejq",
|
|
22
|
+
styles: "flex:auto"
|
|
23
|
+
} : {
|
|
24
|
+
name: "1o3mejq",
|
|
25
|
+
styles: "flex:auto/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3NpZGViYXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtCeUIiLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvc2lkZWJhci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IExheW91dFByb3BzIH0gZnJvbSBcIi4uL3Byb3BzXCI7XG5cbmltcG9ydCB7IENsYXNzTmFtZXMsIGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgU2Nyb2xsQXJlYSB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmltcG9ydCB7IEhvbmV5Y29tYlBhdHRlcm4gfSBmcm9tIFwiLi9ob25leWNvbWItcGF0dGVyblwiO1xuaW1wb3J0IHsgTG9nbyB9IGZyb20gXCIuL2xvZ29cIjtcbmltcG9ydCB7IE1lbnUgfSBmcm9tIFwiLi9tZW51XCI7XG5cbmludGVyZmFjZSBTaWRlYmFyUHJvcHMgZXh0ZW5kcyBQaWNrPExheW91dFByb3BzLCBcImxvZ29cIiB8IFwidGl0bGVcIj4ge1xuICBpc1NpZGViYXJDb2xsYXBzZWQ/OiBib29sZWFuO1xufVxuXG5jb25zdCBsb2dvU3R5bGUgPSBjc3Moe1xuICBmbGV4OiBcIm5vbmVcIixcbiAgaGVpZ2h0OiBcInZhcigtLXZlZi1sYXlvdXQtaGVhZGVyLWhlaWdodClcIlxufSk7XG5cbmNvbnN0IG1lbnVXcmFwcGVyU3R5bGUgPSBjc3Moe1xuICBmbGV4OiBcImF1dG9cIlxufSk7XG5cbmNvbnN0IG1lbnVDb250YWluZXJTdHlsZSA9IGNzcyh7XG4gIHBhZGRpbmc6IFwiMnB4XCJcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2lkZWJhcih7XG4gIGlzU2lkZWJhckNvbGxhcHNlZCxcbiAgbG9nbyxcbiAgdGl0bGVcbn06IFNpZGViYXJQcm9wcykge1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8SG9uZXljb21iUGF0dGVybiAvPlxuXG4gICAgICA8TG9nb1xuICAgICAgICBjc3M9e2xvZ29TdHlsZX1cbiAgICAgICAgaXNUaXRsZVZpc2libGU9eyFpc1NpZGViYXJDb2xsYXBzZWR9XG4gICAgICAgIGxvZ289e2xvZ299XG4gICAgICAgIHRpdGxlPXt0aXRsZX1cbiAgICAgIC8+XG5cbiAgICAgIDxDbGFzc05hbWVzPlxuICAgICAgICB7KHsgY3NzIH0pID0+IChcbiAgICAgICAgICA8U2Nyb2xsQXJlYVxuICAgICAgICAgICAgY3NzPXttZW51V3JhcHBlclN0eWxlfVxuICAgICAgICAgICAgc2Nyb2xsYmFyU2l6ZT17OH1cbiAgICAgICAgICAgIHR5cGU9XCJzY3JvbGxcIlxuICAgICAgICAgICAgdmlld3BvcnRDbGFzc05hbWU9e2NzcyhtZW51Q29udGFpbmVyU3R5bGUpfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxNZW51IGlzU2lkZWJhckNvbGxhcHNlZD17aXNTaWRlYmFyQ29sbGFwc2VkfSBsYXlvdXQ9XCJ2ZXJ0aWNhbFwiIC8+XG4gICAgICAgICAgPC9TY3JvbGxBcmVhPlxuICAgICAgICApfVxuICAgICAgPC9DbGFzc05hbWVzPlxuICAgIDwvPlxuICApO1xufVxuIl19 */",
|
|
26
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
27
|
+
};
|
|
28
|
+
const menuContainerStyle = process.env.NODE_ENV === "production" ? {
|
|
29
|
+
name: "eeu0j5",
|
|
30
|
+
styles: "padding:2px"
|
|
31
|
+
} : {
|
|
32
|
+
name: "eeu0j5",
|
|
33
|
+
styles: "padding:2px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3NpZGViYXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCMkIiLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvc2lkZWJhci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IExheW91dFByb3BzIH0gZnJvbSBcIi4uL3Byb3BzXCI7XG5cbmltcG9ydCB7IENsYXNzTmFtZXMsIGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgU2Nyb2xsQXJlYSB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmltcG9ydCB7IEhvbmV5Y29tYlBhdHRlcm4gfSBmcm9tIFwiLi9ob25leWNvbWItcGF0dGVyblwiO1xuaW1wb3J0IHsgTG9nbyB9IGZyb20gXCIuL2xvZ29cIjtcbmltcG9ydCB7IE1lbnUgfSBmcm9tIFwiLi9tZW51XCI7XG5cbmludGVyZmFjZSBTaWRlYmFyUHJvcHMgZXh0ZW5kcyBQaWNrPExheW91dFByb3BzLCBcImxvZ29cIiB8IFwidGl0bGVcIj4ge1xuICBpc1NpZGViYXJDb2xsYXBzZWQ/OiBib29sZWFuO1xufVxuXG5jb25zdCBsb2dvU3R5bGUgPSBjc3Moe1xuICBmbGV4OiBcIm5vbmVcIixcbiAgaGVpZ2h0OiBcInZhcigtLXZlZi1sYXlvdXQtaGVhZGVyLWhlaWdodClcIlxufSk7XG5cbmNvbnN0IG1lbnVXcmFwcGVyU3R5bGUgPSBjc3Moe1xuICBmbGV4OiBcImF1dG9cIlxufSk7XG5cbmNvbnN0IG1lbnVDb250YWluZXJTdHlsZSA9IGNzcyh7XG4gIHBhZGRpbmc6IFwiMnB4XCJcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2lkZWJhcih7XG4gIGlzU2lkZWJhckNvbGxhcHNlZCxcbiAgbG9nbyxcbiAgdGl0bGVcbn06IFNpZGViYXJQcm9wcykge1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8SG9uZXljb21iUGF0dGVybiAvPlxuXG4gICAgICA8TG9nb1xuICAgICAgICBjc3M9e2xvZ29TdHlsZX1cbiAgICAgICAgaXNUaXRsZVZpc2libGU9eyFpc1NpZGViYXJDb2xsYXBzZWR9XG4gICAgICAgIGxvZ289e2xvZ299XG4gICAgICAgIHRpdGxlPXt0aXRsZX1cbiAgICAgIC8+XG5cbiAgICAgIDxDbGFzc05hbWVzPlxuICAgICAgICB7KHsgY3NzIH0pID0+IChcbiAgICAgICAgICA8U2Nyb2xsQXJlYVxuICAgICAgICAgICAgY3NzPXttZW51V3JhcHBlclN0eWxlfVxuICAgICAgICAgICAgc2Nyb2xsYmFyU2l6ZT17OH1cbiAgICAgICAgICAgIHR5cGU9XCJzY3JvbGxcIlxuICAgICAgICAgICAgdmlld3BvcnRDbGFzc05hbWU9e2NzcyhtZW51Q29udGFpbmVyU3R5bGUpfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxNZW51IGlzU2lkZWJhckNvbGxhcHNlZD17aXNTaWRlYmFyQ29sbGFwc2VkfSBsYXlvdXQ9XCJ2ZXJ0aWNhbFwiIC8+XG4gICAgICAgICAgPC9TY3JvbGxBcmVhPlxuICAgICAgICApfVxuICAgICAgPC9DbGFzc05hbWVzPlxuICAgIDwvPlxuICApO1xufVxuIl19 */",
|
|
34
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
35
|
+
};
|
|
36
|
+
function Sidebar({
|
|
37
|
+
isSidebarCollapsed,
|
|
38
|
+
logo,
|
|
39
|
+
title
|
|
40
|
+
}) {
|
|
41
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
42
|
+
/* @__PURE__ */ jsx(HoneycombPattern, {}),
|
|
43
|
+
/* @__PURE__ */ jsx(Logo, { css: logoStyle, isTitleVisible: !isSidebarCollapsed, logo, title }),
|
|
44
|
+
/* @__PURE__ */ jsx(ClassNames, { children: ({
|
|
45
|
+
css: css2
|
|
46
|
+
}) => /* @__PURE__ */ jsx(ScrollArea, { css: menuWrapperStyle, scrollbarSize: 8, type: "scroll", viewportClassName: css2(menuContainerStyle), children: /* @__PURE__ */ jsx(Menu, { isSidebarCollapsed, layout: "vertical" }) }) })
|
|
47
|
+
] });
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export { Sidebar };
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.2 made with ❤️ by Venus | 2025-11-25T15:03:22.856Z */
|
|
2
|
+
import { jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { Icon, Dropdown } from '@vef-framework/components';
|
|
4
|
+
import { useShallow } from '@vef-framework/core';
|
|
5
|
+
import { XIcon, ChevronsLeftRightEllipsisIcon, ArrowLeftFromLineIcon, ArrowRightFromLineIcon, ChevronsRightLeftIcon } from 'lucide-react';
|
|
6
|
+
import '../../../../stores/index.js';
|
|
7
|
+
import '../../hooks/index.js';
|
|
8
|
+
import { useTabStore } from '../../../../stores/tab.js';
|
|
9
|
+
import { useTabNavigate } from '../../hooks/use-tab-navigate.js';
|
|
10
|
+
|
|
11
|
+
const contextMenuOptions = [{
|
|
12
|
+
key: "close",
|
|
13
|
+
icon: /* @__PURE__ */ jsx(Icon, { component: XIcon }),
|
|
14
|
+
label: "关闭"
|
|
15
|
+
}, {
|
|
16
|
+
key: "close-other",
|
|
17
|
+
icon: /* @__PURE__ */ jsx(Icon, { component: ChevronsLeftRightEllipsisIcon }),
|
|
18
|
+
label: "关闭其他"
|
|
19
|
+
}, {
|
|
20
|
+
key: "close-left",
|
|
21
|
+
icon: /* @__PURE__ */ jsx(Icon, { component: ArrowLeftFromLineIcon }),
|
|
22
|
+
label: "关闭左侧"
|
|
23
|
+
}, {
|
|
24
|
+
key: "close-right",
|
|
25
|
+
icon: /* @__PURE__ */ jsx(Icon, { component: ArrowRightFromLineIcon }),
|
|
26
|
+
label: "关闭右侧"
|
|
27
|
+
}, {
|
|
28
|
+
key: "close-all",
|
|
29
|
+
icon: /* @__PURE__ */ jsx(Icon, { component: ChevronsRightLeftIcon }),
|
|
30
|
+
label: "关闭所有"
|
|
31
|
+
}];
|
|
32
|
+
function ContextMenu({
|
|
33
|
+
children,
|
|
34
|
+
tabId
|
|
35
|
+
}) {
|
|
36
|
+
const {
|
|
37
|
+
removeTab,
|
|
38
|
+
removeAllTabs,
|
|
39
|
+
removeAllTabsExcept,
|
|
40
|
+
removeLeftTabs,
|
|
41
|
+
removeRightTabs
|
|
42
|
+
} = useTabStore(useShallow(({
|
|
43
|
+
removeTab: removeTab2,
|
|
44
|
+
removeAllTabs: removeAllTabs2,
|
|
45
|
+
removeAllTabsExcept: removeAllTabsExcept2,
|
|
46
|
+
removeLeftTabs: removeLeftTabs2,
|
|
47
|
+
removeRightTabs: removeRightTabs2
|
|
48
|
+
}) => {
|
|
49
|
+
return {
|
|
50
|
+
removeTab: removeTab2,
|
|
51
|
+
removeAllTabs: removeAllTabs2,
|
|
52
|
+
removeAllTabsExcept: removeAllTabsExcept2,
|
|
53
|
+
removeLeftTabs: removeLeftTabs2,
|
|
54
|
+
removeRightTabs: removeRightTabs2
|
|
55
|
+
};
|
|
56
|
+
}));
|
|
57
|
+
const navigate = useTabNavigate({
|
|
58
|
+
async: true
|
|
59
|
+
});
|
|
60
|
+
const handleMenuClick = ({
|
|
61
|
+
key
|
|
62
|
+
}) => {
|
|
63
|
+
switch (key) {
|
|
64
|
+
case "close": {
|
|
65
|
+
removeTab(tabId, navigate);
|
|
66
|
+
break;
|
|
67
|
+
}
|
|
68
|
+
case "close-other": {
|
|
69
|
+
removeAllTabsExcept(tabId, navigate);
|
|
70
|
+
break;
|
|
71
|
+
}
|
|
72
|
+
case "close-left": {
|
|
73
|
+
removeLeftTabs(tabId, navigate);
|
|
74
|
+
break;
|
|
75
|
+
}
|
|
76
|
+
case "close-right": {
|
|
77
|
+
removeRightTabs(tabId, navigate);
|
|
78
|
+
break;
|
|
79
|
+
}
|
|
80
|
+
case "close-all": {
|
|
81
|
+
removeAllTabs(navigate);
|
|
82
|
+
break;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
return /* @__PURE__ */ jsx(Dropdown, { trigger: ["contextMenu"], menu: {
|
|
87
|
+
items: contextMenuOptions,
|
|
88
|
+
onClick: handleMenuClick
|
|
89
|
+
}, children });
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
export { ContextMenu };
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.2 made with ❤️ by Venus | 2025-11-25T15:03:22.856Z */
|
|
2
|
+
import { jsxs, jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { css } from '@emotion/react';
|
|
4
|
+
import { globalCssVars } from '@vef-framework/components';
|
|
5
|
+
import { MainContentMaximum } from './main-content-maximum.js';
|
|
6
|
+
import { Reload } from './reload.js';
|
|
7
|
+
import { TabsContainer } from './tabs-container.js';
|
|
8
|
+
|
|
9
|
+
const tabsStyle = /* @__PURE__ */ css({
|
|
10
|
+
position: "relative",
|
|
11
|
+
zIndex: 1,
|
|
12
|
+
height: "100%",
|
|
13
|
+
backgroundColor: globalCssVars.colorBgContainer,
|
|
14
|
+
boxShadow: "0 1px 2px rgb(0, 21, 41, 0.08)",
|
|
15
|
+
padding: `0 ${globalCssVars.spacingSm}`,
|
|
16
|
+
display: "flex",
|
|
17
|
+
gap: globalCssVars.spacingSm
|
|
18
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RhYnMvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU9rQiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90YWJzL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmltcG9ydCB7IE1haW5Db250ZW50TWF4aW11bSB9IGZyb20gXCIuL21haW4tY29udGVudC1tYXhpbXVtXCI7XG5pbXBvcnQgeyBSZWxvYWQgfSBmcm9tIFwiLi9yZWxvYWRcIjtcbmltcG9ydCB7IFRhYnNDb250YWluZXIgfSBmcm9tIFwiLi90YWJzLWNvbnRhaW5lclwiO1xuXG5jb25zdCB0YWJzU3R5bGUgPSBjc3Moe1xuICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICB6SW5kZXg6IDEsXG4gIGhlaWdodDogXCIxMDAlXCIsXG4gIGJhY2tncm91bmRDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvckJnQ29udGFpbmVyLFxuICBib3hTaGFkb3c6IFwiMCAxcHggMnB4IHJnYigwLCAyMSwgNDEsIDAuMDgpXCIsXG4gIHBhZGRpbmc6IGAwICR7Z2xvYmFsQ3NzVmFycy5zcGFjaW5nU219YCxcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGdhcDogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nU21cbn0pO1xuXG5jb25zdCBhY3Rpb25zU3R5bGUgPSBjc3Moe1xuICBmbGV4OiBcIm5vbmVcIixcbiAgaGVpZ2h0OiBcIjEwMCVcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGNvbHVtbkdhcDogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nWHhzLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiXG59KTtcblxuZXhwb3J0IGZ1bmN0aW9uIFRhYnMoKSB7XG4gIHJldHVybiAoXG4gICAgPGRpdiBjc3M9e3RhYnNTdHlsZX0+XG4gICAgICA8VGFic0NvbnRhaW5lciAvPlxuXG4gICAgICA8ZGl2IGNzcz17YWN0aW9uc1N0eWxlfT5cbiAgICAgICAgPFJlbG9hZCAvPlxuICAgICAgICA8TWFpbkNvbnRlbnRNYXhpbXVtIC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdfQ== */");
|
|
19
|
+
const actionsStyle = /* @__PURE__ */ css({
|
|
20
|
+
flex: "none",
|
|
21
|
+
height: "100%",
|
|
22
|
+
display: "flex",
|
|
23
|
+
columnGap: globalCssVars.spacingXxs,
|
|
24
|
+
alignItems: "center"
|
|
25
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RhYnMvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtCcUIiLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGFicy9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB7IGdsb2JhbENzc1ZhcnMgfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuXG5pbXBvcnQgeyBNYWluQ29udGVudE1heGltdW0gfSBmcm9tIFwiLi9tYWluLWNvbnRlbnQtbWF4aW11bVwiO1xuaW1wb3J0IHsgUmVsb2FkIH0gZnJvbSBcIi4vcmVsb2FkXCI7XG5pbXBvcnQgeyBUYWJzQ29udGFpbmVyIH0gZnJvbSBcIi4vdGFicy1jb250YWluZXJcIjtcblxuY29uc3QgdGFic1N0eWxlID0gY3NzKHtcbiAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgekluZGV4OiAxLFxuICBoZWlnaHQ6IFwiMTAwJVwiLFxuICBiYWNrZ3JvdW5kQ29sb3I6IGdsb2JhbENzc1ZhcnMuY29sb3JCZ0NvbnRhaW5lcixcbiAgYm94U2hhZG93OiBcIjAgMXB4IDJweCByZ2IoMCwgMjEsIDQxLCAwLjA4KVwiLFxuICBwYWRkaW5nOiBgMCAke2dsb2JhbENzc1ZhcnMuc3BhY2luZ1NtfWAsXG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBnYXA6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ1NtXG59KTtcblxuY29uc3QgYWN0aW9uc1N0eWxlID0gY3NzKHtcbiAgZmxleDogXCJub25lXCIsXG4gIGhlaWdodDogXCIxMDAlXCIsXG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBjb2x1bW5HYXA6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ1h4cyxcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIlxufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBUYWJzKCkge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY3NzPXt0YWJzU3R5bGV9PlxuICAgICAgPFRhYnNDb250YWluZXIgLz5cblxuICAgICAgPGRpdiBjc3M9e2FjdGlvbnNTdHlsZX0+XG4gICAgICAgIDxSZWxvYWQgLz5cbiAgICAgICAgPE1haW5Db250ZW50TWF4aW11bSAvPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICk7XG59XG4iXX0= */");
|
|
26
|
+
function Tabs() {
|
|
27
|
+
return /* @__PURE__ */ jsxs("div", { css: tabsStyle, children: [
|
|
28
|
+
/* @__PURE__ */ jsx(TabsContainer, {}),
|
|
29
|
+
/* @__PURE__ */ jsxs("div", { css: actionsStyle, children: [
|
|
30
|
+
/* @__PURE__ */ jsx(Reload, {}),
|
|
31
|
+
/* @__PURE__ */ jsx(MainContentMaximum, {})
|
|
32
|
+
] })
|
|
33
|
+
] });
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export { Tabs };
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.2 made with ❤️ by Venus | 2025-11-25T15:03:22.856Z */
|
|
2
|
+
import { jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { IconButton } from '@vef-framework/components';
|
|
4
|
+
import { ShrinkIcon, ExpandIcon } from 'lucide-react';
|
|
5
|
+
import '../../../../stores/index.js';
|
|
6
|
+
import { useThemeStore } from '../../../../stores/theme.js';
|
|
7
|
+
|
|
8
|
+
function MainContentMaximum({
|
|
9
|
+
className
|
|
10
|
+
}) {
|
|
11
|
+
const isMainContentMaximum = useThemeStore((state) => state.isMainContentMaximum);
|
|
12
|
+
return /* @__PURE__ */ jsx(IconButton, { className, icon: isMainContentMaximum ? /* @__PURE__ */ jsx(ShrinkIcon, {}) : /* @__PURE__ */ jsx(ExpandIcon, {}), placement: "bottom", tip: isMainContentMaximum ? "退出内容最大化" : "内容最大化", onClick: () => {
|
|
13
|
+
useThemeStore.setState((state) => {
|
|
14
|
+
state.isMainContentMaximum = !state.isMainContentMaximum;
|
|
15
|
+
});
|
|
16
|
+
} }, String(isMainContentMaximum));
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export { MainContentMaximum };
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.2 made with ❤️ by Venus | 2025-11-25T15:03:22.856Z */
|
|
2
|
+
import { jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { IconButton } from '@vef-framework/components';
|
|
4
|
+
import { RefreshCwIcon } from 'lucide-react';
|
|
5
|
+
import '../../../../helpers/index.js';
|
|
6
|
+
import '../../../../hooks/index.js';
|
|
7
|
+
import { useRouteFullPath } from '../../../../hooks/use-route-full-path.js';
|
|
8
|
+
import { reloadPage } from '../../../../helpers/event.js';
|
|
9
|
+
|
|
10
|
+
function Reload({
|
|
11
|
+
className
|
|
12
|
+
}) {
|
|
13
|
+
const fullPath = useRouteFullPath();
|
|
14
|
+
return /* @__PURE__ */ jsx(IconButton, { className, icon: /* @__PURE__ */ jsx(RefreshCwIcon, {}), placement: "bottom", tip: "刷新页面", onClick: () => reloadPage(fullPath) });
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export { Reload };
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.2 made with ❤️ by Venus | 2025-11-25T15:03:22.856Z */
|
|
2
|
+
import { jsxs, jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { css } from '@emotion/react';
|
|
4
|
+
import { globalCssVars, IconButton } from '@vef-framework/components';
|
|
5
|
+
import { useSortable, motion } from '@vef-framework/core';
|
|
6
|
+
import { useMergedRef } from '@vef-framework/hooks';
|
|
7
|
+
import { XIcon } from 'lucide-react';
|
|
8
|
+
|
|
9
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
10
|
+
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).";
|
|
11
|
+
}
|
|
12
|
+
const tabItemStyle = /* @__PURE__ */ css({
|
|
13
|
+
flex: "none",
|
|
14
|
+
height: "calc(100% - 12px)",
|
|
15
|
+
display: "flex",
|
|
16
|
+
alignItems: "center",
|
|
17
|
+
columnGap: globalCssVars.spacingXs,
|
|
18
|
+
paddingInlineStart: globalCssVars.spacingSm,
|
|
19
|
+
paddingInlineEnd: `calc(${globalCssVars.spacingSm} - 3px)`,
|
|
20
|
+
borderRadius: globalCssVars.borderRadiusSm,
|
|
21
|
+
cursor: "pointer",
|
|
22
|
+
border: `1px solid ${globalCssVars.colorBorderSecondary}`,
|
|
23
|
+
userSelect: "none",
|
|
24
|
+
backgroundColor: globalCssVars.colorBgContainer,
|
|
25
|
+
transitionDuration: globalCssVars.motionDurationMid,
|
|
26
|
+
transitionProperty: "color, border-color, background-color",
|
|
27
|
+
transitionTimingFunction: "ease",
|
|
28
|
+
"&:hover": {
|
|
29
|
+
color: globalCssVars.colorPrimaryText,
|
|
30
|
+
borderColor: globalCssVars.colorPrimaryBorder,
|
|
31
|
+
"& .vef-btn-sm": {
|
|
32
|
+
"--vef-btn-text-color": globalCssVars.colorPrimaryText,
|
|
33
|
+
"--vef-btn-text-color-hover": globalCssVars.colorPrimaryTextHover,
|
|
34
|
+
"--vef-btn-text-color-active": globalCssVars.colorPrimaryTextActive
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
"&.active": {
|
|
38
|
+
color: globalCssVars.colorPrimaryText,
|
|
39
|
+
borderColor: globalCssVars.colorPrimaryBorder,
|
|
40
|
+
backgroundColor: globalCssVars.colorPrimaryBg,
|
|
41
|
+
"& .vef-btn-sm": {
|
|
42
|
+
"--vef-btn-text-color": globalCssVars.colorPrimaryText,
|
|
43
|
+
"--vef-btn-text-color-hover": globalCssVars.colorPrimaryTextHover,
|
|
44
|
+
"--vef-btn-text-color-active": globalCssVars.colorPrimaryTextActive
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RhYnMvdGFiLWl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVxQiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90YWJzL3RhYi1pdGVtLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMsIFJlYWN0Tm9kZSB9IGZyb20gXCJyZWFjdFwiO1xuXG5pbXBvcnQgeyBjc3MgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB7IGdsb2JhbENzc1ZhcnMsIEljb25CdXR0b24gfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuaW1wb3J0IHsgbW90aW9uLCB1c2VTb3J0YWJsZSB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb3JlXCI7XG5pbXBvcnQgeyB1c2VNZXJnZWRSZWYgfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvaG9va3NcIjtcbmltcG9ydCB7IFhJY29uIH0gZnJvbSBcImx1Y2lkZS1yZWFjdFwiO1xuXG5pbnRlcmZhY2UgVGFiSXRlbVByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8dHlwZW9mIG1vdGlvbi5kaXY+IHtcbiAgaW5kZXg6IG51bWJlcjtcbiAgdGFiSWQ6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbiAgb25DbG9zZT86ICgpID0+IHZvaWQ7XG59XG5cbmNvbnN0IHRhYkl0ZW1TdHlsZSA9IGNzcyh7XG4gIGZsZXg6IFwibm9uZVwiLFxuICBoZWlnaHQ6IFwiY2FsYygxMDAlIC0gMTJweClcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gIGNvbHVtbkdhcDogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nWHMsXG4gIHBhZGRpbmdJbmxpbmVTdGFydDogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nU20sXG4gIHBhZGRpbmdJbmxpbmVFbmQ6IGBjYWxjKCR7Z2xvYmFsQ3NzVmFycy5zcGFjaW5nU219IC0gM3B4KWAsXG4gIGJvcmRlclJhZGl1czogZ2xvYmFsQ3NzVmFycy5ib3JkZXJSYWRpdXNTbSxcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgYm9yZGVyOiBgMXB4IHNvbGlkICR7Z2xvYmFsQ3NzVmFycy5jb2xvckJvcmRlclNlY29uZGFyeX1gLFxuICB1c2VyU2VsZWN0OiBcIm5vbmVcIixcbiAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yQmdDb250YWluZXIsXG4gIHRyYW5zaXRpb25EdXJhdGlvbjogZ2xvYmFsQ3NzVmFycy5tb3Rpb25EdXJhdGlvbk1pZCxcbiAgdHJhbnNpdGlvblByb3BlcnR5OiBcImNvbG9yLCBib3JkZXItY29sb3IsIGJhY2tncm91bmQtY29sb3JcIixcbiAgdHJhbnNpdGlvblRpbWluZ0Z1bmN0aW9uOiBcImVhc2VcIixcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBjb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlUZXh0LFxuICAgIGJvcmRlckNvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeUJvcmRlcixcbiAgICBcIiYgLnZlZi1idG4tc21cIjoge1xuICAgICAgXCItLXZlZi1idG4tdGV4dC1jb2xvclwiOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeVRleHQsXG4gICAgICBcIi0tdmVmLWJ0bi10ZXh0LWNvbG9yLWhvdmVyXCI6IGdsb2JhbENzc1ZhcnMuY29sb3JQcmltYXJ5VGV4dEhvdmVyLFxuICAgICAgXCItLXZlZi1idG4tdGV4dC1jb2xvci1hY3RpdmVcIjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlUZXh0QWN0aXZlXG4gICAgfVxuICB9LFxuICBcIiYuYWN0aXZlXCI6IHtcbiAgICBjb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlUZXh0LFxuICAgIGJvcmRlckNvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeUJvcmRlcixcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IGdsb2JhbENzc1ZhcnMuY29sb3JQcmltYXJ5QmcsXG4gICAgXCImIC52ZWYtYnRuLXNtXCI6IHtcbiAgICAgIFwiLS12ZWYtYnRuLXRleHQtY29sb3JcIjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlUZXh0LFxuICAgICAgXCItLXZlZi1idG4tdGV4dC1jb2xvci1ob3ZlclwiOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeVRleHRIb3ZlcixcbiAgICAgIFwiLS12ZWYtYnRuLXRleHQtY29sb3ItYWN0aXZlXCI6IGdsb2JhbENzc1ZhcnMuY29sb3JQcmltYXJ5VGV4dEFjdGl2ZVxuICAgIH1cbiAgfVxufSk7XG5cbmNvbnN0IGNsb3NlSWNvblN0eWxlID0gY3NzKHtcbiAgXCImLnZlZi1idG4tc21cIjoge1xuICAgIFwiLS12ZWYtY29udHJvbC1oZWlnaHQtc21cIjogXCIyMHB4XCIsXG4gICAgXCItLXZlZi1idXR0b24tY29udGVudC1mb250LXNpemUtc21cIjogXCIxMnB4XCJcbiAgfVxufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBUYWJJdGVtKHtcbiAgcmVmLFxuICBpbmRleCxcbiAgdGFiSWQsXG4gIGxhYmVsLFxuICBvbkNsb3NlLFxuICAuLi5wcm9wc1xufTogVGFiSXRlbVByb3BzKSB7XG4gIGNvbnN0IHsgcmVmOiBzb3J0YWJsZVJlZiB9ID0gdXNlU29ydGFibGUoe1xuICAgIGlkOiB0YWJJZCxcbiAgICBpbmRleFxuICB9KTtcbiAgY29uc3QgbWVyZ2VkUmVmID0gdXNlTWVyZ2VkUmVmPEhUTUxEaXZFbGVtZW50Pihzb3J0YWJsZVJlZiwgcmVmKTtcblxuICByZXR1cm4gKFxuICAgIDxtb3Rpb24uZGl2XG4gICAgICByZWY9e21lcmdlZFJlZn1cbiAgICAgIGNzcz17dGFiSXRlbVN0eWxlfVxuICAgICAgey4uLnByb3BzfVxuICAgID5cbiAgICAgIDxzcGFuPntsYWJlbH08L3NwYW4+XG5cbiAgICAgIDxJY29uQnV0dG9uXG4gICAgICAgIGNzcz17Y2xvc2VJY29uU3R5bGV9XG4gICAgICAgIGljb249ezxYSWNvbiAvPn1cbiAgICAgICAgc2hhcGU9XCJyb3VuZFwiXG4gICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgIG9uQ2xpY2s9e2V2ZW50ID0+IHtcbiAgICAgICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgICAgICBvbkNsb3NlPy4oKTtcbiAgICAgICAgfX1cbiAgICAgIC8+XG4gICAgPC9tb3Rpb24uZGl2PlxuICApO1xufVxuIl19 */");
|
|
48
|
+
const closeIconStyle = process.env.NODE_ENV === "production" ? {
|
|
49
|
+
name: "n4rgm7",
|
|
50
|
+
styles: "&.vef-btn-sm{--vef-control-height-sm:20px;--vef-button-content-font-size-sm:12px;}"
|
|
51
|
+
} : {
|
|
52
|
+
name: "n4rgm7",
|
|
53
|
+
styles: "&.vef-btn-sm{--vef-control-height-sm:20px;--vef-button-content-font-size-sm:12px;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RhYnMvdGFiLWl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9EdUIiLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGFicy90YWItaXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tIFwicmVhY3RcIjtcblxuaW1wb3J0IHsgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgeyBnbG9iYWxDc3NWYXJzLCBJY29uQnV0dG9uIH0gZnJvbSBcIkB2ZWYtZnJhbWV3b3JrL2NvbXBvbmVudHNcIjtcbmltcG9ydCB7IG1vdGlvbiwgdXNlU29ydGFibGUgfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29yZVwiO1xuaW1wb3J0IHsgdXNlTWVyZ2VkUmVmIH0gZnJvbSBcIkB2ZWYtZnJhbWV3b3JrL2hvb2tzXCI7XG5pbXBvcnQgeyBYSWNvbiB9IGZyb20gXCJsdWNpZGUtcmVhY3RcIjtcblxuaW50ZXJmYWNlIFRhYkl0ZW1Qcm9wcyBleHRlbmRzIENvbXBvbmVudFByb3BzPHR5cGVvZiBtb3Rpb24uZGl2PiB7XG4gIGluZGV4OiBudW1iZXI7XG4gIHRhYklkOiBzdHJpbmc7XG4gIGxhYmVsOiBSZWFjdE5vZGU7XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xufVxuXG5jb25zdCB0YWJJdGVtU3R5bGUgPSBjc3Moe1xuICBmbGV4OiBcIm5vbmVcIixcbiAgaGVpZ2h0OiBcImNhbGMoMTAwJSAtIDEycHgpXCIsXG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBjb2x1bW5HYXA6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ1hzLFxuICBwYWRkaW5nSW5saW5lU3RhcnQ6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ1NtLFxuICBwYWRkaW5nSW5saW5lRW5kOiBgY2FsYygke2dsb2JhbENzc1ZhcnMuc3BhY2luZ1NtfSAtIDNweClgLFxuICBib3JkZXJSYWRpdXM6IGdsb2JhbENzc1ZhcnMuYm9yZGVyUmFkaXVzU20sXG4gIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gIGJvcmRlcjogYDFweCBzb2xpZCAke2dsb2JhbENzc1ZhcnMuY29sb3JCb3JkZXJTZWNvbmRhcnl9YCxcbiAgdXNlclNlbGVjdDogXCJub25lXCIsXG4gIGJhY2tncm91bmRDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvckJnQ29udGFpbmVyLFxuICB0cmFuc2l0aW9uRHVyYXRpb246IGdsb2JhbENzc1ZhcnMubW90aW9uRHVyYXRpb25NaWQsXG4gIHRyYW5zaXRpb25Qcm9wZXJ0eTogXCJjb2xvciwgYm9yZGVyLWNvbG9yLCBiYWNrZ3JvdW5kLWNvbG9yXCIsXG4gIHRyYW5zaXRpb25UaW1pbmdGdW5jdGlvbjogXCJlYXNlXCIsXG4gIFwiJjpob3ZlclwiOiB7XG4gICAgY29sb3I6IGdsb2JhbENzc1ZhcnMuY29sb3JQcmltYXJ5VGV4dCxcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlCb3JkZXIsXG4gICAgXCImIC52ZWYtYnRuLXNtXCI6IHtcbiAgICAgIFwiLS12ZWYtYnRuLXRleHQtY29sb3JcIjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlUZXh0LFxuICAgICAgXCItLXZlZi1idG4tdGV4dC1jb2xvci1ob3ZlclwiOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeVRleHRIb3ZlcixcbiAgICAgIFwiLS12ZWYtYnRuLXRleHQtY29sb3ItYWN0aXZlXCI6IGdsb2JhbENzc1ZhcnMuY29sb3JQcmltYXJ5VGV4dEFjdGl2ZVxuICAgIH1cbiAgfSxcbiAgXCImLmFjdGl2ZVwiOiB7XG4gICAgY29sb3I6IGdsb2JhbENzc1ZhcnMuY29sb3JQcmltYXJ5VGV4dCxcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlCb3JkZXIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeUJnLFxuICAgIFwiJiAudmVmLWJ0bi1zbVwiOiB7XG4gICAgICBcIi0tdmVmLWJ0bi10ZXh0LWNvbG9yXCI6IGdsb2JhbENzc1ZhcnMuY29sb3JQcmltYXJ5VGV4dCxcbiAgICAgIFwiLS12ZWYtYnRuLXRleHQtY29sb3ItaG92ZXJcIjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlUZXh0SG92ZXIsXG4gICAgICBcIi0tdmVmLWJ0bi10ZXh0LWNvbG9yLWFjdGl2ZVwiOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeVRleHRBY3RpdmVcbiAgICB9XG4gIH1cbn0pO1xuXG5jb25zdCBjbG9zZUljb25TdHlsZSA9IGNzcyh7XG4gIFwiJi52ZWYtYnRuLXNtXCI6IHtcbiAgICBcIi0tdmVmLWNvbnRyb2wtaGVpZ2h0LXNtXCI6IFwiMjBweFwiLFxuICAgIFwiLS12ZWYtYnV0dG9uLWNvbnRlbnQtZm9udC1zaXplLXNtXCI6IFwiMTJweFwiXG4gIH1cbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gVGFiSXRlbSh7XG4gIHJlZixcbiAgaW5kZXgsXG4gIHRhYklkLFxuICBsYWJlbCxcbiAgb25DbG9zZSxcbiAgLi4ucHJvcHNcbn06IFRhYkl0ZW1Qcm9wcykge1xuICBjb25zdCB7IHJlZjogc29ydGFibGVSZWYgfSA9IHVzZVNvcnRhYmxlKHtcbiAgICBpZDogdGFiSWQsXG4gICAgaW5kZXhcbiAgfSk7XG4gIGNvbnN0IG1lcmdlZFJlZiA9IHVzZU1lcmdlZFJlZjxIVE1MRGl2RWxlbWVudD4oc29ydGFibGVSZWYsIHJlZik7XG5cbiAgcmV0dXJuIChcbiAgICA8bW90aW9uLmRpdlxuICAgICAgcmVmPXttZXJnZWRSZWZ9XG4gICAgICBjc3M9e3RhYkl0ZW1TdHlsZX1cbiAgICAgIHsuLi5wcm9wc31cbiAgICA+XG4gICAgICA8c3Bhbj57bGFiZWx9PC9zcGFuPlxuXG4gICAgICA8SWNvbkJ1dHRvblxuICAgICAgICBjc3M9e2Nsb3NlSWNvblN0eWxlfVxuICAgICAgICBpY29uPXs8WEljb24gLz59XG4gICAgICAgIHNoYXBlPVwicm91bmRcIlxuICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICBvbkNsaWNrPXtldmVudCA9PiB7XG4gICAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgICAgb25DbG9zZT8uKCk7XG4gICAgICAgIH19XG4gICAgICAvPlxuICAgIDwvbW90aW9uLmRpdj5cbiAgKTtcbn1cbiJdfQ== */",
|
|
54
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
55
|
+
};
|
|
56
|
+
function TabItem({
|
|
57
|
+
ref,
|
|
58
|
+
index,
|
|
59
|
+
tabId,
|
|
60
|
+
label,
|
|
61
|
+
onClose,
|
|
62
|
+
...props
|
|
63
|
+
}) {
|
|
64
|
+
const {
|
|
65
|
+
ref: sortableRef
|
|
66
|
+
} = useSortable({
|
|
67
|
+
id: tabId,
|
|
68
|
+
index
|
|
69
|
+
});
|
|
70
|
+
const mergedRef = useMergedRef(sortableRef, ref);
|
|
71
|
+
return /* @__PURE__ */ jsxs(motion.div, { ref: mergedRef, css: tabItemStyle, ...props, children: [
|
|
72
|
+
/* @__PURE__ */ jsx("span", { children: label }),
|
|
73
|
+
/* @__PURE__ */ jsx(IconButton, { css: closeIconStyle, icon: /* @__PURE__ */ jsx(XIcon, {}), shape: "round", size: "small", onClick: (event) => {
|
|
74
|
+
event.stopPropagation();
|
|
75
|
+
onClose?.();
|
|
76
|
+
} })
|
|
77
|
+
] });
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
export { TabItem };
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
/*! @vef-framework/starter v2.0.2 made with ❤️ by Venus | 2025-11-25T15:03:22.856Z */
|
|
2
|
+
import { jsx } from '@emotion/react/jsx-runtime';
|
|
3
|
+
import { css } from '@emotion/react';
|
|
4
|
+
import { globalCssVars } from '@vef-framework/components';
|
|
5
|
+
import { useShallow, DragDropProvider, AnimatePresence, clsx, moveDragItem, RestrictToHorizontalAxis } from '@vef-framework/core';
|
|
6
|
+
import '../../../../constants/index.js';
|
|
7
|
+
import '../../../../stores/index.js';
|
|
8
|
+
import '../../hooks/index.js';
|
|
9
|
+
import { ContextMenu } from './context-menu.js';
|
|
10
|
+
import { TabItem } from './tab-item.js';
|
|
11
|
+
import { useTabStore } from '../../../../stores/tab.js';
|
|
12
|
+
import { useTabNavigate } from '../../hooks/use-tab-navigate.js';
|
|
13
|
+
import { INDEX_ROUTE_PATH } from '../../../../constants/router.js';
|
|
14
|
+
|
|
15
|
+
const tabListStyle = /* @__PURE__ */ css({
|
|
16
|
+
display: "flex",
|
|
17
|
+
alignItems: "center",
|
|
18
|
+
height: "var(--vef-layout-tabs-height)",
|
|
19
|
+
columnGap: globalCssVars.spacingXs,
|
|
20
|
+
width: "max-content"
|
|
21
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RhYnMvdGFiLWxpc3QudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVVxQiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90YWJzL3RhYi1saXN0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5pbXBvcnQgeyBBbmltYXRlUHJlc2VuY2UsIGNsc3gsIERyYWdEcm9wUHJvdmlkZXIsIG1vdmVEcmFnSXRlbSwgUmVzdHJpY3RUb0hvcml6b250YWxBeGlzLCB1c2VTaGFsbG93IH0gZnJvbSBcIkB2ZWYtZnJhbWV3b3JrL2NvcmVcIjtcblxuaW1wb3J0IHsgSU5ERVhfUk9VVEVfUEFUSCB9IGZyb20gXCIuLi8uLi8uLi8uLi9jb25zdGFudHNcIjtcbmltcG9ydCB7IHVzZVRhYlN0b3JlIH0gZnJvbSBcIi4uLy4uLy4uLy4uL3N0b3Jlc1wiO1xuaW1wb3J0IHsgdXNlVGFiTmF2aWdhdGUgfSBmcm9tIFwiLi4vLi4vaG9va3NcIjtcbmltcG9ydCB7IENvbnRleHRNZW51IH0gZnJvbSBcIi4vY29udGV4dC1tZW51XCI7XG5pbXBvcnQgeyBUYWJJdGVtIH0gZnJvbSBcIi4vdGFiLWl0ZW1cIjtcblxuY29uc3QgdGFiTGlzdFN0eWxlID0gY3NzKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gIGhlaWdodDogXCJ2YXIoLS12ZWYtbGF5b3V0LXRhYnMtaGVpZ2h0KVwiLFxuICBjb2x1bW5HYXA6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ1hzLFxuICB3aWR0aDogXCJtYXgtY29udGVudFwiXG59KTtcblxuZXhwb3J0IGZ1bmN0aW9uIFRhYkxpc3QoKSB7XG4gIGNvbnN0IHsgc2V0VGFicywgcmVtb3ZlVGFiIH0gPSB1c2VUYWJTdG9yZShcbiAgICB1c2VTaGFsbG93KCh7IHNldFRhYnMsIHJlbW92ZVRhYiB9KSA9PiB7XG4gICAgICByZXR1cm4geyBzZXRUYWJzLCByZW1vdmVUYWIgfTtcbiAgICB9KVxuICApO1xuXG4gIGNvbnN0IGFjdGl2ZVRhYklkID0gdXNlVGFiU3RvcmUoc3RhdGUgPT4gc3RhdGUuYWN0aXZlVGFiSWQpO1xuICBjb25zdCB0YWJzID0gdXNlVGFiU3RvcmUoc3RhdGUgPT4gc3RhdGUudGFicyk7XG5cbiAgY29uc3QgbmF2aWdhdGUgPSB1c2VUYWJOYXZpZ2F0ZSgpO1xuXG4gIHJldHVybiAoXG4gICAgPERyYWdEcm9wUHJvdmlkZXJcbiAgICAgIC8vIFRPRE8gT3B0aW1pemUgdHlwZSBtaXNtYXRjaFxuICAgICAgbW9kaWZpZXJzPXtbUmVzdHJpY3RUb0hvcml6b250YWxBeGlzIGFzIG5ldmVyXX1cbiAgICAgIG9uRHJhZ0VuZD17ZXZlbnQgPT4ge1xuICAgICAgICBzZXRUYWJzKFxuICAgICAgICAgIG1vdmVEcmFnSXRlbSh0YWJzLCBldmVudClcbiAgICAgICAgKTtcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBjc3M9e3RhYkxpc3RTdHlsZX0+XG4gICAgICAgIDxBbmltYXRlUHJlc2VuY2U+XG4gICAgICAgICAge1xuICAgICAgICAgICAgdGFicy5tYXAoKHRhYiwgaW5kZXgpID0+IChcbiAgICAgICAgICAgICAgPENvbnRleHRNZW51IGtleT17dGFiLmlkfSB0YWJJZD17dGFiLmlkfT5cbiAgICAgICAgICAgICAgICA8VGFiSXRlbVxuICAgICAgICAgICAgICAgICAgbGF5b3V0XG4gICAgICAgICAgICAgICAgICBpbmRleD17aW5kZXh9XG4gICAgICAgICAgICAgICAgICBsYWJlbD17dGFiLmxhYmVsfVxuICAgICAgICAgICAgICAgICAgdGFiSWQ9e3RhYi5pZH1cbiAgICAgICAgICAgICAgICAgIGFuaW1hdGU9e3tcbiAgICAgICAgICAgICAgICAgICAgb3BhY2l0eTogMSxcbiAgICAgICAgICAgICAgICAgICAgeDogMCxcbiAgICAgICAgICAgICAgICAgICAgc2NhbGU6IDFcbiAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICBjbGFzc05hbWU9e2Nsc3goe1xuICAgICAgICAgICAgICAgICAgICBhY3RpdmU6IHRhYi5pZCA9PT0gYWN0aXZlVGFiSWRcbiAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgZXhpdD17e1xuICAgICAgICAgICAgICAgICAgICBvcGFjaXR5OiAwLFxuICAgICAgICAgICAgICAgICAgICB4OiAtMjAsXG4gICAgICAgICAgICAgICAgICAgIHNjYWxlOiAwLjgsXG4gICAgICAgICAgICAgICAgICAgIHRyYW5zaXRpb246IHtcbiAgICAgICAgICAgICAgICAgICAgICBlYXNlOiBcImVhc2VJblwiXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICBpbml0aWFsPXt7XG4gICAgICAgICAgICAgICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgICAgICAgICAgICAgIHg6IDIwLFxuICAgICAgICAgICAgICAgICAgICBzY2FsZTogMC44XG4gICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgdHJhbnNpdGlvbj17e1xuICAgICAgICAgICAgICAgICAgICBkdXJhdGlvbjogMC4zLFxuICAgICAgICAgICAgICAgICAgICBkZWxheTogaW5kZXggKiAwLjA1LFxuICAgICAgICAgICAgICAgICAgICBlYXNlOiBcImVhc2VPdXRcIlxuICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9e2V2ZW50ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgdGFyZ2V0RWxlbWVudCA9IGV2ZW50LmN1cnJlbnRUYXJnZXQ7XG4gICAgICAgICAgICAgICAgICAgIG5hdmlnYXRlKHRhYik7XG4gICAgICAgICAgICAgICAgICAgIHJlcXVlc3RBbmltYXRpb25GcmFtZSgoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHRhcmdldEVsZW1lbnQuaXNDb25uZWN0ZWQpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRhcmdldEVsZW1lbnQuc2Nyb2xsSW50b1ZpZXcoe1xuICAgICAgICAgICAgICAgICAgICAgICAgICBpbmxpbmU6IFwiY2VudGVyXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgIGJlaGF2aW9yOiBcInNtb290aFwiXG4gICAgICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgIG9uQ2xvc2U9eygpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHRhYnMubGVuZ3RoID09PSAxICYmIHRhYi5mdWxsUGF0aCA9PT0gSU5ERVhfUk9VVEVfUEFUSCkge1xuICAgICAgICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgIHJlbW92ZVRhYih0YWIuaWQsIG5hdmlnYXRlKTtcbiAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgPC9Db250ZXh0TWVudT5cbiAgICAgICAgICAgICkpXG4gICAgICAgICAgfVxuICAgICAgICA8L0FuaW1hdGVQcmVzZW5jZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvRHJhZ0Ryb3BQcm92aWRlcj5cbiAgKTtcbn1cbiJdfQ== */");
|
|
22
|
+
function TabList() {
|
|
23
|
+
const {
|
|
24
|
+
setTabs,
|
|
25
|
+
removeTab
|
|
26
|
+
} = useTabStore(useShallow(({
|
|
27
|
+
setTabs: setTabs2,
|
|
28
|
+
removeTab: removeTab2
|
|
29
|
+
}) => {
|
|
30
|
+
return {
|
|
31
|
+
setTabs: setTabs2,
|
|
32
|
+
removeTab: removeTab2
|
|
33
|
+
};
|
|
34
|
+
}));
|
|
35
|
+
const activeTabId = useTabStore((state) => state.activeTabId);
|
|
36
|
+
const tabs = useTabStore((state) => state.tabs);
|
|
37
|
+
const navigate = useTabNavigate();
|
|
38
|
+
return /* @__PURE__ */ jsx(
|
|
39
|
+
DragDropProvider,
|
|
40
|
+
{
|
|
41
|
+
modifiers: [RestrictToHorizontalAxis],
|
|
42
|
+
onDragEnd: (event) => {
|
|
43
|
+
setTabs(moveDragItem(tabs, event));
|
|
44
|
+
},
|
|
45
|
+
children: /* @__PURE__ */ jsx("div", { css: tabListStyle, children: /* @__PURE__ */ jsx(AnimatePresence, { children: tabs.map((tab, index) => /* @__PURE__ */ jsx(ContextMenu, { tabId: tab.id, children: /* @__PURE__ */ jsx(TabItem, { layout: true, index, label: tab.label, tabId: tab.id, animate: {
|
|
46
|
+
opacity: 1,
|
|
47
|
+
x: 0,
|
|
48
|
+
scale: 1
|
|
49
|
+
}, className: clsx({
|
|
50
|
+
active: tab.id === activeTabId
|
|
51
|
+
}), exit: {
|
|
52
|
+
opacity: 0,
|
|
53
|
+
x: -20,
|
|
54
|
+
scale: 0.8,
|
|
55
|
+
transition: {
|
|
56
|
+
ease: "easeIn"
|
|
57
|
+
}
|
|
58
|
+
}, initial: {
|
|
59
|
+
opacity: 0,
|
|
60
|
+
x: 20,
|
|
61
|
+
scale: 0.8
|
|
62
|
+
}, transition: {
|
|
63
|
+
duration: 0.3,
|
|
64
|
+
delay: index * 0.05,
|
|
65
|
+
ease: "easeOut"
|
|
66
|
+
}, onClick: (event) => {
|
|
67
|
+
const targetElement = event.currentTarget;
|
|
68
|
+
navigate(tab);
|
|
69
|
+
requestAnimationFrame(() => {
|
|
70
|
+
if (targetElement.isConnected) {
|
|
71
|
+
targetElement.scrollIntoView({
|
|
72
|
+
inline: "center",
|
|
73
|
+
behavior: "smooth"
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}, onClose: () => {
|
|
78
|
+
if (tabs.length === 1 && tab.fullPath === INDEX_ROUTE_PATH) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
removeTab(tab.id, navigate);
|
|
82
|
+
} }) }, tab.id)) }) })
|
|
83
|
+
}
|
|
84
|
+
);
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
export { TabList };
|