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/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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "xto-fronted",
3
- "version": "0.4.55",
3
+ "version": "0.4.56",
4
4
  "private": false,
5
5
  "type": "module",
6
6
  "description": "XTO 前端应用框架",
@@ -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>