xto-fronted 0.4.35 → 0.4.37

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-337a295f]{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-337a295f]{justify-content:center;padding:0}.sidebar__logo[data-v-337a295f]{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-337a295f]{width:32px;height:32px}.sidebar__logo-text[data-v-337a295f]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__menu[data-v-337a295f]{flex:1;border-right:none;overflow-y:auto}.sidebar__menu-icon[data-v-337a295f]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.sidebar__menu-char[data-v-337a295f]{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-337a295f]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-337a295f]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-337a295f]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-337a295f]{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-ea1d4482]{display:flex;width:100%;height:100%}.layout--sidebar[data-v-ea1d4482]{flex-direction:row}.layout--top[data-v-ea1d4482],.layout--mix[data-v-ea1d4482]{flex-direction:column}.layout__aside[data-v-ea1d4482]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__top-menu[data-v-ea1d4482],.layout__mix-top[data-v-ea1d4482]{width:100%;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.layout__mix-body[data-v-ea1d4482]{display:flex;flex:1;overflow:hidden}.layout__main[data-v-ea1d4482]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-ea1d4482]{height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-ea1d4482]{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-11c97455]{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-11c97455]{justify-content:center;padding:0}.sidebar__logo[data-v-11c97455]{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-11c97455]{width:32px;height:32px}.sidebar__logo-text[data-v-11c97455]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__menu[data-v-11c97455]{flex:1;border-right:none;overflow-y:auto}.sidebar__menu-content[data-v-11c97455]{display:inline-flex;align-items:center}.sidebar__menu-text[data-v-11c97455]{flex:1}.sidebar__menu-icon[data-v-11c97455]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.sidebar__menu-char[data-v-11c97455]{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-11c97455]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-11c97455]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-11c97455]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-11c97455]{font-size:12px;color:var(--color-text-secondary)}.header[data-v-bf260d8d]{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-bf260d8d]{display:flex;align-items:center;gap:15px}.header__logo[data-v-bf260d8d]{display:flex;align-items:center;gap:10px}.header__logo-img[data-v-bf260d8d]{width:32px;height:32px}.header__logo-text[data-v-bf260d8d]{font-size:16px;font-weight:600;color:var(--color-primary)}.header__collapse[data-v-bf260d8d]{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-bf260d8d]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-bf260d8d]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-bf260d8d]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-bf260d8d]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-bf260d8d]{display:flex;align-items:center;gap:8px}.header__action[data-v-bf260d8d]{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-bf260d8d]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-bf260d8d]{position:relative;margin-left:8px}.header__user-trigger[data-v-bf260d8d]{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-bf260d8d]:hover{background-color:var(--color-fill)}.header__user-name[data-v-bf260d8d]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-bf260d8d]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-bf260d8d]{transform:rotate(180deg)}.header__avatar[data-v-bf260d8d]{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-bf260d8d]{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-bf260d8d]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-bf260d8d]{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-bf260d8d]{flex:1}.header__dropdown-name[data-v-bf260d8d]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-bf260d8d]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-bf260d8d]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-bf260d8d]{padding:8px 0}.header__dropdown-item[data-v-bf260d8d]{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-bf260d8d]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-bf260d8d]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-bf260d8d]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.header__search-modal[data-v-bf260d8d]{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-bf260d8d]{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-bf260d8d]{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border-lighter)}.search-input-wrapper .search-icon[data-v-bf260d8d]{color:var(--color-text-secondary);margin-right:12px}.search-input-wrapper .search-input[data-v-bf260d8d]{flex:1;font-size:16px;color:var(--color-text-primary);background:transparent;border:none;outline:none}.search-input-wrapper .search-input[data-v-bf260d8d]::placeholder{color:var(--color-text-placeholder)}.search-input-wrapper .search-shortcut[data-v-bf260d8d]{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-bf260d8d]{max-height:400px;overflow-y:auto;padding:8px 0}.search-result-item[data-v-bf260d8d]{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:background-color .2s}.search-result-item[data-v-bf260d8d]:hover{background-color:var(--color-fill)}.search-result-item.is-first[data-v-bf260d8d]{background-color:var(--color-primary-light-9)}.search-result-item .search-result-icon[data-v-bf260d8d]{color:var(--color-text-secondary)}.search-result-item .search-result-info[data-v-bf260d8d]{flex:1;display:flex;flex-direction:column;gap:2px}.search-result-item .search-result-title[data-v-bf260d8d]{font-size:14px;color:var(--color-text-primary)}.search-result-item .search-result-parent[data-v-bf260d8d]{font-size:12px;color:var(--color-text-secondary)}.search-empty[data-v-bf260d8d]{padding:40px 20px;text-align:center;color:var(--color-text-secondary);font-size:14px}.settings-drawer .settings-section[data-v-bf260d8d]{margin-bottom:24px}.settings-drawer .settings-title[data-v-bf260d8d]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-bf260d8d]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-bf260d8d]{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-bf260d8d]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-bf260d8d]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-bf260d8d]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-bf260d8d]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-bf260d8d]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-bf260d8d]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-bf260d8d]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-bf260d8d]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-bf260d8d]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-bf260d8d]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-bf260d8d]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-bf260d8d]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-bf260d8d]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-bf260d8d]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-bf260d8d]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-bf260d8d]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-bf260d8d]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-bf260d8d]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-bf260d8d]{display:flex;gap:12px}.settings-drawer .color-option[data-v-bf260d8d]{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-bf260d8d]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-bf260d8d]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-bf260d8d]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-bf260d8d]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-bf260d8d]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-bf260d8d]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-bf260d8d]{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-bf260d8d]: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-bf260d8d]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-bf260d8d]:after{left:24px}.dropdown-enter-active[data-v-bf260d8d],.dropdown-leave-active[data-v-bf260d8d]{transition:all .2s ease}.dropdown-enter-from[data-v-bf260d8d],.dropdown-leave-to[data-v-bf260d8d]{opacity:0;transform:translateY(-10px)}.search-enter-active[data-v-bf260d8d],.search-leave-active[data-v-bf260d8d]{transition:all .2s ease}.search-enter-from[data-v-bf260d8d],.search-leave-to[data-v-bf260d8d]{opacity:0}.top-menu[data-v-a7eeb703]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.top-menu__logo[data-v-a7eeb703]{display:flex;align-items:center;gap:10px;margin-right:20px}.top-menu__logo-img[data-v-a7eeb703]{width:32px;height:32px}.top-menu__logo-text[data-v-a7eeb703]{font-size:16px;font-weight:600;color:var(--color-primary)}.top-menu__menu[data-v-a7eeb703]{flex:1;border-bottom:none;height:100%}.top-menu__menu-content[data-v-a7eeb703]{display:inline-flex;align-items:center}.top-menu__menu-text[data-v-a7eeb703]{flex:1}.top-menu__menu-icon[data-v-a7eeb703]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.top-menu__menu-char[data-v-a7eeb703]{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-a7eeb703]{display:flex;align-items:center;gap:8px}.top-menu__action[data-v-a7eeb703]{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-a7eeb703]:hover{background-color:var(--color-fill);color:var(--color-primary)}.top-menu__user[data-v-a7eeb703]{position:relative;margin-left:8px}.top-menu__user-trigger[data-v-a7eeb703]{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-a7eeb703]:hover{background-color:var(--color-fill)}.top-menu__user-name[data-v-a7eeb703]{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-a7eeb703]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.top-menu__user-arrow.is-active[data-v-a7eeb703]{transform:rotate(180deg)}.top-menu__avatar[data-v-a7eeb703]{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-a7eeb703]{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-a7eeb703]{display:flex;align-items:center;gap:12px;padding:16px}.top-menu__dropdown-avatar[data-v-a7eeb703]{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-a7eeb703]{flex:1}.top-menu__dropdown-name[data-v-a7eeb703]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.top-menu__dropdown-role[data-v-a7eeb703]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.top-menu__dropdown-divider[data-v-a7eeb703]{height:1px;background-color:var(--color-border-lighter)}.top-menu__dropdown-menu[data-v-a7eeb703]{padding:8px 0}.top-menu__dropdown-item[data-v-a7eeb703]{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-a7eeb703]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.top-menu__dropdown-item--danger[data-v-a7eeb703]{color:var(--color-danger)}.top-menu__dropdown-item--danger[data-v-a7eeb703]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-a7eeb703]{margin-bottom:24px}.settings-drawer .settings-title[data-v-a7eeb703]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-a7eeb703]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-a7eeb703]{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-a7eeb703]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-a7eeb703]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-a7eeb703]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-a7eeb703]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-a7eeb703]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-a7eeb703]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-a7eeb703]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-a7eeb703]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-a7eeb703]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-a7eeb703]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-a7eeb703]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-a7eeb703]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-a7eeb703]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-a7eeb703]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-a7eeb703]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-a7eeb703]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-a7eeb703]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-a7eeb703]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-a7eeb703]{display:flex;gap:12px}.settings-drawer .color-option[data-v-a7eeb703]{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-a7eeb703]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-a7eeb703]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-a7eeb703]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-a7eeb703]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-a7eeb703]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-a7eeb703]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-a7eeb703]{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-a7eeb703]: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-a7eeb703]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-a7eeb703]:after{left:24px}.dropdown-enter-active[data-v-a7eeb703],.dropdown-leave-active[data-v-a7eeb703]{transition:all .2s ease}.dropdown-enter-from[data-v-a7eeb703],.dropdown-leave-to[data-v-a7eeb703]{opacity:0;transform:translateY(-10px)}.layout[data-v-7e8c7aeb]{display:flex;width:100%;height:100%}.layout--sidebar[data-v-7e8c7aeb]{flex-direction:row}.layout--top[data-v-7e8c7aeb]{flex-direction:column}.layout--top .layout__aside[data-v-7e8c7aeb]{display:none}.layout--top .layout__main[data-v-7e8c7aeb]{flex:1}.layout--mix[data-v-7e8c7aeb]{flex-direction:row}.layout__aside[data-v-7e8c7aeb]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__top-menu[data-v-7e8c7aeb]{width:100%;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.layout__main[data-v-7e8c7aeb]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-7e8c7aeb]{height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-7e8c7aeb]{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.35",
3
+ "version": "0.4.37",
4
4
  "private": false,
5
5
  "type": "module",
6
6
  "description": "XTO 前端应用框架",
@@ -570,71 +570,4 @@
570
570
  }
