Files
CoreInject/frontend/dist/assets/BwNN0oka.css
QiuChenly 8394c93e6c 性能优化、错误修复
### 后端更新

性能优化
- Redis、数据库索引优化, 复杂联表查询查询速度从10秒降低到500ms

功能增强
- 统一文件上传 API
- 论坛权限管理优化

### 前端更新

问题修复
- 统一错误提示、组件复用、图标本地化、密码加密传输、大文件分片上传

新增功能
- 全局通知系统、WebSocket 实时消息、图标批量同步、IP 封禁管理、应用版本批量查询、头像上传、TypeScript 类型完善、讨论区功能增强

代码优化
- 删除冗余组件、统一 API 错误处理、优化代码结构、统一 UI 风格
2025-11-13 03:02:01 +08:00

2 lines
17 KiB
CSS

@charset "UTF-8";@keyframes titleGradient-47770ede{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.profile-page[data-v-47770ede]{margin:-32px -40px;padding:32px 40px;width:calc(100% + 80px);min-height:calc(100% + 64px);box-sizing:border-box;background:transparent}.profile-hero[data-v-47770ede]{position:relative;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-hover) 100%);border-radius:var(--radius-xl);margin-bottom:var(--spacing-xl);overflow:hidden;box-shadow:0 8px 24px #0000001f}.profile-hero .hero-background[data-v-47770ede]{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 50%);opacity:.5}.profile-hero .hero-content[data-v-47770ede]{position:relative;display:flex;align-items:center;gap:var(--spacing-xl);padding:var(--spacing-xl) var(--spacing-2xl);color:#fff}.profile-hero .hero-content .user-avatar-large[data-v-47770ede]{flex-shrink:0;width:120px;height:120px;border:4px solid rgba(255,255,255,.3);border-radius:50%;overflow:hidden;box-shadow:0 4px 16px #0003;display:flex;align-items:center;justify-content:center}.profile-hero .hero-content .user-avatar-large[data-v-47770ede] .avatar-wrapper{width:100%!important;height:100%!important;min-width:100%!important;min-height:100%!important;max-width:100%!important;max-height:100%!important;border:none!important;border-radius:50%!important}.profile-hero .hero-content .user-info-main[data-v-47770ede]{flex:1;min-width:0}.profile-hero .hero-content .user-info-main .user-name[data-v-47770ede]{font-size:2rem;font-weight:700;margin:0 0 var(--spacing-xs) 0;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-hero .hero-content .user-info-main .user-username[data-v-47770ede]{font-size:1rem;margin:0 0 var(--spacing-md) 0;color:#fffc}.profile-hero .hero-content .user-info-main .user-badges[data-v-47770ede]{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.profile-hero .hero-content .hero-actions[data-v-47770ede]{display:flex;gap:var(--spacing-sm);flex-shrink:0}.profile-content[data-v-47770ede]{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--spacing-lg)}.info-card[data-v-47770ede]{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:0 2px 8px #0000000a;border:1px solid var(--border-light);transition:all .2s ease}.info-card[data-v-47770ede]:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.card-header[data-v-47770ede]{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.card-header .card-icon[data-v-47770ede]{font-size:1.5rem;color:var(--primary-color)}.card-header h2[data-v-47770ede]{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.card-content .info-grid[data-v-47770ede]{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.card-content .info-item[data-v-47770ede]{display:flex;align-items:flex-start;gap:var(--spacing-md)}.card-content .info-item .info-icon[data-v-47770ede]{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:var(--radius-md);color:var(--primary-color)}.card-content .info-item .info-icon[data-v-47770ede] svg{font-size:20px}.card-content .info-item .info-content[data-v-47770ede]{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.card-content .info-item .info-content .label[data-v-47770ede]{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.card-content .info-item .info-content .value[data-v-47770ede]{font-size:1rem;color:var(--text-primary);font-weight:500;word-break:break-word}.role-badge[data-v-47770ede]{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:24px;font-size:.875rem;font-weight:500;color:#fff;transition:all .3s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 2px 8px #0000001a}.role-badge[data-v-47770ede] svg{font-size:16px;opacity:1}.role-badge span[data-v-47770ede]{line-height:1}.role-badge.role-user[data-v-47770ede]{background:linear-gradient(135deg,#fff3,#ffffff26);border:1px solid rgba(255,255,255,.25)}.role-badge.role-admin[data-v-47770ede]{background:linear-gradient(135deg,#6366f166,#4f46e54d);border:1px solid rgba(99,102,241,.5);box-shadow:0 2px 12px #6366f14d}.role-badge.role-super[data-v-47770ede]{background:linear-gradient(135deg,#fbbf2480,#f59e0b66);border:1px solid rgba(251,191,36,.6);box-shadow:0 4px 16px #fbbf2466}.role-badge.role-super[data-v-47770ede] svg{filter:drop-shadow(0 0 4px rgba(255,255,255,.5))}.role-badge[data-v-47770ede]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.status-badge[data-v-47770ede]{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:24px;font-size:.875rem;font-weight:500;color:#fff;transition:all .3s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 2px 8px #0000001a}.status-badge span[data-v-47770ede]{line-height:1}.status-badge .status-dot[data-v-47770ede]{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px currentColor}.status-badge.active[data-v-47770ede]{background:linear-gradient(135deg,#22c55e66,#16a34a4d);border:1px solid rgba(34,197,94,.5);box-shadow:0 2px 12px #22c55e4d}.status-badge.active .status-dot[data-v-47770ede]{background:#22c55e;box-shadow:0 0 12px #22c55ecc}.status-badge.inactive[data-v-47770ede]{background:linear-gradient(135deg,#ef444466,#dc26264d);border:1px solid rgba(239,68,68,.5);box-shadow:0 2px 12px #ef44444d}.status-badge.inactive .status-dot[data-v-47770ede]{background:#ef4444;box-shadow:0 0 12px #ef4444cc}.status-badge[data-v-47770ede]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.titles-list[data-v-47770ede]{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.title-badge[data-v-47770ede]{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;background:linear-gradient(135deg,rgba(var(--primary-rgb),.1),rgba(var(--primary-rgb),.15));color:var(--primary-color);border:1px solid rgba(var(--primary-rgb),.2);transition:all .2s ease}.title-badge[data-v-47770ede]:hover{background:linear-gradient(135deg,rgba(var(--primary-rgb),.15),rgba(var(--primary-rgb),.2));transform:translateY(-2px);box-shadow:0 4px 8px rgba(var(--primary-rgb),.2)}.title-badge[data-v-47770ede] svg{font-size:16px}.devices-grid[data-v-47770ede]{display:flex;gap:var(--spacing-md);overflow-x:auto;overflow-y:visible;padding-top:var(--spacing-xs);padding-bottom:var(--spacing-xs);scrollbar-width:thin;scrollbar-color:var(--border-light) transparent}.devices-grid[data-v-47770ede]::-webkit-scrollbar{height:6px}.devices-grid[data-v-47770ede]::-webkit-scrollbar-track{background:transparent;border-radius:3px}.devices-grid[data-v-47770ede]::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.devices-grid[data-v-47770ede]::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.device-card[data-v-47770ede]{position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);transition:all .2s ease;text-align:center;width:240px;height:220px;flex-shrink:0}.device-card[data-v-47770ede]:hover{background:var(--bg-card);border-color:var(--primary-color);transform:translateY(-4px);box-shadow:0 8px 16px #00000014}.device-card:hover .device-actions[data-v-47770ede]{opacity:1;visibility:visible}.device-card .device-icon[data-v-47770ede]{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(var(--primary-rgb),.1),rgba(var(--primary-rgb),.2));border-radius:var(--radius-lg);color:var(--primary-color)}.device-card .device-icon[data-v-47770ede] svg{font-size:32px}.device-card .device-actions[data-v-47770ede]{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);display:flex;gap:var(--spacing-xs);opacity:0;visibility:hidden;transition:all .2s ease}.device-card .device-info[data-v-47770ede]{flex:1;width:100%}.device-card .device-info .device-name[data-v-47770ede]{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0}.device-card .device-info .device-details[data-v-47770ede]{font-size:.875rem;color:var(--text-secondary);margin:0 0 var(--spacing-xs) 0}.device-card .device-info .device-spec[data-v-47770ede]{font-size:.75rem;color:var(--text-tertiary);margin:0}.empty-devices[data-v-47770ede]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--text-tertiary);text-align:center}.empty-devices .empty-icon[data-v-47770ede]{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.empty-devices p[data-v-47770ede]{margin:0;font-size:.875rem}.device-actions-footer[data-v-47770ede]{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.btn-action[data-v-47770ede]{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-action.btn-primary[data-v-47770ede]{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.btn-action.btn-primary[data-v-47770ede]:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.btn-action.btn-secondary[data-v-47770ede]{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.2)}.btn-action.btn-secondary[data-v-47770ede]:hover{background:#ffffff40;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.btn-action[data-v-47770ede] svg{font-size:18px}.table-container[data-v-47770ede]{margin-top:var(--spacing-lg)}.table-header[data-v-47770ede]{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);gap:var(--spacing-md)}.table-header .search-box[data-v-47770ede]{flex:1;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md)}.table-header .search-box input[data-v-47770ede]{flex:1;border:none;background:transparent;color:var(--text-primary);outline:none}.tabs[data-v-47770ede]{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--border-light)}.tabs .tab-button[data-v-47770ede]{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-lg);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.tabs .tab-button[data-v-47770ede]:hover{color:var(--text-primary)}.tabs .tab-button.active[data-v-47770ede]{color:var(--primary-color);border-bottom-color:var(--primary-color)}.data-table[data-v-47770ede]{width:100%;border-collapse:collapse}.data-table thead[data-v-47770ede]{background:var(--bg-secondary)}.data-table th[data-v-47770ede],.data-table td[data-v-47770ede]{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-light)}.data-table th[data-v-47770ede]{font-weight:600;color:var(--text-primary);font-size:.875rem}.data-table td[data-v-47770ede]{color:var(--text-secondary)}.data-table .actions[data-v-47770ede]{display:flex;gap:var(--spacing-xs)}.btn[data-v-47770ede]{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .2s ease}.btn.btn-primary[data-v-47770ede]{background:var(--primary-color);color:#fff}.btn.btn-primary[data-v-47770ede]:hover{background:var(--primary-hover)}.btn.btn-secondary[data-v-47770ede]{background:var(--bg-secondary);color:var(--text-primary)}.btn.btn-secondary[data-v-47770ede]:hover{background:var(--bg-hover)}.btn.btn-sm[data-v-47770ede]{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem}.btn[data-v-47770ede]:disabled{opacity:.5;cursor:not-allowed}.btn-icon[data-v-47770ede]{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.btn-icon[data-v-47770ede]:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--primary-color)}.btn-icon.danger[data-v-47770ede]:hover{color:var(--error-color);border-color:var(--error-color)}.pagination[data-v-47770ede]{display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding:var(--spacing-md)}.loading[data-v-47770ede],.error[data-v-47770ede]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--text-secondary)}.loading .spinner[data-v-47770ede],.error .spinner[data-v-47770ede]{width:40px;height:40px;border:3px solid var(--border-light);border-top-color:var(--primary-color);border-radius:50%;animation:spin-47770ede 1s linear infinite}@keyframes spin-47770ede{to{transform:rotate(360deg)}}.modal-overlay[data-v-47770ede]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000}.modal-dialog[data-v-47770ede]{background:var(--bg-card);border-radius:var(--radius-lg);width:90%;max-width:500px;box-shadow:0 20px 60px #0000004d}.modal-header[data-v-47770ede]{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-light)}.modal-header h3[data-v-47770ede]{margin:0;font-size:1.25rem;font-weight:600}.modal-header .close-btn[data-v-47770ede]{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs)}.modal-content[data-v-47770ede]{padding:var(--spacing-lg)}.modal-content .form-group[data-v-47770ede]{margin-bottom:var(--spacing-md)}.modal-content .form-group label[data-v-47770ede]{display:block;margin-bottom:var(--spacing-xs);font-size:.875rem;font-weight:500;color:var(--text-primary)}.modal-content .form-group .form-select[data-v-47770ede]{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;outline:none;transition:all .2s ease}.modal-content .form-group .form-select[data-v-47770ede]:focus{border-color:var(--primary-color);background:var(--bg-card)}.modal-content .form-group .form-select option[data-v-47770ede]{background:var(--bg-card);color:var(--text-primary)}.modal-content .form-group input[data-v-47770ede]{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;outline:none;transition:all .2s ease}.modal-content .form-group input[data-v-47770ede]:focus{border-color:var(--primary-color);background:var(--bg-card)}.modal-content .form-group input[data-v-47770ede]:disabled{opacity:.6;cursor:not-allowed}.modal-footer[data-v-47770ede]{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--border-light)}.avatar-section-wrapper[data-v-47770ede]{display:flex;justify-content:center;margin-bottom:var(--spacing-lg)}.devices-list[data-v-47770ede]{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.device-item[data-v-47770ede]{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all .2s ease}.device-item[data-v-47770ede]:hover{background:var(--bg-card);border-color:var(--primary-color);box-shadow:0 2px 8px #0000000d}.device-item .device-info[data-v-47770ede]{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1}.device-item .device-info .device-name[data-v-47770ede]{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0}.device-item .device-info .device-details[data-v-47770ede]{font-size:.75rem;color:var(--text-secondary);margin:0}.device-item .device-actions[data-v-47770ede]{display:flex;gap:var(--spacing-xs)}.profile-edit-dialog[data-v-47770ede]{max-width:500px}