Files
CoreInject/frontend/dist/assets/CXAkPYOs.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

.post-detail-page[data-v-f9077bc1]{width:100%;min-height:100%}.page-container[data-v-f9077bc1]{width:100%}.page-header[data-v-f9077bc1]{margin-bottom:24px}.forum-breadcrumb[data-v-f9077bc1]{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding:12px 16px;background:var(--bg-secondary);border-radius:8px;font-size:14px}.forum-info[data-v-f9077bc1]{display:flex;align-items:center;gap:8px;cursor:pointer;transition:all .2s ease;color:var(--text-secondary)}.forum-info[data-v-f9077bc1]:hover{color:var(--primary-color)}.forum-icon-wrapper[data-v-f9077bc1]{flex-shrink:0}.forum-icon[data-v-f9077bc1]{width:24px;height:24px;border-radius:6px;overflow:hidden;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center}.forum-icon img[data-v-f9077bc1]{width:100%;height:100%;object-fit:contain}.forum-icon .icon-placeholder[data-v-f9077bc1]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--text-secondary);background:var(--bg-secondary)}.forum-name[data-v-f9077bc1]{font-weight:500;color:var(--text-primary)}.breadcrumb-separator[data-v-f9077bc1]{font-size:18px;color:var(--text-tertiary);margin:0 4px}.post-breadcrumb-title[data-v-f9077bc1]{flex:1;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-buttons[data-v-f9077bc1]{display:flex;gap:12px;margin-bottom:16px}.back-button[data-v-f9077bc1],.home-button[data-v-f9077bc1]{display:flex;align-items:center;gap:8px;padding:8px 16px;background:transparent;border:1px solid var(--border-light);border-radius:6px;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .2s ease}.back-button[data-v-f9077bc1]:hover,.home-button[data-v-f9077bc1]:hover{color:var(--text-primary);border-color:var(--primary-color);background:var(--bg-secondary)}.back-button .back-icon[data-v-f9077bc1],.back-button .home-icon[data-v-f9077bc1],.home-button .back-icon[data-v-f9077bc1],.home-button .home-icon[data-v-f9077bc1]{font-size:18px}.loading[data-v-f9077bc1],.error[data-v-f9077bc1]{text-align:center;padding:60px 0}.loading .spinner[data-v-f9077bc1],.error .spinner[data-v-f9077bc1]{width:40px;height:40px;border:3px solid var(--border-light);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin-f9077bc1 .8s linear infinite;margin:0 auto 16px}.loading p[data-v-f9077bc1],.error p[data-v-f9077bc1]{color:var(--text-secondary);font-size:14px;margin-bottom:8px}@keyframes spin-f9077bc1{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-icon.spinning[data-v-f9077bc1]{animation:spin-f9077bc1 .8s linear infinite}.post-detail-content[data-v-f9077bc1]{display:flex;flex-direction:column;gap:24px}.post-main[data-v-f9077bc1]{background:var(--bg-card);border:1px solid var(--border-light);border-radius:12px;padding:24px}.post-header[data-v-f9077bc1]{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}.post-title[data-v-f9077bc1]{margin:0 0 12px;font-size:24px;font-weight:600;color:var(--text-primary)}.post-meta[data-v-f9077bc1]{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--text-secondary)}.author-wrapper[data-v-f9077bc1]{display:flex;align-items:center;gap:8px;position:relative}.author-avatar[data-v-f9077bc1]{position:relative;flex-shrink:0;display:flex;align-items:center;justify-content:center}.author-avatar .online-indicator[data-v-f9077bc1]{position:absolute;bottom:0;right:0;width:10px;height:10px;background:var(--success-color);border:2px solid var(--bg-card);border-radius:50%;box-shadow:0 1px 2px #0000001a}.author-avatar.small .online-indicator[data-v-f9077bc1]{width:8px;height:8px;border-width:1.5px}.post-author[data-v-f9077bc1]{font-weight:500;color:var(--text-primary)}.post-author.clickable[data-v-f9077bc1]{cursor:pointer;transition:color .2s ease}.post-author.clickable[data-v-f9077bc1]:hover{color:var(--primary-color);text-decoration:underline}.post-time[data-v-f9077bc1]{color:var(--text-tertiary)}.post-content[data-v-f9077bc1]{margin-bottom:20px;color:var(--text-primary);line-height:1.8;font-size:15px}.post-content p[data-v-f9077bc1]{margin:0 0 16px;white-space:pre-wrap}.post-attachments[data-v-f9077bc1],.reply-attachments[data-v-f9077bc1]{margin-top:16px;display:flex;flex-direction:column;gap:8px}.attachment-item[data-v-f9077bc1]{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-secondary);border-radius:6px;font-size:14px}.attachment-item.clickable[data-v-f9077bc1]{cursor:pointer;transition:all .2s ease}.attachment-item.clickable[data-v-f9077bc1]:hover{background:var(--border-light);transform:translate(2px)}.attachment-icon[data-v-f9077bc1]{font-size:20px;color:var(--text-secondary)}.attachment-name[data-v-f9077bc1]{flex:1;color:var(--text-primary)}.attachment-size[data-v-f9077bc1]{color:var(--text-tertiary);font-size:12px}.attachment-action-icon[data-v-f9077bc1]{font-size:18px;color:var(--primary-color);margin-left:auto;opacity:.7;transition:opacity .2s ease}.attachment-item:hover .attachment-action-icon[data-v-f9077bc1]{opacity:1}.post-actions[data-v-f9077bc1]{display:flex;gap:12px;padding-top:16px;border-top:1px solid var(--border-light)}.action-btn[data-v-f9077bc1]{display:flex;align-items:center;gap:6px;padding:8px 16px;background:transparent;border:1px solid var(--border-light);border-radius:6px;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .2s ease}.action-btn[data-v-f9077bc1]:hover:not(:disabled){color:var(--text-primary);border-color:var(--primary-color);background:var(--bg-secondary)}.action-btn[data-v-f9077bc1]:disabled{opacity:.5;cursor:not-allowed}.action-btn.active[data-v-f9077bc1]{color:var(--primary-color);border-color:var(--primary-color);background:rgba(var(--primary-color-rgb),.1)}.action-btn .action-icon[data-v-f9077bc1]{font-size:18px}.replies-section[data-v-f9077bc1]{background:var(--bg-card);border:1px solid var(--border-light);border-radius:12px;padding:24px}.replies-header[data-v-f9077bc1]{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}.replies-header h2[data-v-f9077bc1]{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.replies-list[data-v-f9077bc1]{display:flex;flex-direction:column;gap:16px}.reply-form-container[data-v-f9077bc1]{margin-bottom:24px;padding:16px;background:var(--bg-secondary);border-radius:8px}.reply-form[data-v-f9077bc1]{display:flex;gap:12px}.form-avatar[data-v-f9077bc1]{flex-shrink:0}.avatar-placeholder[data-v-f9077bc1]{width:40px;height:40px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.form-content[data-v-f9077bc1]{flex:1}.reply-textarea[data-v-f9077bc1]{width:100%;padding:12px;border:1px solid var(--border-light);border-radius:8px;background:var(--bg-card);color:var(--text-primary);font-size:14px;font-family:inherit;resize:vertical;min-height:80px;margin-bottom:12px}.reply-textarea[data-v-f9077bc1]:focus{outline:none;border-color:var(--primary-color)}.reply-textarea[data-v-f9077bc1]::placeholder{color:var(--text-tertiary)}.form-actions[data-v-f9077bc1]{display:flex;justify-content:space-between;align-items:center;gap:12px}.upload-area[data-v-f9077bc1]{display:flex;align-items:center;gap:8px}.upload-btn[data-v-f9077bc1]{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid var(--border-light);border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s ease}.upload-btn[data-v-f9077bc1]:hover:not(:disabled){color:var(--text-primary);border-color:var(--primary-color);background:var(--bg-secondary)}.upload-btn[data-v-f9077bc1]:disabled{opacity:.5;cursor:not-allowed}.upload-btn.small[data-v-f9077bc1]{padding:4px 8px;font-size:12px}.upload-btn .btn-icon[data-v-f9077bc1]{font-size:16px}.upload-count[data-v-f9077bc1]{font-size:12px;color:var(--text-tertiary)}.submit-reply-btn[data-v-f9077bc1]{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--primary-color);border:none;border-radius:6px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.submit-reply-btn[data-v-f9077bc1]:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.submit-reply-btn[data-v-f9077bc1]:disabled{opacity:.5;cursor:not-allowed}.submit-reply-btn.small[data-v-f9077bc1]{padding:6px 12px;font-size:13px}.submit-reply-btn .btn-icon[data-v-f9077bc1]{font-size:16px}.attachment-preview-list[data-v-f9077bc1]{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.attachment-preview-item[data-v-f9077bc1]{position:relative;width:80px;height:80px;border-radius:6px;overflow:hidden;background:var(--bg-secondary)}.attachment-preview-item img[data-v-f9077bc1]{width:100%;height:100%;object-fit:cover}.attachment-preview-item.file[data-v-f9077bc1]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;width:auto;height:auto;min-width:120px}.attachment-preview-item.file .file-icon[data-v-f9077bc1]{font-size:24px;color:var(--text-secondary);margin-bottom:4px}.attachment-preview-item.file .file-name[data-v-f9077bc1]{font-size:11px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100px}.attachment-preview-item.file .file-size[data-v-f9077bc1]{font-size:10px;color:var(--text-tertiary)}.remove-attachment-btn[data-v-f9077bc1]{position:absolute;top:4px;right:4px;width:20px;height:20px;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.remove-attachment-btn[data-v-f9077bc1]:hover{background:#000c}.remove-attachment-btn[data-v-f9077bc1] svg{font-size:12px}.attachment-error[data-v-f9077bc1]{position:absolute;bottom:0;left:0;right:0;background:#f00c;color:#fff;font-size:10px;padding:2px 4px;text-align:center}.reply-item[data-v-f9077bc1]{display:flex;gap:12px;padding:16px;background:var(--bg-secondary);border-radius:8px}.reply-avatar[data-v-f9077bc1]{position:relative;flex-shrink:0;width:40px;height:40px;display:flex;align-items:flex-start;justify-content:flex-start}.reply-avatar[data-v-f9077bc1] .avatar-wrapper{width:40px!important;height:40px!important;min-width:40px!important;min-height:40px!important;max-width:40px!important;max-height:40px!important}.reply-avatar .online-indicator[data-v-f9077bc1]{position:absolute;bottom:0;right:0;width:12px;height:12px;background:var(--success-color);border:2px solid var(--bg-card);border-radius:50%;box-shadow:0 1px 2px #0000001a;z-index:1}.reply-content-wrapper[data-v-f9077bc1]{flex:1}.reply-header[data-v-f9077bc1]{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:14px}.reply-author[data-v-f9077bc1]{font-weight:500;color:var(--text-primary)}.reply-author.clickable[data-v-f9077bc1]{cursor:pointer;transition:color .2s ease}.reply-author.clickable[data-v-f9077bc1]:hover{color:var(--primary-color);text-decoration:underline}.role-tag[data-v-f9077bc1]{display:inline-block;margin-left:6px;padding:2px 8px;font-size:11px;font-weight:700;border-radius:4px;line-height:1.2;vertical-align:middle;position:relative;animation:breathe-f9077bc1 2s ease-in-out infinite;text-shadow:0 0 10px currentColor,0 0 20px currentColor;overflow:hidden}.role-tag.role-admin[data-v-f9077bc1]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 0 10px #667eeacc,0 0 20px #764ba299,0 0 30px #667eea66,inset 0 0 15px #ffffff4d;animation:breathe-f9077bc1 2s ease-in-out infinite,neon-pulse-admin-f9077bc1 3s ease-in-out infinite}.role-tag.role-qiuchenly[data-v-f9077bc1]{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;box-shadow:0 0 10px #f093fbcc,0 0 20px #f5576c99,0 0 30px #f093fb66,inset 0 0 15px #ffffff4d;animation:breathe-f9077bc1 2s ease-in-out infinite,neon-pulse-qiuchenly-f9077bc1 3s ease-in-out infinite}.role-tag[data-v-f9077bc1]:before{content:"";position:absolute;top:-3px;left:-3px;right:-3px;bottom:-3px;border-radius:6px;background:inherit;filter:blur(8px);opacity:.7;z-index:-1;animation:glow-pulse-f9077bc1 2s ease-in-out infinite}.role-tag[data-v-f9077bc1]:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer-f9077bc1 2s linear infinite;border-radius:4px}@keyframes breathe-f9077bc1{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.08)}}@keyframes neon-pulse-admin-f9077bc1{0%,to{box-shadow:0 0 10px #667eeacc,0 0 20px #764ba299,0 0 30px #667eea66,inset 0 0 15px #ffffff4d}50%{box-shadow:0 0 20px #667eea,0 0 40px #764ba2cc,0 0 60px #667eea99,inset 0 0 20px #ffffff80}}@keyframes neon-pulse-qiuchenly-f9077bc1{0%,to{box-shadow:0 0 10px #f093fbcc,0 0 20px #f5576c99,0 0 30px #f093fb66,inset 0 0 15px #ffffff4d}50%{box-shadow:0 0 20px #f093fb,0 0 40px #f5576ccc,0 0 60px #f093fb99,inset 0 0 20px #ffffff80}}@keyframes glow-pulse-f9077bc1{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.9;transform:scale(1.1)}}@keyframes shimmer-f9077bc1{0%{left:-100%}to{left:100%}}.reply-time[data-v-f9077bc1]{color:var(--text-tertiary);margin-left:auto}.reply-content[data-v-f9077bc1]{color:var(--text-primary);line-height:1.8;font-size:14px;margin-bottom:12px}.reply-content p[data-v-f9077bc1]{margin:0;white-space:pre-wrap}.reply-actions[data-v-f9077bc1]{display:flex;gap:12px;margin-top:8px}.action-btn[data-v-f9077bc1]{display:flex;align-items:center;gap:4px;padding:4px 8px;background:transparent;border:none;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s ease;border-radius:4px}.action-btn[data-v-f9077bc1]:hover{color:var(--text-primary);background:var(--bg-secondary)}.action-btn.small[data-v-f9077bc1]{padding:4px 8px;font-size:12px}.action-btn.report-btn[data-v-f9077bc1]{color:#ff6b6b;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3)}.action-btn.report-btn[data-v-f9077bc1]:hover{color:#ff6b6b;background:#ff6b6b26;border-color:#ff6b6b80}.action-btn .action-icon[data-v-f9077bc1]{font-size:16px}.nested-reply-form[data-v-f9077bc1]{display:flex;gap:12px;margin-top:12px;padding:12px;background:var(--bg-card);border-radius:6px;border:1px solid var(--border-light)}.nested-reply-actions[data-v-f9077bc1]{display:flex;gap:8px}.cancel-btn[data-v-f9077bc1]{padding:6px 12px;background:transparent;border:1px solid var(--border-light);border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s ease}.cancel-btn[data-v-f9077bc1]:hover{color:var(--text-primary);border-color:var(--primary-color)}.nested-replies[data-v-f9077bc1]{margin-top:12px;padding-left:16px;border-left:2px solid var(--border-light)}.nested-reply-item[data-v-f9077bc1]{display:flex;gap:10px;padding:12px;margin-bottom:8px;background:var(--bg-card);border-radius:6px}.nested-reply-item[data-v-f9077bc1]:last-child{margin-bottom:0}.nested-reply-avatar[data-v-f9077bc1]{position:relative;flex-shrink:0;width:28px;height:28px;display:flex;align-items:flex-start;justify-content:flex-start}.nested-reply-avatar[data-v-f9077bc1] .avatar-wrapper{width:28px!important;height:28px!important;min-width:28px!important;min-height:28px!important;max-width:28px!important;max-height:28px!important}.nested-reply-avatar .online-indicator[data-v-f9077bc1]{position:absolute;bottom:0;right:0;width:10px;height:10px;background:var(--success-color);border:2px solid var(--bg-card);border-radius:50%;box-shadow:0 1px 2px #0000001a;z-index:1}.nested-reply-content-wrapper[data-v-f9077bc1]{flex:1}.nested-reply-header[data-v-f9077bc1]{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:13px}.nested-reply-author[data-v-f9077bc1]{font-weight:500;color:var(--text-primary)}.nested-reply-author.clickable[data-v-f9077bc1]{cursor:pointer;transition:color .2s ease}.nested-reply-author.clickable[data-v-f9077bc1]:hover{color:var(--primary-color);text-decoration:underline}.reply-to .clickable[data-v-f9077bc1]{cursor:pointer;color:var(--primary-color);transition:color .2s ease}.reply-to .clickable[data-v-f9077bc1]:hover{text-decoration:underline}.reply-to[data-v-f9077bc1]{color:var(--text-tertiary);font-size:12px}.nested-reply-time[data-v-f9077bc1]{color:var(--text-tertiary);font-size:12px;margin-left:auto}.nested-reply-content[data-v-f9077bc1]{color:var(--text-primary);line-height:1.6;font-size:13px;margin-bottom:8px}.nested-reply-content p[data-v-f9077bc1]{margin:0;white-space:pre-wrap}.nested-reply-actions[data-v-f9077bc1]{display:flex;gap:8px;margin-top:8px}.empty-replies[data-v-f9077bc1]{text-align:center;padding:40px 0;color:var(--text-tertiary);font-size:14px}.loading-overlay[data-v-f9077bc1]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-content[data-v-f9077bc1]{background:var(--bg-card);border-radius:12px;padding:32px 40px;box-shadow:0 8px 32px #0000004d;text-align:center;min-width:200px}.loading-content .spinner[data-v-f9077bc1]{width:40px;height:40px;border:3px solid var(--border-light);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin-f9077bc1 .8s linear infinite;margin:0 auto 16px}.loading-content p[data-v-f9077bc1]{color:var(--text-primary);font-size:14px;margin:0}.fade-enter-active[data-v-f9077bc1],.fade-leave-active[data-v-f9077bc1]{transition:opacity .3s ease}.fade-enter-from[data-v-f9077bc1],.fade-leave-to[data-v-f9077bc1]{opacity:0}.btn[data-v-f9077bc1]{padding:8px 16px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn.btn-primary[data-v-f9077bc1]{background:var(--primary-color);color:#fff}.btn.btn-primary[data-v-f9077bc1]:hover{opacity:.9}