Files
zsglpt/static/app/assets/LoginPage-Cz6slTnR.js
237899745 f46f325518 fix(frontend): 修复登录失败时通知弹两次的问题
- 在登录页面不再由 http.js 拦截器弹出 401 通知
- 让 LoginPage.vue 自己处理登录错误的显示
- 避免同一错误消息重复弹出
2026-01-21 19:45:43 +08:00

2 lines
7.9 KiB
JavaScript

import{_ as Z,r as $,a as r,c as ee,o as ae,b as S,d as a,w as t,e as g,u as te,f,g as v,h as k,i as h,j as z,k as d,E as u}from"./index-CPwwGffH.js";import{f as le,l as se,g as j,a as oe,r as ne}from"./auth--ytvFYf6.js";const re={class:"auth-wrap"},ie={class:"captcha-row"},ue=["src"],ce={class:"links"},de={class:"foot"},pe={class:"captcha-row"},me=["src"],fe={class:"captcha-row"},ve=["src"],ge={__name:"LoginPage",setup(ye){const H=te(),i=$({username:"",password:"",captcha:""}),w=r(!1),C=r(""),N=r(""),P=r(!1),y=r(!1),F=r(!1),_=r(!1),b=r(!1),p=$({username:"",captcha:""}),x=r(""),I=r(""),T=r(!1),V=r(""),m=$({email:"",captcha:""}),U=r(""),K=r(""),W=r(!1),A=ee(()=>!!F.value);async function E(){try{const l=await j();N.value=l?.session_id||"",C.value=l?.captcha_image||"",i.captcha=""}catch{N.value="",C.value=""}}async function R(){try{const l=await j();I.value=l?.session_id||"",x.value=l?.captcha_image||"",p.captcha=""}catch{I.value="",x.value=""}}async function B(){try{const l=await j();K.value=l?.session_id||"",U.value=l?.captcha_image||"",m.captcha=""}catch{K.value="",U.value=""}}async function M(){if(!i.username.trim()||!i.password.trim()){u.error("用户名和密码不能为空");return}if(w.value&&!i.captcha.trim()){u.error("请输入验证码");return}P.value=!0;try{await se({username:i.username.trim(),password:i.password,captcha_session:N.value,captcha:i.captcha.trim(),need_captcha:w.value}),u.success("登录成功,正在跳转...");const l=new URLSearchParams(window.location.search||""),e=String(l.get("next")||"").trim(),o=e&&e.startsWith("/")&&!e.startsWith("//")&&!e.startsWith("/\\")?e:"";setTimeout(()=>{const n=o||"/app";H.push(n).catch(()=>{window.location.href=n})},300)}catch(l){const e=l?.response?.status,o=l?.response?.data,n=o?.error||o?.message||"登录失败";u.error(n),o?.need_captcha?(w.value=!0,await E()):w.value&&e===400&&await E()}finally{P.value=!1}}async function D(){_.value=!0,V.value="",p.username="",p.captcha="",y.value&&await R()}async function G(){if(V.value="",!y.value){u.warning("邮件功能未启用,请联系管理员重置密码。");return}const l=p.username.trim();if(!l){u.error("请输入用户名");return}if(!p.captcha.trim()){u.error("请输入验证码");return}T.value=!0;try{const e=await oe({username:l,captcha_session:I.value,captcha:p.captcha.trim()});u.success(e?.message||"已发送重置邮件"),setTimeout(()=>{_.value=!1},800)}catch(e){const o=e?.response?.data,n=o?.error||"发送失败";o?.code==="email_not_bound"?V.value=n:u.error(n),await R()}finally{T.value=!1}}async function J(){b.value=!0,m.email="",m.captcha="",await B()}async function Q(){const l=m.email.trim();if(!l){u.error("请输入邮箱");return}if(!m.captcha.trim()){u.error("请输入验证码");return}W.value=!0;try{const e=await ne({email:l,captcha_session:K.value,captcha:m.captcha.trim()});u.success(e?.message||"验证邮件已发送,请查收"),setTimeout(()=>{b.value=!1},800)}catch(e){const o=e?.response?.data;u.error(o?.error||"发送失败"),await B()}finally{W.value=!1}}function X(){H.push("/register")}return ae(async()=>{try{const l=await le();y.value=!!l?.email_enabled,F.value=!!l?.register_verify_enabled}catch{y.value=!1,F.value=!1}}),(l,e)=>{const o=g("el-input"),n=g("el-form-item"),c=g("el-button"),O=g("el-form"),Y=g("el-card"),L=g("el-alert"),q=g("el-dialog");return f(),S("div",re,[a(Y,{shadow:"never",class:"auth-card","body-style":{padding:"22px"}},{default:t(()=>[e[17]||(e[17]=v("div",{class:"brand"},[v("div",{class:"brand-title"},"知识管理平台"),v("div",{class:"brand-sub app-muted"},"用户登录")],-1)),a(O,{"label-position":"top"},{default:t(()=>[a(n,{label:"用户名"},{default:t(()=>[a(o,{modelValue:i.username,"onUpdate:modelValue":e[0]||(e[0]=s=>i.username=s),placeholder:"请输入用户名",autocomplete:"username"},null,8,["modelValue"])]),_:1}),a(n,{label:"密码"},{default:t(()=>[a(o,{modelValue:i.password,"onUpdate:modelValue":e[1]||(e[1]=s=>i.password=s),type:"password","show-password":"",placeholder:"请输入密码",autocomplete:"current-password",onKeyup:z(M,["enter"])},null,8,["modelValue"])]),_:1}),w.value?(f(),k(n,{key:0,label:"验证码"},{default:t(()=>[v("div",ie,[a(o,{modelValue:i.captcha,"onUpdate:modelValue":e[2]||(e[2]=s=>i.captcha=s),placeholder:"请输入验证码",onKeyup:z(M,["enter"])},null,8,["modelValue"]),C.value?(f(),S("img",{key:0,class:"captcha-img",src:C.value,alt:"验证码",title:"点击刷新",onClick:E},null,8,ue)):h("",!0),a(c,{onClick:E},{default:t(()=>[...e[11]||(e[11]=[d("刷新",-1)])]),_:1})])]),_:1})):h("",!0)]),_:1}),v("div",ce,[a(c,{text:"",type:"primary",onClick:D},{default:t(()=>[...e[12]||(e[12]=[d("忘记密码?",-1)])]),_:1}),A.value?(f(),k(c,{key:0,text:"",type:"primary",onClick:J},{default:t(()=>[...e[13]||(e[13]=[d("重发验证邮件",-1)])]),_:1})):h("",!0)]),a(c,{type:"primary",class:"submit-btn",loading:P.value,onClick:M},{default:t(()=>[...e[14]||(e[14]=[d("登录",-1)])]),_:1},8,["loading"]),v("div",de,[e[16]||(e[16]=v("span",{class:"app-muted"},"还没有账号?",-1)),a(c,{link:"",type:"primary",onClick:X},{default:t(()=>[...e[15]||(e[15]=[d("立即注册",-1)])]),_:1})])]),_:1}),a(q,{modelValue:_.value,"onUpdate:modelValue":e[6]||(e[6]=s=>_.value=s),title:"找回密码",width:"min(560px, 92vw)"},{footer:t(()=>[a(c,{onClick:e[5]||(e[5]=s=>_.value=!1)},{default:t(()=>[...e[19]||(e[19]=[d("取消",-1)])]),_:1}),a(c,{type:"primary",loading:T.value,disabled:!y.value,onClick:G},{default:t(()=>[...e[20]||(e[20]=[d(" 发送重置邮件 ",-1)])]),_:1},8,["loading","disabled"])]),default:t(()=>[y.value?(f(),k(L,{key:1,type:"info",closable:!1,title:"通过邮箱找回密码",description:"输入用户名并完成验证码,我们将向该账号绑定的邮箱发送重置链接。","show-icon":""})):(f(),k(L,{key:0,type:"warning",closable:!1,title:"邮件功能未启用",description:"无法通过邮箱找回密码,请联系管理员重置密码。","show-icon":""})),V.value?(f(),k(L,{key:2,type:"warning",closable:!1,title:"无法通过邮箱找回密码",description:V.value,"show-icon":"",class:"alert"},null,8,["description"])):h("",!0),a(O,{"label-position":"top",class:"dialog-form"},{default:t(()=>[a(n,{label:"用户名"},{default:t(()=>[a(o,{modelValue:p.username,"onUpdate:modelValue":e[3]||(e[3]=s=>p.username=s),placeholder:"请输入用户名"},null,8,["modelValue"])]),_:1}),a(n,{label:"验证码"},{default:t(()=>[v("div",pe,[a(o,{modelValue:p.captcha,"onUpdate:modelValue":e[4]||(e[4]=s=>p.captcha=s),placeholder:"请输入验证码"},null,8,["modelValue"]),x.value?(f(),S("img",{key:0,class:"captcha-img",src:x.value,alt:"验证码",title:"点击刷新",onClick:R},null,8,me)):h("",!0),a(c,{onClick:R},{default:t(()=>[...e[18]||(e[18]=[d("刷新",-1)])]),_:1})])]),_:1})]),_:1})]),_:1},8,["modelValue"]),a(q,{modelValue:b.value,"onUpdate:modelValue":e[10]||(e[10]=s=>b.value=s),title:"重发验证邮件",width:"min(520px, 92vw)"},{footer:t(()=>[a(c,{onClick:e[9]||(e[9]=s=>b.value=!1)},{default:t(()=>[...e[22]||(e[22]=[d("取消",-1)])]),_:1}),a(c,{type:"primary",loading:W.value,onClick:Q},{default:t(()=>[...e[23]||(e[23]=[d("发送",-1)])]),_:1},8,["loading"])]),default:t(()=>[a(L,{type:"info",closable:!1,title:"用于注册邮箱验证:请输入邮箱并完成验证码。","show-icon":""}),a(O,{"label-position":"top",class:"dialog-form"},{default:t(()=>[a(n,{label:"邮箱"},{default:t(()=>[a(o,{modelValue:m.email,"onUpdate:modelValue":e[7]||(e[7]=s=>m.email=s),placeholder:"name@example.com"},null,8,["modelValue"])]),_:1}),a(n,{label:"验证码"},{default:t(()=>[v("div",fe,[a(o,{modelValue:m.captcha,"onUpdate:modelValue":e[8]||(e[8]=s=>m.captcha=s),placeholder:"请输入验证码"},null,8,["modelValue"]),U.value?(f(),S("img",{key:0,class:"captcha-img",src:U.value,alt:"验证码",title:"点击刷新",onClick:B},null,8,ve)):h("",!0),a(c,{onClick:B},{default:t(()=>[...e[21]||(e[21]=[d("刷新",-1)])]),_:1})])]),_:1})]),_:1})]),_:1},8,["modelValue"])])}}},_e=Z(ge,[["__scopeId","data-v-9eb557e5"]]);export{_e as default};