- 修复BCryptPasswordEncoder密码验证问题 - 实现密码设置提示弹窗功能(仅对无密码用户显示一次) - 优化修改密码逻辑和验证流程 - 更新Welcome页面背景样式 - 清理临时SQL文件和测试代码 - 移动数据库备份文件到database/backups目录 - 删除不必要的MD文档和临时文件
2 lines
18 KiB
CSS
2 lines
18 KiB
CSS
.image-to-video-create-page[data-v-44c16b28]{height:100vh;background:#0a0a0a;color:#fff;display:flex;flex-direction:column;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.top-header[data-v-44c16b28]{display:flex;justify-content:space-between;align-items:center;padding:20px 32px;background:#0a0a0a;border-bottom:1px solid #1f1f1f;min-height:60px}.header-left[data-v-44c16b28]{display:flex;align-items:center}.back-btn[data-v-44c16b28]{background:none;border:none;color:#fff;font-size:16px;cursor:pointer;padding:10px 20px;border-radius:8px;transition:all .2s ease;font-weight:500}.back-btn[data-v-44c16b28]:hover{background:#1a1a1a;transform:translate(-2px)}.header-right[data-v-44c16b28]{display:flex;align-items:center;gap:24px}.points-display[data-v-44c16b28]{display:flex;align-items:center;gap:8px;padding:6px 12px;background:rgba(64,158,255,.1);border-radius:20px;border:1px solid rgba(64,158,255,.3)}.points-icon[data-v-44c16b28]{width:20px;height:20px;background:#409EFF;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px}.points-number[data-v-44c16b28]{color:#409eff;font-size:14px;font-weight:600}.user-avatar[data-v-44c16b28]{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease;overflow:hidden}.user-avatar img[data-v-44c16b28]{width:100%;height:100%;object-fit:cover}.user-avatar[data-v-44c16b28]:hover{transform:scale(1.05)}.user-menu-teleport[data-v-44c16b28]{background:white;border-radius:12px;box-shadow:0 8px 32px #0000001f;border:1px solid rgba(0,0,0,.08);padding:8px 0;min-width:200px;z-index:99999}.menu-item[data-v-44c16b28]{display:flex;align-items:center;padding:12px 16px;cursor:pointer;transition:all .2s ease;color:#333;font-size:14px}.menu-item[data-v-44c16b28]:hover{background:#f5f7fa;color:#667eea}.menu-item.logout[data-v-44c16b28]{color:#f56565}.menu-item.logout[data-v-44c16b28]:hover{background:#fef2f2;color:#e53e3e}.menu-divider[data-v-44c16b28]{height:1px;background:#e2e8f0;margin:4px 0}.menu-item .el-icon[data-v-44c16b28]{margin-right:12px;font-size:16px}.main-content[data-v-44c16b28]{flex:1;display:grid;grid-template-columns:400px 1fr;gap:0;height:calc(100vh - 100px)}.left-panel[data-v-44c16b28]{background:#1a1a1a;border-right:1px solid #2a2a2a;padding:32px;display:flex;flex-direction:column;gap:32px;overflow-y:auto}.creation-tabs[data-v-44c16b28]{display:flex;gap:4px;background:#0a0a0a;padding:4px;border-radius:12px}.tab[data-v-44c16b28]{flex:1;padding:12px 16px;border-radius:8px;cursor:pointer;transition:all .2s ease;color:#9ca3af;font-size:14px;font-weight:500;text-align:center}.tab.active[data-v-44c16b28]{background:#3b82f6;color:#fff;box-shadow:0 2px 8px #3b82f64d}.tab[data-v-44c16b28]:hover:not(.active){background:#2a2a2a;color:#fff}.image-input-section[data-v-44c16b28]{display:flex;flex-direction:column;gap:16px}.image-upload-area[data-v-44c16b28]{display:flex;align-items:center;gap:16px}.upload-box[data-v-44c16b28]{flex:1;aspect-ratio:1;background:#0a0a0a;border:2px dashed #2a2a2a;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.upload-box[data-v-44c16b28]:hover{border-color:#3b82f6;background:#1a1a1a}.upload-box.optional[data-v-44c16b28]{opacity:.7}.upload-placeholder[data-v-44c16b28]{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%}.upload-icon[data-v-44c16b28]{font-size:32px;color:#6b7280;font-weight:300;margin-bottom:8px}.upload-text[data-v-44c16b28]{font-size:14px;color:#9ca3af;font-weight:500}.upload-preview[data-v-44c16b28]{width:100%;height:100%;position:relative}.upload-preview img[data-v-44c16b28]{width:100%;height:100%;object-fit:cover;border-radius:10px}.arrow-icon[data-v-44c16b28]{font-size:20px;color:#6b7280;font-weight:700}.remove-btn[data-v-44c16b28]{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.8);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;z-index:10;transition:all .2s ease}.remove-btn[data-v-44c16b28]:hover{background:rgba(239,68,68,.9);transform:scale(1.1)}.text-input-section[data-v-44c16b28]{display:flex;flex-direction:column;gap:16px}.text-input[data-v-44c16b28]{width:100%;min-height:120px;padding:16px;background:#0a0a0a;border:2px solid #2a2a2a;border-radius:12px;color:#fff;font-size:15px;line-height:1.6;resize:vertical;outline:none;transition:all .2s ease;font-family:inherit}.text-input[data-v-44c16b28]:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.text-input[data-v-44c16b28]::placeholder{color:#6b7280}.optimize-btn[data-v-44c16b28]{display:flex;justify-content:flex-end}.optimize-button[data-v-44c16b28]{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;box-shadow:0 2px 8px #3b82f64d}.optimize-button[data-v-44c16b28]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.video-settings[data-v-44c16b28]{display:flex;flex-direction:column;gap:20px}.setting-item[data-v-44c16b28]{display:flex;flex-direction:column;gap:10px}.setting-item label[data-v-44c16b28]{font-size:14px;color:#e5e7eb;font-weight:600}.setting-select[data-v-44c16b28]{padding:12px 16px;background:#0a0a0a;border:2px solid #2a2a2a;border-radius:8px;color:#fff;font-size:14px;outline:none;cursor:pointer;transition:all .2s ease;font-family:inherit}.setting-select[data-v-44c16b28]:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.setting-select[data-v-44c16b28]:hover{border-color:#374151}.hd-setting[data-v-44c16b28]{display:flex;align-items:center;gap:12px}.cost-text[data-v-44c16b28]{font-size:13px;color:#9ca3af;font-weight:500}.generate-section[data-v-44c16b28]{margin-top:auto}.generate-btn[data-v-44c16b28]{width:100%;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;padding:16px 24px;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #3b82f64d;text-transform:uppercase;letter-spacing:.5px}.generate-btn[data-v-44c16b28]:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.generate-btn[data-v-44c16b28]:active{transform:translateY(0)}.generate-btn[data-v-44c16b28]:disabled{background:#6b7280;cursor:not-allowed;transform:none;box-shadow:none}.login-tip[data-v-44c16b28]{margin-top:12px;text-align:center;padding:12px;background:rgba(59,130,246,.1);border-radius:8px;border:1px solid rgba(59,130,246,.3)}.login-tip p[data-v-44c16b28]{color:#9ca3af;font-size:13px;margin:0 0 8px}.login-link-btn[data-v-44c16b28]{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.login-link-btn[data-v-44c16b28]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.right-panel[data-v-44c16b28]{background:#0a0a0a;padding:32px;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.right-panel[data-v-44c16b28]::-webkit-scrollbar{width:8px}.right-panel[data-v-44c16b28]::-webkit-scrollbar-track{background:#1a1a1a;border-radius:4px}.right-panel[data-v-44c16b28]::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:4px}.right-panel[data-v-44c16b28]::-webkit-scrollbar-thumb:hover{background:#2563eb}.preview-area[data-v-44c16b28]{flex:1;display:flex;flex-direction:column;gap:20px;min-height:min-content}.status-checkbox[data-v-44c16b28]{display:flex;align-items:center;gap:12px;margin-bottom:8px}.status-checkbox input[type=checkbox][data-v-44c16b28]{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6}.status-checkbox label[data-v-44c16b28]{font-size:14px;color:#e5e7eb;cursor:pointer;font-weight:500}.preview-content[data-v-44c16b28]{flex:1;background:#1a1a1a;border:2px solid #2a2a2a;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;width:80%;max-width:1000px;margin-left:0;margin-right:auto;align-self:flex-start}.preview-content[data-v-44c16b28]:hover{border-color:#374151}.preview-placeholder[data-v-44c16b28]{width:100%;min-height:400px;background:#1a1a1a;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:60px 40px}.placeholder-text[data-v-44c16b28]{font-size:20px;color:#9ca3af;font-weight:500;line-height:1.6}.task-status[data-v-44c16b28]{background:#1a1a1a;border:2px solid #2a2a2a;border-radius:12px;padding:24px;margin-bottom:20px}.status-header[data-v-44c16b28]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #2a2a2a}.status-header h3[data-v-44c16b28]{color:#fff;font-size:18px;font-weight:600;margin:0}.task-id[data-v-44c16b28]{color:#9ca3af;font-size:12px;font-family:monospace}.status-info[data-v-44c16b28]{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.status-item[data-v-44c16b28]{display:flex;justify-content:space-between;align-items:center}.status-item .label[data-v-44c16b28]{color:#9ca3af;font-size:14px;font-weight:500}.status-item .value[data-v-44c16b28]{color:#fff;font-size:14px;font-weight:600}.status-pending[data-v-44c16b28]{color:#f59e0b!important}.status-processing[data-v-44c16b28]{color:#3b82f6!important}.status-completed[data-v-44c16b28]{color:#10b981!important}.status-failed[data-v-44c16b28]{color:#ef4444!important}.status-cancelled[data-v-44c16b28]{color:#6b7280!important}.progress-bar[data-v-44c16b28]{width:100%;height:8px;background:#2a2a2a;border-radius:4px;overflow:hidden;margin-bottom:20px}.progress-fill[data-v-44c16b28]{height:100%;background:linear-gradient(90deg,#3b82f6,#1d4ed8);border-radius:4px;transition:width .3s ease;position:relative}.progress-fill[data-v-44c16b28]:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:progress-shine-44c16b28 2s infinite}@keyframes progress-shine-44c16b28{0%{transform:translate(-100%)}to{transform:translate(100%)}}.task-actions[data-v-44c16b28]{display:flex;gap:12px}.task-description[data-v-44c16b28]{background:rgba(255,255,255,.05);border-radius:8px;padding:16px;margin:15px 0;font-size:14px;line-height:1.6;color:#e5e7eb;border:1px solid rgba(255,255,255,.1);max-height:120px;overflow-y:auto}.video-preview-container[data-v-44c16b28]{background:#1a1a1a;border:2px solid #2a2a2a;border-radius:12px;min-height:300px;display:flex;align-items:center;justify-content:center;overflow:hidden;width:80%;max-width:1000px;margin:15px auto 15px 0}.generating-container[data-v-44c16b28]{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.generating-placeholder[data-v-44c16b28]{text-align:center;padding:40px}.generating-text[data-v-44c16b28]{font-size:18px;color:#3b82f6;font-weight:600;margin-bottom:20px}.progress-bar-large[data-v-44c16b28]{width:200px;height:8px;background:rgba(255,255,255,.1);border-radius:4px;overflow:hidden}.progress-fill-large[data-v-44c16b28]{height:100%;background:linear-gradient(90deg,#3b82f6,#1d4ed8);border-radius:4px;transition:width .3s ease}.completed-container[data-v-44c16b28]{width:100%;height:100%;display:flex;flex-direction:column;padding:0}.task-info-header[data-v-44c16b28]{margin-bottom:15px}.task-checkbox[data-v-44c16b28]{display:flex;align-items:center;gap:8px}.task-checkbox input[type=checkbox][data-v-44c16b28]{width:16px;height:16px;cursor:pointer;accent-color:#3b82f6}.task-checkbox label[data-v-44c16b28]{font-size:14px;color:#e5e7eb;cursor:pointer;font-weight:500}.video-player-container[data-v-44c16b28]{flex:1;position:relative;margin-bottom:20px}.video-player[data-v-44c16b28]{position:relative;width:100%;background:#1a1a1a;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}.result-video[data-v-44c16b28]{width:100%;height:100%;object-fit:contain;border-radius:12px;display:block}.no-video-placeholder[data-v-44c16b28]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#9ca3af}.no-video-text[data-v-44c16b28]{font-size:16px;font-weight:500}.watermark-overlay[data-v-44c16b28]{position:absolute;bottom:15px;right:15px;background:rgba(0,0,0,.8);border-radius:8px;padding:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.watermark-options[data-v-44c16b28]{display:flex;flex-direction:column;gap:8px}.watermark-option[data-v-44c16b28]{display:flex;align-items:center;gap:8px}.watermark-option input[type=radio][data-v-44c16b28]{width:16px;height:16px;cursor:pointer;accent-color:#3b82f6}.watermark-option label[data-v-44c16b28]{font-size:13px;color:#e5e7eb;cursor:pointer;font-weight:500}.result-actions[data-v-44c16b28]{display:flex;align-items:center;justify-content:space-between;gap:12px}.action-buttons[data-v-44c16b28]{display:flex;gap:12px}.action-btn[data-v-44c16b28]{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.action-btn.primary[data-v-44c16b28]{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.action-btn.primary[data-v-44c16b28]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.action-icons[data-v-44c16b28]{display:flex;gap:8px}.icon-btn[data-v-44c16b28]{width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#e5e7eb;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.icon-btn[data-v-44c16b28]:hover{background:rgba(255,255,255,.2);transform:translateY(-1px)}.icon-btn svg[data-v-44c16b28]{width:16px;height:16px}.failed-container[data-v-44c16b28]{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px}.failed-placeholder[data-v-44c16b28]{text-align:center;margin-bottom:20px}.failed-icon[data-v-44c16b28]{font-size:48px;margin-bottom:16px}.failed-text[data-v-44c16b28]{font-size:20px;color:#ef4444;font-weight:600;margin-bottom:8px}.failed-desc[data-v-44c16b28]{font-size:14px;color:#9ca3af}.status-placeholder[data-v-44c16b28]{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.status-text[data-v-44c16b28]{font-size:18px;color:#9ca3af;font-weight:500}.task-controls[data-v-44c16b28]{margin-top:15px;text-align:center}.history-section[data-v-44c16b28]{margin-top:24px;padding-top:24px;border-top:1px solid #2a2a2a}.history-list[data-v-44c16b28]{display:flex;flex-direction:column;gap:20px}.history-item[data-v-44c16b28]{background:transparent;border:none;padding:0;transition:all .2s ease;width:80%;max-width:1000px;margin-left:0;margin-right:auto}.history-status-checkbox[data-v-44c16b28]{display:flex;align-items:center;gap:8px;margin-bottom:12px}.history-status-checkbox input[type=checkbox][data-v-44c16b28]{width:16px;height:16px;cursor:default;accent-color:#3b82f6}.history-status-checkbox label[data-v-44c16b28]{color:#e5e7eb;font-size:14px;font-weight:500;cursor:default}.history-item-header[data-v-44c16b28]{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.history-type[data-v-44c16b28]{color:#3b82f6;font-size:14px;font-weight:600}.history-date[data-v-44c16b28]{color:#9ca3af;font-size:13px}.history-prompt[data-v-44c16b28]{color:#e5e7eb;font-size:14px;line-height:1.6;margin-bottom:16px;white-space:pre-wrap;word-wrap:break-word}.history-preview[data-v-44c16b28]{width:100%;aspect-ratio:16/9;background:#000;border-radius:8px;overflow:hidden;margin-bottom:16px;position:relative}.history-placeholder[data-v-44c16b28]{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000;color:#fff;gap:12px}.queue-text[data-v-44c16b28]{font-size:18px;font-weight:600;color:#fff}.queue-link[data-v-44c16b28]{font-size:14px;color:#3b82f6;cursor:pointer;text-decoration:none}.queue-link[data-v-44c16b28]:hover{color:#60a5fa;text-decoration:underline}.cancel-btn[data-v-44c16b28]{padding:8px 24px;background:transparent;color:#fff;border:1px solid #fff;border-radius:4px;font-size:14px;cursor:pointer;margin-top:8px;transition:all .2s ease}.cancel-btn[data-v-44c16b28]:hover{background:rgba(255,255,255,.1)}.no-result-text[data-v-44c16b28]{font-size:14px;color:#6b7280}.history-video-thumbnail[data-v-44c16b28]{width:100%;height:100%;position:relative;cursor:pointer;overflow:hidden}.history-video-thumbnail video[data-v-44c16b28]{width:100%;height:100%;object-fit:cover;cursor:pointer;display:block}.history-image-thumbnail[data-v-44c16b28]{width:100%;height:100%;position:relative;overflow:hidden}.history-image-thumbnail img[data-v-44c16b28]{width:100%;height:100%;object-fit:cover;display:block}.play-overlay[data-v-44c16b28]{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.history-video-thumbnail:hover .play-overlay[data-v-44c16b28]{opacity:1}.play-icon[data-v-44c16b28]{width:48px;height:48px;background:rgba(59,130,246,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;padding-left:4px}.history-actions[data-v-44c16b28]{display:flex;justify-content:flex-start;margin-top:0}.similar-btn[data-v-44c16b28]{padding:10px 20px;background:#2a2a2a;color:#e5e7eb;border:1px solid #3a3a3a;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.similar-btn[data-v-44c16b28]:hover{background:#3a3a3a;border-color:#4a4a4a}@media (max-width: 1200px){.main-content[data-v-44c16b28]{grid-template-columns:350px 1fr}.left-panel[data-v-44c16b28],.right-panel[data-v-44c16b28]{padding:24px}}@media (max-width: 1024px){.main-content[data-v-44c16b28]{grid-template-columns:1fr;grid-template-rows:auto 1fr}.left-panel[data-v-44c16b28]{border-right:none;border-bottom:1px solid #2a2a2a;padding:20px}.right-panel[data-v-44c16b28]{padding:20px}}@media (max-width: 768px){.top-header[data-v-44c16b28]{padding:16px 20px}.header-right[data-v-44c16b28]{gap:16px}.left-panel[data-v-44c16b28]{padding:16px;gap:24px}.right-panel[data-v-44c16b28]{padding:16px}.creation-tabs[data-v-44c16b28]{flex-direction:column;gap:8px}.tab[data-v-44c16b28]{text-align:left}.image-upload-area[data-v-44c16b28]{flex-direction:column;gap:12px}.arrow-icon[data-v-44c16b28]{transform:rotate(90deg)}}
|