xto-fronted 0.4.4 → 0.4.5

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-abf8c2be]{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-abf8c2be]{justify-content:center;padding:0}.sidebar__logo[data-v-abf8c2be]{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-abf8c2be]{width:32px;height:32px}.sidebar__logo-text[data-v-abf8c2be]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__menu[data-v-abf8c2be]{flex:1;border-right:none;overflow-y:auto}.sidebar__user[data-v-abf8c2be]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-abf8c2be]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-abf8c2be]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-abf8c2be]{font-size:12px;color:var(--color-text-secondary)}.header[data-v-de94213f]{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-de94213f]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-de94213f]{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-de94213f]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-de94213f]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-de94213f]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-de94213f]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-de94213f]{display:flex;align-items:center;gap:8px}.header__action[data-v-de94213f]{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-de94213f]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-de94213f]{position:relative;margin-left:8px}.header__user-trigger[data-v-de94213f]{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-de94213f]:hover{background-color:var(--color-fill)}.header__user-name[data-v-de94213f]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-de94213f]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-de94213f]{transform:rotate(180deg)}.header__avatar[data-v-de94213f]{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-de94213f]{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-de94213f]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-de94213f]{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-de94213f]{flex:1}.header__dropdown-name[data-v-de94213f]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-de94213f]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-de94213f]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-de94213f]{padding:8px 0}.header__dropdown-item[data-v-de94213f]{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-de94213f]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-de94213f]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-de94213f]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.header__search-modal[data-v-de94213f]{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-de94213f]{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-de94213f]{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border-lighter)}.search-input-wrapper .search-icon[data-v-de94213f]{color:var(--color-text-secondary);margin-right:12px}.search-input-wrapper .search-input[data-v-de94213f]{flex:1;font-size:16px;color:var(--color-text-primary);background:transparent;border:none;outline:none}.search-input-wrapper .search-input[data-v-de94213f]::placeholder{color:var(--color-text-placeholder)}.search-input-wrapper .search-shortcut[data-v-de94213f]{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-de94213f]{max-height:400px;overflow-y:auto;padding:8px 0}.search-result-item[data-v-de94213f]{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:background-color .2s}.search-result-item[data-v-de94213f]:hover{background-color:var(--color-fill)}.search-result-item.is-first[data-v-de94213f]{background-color:var(--color-primary-light-9)}.search-result-item .search-result-icon[data-v-de94213f]{color:var(--color-text-secondary)}.search-result-item .search-result-info[data-v-de94213f]{flex:1;display:flex;flex-direction:column;gap:2px}.search-result-item .search-result-title[data-v-de94213f]{font-size:14px;color:var(--color-text-primary)}.search-result-item .search-result-parent[data-v-de94213f]{font-size:12px;color:var(--color-text-secondary)}.search-empty[data-v-de94213f]{padding:40px 20px;text-align:center;color:var(--color-text-secondary);font-size:14px}.settings-drawer .settings-section[data-v-de94213f]{margin-bottom:24px}.settings-drawer .settings-title[data-v-de94213f]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-de94213f]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-de94213f]{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-de94213f]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-de94213f]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-de94213f]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-de94213f]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-de94213f]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-de94213f]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-de94213f]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-de94213f]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-de94213f]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-de94213f]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-de94213f]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-de94213f]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-de94213f]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-de94213f]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-de94213f]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-de94213f]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-de94213f]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-de94213f]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-de94213f]{display:flex;gap:12px}.settings-drawer .color-option[data-v-de94213f]{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-de94213f]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-de94213f]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-de94213f]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-de94213f]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-de94213f]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-de94213f]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-de94213f]{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-de94213f]: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-de94213f]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-de94213f]:after{left:24px}.dropdown-enter-active[data-v-de94213f],.dropdown-leave-active[data-v-de94213f]{transition:all .2s ease}.dropdown-enter-from[data-v-de94213f],.dropdown-leave-to[data-v-de94213f]{opacity:0;transform:translateY(-10px)}.search-enter-active[data-v-de94213f],.search-leave-active[data-v-de94213f]{transition:all .2s ease}.search-enter-from[data-v-de94213f],.search-leave-to[data-v-de94213f]{opacity:0}:root.grey-mode[data-v-de94213f]{filter:grayscale(100%)}.layout[data-v-a3110011]{display:flex;width:100%;height:100%}.layout__aside[data-v-a3110011]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__main[data-v-a3110011]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-a3110011]{height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-a3110011]{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-ed827d66]{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-ed827d66]{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-ed827d66]{text-align:center;margin-bottom:30px}.login__logo[data-v-ed827d66]{width:60px;height:60px}.login__title[data-v-ed827d66]{font-size:28px;font-weight:600;color:var(--color-primary);margin:15px 0 5px}.login__subtitle[data-v-ed827d66]{font-size:14px;color:var(--color-text-secondary)}.login__form[data-v-ed827d66] .x-form-item{margin-bottom:20px}.login__form[data-v-ed827d66] .x-input__prefix{margin-right:8px}.login__submit[data-v-ed827d66]{width:100%}.login__footer[data-v-ed827d66]{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-abf8c2be]{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-abf8c2be]{justify-content:center;padding:0}.sidebar__logo[data-v-abf8c2be]{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-abf8c2be]{width:32px;height:32px}.sidebar__logo-text[data-v-abf8c2be]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__menu[data-v-abf8c2be]{flex:1;border-right:none;overflow-y:auto}.sidebar__user[data-v-abf8c2be]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-abf8c2be]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-abf8c2be]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-abf8c2be]{font-size:12px;color:var(--color-text-secondary)}.header[data-v-de94213f]{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-de94213f]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-de94213f]{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-de94213f]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-de94213f]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-de94213f]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-de94213f]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-de94213f]{display:flex;align-items:center;gap:8px}.header__action[data-v-de94213f]{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-de94213f]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-de94213f]{position:relative;margin-left:8px}.header__user-trigger[data-v-de94213f]{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-de94213f]:hover{background-color:var(--color-fill)}.header__user-name[data-v-de94213f]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-de94213f]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-de94213f]{transform:rotate(180deg)}.header__avatar[data-v-de94213f]{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-de94213f]{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-de94213f]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-de94213f]{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-de94213f]{flex:1}.header__dropdown-name[data-v-de94213f]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-de94213f]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-de94213f]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-de94213f]{padding:8px 0}.header__dropdown-item[data-v-de94213f]{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-de94213f]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-de94213f]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-de94213f]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.header__search-modal[data-v-de94213f]{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-de94213f]{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-de94213f]{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border-lighter)}.search-input-wrapper .search-icon[data-v-de94213f]{color:var(--color-text-secondary);margin-right:12px}.search-input-wrapper .search-input[data-v-de94213f]{flex:1;font-size:16px;color:var(--color-text-primary);background:transparent;border:none;outline:none}.search-input-wrapper .search-input[data-v-de94213f]::placeholder{color:var(--color-text-placeholder)}.search-input-wrapper .search-shortcut[data-v-de94213f]{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-de94213f]{max-height:400px;overflow-y:auto;padding:8px 0}.search-result-item[data-v-de94213f]{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:background-color .2s}.search-result-item[data-v-de94213f]:hover{background-color:var(--color-fill)}.search-result-item.is-first[data-v-de94213f]{background-color:var(--color-primary-light-9)}.search-result-item .search-result-icon[data-v-de94213f]{color:var(--color-text-secondary)}.search-result-item .search-result-info[data-v-de94213f]{flex:1;display:flex;flex-direction:column;gap:2px}.search-result-item .search-result-title[data-v-de94213f]{font-size:14px;color:var(--color-text-primary)}.search-result-item .search-result-parent[data-v-de94213f]{font-size:12px;color:var(--color-text-secondary)}.search-empty[data-v-de94213f]{padding:40px 20px;text-align:center;color:var(--color-text-secondary);font-size:14px}.settings-drawer .settings-section[data-v-de94213f]{margin-bottom:24px}.settings-drawer .settings-title[data-v-de94213f]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-de94213f]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-de94213f]{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-de94213f]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-de94213f]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-de94213f]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-de94213f]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-de94213f]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-de94213f]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-de94213f]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-de94213f]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-de94213f]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-de94213f]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-de94213f]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-de94213f]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-de94213f]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-de94213f]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-de94213f]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-de94213f]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-de94213f]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-de94213f]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-de94213f]{display:flex;gap:12px}.settings-drawer .color-option[data-v-de94213f]{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-de94213f]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-de94213f]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-de94213f]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-de94213f]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-de94213f]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-de94213f]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-de94213f]{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-de94213f]: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-de94213f]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-de94213f]:after{left:24px}.dropdown-enter-active[data-v-de94213f],.dropdown-leave-active[data-v-de94213f]{transition:all .2s ease}.dropdown-enter-from[data-v-de94213f],.dropdown-leave-to[data-v-de94213f]{opacity:0;transform:translateY(-10px)}.search-enter-active[data-v-de94213f],.search-leave-active[data-v-de94213f]{transition:all .2s ease}.search-enter-from[data-v-de94213f],.search-leave-to[data-v-de94213f]{opacity:0}:root.grey-mode[data-v-de94213f]{filter:grayscale(100%)}.layout[data-v-a3110011]{display:flex;width:100%;height:100%}.layout__aside[data-v-a3110011]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__main[data-v-a3110011]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-a3110011]{height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-a3110011]{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-f8d69f9f]{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-f8d69f9f]{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-f8d69f9f]{text-align:center;margin-bottom:30px}.login__logo[data-v-f8d69f9f]{width:60px;height:60px}.login__title[data-v-f8d69f9f]{font-size:28px;font-weight:600;color:var(--color-primary);margin:15px 0 5px}.login__subtitle[data-v-f8d69f9f]{font-size:14px;color:var(--color-text-secondary)}.login__form[data-v-f8d69f9f] .x-form-item{margin-bottom:20px}.login__form[data-v-f8d69f9f] .x-input__prefix{margin-right:8px}.login__submit[data-v-f8d69f9f]{width:100%}.login__footer[data-v-f8d69f9f]{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}
@@ -0,0 +1,30 @@
1
+ /**
2
+ * 应用配置(动态设置,避免 import.meta.env 静态替换)
3
+ */
4
+ /**
5
+ * 初始化应用配置
6
+ * 在项目入口文件(main.ts)中调用此函数设置配置
7
+ */
8
+ export declare function initAppConfig(config: {
9
+ appId?: string;
10
+ clientId?: string;
11
+ apiBaseUrl?: string;
12
+ }): void;
13
+ /**
14
+ * 获取 AppId
15
+ * 优先使用动态配置,其次使用环境变量
16
+ */
17
+ export declare function getAppId(): string;
18
+ /**
19
+ * 获取 ClientId
20
+ */
21
+ export declare function getClientId(): string;
22
+ /**
23
+ * 获取 API 基础路径
24
+ */
25
+ export declare function getApiBaseUrl(): string;
26
+ export declare const appConfig: {
27
+ appId: import('vue').Ref<string, string>;
28
+ clientId: import('vue').Ref<string, string>;
29
+ apiBaseUrl: import('vue').Ref<string, string>;
30
+ };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "xto-fronted",
3
- "version": "0.4.4",
3
+ "version": "0.4.5",
4
4
  "private": false,
