更新说明:\n1. 新增用户端与管理员端 Passkey 登录/注册/设备管理(最多3台,支持设备备注、删除设备)。\n2. 修复 Passkey 注册与登录流程中的浏览器/证书/CSRF相关问题,增强错误提示。\n3. 前台登录页改为独立入口,首屏仅加载必要资源,其他页面按需加载。\n4. 系统配置页改为静默获取金山文档状态,避免首屏阻塞,并优化状态展示为“检测中/已登录/未登录/异常”。\n5. 补充后端接口与页面渲染适配,修复多入口下样式依赖注入问题。\n6. 同步更新前后台构建产物与相关静态资源。
2 lines
5.2 KiB
CSS
2 lines
5.2 KiB
CSS
.login-page[data-v-01524203]{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;background:linear-gradient(135deg,#eef2ff,#f6f7fb 45%,#ecfeff)}.login-page[data-v-01524203]:before{content:"";position:fixed;inset:0;background:radial-gradient(800px 500px at 15% 20%,rgba(59,130,246,.18),transparent 60%),radial-gradient(700px 420px at 85% 70%,rgba(124,58,237,.16),transparent 55%);pointer-events:none}.login-container[data-v-01524203]{width:100%;max-width:420px;background:#fff;border-radius:16px;box-shadow:0 18px 60px #11182726;border:1px solid rgba(17,24,39,.08);padding:36px 30px;position:relative;z-index:1}.login-header[data-v-01524203]{text-align:center;margin-bottom:26px}.login-badge[data-v-01524203]{display:inline-block;background:#3b82f61a;color:#1d4ed8;padding:6px 14px;border-radius:999px;font-size:12px;font-weight:700;margin-bottom:14px}.login-header h1[data-v-01524203]{font-size:24px;color:#111827;margin:0 0 10px;letter-spacing:.2px}.login-header p[data-v-01524203]{margin:0;color:#6b7280;font-size:14px}.notice[data-v-01524203]{margin-bottom:14px;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:600}.notice.is-error[data-v-01524203]{color:#b91c1c;background:#fee2e2;border:1px solid #fecaca}.notice.is-success[data-v-01524203]{color:#065f46;background:#d1fae5;border:1px solid #a7f3d0}.form-group[data-v-01524203]{margin-bottom:16px}.form-group label[data-v-01524203]{display:block;margin-bottom:8px;color:#111827;font-weight:700;font-size:13px}.text-input[data-v-01524203]{width:100%;height:44px;border-radius:10px;border:1px solid rgba(17,24,39,.18);padding:0 12px;font-size:14px;color:#111827;background:#ffffffeb;outline:none;transition:border-color .18s,box-shadow .18s;box-sizing:border-box}.text-input[data-v-01524203]:focus{border-color:#3b82f6cc;box-shadow:0 0 0 4px #3b82f624}.btn-login[data-v-01524203]{width:100%;height:44px;border:none;border-radius:10px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-size:14px;font-weight:800;cursor:pointer;transition:transform .15s,filter .15s}.btn-passkey[data-v-01524203]{width:100%;height:42px;margin-top:10px;border-radius:10px;border:1px solid rgba(17,24,39,.14);background:#f8fafc;color:#0f172a;font-size:14px;font-weight:700;cursor:pointer}.btn-passkey[data-v-01524203]:hover:not(:disabled){background:#f1f5f9}.btn-passkey[data-v-01524203]:disabled,.btn-login[data-v-01524203]:disabled,.btn-ghost[data-v-01524203]:disabled,.captcha-refresh[data-v-01524203]:disabled{cursor:not-allowed;opacity:.72}.btn-login[data-v-01524203]:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.02)}.action-links[data-v-01524203]{margin-top:14px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.link-btn[data-v-01524203]{border:none;background:none;color:#2563eb;font-size:13px;font-weight:700;cursor:pointer;padding:0}.link-btn[data-v-01524203]:hover{text-decoration:underline}.register-row[data-v-01524203]{margin-top:16px;display:flex;justify-content:center;align-items:center;gap:8px;color:#6b7280;font-size:13px}.captcha-row[data-v-01524203]{display:flex;align-items:center;gap:10px;width:100%}.captcha-input[data-v-01524203]{flex:1;min-width:0}.captcha-img[data-v-01524203]{height:44px;border:1px solid rgba(17,24,39,.14);border-radius:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.captcha-refresh[data-v-01524203]{height:42px;padding:0 12px;border:1px solid rgba(17,24,39,.14);border-radius:10px;background:#f8fafc;color:#111827;font-size:13px;cursor:pointer}.captcha-refresh[data-v-01524203]:hover{background:#f1f5f9}.modal-mask[data-v-01524203]{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:16px;z-index:20}.modal-card[data-v-01524203]{width:min(560px,96vw);border-radius:14px;background:#fff;border:1px solid rgba(17,24,39,.08);box-shadow:0 16px 42px #0f172a47;padding:16px}.modal-head[data-v-01524203]{display:flex;align-items:center;justify-content:space-between;gap:10px}.modal-head h3[data-v-01524203]{margin:0;font-size:16px;font-weight:800;color:#0f172a}.modal-close[data-v-01524203]{height:30px;padding:0 10px;border-radius:8px;border:1px solid rgba(17,24,39,.16);background:#fff;color:#334155;cursor:pointer}.modal-tip[data-v-01524203]{margin:12px 0;padding:10px;border-radius:10px;background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a;font-size:13px}.modal-tip.warn[data-v-01524203]{background:#fffbeb;border-color:#fde68a;color:#92400e}.modal-tip.error[data-v-01524203]{background:#fef2f2;border-color:#fecaca;color:#991b1b}.modal-actions[data-v-01524203]{margin-top:14px;display:flex;justify-content:flex-end;gap:10px}.btn-ghost[data-v-01524203]{min-width:86px;height:40px;border-radius:10px;border:1px solid rgba(17,24,39,.2);background:#fff;color:#334155;font-size:13px;font-weight:700;cursor:pointer}@media(max-width:480px){.login-page[data-v-01524203]{align-items:flex-start;padding:16px 10px 10px}.login-container[data-v-01524203]{max-width:100%;padding:26px 18px;border-radius:14px}.login-header h1[data-v-01524203]{font-size:22px}.captcha-img[data-v-01524203]{height:42px}.captcha-refresh[data-v-01524203]{height:40px;padding:0 10px}.modal-card[data-v-01524203]{padding:14px}}
|