571
571
  }
572
572
  }
573
-
574
- // 混合顶部菜单
575
- .mix-top-menu {
576
- background-color: #1d1e1f;
577
- border-bottom-color: #363637;
578
-
579
- &__logo-text {
580
- color: #409eff;
581
- }
582
-
583
- &__menu {
584
- background-color: #1d1e1f !important;
585
- }
586
-
587
- &__menu-char {
588
- color: #79bbff;
589
- background-color: rgba(64, 158, 255, 0.2);
590
- }
591
-
592
- &__action {
593
- color: #cfd3dc;
594
-
595
- &:hover {
596
- background-color: #262727;
597
- color: #409eff;
598
- }
599
- }
600
-
601
- &__user-trigger:hover {
602
- background-color: #262727;
603
- }
604
-
605
- &__user-name {
606
- color: #cfd3dc;
607
- }
608
-
609
- &__user-arrow {
610
- color: #a3a6ad;
611
- }
612
-
613
- &__dropdown {
614
- background-color: #1d1e1f;
615
- border: 1px solid #363637;
616
- box-shadow: 0 2px 12px rgba(0, 0, 0, 0.5);
617
- }
618
-
619
- &__dropdown-name {
620
- color: #e5eaf3;
621
- }
622
-
623
- &__dropdown-role {
624
- color: #a3a6ad;
625
- }
626
-
627
- &__dropdown-divider {
628
- background-color: #363637;
629
- }
630
-
631
- &__dropdown-item {
632
- color: #cfd3dc;
633
-
634
- &:hover {
635
- background-color: #262727;
636
- color: #e5eaf3;
637
- }
638
- }
639
- }
640
573
  }