5
5
  "type": "module",
6
6
  "description": "XTO 前端应用框架",
package/src/api/system.ts CHANGED
@@ -4,6 +4,7 @@
4
4
 
5
5
  import { http, type PageParams, type PageResponse } from '@/utils/request'
6
6
  import type { RoleInfo, MenuItem } from '@/types/api'
7
+ import { getAppId } from '@/utils/config'
7
8
 
8
9
  // ========== 角色管理 ==========
9
10
 
@@ -46,7 +47,7 @@ export function getMenuList() {
46
47
 
47
48
  // 获取用户菜单(根据 appId)
48
49
  export function getMenuTree(appId?: string) {
49
- const id = appId || import.meta.env.VITE_APP_ID
50
+ const id = appId || getAppId()
50
51
  return http.get<MenuItem[]>(`/user/v1.0/menu/get-menu?appId=${id}`)
51
52
  }
52
53
 
package/src/env.d.ts CHANGED
@@ -10,6 +10,8 @@ interface ImportMetaEnv {
10
10
  readonly VITE_APP_TITLE: string
11
11
  readonly VITE_API_BASE_URL: string
12
12
  readonly VITE_USE_MOCK: string
13
+ readonly VITE_APP_ID: string
14
+ readonly VITE_APP_CLIENT_ID: string
13
15
  }
14
16
 
15
17
  interface ImportMeta {
package/src/index.ts CHANGED
@@ -21,6 +21,7 @@ export * from './utils/auth'
21
21
  export * from './utils/permission'
22
22
  export * from './utils/request'
23
23
  export * from './utils/storage'
24
+ export * from './utils/config'
24
25
 
25
26
  // Store
26
27
  export * from './stores/app'
@@ -6,6 +6,7 @@ import { createRouter, createWebHistory } from 'vue-router'
6
6
  import { staticRoutes, errorRoute } from './staticRoutes'
7
7
  import { layoutRoute } from './dynamicRoutes'
8
8
  import { hasToken } from '@/utils/auth'
9
+ import { getAppId } from '@/utils/config'
9
10
  import { useUserStore } from '@/stores/user'
10
11
  import { useMenuStore } from '@/stores/menu'
11
12
  import { useAppStore } from '@/stores/app'
@@ -37,7 +38,7 @@ router.beforeEach(async (to, _from, next) => {
37
38
  const userStore = useUserStore()
38
39
  if (!userStore.isLoggedIn) {
39
40
  userStore.setUserInfo({
40
- appId: import.meta.env.VITE_APP_ID,
41
+ appId: getAppId(),
41
42
  userId: '1',
42
43
  userName: '管理员',
43
44
  departmentName: '技术部',
@@ -0,0 +1,81 @@
1
+ /**
2
+ * 应用配置(动态设置,避免 import.meta.env 静态替换)
3
+ */
4
+
5
+ import { ref } from 'vue'
6
+
7
+ // 配置状态
8
+ const appId = ref<string>('')
9
+ const clientId = ref<string>('')
10
+ const apiBaseUrl = ref<string>('')
11
+
12
+ /**
13
+ * 初始化应用配置
14
+ * 在项目入口文件(main.ts)中调用此函数设置配置
15
+ */
16
+ export function initAppConfig(config: {
17
+ appId?: string
18
+ clientId?: string
19
+ apiBaseUrl?: string
20
+ }) {
21
+ if (config.appId) {
22
+ appId.value = config.appId
23
+ }
24
+ if (config.clientId) {
25
+ clientId.value = config.clientId
26
+ }
27
+ if (config.apiBaseUrl) {
28
+ apiBaseUrl.value = config.apiBaseUrl
29
+ }
30
+ }
31
+
32
+ /**
33
+ * 获取 AppId
34
+ * 优先使用动态配置,其次使用环境变量
35
+ */
36
+ export function getAppId(): string {
37
+ if (appId.value) {
38
+ return appId.value
39
+ }
40
+ // 尝试从环境变量获取(使用方项目构建时会注入)
41
+ try {
42
+ return import.meta.env.VITE_APP_ID || ''
43
+ } catch {
44
+ return ''
45
+ }
46
+ }
47
+
48
+ /**
49
+ * 获取 ClientId
50
+ */
51
+ export function getClientId(): string {
52
+ if (clientId.value) {
53
+ return clientId.value
54
+ }
55
+ try {
56
+ return import.meta.env.VITE_APP_CLIENT_ID || ''
57
+ } catch {
58
+ return ''
59
+ }
60
+ }
61
+
62
+ /**
63
+ * 获取 API 基础路径
64
+ */
65
+ export function getApiBaseUrl(): string {
66
+ if (apiBaseUrl.value) {
67
+ return apiBaseUrl.value
68
+ }
69
+ try {
70
+ return import.meta.env.VITE_API_BASE_URL || ''
71
+ } catch {
72
+ return ''
73
+ }
74
+ }
75
+
76
+ // 导出响应式引用(供特殊场景直接使用)
77
+ export const appConfig = {
78
+ appId,
79
+ clientId,
80
+ apiBaseUrl
81
+ }
@@ -6,6 +6,7 @@ import { Form, FormItem, Input, Checkbox } from '@xto/form'
6
6
  import { Message } from '@xto/feedback'
7
7
  import { login } from '@/api/auth'
8
8
  import { setTokenInfo } from '@/utils/auth'
9
+ import { getAppId, getClientId } from '@/utils/config'
9
10
 
10
11
  const router = useRouter()
11
12
  const route = useRoute()
@@ -38,8 +39,8 @@ const handleLogin = async () => {
38
39
 
39
40
  // 调用登录 API
40
41
  const result = await login({
41
- appId: import.meta.env.VITE_APP_ID,
42
- clientId: import.meta.env.VITE_APP_CLIENT_ID,
42
+ appId: getAppId(),
43
+ clientId: getClientId(),
43
44
  uid: formData.uid,
44
45
  password: formData.password,
45
46
  code: true