mirror of
https://git-qiuchenly.yltfspace.com/QiuChenly/corepatch
synced 2025-11-25 10:08:20 +08:00
### 后端更新 性能优化 - Redis、数据库索引优化, 复杂联表查询查询速度从10秒降低到500ms 功能增强 - 统一文件上传 API - 论坛权限管理优化 ### 前端更新 问题修复 - 统一错误提示、组件复用、图标本地化、密码加密传输、大文件分片上传 新增功能 - 全局通知系统、WebSocket 实时消息、图标批量同步、IP 封禁管理、应用版本批量查询、头像上传、TypeScript 类型完善、讨论区功能增强 代码优化 - 删除冗余组件、统一 API 错误处理、优化代码结构、统一 UI 风格
2 lines
15 KiB
CSS
2 lines
15 KiB
CSS
.upload-progress-content[data-v-a922ff57]{padding:var(--spacing-md) 0}[data-v-a922ff57] .modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.progress-info[data-v-a922ff57]{display:flex;align-items:center;gap:12px;margin-bottom:20px}.progress-info .progress-icon[data-v-a922ff57]{font-size:24px;color:var(--primary-color)}.progress-info .progress-text[data-v-a922ff57]{font-size:14px;color:var(--text-primary)}.progress-bar-container[data-v-a922ff57]{display:flex;align-items:center;gap:12px;margin-bottom:16px}.progress-bar[data-v-a922ff57]{flex:1;height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden}.progress-fill[data-v-a922ff57]{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--primary-color-light));border-radius:4px;transition:width .3s ease}.progress-percent[data-v-a922ff57]{font-size:14px;font-weight:600;color:var(--text-primary);min-width:45px;text-align:right}.error-message[data-v-a922ff57]{display:flex;align-items:center;gap:8px;padding:12px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:8px;color:var(--error-color);font-size:14px}.error-message .error-icon[data-v-a922ff57]{font-size:20px;flex-shrink:0}.dialog-footer[data-v-a922ff57]{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border-light)}.fade-enter-active[data-v-a922ff57],.fade-leave-active[data-v-a922ff57]{transition:opacity .3s ease}.fade-enter-from[data-v-a922ff57],.fade-leave-to[data-v-a922ff57]{opacity:0}.discussion-forum-page[data-v-973c5f2d]{width:100%;min-height:100%}.page-container[data-v-973c5f2d]{width:100%}.page-header[data-v-973c5f2d]{margin-bottom:32px}.header-buttons[data-v-973c5f2d]{display:flex;gap:12px;margin-bottom:16px}.back-button[data-v-973c5f2d],.home-button[data-v-973c5f2d]{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-973c5f2d]:hover,.home-button[data-v-973c5f2d]:hover{color:var(--text-primary);border-color:var(--primary-color);background:var(--bg-secondary)}.back-button .back-icon[data-v-973c5f2d],.back-button .home-icon[data-v-973c5f2d],.home-button .back-icon[data-v-973c5f2d],.home-button .home-icon[data-v-973c5f2d]{font-size:18px}.header-content .app-header[data-v-973c5f2d]{display:flex;align-items:center;gap:20px}.header-content .app-icon-wrapper[data-v-973c5f2d]{flex-shrink:0}.header-content .app-icon[data-v-973c5f2d]{width:64px;height:64px;border-radius:12px;overflow:hidden;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;position:relative;transition:transform .2s ease,box-shadow .2s ease}.header-content .app-icon[data-v-973c5f2d]:has(img){cursor:zoom-in}.header-content .app-icon[data-v-973c5f2d]:has(img):hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.header-content .app-icon .builtin-forum-icon[data-v-973c5f2d]{font-size:40px;color:var(--primary-color)}.header-content .app-icon img[data-v-973c5f2d]{width:100%;height:100%;object-fit:cover;object-position:center}.header-content .app-icon .icon-placeholder[data-v-973c5f2d]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:600;color:var(--text-secondary);background:var(--bg-secondary)}.header-content .app-title-info[data-v-973c5f2d]{flex:1}.forum-stats[data-v-973c5f2d]{display:flex;gap:16px;margin-top:8px;flex-wrap:wrap}.forum-stats .stat-item[data-v-973c5f2d]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.forum-stats .stat-icon[data-v-973c5f2d]{font-size:16px;color:var(--primary-color)}.page-title[data-v-973c5f2d]{margin:0 0 8px;font-size:28px;font-weight:600;color:var(--text-primary)}.page-description[data-v-973c5f2d]{margin:0;font-size:14px;color:var(--text-secondary)}.loading[data-v-973c5f2d],.error[data-v-973c5f2d],.empty-discussion[data-v-973c5f2d]{text-align:center;padding:60px 0}.loading .spinner[data-v-973c5f2d],.error .spinner[data-v-973c5f2d],.empty-discussion .spinner[data-v-973c5f2d]{width:40px;height:40px;border:3px solid var(--border-light);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin-973c5f2d .8s linear infinite;margin:0 auto 16px}.loading p[data-v-973c5f2d],.error p[data-v-973c5f2d],.empty-discussion p[data-v-973c5f2d]{color:var(--text-secondary);font-size:14px;margin-bottom:8px}.loading .empty-hint[data-v-973c5f2d],.error .empty-hint[data-v-973c5f2d],.empty-discussion .empty-hint[data-v-973c5f2d]{font-size:12px;color:var(--text-tertiary)}@keyframes spin-973c5f2d{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-icon[data-v-973c5f2d]{font-size:64px;margin-bottom:16px;opacity:.3;color:var(--text-tertiary)}.discussion-content[data-v-973c5f2d]{min-height:400px}.posts-list[data-v-973c5f2d]{display:flex;flex-direction:column;gap:20px}.post-card[data-v-973c5f2d]{background:var(--bg-card);border:1px solid var(--border-light);border-radius:12px;padding:20px;cursor:pointer;transition:all .2s ease}.post-card[data-v-973c5f2d]:hover{box-shadow:0 2px 8px #0000001a;border-color:var(--primary-color);transform:translateY(-2px)}.post-header[data-v-973c5f2d]{margin-bottom:12px}.post-title[data-v-973c5f2d]{margin:0 0 8px;font-size:18px;font-weight:600;color:var(--text-primary)}.post-meta[data-v-973c5f2d]{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-secondary)}.author-wrapper[data-v-973c5f2d]{display:flex;align-items:center;gap:8px;position:relative}.author-avatar[data-v-973c5f2d]{position:relative;flex-shrink:0;display:flex;align-items:center;justify-content:center}.author-avatar .online-indicator[data-v-973c5f2d]{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}.post-author[data-v-973c5f2d]{font-weight:500;color:var(--text-primary)}.post-author.clickable[data-v-973c5f2d]{cursor:pointer;transition:color .2s ease}.post-author.clickable[data-v-973c5f2d]:hover{color:var(--primary-color);text-decoration:underline}.post-time[data-v-973c5f2d]{color:var(--text-tertiary)}.post-content-preview[data-v-973c5f2d]{margin-bottom:16px;color:var(--text-secondary);line-height:1.6;font-size:14px}.post-content-preview p[data-v-973c5f2d]{margin:0;white-space:pre-wrap}.post-attachments[data-v-973c5f2d],.reply-attachments[data-v-973c5f2d]{margin-top:12px;display:flex;flex-direction:column;gap:8px}.attachment-item[data-v-973c5f2d]{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-secondary);border-radius:6px;font-size:13px}.attachment-icon[data-v-973c5f2d]{font-size:18px;color:var(--text-secondary)}.attachment-name[data-v-973c5f2d]{flex:1;color:var(--text-primary)}.attachment-size[data-v-973c5f2d]{color:var(--text-tertiary);font-size:12px}.post-footer[data-v-973c5f2d]{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--border-light)}.post-stats[data-v-973c5f2d]{display:flex;gap:20px}.stat-item[data-v-973c5f2d]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.stat-icon[data-v-973c5f2d]{font-size:16px}.post-actions[data-v-973c5f2d]{display:flex;gap:8px}.action-btn[data-v-973c5f2d]{display:flex;align-items:center;gap:4px;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}.action-btn[data-v-973c5f2d]:hover{color:var(--text-primary);border-color:var(--primary-color);background:var(--bg-secondary)}.action-btn.active[data-v-973c5f2d]{color:var(--primary-color);border-color:var(--primary-color);background:rgba(var(--primary-color-rgb),.1)}.action-btn .action-icon[data-v-973c5f2d]{font-size:16px}.action-btn.report-btn[data-v-973c5f2d]{color:#ff6b6b;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3)}.action-btn.report-btn[data-v-973c5f2d]:hover{color:#ff6b6b;background:#ff6b6b26;border-color:#ff6b6b80}.create-post-section[data-v-973c5f2d]{margin-bottom:20px}.section-header[data-v-973c5f2d]{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.sort-selector[data-v-973c5f2d]{display:flex;align-items:center;gap:8px}.sort-label[data-v-973c5f2d]{font-size:14px;color:var(--text-secondary);white-space:nowrap}.create-post-btn[data-v-973c5f2d]{display:flex;align-items:center;gap:8px;padding:12px 20px;background:var(--primary-color);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.create-post-btn[data-v-973c5f2d]:hover{opacity:.9;transform:translateY(-1px)}.create-post-btn .btn-icon[data-v-973c5f2d]{font-size:20px}.post-form-container[data-v-973c5f2d]{background:var(--bg-card);border:1px solid var(--border-light);border-radius:12px;padding:20px;margin-bottom:24px}.post-form-header[data-v-973c5f2d]{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.post-form-header h3[data-v-973c5f2d]{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.close-form-btn[data-v-973c5f2d]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-light);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.close-form-btn[data-v-973c5f2d]:hover{color:var(--text-primary);border-color:var(--primary-color);background:var(--bg-secondary)}.close-form-btn[data-v-973c5f2d] svg{font-size:18px}.post-form-slide-enter-active[data-v-973c5f2d],.post-form-slide-leave-active[data-v-973c5f2d]{transition:all .3s ease;overflow:hidden}.post-form-slide-enter-from[data-v-973c5f2d]{opacity:0;transform:translateY(-20px);max-height:0}.post-form-slide-enter-to[data-v-973c5f2d],.post-form-slide-leave-from[data-v-973c5f2d]{opacity:1;transform:translateY(0);max-height:1000px}.post-form-slide-leave-to[data-v-973c5f2d]{opacity:0;transform:translateY(-20px);max-height:0}.post-form[data-v-973c5f2d]{display:flex;flex-direction:column;gap:12px}.form-row[data-v-973c5f2d]{width:100%}.post-title-input[data-v-973c5f2d]{width:100%;padding:12px;border:1px solid var(--border-light);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:16px;font-weight:500;font-family:inherit}.post-title-input[data-v-973c5f2d]:focus{outline:none;border-color:var(--primary-color)}.post-title-input[data-v-973c5f2d]::placeholder{color:var(--text-tertiary)}.post-content-input[data-v-973c5f2d]{width:100%;padding:12px;border:1px solid var(--border-light);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:inherit;resize:vertical;min-height:100px}.post-content-input[data-v-973c5f2d]:focus{outline:none;border-color:var(--primary-color)}.post-content-input[data-v-973c5f2d]::placeholder{color:var(--text-tertiary)}.form-actions[data-v-973c5f2d]{display:flex;justify-content:space-between;align-items:center;gap:12px}.upload-area[data-v-973c5f2d]{display:flex;align-items:center;gap:8px}.upload-btn[data-v-973c5f2d]{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-973c5f2d]:hover:not(:disabled){color:var(--text-primary);border-color:var(--primary-color);background:var(--bg-secondary)}.upload-btn[data-v-973c5f2d]:disabled{opacity:.5;cursor:not-allowed}.upload-btn .btn-icon[data-v-973c5f2d]{font-size:16px}.upload-count[data-v-973c5f2d]{font-size:12px;color:var(--text-tertiary)}.submit-post-btn[data-v-973c5f2d]{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-post-btn[data-v-973c5f2d]:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.submit-post-btn[data-v-973c5f2d]:disabled{opacity:.5;cursor:not-allowed}.submit-post-btn .btn-icon[data-v-973c5f2d]{font-size:16px}.attachment-preview-list[data-v-973c5f2d]{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.attachment-preview-item[data-v-973c5f2d]{position:relative;width:80px;height:80px;border-radius:6px;overflow:hidden;background:var(--bg-secondary)}.attachment-preview-item img[data-v-973c5f2d]{width:100%;height:100%;object-fit:cover}.attachment-preview-item.file[data-v-973c5f2d]{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-973c5f2d]{font-size:24px;color:var(--text-secondary);margin-bottom:4px}.attachment-preview-item.file .file-name[data-v-973c5f2d]{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-973c5f2d]{font-size:10px;color:var(--text-tertiary)}.remove-attachment-btn[data-v-973c5f2d]{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-973c5f2d]:hover{background:#000c}.remove-attachment-btn[data-v-973c5f2d] svg{font-size:12px}.attachment-error[data-v-973c5f2d]{position:absolute;bottom:0;left:0;right:0;background:#f00c;color:#fff;font-size:10px;padding:2px 4px;text-align:center}.btn[data-v-973c5f2d]{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-973c5f2d]{background:var(--primary-color);color:#fff}.btn.btn-primary[data-v-973c5f2d]:hover{opacity:.9}.icon-preview-overlay[data-v-973c5f2d]{position:fixed;z-index:10000;max-width:90vw;max-height:90vh;pointer-events:auto;border-radius:var(--radius-lg);overflow:visible;box-shadow:0 8px 32px #0000004d,0 4px 16px #0003;background:var(--bg-card);border:1px solid var(--border-light);transform:translate(-50%);display:inline-block}.icon-preview-overlay .preview-image[data-v-973c5f2d]{display:block;max-width:90vw;max-height:90vh;width:auto;height:auto;object-fit:contain;object-position:center;border-radius:var(--radius-lg)}.icon-preview-overlay .preview-loading[data-v-973c5f2d]{width:400px;height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-secondary)}.icon-preview-overlay .preview-loading .loading-spinner[data-v-973c5f2d]{width:40px;height:40px;border:3px solid var(--border-light);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin-973c5f2d 1s linear infinite}.icon-preview-overlay .preview-loading p[data-v-973c5f2d]{margin:0;font-size:14px}.icon-preview-fade-enter-active[data-v-973c5f2d],.icon-preview-fade-leave-active[data-v-973c5f2d]{transition:opacity .2s ease,transform .2s ease}.icon-preview-fade-enter-from[data-v-973c5f2d],.icon-preview-fade-leave-to[data-v-973c5f2d]{opacity:0;transform:translate(-50%,-10px) scale(.95)}@keyframes spin-973c5f2d{to{transform:rotate(360deg)}}
|