xto-fronted 0.4.23 → 0.4.25

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-480fc818]{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-480fc818]{justify-content:center;padding:0}.sidebar__logo[data-v-480fc818]{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-480fc818]{width:32px;height:32px}.sidebar__logo-text[data-v-480fc818]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__menu[data-v-480fc818]{flex:1;border-right:none;overflow-y:auto}.sidebar__menu-icon[data-v-480fc818]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.sidebar__menu-char[data-v-480fc818]{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-480fc818]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-480fc818]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-480fc818]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-480fc818]{font-size:12px;color:var(--color-text-secondary)}.header[data-v-702ab2d7]{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-702ab2d7]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-702ab2d7]{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-702ab2d7]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-702ab2d7]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-702ab2d7]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-702ab2d7]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-702ab2d7]{display:flex;align-items:center;gap:8px}.header__action[data-v-702ab2d7]{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-702ab2d7]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-702ab2d7]{position:relative;margin-left:8px}.header__user-trigger[data-v-702ab2d7]{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-702ab2d7]:hover{background-color:var(--color-fill)}.header__user-name[data-v-702ab2d7]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-702ab2d7]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-702ab2d7]{transform:rotate(180deg)}.header__avatar[data-v-702ab2d7]{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-702ab2d7]{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-702ab2d7]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-702ab2d7]{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-702ab2d7]{flex:1}.header__dropdown-name[data-v-702ab2d7]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-702ab2d7]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-702ab2d7]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-702ab2d7]{padding:8px 0}.header__dropdown-item[data-v-702ab2d7]{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-702ab2d7]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-702ab2d7]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-702ab2d7]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.header__search-modal[data-v-702ab2d7]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:flex-start;justify-content:center;padding-top:100px;z-index:200}.search-container[data-v-702ab2d7]{width:600px;max-width:90vw;background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-dark);overflow:hidden}.search-input-wrapper[data-v-702ab2d7]{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border-lighter)}.search-input-wrapper .search-icon[data-v-702ab2d7]{color:var(--color-text-secondary);margin-right:12px}.search-input-wrapper .search-input[data-v-702ab2d7]{flex:1;font-size:16px;color:var(--color-text-primary);background:transparent;border:none;outline:none}.search-input-wrapper .search-input[data-v-702ab2d7]::placeholder{color:var(--color-text-placeholder)}.search-input-wrapper .search-shortcut[data-v-702ab2d7]{font-size:12px;color:var(--color-text-secondary);padding:4px 8px;background-color:var(--color-fill);border-radius:var(--border-radius-base)}.search-results[data-v-702ab2d7]{max-height:400px;overflow-y:auto;padding:8px 0}.search-result-item[data-v-702ab2d7]{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:background-color .2s}.search-result-item[data-v-702ab2d7]:hover{background-color:var(--color-fill)}.search-result-item.is-first[data-v-702ab2d7]{background-color:var(--color-primary-light-9)}.search-result-item .search-result-icon[data-v-702ab2d7]{color:var(--color-text-secondary)}.search-result-item .search-result-info[data-v-702ab2d7]{flex:1;display:flex;flex-direction:column;gap:2px}.search-result-item .search-result-title[data-v-702ab2d7]{font-size:14px;color:var(--color-text-primary)}.search-result-item .search-result-parent[data-v-702ab2d7]{font-size:12px;color:var(--color-text-secondary)}.search-empty[data-v-702ab2d7]{padding:40px 20px;text-align:center;color:var(--color-text-secondary);font-size:14px}.settings-drawer .settings-section[data-v-702ab2d7]{margin-bottom:24px}.settings-drawer .settings-title[data-v-702ab2d7]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-702ab2d7]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-702ab2d7]{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-702ab2d7]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-702ab2d7]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-702ab2d7]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-702ab2d7]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-702ab2d7]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-702ab2d7]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-702ab2d7]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-702ab2d7]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-702ab2d7]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-702ab2d7]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-702ab2d7]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-702ab2d7]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-702ab2d7]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-702ab2d7]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-702ab2d7]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-702ab2d7]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-702ab2d7]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-702ab2d7]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-702ab2d7]{display:flex;gap:12px}.settings-drawer .color-option[data-v-702ab2d7]{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-702ab2d7]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-702ab2d7]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-702ab2d7]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-702ab2d7]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-702ab2d7]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-702ab2d7]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-702ab2d7]{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-702ab2d7]: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-702ab2d7]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-702ab2d7]:after{left:24px}.dropdown-enter-active[data-v-702ab2d7],.dropdown-leave-active[data-v-702ab2d7]{transition:all .2s ease}.dropdown-enter-from[data-v-702ab2d7],.dropdown-leave-to[data-v-702ab2d7]{opacity:0;transform:translateY(-10px)}.search-enter-active[data-v-702ab2d7],.search-leave-active[data-v-702ab2d7]{transition:all .2s ease}.search-enter-from[data-v-702ab2d7],.search-leave-to[data-v-702ab2d7]{opacity:0}.top-menu[data-v-4f7f3ce1]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.top-menu__menu[data-v-4f7f3ce1]{flex:1;border-bottom:none;height:100%}.top-menu__menu-icon[data-v-4f7f3ce1]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.top-menu__menu-char[data-v-4f7f3ce1]{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-4f7f3ce1]{display:flex;align-items:center;gap:8px}.top-menu__action[data-v-4f7f3ce1]{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-4f7f3ce1]:hover{background-color:var(--color-fill);color:var(--color-primary)}.top-menu__user[data-v-4f7f3ce1]{position:relative;margin-left:8px}.top-menu__user-trigger[data-v-4f7f3ce1]{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-4f7f3ce1]:hover{background-color:var(--color-fill)}.top-menu__user-name[data-v-4f7f3ce1]{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-4f7f3ce1]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.top-menu__user-arrow.is-active[data-v-4f7f3ce1]{transform:rotate(180deg)}.top-menu__avatar[data-v-4f7f3ce1]{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-4f7f3ce1]{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-4f7f3ce1]{display:flex;align-items:center;gap:12px;padding:16px}.top-menu__dropdown-avatar[data-v-4f7f3ce1]{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-4f7f3ce1]{flex:1}.top-menu__dropdown-name[data-v-4f7f3ce1]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.top-menu__dropdown-role[data-v-4f7f3ce1]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.top-menu__dropdown-divider[data-v-4f7f3ce1]{height:1px;background-color:var(--color-border-lighter)}.top-menu__dropdown-menu[data-v-4f7f3ce1]{padding:8px 0}.top-menu__dropdown-item[data-v-4f7f3ce1]{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-4f7f3ce1]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.top-menu__dropdown-item--danger[data-v-4f7f3ce1]{color:var(--color-danger)}.top-menu__dropdown-item--danger[data-v-4f7f3ce1]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-4f7f3ce1]{margin-bottom:24px}.settings-drawer .settings-title[data-v-4f7f3ce1]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-4f7f3ce1]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-4f7f3ce1]{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-4f7f3ce1]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-4f7f3ce1]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-4f7f3ce1]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-4f7f3ce1]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-4f7f3ce1]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-4f7f3ce1]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-4f7f3ce1]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-4f7f3ce1]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-4f7f3ce1]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-4f7f3ce1]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-4f7f3ce1]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-4f7f3ce1]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-4f7f3ce1]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-4f7f3ce1]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-4f7f3ce1]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-4f7f3ce1]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-4f7f3ce1]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-4f7f3ce1]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-4f7f3ce1]{display:flex;gap:12px}.settings-drawer .color-option[data-v-4f7f3ce1]{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-4f7f3ce1]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-4f7f3ce1]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-4f7f3ce1]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-4f7f3ce1]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-4f7f3ce1]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-4f7f3ce1]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-4f7f3ce1]{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-4f7f3ce1]: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-4f7f3ce1]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-4f7f3ce1]:after{left:24px}.dropdown-enter-active[data-v-4f7f3ce1],.dropdown-leave-active[data-v-4f7f3ce1]{transition:all .2s ease}.dropdown-enter-from[data-v-4f7f3ce1],.dropdown-leave-to[data-v-4f7f3ce1]{opacity:0;transform:translateY(-10px)}.mix-top-menu[data-v-aa15a69c]{width:100%;height:50px;display:flex;align-items:center;padding:0 20px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.mix-top-menu__logo[data-v-aa15a69c]{display:flex;align-items:center;padding-right:20px;margin-right:20px}.mix-top-menu__logo-text[data-v-aa15a69c]{font-size:16px;font-weight:600;color:var(--color-primary)}.mix-top-menu__menu[data-v-aa15a69c]{flex:1;border-bottom:none;height:100%}.mix-top-menu__menu-icon[data-v-aa15a69c]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.mix-top-menu__menu-char[data-v-aa15a69c]{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-aa15a69c]{display:flex;align-items:center;gap:8px}.mix-top-menu__action[data-v-aa15a69c]{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-aa15a69c]:hover{background-color:var(--color-fill);color:var(--color-primary)}.mix-top-menu__user[data-v-aa15a69c]{position:relative;margin-left:8px}.mix-top-menu__user-trigger[data-v-aa15a69c]{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-aa15a69c]:hover{background-color:var(--color-fill)}.mix-top-menu__user-name[data-v-aa15a69c]{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-aa15a69c]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.mix-top-menu__user-arrow.is-active[data-v-aa15a69c]{transform:rotate(180deg)}.mix-top-menu__avatar[data-v-aa15a69c]{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-aa15a69c]{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-aa15a69c]{display:flex;align-items:center;gap:12px;padding:16px}.mix-top-menu__dropdown-avatar[data-v-aa15a69c]{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-aa15a69c]{flex:1}.mix-top-menu__dropdown-name[data-v-aa15a69c]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.mix-top-menu__dropdown-role[data-v-aa15a69c]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.mix-top-menu__dropdown-divider[data-v-aa15a69c]{height:1px;background-color:var(--color-border-lighter)}.mix-top-menu__dropdown-menu[data-v-aa15a69c]{padding:8px 0}.mix-top-menu__dropdown-item[data-v-aa15a69c]{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-aa15a69c]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.mix-top-menu__dropdown-item--danger[data-v-aa15a69c]{color:var(--color-danger)}.mix-top-menu__dropdown-item--danger[data-v-aa15a69c]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-aa15a69c]{margin-bottom:24px}.settings-drawer .settings-title[data-v-aa15a69c]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-aa15a69c]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-aa15a69c]{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-aa15a69c]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-aa15a69c]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-aa15a69c]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-aa15a69c]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-aa15a69c]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-aa15a69c]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-aa15a69c]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-aa15a69c]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-aa15a69c]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-aa15a69c]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-aa15a69c]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-aa15a69c]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-aa15a69c]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-aa15a69c]{height:30%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-aa15a69c]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-aa15a69c]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-aa15a69c]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-aa15a69c]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-aa15a69c]{display:flex;gap:12px}.settings-drawer .color-option[data-v-aa15a69c]{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-aa15a69c]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-aa15a69c]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-aa15a69c]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-aa15a69c]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-aa15a69c]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-aa15a69c]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-aa15a69c]{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-aa15a69c]: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-aa15a69c]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-aa15a69c]:after{left:24px}.dropdown-enter-active[data-v-aa15a69c],.dropdown-leave-active[data-v-aa15a69c]{transition:all .2s ease}.dropdown-enter-from[data-v-aa15a69c],.dropdown-leave-to[data-v-aa15a69c]{opacity:0;transform:translateY(-10px)}.layout[data-v-516e5c0a]{display:flex;width:100%;height:100%}.layout--sidebar[data-v-516e5c0a]{flex-direction:row}.layout--top[data-v-516e5c0a]{flex-direction:column}.layout--top .layout__aside[data-v-516e5c0a]{display:none}.layout--top .layout__main[data-v-516e5c0a]{flex:1}.layout--mix[data-v-516e5c0a]{flex-direction:column}.layout--mix .layout__mix-body[data-v-516e5c0a]{display:flex;flex:1;overflow:hidden}.layout--mix .layout__aside[data-v-516e5c0a]{height:100%}.layout--mix .layout__main[data-v-516e5c0a]{flex:1}.layout__aside[data-v-516e5c0a]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__top-menu[data-v-516e5c0a]{width:100%;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.layout__main[data-v-516e5c0a]{display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-516e5c0a]{height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-516e5c0a]{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-c3c12c24]{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-c3c12c24]{text-align:center}.error-page__code[data-v-c3c12c24]{font-size:120px;font-weight:600;color:var(--color-primary);line-height:1;margin-bottom:20px}.error-page__title[data-v-c3c12c24]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-c3c12c24]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}.error-page[data-v-dd5f2795]{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-dd5f2795]{text-align:center}.error-page__code[data-v-dd5f2795]{font-size:120px;font-weight:600;color:var(--color-warning);line-height:1;margin-bottom:20px}.error-page__title[data-v-dd5f2795]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-dd5f2795]{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-480fc818]{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-480fc818]{justify-content:center;padding:0}.sidebar__logo[data-v-480fc818]{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-480fc818]{width:32px;height:32px}.sidebar__logo-text[data-v-480fc818]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__menu[data-v-480fc818]{flex:1;border-right:none;overflow-y:auto}.sidebar__menu-icon[data-v-480fc818]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.sidebar__menu-char[data-v-480fc818]{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-480fc818]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-480fc818]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-480fc818]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-480fc818]{font-size:12px;color:var(--color-text-secondary)}.header[data-v-702ab2d7]{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-702ab2d7]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-702ab2d7]{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-702ab2d7]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-702ab2d7]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-702ab2d7]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-702ab2d7]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-702ab2d7]{display:flex;align-items:center;gap:8px}.header__action[data-v-702ab2d7]{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-702ab2d7]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-702ab2d7]{position:relative;margin-left:8px}.header__user-trigger[data-v-702ab2d7]{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-702ab2d7]:hover{background-color:var(--color-fill)}.header__user-name[data-v-702ab2d7]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-702ab2d7]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-702ab2d7]{transform:rotate(180deg)}.header__avatar[data-v-702ab2d7]{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-702ab2d7]{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-702ab2d7]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-702ab2d7]{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-702ab2d7]{flex:1}.header__dropdown-name[data-v-702ab2d7]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-702ab2d7]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-702ab2d7]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-702ab2d7]{padding:8px 0}.header__dropdown-item[data-v-702ab2d7]{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-702ab2d7]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-702ab2d7]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-702ab2d7]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.header__search-modal[data-v-702ab2d7]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:flex-start;justify-content:center;padding-top:100px;z-index:200}.search-container[data-v-702ab2d7]{width:600px;max-width:90vw;background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-dark);overflow:hidden}.search-input-wrapper[data-v-702ab2d7]{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border-lighter)}.search-input-wrapper .search-icon[data-v-702ab2d7]{color:var(--color-text-secondary);margin-right:12px}.search-input-wrapper .search-input[data-v-702ab2d7]{flex:1;font-size:16px;color:var(--color-text-primary);background:transparent;border:none;outline:none}.search-input-wrapper .search-input[data-v-702ab2d7]::placeholder{color:var(--color-text-placeholder)}.search-input-wrapper .search-shortcut[data-v-702ab2d7]{font-size:12px;color:var(--color-text-secondary);padding:4px 8px;background-color:var(--color-fill);border-radius:var(--border-radius-base)}.search-results[data-v-702ab2d7]{max-height:400px;overflow-y:auto;padding:8px 0}.search-result-item[data-v-702ab2d7]{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:background-color .2s}.search-result-item[data-v-702ab2d7]:hover{background-color:var(--color-fill)}.search-result-item.is-first[data-v-702ab2d7]{background-color:var(--color-primary-light-9)}.search-result-item .search-result-icon[data-v-702ab2d7]{color:var(--color-text-secondary)}.search-result-item .search-result-info[data-v-702ab2d7]{flex:1;display:flex;flex-direction:column;gap:2px}.search-result-item .search-result-title[data-v-702ab2d7]{font-size:14px;color:var(--color-text-primary)}.search-result-item .search-result-parent[data-v-702ab2d7]{font-size:12px;color:var(--color-text-secondary)}.search-empty[data-v-702ab2d7]{padding:40px 20px;text-align:center;color:var(--color-text-secondary);font-size:14px}.settings-drawer .settings-section[data-v-702ab2d7]{margin-bottom:24px}.settings-drawer .settings-title[data-v-702ab2d7]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-702ab2d7]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-702ab2d7]{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-702ab2d7]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-702ab2d7]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-702ab2d7]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-702ab2d7]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-702ab2d7]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-702ab2d7]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-702ab2d7]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-702ab2d7]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-702ab2d7]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-702ab2d7]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-702ab2d7]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-702ab2d7]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-702ab2d7]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-702ab2d7]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-702ab2d7]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-702ab2d7]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-702ab2d7]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-702ab2d7]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-702ab2d7]{display:flex;gap:12px}.settings-drawer .color-option[data-v-702ab2d7]{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-702ab2d7]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-702ab2d7]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-702ab2d7]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-702ab2d7]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-702ab2d7]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-702ab2d7]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-702ab2d7]{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-702ab2d7]: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-702ab2d7]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-702ab2d7]:after{left:24px}.dropdown-enter-active[data-v-702ab2d7],.dropdown-leave-active[data-v-702ab2d7]{transition:all .2s ease}.dropdown-enter-from[data-v-702ab2d7],.dropdown-leave-to[data-v-702ab2d7]{opacity:0;transform:translateY(-10px)}.search-enter-active[data-v-702ab2d7],.search-leave-active[data-v-702ab2d7]{transition:all .2s ease}.search-enter-from[data-v-702ab2d7],.search-leave-to[data-v-702ab2d7]{opacity:0}.top-menu[data-v-4f7f3ce1]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.top-menu__menu[data-v-4f7f3ce1]{flex:1;border-bottom:none;height:100%}.top-menu__menu-icon[data-v-4f7f3ce1]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.top-menu__menu-char[data-v-4f7f3ce1]{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-4f7f3ce1]{display:flex;align-items:center;gap:8px}.top-menu__action[data-v-4f7f3ce1]{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-4f7f3ce1]:hover{background-color:var(--color-fill);color:var(--color-primary)}.top-menu__user[data-v-4f7f3ce1]{position:relative;margin-left:8px}.top-menu__user-trigger[data-v-4f7f3ce1]{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-4f7f3ce1]:hover{background-color:var(--color-fill)}.top-menu__user-name[data-v-4f7f3ce1]{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-4f7f3ce1]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.top-menu__user-arrow.is-active[data-v-4f7f3ce1]{transform:rotate(180deg)}.top-menu__avatar[data-v-4f7f3ce1]{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-4f7f3ce1]{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-4f7f3ce1]{display:flex;align-items:center;gap:12px;padding:16px}.top-menu__dropdown-avatar[data-v-4f7f3ce1]{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-4f7f3ce1]{flex:1}.top-menu__dropdown-name[data-v-4f7f3ce1]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.top-menu__dropdown-role[data-v-4f7f3ce1]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.top-menu__dropdown-divider[data-v-4f7f3ce1]{height:1px;background-color:var(--color-border-lighter)}.top-menu__dropdown-menu[data-v-4f7f3ce1]{padding:8px 0}.top-menu__dropdown-item[data-v-4f7f3ce1]{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-4f7f3ce1]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.top-menu__dropdown-item--danger[data-v-4f7f3ce1]{color:var(--color-danger)}.top-menu__dropdown-item--danger[data-v-4f7f3ce1]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-4f7f3ce1]{margin-bottom:24px}.settings-drawer .settings-title[data-v-4f7f3ce1]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-4f7f3ce1]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-4f7f3ce1]{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-4f7f3ce1]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-4f7f3ce1]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-4f7f3ce1]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-4f7f3ce1]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-4f7f3ce1]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-4f7f3ce1]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-4f7f3ce1]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-4f7f3ce1]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-4f7f3ce1]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-4f7f3ce1]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-4f7f3ce1]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-4f7f3ce1]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-4f7f3ce1]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-4f7f3ce1]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-4f7f3ce1]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-4f7f3ce1]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-4f7f3ce1]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-4f7f3ce1]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-4f7f3ce1]{display:flex;gap:12px}.settings-drawer .color-option[data-v-4f7f3ce1]{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-4f7f3ce1]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-4f7f3ce1]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-4f7f3ce1]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-4f7f3ce1]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-4f7f3ce1]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-4f7f3ce1]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-4f7f3ce1]{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-4f7f3ce1]: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-4f7f3ce1]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-4f7f3ce1]:after{left:24px}.dropdown-enter-active[data-v-4f7f3ce1],.dropdown-leave-active[data-v-4f7f3ce1]{transition:all .2s ease}.dropdown-enter-from[data-v-4f7f3ce1],.dropdown-leave-to[data-v-4f7f3ce1]{opacity:0;transform:translateY(-10px)}.mix-top-menu[data-v-01262417]{width:100%;height:50px;display:flex;align-items:center;padding:0 20px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.mix-top-menu__logo[data-v-01262417]{display:flex;align-items:center;padding-right:20px;margin-right:20px}.mix-top-menu__logo-text[data-v-01262417]{font-size:16px;font-weight:600;color:var(--color-primary)}.mix-top-menu__menu[data-v-01262417]{flex:1;border-bottom:none;height:100%}.mix-top-menu__menu-icon[data-v-01262417]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.mix-top-menu__menu-char[data-v-01262417]{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-01262417]{display:flex;align-items:center;gap:8px}.mix-top-menu__action[data-v-01262417]{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-01262417]:hover{background-color:var(--color-fill);color:var(--color-primary)}.mix-top-menu__user[data-v-01262417]{position:relative;margin-left:8px}.mix-top-menu__user-trigger[data-v-01262417]{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-01262417]:hover{background-color:var(--color-fill)}.mix-top-menu__user-name[data-v-01262417]{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-01262417]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.mix-top-menu__user-arrow.is-active[data-v-01262417]{transform:rotate(180deg)}.mix-top-menu__avatar[data-v-01262417]{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-01262417]{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-01262417]{display:flex;align-items:center;gap:12px;padding:16px}.mix-top-menu__dropdown-avatar[data-v-01262417]{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-01262417]{flex:1}.mix-top-menu__dropdown-name[data-v-01262417]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.mix-top-menu__dropdown-role[data-v-01262417]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.mix-top-menu__dropdown-divider[data-v-01262417]{height:1px;background-color:var(--color-border-lighter)}.mix-top-menu__dropdown-menu[data-v-01262417]{padding:8px 0}.mix-top-menu__dropdown-item[data-v-01262417]{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-01262417]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.mix-top-menu__dropdown-item--danger[data-v-01262417]{color:var(--color-danger)}.mix-top-menu__dropdown-item--danger[data-v-01262417]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-01262417]{margin-bottom:24px}.settings-drawer .settings-title[data-v-01262417]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-01262417]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-01262417]{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-01262417]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-01262417]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-01262417]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-01262417]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-01262417]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-01262417]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-01262417]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-01262417]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-01262417]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-01262417]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-01262417]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-01262417]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-01262417]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-01262417]{height:30%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-01262417]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-01262417]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-01262417]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-01262417]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-01262417]{display:flex;gap:12px}.settings-drawer .color-option[data-v-01262417]{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-01262417]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-01262417]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-01262417]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-01262417]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-01262417]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-01262417]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-01262417]{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-01262417]: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-01262417]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-01262417]:after{left:24px}.dropdown-enter-active[data-v-01262417],.dropdown-leave-active[data-v-01262417]{transition:all .2s ease}.dropdown-enter-from[data-v-01262417],.dropdown-leave-to[data-v-01262417]{opacity:0;transform:translateY(-10px)}.layout[data-v-90a1f90c]{display:flex;width:100%;height:100%}.layout--sidebar[data-v-90a1f90c]{flex-direction:row}.layout--top[data-v-90a1f90c],.layout--mix[data-v-90a1f90c]{flex-direction:column}.layout__aside[data-v-90a1f90c]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__top-menu[data-v-90a1f90c],.layout__mix-top[data-v-90a1f90c]{width:100%;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.layout__mix-body[data-v-90a1f90c]{display:flex;flex:1;overflow:hidden}.layout__main[data-v-90a1f90c]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-90a1f90c]{height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-90a1f90c]{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-c3c12c24]{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-c3c12c24]{text-align:center}.error-page__code[data-v-c3c12c24]{font-size:120px;font-weight:600;color:var(--color-primary);line-height:1;margin-bottom:20px}.error-page__title[data-v-c3c12c24]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-c3c12c24]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}.error-page[data-v-dd5f2795]{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-dd5f2795]{text-align:center}.error-page__code[data-v-dd5f2795]{font-size:120px;font-weight:600;color:var(--color-warning);line-height:1;margin-bottom:20px}.error-page__title[data-v-dd5f2795]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-dd5f2795]{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.23",
3
+ "version": "0.4.25",
4
4
  "private": false,
5
5
  "type": "module",
6
6
  "description": "XTO 前端应用框架",
@@ -16,7 +16,7 @@ const appStore = useAppStore()
16
16
  const userStore = useUserStore()
17
17
  const authStore = useAuthStore()
18
18
 
19
- // 当前激活的一级菜单(用于顶部菜单高亮)
19
+ // 当前激活的一级菜单
20
20
  const activeTopMenu = computed(() => appStore.activeTopMenuPath)
21
21
 
22
22
  // 菜单主题相关
@@ -113,15 +113,17 @@ const handleTopMenuClick = (menuUrl: string) => {
113
113
  // 找到对应的菜单
114
114
  const menu = menuStore.menuList.find(m => m.menuUrl === menuUrl)
115
115
  if (menu) {
116
- // 如果有子菜单,跳转到第一个子菜单或默认子菜单
116
+ // 有二级菜单:跳转到第一个二级菜单
117
117
  if (menu.children && menu.children.length > 0) {
118
- const defaultChild = menu.children.find(c => c.isDefault) || menu.children[0]
119
- if (defaultChild && defaultChild.menuUrl !== route.path) {
120
- router.push(defaultChild.menuUrl)
118
+ const firstChild = menu.children[0]
119
+ if (firstChild.menuUrl !== route.path) {
120
+ router.push(firstChild.menuUrl)
121
+ }
122
+ } else {
123
+ // 没有二级菜单:直接跳转一级菜单
124
+ if (menuUrl !== route.path) {
125
+ router.push(menuUrl)
121
126
  }
122
- } else if (menuUrl !== route.path) {
123
- // 没有子菜单,直接跳转
124
- router.push(menuUrl)
125
127
  }
126
128
  }
127
129
  }
@@ -186,10 +188,10 @@ const handleDarkModeToggle = () => {
186
188
 
187
189
  // 布局模式选项
188
190
  type LayoutMode = 'sidebar' | 'top' | 'mix'
189
- const layoutOptions: { value: LayoutMode; label: string; icon: string }[] = [
190
- { value: 'sidebar', label: '左侧菜单', icon: 'sidebar-left' },
191
- { value: 'top', label: '顶部菜单', icon: 'menu' },
192
- { value: 'mix', label: '混合菜单', icon: 'grid' }
191
+ const layoutOptions: { value: LayoutMode; label: string }[] = [
192
+ { value: 'sidebar', label: '左侧菜单' },
193
+ { value: 'top', label: '顶部菜单' },
194
+ { value: 'mix', label: '混合菜单' }
193
195
  ]
194
196
 
195
197
  const currentLayout = computed(() => appStore.layout)
@@ -244,38 +246,10 @@ const handleClickOutside = (event: MouseEvent) => {
244
246
  }
245
247
  }
246
248
 
247
- // 初始化:根据当前路由设置一级菜单选中状态
248
- const initActiveTopMenu = () => {
249
- if (!appStore.activeTopMenuPath && menuStore.menuList.length > 0) {
250
- // 找到当前路由所属的一级菜单
251
- for (const menu of menuStore.menuList) {
252
- if (menu.menuUrl === route.path) {
253
- appStore.setActiveTopMenuPath(menu.menuUrl)
254
- break
255
- }
256
- if (menu.children && menu.children.length > 0) {
257
- const found = menu.children.some(child =>
258
- child.menuUrl === route.path ||
259
- (child.children && child.children.some(c => c.menuUrl === route.path))
260
- )
261
- if (found) {
262
- appStore.setActiveTopMenuPath(menu.menuUrl)
263
- break
264
- }
265
- }
266
- }
267
- // 如果没找到,默认选中第一个
268
- if (!appStore.activeTopMenuPath) {
269
- appStore.setActiveTopMenuPath(menuStore.menuList[0].menuUrl)
270
- }
271
- }
272
- }
273
-
274
249
  onMounted(() => {
275
250
  document.addEventListener('click', handleClickOutside)
276
251
  document.addEventListener('fullscreenchange', handleFullscreenChange)
277
252
  greyMode.value = document.documentElement.classList.contains('grey-mode')
278
- initActiveTopMenu()
279
253
  })
280
254
 
281
255
  onUnmounted(() => {
@@ -291,7 +265,7 @@ onUnmounted(() => {
291
265
  <span class="mix-top-menu__logo-text">{{ appStore.appName }}</span>
292
266
  </div>
293
267
 
294
- <!-- 一级菜单 -->
268
+ <!-- 一级菜单(水平排列) -->
295
269
  <Menu
296
270
  :default-active="activeTopMenu"
297
271
  mode="horizontal"
@@ -1,5 +1,5 @@
1
1
  <script setup lang="ts">
2
- import { computed, watch, onMounted } from 'vue'
2
+ import { computed, watch } from 'vue'
3
3
  import { useRoute } from 'vue-router'
4
4
  import { useAppStore } from '@/stores/app'
5
5
  import { useMenuStore } from '@/stores/menu'
@@ -19,171 +19,133 @@ const sidebarWidth = computed(() =>
19
19
  // 布局模式
20
20
  const layoutMode = computed(() => appStore.layout)
21
21
 
22
- // 是否显示左侧菜单(sidebar模式始终显示,mix模式根据一级菜单是否有子菜单决定)
23
- const showSidebar = computed(() => {
24
- if (layoutMode.value === 'sidebar') return true
25
- if (layoutMode.value === 'mix') {
26
- return mixSubMenus.value.length > 0
27
- }
28
- return false
29
- })
30
-
31
- // 是否显示顶部菜单(仅 top 模式)
32
- const showTopMenu = computed(() => layoutMode.value === 'top')
33
-
34
- // 是否显示Header(顶部菜单模式和混合菜单模式下不显示)
35
- const showHeader = computed(() => layoutMode.value === 'sidebar')
36
-
37
- // 混合模式下当前选中一级菜单的子菜单
22
+ // 混合模式下当前选中一级菜单的子菜单(二级及以下)
38
23
  const mixSubMenus = computed(() => {
39
- if (layoutMode.value !== 'mix') return menuStore.menuList
24
+ if (layoutMode.value !== 'mix') return []
40
25
 
41
- // 找到当前选中的一级菜单
42
26
  const topMenuPath = appStore.activeTopMenuPath
43
- console.log('mixSubMenus - topMenuPath:', topMenuPath, 'menuList:', menuStore.menuList)
44
-
45
- if (!topMenuPath) {
46
- // 如果没有选中一级菜单,默认返回第一个菜单的children(如果有)
47
- if (menuStore.menuList.length > 0) {
48
- const firstMenu = menuStore.menuList[0]
49
- return firstMenu.children || []
50
- }
51
- return []
52
- }
27
+ if (!topMenuPath) return []
53
28
 
29
+ // 找到当前选中的一级菜单
54
30
  const topMenu = menuStore.menuList.find(m => m.menuUrl === topMenuPath)
55
- console.log('mixSubMenus - topMenu:', topMenu)
31
+ // 返回其children(二级菜单),如果没有children则返回空数组
56
32
  return topMenu?.children || []
57
33
  })
58
34
 
59
- // 初始化一级菜单选中状态
60
- const initActiveTopMenu = () => {
61
- if (layoutMode.value === 'mix' && menuStore.menuList.length > 0) {
62
- // 如果还没有设置activeTopMenuPath,设置默认值
63
- if (!appStore.activeTopMenuPath) {
64
- // 找到当前路由所属的一级菜单
65
- let foundTopMenu: string | null = null
35
+ // 混合模式下是否显示左侧菜单(有二级菜单才显示)
36
+ const showMixSidebar = computed(() => {
37
+ return layoutMode.value === 'mix' && mixSubMenus.value.length > 0
38
+ })
66
39
 
67
- for (const menu of menuStore.menuList) {
68
- if (menu.menuUrl === route.path) {
69
- foundTopMenu = menu.menuUrl
70
- break
71
- }
72
- if (menu.children && menu.children.length > 0) {
73
- const found = menu.children.some(child =>
74
- child.menuUrl === route.path ||
75
- (child.children && child.children.some(c => c.menuUrl === route.path))
76
- )
77
- if (found) {
78
- foundTopMenu = menu.menuUrl
79
- break
80
- }
40
+ // 根据当前路由自动匹配一级菜单
41
+ const syncTopMenuByRoute = (path: string) => {
42
+ if (layoutMode.value === 'mix' && menuStore.menuList.length > 0) {
43
+ // 遍历一级菜单
44
+ for (const menu of menuStore.menuList) {
45
+ // 检查是否直接是一级菜单路径
46
+ if (menu.menuUrl === path) {
47
+ appStore.setActiveTopMenuPath(menu.menuUrl)
48
+ return
49
+ }
50
+ // 检查是否是该一级菜单的子菜单(包括多级子菜单)
51
+ if (menu.children && menu.children.length > 0) {
52
+ const isInChildren = checkPathInChildren(menu.children, path)
53
+ if (isInChildren) {
54
+ appStore.setActiveTopMenuPath(menu.menuUrl)
55
+ return
81
56
  }
82
57
  }
58
+ }
59
+ // 如果没匹配到,默认选中第一个有子菜单的一级菜单,或第一个菜单
60
+ const firstMenuWithChildren = menuStore.menuList.find(m => m.children && m.children.length > 0)
61
+ const defaultMenu = firstMenuWithChildren || menuStore.menuList[0]
62
+ if (defaultMenu) {
63
+ appStore.setActiveTopMenuPath(defaultMenu.menuUrl)
64
+ }
65
+ }
66
+ }
83
67
 
84
- // 如果没找到,默认选中第一个有子菜单的一级菜单,或者第一个菜单
85
- if (!foundTopMenu) {
86
- const menuWithChildren = menuStore.menuList.find(m => m.children && m.children.length > 0)
87
- foundTopMenu = menuWithChildren ? menuWithChildren.menuUrl : menuStore.menuList[0].menuUrl
68
+ // 递归检查路径是否在子菜单中
69
+ const checkPathInChildren = (children: any[], path: string): boolean => {
70
+ for (const child of children) {
71
+ if (child.menuUrl === path) {
72
+ return true
73
+ }
74
+ if (child.children && child.children.length > 0) {
75
+ if (checkPathInChildren(child.children, path)) {
76
+ return true
88
77
  }
89
-
90
- appStore.setActiveTopMenuPath(foundTopMenu)
91
78
  }
92
79
  }
80
+ return false
93
81
  }
94
82
 
95
- // 根据当前路由自动设置一级菜单选中状态
83
+ // 监听路由变化,同步一级菜单选中状态
96
84
  watch(
97
85
  () => route.path,
98
86
  (path) => {
99
- if (layoutMode.value === 'mix' && menuStore.menuList.length > 0) {
100
- // 找到当前路由所属的一级菜单
101
- for (const menu of menuStore.menuList) {
102
- if (menu.menuUrl === path) {
103
- if (appStore.activeTopMenuPath !== menu.menuUrl) {
104
- appStore.setActiveTopMenuPath(menu.menuUrl)
105
- }
106
- break
107
- }
108
- if (menu.children && menu.children.length > 0) {
109
- const found = menu.children.some(child =>
110
- child.menuUrl === path ||
111
- (child.children && child.children.some(c => c.menuUrl === route.path))
112
- )
113
- if (found) {
114
- if (appStore.activeTopMenuPath !== menu.menuUrl) {
115
- appStore.setActiveTopMenuPath(menu.menuUrl)
116
- }
117
- break
118
- }
119
- }
120
- }
121
- }
87
+ syncTopMenuByRoute(path)
122
88
  },
123
89
  { immediate: true }
124
90
  )
125
91
 
126
- // 监听菜单列表变化,重新初始化
92
+ // 监听菜单列表变化,重新同步
127
93
  watch(
128
94
  () => menuStore.menuList,
129
95
  () => {
130
96
  if (layoutMode.value === 'mix') {
131
- initActiveTopMenu()
97
+ syncTopMenuByRoute(route.path)
132
98
  }
133
- },
134
- { immediate: true }
99
+ }
135
100
  )
136
-
137
- onMounted(() => {
138
- initActiveTopMenu()
139
- })
140
101
  </script>
141
102
 
142
103
  <template>
143
104
  <div class="layout" :class="`layout--${layoutMode}`">
144
- <!-- 混合菜单模式 -->
145
- <template v-if="layoutMode === 'mix'">
146
- <!-- 混合模式顶部菜单(一级菜单) -->
147
- <MixTopMenu />
148
-
149
- <!-- 混合模式主体区域 -->
150
- <div class="layout__mix-body">
151
- <!-- 左侧子菜单(二级菜单) -->
152
- <aside v-if="mixSubMenus.length > 0" class="layout__aside" :style="{ width: sidebarWidth }">
153
- <Sidebar :menu-list="mixSubMenus" />
154
- </aside>
155
-
156
- <!-- 主内容区 -->
157
- <div class="layout__main">
158
- <main class="layout__content">
159
- <router-view />
160
- </main>
161
- </div>
162
- </div>
163
- </template>
164
-
165
- <!-- 其他布局模式 -->
166
- <template v-else>
167
- <!-- 左侧菜单布局 -->
168
- <aside v-if="showSidebar" class="layout__aside" :style="{ width: sidebarWidth }">
105
+ <!-- sidebar模式:左侧菜单 + Header + 内容 -->
106
+ <template v-if="layoutMode === 'sidebar'">
107
+ <aside class="layout__aside" :style="{ width: sidebarWidth }">
169
108
  <Sidebar :menu-list="menuStore.menuList" />
170
109
  </aside>
110
+ <div class="layout__main">
111
+ <header class="layout__header">
112
+ <Header />
113
+ </header>
114
+ <main class="layout__content">
115
+ <router-view />
116
+ </main>
117
+ </div>
118
+ </template>
171
119
 
172
- <!-- 顶部菜单布局 -->
173
- <div v-if="showTopMenu" class="layout__top-menu">
120
+ <!-- top模式:顶部菜单 + 内容 -->
121
+ <template v-if="layoutMode === 'top'">
122
+ <div class="layout__top-menu">
174
123
  <TopMenu />
175
124
  </div>
176
-
177
125
  <div class="layout__main">
178
- <!-- Header仅在sidebar模式下显示 -->
179
- <header v-if="showHeader" class="layout__header">
180
- <Header />
181
- </header>
182
126
  <main class="layout__content">
183
127
  <router-view />
184
128
  </main>
185
129
  </div>
186
130
  </template>
131
+
132
+ <!-- mix模式:顶部一级菜单 + 左侧二级菜单 + 内容 -->
133
+ <template v-if="layoutMode === 'mix'">
134
+ <div class="layout__mix-top">
135
+ <MixTopMenu />
136
+ </div>
137
+ <div class="layout__mix-body">
138
+ <!-- 只有当一级菜单有子菜单时才显示左侧菜单 -->
139
+ <aside v-if="showMixSidebar" class="layout__aside" :style="{ width: sidebarWidth }">
140
+ <Sidebar :menu-list="mixSubMenus" />
141
+ </aside>
142
+ <div class="layout__main">
143
+ <main class="layout__content">
144
+ <router-view />
145
+ </main>
146
+ </div>
147
+ </div>
148
+ </template>
187
149
  </div>
188
150
  </template>
189
151
 
@@ -201,33 +163,11 @@ onMounted(() => {
201
163
  // 顶部菜单模式
202
164
  &--top {
203
165
  flex-direction: column;
204
-
205
- .layout__aside {
206
- display: none;
207
- }
208
-
209
- .layout__main {
210
- flex: 1;
211
- }
212
166
  }
213
167
 
214
168
  // 混合菜单模式
215
169
  &--mix {
216
170
  flex-direction: column;
217
-
218
- .layout__mix-body {
219
- display: flex;
220
- flex: 1;
221
- overflow: hidden;
222
- }
223
-
224
- .layout__aside {
225
- height: 100%;
226
- }
227
-
228
- .layout__main {
229
- flex: 1;
230
- }
231
171
  }
232
172
 
233
173
  &__aside {
@@ -244,7 +184,21 @@ onMounted(() => {
244
184
  border-bottom: 1px solid var(--color-border-lighter);
245
185
  }
246
186
 
187
+ &__mix-top {
188
+ width: 100%;
189
+ height: 50px;
190
+ background-color: var(--bg-color);
191
+ border-bottom: 1px solid var(--color-border-lighter);
192
+ }
193
+
194
+ &__mix-body {
195
+ display: flex;
196
+ flex: 1;
197
+ overflow: hidden;
198
+ }
199
+
247
200
  &__main {
201
+ flex: 1;
248
202
  display: flex;
249
203
  flex-direction: column;
250
204
  overflow: hidden;