@particle-network/auth-core-modal
Version:
Auth Core provides MPC (Multi-Party Computation)-based threshold signatures.
178 lines (177 loc) • 9.55 kB
JavaScript
"use client";
import{a as U}from"./chunk-L4B4DLOJ.js";import{a as j}from"./chunk-5MT6UC7Z.js";import"./chunk-CA2ONM6K.js";import{a as O}from"./chunk-3GNUKO34.js";import{b as T}from"./chunk-6ART4FPU.js";import{a as q}from"./chunk-JLTVTEXA.js";import{H as I,Q as z,R as V,qa as D,ra as F,sa as G,ta as H}from"./chunk-CNYYVI6H.js";import"./chunk-L535NPP3.js";import{ApiError as m,AuthType as g,bindLoginAccount as he,getBindSecurityAccounCaptcha as ve,getCloudflareTurnstileResponse as xe,getSecurityAccountCaptcha as be,getSecurityAccountToken as Ce,setPaymentPassword as _e,syncUserInfo as J,thirdpartyAuth as we}from"@particle-network/auth-core";import{useInterval as Ae,useRequest as h}from"ahooks";import{Button as K,Modal as ke}from"antd";import Te from"base64url";import Le from"lodash/throttle.js";import o,{useCallback as Ne,useEffect as Q,useMemo as Se,useRef as Be,useState as b}from"react";import{useTranslation as Ee}from"react-i18next";var $=`.set-viery-container {
position: relative;
display: flex;
flex-direction: column;
align-items: center;
height: 100%;
overflow: auto;
color: var(--text-color);
}
.set-viery-container .footer-box {
position: absolute;
bottom: 10px;
margin: 0;
}
@media only screen and (max-height: 520px) {
.set-viery-container .footer-box {
position: unset;
bottom: 0;
margin-top: 20px;
margin-bottom: 10px;
}
}
.set-viery-container .display-none {
display: none;
}
.set-viery-container .error-tip {
width: 90%;
height: 0;
padding-left: 10px;
margin-top: 6px;
margin-bottom: 0;
text-align: left;
color: red;
opacity: 0;
transition: all 0.3s;
}
.set-viery-container .error-tip.show {
height: 30px;
opacity: 1;
}
.set-viery-container .set-email-title {
margin-top: 60px;
font-size: 22px;
color: var(--text-color);
}
.set-viery-container .patment-tips1 {
width: 80vw;
margin-top: 30px;
font-size: 14px;
text-align: center;
color: var(--text-color);
}
@media (min-width: 600px) {
.set-viery-container .patment-tips1 {
width: calc(80 * var(--vw));
}
}
.set-viery-container .set-email-buttons {
position: absolute;
bottom: 0;
left: 0;
display: flex;
flex-direction: column;
justify-content: flex-end;
align-items: center;
width: 100%;
height: auto;
padding-bottom: 20px;
}
.set-viery-container .success-icon {
width: 50px;
height: 50px;
margin-top: 60px;
}
.set-viery-container .set-email-desc-1 {
box-sizing: border-box;
padding: 0 18px;
margin: 15px 0 25px;
font-weight: 400;
font-size: 14px;
line-height: 16px;
text-align: center;
color: var(--text-color);
}
.set-viery-container .account-submit-btn {
width: 90%;
height: 47px;
padding: 0;
margin-top: 38px;
border: none;
border-radius: var(--primary-btn-border-radius);
font-weight: 500;
font-size: var(--primary-btn-font-size);
line-height: 47px;
text-align: center;
color: var(--primary-btn-color);
background: var(--primary-btn-background-color);
opacity: 1;
}
.set-viery-container .account-submit-btn:hover {
border: none;
color: var(--primary-btn-color) !important;
background: var(--primary-btn-background-color) !important;
opacity: var(--hover-opacity);
}
.set-viery-container .account-switch-item {
margin-top: 40px;
font-weight: 500;
font-size: 13px;
line-height: 19px;
color: var(--accent-color);
cursor: pointer;
}
.set-viery-container .set-email-desc-2 {
min-width: 116px;
height: 23px;
padding: 0 15px;
margin: 20px 0 28px;
border-radius: var(--primary-btn-border-radius);
font-weight: 400;
font-size: 12px;
line-height: 23px;
text-align: center;
color: var(--secondary-text-color);
background: var(--tag-background-color);
opacity: 1;
}
.set-viery-container .back {
display: flex;
align-items: center;
margin-top: 90px;
font-weight: 400;
font-size: 16px;
line-height: 19px;
color: var(--accent-color);
opacity: 1;
cursor: pointer;
gap: 8px;
}
.set-viery-container .back svg {
position: relative;
top: -1px;
color: var(--accent-color);
}
.set-viery-container .code-error {
position: absolute;
left: calc((100vw - 316px) / 2);
margin-top: 224px;
font-weight: 400;
font-size: 12px;
color: var(--error-color);
}
@media (min-width: 600px) {
.set-viery-container .code-error {
left: calc((var(--vw) * 100 - 316px) / 2);
}
}
.set-viery-container .send-again {
margin-top: 20px;
border: none !important;
outline: none !important;
font-weight: 400;
font-size: 16px;
line-height: 19px;
color: var(--text-color);
background-color: transparent;
box-shadow: none;
}
.set-viery-container .send-again:hover {
color: var(--text-color) !important;
background-color: transparent !important;
}
.set-viery-container .send-again:disabled {
opacity: 0.5;
}
`;var Me=R=>{let c=G(),{t:n}=Ee(),W=R,v=O(),{customRouter:X}=F(),{themeType:Y,language:Z}=I(),{account:a,pageType:d,authType:s,verifyToken:ee,redirectUrl:te,password:ne}=W,[x,oe]=b(""),[L,C]=b(1e3),[y,_]=b(60),[w,l]=b(),{authCoreModal:N}=D(),{userInfo:ie}=H(),S=Be(null);Ae(()=>{if(y>0){let e=y-1;_(e),e===0&&C(void 0)}},L);let{run:B}=h(async e=>d==="bind_login_account"?(e={[s]:a,cf_turnstile_response:e.cf_turnstile_response},ve(e).then(t=>t)):be(e.verifyCodeMethod),{manual:!0,onSuccess:(e,t)=>{L||(_(60),C(1e3))},onError:e=>{_(0),C(void 0)}}),{loading:re,runAsync:E}=h(Ce,{manual:!0,onError:e=>{(e==null?void 0:e.error_code)===m.InvalidCode?l(n("login.invalid_code")):(e==null?void 0:e.error_code)===m.ResendCode?l(n("login.please_send_again")):e.message&&v.error(e.message)}}),{loading:ae,runAsync:se}=h(async e=>he(e).then(async()=>{await J()}),{manual:!0,onSuccess:e=>{v.success(n("new.bind_login_account_success"))},onError:e=>{var i;let t=e.message;if((e==null?void 0:e.error_code)===m.InvalidCode){l(n("login.invalid_code"));return}else if((e==null?void 0:e.error_code)===m.ResendCode){l(n("login.please_send_again"));return}else e.error_code===20109?t=s==g.email?n("error.server_email_20109"):n("error.server_phone_20109"):t=((i=e==null?void 0:e.extra)==null?void 0:i[0])||e.message;ke.error({title:t,wrapClassName:"auth-core-modal-error",getContainer:()=>N.rootBody,onOk:()=>{var r;(r=S.current)==null||r.clear(),e.error_code===20109&&c(-1)}})}}),{loading:ce,run:le}=h(_e,{manual:!0,onError:e=>{(e==null?void 0:e.error_code)===m.InvalidCode?l(n("login.invalid_code")):(e==null?void 0:e.error_code)===m.ResendCode&&l(n("login.please_send_again"))},onSuccess:(e,t)=>{J();let i=["account/security","solana/sign","evm-chain/sign"],r=i.map(k=>{var u;return(u=X.history)==null?void 0:u.findIndex(p=>p.path===k)}),A=r.indexOf(Math.max(...r));c(i[A],{replace:!0,back:!0})}}),{loading:de,run:Pe}=h(()=>new Promise((e,t)=>{}),{manual:!0,onSuccess:e=>{}}),f=Se(()=>a!=null&&a.includes("@")?g.email:g.phone,[a]);Q(()=>{M()},[a]);let M=()=>{l(""),d==="bind_login_account"&&s===g.phone?xe({theme:Y,language:Z,getContainer:()=>N.rootBody}).then(e=>{B({verify_code_method:f,cf_turnstile_response:e})}).catch(()=>{v.error(n("error.server_20112")),c(-1)}):B({verifyCodeMethod:f})},ue=e=>{l(""),oe(e),e.length===6&&pe(e)},pe=Ne(Le(e=>{P(e)},1e3,{leading:!0,trailing:!1}),[]),me=e=>{le({password:ne,verifyCodeMethod:f,code:e||x})},P=(e="")=>{if(w)return;let t={code:e};d==="reset_payment_password"?me(e):d=="verify_security_account_set_security_account"?E({verifyCodeMethod:f,code:e}).then(i=>{c("/account/bind",{replace:!0,state:{accountType:s,verifyToken:i,redirectUrl:te}})}):d==="verify_security_account_bind_login_account"?E({verifyCodeMethod:f,code:e}).then(i=>{let r=j({userInfo:ie,t:n}),{id:A,value:k}=r.find(u=>u.type===s)||{};if(s===g.phone||s===g.email||k||A)c("/login-account/bind",{state:{authType:s,verifyToken:i},replace:!0});else{let u=Te.encode(JSON.stringify({verifyToken:i,purpose:"bindLoginAccount"}));we({authType:s,appState:u,prompt:"select_account"}).catch(p=>{v.error((p==null?void 0:p.message)||p)})}}):d==="bind_login_account"?(t={...t,security_account_verify_token:ee,[s]:a},se(t).then(i=>{c(-2)})):"unbind_login_account"},ge=()=>a.includes("@")?z(a):V(a);Q(()=>{var i;let e=document.getElementsByClassName("react-input-code"),t=r=>r.preventDefault();return(i=e[0])==null||i.addEventListener("contextmenu",t),()=>{var r;(r=e[0])==null||r.removeEventListener("contextmenu",t)}},[]);let ye=()=>{var t;(t=document.getElementsByClassName("input-code-item")[Math.min(x.length,5)])==null||t.focus()};return o.createElement("div",{className:"set-viery-container"},o.createElement("style",null,$),o.createElement("div",{className:"account-header"},o.createElement(T,{className:"icon-navigation-back",name:"circle_back",onClick:()=>{c(-1)}})),o.createElement("h2",{className:"set-email-title"},n("account.enter_code")),o.createElement("p",{className:"set-email-desc-2"},ge()),o.createElement("div",{onClick:ye},o.createElement(U,{containerClassName:"react-input-code",inputClassName:"input-code-item",allowedCharacters:"numeric",length:6,ref:S,placeholder:" ",onChange:ue})),w&&o.createElement("div",{className:"code-error"},w),o.createElement(K,{className:"account-submit-btn",loading:ce||re||ae||de,onClick:()=>{setTimeout(()=>{P(x)})},disabled:x.length!==6},n("common.confirm")),o.createElement(K,{className:"send-again",onClick:M,disabled:y>0},y>0?`${n("login.send_again")} (${y}s)`:n("login.send_again")),o.createElement("div",{className:"back",onClick:()=>{c(-1)}},o.createElement(T,{className:"arrow1-icon",name:"arrow1_icon"}),o.createElement("span",null,n("login.back"))),o.createElement(q,null))},Xe=Me;export{Xe as default};