@@ -234,6 +234,12 @@ onUnmounted(() => {
234
234
  <div class="header">
235
235
  <!-- 左侧 -->
236
236
  <div class="header__left">
237
+ <!-- Logo -->
238
+ <div class="header__logo">
239
+ <img src="/vite.svg" alt="Logo" class="header__logo-img" />
240
+ <span class="header__logo-text">{{ appStore.appName }}</span>
241
+ </div>
242
+
237
243
  <!-- 折叠按钮 -->
238
244
  <div class="header__collapse" @click="toggleCollapse">
239
245
  <Icon :name="appStore.isCollapsed ? 'menu-unfold' : 'menu-fold'" :size="18" />
@@ -453,6 +459,23 @@ onUnmounted(() => {
453
459
  gap: 15px;
454
460
  }
455
461
 
462
+ &__logo {
463
+ display: flex;
464
+ align-items: center;
465
+ gap: 10px;
466
+ }
467
+
468
+ &__logo-img {
469
+ width: 32px;
470
+ height: 32px;
471
+ }
472
+
473
+ &__logo-text {
474
+ font-size: 16px;
475
+ font-weight: 600;
476
+ color: var(--color-primary);
477
+ }
478
+
456
479
  &__collapse {
457
480
  width: 24px;
458
481
  height: 24px;
@@ -11,12 +11,8 @@ import { Button, Icon } from '@xto/base'
11
11
  // Props
12
12
  const props = withDefaults(defineProps<{
13
13
  menuList?: any[]
14
- showLogo?: boolean
15
- showUser?: boolean
16
14
  }>(), {
17
- menuList: () => [],
18
- showLogo: true,
19
- showUser: true
15
+ menuList: () => []
20
16
  })
21
17
 
22
18
  const route = useRoute()
@@ -135,9 +131,9 @@ const iconExists = (iconName: string): boolean => {
135
131
  </script>
136
132
 
137
133
  <template>
138
- <div class="sidebar" :class="{ 'sidebar--collapsed': isCollapsed, 'sidebar--no-logo': !props.showLogo }">
139
- <!-- Logo(仅在非混合模式下显示) -->
140
- <div v-if="props.showLogo" class="sidebar__logo">
134
+ <div class="sidebar" :class="{ 'sidebar--collapsed': isCollapsed }">
135
+ <!-- Logo -->
136
+ <div class="sidebar__logo">
141
137
  <img src="/vite.svg" alt="Logo" class="sidebar__logo-img" />
142
138
  <span v-show="!isCollapsed" class="sidebar__logo-text">{{ appStore.appName }}</span>
143
139
  </div>
@@ -158,37 +154,43 @@ const iconExists = (iconName: string): boolean => {
158
154
  <!-- 有子菜单 -->
159
155
  <SubMenu v-if="menu.children && menu.children.length > 0" :index="menu.menuUrl">
160
156
  <template #title>
161
- <span class="sidebar__menu-icon">
162
- <Icon v-if="iconExists(getMenuIcon(menu.icon))" :name="getMenuIcon(menu.icon)" :size="16" />
163
- <span v-else class="sidebar__menu-char">{{ getFirstChar(menu.menuName) }}</span>
157
+ <span class="sidebar__menu-content">
158
+ <span class="sidebar__menu-icon">
159
+ <Icon v-if="iconExists(getMenuIcon(menu.icon))" :name="getMenuIcon(menu.icon)" :size="16" />
160
+ <span v-else class="sidebar__menu-char">{{ getFirstChar(menu.menuName) }}</span>
161
+ </span>
162
+ <span class="sidebar__menu-text">{{ menu.menuName }}</span>
164
163
  </span>
165
- <span>{{ menu.menuName }}</span>
166
164
  </template>
167
165
  <MenuItem
168
166
  v-for="child in menu.children"
169
167
  :key="child.menuUrl"
170
168
  :index="child.menuUrl"
171
169
  >
172
- <span class="sidebar__menu-icon">
173
- <Icon v-if="iconExists(getMenuIcon(child.icon))" :name="getMenuIcon(child.icon)" :size="16" />
174
- <span v-else class="sidebar__menu-char">{{ getFirstChar(child.menuName) }}</span>
170
+ <span class="sidebar__menu-content">
171
+ <span class="sidebar__menu-icon">
172
+ <Icon v-if="iconExists(getMenuIcon(child.icon))" :name="getMenuIcon(child.icon)" :size="16" />
173
+ <span v-else class="sidebar__menu-char">{{ getFirstChar(child.menuName) }}</span>
174
+ </span>
175
+ <span class="sidebar__menu-text">{{ child.menuName }}</span>
175
176
  </span>
176
- <span>{{ child.menuName }}</span>
177
177
  </MenuItem>
178
178
  </SubMenu>
179
179
  <!-- 无子菜单 -->
180
180
  <MenuItem v-else :index="menu.menuUrl">
181
- <span class="sidebar__menu-icon">
182
- <Icon v-if="iconExists(getMenuIcon(menu.icon))" :name="getMenuIcon(menu.icon)" :size="16" />
183
- <span v-else class="sidebar__menu-char">{{ getFirstChar(menu.menuName) }}</span>
181
+ <span class="sidebar__menu-content">
182
+ <span class="sidebar__menu-icon">
183
+ <Icon v-if="iconExists(getMenuIcon(menu.icon))" :name="getMenuIcon(menu.icon)" :size="16" />
184
+ <span v-else class="sidebar__menu-char">{{ getFirstChar(menu.menuName) }}</span>
185
+ </span>
186
+ <span class="sidebar__menu-text">{{ menu.menuName }}</span>
184
187
  </span>
185
- <span>{{ menu.menuName }}</span>
186
188
  </MenuItem>
187
189
  </template>
188
190
  </Menu>
189
191
 
190
- <!-- 用户信息(仅在非混合模式下显示) -->
191
- <div v-if="props.showUser && !isCollapsed" class="sidebar__user">
192
+ <!-- 用户信息 -->
193
+ <div v-if="!isCollapsed" class="sidebar__user">
192
194
  <div class="sidebar__user-info">
193
195
  <span class="sidebar__user-name">{{ userStore.userName }}</span>
194
196
  <span class="sidebar__user-role">{{ userStore.departmentName }}</span>
@@ -213,10 +215,6 @@ const iconExists = (iconName: string): boolean => {
213
215
  }
214
216
  }
215
217
 
216
- &--no-logo {
217
- // 没有 logo 时,菜单直接从顶部开始
218
- }
219
-
220
218
  &__logo {
221
219
  height: 50px;
222
220
  display: flex;
@@ -243,6 +241,15 @@ const iconExists = (iconName: string): boolean => {
243
241
  overflow-y: auto;
244
242
  }
245
243
 
244
+ &__menu-content {
245
+ display: inline-flex;
246
+ align-items: center;
247
+ }
248
+
249
+ &__menu-text {
250
+ flex: 1;
251
+ }
252
+
246
253
  &__menu-icon {
247
254
  display: inline-flex;
248
255
  align-items: center;
@@ -244,6 +244,12 @@ onUnmounted(() => {
244
244
 
245
245
  <template>
246
246
  <div class="top-menu">
247
+ <!-- 左侧 Logo -->
248
+ <div class="top-menu__logo">
249
+ <img src="/vite.svg" alt="Logo" class="top-menu__logo-img" />
250
+ <span class="top-menu__logo-text">{{ appStore.appName }}</span>
251
+ </div>
252
+
247
253
  <!-- 左侧菜单 -->
248
254
  <Menu
249
255
  :default-active="activeMenu"
@@ -258,31 +264,37 @@ onUnmounted(() => {
258
264
  <!-- 有子菜单 -->
259
265
  <SubMenu v-if="menu.children && menu.children.length > 0" :index="menu.menuUrl">
260
266
  <template #title>
261
- <span class="top-menu__menu-icon">
262
- <Icon v-if="iconExists(getMenuIcon(menu.icon))" :name="getMenuIcon(menu.icon)" :size="16" />
263
- <span v-else class="top-menu__menu-char">{{ getFirstChar(menu.menuName) }}</span>
267
+ <span class="top-menu__menu-content">
268
+ <span class="top-menu__menu-icon">
269
+ <Icon v-if="iconExists(getMenuIcon(menu.icon))" :name="getMenuIcon(menu.icon)" :size="16" />
270
+ <span v-else class="top-menu__menu-char">{{ getFirstChar(menu.menuName) }}</span>
271
+ </span>
272
+ <span class="top-menu__menu-text">{{ menu.menuName }}</span>
264
273
  </span>
265
- <span>{{ menu.menuName }}</span>
266
274
  </template>
267
275
  <MenuItem
268
276
  v-for="child in menu.children"
269
277
  :key="child.menuUrl"
270
278
  :index="child.menuUrl"
271
279
  >
272
- <span class="top-menu__menu-icon">
273
- <Icon v-if="iconExists(getMenuIcon(child.icon))" :name="getMenuIcon(child.icon)" :size="16" />
274
- <span v-else class="top-menu__menu-char">{{ getFirstChar(child.menuName) }}</span>
280
+ <span class="top-menu__menu-content">
281
+ <span class="top-menu__menu-icon">
282
+ <Icon v-if="iconExists(getMenuIcon(child.icon))" :name="getMenuIcon(child.icon)" :size="16" />
283
+ <span v-else class="top-menu__menu-char">{{ getFirstChar(child.menuName) }}</span>
284
+ </span>
285
+ <span class="top-menu__menu-text">{{ child.menuName }}</span>
275
286
  </span>
276
- <span>{{ child.menuName }}</span>
277
287
  </MenuItem>
278
288
  </SubMenu>
279
289
  <!-- 无子菜单 -->
280
290
  <MenuItem v-else :index="menu.menuUrl">
281
- <span class="top-menu__menu-icon">
282
- <Icon v-if="iconExists(getMenuIcon(menu.icon))" :name="getMenuIcon(menu.icon)" :size="16" />
283
- <span v-else class="top-menu__menu-char">{{ getFirstChar(menu.menuName) }}</span>
291
+ <span class="top-menu__menu-content">
292
+ <span class="top-menu__menu-icon">
293
+ <Icon v-if="iconExists(getMenuIcon(menu.icon))" :name="getMenuIcon(menu.icon)" :size="16" />
294
+ <span v-else class="top-menu__menu-char">{{ getFirstChar(menu.menuName) }}</span>
295
+ </span>
296
+ <span class="top-menu__menu-text">{{ menu.menuName }}</span>
284
297
  </span>
285
- <span>{{ menu.menuName }}</span>
286
298
  </MenuItem>
287
299
  </template>
288
300
  </Menu>
@@ -440,12 +452,39 @@ onUnmounted(() => {
440
452
  align-items: center;
441
453
  padding: 0 20px;
442
454
 
455
+ &__logo {
456
+ display: flex;
457
+ align-items: center;
458
+ gap: 10px;
459
+ margin-right: 20px;
460
+ }
461
+
462
+ &__logo-img {
463
+ width: 32px;
464
+ height: 32px;
465
+ }
466
+
467
+ &__logo-text {
468
+ font-size: 16px;
469
+ font-weight: 600;
470
+ color: var(--color-primary);
471
+ }
472
+
443
473
  &__menu {
444
474
  flex: 1;
445
475
  border-bottom: none;
446
476
  height: 100%;
447
477
  }
448
478
 
479
+ &__menu-content {
480
+ display: inline-flex;
481
+ align-items: center;
482
+ }
483
+
484
+ &__menu-text {
485
+ flex: 1;
486
+ }
487
+
449
488
  &__menu-icon {
450
489
  display: inline-flex;
451
490
  align-items: center;