xto-fronted 0.4.55 → 0.4.56
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/dist/components/Layout/MixTopMenu.vue.d.ts +1 -0
- package/dist/components/Layout/TopMenu.vue.d.ts +1 -0
- package/dist/index-BVpqTdd2.js +3132 -0
- package/dist/index-CgofFg1D.js +372 -0
- package/dist/index-DS1wfdxM.js +142 -0
- package/dist/index-YnSLCdjP.js +475 -0
- package/dist/index-s3vGq0ro.js +345 -0
- package/dist/index.es.js +1 -1
- package/dist/index.umd.js +1 -1
- package/dist/style.css +1 -1
- package/package.json +1 -1
- package/src/components/Layout/MixTopMenu.vue +198 -0
- package/src/components/Layout/TopMenu.vue +198 -0
package/dist/style.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
.sidebar[data-v-356129ba]{height:100%;display:flex;flex-direction:column;background-color:var(--bg-color);border-right:1px solid var(--color-border-lighter)}.sidebar--collapsed .sidebar__logo[data-v-356129ba]{justify-content:center;padding:0}.sidebar__logo[data-v-356129ba]{height:50px;display:flex;align-items:center;padding:0 20px;gap:10px;border-bottom:1px solid var(--color-border-lighter)}.sidebar__logo-img[data-v-356129ba]{width:32px;height:32px}.sidebar__logo-text[data-v-356129ba]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__menu[data-v-356129ba]{flex:1;border-right:none;overflow-y:auto}.sidebar__menu-content[data-v-356129ba]{display:inline-flex;align-items:center;line-height:1}.sidebar__menu-text[data-v-356129ba]{flex:1;line-height:1}.sidebar__menu-icon[data-v-356129ba]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.sidebar__menu-char[data-v-356129ba]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.sidebar__user[data-v-356129ba]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-356129ba]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-356129ba]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-356129ba]{font-size:12px;color:var(--color-text-secondary)}.header[data-v-916fcfad]{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:100%;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.header__left[data-v-916fcfad]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-916fcfad]{width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-regular);transition:color .2s}.header__collapse[data-v-916fcfad]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-916fcfad]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-916fcfad]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-916fcfad]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-916fcfad]{display:flex;align-items:center;gap:8px}.header__search[data-v-916fcfad]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.header__search-icon[data-v-916fcfad]{color:var(--color-text-secondary)}.header__search-input[data-v-916fcfad]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.header__search-input[data-v-916fcfad]::placeholder{color:var(--color-text-placeholder)}.header__search-dropdown[data-v-916fcfad]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.header__search-results[data-v-916fcfad]{padding:8px 0}.header__search-item[data-v-916fcfad]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.header__search-item[data-v-916fcfad]:hover{background-color:var(--color-fill)}.header__search-item-title[data-v-916fcfad]{font-size:14px;color:var(--color-text-primary)}.header__search-item-parent[data-v-916fcfad]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.header__search-icon[data-v-916fcfad]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.header__search-char[data-v-916fcfad]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.header__search-empty[data-v-916fcfad]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.header__action[data-v-916fcfad]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.header__action[data-v-916fcfad]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-916fcfad]{position:relative;margin-left:8px}.header__user-trigger[data-v-916fcfad]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.header__user-trigger[data-v-916fcfad]:hover{background-color:var(--color-fill)}.header__user-name[data-v-916fcfad]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-916fcfad]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-916fcfad]{transform:rotate(180deg)}.header__avatar[data-v-916fcfad]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.header__dropdown[data-v-916fcfad]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.header__dropdown-header[data-v-916fcfad]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-916fcfad]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.header__dropdown-info[data-v-916fcfad]{flex:1}.header__dropdown-name[data-v-916fcfad]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-916fcfad]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-916fcfad]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-916fcfad]{padding:8px 0}.header__dropdown-item[data-v-916fcfad]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.header__dropdown-item[data-v-916fcfad]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-916fcfad]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-916fcfad]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-916fcfad]{margin-bottom:24px}.settings-drawer .settings-title[data-v-916fcfad]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-916fcfad]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-916fcfad]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-916fcfad]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-916fcfad]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-916fcfad]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-916fcfad]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-916fcfad]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-916fcfad]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-916fcfad]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-916fcfad]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-916fcfad]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-916fcfad]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-916fcfad]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-916fcfad]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-916fcfad]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-916fcfad]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-916fcfad]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-916fcfad]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-916fcfad]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-916fcfad]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-916fcfad]{display:flex;gap:12px}.settings-drawer .color-option[data-v-916fcfad]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-916fcfad]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-916fcfad]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-916fcfad]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-916fcfad]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-916fcfad]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-916fcfad]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-916fcfad]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-916fcfad]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-916fcfad]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-916fcfad]:after{left:24px}.dropdown-enter-active[data-v-916fcfad],.dropdown-leave-active[data-v-916fcfad]{transition:all .2s ease}.dropdown-enter-from[data-v-916fcfad],.dropdown-leave-to[data-v-916fcfad]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-916fcfad],.search-dropdown-leave-active[data-v-916fcfad]{transition:all .2s ease}.search-dropdown-enter-from[data-v-916fcfad],.search-dropdown-leave-to[data-v-916fcfad]{opacity:0;transform:translateY(-4px)}.top-menu[data-v-0e7ff899]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.top-menu__logo[data-v-0e7ff899]{display:flex;align-items:center;gap:10px;margin-right:20px}.top-menu__logo-img[data-v-0e7ff899]{width:32px;height:32px}.top-menu__logo-text[data-v-0e7ff899]{font-size:16px;font-weight:600;color:var(--color-primary)}.top-menu__menu[data-v-0e7ff899]{flex:1;border-bottom:none;height:49px;display:flex;align-items:center;line-height:49px}.top-menu__menu[data-v-0e7ff899] .x-menu{height:49px;line-height:49px;border-bottom:none}.top-menu__menu[data-v-0e7ff899] .x-menu--horizontal{height:49px;display:flex;align-items:center;border-bottom:none;line-height:49px}.top-menu__menu[data-v-0e7ff899] .x-menu-item{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-0e7ff899] .x-menu-item.is-horizontal{height:49px;line-height:49px}.top-menu__menu[data-v-0e7ff899] .x-menu-item__content{height:49px}.top-menu__menu[data-v-0e7ff899] .x-sub-menu{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-0e7ff899] .x-sub-menu--horizontal{height:49px}.top-menu__menu[data-v-0e7ff899] .x-sub-menu__title{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-0e7ff899] .x-sub-menu__content{height:49px}.top-menu__menu-content[data-v-0e7ff899]{align-items:center;line-height:1}.top-menu__menu-text[data-v-0e7ff899]{line-height:1}.top-menu__menu-icon[data-v-0e7ff899]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.top-menu__menu-char[data-v-0e7ff899]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.top-menu__actions[data-v-0e7ff899]{display:flex;align-items:center;gap:8px}.top-menu__action[data-v-0e7ff899]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.top-menu__action[data-v-0e7ff899]:hover{background-color:var(--color-fill);color:var(--color-primary)}.top-menu__user[data-v-0e7ff899]{position:relative;margin-left:8px}.top-menu__user-trigger[data-v-0e7ff899]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.top-menu__user-trigger[data-v-0e7ff899]:hover{background-color:var(--color-fill)}.top-menu__user-name[data-v-0e7ff899]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-menu__user-arrow[data-v-0e7ff899]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.top-menu__user-arrow.is-active[data-v-0e7ff899]{transform:rotate(180deg)}.top-menu__avatar[data-v-0e7ff899]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.top-menu__dropdown[data-v-0e7ff899]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.top-menu__dropdown-header[data-v-0e7ff899]{display:flex;align-items:center;gap:12px;padding:16px}.top-menu__dropdown-avatar[data-v-0e7ff899]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.top-menu__dropdown-info[data-v-0e7ff899]{flex:1}.top-menu__dropdown-name[data-v-0e7ff899]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.top-menu__dropdown-role[data-v-0e7ff899]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.top-menu__dropdown-divider[data-v-0e7ff899]{height:1px;background-color:var(--color-border-lighter)}.top-menu__dropdown-menu[data-v-0e7ff899]{padding:8px 0}.top-menu__dropdown-item[data-v-0e7ff899]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.top-menu__dropdown-item[data-v-0e7ff899]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.top-menu__dropdown-item--danger[data-v-0e7ff899]{color:var(--color-danger)}.top-menu__dropdown-item--danger[data-v-0e7ff899]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-0e7ff899]{margin-bottom:24px}.settings-drawer .settings-title[data-v-0e7ff899]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-0e7ff899]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-0e7ff899]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-0e7ff899]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-0e7ff899]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-0e7ff899]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-0e7ff899]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-0e7ff899]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-0e7ff899]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-0e7ff899]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-0e7ff899]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-0e7ff899]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-0e7ff899]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-0e7ff899]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-0e7ff899]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-0e7ff899]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-0e7ff899]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-0e7ff899]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-0e7ff899]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-0e7ff899]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-0e7ff899]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-0e7ff899]{display:flex;gap:12px}.settings-drawer .color-option[data-v-0e7ff899]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-0e7ff899]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-0e7ff899]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-0e7ff899]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-0e7ff899]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-0e7ff899]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-0e7ff899]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-0e7ff899]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-0e7ff899]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-0e7ff899]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-0e7ff899]:after{left:24px}.dropdown-enter-active[data-v-0e7ff899],.dropdown-leave-active[data-v-0e7ff899]{transition:all .2s ease}.dropdown-enter-from[data-v-0e7ff899],.dropdown-leave-to[data-v-0e7ff899]{opacity:0;transform:translateY(-10px)}.mix-top-menu[data-v-e34b966d]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.mix-top-menu__logo[data-v-e34b966d]{display:flex;align-items:center;gap:10px;margin-right:20px}.mix-top-menu__logo-img[data-v-e34b966d]{width:32px;height:32px}.mix-top-menu__logo-text[data-v-e34b966d]{font-size:16px;font-weight:600;color:var(--color-primary)}.mix-top-menu__menu[data-v-e34b966d]{flex:1;border-bottom:none;height:49px;display:flex;align-items:center;line-height:49px}.mix-top-menu__menu[data-v-e34b966d] .x-menu{height:49px;line-height:49px;border-bottom:none}.mix-top-menu__menu[data-v-e34b966d] .x-menu--horizontal{height:49px;display:flex;align-items:center;border-bottom:none;line-height:49px}.mix-top-menu__menu[data-v-e34b966d] .x-menu-item{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-e34b966d] .x-menu-item.is-horizontal{height:49px;line-height:49px}.mix-top-menu__menu[data-v-e34b966d] .x-menu-item__content{height:49px}.mix-top-menu__menu[data-v-e34b966d] .x-sub-menu{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-e34b966d] .x-sub-menu--horizontal{height:49px}.mix-top-menu__menu[data-v-e34b966d] .x-sub-menu__title{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-e34b966d] .x-sub-menu__content{height:49px}.mix-top-menu__menu-content[data-v-e34b966d]{align-items:center;line-height:1}.mix-top-menu__menu-text[data-v-e34b966d]{line-height:1}.mix-top-menu__menu-icon[data-v-e34b966d]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.mix-top-menu__menu-char[data-v-e34b966d]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.mix-top-menu__actions[data-v-e34b966d]{display:flex;align-items:center;gap:8px}.mix-top-menu__action[data-v-e34b966d]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.mix-top-menu__action[data-v-e34b966d]:hover{background-color:var(--color-fill);color:var(--color-primary)}.mix-top-menu__user[data-v-e34b966d]{position:relative;margin-left:8px}.mix-top-menu__user-trigger[data-v-e34b966d]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.mix-top-menu__user-trigger[data-v-e34b966d]:hover{background-color:var(--color-fill)}.mix-top-menu__user-name[data-v-e34b966d]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mix-top-menu__user-arrow[data-v-e34b966d]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.mix-top-menu__user-arrow.is-active[data-v-e34b966d]{transform:rotate(180deg)}.mix-top-menu__avatar[data-v-e34b966d]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.mix-top-menu__dropdown[data-v-e34b966d]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.mix-top-menu__dropdown-header[data-v-e34b966d]{display:flex;align-items:center;gap:12px;padding:16px}.mix-top-menu__dropdown-avatar[data-v-e34b966d]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.mix-top-menu__dropdown-info[data-v-e34b966d]{flex:1}.mix-top-menu__dropdown-name[data-v-e34b966d]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.mix-top-menu__dropdown-role[data-v-e34b966d]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.mix-top-menu__dropdown-divider[data-v-e34b966d]{height:1px;background-color:var(--color-border-lighter)}.mix-top-menu__dropdown-menu[data-v-e34b966d]{padding:8px 0}.mix-top-menu__dropdown-item[data-v-e34b966d]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.mix-top-menu__dropdown-item[data-v-e34b966d]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.mix-top-menu__dropdown-item--danger[data-v-e34b966d]{color:var(--color-danger)}.mix-top-menu__dropdown-item--danger[data-v-e34b966d]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-e34b966d]{margin-bottom:24px}.settings-drawer .settings-title[data-v-e34b966d]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-e34b966d]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-e34b966d]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-e34b966d]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-e34b966d]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-e34b966d]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-e34b966d]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-e34b966d]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-e34b966d]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-e34b966d]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-e34b966d]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-e34b966d]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-e34b966d]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-e34b966d]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-e34b966d]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-e34b966d]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-e34b966d]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-e34b966d]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-e34b966d]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-e34b966d]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-e34b966d]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-e34b966d]{display:flex;gap:12px}.settings-drawer .color-option[data-v-e34b966d]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-e34b966d]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-e34b966d]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-e34b966d]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-e34b966d]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-e34b966d]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-e34b966d]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-e34b966d]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-e34b966d]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-e34b966d]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-e34b966d]:after{left:24px}.dropdown-enter-active[data-v-e34b966d],.dropdown-leave-active[data-v-e34b966d]{transition:all .2s ease}.dropdown-enter-from[data-v-e34b966d],.dropdown-leave-to[data-v-e34b966d]{opacity:0;transform:translateY(-10px)}.layout[data-v-70b115a5]{display:flex;width:100%;height:100%}.layout--sidebar[data-v-70b115a5]{flex-direction:row}.layout--sidebar .layout__aside[data-v-70b115a5]{height:100%}.layout--sidebar .layout__main[data-v-70b115a5]{flex:1;display:flex;flex-direction:column;height:100%}.layout--top[data-v-70b115a5]{flex-direction:column}.layout--top .layout__main[data-v-70b115a5]{flex:1;display:flex;flex-direction:column;height:calc(100% - 50px)}.layout--top .layout__content[data-v-70b115a5]{flex:1}.layout--mix[data-v-70b115a5]{flex-direction:column}.layout--mix .layout__mix-top-menu[data-v-70b115a5]{width:100%;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout--mix .layout__mix-body[data-v-70b115a5]{flex:1;display:flex;flex-direction:row;height:calc(100% - 50px)}.layout__aside[data-v-70b115a5]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__top-menu[data-v-70b115a5]{width:100%;height:50px;box-sizing:border-box;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__mix-top-menu[data-v-70b115a5]{width:100%;height:50px;box-sizing:border-box;flex-shrink:0}.layout__main[data-v-70b115a5]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-70b115a5]{height:50px;box-sizing:border-box;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-70b115a5]{flex:1;overflow:auto;background-color:var(--bg-color-page)}.tabs-wrapper[data-v-9156d8cd]{width:100%;height:100%;padding:0 10px}.tabs-wrapper[data-v-9156d8cd] .t-tabs{height:100%}.tabs-wrapper[data-v-9156d8cd] .t-tabs__header{margin:0;border-bottom:none}.tabs-wrapper[data-v-9156d8cd] .t-tabs__nav{border:none}.tabs-wrapper[data-v-9156d8cd] .t-tabs__item{height:32px;line-height:32px;border:1px solid var(--color-border-lighter);margin-right:5px;border-radius:var(--border-radius-base);padding:0 15px}.tabs-wrapper[data-v-9156d8cd] .t-tabs__item.is-active{background-color:var(--color-primary-light-9);border-color:var(--color-primary)}.tab-label[data-v-9156d8cd]{display:flex;align-items:center;gap:5px}.tab-close[data-v-9156d8cd]{width:14px;height:14px;display:flex;align-items:center;justify-content:center;font-size:10px;border-radius:50%}.tab-close[data-v-9156d8cd]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.footer[data-v-4852826a]{width:100%;text-align:center;font-size:12px;color:var(--color-text-secondary)}.login[data-v-f3e724b6]{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:flex-end;padding-right:15%;background:linear-gradient(135deg,var(--color-primary-light-9) 0%,var(--color-primary-light-7) 100%)}.login__container[data-v-f3e724b6]{width:400px;padding:40px;background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-dark)}.login__header[data-v-f3e724b6]{text-align:center;margin-bottom:30px}.login__logo[data-v-f3e724b6]{width:60px;height:60px}.login__title[data-v-f3e724b6]{font-size:28px;font-weight:600;color:var(--color-primary);margin:15px 0 5px}.login__subtitle[data-v-f3e724b6]{font-size:14px;color:var(--color-text-secondary)}.login__form[data-v-f3e724b6] .x-form-item{margin-bottom:20px}.login__form[data-v-f3e724b6] .x-input__prefix{margin-right:8px}.login__submit[data-v-f3e724b6]{width:100%}.login__footer[data-v-f3e724b6]{text-align:center;margin-top:20px;font-size:12px;color:var(--color-text-placeholder)}.error-page[data-v-54fcac4c]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-54fcac4c]{text-align:center}.error-page__code[data-v-54fcac4c]{font-size:120px;font-weight:600;color:var(--color-primary);line-height:1;margin-bottom:20px}.error-page__title[data-v-54fcac4c]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-54fcac4c]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}.error-page[data-v-b2ff9b3e]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-b2ff9b3e]{text-align:center}.error-page__code[data-v-b2ff9b3e]{font-size:120px;font-weight:600;color:var(--color-warning);line-height:1;margin-bottom:20px}.error-page__title[data-v-b2ff9b3e]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-b2ff9b3e]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}.dashboard[data-v-44648cb1]{padding:20px}.dashboard__stats[data-v-44648cb1]{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:20px}@media (max-width: 1200px){.dashboard__stats[data-v-44648cb1]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dashboard__stats[data-v-44648cb1]{grid-template-columns:1fr}}.dashboard__main[data-v-44648cb1]{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}@media (max-width: 992px){.dashboard__main[data-v-44648cb1]{grid-template-columns:1fr}}.dashboard__quick[data-v-44648cb1],.dashboard__activity[data-v-44648cb1]{min-height:300px}.card-title[data-v-44648cb1]{font-size:16px;font-weight:500}.stat-card__content[data-v-44648cb1]{display:flex;align-items:center;gap:15px}.stat-card__icon[data-v-44648cb1]{width:50px;height:50px;display:flex;align-items:center;justify-content:center;font-size:24px;border-radius:var(--border-radius-base)}.stat-card__info[data-v-44648cb1]{flex:1}.stat-card__title[data-v-44648cb1]{font-size:14px;color:var(--color-text-secondary);margin-bottom:5px}.stat-card__value[data-v-44648cb1]{font-size:24px;font-weight:600}.quick-links[data-v-44648cb1]{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}@media (max-width: 768px){.quick-links[data-v-44648cb1]{grid-template-columns:repeat(2,1fr)}}.quick-link[data-v-44648cb1]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;border-radius:var(--border-radius-base);background-color:var(--color-fill);text-decoration:none;transition:all var(--transition-duration-fast)}.quick-link[data-v-44648cb1]:hover{background-color:var(--color-primary-light-9);transform:translateY(-2px)}.quick-link__icon[data-v-44648cb1]{font-size:28px;margin-bottom:10px}.quick-link__title[data-v-44648cb1]{font-size:14px;color:var(--color-text-primary)}.activity-list[data-v-44648cb1]{display:flex;flex-direction:column;gap:15px}.activity-item[data-v-44648cb1]{display:flex;align-items:center;gap:10px;padding-bottom:15px;border-bottom:1px solid var(--color-border-lighter)}.activity-item[data-v-44648cb1]:last-child{border-bottom:none;padding-bottom:0}.activity-item__action[data-v-44648cb1]{flex:1;font-size:14px;color:var(--color-text-regular)}.activity-item__time[data-v-44648cb1]{font-size:12px;color:var(--color-text-placeholder)}.system-info[data-v-44648cb1]{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media (max-width: 768px){.system-info[data-v-44648cb1]{grid-template-columns:1fr}}.system-info__item[data-v-44648cb1]{display:flex;align-items:center;gap:10px}.system-info__label[data-v-44648cb1]{font-size:14px;color:var(--color-text-secondary);min-width:80px}.system-info__value[data-v-44648cb1]{font-size:14px;color:var(--color-text-primary)}.user-page[data-v-d2491ae0]{padding:20px}.user-page .search-card[data-v-d2491ae0]{margin-bottom:20px}.user-page .toolbar[data-v-d2491ae0]{margin-bottom:15px}.data-table[data-v-d2491ae0]{width:100%;border-collapse:collapse}.data-table th[data-v-d2491ae0],.data-table td[data-v-d2491ae0]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-d2491ae0]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.data-table .loading-cell[data-v-d2491ae0],.data-table .empty-cell[data-v-d2491ae0]{text-align:center;color:var(--color-text-secondary);padding:40px}.pagination-wrapper[data-v-d2491ae0]{display:flex;justify-content:flex-end;margin-top:20px}.role-page[data-v-8ad30bc6]{padding:20px}.role-page .search-card[data-v-8ad30bc6]{margin-bottom:20px}.role-page .toolbar[data-v-8ad30bc6]{margin-bottom:15px}.data-table[data-v-8ad30bc6]{width:100%;border-collapse:collapse}.data-table th[data-v-8ad30bc6],.data-table td[data-v-8ad30bc6]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-8ad30bc6]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.data-table .loading-cell[data-v-8ad30bc6],.data-table .empty-cell[data-v-8ad30bc6]{text-align:center;color:var(--color-text-secondary);padding:40px}.pagination-wrapper[data-v-8ad30bc6]{display:flex;justify-content:flex-end;margin-top:20px}.menu-page[data-v-2a272a68]{padding:20px}.menu-page .toolbar[data-v-2a272a68]{margin-bottom:15px}.tree-table[data-v-2a272a68]{width:100%;border-collapse:collapse}.tree-table th[data-v-2a272a68],.tree-table td[data-v-2a272a68]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.tree-table th[data-v-2a272a68]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.tree-table .tree-row--level-1 td[data-v-2a272a68]:first-child{padding-left:30px}.tree-indent[data-v-2a272a68]{display:inline-block;width:20px}.menu-name[data-v-2a272a68]{cursor:pointer;color:var(--color-primary)}.menu-name[data-v-2a272a68]:hover{text-decoration:underline}
|
|
1
|
+
.sidebar[data-v-356129ba]{height:100%;display:flex;flex-direction:column;background-color:var(--bg-color);border-right:1px solid var(--color-border-lighter)}.sidebar--collapsed .sidebar__logo[data-v-356129ba]{justify-content:center;padding:0}.sidebar__logo[data-v-356129ba]{height:50px;display:flex;align-items:center;padding:0 20px;gap:10px;border-bottom:1px solid var(--color-border-lighter)}.sidebar__logo-img[data-v-356129ba]{width:32px;height:32px}.sidebar__logo-text[data-v-356129ba]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__menu[data-v-356129ba]{flex:1;border-right:none;overflow-y:auto}.sidebar__menu-content[data-v-356129ba]{display:inline-flex;align-items:center;line-height:1}.sidebar__menu-text[data-v-356129ba]{flex:1;line-height:1}.sidebar__menu-icon[data-v-356129ba]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.sidebar__menu-char[data-v-356129ba]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.sidebar__user[data-v-356129ba]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-356129ba]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-356129ba]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-356129ba]{font-size:12px;color:var(--color-text-secondary)}.header[data-v-916fcfad]{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:100%;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.header__left[data-v-916fcfad]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-916fcfad]{width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-regular);transition:color .2s}.header__collapse[data-v-916fcfad]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-916fcfad]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-916fcfad]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-916fcfad]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-916fcfad]{display:flex;align-items:center;gap:8px}.header__search[data-v-916fcfad]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.header__search-icon[data-v-916fcfad]{color:var(--color-text-secondary)}.header__search-input[data-v-916fcfad]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.header__search-input[data-v-916fcfad]::placeholder{color:var(--color-text-placeholder)}.header__search-dropdown[data-v-916fcfad]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.header__search-results[data-v-916fcfad]{padding:8px 0}.header__search-item[data-v-916fcfad]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.header__search-item[data-v-916fcfad]:hover{background-color:var(--color-fill)}.header__search-item-title[data-v-916fcfad]{font-size:14px;color:var(--color-text-primary)}.header__search-item-parent[data-v-916fcfad]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.header__search-icon[data-v-916fcfad]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.header__search-char[data-v-916fcfad]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.header__search-empty[data-v-916fcfad]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.header__action[data-v-916fcfad]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.header__action[data-v-916fcfad]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-916fcfad]{position:relative;margin-left:8px}.header__user-trigger[data-v-916fcfad]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.header__user-trigger[data-v-916fcfad]:hover{background-color:var(--color-fill)}.header__user-name[data-v-916fcfad]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-916fcfad]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-916fcfad]{transform:rotate(180deg)}.header__avatar[data-v-916fcfad]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.header__dropdown[data-v-916fcfad]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.header__dropdown-header[data-v-916fcfad]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-916fcfad]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.header__dropdown-info[data-v-916fcfad]{flex:1}.header__dropdown-name[data-v-916fcfad]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-916fcfad]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-916fcfad]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-916fcfad]{padding:8px 0}.header__dropdown-item[data-v-916fcfad]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.header__dropdown-item[data-v-916fcfad]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-916fcfad]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-916fcfad]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-916fcfad]{margin-bottom:24px}.settings-drawer .settings-title[data-v-916fcfad]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-916fcfad]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-916fcfad]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-916fcfad]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-916fcfad]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-916fcfad]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-916fcfad]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-916fcfad]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-916fcfad]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-916fcfad]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-916fcfad]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-916fcfad]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-916fcfad]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-916fcfad]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-916fcfad]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-916fcfad]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-916fcfad]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-916fcfad]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-916fcfad]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-916fcfad]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-916fcfad]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-916fcfad]{display:flex;gap:12px}.settings-drawer .color-option[data-v-916fcfad]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-916fcfad]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-916fcfad]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-916fcfad]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-916fcfad]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-916fcfad]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-916fcfad]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-916fcfad]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-916fcfad]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-916fcfad]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-916fcfad]:after{left:24px}.dropdown-enter-active[data-v-916fcfad],.dropdown-leave-active[data-v-916fcfad]{transition:all .2s ease}.dropdown-enter-from[data-v-916fcfad],.dropdown-leave-to[data-v-916fcfad]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-916fcfad],.search-dropdown-leave-active[data-v-916fcfad]{transition:all .2s ease}.search-dropdown-enter-from[data-v-916fcfad],.search-dropdown-leave-to[data-v-916fcfad]{opacity:0;transform:translateY(-4px)}.top-menu[data-v-b933056f]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.top-menu__logo[data-v-b933056f]{display:flex;align-items:center;gap:10px;margin-right:20px}.top-menu__logo-img[data-v-b933056f]{width:32px;height:32px}.top-menu__logo-text[data-v-b933056f]{font-size:16px;font-weight:600;color:var(--color-primary)}.top-menu__menu[data-v-b933056f]{flex:1;border-bottom:none;height:49px;display:flex;align-items:center;line-height:49px}.top-menu__menu[data-v-b933056f] .x-menu{height:49px;line-height:49px;border-bottom:none}.top-menu__menu[data-v-b933056f] .x-menu--horizontal{height:49px;display:flex;align-items:center;border-bottom:none;line-height:49px}.top-menu__menu[data-v-b933056f] .x-menu-item{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-b933056f] .x-menu-item.is-horizontal{height:49px;line-height:49px}.top-menu__menu[data-v-b933056f] .x-menu-item__content{height:49px}.top-menu__menu[data-v-b933056f] .x-sub-menu{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-b933056f] .x-sub-menu--horizontal{height:49px}.top-menu__menu[data-v-b933056f] .x-sub-menu__title{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-b933056f] .x-sub-menu__content{height:49px}.top-menu__menu-content[data-v-b933056f]{align-items:center;line-height:1}.top-menu__menu-text[data-v-b933056f]{line-height:1}.top-menu__menu-icon[data-v-b933056f]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.top-menu__menu-char[data-v-b933056f]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.top-menu__actions[data-v-b933056f]{display:flex;align-items:center;gap:8px}.top-menu__search[data-v-b933056f]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.top-menu__search-icon[data-v-b933056f]{color:var(--color-text-secondary)}.top-menu__search-input[data-v-b933056f]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.top-menu__search-input[data-v-b933056f]::placeholder{color:var(--color-text-placeholder)}.top-menu__search-dropdown[data-v-b933056f]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.top-menu__search-results[data-v-b933056f]{padding:8px 0}.top-menu__search-item[data-v-b933056f]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.top-menu__search-item[data-v-b933056f]:hover{background-color:var(--color-fill)}.top-menu__search-item-title[data-v-b933056f]{font-size:14px;color:var(--color-text-primary)}.top-menu__search-item-parent[data-v-b933056f]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.top-menu__search-icon-item[data-v-b933056f]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.top-menu__search-char[data-v-b933056f]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.top-menu__search-empty[data-v-b933056f]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.top-menu__action[data-v-b933056f]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.top-menu__action[data-v-b933056f]:hover{background-color:var(--color-fill);color:var(--color-primary)}.top-menu__user[data-v-b933056f]{position:relative;margin-left:8px}.top-menu__user-trigger[data-v-b933056f]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.top-menu__user-trigger[data-v-b933056f]:hover{background-color:var(--color-fill)}.top-menu__user-name[data-v-b933056f]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-menu__user-arrow[data-v-b933056f]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.top-menu__user-arrow.is-active[data-v-b933056f]{transform:rotate(180deg)}.top-menu__avatar[data-v-b933056f]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.top-menu__dropdown[data-v-b933056f]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.top-menu__dropdown-header[data-v-b933056f]{display:flex;align-items:center;gap:12px;padding:16px}.top-menu__dropdown-avatar[data-v-b933056f]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.top-menu__dropdown-info[data-v-b933056f]{flex:1}.top-menu__dropdown-name[data-v-b933056f]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.top-menu__dropdown-role[data-v-b933056f]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.top-menu__dropdown-divider[data-v-b933056f]{height:1px;background-color:var(--color-border-lighter)}.top-menu__dropdown-menu[data-v-b933056f]{padding:8px 0}.top-menu__dropdown-item[data-v-b933056f]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.top-menu__dropdown-item[data-v-b933056f]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.top-menu__dropdown-item--danger[data-v-b933056f]{color:var(--color-danger)}.top-menu__dropdown-item--danger[data-v-b933056f]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-b933056f]{margin-bottom:24px}.settings-drawer .settings-title[data-v-b933056f]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-b933056f]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-b933056f]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-b933056f]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-b933056f]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-b933056f]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-b933056f]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-b933056f]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-b933056f]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-b933056f]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-b933056f]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-b933056f]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-b933056f]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-b933056f]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-b933056f]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-b933056f]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-b933056f]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-b933056f]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-b933056f]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-b933056f]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-b933056f]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-b933056f]{display:flex;gap:12px}.settings-drawer .color-option[data-v-b933056f]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-b933056f]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-b933056f]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-b933056f]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-b933056f]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-b933056f]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-b933056f]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-b933056f]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-b933056f]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-b933056f]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-b933056f]:after{left:24px}.dropdown-enter-active[data-v-b933056f],.dropdown-leave-active[data-v-b933056f]{transition:all .2s ease}.dropdown-enter-from[data-v-b933056f],.dropdown-leave-to[data-v-b933056f]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-b933056f],.search-dropdown-leave-active[data-v-b933056f]{transition:all .2s ease}.search-dropdown-enter-from[data-v-b933056f],.search-dropdown-leave-to[data-v-b933056f]{opacity:0;transform:translateY(-4px)}.mix-top-menu[data-v-be763648]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.mix-top-menu__logo[data-v-be763648]{display:flex;align-items:center;gap:10px;margin-right:20px}.mix-top-menu__logo-img[data-v-be763648]{width:32px;height:32px}.mix-top-menu__logo-text[data-v-be763648]{font-size:16px;font-weight:600;color:var(--color-primary)}.mix-top-menu__menu[data-v-be763648]{flex:1;border-bottom:none;height:49px;display:flex;align-items:center;line-height:49px}.mix-top-menu__menu[data-v-be763648] .x-menu{height:49px;line-height:49px;border-bottom:none}.mix-top-menu__menu[data-v-be763648] .x-menu--horizontal{height:49px;display:flex;align-items:center;border-bottom:none;line-height:49px}.mix-top-menu__menu[data-v-be763648] .x-menu-item{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-be763648] .x-menu-item.is-horizontal{height:49px;line-height:49px}.mix-top-menu__menu[data-v-be763648] .x-menu-item__content{height:49px}.mix-top-menu__menu[data-v-be763648] .x-sub-menu{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-be763648] .x-sub-menu--horizontal{height:49px}.mix-top-menu__menu[data-v-be763648] .x-sub-menu__title{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-be763648] .x-sub-menu__content{height:49px}.mix-top-menu__menu-content[data-v-be763648]{align-items:center;line-height:1}.mix-top-menu__menu-text[data-v-be763648]{line-height:1}.mix-top-menu__menu-icon[data-v-be763648]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.mix-top-menu__menu-char[data-v-be763648]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.mix-top-menu__actions[data-v-be763648]{display:flex;align-items:center;gap:8px}.mix-top-menu__search[data-v-be763648]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.mix-top-menu__search-icon[data-v-be763648]{color:var(--color-text-secondary)}.mix-top-menu__search-input[data-v-be763648]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.mix-top-menu__search-input[data-v-be763648]::placeholder{color:var(--color-text-placeholder)}.mix-top-menu__search-dropdown[data-v-be763648]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.mix-top-menu__search-results[data-v-be763648]{padding:8px 0}.mix-top-menu__search-item[data-v-be763648]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.mix-top-menu__search-item[data-v-be763648]:hover{background-color:var(--color-fill)}.mix-top-menu__search-item-title[data-v-be763648]{font-size:14px;color:var(--color-text-primary)}.mix-top-menu__search-item-parent[data-v-be763648]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.mix-top-menu__search-icon-item[data-v-be763648]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.mix-top-menu__search-char[data-v-be763648]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.mix-top-menu__search-empty[data-v-be763648]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.mix-top-menu__action[data-v-be763648]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.mix-top-menu__action[data-v-be763648]:hover{background-color:var(--color-fill);color:var(--color-primary)}.mix-top-menu__user[data-v-be763648]{position:relative;margin-left:8px}.mix-top-menu__user-trigger[data-v-be763648]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.mix-top-menu__user-trigger[data-v-be763648]:hover{background-color:var(--color-fill)}.mix-top-menu__user-name[data-v-be763648]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mix-top-menu__user-arrow[data-v-be763648]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.mix-top-menu__user-arrow.is-active[data-v-be763648]{transform:rotate(180deg)}.mix-top-menu__avatar[data-v-be763648]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.mix-top-menu__dropdown[data-v-be763648]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.mix-top-menu__dropdown-header[data-v-be763648]{display:flex;align-items:center;gap:12px;padding:16px}.mix-top-menu__dropdown-avatar[data-v-be763648]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.mix-top-menu__dropdown-info[data-v-be763648]{flex:1}.mix-top-menu__dropdown-name[data-v-be763648]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.mix-top-menu__dropdown-role[data-v-be763648]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.mix-top-menu__dropdown-divider[data-v-be763648]{height:1px;background-color:var(--color-border-lighter)}.mix-top-menu__dropdown-menu[data-v-be763648]{padding:8px 0}.mix-top-menu__dropdown-item[data-v-be763648]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.mix-top-menu__dropdown-item[data-v-be763648]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.mix-top-menu__dropdown-item--danger[data-v-be763648]{color:var(--color-danger)}.mix-top-menu__dropdown-item--danger[data-v-be763648]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-be763648]{margin-bottom:24px}.settings-drawer .settings-title[data-v-be763648]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-be763648]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-be763648]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-be763648]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-be763648]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-be763648]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-be763648]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-be763648]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-be763648]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-be763648]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-be763648]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-be763648]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-be763648]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-be763648]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-be763648]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-be763648]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-be763648]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-be763648]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-be763648]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-be763648]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-be763648]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-be763648]{display:flex;gap:12px}.settings-drawer .color-option[data-v-be763648]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-be763648]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-be763648]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-be763648]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-be763648]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-be763648]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-be763648]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-be763648]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-be763648]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-be763648]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-be763648]:after{left:24px}.dropdown-enter-active[data-v-be763648],.dropdown-leave-active[data-v-be763648]{transition:all .2s ease}.dropdown-enter-from[data-v-be763648],.dropdown-leave-to[data-v-be763648]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-be763648],.search-dropdown-leave-active[data-v-be763648]{transition:all .2s ease}.search-dropdown-enter-from[data-v-be763648],.search-dropdown-leave-to[data-v-be763648]{opacity:0;transform:translateY(-4px)}.layout[data-v-70b115a5]{display:flex;width:100%;height:100%}.layout--sidebar[data-v-70b115a5]{flex-direction:row}.layout--sidebar .layout__aside[data-v-70b115a5]{height:100%}.layout--sidebar .layout__main[data-v-70b115a5]{flex:1;display:flex;flex-direction:column;height:100%}.layout--top[data-v-70b115a5]{flex-direction:column}.layout--top .layout__main[data-v-70b115a5]{flex:1;display:flex;flex-direction:column;height:calc(100% - 50px)}.layout--top .layout__content[data-v-70b115a5]{flex:1}.layout--mix[data-v-70b115a5]{flex-direction:column}.layout--mix .layout__mix-top-menu[data-v-70b115a5]{width:100%;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout--mix .layout__mix-body[data-v-70b115a5]{flex:1;display:flex;flex-direction:row;height:calc(100% - 50px)}.layout__aside[data-v-70b115a5]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__top-menu[data-v-70b115a5]{width:100%;height:50px;box-sizing:border-box;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__mix-top-menu[data-v-70b115a5]{width:100%;height:50px;box-sizing:border-box;flex-shrink:0}.layout__main[data-v-70b115a5]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-70b115a5]{height:50px;box-sizing:border-box;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-70b115a5]{flex:1;overflow:auto;background-color:var(--bg-color-page)}.tabs-wrapper[data-v-9156d8cd]{width:100%;height:100%;padding:0 10px}.tabs-wrapper[data-v-9156d8cd] .t-tabs{height:100%}.tabs-wrapper[data-v-9156d8cd] .t-tabs__header{margin:0;border-bottom:none}.tabs-wrapper[data-v-9156d8cd] .t-tabs__nav{border:none}.tabs-wrapper[data-v-9156d8cd] .t-tabs__item{height:32px;line-height:32px;border:1px solid var(--color-border-lighter);margin-right:5px;border-radius:var(--border-radius-base);padding:0 15px}.tabs-wrapper[data-v-9156d8cd] .t-tabs__item.is-active{background-color:var(--color-primary-light-9);border-color:var(--color-primary)}.tab-label[data-v-9156d8cd]{display:flex;align-items:center;gap:5px}.tab-close[data-v-9156d8cd]{width:14px;height:14px;display:flex;align-items:center;justify-content:center;font-size:10px;border-radius:50%}.tab-close[data-v-9156d8cd]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.footer[data-v-4852826a]{width:100%;text-align:center;font-size:12px;color:var(--color-text-secondary)}.login[data-v-f3e724b6]{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:flex-end;padding-right:15%;background:linear-gradient(135deg,var(--color-primary-light-9) 0%,var(--color-primary-light-7) 100%)}.login__container[data-v-f3e724b6]{width:400px;padding:40px;background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-dark)}.login__header[data-v-f3e724b6]{text-align:center;margin-bottom:30px}.login__logo[data-v-f3e724b6]{width:60px;height:60px}.login__title[data-v-f3e724b6]{font-size:28px;font-weight:600;color:var(--color-primary);margin:15px 0 5px}.login__subtitle[data-v-f3e724b6]{font-size:14px;color:var(--color-text-secondary)}.login__form[data-v-f3e724b6] .x-form-item{margin-bottom:20px}.login__form[data-v-f3e724b6] .x-input__prefix{margin-right:8px}.login__submit[data-v-f3e724b6]{width:100%}.login__footer[data-v-f3e724b6]{text-align:center;margin-top:20px;font-size:12px;color:var(--color-text-placeholder)}.error-page[data-v-54fcac4c]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-54fcac4c]{text-align:center}.error-page__code[data-v-54fcac4c]{font-size:120px;font-weight:600;color:var(--color-primary);line-height:1;margin-bottom:20px}.error-page__title[data-v-54fcac4c]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-54fcac4c]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}.error-page[data-v-b2ff9b3e]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-b2ff9b3e]{text-align:center}.error-page__code[data-v-b2ff9b3e]{font-size:120px;font-weight:600;color:var(--color-warning);line-height:1;margin-bottom:20px}.error-page__title[data-v-b2ff9b3e]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-b2ff9b3e]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}.dashboard[data-v-44648cb1]{padding:20px}.dashboard__stats[data-v-44648cb1]{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:20px}@media (max-width: 1200px){.dashboard__stats[data-v-44648cb1]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dashboard__stats[data-v-44648cb1]{grid-template-columns:1fr}}.dashboard__main[data-v-44648cb1]{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}@media (max-width: 992px){.dashboard__main[data-v-44648cb1]{grid-template-columns:1fr}}.dashboard__quick[data-v-44648cb1],.dashboard__activity[data-v-44648cb1]{min-height:300px}.card-title[data-v-44648cb1]{font-size:16px;font-weight:500}.stat-card__content[data-v-44648cb1]{display:flex;align-items:center;gap:15px}.stat-card__icon[data-v-44648cb1]{width:50px;height:50px;display:flex;align-items:center;justify-content:center;font-size:24px;border-radius:var(--border-radius-base)}.stat-card__info[data-v-44648cb1]{flex:1}.stat-card__title[data-v-44648cb1]{font-size:14px;color:var(--color-text-secondary);margin-bottom:5px}.stat-card__value[data-v-44648cb1]{font-size:24px;font-weight:600}.quick-links[data-v-44648cb1]{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}@media (max-width: 768px){.quick-links[data-v-44648cb1]{grid-template-columns:repeat(2,1fr)}}.quick-link[data-v-44648cb1]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;border-radius:var(--border-radius-base);background-color:var(--color-fill);text-decoration:none;transition:all var(--transition-duration-fast)}.quick-link[data-v-44648cb1]:hover{background-color:var(--color-primary-light-9);transform:translateY(-2px)}.quick-link__icon[data-v-44648cb1]{font-size:28px;margin-bottom:10px}.quick-link__title[data-v-44648cb1]{font-size:14px;color:var(--color-text-primary)}.activity-list[data-v-44648cb1]{display:flex;flex-direction:column;gap:15px}.activity-item[data-v-44648cb1]{display:flex;align-items:center;gap:10px;padding-bottom:15px;border-bottom:1px solid var(--color-border-lighter)}.activity-item[data-v-44648cb1]:last-child{border-bottom:none;padding-bottom:0}.activity-item__action[data-v-44648cb1]{flex:1;font-size:14px;color:var(--color-text-regular)}.activity-item__time[data-v-44648cb1]{font-size:12px;color:var(--color-text-placeholder)}.system-info[data-v-44648cb1]{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media (max-width: 768px){.system-info[data-v-44648cb1]{grid-template-columns:1fr}}.system-info__item[data-v-44648cb1]{display:flex;align-items:center;gap:10px}.system-info__label[data-v-44648cb1]{font-size:14px;color:var(--color-text-secondary);min-width:80px}.system-info__value[data-v-44648cb1]{font-size:14px;color:var(--color-text-primary)}.user-page[data-v-d2491ae0]{padding:20px}.user-page .search-card[data-v-d2491ae0]{margin-bottom:20px}.user-page .toolbar[data-v-d2491ae0]{margin-bottom:15px}.data-table[data-v-d2491ae0]{width:100%;border-collapse:collapse}.data-table th[data-v-d2491ae0],.data-table td[data-v-d2491ae0]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-d2491ae0]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.data-table .loading-cell[data-v-d2491ae0],.data-table .empty-cell[data-v-d2491ae0]{text-align:center;color:var(--color-text-secondary);padding:40px}.pagination-wrapper[data-v-d2491ae0]{display:flex;justify-content:flex-end;margin-top:20px}.role-page[data-v-8ad30bc6]{padding:20px}.role-page .search-card[data-v-8ad30bc6]{margin-bottom:20px}.role-page .toolbar[data-v-8ad30bc6]{margin-bottom:15px}.data-table[data-v-8ad30bc6]{width:100%;border-collapse:collapse}.data-table th[data-v-8ad30bc6],.data-table td[data-v-8ad30bc6]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-8ad30bc6]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.data-table .loading-cell[data-v-8ad30bc6],.data-table .empty-cell[data-v-8ad30bc6]{text-align:center;color:var(--color-text-secondary);padding:40px}.pagination-wrapper[data-v-8ad30bc6]{display:flex;justify-content:flex-end;margin-top:20px}.menu-page[data-v-2a272a68]{padding:20px}.menu-page .toolbar[data-v-2a272a68]{margin-bottom:15px}.tree-table[data-v-2a272a68]{width:100%;border-collapse:collapse}.tree-table th[data-v-2a272a68],.tree-table td[data-v-2a272a68]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.tree-table th[data-v-2a272a68]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.tree-table .tree-row--level-1 td[data-v-2a272a68]:first-child{padding-left:30px}.tree-indent[data-v-2a272a68]{display:inline-block;width:20px}.menu-name[data-v-2a272a68]{cursor:pointer;color:var(--color-primary)}.menu-name[data-v-2a272a68]:hover{text-decoration:underline}
|
package/package.json
CHANGED
|
@@ -19,6 +19,28 @@ const authStore = useAuthStore()
|
|
|
19
19
|
// 当前激活的一级菜单路径
|
|
20
20
|
const activeTopMenuPath = ref<string>('')
|
|
21
21
|
|
|
22
|
+
// 扁平化菜单用于搜索
|
|
23
|
+
const flattenMenus = (menus: any[], parentTitle = ''): any[] => {
|
|
24
|
+
const result: any[] = []
|
|
25
|
+
menus.forEach(menu => {
|
|
26
|
+
if (menu.children && menu.children.length > 0) {
|
|
27
|
+
result.push(...flattenMenus(menu.children, menu.menuName))
|
|
28
|
+
} else {
|
|
29
|
+
result.push({ ...menu, parentTitle, title: menu.menuName, path: menu.menuUrl })
|
|
30
|
+
}
|
|
31
|
+
})
|
|
32
|
+
return result
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
// 搜索结果
|
|
36
|
+
const searchResults = computed(() => {
|
|
37
|
+
if (!searchKeyword.value.trim()) return []
|
|
38
|
+
const flatMenus = flattenMenus(menuStore.menuList)
|
|
39
|
+
return flatMenus.filter(menu =>
|
|
40
|
+
menu.title.toLowerCase().includes(searchKeyword.value.toLowerCase())
|
|
41
|
+
)
|
|
42
|
+
})
|
|
43
|
+
|
|
22
44
|
// 获取当前选中一级菜单的子菜单
|
|
23
45
|
const currentSubMenuList = computed(() => {
|
|
24
46
|
const topMenu = menuStore.menuList.find(menu => menu.menuUrl === activeTopMenuPath.value)
|
|
@@ -78,6 +100,9 @@ const dropdownRef = ref<HTMLElement | null>(null)
|
|
|
78
100
|
const isFullscreen = ref(false)
|
|
79
101
|
const drawerVisible = ref(false)
|
|
80
102
|
const greyMode = ref(false)
|
|
103
|
+
const searchVisible = ref(false)
|
|
104
|
+
const searchKeyword = ref('')
|
|
105
|
+
const searchRef = ref<HTMLElement | null>(null)
|
|
81
106
|
|
|
82
107
|
// 监听路由变化,更新激活的一级菜单
|
|
83
108
|
watch(() => route.path, () => {
|
|
@@ -198,6 +223,18 @@ const closeDropdowns = () => {
|
|
|
198
223
|
dropdownVisible.value = false
|
|
199
224
|
}
|
|
200
225
|
|
|
226
|
+
// 隐藏搜索
|
|
227
|
+
const hideSearch = () => {
|
|
228
|
+
searchVisible.value = false
|
|
229
|
+
searchKeyword.value = ''
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
// 搜索结果点击
|
|
233
|
+
const handleSearchItemClick = (path: string) => {
|
|
234
|
+
router.push(path)
|
|
235
|
+
hideSearch()
|
|
236
|
+
}
|
|
237
|
+
|
|
201
238
|
// 打开设置抽屉
|
|
202
239
|
const openSettingsDrawer = () => {
|
|
203
240
|
drawerVisible.value = true
|
|
@@ -284,11 +321,23 @@ const handleClickOutside = (event: MouseEvent) => {
|
|
|
284
321
|
if (dropdownRef.value && !dropdownRef.value.contains(event.target as Node)) {
|
|
285
322
|
closeDropdowns()
|
|
286
323
|
}
|
|
324
|
+
if (searchRef.value && !searchRef.value.contains(event.target as Node)) {
|
|
325
|
+
hideSearch()
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
|
|
329
|
+
// 键盘快捷键
|
|
330
|
+
const handleKeydown = (event: KeyboardEvent) => {
|
|
331
|
+
if (event.key === 'Escape') {
|
|
332
|
+
hideSearch()
|
|
333
|
+
closeDropdowns()
|
|
334
|
+
}
|
|
287
335
|
}
|
|
288
336
|
|
|
289
337
|
onMounted(() => {
|
|
290
338
|
document.addEventListener('click', handleClickOutside)
|
|
291
339
|
document.addEventListener('fullscreenchange', handleFullscreenChange)
|
|
340
|
+
document.addEventListener('keydown', handleKeydown)
|
|
292
341
|
greyMode.value = document.documentElement.classList.contains('grey-mode')
|
|
293
342
|
initActiveTopMenu()
|
|
294
343
|
})
|
|
@@ -296,6 +345,7 @@ onMounted(() => {
|
|
|
296
345
|
onUnmounted(() => {
|
|
297
346
|
document.removeEventListener('click', handleClickOutside)
|
|
298
347
|
document.removeEventListener('fullscreenchange', handleFullscreenChange)
|
|
348
|
+
document.removeEventListener('keydown', handleKeydown)
|
|
299
349
|
})
|
|
300
350
|
</script>
|
|
301
351
|
|
|
@@ -334,6 +384,41 @@ onUnmounted(() => {
|
|
|
334
384
|
|
|
335
385
|
<!-- 右侧操作区域 -->
|
|
336
386
|
<div class="mix-top-menu__actions">
|
|
387
|
+
<!-- 搜索输入框 -->
|
|
388
|
+
<div class="mix-top-menu__search" ref="searchRef">
|
|
389
|
+
<Icon name="search" :size="14" class="mix-top-menu__search-icon" />
|
|
390
|
+
<input
|
|
391
|
+
v-model="searchKeyword"
|
|
392
|
+
type="text"
|
|
393
|
+
class="mix-top-menu__search-input"
|
|
394
|
+
placeholder="搜索菜单..."
|
|
395
|
+
@focus="searchVisible = true"
|
|
396
|
+
/>
|
|
397
|
+
<!-- 搜索结果下拉 -->
|
|
398
|
+
<Transition name="search-dropdown">
|
|
399
|
+
<div v-if="searchVisible && (searchResults.length > 0 || searchKeyword)" class="mix-top-menu__search-dropdown">
|
|
400
|
+
<div v-if="searchResults.length > 0" class="mix-top-menu__search-results">
|
|
401
|
+
<div
|
|
402
|
+
v-for="item in searchResults"
|
|
403
|
+
:key="item.path"
|
|
404
|
+
class="mix-top-menu__search-item"
|
|
405
|
+
@click="handleSearchItemClick(item.path)"
|
|
406
|
+
>
|
|
407
|
+
<span v-if="item.title !== '首页'" class="mix-top-menu__search-icon-item">
|
|
408
|
+
<Icon v-if="iconExists(getMenuIcon(item.icon))" :name="getMenuIcon(item.icon)" :size="16" />
|
|
409
|
+
<span v-else class="mix-top-menu__search-char">{{ getFirstChar(item.title) }}</span>
|
|
410
|
+
</span>
|
|
411
|
+
<span class="mix-top-menu__search-item-title">{{ item.title }}</span>
|
|
412
|
+
<span v-if="item.parentTitle" class="mix-top-menu__search-item-parent">{{ item.parentTitle }}</span>
|
|
413
|
+
</div>
|
|
414
|
+
</div>
|
|
415
|
+
<div v-else class="mix-top-menu__search-empty">
|
|
416
|
+
未找到匹配的菜单
|
|
417
|
+
</div>
|
|
418
|
+
</div>
|
|
419
|
+
</Transition>
|
|
420
|
+
</div>
|
|
421
|
+
|
|
337
422
|
<!-- 全屏切换 -->
|
|
338
423
|
<div class="mix-top-menu__action" @click="toggleFullscreen" :title="isFullscreen ? '退出全屏' : '全屏'">
|
|
339
424
|
<Icon :name="isFullscreen ? 'fullscreen-exit' : 'fullscreen'" :size="16" />
|
|
@@ -604,6 +689,107 @@ onUnmounted(() => {
|
|
|
604
689
|
gap: 8px;
|
|
605
690
|
}
|
|
606
691
|
|
|
692
|
+
&__search {
|
|
693
|
+
position: relative;
|
|
694
|
+
display: flex;
|
|
695
|
+
align-items: center;
|
|
696
|
+
background-color: var(--color-fill-light);
|
|
697
|
+
border-radius: var(--border-radius-base);
|
|
698
|
+
padding: 0 12px;
|
|
699
|
+
height: 32px;
|
|
700
|
+
width: 200px;
|
|
701
|
+
|
|
702
|
+
&-icon {
|
|
703
|
+
color: var(--color-text-secondary);
|
|
704
|
+
}
|
|
705
|
+
|
|
706
|
+
&-input {
|
|
707
|
+
flex: 1;
|
|
708
|
+
height: 100%;
|
|
709
|
+
font-size: 14px;
|
|
710
|
+
color: var(--color-text-primary);
|
|
711
|
+
background: transparent;
|
|
712
|
+
border: none;
|
|
713
|
+
outline: none;
|
|
714
|
+
padding-left: 8px;
|
|
715
|
+
|
|
716
|
+
&::placeholder {
|
|
717
|
+
color: var(--color-text-placeholder);
|
|
718
|
+
}
|
|
719
|
+
}
|
|
720
|
+
|
|
721
|
+
&-dropdown {
|
|
722
|
+
position: absolute;
|
|
723
|
+
top: calc(100% + 4px);
|
|
724
|
+
left: 0;
|
|
725
|
+
right: 0;
|
|
726
|
+
min-width: 200px;
|
|
727
|
+
max-height: 300px;
|
|
728
|
+
overflow-y: auto;
|
|
729
|
+
background-color: var(--bg-color);
|
|
730
|
+
border-radius: var(--border-radius-base);
|
|
731
|
+
box-shadow: var(--box-shadow);
|
|
732
|
+
z-index: 100;
|
|
733
|
+
}
|
|
734
|
+
|
|
735
|
+
&-results {
|
|
736
|
+
padding: 8px 0;
|
|
737
|
+
}
|
|
738
|
+
|
|
739
|
+
&-item {
|
|
740
|
+
display: flex;
|
|
741
|
+
align-items: center;
|
|
742
|
+
gap: 8px;
|
|
743
|
+
padding: 8px 12px;
|
|
744
|
+
cursor: pointer;
|
|
745
|
+
transition: background-color 0.2s;
|
|
746
|
+
|
|
747
|
+
&:hover {
|
|
748
|
+
background-color: var(--color-fill);
|
|
749
|
+
}
|
|
750
|
+
|
|
751
|
+
&-title {
|
|
752
|
+
font-size: 14px;
|
|
753
|
+
color: var(--color-text-primary);
|
|
754
|
+
}
|
|
755
|
+
|
|
756
|
+
&-parent {
|
|
757
|
+
font-size: 12px;
|
|
758
|
+
color: var(--color-text-secondary);
|
|
759
|
+
margin-left: auto;
|
|
760
|
+
}
|
|
761
|
+
}
|
|
762
|
+
|
|
763
|
+
&-icon-item {
|
|
764
|
+
display: inline-flex;
|
|
765
|
+
align-items: center;
|
|
766
|
+
justify-content: center;
|
|
767
|
+
width: 16px;
|
|
768
|
+
height: 16px;
|
|
769
|
+
flex-shrink: 0;
|
|
770
|
+
}
|
|
771
|
+
|
|
772
|
+
&-char {
|
|
773
|
+
display: inline-flex;
|
|
774
|
+
align-items: center;
|
|
775
|
+
justify-content: center;
|
|
776
|
+
width: 16px;
|
|
777
|
+
height: 16px;
|
|
778
|
+
font-size: 12px;
|
|
779
|
+
font-weight: 600;
|
|
780
|
+
color: var(--color-primary);
|
|
781
|
+
background-color: var(--color-primary-light-8);
|
|
782
|
+
border-radius: 4px;
|
|
783
|
+
}
|
|
784
|
+
|
|
785
|
+
&-empty {
|
|
786
|
+
padding: 16px 12px;
|
|
787
|
+
text-align: center;
|
|
788
|
+
color: var(--color-text-secondary);
|
|
789
|
+
font-size: 14px;
|
|
790
|
+
}
|
|
791
|
+
}
|
|
792
|
+
|
|
607
793
|
&__action {
|
|
608
794
|
width: 32px;
|
|
609
795
|
height: 32px;
|
|
@@ -978,4 +1164,16 @@ onUnmounted(() => {
|
|
|
978
1164
|
opacity: 0;
|
|
979
1165
|
transform: translateY(-10px);
|
|
980
1166
|
}
|
|
1167
|
+
|
|
1168
|
+
// 搜索下拉动画
|
|
1169
|
+
.search-dropdown-enter-active,
|
|
1170
|
+
.search-dropdown-leave-active {
|
|
1171
|
+
transition: all 0.2s ease;
|
|
1172
|
+
}
|
|
1173
|
+
|
|
1174
|
+
.search-dropdown-enter-from,
|
|
1175
|
+
.search-dropdown-leave-to {
|
|
1176
|
+
opacity: 0;
|
|
1177
|
+
transform: translateY(-4px);
|
|
1178
|
+
}
|
|
981
1179
|
</style>
|