xto-fronted 0.4.13 → 0.4.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Layout/MixTopMenu.vue.d.ts +2 -0
- package/dist/index-Bqx7oYvi.js +2303 -0
- package/dist/{index-CrJYCWl-.js → index-CXru1UAh.js} +1 -1
- package/dist/{index-D8DWh2wV.js → index-Cp8sP57V.js} +1 -1
- package/dist/{index-BCv8lkNK.js → index-DYjM-bJ4.js} +1 -1
- package/dist/{index-CGq_kOCw.js → index-U9HXi5z6.js} +1 -1
- package/dist/index.es.js +1 -1
- package/dist/index.umd.js +1 -1
- package/dist/stores/app.d.ts +8 -2
- package/dist/style.css +1 -1
- package/package.json +3 -3
- package/src/assets/styles/_dark.scss +33 -0
- package/src/components/Layout/Header.vue +2 -2
- package/src/components/Layout/MixTopMenu.vue +253 -0
- package/src/components/Layout/index.vue +113 -28
- package/src/stores/app.ts +15 -0
- package/dist/index-TvEBauqV.js +0 -2067
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-9da60fc6]{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-9da60fc6]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-9da60fc6]{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-9da60fc6]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-9da60fc6]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-9da60fc6]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-9da60fc6]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-9da60fc6]{display:flex;align-items:center;gap:8px}.header__action[data-v-9da60fc6]{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-9da60fc6]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-9da60fc6]{position:relative;margin-left:8px}.header__user-trigger[data-v-9da60fc6]{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-9da60fc6]:hover{background-color:var(--color-fill)}.header__user-name[data-v-9da60fc6]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-9da60fc6]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-9da60fc6]{transform:rotate(180deg)}.header__avatar[data-v-9da60fc6]{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-9da60fc6]{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-9da60fc6]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-9da60fc6]{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-9da60fc6]{flex:1}.header__dropdown-name[data-v-9da60fc6]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-9da60fc6]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-9da60fc6]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-9da60fc6]{padding:8px 0}.header__dropdown-item[data-v-9da60fc6]{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-9da60fc6]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-9da60fc6]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-9da60fc6]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.header__search-modal[data-v-9da60fc6]{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-9da60fc6]{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-9da60fc6]{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border-lighter)}.search-input-wrapper .search-icon[data-v-9da60fc6]{color:var(--color-text-secondary);margin-right:12px}.search-input-wrapper .search-input[data-v-9da60fc6]{flex:1;font-size:16px;color:var(--color-text-primary);background:transparent;border:none;outline:none}.search-input-wrapper .search-input[data-v-9da60fc6]::placeholder{color:var(--color-text-placeholder)}.search-input-wrapper .search-shortcut[data-v-9da60fc6]{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-9da60fc6]{max-height:400px;overflow-y:auto;padding:8px 0}.search-result-item[data-v-9da60fc6]{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:background-color .2s}.search-result-item[data-v-9da60fc6]:hover{background-color:var(--color-fill)}.search-result-item.is-first[data-v-9da60fc6]{background-color:var(--color-primary-light-9)}.search-result-item .search-result-icon[data-v-9da60fc6]{color:var(--color-text-secondary)}.search-result-item .search-result-info[data-v-9da60fc6]{flex:1;display:flex;flex-direction:column;gap:2px}.search-result-item .search-result-title[data-v-9da60fc6]{font-size:14px;color:var(--color-text-primary)}.search-result-item .search-result-parent[data-v-9da60fc6]{font-size:12px;color:var(--color-text-secondary)}.search-empty[data-v-9da60fc6]{padding:40px 20px;text-align:center;color:var(--color-text-secondary);font-size:14px}.settings-drawer .settings-section[data-v-9da60fc6]{margin-bottom:24px}.settings-drawer .settings-title[data-v-9da60fc6]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-9da60fc6]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-9da60fc6]{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-9da60fc6]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-9da60fc6]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-9da60fc6]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-9da60fc6]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-9da60fc6]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-9da60fc6]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-9da60fc6]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-9da60fc6]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-9da60fc6]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-9da60fc6]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-9da60fc6]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-9da60fc6]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-9da60fc6]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-9da60fc6]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-9da60fc6]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-9da60fc6]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-9da60fc6]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-9da60fc6]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-9da60fc6]{display:flex;gap:12px}.settings-drawer .color-option[data-v-9da60fc6]{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-9da60fc6]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-9da60fc6]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-9da60fc6]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-9da60fc6]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-9da60fc6]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-9da60fc6]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-9da60fc6]{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-9da60fc6]: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-9da60fc6]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-9da60fc6]:after{left:24px}.dropdown-enter-active[data-v-9da60fc6],.dropdown-leave-active[data-v-9da60fc6]{transition:all .2s ease}.dropdown-enter-from[data-v-9da60fc6],.dropdown-leave-to[data-v-9da60fc6]{opacity:0;transform:translateY(-10px)}.search-enter-active[data-v-9da60fc6],.search-leave-active[data-v-9da60fc6]{transition:all .2s ease}.search-enter-from[data-v-9da60fc6],.search-leave-to[data-v-9da60fc6]{opacity:0}.top-menu[data-v-8b571a75]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.top-menu__menu[data-v-8b571a75]{flex:1;border-bottom:none;height:100%}.top-menu__menu-icon[data-v-8b571a75]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.top-menu__menu-char[data-v-8b571a75]{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}.layout[data-v-ce02c7c0]{display:flex;width:100%;height:100%}.layout--sidebar[data-v-ce02c7c0]{flex-direction:row}.layout--top[data-v-ce02c7c0]{flex-direction:column}.layout--top .layout__aside[data-v-ce02c7c0]{display:none}.layout--top .layout__main[data-v-ce02c7c0]{flex:1}.layout--mix[data-v-ce02c7c0]{flex-direction:row}.layout__aside[data-v-ce02c7c0]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__top-menu[data-v-ce02c7c0]{width:100%;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.layout__main[data-v-ce02c7c0]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-ce02c7c0]{height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-ce02c7c0]{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-5b72324e]{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-5b72324e]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-5b72324e]{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-5b72324e]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-5b72324e]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-5b72324e]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-5b72324e]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-5b72324e]{display:flex;align-items:center;gap:8px}.header__action[data-v-5b72324e]{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-5b72324e]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-5b72324e]{position:relative;margin-left:8px}.header__user-trigger[data-v-5b72324e]{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-5b72324e]:hover{background-color:var(--color-fill)}.header__user-name[data-v-5b72324e]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-5b72324e]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-5b72324e]{transform:rotate(180deg)}.header__avatar[data-v-5b72324e]{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-5b72324e]{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-5b72324e]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-5b72324e]{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-5b72324e]{flex:1}.header__dropdown-name[data-v-5b72324e]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-5b72324e]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-5b72324e]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-5b72324e]{padding:8px 0}.header__dropdown-item[data-v-5b72324e]{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-5b72324e]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-5b72324e]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-5b72324e]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.header__search-modal[data-v-5b72324e]{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-5b72324e]{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-5b72324e]{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border-lighter)}.search-input-wrapper .search-icon[data-v-5b72324e]{color:var(--color-text-secondary);margin-right:12px}.search-input-wrapper .search-input[data-v-5b72324e]{flex:1;font-size:16px;color:var(--color-text-primary);background:transparent;border:none;outline:none}.search-input-wrapper .search-input[data-v-5b72324e]::placeholder{color:var(--color-text-placeholder)}.search-input-wrapper .search-shortcut[data-v-5b72324e]{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-5b72324e]{max-height:400px;overflow-y:auto;padding:8px 0}.search-result-item[data-v-5b72324e]{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:background-color .2s}.search-result-item[data-v-5b72324e]:hover{background-color:var(--color-fill)}.search-result-item.is-first[data-v-5b72324e]{background-color:var(--color-primary-light-9)}.search-result-item .search-result-icon[data-v-5b72324e]{color:var(--color-text-secondary)}.search-result-item .search-result-info[data-v-5b72324e]{flex:1;display:flex;flex-direction:column;gap:2px}.search-result-item .search-result-title[data-v-5b72324e]{font-size:14px;color:var(--color-text-primary)}.search-result-item .search-result-parent[data-v-5b72324e]{font-size:12px;color:var(--color-text-secondary)}.search-empty[data-v-5b72324e]{padding:40px 20px;text-align:center;color:var(--color-text-secondary);font-size:14px}.settings-drawer .settings-section[data-v-5b72324e]{margin-bottom:24px}.settings-drawer .settings-title[data-v-5b72324e]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-5b72324e]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-5b72324e]{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-5b72324e]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-5b72324e]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-5b72324e]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-5b72324e]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-5b72324e]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-5b72324e]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-5b72324e]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-5b72324e]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-5b72324e]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-5b72324e]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-5b72324e]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-5b72324e]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-5b72324e]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-5b72324e]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-5b72324e]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-5b72324e]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-5b72324e]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-5b72324e]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-5b72324e]{display:flex;gap:12px}.settings-drawer .color-option[data-v-5b72324e]{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-5b72324e]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-5b72324e]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-5b72324e]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-5b72324e]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-5b72324e]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-5b72324e]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-5b72324e]{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-5b72324e]: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-5b72324e]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-5b72324e]:after{left:24px}.dropdown-enter-active[data-v-5b72324e],.dropdown-leave-active[data-v-5b72324e]{transition:all .2s ease}.dropdown-enter-from[data-v-5b72324e],.dropdown-leave-to[data-v-5b72324e]{opacity:0;transform:translateY(-10px)}.search-enter-active[data-v-5b72324e],.search-leave-active[data-v-5b72324e]{transition:all .2s ease}.search-enter-from[data-v-5b72324e],.search-leave-to[data-v-5b72324e]{opacity:0}.top-menu[data-v-8b571a75]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.top-menu__menu[data-v-8b571a75]{flex:1;border-bottom:none;height:100%}.top-menu__menu-icon[data-v-8b571a75]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.top-menu__menu-char[data-v-8b571a75]{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[data-v-5df2ff55]{width:100%;height:50px;display:flex;align-items:center;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);padding:0 20px}.mix-top-menu__logo[data-v-5df2ff55]{display:flex;align-items:center;padding-right:20px;border-right:1px solid var(--color-border-lighter);margin-right:20px}.mix-top-menu__logo-text[data-v-5df2ff55]{font-size:16px;font-weight:600;color:var(--color-primary)}.mix-top-menu__items[data-v-5df2ff55]{flex:1;display:flex;align-items:center;gap:4px}.mix-top-menu__item[data-v-5df2ff55]{display:flex;align-items:center;padding:8px 16px;cursor:pointer;border-radius:4px;transition:all .2s}.mix-top-menu__item[data-v-5df2ff55]:hover{background-color:var(--color-fill)}.mix-top-menu__item.is-active[data-v-5df2ff55]{background-color:var(--color-primary-light-9);color:var(--color-primary)}.mix-top-menu__item-icon[data-v-5df2ff55]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px}.mix-top-menu__item-char[data-v-5df2ff55]{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__item-text[data-v-5df2ff55]{font-size:14px;color:var(--color-text-regular)}.mix-top-menu.is-active .mix-top-menu__item-text[data-v-5df2ff55]{color:var(--color-primary)}.mix-top-menu__actions[data-v-5df2ff55]{display:flex;align-items:center;gap:8px}.layout[data-v-335d0383]{display:flex;width:100%;height:100%}.layout--sidebar[data-v-335d0383]{flex-direction:row}.layout--top[data-v-335d0383]{flex-direction:column}.layout--top .layout__aside[data-v-335d0383]{display:none}.layout--top .layout__main[data-v-335d0383]{flex:1}.layout--mix[data-v-335d0383]{flex-direction:column}.layout--mix .layout__mix-body[data-v-335d0383]{display:flex;flex:1;overflow:hidden}.layout--mix .layout__aside[data-v-335d0383]{height:100%}.layout--mix .layout__main[data-v-335d0383]{flex:1}.layout__aside[data-v-335d0383]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__top-menu[data-v-335d0383]{width:100%;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.layout__main[data-v-335d0383]{display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-335d0383]{height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-335d0383]{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.
|
|
3
|
+
"version": "0.4.15",
|
|
4
4
|
"private": false,
|
|
5
5
|
"type": "module",
|
|
6
6
|
"description": "XTO 前端应用框架",
|
|
@@ -40,7 +40,7 @@
|
|
|
40
40
|
"@xto/data": "^1.1.1",
|
|
41
41
|
"@xto/feedback": "^1.1.5",
|
|
42
42
|
"@xto/form": "^1.1.2",
|
|
43
|
-
"@xto/layout": "^1.0.
|
|
43
|
+
"@xto/layout": "^1.0.6",
|
|
44
44
|
"@xto/navigation": "^1.2.3",
|
|
45
45
|
"axios": "^1.6.0",
|
|
46
46
|
"pinia": "^2.1.0",
|
|
@@ -56,7 +56,7 @@
|
|
|
56
56
|
"@xto/data": "^1.1.1",
|
|
57
57
|
"@xto/feedback": "^1.1.5",
|
|
58
58
|
"@xto/form": "^1.1.2",
|
|
59
|
-
"@xto/layout": "^1.0.
|
|
59
|
+
"@xto/layout": "^1.0.6",
|
|
60
60
|
"@xto/navigation": "^1.2.3",
|
|
61
61
|
"axios": "^1.6.8",
|
|
62
62
|
"pinia": "^2.1.7",
|
|
@@ -522,4 +522,37 @@
|
|
|
522
522
|
}
|
|
523
523
|
}
|
|
524
524
|
}
|
|
525
|
+
|
|
526
|
+
// 混合顶部菜单
|
|
527
|
+
.mix-top-menu {
|
|
528
|
+
background-color: #1d1e1f;
|
|
529
|
+
border-bottom-color: #363637;
|
|
530
|
+
|
|
531
|
+
&__logo-text {
|
|
532
|
+
color: #409eff;
|
|
533
|
+
}
|
|
534
|
+
|
|
535
|
+
&__item {
|
|
536
|
+
&:hover {
|
|
537
|
+
background-color: #262727;
|
|
538
|
+
}
|
|
539
|
+
|
|
540
|
+
&.is-active {
|
|
541
|
+
background-color: rgba(64, 158, 255, 0.1);
|
|
542
|
+
}
|
|
543
|
+
}
|
|
544
|
+
|
|
545
|
+
&__item-text {
|
|
546
|
+
color: #cfd3dc;
|
|
547
|
+
}
|
|
548
|
+
|
|
549
|
+
&.is-active &__item-text {
|
|
550
|
+
color: #409eff;
|
|
551
|
+
}
|
|
552
|
+
|
|
553
|
+
&__item-char {
|
|
554
|
+
color: #79bbff;
|
|
555
|
+
background-color: rgba(64, 158, 255, 0.2);
|
|
556
|
+
}
|
|
557
|
+
}
|
|
525
558
|
}
|
|
@@ -220,8 +220,8 @@ onUnmounted(() => {
|
|
|
220
220
|
<div class="header">
|
|
221
221
|
<!-- 左侧 -->
|
|
222
222
|
<div class="header__left">
|
|
223
|
-
<!--
|
|
224
|
-
<div class="header__collapse" @click="toggleCollapse">
|
|
223
|
+
<!-- 折叠按钮(仅 sidebar 模式显示) -->
|
|
224
|
+
<div v-if="appStore.layout === 'sidebar'" class="header__collapse" @click="toggleCollapse">
|
|
225
225
|
<Icon :name="appStore.isCollapsed ? 'menu-unfold' : 'menu-fold'" :size="18" />
|
|
226
226
|
</div>
|
|
227
227
|
|
|
@@ -0,0 +1,253 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
import { computed, onMounted } from 'vue'
|
|
3
|
+
import { useRoute, useRouter } from 'vue-router'
|
|
4
|
+
import { useMenuStore } from '@/stores/menu'
|
|
5
|
+
import { useAppStore } from '@/stores/app'
|
|
6
|
+
import { Icon } from '@xto/base'
|
|
7
|
+
import type { MenuItem } from '@/types/api'
|
|
8
|
+
|
|
9
|
+
const route = useRoute()
|
|
10
|
+
const router = useRouter()
|
|
11
|
+
const menuStore = useMenuStore()
|
|
12
|
+
const appStore = useAppStore()
|
|
13
|
+
|
|
14
|
+
// 当前选中的一级菜单路径
|
|
15
|
+
const activeTopMenu = computed(() => appStore.activeTopMenuPath)
|
|
16
|
+
|
|
17
|
+
// 一级菜单列表(只显示顶层菜单)
|
|
18
|
+
const topMenuList = computed(() => menuStore.menuList)
|
|
19
|
+
|
|
20
|
+
// 已知的图标名称列表
|
|
21
|
+
const knownIcons = new Set([
|
|
22
|
+
'arrow-up', 'arrow-down', 'arrow-left', 'arrow-right',
|
|
23
|
+
'caret-down', 'caret-right', 'plus', 'minus', 'close', 'check',
|
|
24
|
+
'edit', 'delete', 'copy', 'download', 'upload', 'refresh', 'search',
|
|
25
|
+
'filter', 'more', 'setting', 'share', 'loading', 'info', 'success',
|
|
26
|
+
'warning', 'error', 'question', 'user', 'user-add', 'user-group',
|
|
27
|
+
'logout', 'login', 'file', 'folder', 'folder-open', 'document',
|
|
28
|
+
'image', 'video', 'music', 'camera', 'mail', 'phone', 'chat',
|
|
29
|
+
'bell', 'message', 'eye', 'eye-off', 'calendar', 'clock', 'history',
|
|
30
|
+
'timer', 'location', 'map', 'globe', 'star', 'heart', 'thumb-up',
|
|
31
|
+
'link', 'external-link', 'lock', 'unlock', 'key', 'home', 'menu',
|
|
32
|
+
'menu-fold', 'menu-unfold', 'sidebar-fold', 'sidebar-expand',
|
|
33
|
+
'sidebar-left', 'dashboard', 'chart', 'chart-pie', 'chart-line',
|
|
34
|
+
'report', 'analytics', 'system', 'permission', 'role', 'user-manage',
|
|
35
|
+
'log', 'notification', 'app', 'list', 'grid', 'fullscreen',
|
|
36
|
+
'fullscreen-exit', 'zoom-in', 'zoom-out', 'print', 'bookmark',
|
|
37
|
+
'tag', 'code', 'terminal', 'database', 'server', 'cloud', 'gift',
|
|
38
|
+
'moon', 'sun', 'theme', 'skin'
|
|
39
|
+
])
|
|
40
|
+
|
|
41
|
+
// 获取菜单图标名称
|
|
42
|
+
const getMenuIcon = (icon?: string): string => {
|
|
43
|
+
if (!icon || icon === '') return ''
|
|
44
|
+
|
|
45
|
+
if (icon.startsWith('tineco-icon-')) {
|
|
46
|
+
const iconName = icon.replace('tineco-icon-', '')
|
|
47
|
+
const tinecoIconMap: Record<string, string> = {
|
|
48
|
+
home: 'home',
|
|
49
|
+
dashboard: 'dashboard',
|
|
50
|
+
system: 'system',
|
|
51
|
+
user: 'user',
|
|
52
|
+
role: 'role',
|
|
53
|
+
menu: 'list',
|
|
54
|
+
setting: 'setting',
|
|
55
|
+
file: 'file',
|
|
56
|
+
folder: 'folder',
|
|
57
|
+
chart: 'chart',
|
|
58
|
+
report: 'report',
|
|
59
|
+
analytics: 'analytics'
|
|
60
|
+
}
|
|
61
|
+
return tinecoIconMap[iconName] || iconName
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
const iconMap: Record<string, string> = {
|
|
65
|
+
dashboard: 'dashboard',
|
|
66
|
+
system: 'system',
|
|
67
|
+
user: 'user',
|
|
68
|
+
role: 'role',
|
|
69
|
+
menu: 'list',
|
|
70
|
+
setting: 'setting',
|
|
71
|
+
home: 'home',
|
|
72
|
+
chart: 'chart',
|
|
73
|
+
report: 'report',
|
|
74
|
+
analytics: 'analytics',
|
|
75
|
+
permission: 'permission',
|
|
76
|
+
log: 'log',
|
|
77
|
+
notification: 'notification',
|
|
78
|
+
app: 'app',
|
|
79
|
+
list: 'list',
|
|
80
|
+
grid: 'grid'
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
return iconMap[icon] || icon
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
const getFirstChar = (name?: string): string => {
|
|
87
|
+
if (!name) return ''
|
|
88
|
+
return name.charAt(0)
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
const iconExists = (iconName: string): boolean => {
|
|
92
|
+
return knownIcons.has(iconName)
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
// 点击一级菜单
|
|
96
|
+
const handleTopMenuClick = (menu: MenuItem) => {
|
|
97
|
+
appStore.setActiveTopMenuPath(menu.menuUrl)
|
|
98
|
+
|
|
99
|
+
// 如果一级菜单有直接跳转路径,则跳转
|
|
100
|
+
if (menu.menuUrl) {
|
|
101
|
+
// 如果有子菜单,跳转到第一个子菜单或默认子菜单
|
|
102
|
+
if (menu.children && menu.children.length > 0) {
|
|
103
|
+
// 找到默认子菜单或第一个子菜单
|
|
104
|
+
const defaultChild = menu.children.find(c => c.isDefault) || menu.children[0]
|
|
105
|
+
if (defaultChild && defaultChild.menuUrl !== route.path) {
|
|
106
|
+
router.push(defaultChild.menuUrl)
|
|
107
|
+
}
|
|
108
|
+
} else if (menu.menuUrl !== route.path) {
|
|
109
|
+
router.push(menu.menuUrl)
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
// 初始化:根据当前路由设置一级菜单选中状态
|
|
115
|
+
onMounted(() => {
|
|
116
|
+
if (!appStore.activeTopMenuPath && topMenuList.value.length > 0) {
|
|
117
|
+
// 找到当前路由所属的一级菜单
|
|
118
|
+
for (const menu of topMenuList.value) {
|
|
119
|
+
if (menu.menuUrl === route.path) {
|
|
120
|
+
appStore.setActiveTopMenuPath(menu.menuUrl)
|
|
121
|
+
break
|
|
122
|
+
}
|
|
123
|
+
if (menu.children && menu.children.length > 0) {
|
|
124
|
+
const found = menu.children.some(child =>
|
|
125
|
+
child.menuUrl === route.path ||
|
|
126
|
+
(child.children && child.children.some(c => c.menuUrl === route.path))
|
|
127
|
+
)
|
|
128
|
+
if (found) {
|
|
129
|
+
appStore.setActiveTopMenuPath(menu.menuUrl)
|
|
130
|
+
break
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
// 如果没找到,默认选中第一个
|
|
135
|
+
if (!appStore.activeTopMenuPath) {
|
|
136
|
+
appStore.setActiveTopMenuPath(topMenuList.value[0].menuUrl)
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
})
|
|
140
|
+
</script>
|
|
141
|
+
|
|
142
|
+
<template>
|
|
143
|
+
<div class="mix-top-menu">
|
|
144
|
+
<div class="mix-top-menu__logo">
|
|
145
|
+
<span class="mix-top-menu__logo-text">{{ appStore.appName }}</span>
|
|
146
|
+
</div>
|
|
147
|
+
<div class="mix-top-menu__items">
|
|
148
|
+
<div
|
|
149
|
+
v-for="menu in topMenuList"
|
|
150
|
+
:key="menu.menuUrl"
|
|
151
|
+
:class="['mix-top-menu__item', { 'is-active': activeTopMenu === menu.menuUrl }]"
|
|
152
|
+
@click="handleTopMenuClick(menu)"
|
|
153
|
+
>
|
|
154
|
+
<span class="mix-top-menu__item-icon">
|
|
155
|
+
<Icon v-if="iconExists(getMenuIcon(menu.icon))" :name="getMenuIcon(menu.icon)" :size="16" />
|
|
156
|
+
<span v-else class="mix-top-menu__item-char">{{ getFirstChar(menu.menuName) }}</span>
|
|
157
|
+
</span>
|
|
158
|
+
<span class="mix-top-menu__item-text">{{ menu.menuName }}</span>
|
|
159
|
+
</div>
|
|
160
|
+
</div>
|
|
161
|
+
<div class="mix-top-menu__actions">
|
|
162
|
+
<!-- 这里可以放一些操作按钮 -->
|
|
163
|
+
</div>
|
|
164
|
+
</div>
|
|
165
|
+
</template>
|
|
166
|
+
|
|
167
|
+
<style lang="scss" scoped>
|
|
168
|
+
.mix-top-menu {
|
|
169
|
+
width: 100%;
|
|
170
|
+
height: 50px;
|
|
171
|
+
display: flex;
|
|
172
|
+
align-items: center;
|
|
173
|
+
background-color: var(--bg-color);
|
|
174
|
+
border-bottom: 1px solid var(--color-border-lighter);
|
|
175
|
+
padding: 0 20px;
|
|
176
|
+
|
|
177
|
+
&__logo {
|
|
178
|
+
display: flex;
|
|
179
|
+
align-items: center;
|
|
180
|
+
padding-right: 20px;
|
|
181
|
+
border-right: 1px solid var(--color-border-lighter);
|
|
182
|
+
margin-right: 20px;
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
&__logo-text {
|
|
186
|
+
font-size: 16px;
|
|
187
|
+
font-weight: 600;
|
|
188
|
+
color: var(--color-primary);
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
&__items {
|
|
192
|
+
flex: 1;
|
|
193
|
+
display: flex;
|
|
194
|
+
align-items: center;
|
|
195
|
+
gap: 4px;
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
&__item {
|
|
199
|
+
display: flex;
|
|
200
|
+
align-items: center;
|
|
201
|
+
padding: 8px 16px;
|
|
202
|
+
cursor: pointer;
|
|
203
|
+
border-radius: 4px;
|
|
204
|
+
transition: all 0.2s;
|
|
205
|
+
|
|
206
|
+
&:hover {
|
|
207
|
+
background-color: var(--color-fill);
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
&.is-active {
|
|
211
|
+
background-color: var(--color-primary-light-9);
|
|
212
|
+
color: var(--color-primary);
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
&__item-icon {
|
|
217
|
+
display: inline-flex;
|
|
218
|
+
align-items: center;
|
|
219
|
+
justify-content: center;
|
|
220
|
+
width: 16px;
|
|
221
|
+
height: 16px;
|
|
222
|
+
margin-right: 8px;
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
&__item-char {
|
|
226
|
+
display: inline-flex;
|
|
227
|
+
align-items: center;
|
|
228
|
+
justify-content: center;
|
|
229
|
+
width: 16px;
|
|
230
|
+
height: 16px;
|
|
231
|
+
font-size: 12px;
|
|
232
|
+
font-weight: 600;
|
|
233
|
+
color: var(--color-primary);
|
|
234
|
+
background-color: var(--color-primary-light-8);
|
|
235
|
+
border-radius: 4px;
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
&__item-text {
|
|
239
|
+
font-size: 14px;
|
|
240
|
+
color: var(--color-text-regular);
|
|
241
|
+
}
|
|
242
|
+
|
|
243
|
+
&.is-active .mix-top-menu__item-text {
|
|
244
|
+
color: var(--color-primary);
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
&__actions {
|
|
248
|
+
display: flex;
|
|
249
|
+
align-items: center;
|
|
250
|
+
gap: 8px;
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
</style>
|
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
<script setup lang="ts">
|
|
2
|
-
import { computed } from 'vue'
|
|
2
|
+
import { computed, watch } from 'vue'
|
|
3
|
+
import { useRoute } from 'vue-router'
|
|
3
4
|
import { useAppStore } from '@/stores/app'
|
|
4
5
|
import { useMenuStore } from '@/stores/menu'
|
|
5
6
|
import Sidebar from './Sidebar.vue'
|
|
6
7
|
import Header from './Header.vue'
|
|
7
8
|
import TopMenu from './TopMenu.vue'
|
|
9
|
+
import MixTopMenu from './MixTopMenu.vue'
|
|
8
10
|
|
|
11
|
+
const route = useRoute()
|
|
9
12
|
const appStore = useAppStore()
|
|
10
13
|
const menuStore = useMenuStore()
|
|
11
14
|
|
|
@@ -16,41 +19,110 @@ const sidebarWidth = computed(() =>
|
|
|
16
19
|
// 布局模式
|
|
17
20
|
const layoutMode = computed(() => appStore.layout)
|
|
18
21
|
|
|
19
|
-
//
|
|
20
|
-
const showSidebar = computed(() =>
|
|
22
|
+
// 是否显示左侧菜单(sidebar模式始终显示,mix模式根据一级菜单是否有子菜单决定)
|
|
23
|
+
const showSidebar = computed(() => {
|
|
24
|
+
if (layoutMode.value === 'sidebar') return true
|
|
25
|
+
if (layoutMode.value === 'mix') {
|
|
26
|
+
// 混合模式:有选中的一级菜单且该菜单有子菜单时显示
|
|
27
|
+
return mixSubMenus.value.length > 0
|
|
28
|
+
}
|
|
29
|
+
return false
|
|
30
|
+
})
|
|
21
31
|
|
|
22
|
-
//
|
|
32
|
+
// 是否显示顶部菜单(仅 top 模式)
|
|
23
33
|
const showTopMenu = computed(() => layoutMode.value === 'top')
|
|
24
34
|
|
|
25
|
-
//
|
|
35
|
+
// 混合模式下当前选中一级菜单的子菜单
|
|
26
36
|
const mixSubMenus = computed(() => {
|
|
27
37
|
if (layoutMode.value !== 'mix') return menuStore.menuList
|
|
28
|
-
|
|
29
|
-
//
|
|
30
|
-
|
|
38
|
+
|
|
39
|
+
// 找到当前选中的一级菜单
|
|
40
|
+
const topMenuPath = appStore.activeTopMenuPath
|
|
41
|
+
if (!topMenuPath) return []
|
|
42
|
+
|
|
43
|
+
const topMenu = menuStore.menuList.find(m => m.menuUrl === topMenuPath)
|
|
44
|
+
return topMenu?.children || []
|
|
31
45
|
})
|
|
46
|
+
|
|
47
|
+
// 根据当前路由自动设置一级菜单选中状态
|
|
48
|
+
watch(
|
|
49
|
+
() => route.path,
|
|
50
|
+
(path) => {
|
|
51
|
+
if (layoutMode.value === 'mix' && menuStore.menuList.length > 0) {
|
|
52
|
+
// 找到当前路由所属的一级菜单
|
|
53
|
+
for (const menu of menuStore.menuList) {
|
|
54
|
+
if (menu.menuUrl === path) {
|
|
55
|
+
// 直接是一级菜单
|
|
56
|
+
if (!appStore.activeTopMenuPath || appStore.activeTopMenuPath !== menu.menuUrl) {
|
|
57
|
+
appStore.setActiveTopMenuPath(menu.menuUrl)
|
|
58
|
+
}
|
|
59
|
+
break
|
|
60
|
+
}
|
|
61
|
+
// 检查是否是该一级菜单的子菜单
|
|
62
|
+
if (menu.children && menu.children.length > 0) {
|
|
63
|
+
const found = menu.children.some(child =>
|
|
64
|
+
child.menuUrl === path ||
|
|
65
|
+
(child.children && child.children.some(c => c.menuUrl === path))
|
|
66
|
+
)
|
|
67
|
+
if (found) {
|
|
68
|
+
if (!appStore.activeTopMenuPath || appStore.activeTopMenuPath !== menu.menuUrl) {
|
|
69
|
+
appStore.setActiveTopMenuPath(menu.menuUrl)
|
|
70
|
+
}
|
|
71
|
+
break
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
},
|
|
77
|
+
{ immediate: true }
|
|
78
|
+
)
|
|
32
79
|
</script>
|
|
33
80
|
|
|
34
81
|
<template>
|
|
35
82
|
<div class="layout" :class="`layout--${layoutMode}`">
|
|
36
|
-
<!--
|
|
37
|
-
<
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
83
|
+
<!-- 混合菜单模式 -->
|
|
84
|
+
<template v-if="layoutMode === 'mix'">
|
|
85
|
+
<!-- 混合模式顶部菜单(一级菜单) -->
|
|
86
|
+
<MixTopMenu />
|
|
87
|
+
|
|
88
|
+
<!-- 混合模式主体区域 -->
|
|
89
|
+
<div class="layout__mix-body">
|
|
90
|
+
<!-- 左侧子菜单 -->
|
|
91
|
+
<aside v-if="mixSubMenus.length > 0" class="layout__aside" :style="{ width: sidebarWidth }">
|
|
92
|
+
<Sidebar :menu-list="mixSubMenus" />
|
|
93
|
+
</aside>
|
|
94
|
+
|
|
95
|
+
<!-- 主内容区 -->
|
|
96
|
+
<div class="layout__main">
|
|
97
|
+
<header class="layout__header">
|
|
98
|
+
<Header />
|
|
99
|
+
</header>
|
|
100
|
+
<main class="layout__content">
|
|
101
|
+
<router-view />
|
|
102
|
+
</main>
|
|
103
|
+
</div>
|
|
104
|
+
</div>
|
|
105
|
+
</template>
|
|
106
|
+
|
|
107
|
+
<!-- 其他布局模式 -->
|
|
108
|
+
<template v-else>
|
|
109
|
+
<!-- 左侧菜单布局 -->
|
|
110
|
+
<aside v-if="showSidebar" class="layout__aside" :style="{ width: sidebarWidth }">
|
|
111
|
+
<Sidebar :menu-list="menuStore.menuList" />
|
|
112
|
+
</aside>
|
|
113
|
+
|
|
114
|
+
<!-- 顶部菜单布局(top 模式) -->
|
|
115
|
+
<TopMenu v-if="showTopMenu" />
|
|
116
|
+
|
|
117
|
+
<div class="layout__main">
|
|
118
|
+
<header class="layout__header">
|
|
119
|
+
<Header />
|
|
120
|
+
</header>
|
|
121
|
+
<main class="layout__content">
|
|
122
|
+
<router-view />
|
|
123
|
+
</main>
|
|
124
|
+
</div>
|
|
125
|
+
</template>
|
|
54
126
|
</div>
|
|
55
127
|
</template>
|
|
56
128
|
|
|
@@ -80,7 +152,21 @@ const mixSubMenus = computed(() => {
|
|
|
80
152
|
|
|
81
153
|
// 混合菜单模式
|
|
82
154
|
&--mix {
|
|
83
|
-
flex-direction:
|
|
155
|
+
flex-direction: column;
|
|
156
|
+
|
|
157
|
+
.layout__mix-body {
|
|
158
|
+
display: flex;
|
|
159
|
+
flex: 1;
|
|
160
|
+
overflow: hidden;
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
.layout__aside {
|
|
164
|
+
height: 100%;
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
.layout__main {
|
|
168
|
+
flex: 1;
|
|
169
|
+
}
|
|
84
170
|
}
|
|
85
171
|
|
|
86
172
|
&__aside {
|
|
@@ -98,7 +184,6 @@ const mixSubMenus = computed(() => {
|
|
|
98
184
|
}
|
|
99
185
|
|
|
100
186
|
&__main {
|
|
101
|
-
flex: 1;
|
|
102
187
|
display: flex;
|
|
103
188
|
flex-direction: column;
|
|
104
189
|
overflow: hidden;
|
package/src/stores/app.ts
CHANGED
|
@@ -22,6 +22,8 @@ export const useAppStore = defineStore('app', () => {
|
|
|
22
22
|
const showBreadcrumb = ref<boolean>(local.get<boolean>('showBreadcrumb') ?? true)
|
|
23
23
|
const primaryColor = ref<string>(local.get<string>('primaryColor') || '#409eff')
|
|
24
24
|
const cachedViews = ref<string[]>([])
|
|
25
|
+
// 混合模式下选中的一级菜单路径
|
|
26
|
+
const activeTopMenuPath = ref<string>(local.get<string>('activeTopMenuPath') || '')
|
|
25
27
|
|
|
26
28
|
// 计算属性
|
|
27
29
|
const themeClass = computed(() => (isDark.value ? 'dark' : 'light'))
|
|
@@ -74,6 +76,17 @@ export const useAppStore = defineStore('app', () => {
|
|
|
74
76
|
const setLayout = (mode: LayoutMode) => {
|
|
75
77
|
layout.value = mode
|
|
76
78
|
local.set('layout', mode)
|
|
79
|
+
// 切换布局时清除一级菜单选中状态
|
|
80
|
+
if (mode !== 'mix') {
|
|
81
|
+
activeTopMenuPath.value = ''
|
|
82
|
+
local.remove('activeTopMenuPath')
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// 设置混合模式选中的一级菜单
|
|
87
|
+
const setActiveTopMenuPath = (path: string) => {
|
|
88
|
+
activeTopMenuPath.value = path
|
|
89
|
+
local.set('activeTopMenuPath', path)
|
|
77
90
|
}
|
|
78
91
|
|
|
79
92
|
// 切换标签页
|
|
@@ -144,6 +157,7 @@ export const useAppStore = defineStore('app', () => {
|
|
|
144
157
|
showBreadcrumb,
|
|
145
158
|
primaryColor,
|
|
146
159
|
cachedViews,
|
|
160
|
+
activeTopMenuPath,
|
|
147
161
|
themeClass,
|
|
148
162
|
setAppName,
|
|
149
163
|
setIndexPath,
|
|
@@ -151,6 +165,7 @@ export const useAppStore = defineStore('app', () => {
|
|
|
151
165
|
toggleCollapse,
|
|
152
166
|
setTheme,
|
|
153
167
|
setLayout,
|
|
168
|
+
setActiveTopMenuPath,
|
|
154
169
|
toggleTabs,
|
|
155
170
|
toggleFooter,
|
|
156
171
|
toggleBreadcrumb,
|