@authing/react-ui-components 4.4.1-alpha.9 → 4.4.2-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/index.min.css +2 -2
- package/lib/index.min.js +1 -1
- package/package.json +9 -9
- package/types/CompleteInfo/interface.d.ts +4 -1
- package/types/CompleteInfo/utils.d.ts +6 -0
- package/types/ForgetPassword/core/resetPassword.d.ts +1 -0
- package/types/Guard/core/hooks/useMultipleAccounts.d.ts +4 -2
- package/types/Guard/event.d.ts +2 -1
- package/types/Guard/module.d.ts +1 -0
- package/types/IdentityBinding/businessRequest.d.ts +1 -1
- package/types/Login/hooks/useLoginMultiple.d.ts +2 -1
- package/types/Register/core/WithEmail.d.ts +1 -2
- package/types/SelectAccount2Login/index.d.ts +3 -0
- package/types/Type/application.d.ts +1 -4
- package/types/Type/index.d.ts +1 -0
- package/types/_utils/GuardErrorCode.d.ts +1 -0
- package/types/_utils/context.d.ts +2 -1
- package/types/_utils/guardHttp.d.ts +1 -1
- package/types/_utils/http.d.ts +0 -2
- package/types/_utils/index.d.ts +5 -4
- package/types/_utils/responseManagement/interface.d.ts +2 -2
- package/types/version/version.d.ts +1 -1
- package/dist/asset-manifest.json +0 -26
- package/dist/index.html +0 -1
- package/dist/static/css/2.839329b5.chunk.css +0 -3
- package/dist/static/css/2.839329b5.chunk.css.map +0 -1
- package/dist/static/css/main.98fc077f.chunk.css +0 -2
- package/dist/static/css/main.98fc077f.chunk.css.map +0 -1
- package/dist/static/js/2.acd455a5.chunk.js +0 -3
- package/dist/static/js/2.acd455a5.chunk.js.LICENSE.txt +0 -124
- package/dist/static/js/2.acd455a5.chunk.js.map +0 -1
- package/dist/static/js/3.ca746d7e.chunk.js +0 -2
- package/dist/static/js/3.ca746d7e.chunk.js.map +0 -1
- package/dist/static/js/main.59425d4f.chunk.js +0 -2
- package/dist/static/js/main.59425d4f.chunk.js.map +0 -1
- package/dist/static/js/runtime-main.5d2cd96c.js +0 -2
- package/dist/static/js/runtime-main.5d2cd96c.js.map +0 -1
- package/dist/static/media/loading.3cf0104f.svg +0 -32
- package/types/Login/hooks/useOtpPushLogin.d.ts +0 -10
- package/types/_utils/workflowHandleStorage.d.ts +0 -4
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["components/_utils/guardDocument.ts","components/Type/application.ts","reportWebVitals.ts","components/_utils/locales/index.ts","components/Guard/core/useAppendConfig.tsx","components/_utils/appendConfig.ts","components/IconFont/iconfont.ts","components/IconFont/index.tsx","components/_utils/context.tsx","components/ChangeLanguage/index.tsx","components/_utils/popupCenter.ts","components/_utils/index.ts","components/_utils/logger/interface.ts","components/_utils/corsVerification.ts","components/_utils/logger/index.ts","components/Guard/module.ts","components/_utils/config/index.ts","components/Guard/authClient.ts","components/Type/index.ts","components/AuthClientProvider/context.tsx","components/AuthClientProvider/AuthClientProvider.tsx","components/version/version.tsx","components/version/index.tsx","components/Guard/event.ts","components/Login/interface.ts","components/Register/interface.ts","components/ShieldSpin/loading.svg","components/Guard/GuardModule/stateMachine.ts","components/ShieldSpin/index.tsx","components/Guard/config.tsx","components/_utils/flowHandleStorage.ts","components/_utils/http.ts","components/_utils/responseManagement/index.ts","components/_utils/guardHttp.ts","components/_utils/GuardErrorCode.ts","components/Guard/sso.ts","components/Guard/core/hooks/useMultipleAccounts.ts","components/_utils/tenant.ts","components/Guard/core/renderContext.tsx","components/_utils/initAppId.ts","components/IconFont/useGuardIconfont.ts","components/_utils/hooks/index.ts","components/BindTotp/businessRequest.ts","components/GuardButton/GuardButton.tsx","components/SubmitButton/index.tsx","components/MFA/interface.ts","components/BindTotp/core/bindSuccess.tsx","components/ImagePro/index.tsx","components/MFA/VerifyCodeInput/VerifyCodeFormItem.tsx","components/MFA/VerifyCodeInput/index.tsx","components/BindTotp/core/securityCode.tsx","components/BindTotp/index.tsx","components/Back/index.tsx","components/Guard/core/hooks/useGuardView.ts","components/ValidatorRules/useCheckRepeat.ts","components/ValidatorRules/ValidatorFormItem.tsx","components/ValidatorRules/index.ts","components/ValidatorRules/PasswordFormItem.tsx","components/ChangePassword/businessRequest.ts","components/InputPassword/index.tsx","components/_utils/useErrorText.tsx","components/ChangePassword/core/completePassword.tsx","components/CompleteInfo/interface.ts","components/ChangePassword/core/firstLoginReset.tsx","components/ChangePassword/core/rotateReset.tsx","components/ChangePassword/core/PasswordNotSafeReset.tsx","components/ChangePassword/index.tsx","components/CompleteInfo/businessRequest.ts","components/InputNumber/index.tsx","components/SendCode/SendCodeBtn.tsx","components/SendCode/index.tsx","components/SendCode/SendCodeByEmail.tsx","components/SendCode/SendCodeByPhone.tsx","components/_utils/countryList.ts","components/Login/core/withVerifyCode/VirtualDropdown.tsx","components/Login/core/withVerifyCode/InputInternationPhone.tsx","components/UploadImage/index.tsx","components/CompleteInfo/core/completeInfo.tsx","components/DownloadAuthenticator/index.tsx","components/CompleteInfo/utils.tsx","components/CompleteInfo/index.tsx","components/ForgetPassword/core/resetPassword.tsx","components/Error/index.tsx","components/Login/core/withVerifyCode/FormItemIdentify.tsx","components/ForgetPassword/core/inputIdentify.tsx","components/ForgetPassword/InputPassword/index.tsx","components/ForgetPassword/index.tsx","components/Login/core/withPassword/FormItemAccount.tsx","components/Login/core/withPassword/InputAccount.tsx","components/Login/core/withPassword/GraphicVerifyCode.tsx","components/Register/components/Agreements/index.tsx","components/Guard/core/hooks/useAgreements.ts","components/Login/hooks/useLoginMultiple.ts","components/_utils/getCaptchaUrl.ts","components/Login/core/withPassword/index.tsx","components/Login/core/withLDAP.tsx","components/Login/core/withAD.tsx","components/Qrcode/UiQrCode.tsx","components/Qrcode/hooks/useStatus.tsx","components/Qrcode/hooks/useImage.ts","components/Qrcode/hooks/usePreQrCode.ts","components/Qrcode/WorkQrCode.tsx","components/Qrcode/hooks/usePostQrCode.ts","components/Qrcode/index.ts","components/Login/core/withAppQrcode.tsx","components/Login/resetAccountName/businessRequest.ts","components/Login/core/withWechatMiniQrcode.tsx","components/Login/core/withWechatmpQrcode.tsx","components/Login/codemap.ts","components/Login/socialLogin/IdpButton/index.tsx","components/Login/socialLogin/index.tsx","components/Login/socialLogin/postMessage.ts","components/Login/multipleAccounts/panel.tsx","components/Login/multipleAccounts/index.tsx","components/Login/resetAccountName/index.tsx","components/Login/core/withVerifyCode/inputIdentify.tsx","components/Login/core/withVerifyCode/index.tsx","components/Login/core/withAuthingOtpPush/PushLoginGuideSelector.tsx","components/LazyloadImage/index.tsx","components/Login/core/withAuthingOtpPush/HowBindClient.tsx","components/Login/core/withAuthingOtpPush/HowUsePushLogin.tsx","components/Login/core/withAuthingOtpPush/HowGetAppLoginUrl.tsx","components/Login/core/withAuthingOtpPush/PushLoginGuideModal.tsx","components/Login/core/withAuthingOtpPush/BeforeLogin.tsx","components/Login/core/withAuthingOtpPush/PendingLogin.tsx","components/Login/core/withAuthingOtpPush/index.tsx","components/Login/index.tsx","components/MFA/businessRequest.ts","components/_utils/facePlugin/index.ts","components/_utils/errorFace.ts","components/MFA/core/email.tsx","components/MFA/core/sms.tsx","components/MFA/core/face_deps.tsx","components/RecoveryCode/businessRequest.ts","components/MFA/core/face.tsx","components/MFA/core/totp.tsx","components/MFA/mfaMethods/index.tsx","components/MFA/codemap.ts","components/MFA/index.tsx","components/NeedHelpView/core/describeQuestions.tsx","components/NeedHelpView/index.tsx","components/RecoveryCode/core/saveCode.tsx","components/IdentityBinding/businessRequest.ts","components/RecoveryCode/core/useCode.tsx","components/RecoveryCode/index.tsx","components/Register/utils.ts","components/Register/core/WithEmail.tsx","components/Register/core/WithCode.tsx","components/Register/index.tsx","components/SubmitSuccess/index.tsx","components/SelfUnlock/core/selfUnlock.tsx","components/IdentityBinding/IdentityBinding.tsx","components/IdentityBindingAsk/IdentityBindingAsk.tsx","components/Guard/core/renderModule.tsx","components/SelfUnlock/index.tsx","components/SelectAccount/index.tsx","components/GuardFace/index.tsx","components/GuardSelect/index.tsx","components/TenantPortalSelect/index.tsx","components/NewSubmitSuccess/index.tsx","components/_utils/responseManagement/interface.ts","components/Guard/core/usePlugin.ts","components/Guard/core/index.tsx","components/Guard/Guard.tsx","examples.tsx"],"names":["guardDocument","LoginMethods","OIDCConnectionMode","SocialConnectionProvider","Protocol","RegisterMethods","RegisterSortMethods","reportWebVitals","onPerfEntry","Function","then","getCLS","getFID","getFCP","getLCP","getTTFB","LanguageResources","translation","enUsTrans","zhCnTrans","zhTwTrans","jaJpTrans","fallbackLng","code","fallbacks","startsWith","push","includes","toLocaleLowerCase","initGuardI18n","options","callback","a","defaultLanguage","detectionOrder","lng","undefined","i18nOptions","detection","order","lookupLocalStorage","resources","debug","interpolation","escapeValue","i18n","use","LanguageDetector","initReactI18next","init","getGuardDocument","getGuardWindow","window","guardWindow","defaultView","useInitGuardAppendConfig","setForceUpdate","appId","appendConfig","useEffect","Date","now","initAppendConfig","publicConfig","setPublicConfig","pageConfig","setPageConfig","GenerateSvg","svgString","svgDOM","tempDiv","createElement","innerHTML","tempSVG","getElementsByTagName","setAttribute","id","style","position","width","height","overflow","body","firstChild","insertBefore","appendChild","readyState","setTimeout","addEventListener","loadedFn","removeEventListener","IconFont","type","className","getClassnames","xlinkHref","DefaultGuardX","finallyConfig","defaultMergedConfig","httpClient","initData","currentModule","events","isAuthFlow","contextLoaded","guardPageConfig","multipleInstance","isMultipleAccount","instance","referMultipleState","multipleAccountData","clearBackFillData","phoneRegex","defaultLanguageConfig","tenantInstance","isForeignUserpool","GuardXContext","React","createContext","GuardButtonContext","spin","spinChange","useGuardButtonState","useContext","useGuardPublicConfig","useGuardHttpClient","useGuardAppId","useGuardTenantId","tenantId","useGuardInitData","useGuardCurrentModule","useGuardEvents","useGuardModule","guardX","changeModule","backModule","useGuardFinallyConfig","useGuardIsAuthFlow","useGuardMultipleInstance","useGuardPhoneRegex","useGuardDefaultLanguage","useRobotVerify","customSecurityEnabled","appRobotVerify","userpoolRobotVerify","useIsForeignUserpool","LngTextMapping","label","ChangeLanguage","props","langRange","onLangChange","useTranslation","onChangeLng","useCallback","changeLanguage","showChangeLng","useMemo","global","showChangeLanguage","currentLng","Object","keys","language","currentLngText","lngMenu","menuItem","filter","map","key","isCurrent","Item","onClick","length","overlay","trigger","placement","overlayClassName","getPopupContainer","node","parentElement","popupCenter","url","w","h","document","dualScreenLeft","screenLeft","screenX","dualScreenTop","screenTop","screenY","innerWidth","documentElement","clientWidth","screen","innerHeight","clientHeight","systemZoom","availWidth","left","top","newWindow","open","focus","VALIDATE_PATTERN","email","phone","ip","host","username","validate","val","test","fieldRequiredRule","fieldRequiredRuleMessage","required","validateTrigger","message","t","name","whitespace","getDeviceName","userAgent","navigator","platform","os","indexOf","insertedRecord","appConfig","userConfig","classnames","Boolean","join","PasswordStrength","getUserRegisterParams","params","query","qs","parse","location","search","ignoreQueryPrefix","value","item","isWeChatBrowser","isLarkBrowser","isDingtalkBrowser","isSpecialBrowser","match","parser","UAParser","browser","LoggerType","PASSWORD_STRENGTH_TEXT_MAP","NoCheck","placeholder","validateMessage","Low","Middle","High","AUTO","SYMBOL_TYPE_PATTERNS","getSymbolTypeLength","pwd","pattern","getPasswordValidate","strength","customPasswordStrength","getCustomPassword","zhMessageOpen","zhMessage","enMessageOpen","enMessage","jaMessageOpen","jaMessage","jpMessageOpen","jpMessage","twMessageOpen","twMessage","validateMap","validator","r","v","Promise","reject","resolve","regex","sleep","delay","transformMethod","method","Phone","EmailCode","Email","getDocumentNode","nodeName","parentNode","getLoginTypePipe","registerMethod","loginTabs","list","verifyCodeTabMethods","verifyCodeTabConfig","enabledLoginMethods","passwordTabMethods","passwordTabConfig","PhoneCode","specifyDefaultLoginMethod","lockMethod","Password","getPasswordIdentify","identity","getCurrentLng","languages","getI18nLabel","i18nFields","lang","split","get","getSortLabels","methods","i18nConfig","labels","forEach","getSortTabs","tabs","tab","findIndex","splice","unshift","isOriginMatched","whitelist","corsWhitelist","origin","wildcard","require","some","allowedOrigin","corsVerification","allowedOrigins","allowed","Error","Logger","INFO","log","console","JSON","stringify","this","WARN","ERROR","printType","GuardModuleType","publicConfigMap","getPublicConfig","config","pageConfigMap","getPageConfig","requestPublicConfig","res","error","data","setUserpoolId","userPoolId","requestGuardPageConfig","mergedPublicConfig","autoRegister","ssoPageComponentDisplay","autoRegisterThenLoginHintInfo","registerMethods","validRegisterMethods","concat","transformSortMethod","title","logo","loginMethods","passwordLoginMethods","validLoginMethods","defaultLoginMethod","default","disableResetPwd","forgetPasswordBtn","registerTabs","defaultRegisterMethod","disableRegister","registerBtn","publicKey","agreementEnabled","agreements","contentCss","css","assembledRequestHost","__internalRequest__","requestHostname","configHost","identifier","hostUrl","URL","splitHost","hostname","shift","port","protocol","utilAssembledRequestHost","authClient","GuardMode","AuthClientContext","useGlobalAuthClient","authClientContext","client","version","checkAuthClientProps","useGuardAuthClient","getGuardAuthClient","guardEventsFilter","openEventsMapping","eventsNameWhiteList","eventName","oldEvents","wrapperEvents","user","setUserInfo","guardEventsHijacking","eventsMapping","onLogin","success","token","setToken","password","encryptedPassword","setCurrentUser","onRegister","newEvents","eventsKey","InputMethod","GuardPageSene","EmailScene","defaultG2Config","escCloseable","clickCloseable","mode","Normal","getDefaultG2Config","defaultConfig","getDefaultRegisterConfig","_extends","assign","target","i","arguments","source","prototype","hasOwnProperty","call","apply","_objectWithoutProperties","excluded","sourceKeys","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","propertyIsEnumerable","transform","fillRule","strokeWidth","d","SvgLoading","_ref","svgRef","titleId","viewBox","xmlns","xmlnsXlink","ref","ActionType","ForwardRef","ShieldSpin","size","customLoading","src","alt","Spin","isSSO","defaultInitData","showLoading","_closeLoopCheckQrcode","loadingComponent","flowHandleStorage","GuardStateMachine","changeModuleEvent","moduleStateHistory","stateMachineLog","uninstallPopstate","globalWindow","onPopstate","next","nextModule","moduleData","moduleName","prevModuleData","slice","isUseHistoryHijack","history","pushState","href","isEqual","back","historyPush","end","actionType","ChangeModule","action","date","getTime","dataSource","historyBack","Back","setConfig","Init","getFlowHandle","updateFlowHandle","flowHandle","requestClient","fetch","json","timeoutAction","cancel","timer","path","headers","langHeader","tenantHeader","CancelToken","Axios","race","baseUrl","addQueryPrefix","withCredentials","cancelToken","post","postForm","formData","setBaseUrl","base","replace","DEFAULT_LANG_HEADER","setLangHeader","setTenantHeader","setTenantId","InterceptorName","errorCodeInterceptor","callBack","statusCode","num","apiCode","Math","floor","ApiCode","FLOW_END","CodeAction","CHANGE_MODULE","RENDER_MESSAGE","ErrorCode","GuardHttp","responseInterceptorMap","Map","getHeaders","responseIntercept","authFlow","requestData","initErrorCodeInterceptor","has","ERROR_CODE","set","Array","from","values","reduce","acc","cur","getRequestClient","userpoolId","getGuardHttp","useGuardHttp","trackSession","MULTIPLE_ACCOUNT_KEY","MULTIPLE_ACCOUNT_LISTS","QR_CODE_WAY","EXCLUDE_CODE_WAY","MultipleAccount","originAccount","originWay","originStore","currentStore","initStore","serverSideLoginMethods","isInternationSms","localStorage","getItem","getCurrentStore","initMemberState","backfillData","memberState","firstBackFillData","memberStateCount","qrCount","normalCount","initBackfillData","initWay","wayLists","find","way","account","getAccountByWay","qrCodeId","phoneCountryCode","areaCode","getServerLoginMethodByFront","front","ldap","ad","result","create","entries","passMethod","validateMethod","validateInternationSms","cloneDeep","currentIsInternationSms","serverWay","setLoginWay","internation","tabStatus","loginWay","photo","nickname","loginAccount","_updateTime","saveStore","newStore","setItem","setLoginWayByHttpData","setLoginWayByLDAPData","delUserById","getMemoUser","excludeWays","_mappingUser","sort","b","getMemoSingleUser","userId","currentUser","description","parseInt","getStore","getMemberState","getFirstBackFillData","getOriginAccount","getOriginWay","useMultipleAccounts","useState","setMultipleAccount","setMultipleAccountData","storeInstance","setStoreInstance","changeMultipleState","updateBackFillData","initFirstState","enableLoginAccountSwitch","configLists","internationalSmsConfig","enabled","MultipleTenant","getCurrentTenantId","$tenantId","getCurrentTenantInfo","$config","tenantInfo","isTenantConsole","isTenantSSO","isTenantDefault","isTenantSSOLaunchPad","RenderContext","guardProps","initState","children","forceUpdate","setEvents","authClint","setAuthClint","setHttpClient","cdnBase","setCdnBase","setError","setIsAuthFlow","i18nInit","setI18nInit","propsAppid","propsAuthClient","globalAuthClient","useInitAppId","setDefaultLanguageConfig","setIsForeignUserpool","guardStateMachine","setGuardStateMachine","Provider","Consumer","useReducer","state","payload","moduleState","onChangeModule","onBeforeChangeModule","mergedConfig","setMergedConfig","useMergeDefaultConfig","guardHttp","initGuardHttp","setAppId","initPublicConfig","all","useFetchConsoleConfig","useMultipleTenant","sdkClient","globalClient","setClient","AuthenticationClient","appHost","requestFrom","onError","msg","useInitGuardAuthClient","iconfontLoaded","loaded","setLoaded","initIconfont","useGuardIconfont","sessionData","typedData","userInfo","styles","recordKey","styleElt","styleSheet","createStyleSheet","head","styleSheets","cssText","selector","insertRule","rule","addRule","insertStyles","removeChild","removeStyles","__unAuthFlow__","catch","moduleEvents","str","regexRules","userpoolLevel","string","exec","RegExp","regexFromString","onLoad","contextValues","renderContext","RenderErrorContext","onLoadError","SocialConnectionEvent","HIDE_SOCIALS","HIDE_SOCIALS_SHOWIN_ENTERPRISE","useMediaSize","isPhoneMedia","useMediaQuery","maxWidth","parsePhone","fieldValue","countryCode","phoneNumber","country","isValid","BindTotpBusinessAction","useMethod","enterpriseConnectionObjs","socialConnectionObjs","noLoginMethods","enterpriseConnections","identityProviders","socialConnections","socials","provider","connection","hiddenSocialConnection","wechatDisplayButtonsMessage","WECHATPC","GITHUB","QQ","APPLE_WEB","ALIPAY","LINKEDIN","BAIDU","GOOGLE","WEIBO","FACEBOOK","SLACK","DINGTALK","hiddenSocialConnectionInWeChatBrowser","Message","Auth","qqbuiltDisplayButtonsMessage","WECHATMP","WECHATWORK_CORP_QRCONNECT","hiddenSocialConnectionInQQBuiltInBrowser","weWorkBuiltDisplayButtonsMessage","hiddenSocialConnectionInWeWorkBuiltInBrowser","dingTalkDisplayButtonsMessage","hiddenSocialConnectionInDingtalkBrowser","larkDisplayButtonsMessage","hiddenSocialConnectionInLarkBrowser","pcDisplayButtonsMessage","hiddenSocialConnectionInPCBrowser","isHost","postMessage","isNoMethod","socialLoginBtns","idpBtns","GuardButton","isLockButtonClick","buttonClassName","e","SubmitButton","buttonSpin","setSpin","shaking","setShaking","inputs","getElementsByClassName","saftyCode","bindTotpSecretSave","MountShaking","input","classList","add","agreement","UnMountShaking","remove","useShaking","timeOut","clearTimeout","useImperativeHandle","text","onSpin","sp","propsCls","htmlType","loading","disabled","forwardRef","MFAType","content","Paragraph","BindSuccess","secret","onBind","submitButtonRef","useRef","useForm","form","bindSuccess","current","validateFields","ConfirmTotpRecoveryCode","isFlowEnd","onGuardHandling","copyable","onFinish","onFinishFailed","rules","_","valuePropName","ImagePro","borderRadius","noSpin","imgProps","draggable","ImagePro2","maskRef","onMouseMove","marginRight","fill","clip-path","VerifyCodeFormItem","codeLength","ruleKeyword","formItemProps","validateFirst","min","VerifyCodeInput","gutter","onEenter","showDivider","onChangeProps","onChange","rest","inputRef","codeInputRef","fromClipboard","verifyCode","setVerifyCode","focusIndex","setFocusIndex","codes","handleChange","index","isNaN","String","el","pasteEvent","preventDefault","stopPropagation","paste","clipboardData","getData","_i","onFocus","minWidth","minHeight","lineHeight","marginLeft","autoFocus","onKeyDown","evt","currentVal","handleKeyDown","maxLength","persist","nativeEvent","isComposing","nextValue","preValue","changeValue","SecurityCode","mfaToken","qrcode","onNext","useAsyncFn","getFieldValue","VerifyTotpFirstTime","totp","authenticator_type","authorization","bindTotp","textAlign","color","cursor","DOWNLOAD_AT","onSubmitCapture","BindTotpType","BackLogin","onBack","LOGIN","isRender","renderBack","REGISTER","defaultScenes","fontSize","display","BackCustom","useGuardView","currentTab","changeTab","$$guard","viewContext","currentView","onAfterChangeModule","GuardBindTotpView","setSecret","setQrcode","setUser","SECURITY_CODE","bindTotpType","setBindTotpType","LOGIN_INVALID","recovery_code","qrcode_data_url","bindInfo","fetchBindInfo","renderContent","BIND_SUCCESS","MFA","TOTP","resUser","useCheckRepeat","checkFn","setTimer","timeout","ValidatorFormItem","checkRepeat","checkExist","isCheckPattern","checkInternationalSms","methodContent","field","checkRepeatErrorMessage","formatErrorMessage","checkExistErrorMessage","checkRepeatFn","formatRules","CustomFormItem","FormItem","fromItemProos","passwordStrength","userPasswordStrength","userCustomPasswordStrength","UserName","CustomName","ChangePasswordBusinessAction","InputPassword","autoComplete","iconRender","visible","alignItems","usePasswordErrorText","show","setPasswordErrorTextShow","getPassWordUnsafeText","marginBottom","CompletePassword","businessRequestName","isChangeComplete","onRegisterSuccess","onRegisterFailed","encrypt","encryptFunction","REGISTER_COMPLETE_INFO","postUserInfoPipeline","UNSAFE_PASSWORD_TIP","onRegisterError","prefix","FormValidateRule","CompleteInfoBaseControls","CompleteInfoExtendsControls","OmitCompleteInfo","FirstLoginReset","onReset","newPassword","ABORT_FLOW","resetPasswordByFirstLoginToken","RotateReset","onFinishCallBack","oldPassword","ResetPassword","resetPasswordByForceResetToken","PasswordNotSafeReset","ResetPasswordStrengthDetection","GuardChangePassword","explain","typeContent","GuardFirstLoginPasswordResetView","coreForm","GuardPasswordNotSafeResetView","GuardForcedPasswordResetView","number","forcedCycle","GuardNoticePasswordResetView","GuardRegisterCompletePasswordView","CompleteInfoAuthFlowAction","isPhone","propsValue","InputNumber","inputProps","setValue","valueChange","SendCodeBtn","sendDesc","beforeSend","btnRef","setSent","buttonProps","effect","countDown","setCountDown","timerRef","clearInterval","send","setInterval","prev","useSentCounter","setLoading","time","SendCode","autoSubmit","justify","align","span","submit","offset","SendCodeByEmail","scene","onSendCodeBefore","fieldName","remainProps","sendEmail","status","tips","onEmailSend","onEmailSendError","SendCodeByPhone","codeFieldName","captchaCode","sendPhone","onPhoneSend","onPhoneSendError","isoInfo","iso","regions","regions_en","VirtualDropdown","info","region","region_en","showSearch","dropdownClassName","bordered","listHeight","optionLabelProp","dropdownMatchSelectWidth","filterOption","option","toLowerCase","suffixIcon","InputInternationPhone","onAreaCodeChange","formValue","UploadImage","uploading","setUploading","uploadButton","PlusOutlined","marginTop","accept","listType","showUploadList","file","response","errMsg","spinning","MomentPicker","CompleteInfo","metaData","businessRequest","verifyCodeLength","countryList","setCountryList","defaultISOType","setAreaCode","loadInitCountryList","countryMap","zh","en","PhoneAccount","baseControlMap","gender","image","datetime","select","dropdown","boolean","internalControlMap","SceneType","SCENE_TYPE_COMPLETE_PHONE","INFORMATION_COMPLETION_VERIFY_CODE","getMetaDateLabel","fieldsI18n","extendsFieldsI18n","generateRules","formRules","validateRules","DATE_TIME","errorMessage","replaceAll","inputElement","userFormItem","formFieldsV2","fieldKeys","fieldValues","baseData","phoneCode","emailCode","checkResult","checkCode","valid","checkMessage","layout","DownloadType","fnName","profile","phoneToken","emailToken","registerSkipMethod","registerRequest","registerFnName","registerContent","registerProfile","Skip","Complete","fieldValuesToRegisterProfile","extendsFields","udf","fieldType","GuardCompleteInfo","skipComplateFileds","skipLoading","setSkipLoading","onSkip","GuardLoginCompleteInfoView","skip","resData","GuardRegisterCompleteInfoView","selectOptions","setSelectOptions","setMetaData","loadSelectOptions","onRegisterInfoCompleted","onRegisterInfoCompletedError","inputType","extendsFieldsToMetaData","InputMethodMap","GuardDownloadATView","downloadConfig","IOS","google","microsoft","Android","renderTab","TabPane","defaultActiveKey","GuardErrorView","propsInitData","guardXInitData","messages","justifyContent","backgroundImage","backgroundSize","dangerouslySetInnerHTML","__html","FindMethodConversion","FormItemIdentify","currentMethod","checkValue","renderTemplate","InputIdentify","verifyCodeMethodsText","renderInput","identify","setIdentify","codeMethod","setCodeMethod","context","setPhoneOrEmailText","setPolicyStrength","setCustomPasswordStrength","setControlShow","setResetToken","resetPasswordToken","SCENE_TYPE_RESET","RESET_PASSWORD_VERIFY_CODE","InputPasswordForget","GuardForgetPassword","controlShow","policyStrength","phoneOrEmailText","resetToken","needBack","goBack","submitBtnRef","getFieldsValue","repeatPassword","onPwdResetError","onPwdReset","New_SUBMIT_SUCCESS","customValidateTrigger","getPasswordValidateRules","FormItemAccount","validPasswordLoginMethods","formItemPtops","runderTemplate","InputAccount","runderInput","GraphicVerifyCode","verifyCodeUrl","changeCode","Agreements","showError","acceptList","setAcceptList","checkedAgreements","agreementsContext","checkAllAgreements","unCheckAllAgreements","useAgreements","isAccept","every","checked","useLoginMultipleBackFill","formKey","isOnlyInternationSms","cancelBackfill","changeCurrentMethod","parseFillData","matchLoginWay","setFieldsValue","getCaptchaUrl","pathname","LoginWithPassword","onLoginFailed","onLoginSuccess","saveIdentify","_firstItemInitialValue","acceptedAgreements","setAcceptedAgreements","validated","setValidated","robotVerify","showCaptcha","setShowCaptcha","setVerifyCodeUrl","remainCount","setRemainCount","accountLock","setAccountLock","loginRequest","loginInfo","onLoginRequest","loginData","mergeAdAndAccountPasswordLogin","trim","customData","withCustomData","onBeforeLogin","onLoginRes","INPUT_CAPTCHACODE","PASSWORD_ERROR","ACCOUNT_LOCK","MULTIPLE_ERROR_LOCK","handMode","submitText","submitButText","registerDisabled","i18nMap","tabMethodsFields","onValuesChange","changedValues","initialValue","LoginWithLDAP","captchaUrl","LDAP","addonAfter","LoginWithAD","AD","encryptPassword","api","credentials","fetchRes","userPasswordInput","QrCode","descriptions","containerStyle","imageStyle","onClickMaskEl","onMaskContent","classes","ready","already","expired","useStatus","statusCls","statusComponent","preFetchImage","axios","responseType","blob","fileReader","FileReader","onload","base64","readAsDataURL","useImage","classPrefix","Loading","cloneElement","UiQrCode","memo","reducer","WorkQrCodeComponent","sleepTime","onStatusChange","onClickMaskContent","qrCodeScanOptions","extIdpConnId","genCodeRequest","autoMergeQrCode","random","dispatch","usePreQrCode","checkedRequest","exchangeUserInfo","ticket","request","destroy","readyCheckedRequest","alreadyCheckedRequest","getStatusByRes","processReady","uniteRequestHandler","processAReady","processSuccess","processExpired","processCancel","processMFA","processError","emitEvents","processFlowByResponse","changeStatus","processResponseFlow","processLoading","flowHandlers","handler","useQrCode","referQrCode","formatterDescriptions","formatDescriptions","parseKey","processDefaultMaskClick","UI","ResetAccountBusinessAction","LoginWithAppQrcode","codeRef","canLoop","AppQr","scannedResult","LoginWithWechatMiniQrcode","WxMinQr","LoginWithWechatmpQrcode","WechatMpQrcode","codeMap","APP_MFA_CODE","module","OTP_MFA_CODE","totpMfaEnabled","IDENTITY_BINDING","IDENTITY_BINDING_ASK","LOGIN_COMPLETE_INFO","IDENTITY_BINDING_NO_ASK","RESET_ACCOUNT_NAME","baseLoginPathMapping","OIDC","SAML","CAS","OAUTH","AZURE_AD","AD_KERBEROS","loginUrlFieldMapping","IdpButton","initUrl","from_guard","app_id","guard_version","tenant_id","from_hosted_guard","redirected","redirect_url","iconType","block","icon","displayName","name_en","basePath","renderBtn","SocialLogin","onMessage","event","parsedMessage","authingCode","authingMessage","authingResData","usePostMessage","onPostMessage","idpButtons","socialLoginButtons","querystring","shape","socialConnectionsBtnShape","tooltip","overlayStyle","fontFamily","idp","socialLogin","direction","flex","SelectPanel","lists","handleDel","triggerWay","finallyLists","operation","element","onDel","renderLits","triggerNode","MultipleAccountsFC","setState","MultipleAccounts","ResetAccountName","ResetName","LoginWithVerifyCode","_lockMethod","setCurrentMethod","setInternationSms","changeMethod","SCENE_TYPE_LOGIN","LOGIN_VERIFY_CODE","loginByPhoneCode","reqContent","loginByEmailCode","AreaCodePhoneAccount","PushLoginGuideSelector","defaultValue","showArrow","LazyloadImage","loadStatus","setLoadStatus","Image","HowBindClient","qrcodeInfo","padding","boxSizing","backgroundColor","HowUsePushLogin","HowGetAppLoginUrl","PushLoginGudeModal","onClose","howBindClient","howGetAppLoginUrl","howUsePushLogin","setSelector","selectorOptions","componentMap","closeIcon","BeforeLogin","onPushSuccess","signinByPush","pushLoginStatus","setAccount","onPushLogin","_message","pushCodeId","setVisible","authingOtpPushTabConfig","onchangePushLoginStatus","PendingLogin","background","border","onCancelLogin","LoginWithAuthingOtpPush","loginStatus","setLoginStatus","setPushCodeId","setPushLoginStatus","clearTimer","checkPushCodeStatus","getUserInfo","accessToken","access_token","tokenSet","_userInfo","AuthingOtpPush","loginStatusMap","before","defaultAccount","pending","MfaBusinessAction","inputWays","qrcodeWays","computedTabName","substring","GuardLoginView","isResetPage","dlm","propsMethods","intersection","useMethods","defaultMethod","renderInputWay","renderQrcodeWay","multipleQrWay","onBackFillData","qrCodeDefaultTab","useLayoutEffect","defaultQrWay","useLoginMultiple","setCanLoop","qrcodeTabsSettings","errorNumber","setErrorNumber","identifyRef","tenantProvider","tags","ms","firstInputWay","firstQRcodeWay","useDisables","hiddenTab","scanLogins","defaultQrCodeWay","isDefault","onLoginError","switchText","inputNone","qrcodeNone","useSwitchStates","agree","availableAt","verifyLoginMethods","containerDOM","innerContainer","querySelector","loginMethodsI18nDisplaySettings","passwordI18n","verifyCodeI18n","adI18n","ldapI18n","PasswordTab","CodeTab","LdapTab","ADTab","WxMiniQrTab","AppQrTab","WechatMpQrTab","AuthingOtpPushTab","tabMap","GeneralLoginComponent","total","tabName","QrCodeTabMap","CodeLoginComponent","qrCodeMap","loginMethodsSort","qrCodeSortConfig","sortWithType","welcomeMessage","it","destroyInactiveTabPane","k","onLoginTabChange","activeKey","FORGET_PWD","margin","ANY_QUESTIONS","facePluginInstance","FaceErrorName","VerifyEmail","VerifySms","VerifyTotp","VerifyFace","AssociateFace","photoA","photoB","isExternalPhoto","useMfaBusinessRequest","isFlow","BindMFAEmail","VerifyMFAEmail","onVerify","sendCodeRef","sent","sendVerifyCode","MFA_VERIFY_CODE","mfaCode","mail","mailArr","substr","mailName","mailDesensitization","MFAEmail","userEmail","mfaLogin","setEmail","click","BindMFASms","VerifyMFASms","userPhone","phoneDesensitization","sendSmsCode","SCENE_TYPE_MFA_VERIFY","MFASms","mfaPhone","mfaPhoneCountryCode","setPhone","getFacePlugin","devicesConstraints","video","getFaceDetectorOptions","facePlugin","TinyFaceDetectorOptions","inputSize","scoreThreshold","getCurrentFaceDetectionNet","nets","tinyFaceDetector","dataURItoBlob","base64Data","byteString","atob","unescape","mimeString","ia","Uint8Array","charCodeAt","Blob","TotpRecoveryCodeBusinessAction","MFAFace","mfaBackContext","MFABackStateContext","faceState","setFaceState","percent","setPercent","mfaBusinessRequest","verifyRequest","bindRequest","videoRef","canvasRef","interval","p1","p2","cooldown","dashStyle","useDashoffset","_FACE_SCORE","mfa","faceScore","loadFromUri","mediaDevices","getUserMedia","stream","srcObject","NotAllowedError","SecurityError","OverconstrainedError","faceErrorMessage","mfaBackState","setShowMethods","uploadImage","FormData","append","getBase64","videoDom","canvas","ctx","getContext","clearRect","drawImage","toDataURL","faceBind","faceCheck","quitIdentifying","faceMfaEnabled","goToCheckScene","goToBindScene","autoShoot","paused","ended","detectSingleFace","score","setMfaBackState","autoPlay","muted","playsInline","strokeDasharray","strokeDashoffset","cx","cy","opacity","BindMFATotp","BIND_TOTP","VerifyMFATotp","RECOVERY_CODE","MFATotp","methodTitleMapping","EMAIL","SMS","FACE","MFAMethods","onChangeMethod","applicationMfa","otherMethods","mfaPolicy","2021","1700","1701","1702","500","6001","602","ComponentsMapping","mfaEmail","GuardMFAView","showMethods","__codePaser","m","__message","DescribeQuestions","typeProblemMap","0","1","2","3","4","5","6","typeOperations","uploadUrl","setUploadUrl","previewVisible","setPreviewVisible","previewImage","setPreviewImage","fileList","setFileList","typeProblem","setTypeProblem","textMap","handlePreview","reader","originFileObj","images","onSuccess","Option","TextArea","showCount","rows","onPreview","imgUrl","beforeUpload","itemRender","n","showInfo","footer","onCancel","GuardNeedHelpView","SUBMIT_SUCCESS","IdentityBindingBusinessAction","IdentityBindingAction","SaveCode","UseCode","onSubmit","RecoveryTotp","recoveryCode","RecoveryCode","setCode","RecoveryCodeAuthFlow","setRecoveryCode","GuardRecoveryCodeView","useIsChangeComplete","currentMode","complateFiledsPlace","omit","RegisterWithEmail","onBeforeRegister","registeContext","device","forceLogin","generateToken","clientIp","onRegisterSuccessIntercept","registerFrom","AccountForm","RegisterWithCode","isPhoneChangeComplete","isEmailChangeComplete","setCaptchaCode","registerByPhoneCode","needPassword","enableCompletePassword","REGISTER_PASSWORD","errMessage","registerByEmailCode","registerMessage","SCENE_TYPE_REGISTER","REGISTER_VERIFY_CODE","GuardRegisterView","verifyRegisterMethods","registerContextProps","registerInfo","loginInitData","registerContext","tabMapping","verifyCodeLogin","component","setActiveKey","filterRegisterMethods","Set","onRegisterTabChange","GuardSubmitSuccessView","__changeModule","countDesc","useIdentityBindingBusinessRequest","BindByPhoneCode","RegisterByPhoneCode","BindByEmailCode","RegisterByEmailCode","BindByPassword","RegisterByPassword","GuardIdentityBindingView","skipAsk","bindType","phoneCodeRequest","emailCodeRequest","PasswordRequest","bindMethodsMap","onBinding","onBindingError","loginMethodsBase","codeLoginMethods","bindText","GuardIdentityBindingAskView","onCreate","onCreateError","CreateUser","createLoading","createAccount","LangMAP","SelfUnlock","defaultEmail","defaultPhone","selfUnlockStrategy","encryptPassWord","SELF_UNLOCKING_VERIFY_CODE","GuardUnlockView","GuardSelectAccountView","renderList","accounts","GuardFace","avatar","avatarProps","tag","GuardSelect","onSelect","gap","listProps","classNames","renderItem","actions","extra","Meta","GuardTenantPortalSelectView","http","handleSelect","onTenantSelect","tenantName","userName","tenantLogo","GuardNewSubmitSuccessView","PREFIX_CLS","prefixCls","langMap","zhCn","zhCN","enUs","enUS","jaJp","jaJP","RenderModule","GuardButtonProvider","useGuardButtonContext","FIRST_LOGIN_PASSWORD","NOTICE_PASSWORD_RESET","FORCED_PASSWORD_RESET","SELF_UNLOCK","UNSAFE_PASSWORD_RESET","FLOW_SELECT_ACCOUNT","TENANT_PORTAL","codeAction","ChangeModuleApiCodeMapping","nextData","newData","renderModule","toString","renderGuardContent","locale","Modal","closable","keyboard","maskClosable","getContainer","useGuardFacePlugin","guardFace","initFacePlugin","GuardCore","plugin","useGuardPlugin","propsAreEqual","pre","preAttribute","currentAttribute","GuardPropsFilter","Guard","guardWindowMount","mounted","initGuardDocument","APP_MFA","COMPLETE_INFO","UNLOCK","App","err","ReactDOM","render","getElementById"],"mappings":"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","file":"static/js/main.59425d4f.chunk.js","sourcesContent":["let guardDocument: Document\n\nexport const getGuardDocument = (): Document => {\n return guardDocument\n}\n\nexport const useAppendConfig = getGuardDocument\n\nexport const initGuardDocument = (document: Document) => {\n guardDocument = document\n}\n","import { Lang } from '..'\nimport { PasswordStrength } from '../_utils'\nexport * from 'authing-js-sdk'\n\nexport enum LoginMethods {\n LDAP = 'ldap',\n AppQr = 'app-qrcode',\n Password = 'password',\n PhoneCode = 'phone-code',\n WxMinQr = 'wechat-miniprogram-qrcode', // 对应社会化登录的 wechat:miniprogram:qrconnect(小程序扫码登录)\n AD = 'ad', // 对应企业身份源的 Windows AD 登录\n WechatMpQrcode = 'wechatmp-qrcode', // 微信扫码关注登录\n AuthingOtpPush = 'authing-otp-push', // App 扫码登录\n}\n\nexport enum OIDCConnectionMode {\n FRONT_CHANNEL = 'FRONT_CHANNEL',\n BACK_CHANNEL = 'BACK_CHANNEL',\n}\n\nexport enum SocialConnectionProvider {\n ALIPAY = 'alipay',\n GOOGLE = 'google',\n WECHATPC = 'wechat:pc',\n WECHATMP = 'wechat:webpage-authorization',\n WECHAT_MINIPROGRAM = 'wechat:miniprogram:default',\n WECHAT_MINIPROGRAM_QRCODE = 'wechat:miniprogram:qrconnect',\n WECHAT_MINIPROGRAM_APPLAUNCH = 'wechat:miniprogram:app-launch',\n WECHATMOBILE = 'wechat:mobile',\n GITHUB = 'github',\n QQ = 'qq',\n WECHATWORK_ADDRESS_BOOK = 'wechatwork:addressbook',\n WECHATWORK_CORP_QRCONNECT = 'wechatwork:corp:qrconnect',\n WECHATWORK_SERVICEPROVIDER_QRCONNECT = 'wechatwork:service-provider:qrconnect',\n DINGTALK = 'dingtalk',\n WEIBO = 'weibo',\n APPLE = 'apple',\n APPLE_WEB = 'apple:web',\n LARK_PUBLIC = 'lark-public',\n LARK_INTERNAL = 'lark-internal',\n BAIDU = 'baidu',\n LINKEDIN = 'linkedin',\n SLACK = 'slack',\n YIDUN = 'yidun',\n QINGCLOUD = 'qingcloud',\n FACEBOOK = 'facebook',\n}\n\nexport enum Protocol {\n AD = 'ad',\n CAS = 'cas',\n LDAP = 'ldap',\n OIDC = 'oidc',\n SAML = 'saml',\n OAUTH = 'oauth',\n AZURE_AD = 'azure-ad',\n AD_KERBEROS = 'ad-kerberos',\n}\n\nexport interface IOAuthConnectionConfig {\n authEndPoint: string\n tokenEndPoint: string\n scope: string\n clientId: string\n clientSecret: string\n authUrlTemplate: string\n codeToTokenScript: string\n tokenToUserInfoScript: string\n tokenToUserInfoScriptFuncId: string\n codeToTokenScriptFuncId: string\n authUrl?: string // 根据模板拼接出来的授权 url\n}\n\nexport interface IAzureAdConnectionConfig {\n microsoftAzureAdDomain: string\n clientId: string\n syncUserProfileOnLogin: string\n emailVerifiedDefault: boolean\n authorizationUrl: string\n callbackUrl: string\n}\n\nexport interface ISamlConnectionConfig {\n signInEndPoint: string\n samlRequest?: string\n\n // saml assertion 验签公钥\n\n samlIdpCert: string\n\n // saml request 验签公钥\n\n samlSpCert: string\n\n // saml request 签名私钥\n\n samlSpKey: string\n\n signOutEndPoint: string\n\n signSamlRequest: boolean\n\n signatureAlgorithm: string\n\n digestAlgorithm: string\n\n protocolBinding: string\n}\n\nexport interface ICasConnectionConfig {\n casConnectionLoginUrl: string\n}\n\nexport interface SocialConnectionItem {\n name: string\n name_en: string\n displayName: string\n logo: string\n description: string\n identifier: string\n provider: SocialConnectionProvider\n authorizationUrl: string\n tooltip: Record<Lang, string>\n}\n\nexport enum RegisterMethods {\n Email = 'email',\n Phone = 'phone',\n EmailCode = 'emailCode',\n}\n\nexport enum RegisterSortMethods {\n Email = 'email-password',\n Phone = 'phone-code',\n EmailCode = 'email-code',\n}\n\nexport interface QrCodeItem {\n id: string\n title: string\n isDefault?: boolean\n}\n\nexport type QrcodeTabsSettings = Record<LoginMethods, Array<QrCodeItem>>\n\nexport interface OidcClientMetadata {\n grant_types: string[]\n client_id: string\n redirect_uris: string[]\n scope: string\n response_types: ResponseType[]\n}\n\nexport interface OIDCConnectionConfig {\n issuerUrl: string\n authorizationEdpoint: string\n responseType: string\n mode: OIDCConnectionMode\n clientId: string\n clientSecret: string\n scopes: string\n redirectUri: string\n}\n\nexport interface InternalExtendsField {\n type: 'internal'\n name: string\n label: string\n inputType: string\n required: boolean\n validateRules: any[]\n}\n\nexport interface UserExtendsField {\n type: 'user'\n id: string\n name: string\n label: string\n inputType: string\n required: boolean\n validateRules: any[]\n}\n\nexport type ExtendsField = InternalExtendsField | UserExtendsField\n\n// 密码登录注册支持\nexport interface ApplicationPasswordTabConfig {\n enabledLoginMethods?: PasswordLoginMethods[]\n validRegisterMethods?: string[]\n validLoginMethods?: string[]\n}\n\n// 验证码登录注册支持\nexport interface ApplicationVerifyCodeTabConfig {\n enabledLoginMethods: VerifyLoginMethods[]\n validRegisterMethods?: string[]\n validLoginMethods?: string[]\n}\n\nexport interface Agreement {\n id: number\n title: string\n required: boolean\n lang: Lang\n availableAt?: number\n}\n\nexport type PasswordLoginMethods =\n | 'username-password'\n | 'email-password'\n | 'phone-password'\n\nexport type VerifyLoginMethods = 'email-code' | 'phone-code'\n\nexport type ComplateFiledsPlace = 'register' | 'login'\n\nexport interface TabFieldsI18nItem {\n key: string\n label: string\n labelEn: string\n i18n: {\n [propName in Lang]?: string\n }\n}\n\ninterface LoginTypeI18nProps {\n tab: {\n default: string\n i18n: {\n [propName: string]: string\n }\n }\n}\n\nexport interface ApplicationConfig {\n id: string\n allowedOrigins: string[]\n corsWhitelist: string[]\n cdnBase: string\n userPoolId: string\n rootUserPoolId: string\n publicKey: string\n internationalSmsConfig?: {\n enabled: boolean\n defaultISOType: string\n }\n // 登录框自定义 css 代码\n css: string\n customLoading?: string\n name: string\n logo: string\n description?: string\n redirectUris: string[]\n registerDisabled: boolean\n mergeAdAndAccountPasswordLogin: boolean\n registerTabs: {\n list: string[]\n default: string\n title: { [x: string]: string }\n }\n registerTabsConfig: {\n list: string[]\n default: string\n title: { [x: string]: string }\n registerTypeConfig: {\n emailRegisterType?: RegisterMethods[]\n phoneRegisterType?: RegisterMethods[]\n }\n }\n\n qrcodeTabsSettings: QrcodeTabsSettings\n\n qrCodeSortConfig: {\n loginMethodsSort?: string[]\n }\n\n loginTabs: {\n list: string[]\n default: string\n defaultV2?: string\n title: { [x: string]: string }\n }\n socialConnections: SocialConnectionItem[]\n\n complateFiledsPlace: ComplateFiledsPlace[]\n extendsFieldsEnabled: boolean\n extendsFields: ExtendsField[]\n extendsFieldsI18n?: {\n [key: string]: Record<Lang, { enabled: boolean; value: string }>\n }\n\n identifier: string\n requestHostname: string\n identityProviders: {\n identifier: string\n protocol: Protocol\n displayName: string\n logo: string\n config:\n | ISamlConnectionConfig\n | OIDCConnectionConfig\n | ICasConnectionConfig\n | IAzureAdConnectionConfig\n | IOAuthConnectionConfig\n }[]\n\n ssoPageComponentDisplay: {\n autoRegisterThenLoginHintInfo: boolean\n forgetPasswordBtn: boolean\n idpBtns: boolean\n loginBtn: boolean\n loginByPhoneCodeTab: boolean\n loginByUserPasswordTab: boolean\n loginMethodNav: boolean\n phoneCodeInput: boolean\n registerBtn: boolean\n registerByEmailTab: boolean\n registerByPhoneTab: boolean\n registerMethodNav: boolean\n socialLoginBtns: boolean\n userPasswordInput: boolean\n wxMpScanTab: boolean\n loginMethodsI18nDisplaySettings: {\n password?: LoginTypeI18nProps\n verifyCode?: LoginTypeI18nProps\n ad?: LoginTypeI18nProps\n ldap?: LoginTypeI18nProps\n }\n }\n\n protocol: Protocol\n oidcConfig: OidcClientMetadata\n passwordTabConfig: ApplicationPasswordTabConfig\n verifyCodeTabConfig?: ApplicationVerifyCodeTabConfig\n\n agreementEnabled: boolean\n agreements: Agreement[]\n customPasswordStrength: any\n passwordStrength: PasswordStrength\n verifyCodeLength: number\n websocket: string\n welcomeMessage: any\n\n skipComplateFileds: boolean\n\n selfUnlockStrategy: 'captcha' | 'password-captcha'\n\n defaultLanguageConfig: Lang\n /**\n * 是否开启账号切换\n */\n enableLoginAccountSwitch: boolean\n /**\n * 是否开启注册密码补全\n */\n enableCompletePassword: boolean\n /**\n * 登录注册排序\n */\n tabMethodsSortConfig: {\n loginMethodsSort: string[]\n }\n // i18n\n tabMethodsFields: TabFieldsI18nItem[]\n\n regexRules?: { key: string; appLevel: string; userpoolLevel: string }[]\n /** 是否为租户控制台应用 */\n isTenantConsole?: boolean\n\n /** 是否默认为租户应用面板应用 */\n isTenantDefault?: boolean\n\n /** 租户详情 */\n tenantInfo?: Record<string, any>\n\n /** mfa 相关 */\n mfa: {\n faceScore: number\n }\n\n authingOtpPushTabConfig: {\n enabledLoginMethods: Array<string> | null\n validLoginMethods: Array<string> | null\n validRegisterMethods: Array<string> | null\n }\n /** 是否开启自定义安全规则 */\n customSecurityEnabled: boolean\n /** 应用的人机验证策略,始终开启、不开启、设置条件触发 */\n appRobotVerify: 'always_enable' | 'disable' | 'condition_set'\n /** 用户池的人机验证策略,始终开启、不开启、设置条件触发 */\n userpoolRobotVerify: 'always_enable' | 'disable' | 'condition_set'\n}\n","import { ReportHandler } from 'web-vitals'\n\nconst reportWebVitals = (onPerfEntry?: ReportHandler) => {\n if (onPerfEntry && onPerfEntry instanceof Function) {\n import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\n getCLS(onPerfEntry)\n getFID(onPerfEntry)\n getFCP(onPerfEntry)\n getLCP(onPerfEntry)\n getTTFB(onPerfEntry)\n })\n }\n}\n\nexport default reportWebVitals\n","import i18n, { InitOptions, Resource } from 'i18next'\nimport { initReactI18next } from 'react-i18next'\nimport LanguageDetector from 'i18next-browser-languagedetector'\nimport * as enUsTrans from './en-us'\nimport * as zhCnTrans from './zh-cn'\nimport * as zhTwTrans from './zh-tw'\nimport * as jaJpTrans from './ja-jp'\nimport { Lang } from '../../Type'\n\nconst LanguageResources: Resource = {\n 'en-US': { translation: enUsTrans },\n 'zh-CN': { translation: zhCnTrans },\n 'zh-TW': { translation: zhTwTrans },\n 'ja-JP': { translation: jaJpTrans },\n}\n\nexport interface InitGuardI18nOptions {\n // 默认显示\n defaultLanguage?: Lang | 'browser'\n}\n\n// fackbackLang\n\nexport const fallbackLng = (code = '') => {\n if (!code || code === 'en') return ['en-US']\n\n if (!code || code === 'zh') return ['zh-CN']\n\n if (!code || code === 'ja') return ['ja-JP']\n\n const fallbacks = []\n\n if (code.startsWith('en-')) {\n fallbacks.push(`en-US`)\n return fallbacks\n }\n\n if (code.startsWith('ja-')) {\n fallbacks.push(`ja-JP`)\n return fallbacks\n }\n\n if (code.startsWith('zh-')) {\n if (\n ['zh-tw', 'zh-hk', 'zh-mo', 'zh-hant'].includes(code.toLocaleLowerCase())\n ) {\n fallbacks.push(`zh-TW`)\n } else if (['zh-cn', 'zh-sg', 'zh-my'].includes(code.toLocaleLowerCase())) {\n fallbacks.push(`zh-CN`)\n } else {\n fallbacks.push(`zh-CN`)\n }\n\n return fallbacks\n }\n\n return ['en-US']\n}\n\nexport const initGuardI18n = async (\n options: InitGuardI18nOptions,\n callback: React.Dispatch<React.SetStateAction<boolean>>\n) => {\n const { defaultLanguage } = options\n\n const detectionOrder: string[] = []\n\n let lng: Lang | undefined = undefined\n\n // 如果需要跟随浏览器语言, 则添加到监测顺序\n if (defaultLanguage === 'browser') {\n detectionOrder.push(\n ...[\n 'querystring',\n 'cookie',\n 'navigator',\n 'localStorage', //不保存用户所选语言 刷新重新走浏览器语言检测\n 'htmlTag',\n 'path',\n 'subdomain',\n ]\n )\n } else {\n // 此处 defaultLanguage 可能为 Lng 也可能是 undefined\n lng = defaultLanguage\n }\n\n // 统一拼装一下 i18n 的 options\n const i18nOptions: InitOptions = {\n // 默认语言\n lng,\n detection: {\n order: detectionOrder,\n lookupLocalStorage: '_guard_i18nextLng', //与console主要业务i18n相关的key脱离\n },\n resources: LanguageResources,\n // 兜底语言\n fallbackLng,\n debug: false,\n interpolation: {\n escapeValue: false,\n },\n }\n\n // 开始初始化了嗷~\n await i18n.use(LanguageDetector).use(initReactI18next).init(i18nOptions)\n // 告知外部i18n初始化完成\n callback(true)\n}\n\nexport { i18n }\n","import { useEffect } from 'react'\nimport { GuardAppendConfig, setPublicConfig } from '../..'\nimport { initAppendConfig } from '../../_utils/appendConfig'\nimport { setPageConfig } from '../../_utils/config'\nimport { getGuardDocument } from '../../_utils/guardDocument'\n\nexport const getGuardWindow = () => {\n if (typeof window === 'undefined') {\n return undefined\n }\n\n const guardDocument = getGuardDocument()\n\n const guardWindow = guardDocument?.defaultView\n\n if (guardWindow) {\n return guardWindow\n }\n\n return window\n}\n\nexport const useGuardWindow = getGuardWindow\n\nexport const useInitGuardAppendConfig = (\n setForceUpdate: any,\n appId?: string,\n appendConfig?: GuardAppendConfig\n) => {\n useEffect(() => {\n if (!appId) return\n setForceUpdate(Date.now())\n\n initAppendConfig(appendConfig)\n\n if (appendConfig?.publicConfig) {\n setPublicConfig(appId, appendConfig.publicConfig)\n }\n\n if (appendConfig?.pageConfig) {\n setPageConfig(appId, appendConfig.pageConfig)\n }\n }, [appId, appendConfig, setForceUpdate])\n}\n","import { GuardAppendConfig } from '..'\n\nlet appendConfigMapping: GuardAppendConfig\n\nexport const getAppendConfig = (): GuardAppendConfig => {\n return appendConfigMapping\n}\n\nexport const useAppendConfig = getAppendConfig\n\nexport const initAppendConfig = (appendConfig: GuardAppendConfig = {}) => {\n appendConfigMapping = appendConfig\n}\n","export const GenerateSvg = (guardDocument: Document, svgString: string) => {\n const svgDOM = () => {\n const tempDiv = guardDocument.createElement('div')\n\n tempDiv.innerHTML = svgString\n\n const tempSVG = tempDiv.getElementsByTagName('svg')[0]\n\n tempSVG.setAttribute('aria-hidden', 'true')\n tempSVG.id = 'guard-svg-string'\n tempSVG.style.position = 'absolute'\n tempSVG.style.width = '0'\n tempSVG.style.height = '0'\n tempSVG.style.overflow = 'hidden'\n\n const body = guardDocument.body\n\n body.firstChild\n ? body.insertBefore(tempSVG, body.firstChild)\n : body.appendChild(tempSVG)\n }\n\n const readyState = guardDocument.readyState\n\n if (['complete', 'loaded', 'interactive'].includes(readyState)) {\n setTimeout(() => {\n svgDOM()\n }, 0)\n } else {\n const loadedFn = function () {\n guardDocument.removeEventListener('DOMContentLoaded', loadedFn)\n\n svgDOM()\n }\n\n guardDocument.addEventListener('DOMContentLoaded', loadedFn)\n }\n}\n","import React, { FC } from 'react'\nimport { getClassnames } from '../_utils'\nimport './iconfont'\nimport './style.less'\n\nexport const IconFont: FC<{\n type: string\n style?: React.CSSProperties\n className?: string\n}> = ({ type, style, className }) => {\n return (\n <svg style={{ ...style }} className={getClassnames(['g2-icon', className])}>\n <use xlinkHref={`#${type}`}></use>\n </svg>\n )\n}\n","import React, { ReactNode, useContext, useMemo } from 'react'\nimport {\n GuardEvents,\n GuardLocalConfig,\n GuardModuleType,\n GuardPageConfig,\n Lang,\n} from '..'\nimport {\n BackFillMultipleState,\n StoreInstance,\n} from '../Guard/core/hooks/useMultipleAccounts'\nimport { ModuleState } from '../Guard/GuardModule/stateMachine'\nimport { ApplicationConfig } from '../Type/application'\nimport { GuardHttp } from './guardHttp'\nimport { MultipleTenant } from './tenant'\n\nexport interface IGuardContext {\n finallyConfig: GuardLocalConfig\n\n defaultMergedConfig: GuardLocalConfig\n\n publicConfig: ApplicationConfig\n\n httpClient: GuardHttp\n\n appId: string\n\n tenantId?: string\n\n initData: any\n\n currentModule: ModuleState\n\n events: Partial<GuardEvents>\n\n changeModule?: (moduleName: GuardModuleType, initData?: any) => Promise<void>\n\n backModule?: () => void\n\n isAuthFlow: boolean\n\n contextLoaded: boolean\n\n guardPageConfig: Partial<GuardPageConfig>\n\n multipleInstance: {\n /**\n * 多账号相关\n */\n isMultipleAccount: boolean\n /**\n * when: 多账号页面跳转进入登录页面\n * 携带的回填数据信息\n */\n multipleAccountData?: BackFillMultipleState\n /**\n * 多账号 store 实例\n */\n instance?: StoreInstance\n /**\n * 切换多账号 isMultipleAccount 状态\n */\n referMultipleState?: (type: 'login' | 'multiple') => void\n /**\n * 清空回填数据\n */\n clearBackFillData?: () => void\n }\n\n phoneRegex: RegExp | null\n defaultLanguageConfig: Lang\n /** 租户信息获取和操作处理相关 */\n tenantInstance?: MultipleTenant\n\n /** 判断是否是国外的用户池 */\n isForeignUserpool: boolean\n}\n\nconst DefaultGuardX: IGuardContext = {\n finallyConfig: {} as GuardLocalConfig,\n\n defaultMergedConfig: {} as GuardLocalConfig,\n\n publicConfig: {} as ApplicationConfig,\n\n httpClient: {} as GuardHttp,\n\n appId: '',\n\n initData: {},\n\n currentModule: {} as ModuleState,\n\n events: {} as Partial<GuardEvents>,\n\n isAuthFlow: false,\n\n contextLoaded: false,\n\n guardPageConfig: {} as Partial<GuardPageConfig>,\n\n /**\n * 多账号 状态\n */\n multipleInstance: {\n isMultipleAccount: false,\n\n instance: undefined,\n\n referMultipleState: undefined,\n\n multipleAccountData: undefined,\n\n clearBackFillData: undefined,\n },\n\n phoneRegex: null,\n defaultLanguageConfig: 'zh-CN',\n\n tenantInstance: undefined,\n\n isForeignUserpool: false,\n}\n\nconst GuardXContext = React.createContext<IGuardContext>(DefaultGuardX)\n\nexport const createGuardXContext = () => {\n const Provider = GuardXContext.Provider\n const Consumer = GuardXContext.Consumer\n\n const guardXProvider: React.FC<{\n value: Partial<IGuardContext>\n children: ReactNode\n }> = ({ value, children }) => {\n return (\n <Provider\n value={{\n ...DefaultGuardX,\n ...value,\n }}\n >\n {children}\n </Provider>\n )\n }\n\n return {\n Provider: guardXProvider,\n Consumer,\n }\n}\n\nexport const useGuardXContext = () => {\n return useMemo(() => {\n const Provider = GuardXContext.Provider\n const Consumer = GuardXContext.Consumer\n\n const guardXProvider: React.FC<{\n value: Partial<IGuardContext>\n children: ReactNode\n }> = ({ value, children }) => {\n return (\n <Provider\n value={{\n ...DefaultGuardX,\n ...value,\n }}\n >\n {children}\n </Provider>\n )\n }\n\n return {\n Provider: guardXProvider,\n Consumer,\n }\n }, [])\n}\n\nexport interface IGuardContextProvider {\n spin: boolean\n spinChange: (spin: boolean) => void\n}\n\nconst GuardButtonContext = React.createContext<IGuardContextProvider>({\n spin: false,\n spinChange: () => {},\n})\n\nexport const useGuardButtonContext = () => {\n const Provider = GuardButtonContext.Provider\n\n const GuardButtonProvider: React.FC<{ children: ReactNode }> = ({\n children,\n }) => {\n const [spin, setSpin] = React.useState(false)\n\n return (\n <Provider\n value={{\n spin: spin,\n spinChange: (spin: boolean) => {\n setSpin(spin)\n },\n }}\n >\n {children}\n </Provider>\n )\n }\n\n return {\n GuardButtonProvider,\n }\n}\n\nexport const useGuardButtonState = () => useContext(GuardButtonContext)\n\nexport const useGuardPublicConfig = () => useContext(GuardXContext).publicConfig\n\nexport const useGuardHttpClient = () => useContext(GuardXContext).httpClient\n\nexport const useGuardDefaultMergedConfig = () =>\n useContext(GuardXContext).defaultMergedConfig\n\nexport const useGuardAppId = () => useContext(GuardXContext).appId\n\nexport const useGuardTenantId = () => useContext(GuardXContext).tenantId\n\nexport function useGuardInitData<T>(): T {\n const { initData } = useContext(GuardXContext)\n return initData as T\n}\n\nexport const useGuardCurrentModule = () =>\n useContext(GuardXContext).currentModule\n\nexport const useGuardEvents = () => useContext(GuardXContext).events\n\nexport const useGuardModule = () => {\n const guardX = useContext(GuardXContext)\n\n return {\n changeModule: guardX.changeModule,\n backModule: guardX.backModule,\n currentModule: guardX.currentModule,\n }\n}\n\nexport const useGuardFinallyConfig = () =>\n useContext(GuardXContext).finallyConfig\n\nexport const useGuardContextLoaded = () =>\n useContext(GuardXContext).contextLoaded\n\nexport const useGuardIsAuthFlow = () => useContext(GuardXContext).isAuthFlow\n\nexport const useGuardPageConfig = () =>\n useContext(GuardXContext).guardPageConfig\n\n/**\n * 多账号登录 store 实例\n */\nexport const useGuardMultipleInstance = () =>\n useContext(GuardXContext).multipleInstance\n\n// 手机号正则\nexport const useGuardPhoneRegex = () => useContext(GuardXContext).phoneRegex\n/**\n * 默认语言\n */\nexport const useGuardDefaultLanguage = () =>\n useContext(GuardXContext).defaultLanguageConfig\n\n/** 用来操作和获取租户相关的内容 */\nexport const useGuardTenantProvider = () =>\n useContext(GuardXContext).tenantInstance\n\n/** 当前人机验证策略 */\nexport const useRobotVerify = () => {\n const {\n customSecurityEnabled,\n appRobotVerify,\n userpoolRobotVerify,\n } = useGuardPublicConfig()\n\n return customSecurityEnabled ? appRobotVerify : userpoolRobotVerify\n}\n\n/** 当前用户池是否是国外用户池 */\nexport const useIsForeignUserpool = () =>\n useContext(GuardXContext).isForeignUserpool\n","import { Dropdown, Menu } from 'antd'\nimport React, { useCallback, useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { IconFont } from '../IconFont'\nimport { Lang } from '../Type'\nimport { useGuardPageConfig } from '../_utils/context'\nimport { fallbackLng } from '../_utils/locales'\nimport './style.less'\n\nexport const LngTextMapping: Record<\n Lang,\n {\n label: string\n }\n> = {\n 'zh-CN': {\n label: '简体中文',\n },\n 'zh-TW': {\n label: '繁體中文',\n },\n 'en-US': {\n label: 'English',\n },\n 'ja-JP': {\n label: '日本語',\n },\n}\n\nexport const ChangeLanguage = (props: {\n onLangChange?: (lang: Lang) => void\n langRange?: Lang[]\n}) => {\n const { langRange = ['zh-CN', 'zh-TW', 'en-US', 'ja-JP'] } = props\n const { onLangChange } = props\n const { i18n } = useTranslation()\n const guardPageConfig = useGuardPageConfig()\n\n const onChangeLng = useCallback(\n (lng: Lang) => {\n i18n.changeLanguage(lng)\n onLangChange?.(lng)\n },\n [i18n, onLangChange]\n )\n\n const showChangeLng = useMemo(() => {\n return guardPageConfig.global?.showChangeLanguage\n }, [guardPageConfig])\n const currentLng = useMemo<Lang>(() => {\n if (Object.keys(LngTextMapping).includes(i18n.language)) {\n return i18n.language as Lang\n } else {\n return (fallbackLng(i18n.language)[0] || 'en-US') as Lang\n }\n }, [i18n.language])\n\n const currentLngText = useMemo(() => {\n return (\n <>\n <span>{LngTextMapping[currentLng].label}</span>\n </>\n )\n }, [currentLng])\n\n const lngMenu = useMemo(() => {\n let menuItem: {\n key: string\n label: string\n }[] = []\n\n menuItem = Object.keys(LngTextMapping)\n .filter((lng) => langRange.includes(lng as Lang))\n .map((lng) => ({\n key: lng,\n label: LngTextMapping[lng as Lang].label,\n }))\n\n return (\n <Menu>\n {menuItem.map(({ key, label }) => {\n const isCurrent = key === currentLng\n\n return (\n <Menu.Item\n key={key}\n className={isCurrent ? 'select' : ''}\n onClick={() => {\n if (currentLng !== key) {\n onChangeLng(key as Lang)\n }\n }}\n >\n <span>{label}</span>\n {isCurrent && <IconFont type=\"authing-check-fill\" />}\n </Menu.Item>\n )\n })}\n </Menu>\n )\n }, [currentLng, langRange, onChangeLng])\n\n if (!showChangeLng || langRange.length === 0) {\n return null\n }\n\n return (\n <div className=\"g2-change-language-container\">\n <Dropdown\n overlay={lngMenu}\n trigger={['click']}\n placement=\"bottomCenter\"\n overlayClassName=\"authing-g2-change-language-menu\"\n getPopupContainer={(node) => {\n if (node?.parentElement) {\n return node.parentElement\n }\n return node\n }}\n >\n <span className=\"g2-change-language-text\">\n {currentLngText}\n <IconFont\n type=\"authing-arrow-down-s-fill\"\n className=\"down-fill-svg\"\n />\n </span>\n </Dropdown>\n </div>\n )\n}\n","import { getGuardWindow } from '../Guard/core/useAppendConfig'\n\n/**\n * 在屏幕中心弹出新窗口加载 url\n * @param url\n * @param param1\n */\nexport const popupCenter = (\n url: string,\n { w, h }: { w: number; h: number } = { w: 585, h: 649 }\n) => {\n const guardWindow = getGuardWindow()\n\n if (!guardWindow) return\n\n const document = guardWindow.document\n\n // Fixes dual-screen position Most browsers Firefox\n const dualScreenLeft =\n guardWindow.screenLeft !== undefined\n ? guardWindow.screenLeft\n : guardWindow.screenX\n const dualScreenTop =\n guardWindow.screenTop !== undefined\n ? guardWindow.screenTop\n : guardWindow.screenY\n\n const width = guardWindow.innerWidth\n ? guardWindow.innerWidth\n : document.documentElement.clientWidth\n ? document.documentElement.clientWidth\n : guardWindow.screen.width\n const height = guardWindow.innerHeight\n ? guardWindow.innerHeight\n : document.documentElement.clientHeight\n ? document.documentElement.clientHeight\n : guardWindow.screen.height\n\n const systemZoom = width / guardWindow.screen.availWidth\n const left = (width - w) / 2 / systemZoom + dualScreenLeft\n const top = (height - h) / 2 / systemZoom + dualScreenTop\n const newWindow = guardWindow.open(\n url,\n '_blank',\n `\n toolbar=no,\n menubar=no,\n scrollbars=no,\n resizable=no,\n location=no,\n status=no\n width=${w / systemZoom}, \n height=${h / systemZoom}, \n top=${top}, \n left=${left}\n `\n )\n\n newWindow?.focus()\n}\n","import { Rule } from 'antd/lib/form'\nimport qs from 'qs'\nimport { i18n } from './locales'\nimport { User } from 'authing-js-sdk'\nimport { GuardProps } from '../Guard'\nimport isEqual from 'lodash/isEqual'\nimport omit from 'lodash/omit'\nimport { getGuardWindow } from '../Guard/core/useAppendConfig'\nimport UAParser from 'ua-parser-js'\nimport {\n ApplicationConfig,\n ComplateFiledsPlace,\n LoginMethods,\n RegisterMethods,\n RegisterSortMethods,\n TabFieldsI18nItem,\n} from '../Type/application'\nimport { LngTextMapping } from '../ChangeLanguage'\nimport { Lang } from '../Type'\nexport * from './popupCenter'\nexport * from './clipboard'\n\nexport const VALIDATE_PATTERN = {\n // https://emailregex.com/\n // eslint-disable-next-line no-control-regex\n email: /^(([^<>()[\\]\\\\.,;:\\s@\"]+(\\.[^<>()[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/,\n // https://cloud.tencent.com/developer/article/1751120\n // email: /^\\w+([-+.]\\w+)*@\\w+([-.]\\w+)*\\.\\w+([-.]\\w+)*$/,\n // 以下的来自 authing-user-portal 项目\n phone: /^1(3\\d|4[5-9]|5[0-35-9]|6[2567]|7[0-8]|8\\d|9[0-35-9])\\d{8}$/,\n ip: /^((2(5[0-5]|[0-4]\\d))|[0-1]?\\d{1,2})(\\.((2(5[0-5]|[0-4]\\d))|[0-1]?\\d{1,2})){3}$/,\n host: /^[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+.?$/,\n username: /.?/,\n} as const\n\nexport const validate = (type: keyof typeof VALIDATE_PATTERN, val: string) => {\n return VALIDATE_PATTERN[type].test(val)\n}\n\nexport const getRequiredRules = (msg: string): Rule[] => {\n return [\n {\n required: true,\n message: msg,\n },\n ]\n}\n\nexport const fieldRequiredRule = (\n fieldRequiredRule: string,\n fieldRequiredRuleMessage?: string\n): Rule[] => {\n return [\n {\n required: true,\n validateTrigger: ['onChange'],\n message:\n fieldRequiredRuleMessage ||\n i18n.t('common.isMissing', {\n name: fieldRequiredRule,\n }),\n whitespace: true,\n },\n ]\n}\n\nexport function getDeviceName() {\n const guardWindow = getGuardWindow()\n\n if (!guardWindow) return\n\n const userAgent = guardWindow.navigator.userAgent\n const platform = guardWindow.navigator.platform\n const macosPlatforms = ['Macintosh', 'MacIntel', 'MacPPC', 'Mac68K']\n const windowsPlatforms = ['Win32', 'Win64', 'Windows', 'WinCE']\n const iosPlatforms = ['iPhone', 'iPad', 'iPod']\n\n let os = null\n\n if (macosPlatforms.indexOf(platform) !== -1) {\n os = 'Mac OS'\n } else if (iosPlatforms.indexOf(platform) !== -1) {\n os = 'iOS'\n } else if (windowsPlatforms.indexOf(platform) !== -1) {\n os = 'Windows'\n } else if (/Android/.test(userAgent)) {\n os = 'Android'\n } else if (!os && /Linux/.test(platform)) {\n os = 'Linux'\n }\n\n return os\n}\n\nexport type STYLE_RECORD_KEY = 'appConfig' | 'userConfig'\n\n/**\n * 传对象 {'background-color': 'red'}\n * 传字符串 \"CSS 样式\"\n */\nconst insertedRecord: Record<STYLE_RECORD_KEY, any> = {\n appConfig: null,\n userConfig: null,\n}\nexport const insertStyles = (\n styles: string | any,\n recordKey?: STYLE_RECORD_KEY\n) => {\n const guardWindow = getGuardWindow()\n\n if (!guardWindow) return\n\n const document = guardWindow.document\n\n let styleElt, styleSheet\n if ((document as any).createStyleSheet) {\n // IE\n styleSheet = (document as any).createStyleSheet()\n } else {\n let head = document.getElementsByTagName('head')[0]\n styleElt = document.createElement('style')\n head.appendChild(styleElt)\n styleSheet = document.styleSheets[document.styleSheets.length - 1]\n }\n if (typeof styles === 'string') {\n if (styleElt) styleElt.innerHTML = styles\n else styleSheet.cssText = styles // IE\n } else {\n let i = 0\n for (let selector in styles) {\n if (styleSheet.insertRule) {\n let rule = selector + ' {' + styles[selector] + '}'\n styleSheet.insertRule(rule, i++)\n } else {\n styleSheet.addRule(selector, styles[selector], i++)\n }\n }\n }\n\n if (recordKey) {\n insertedRecord[recordKey] = styleElt || styleSheet\n }\n}\n\nexport const removeStyles = (recordKey: STYLE_RECORD_KEY) => {\n if (!insertedRecord[recordKey]) {\n return\n }\n\n const styleElt = insertedRecord[recordKey]\n styleElt.parentNode?.removeChild(styleElt)\n\n insertedRecord[recordKey] = null\n}\n\nexport const getClassnames = (classnames: (string | boolean | undefined)[]) => {\n return classnames.filter(Boolean).join(' ')\n}\n\n/**\n * https://www.itranslater.com/qa/details/2115518846294557696\n * Simple object check.\n * @param item\n * @returns {boolean}\n */\nexport function isObject(item: any) {\n return item && typeof item === 'object' && !Array.isArray(item)\n}\n\n/**\n * https://www.itranslater.com/qa/details/2115518846294557696\n * Deep merge two objects.\n * @param target\n * @param ...sources\n */\nexport function deepMerge<T extends object = any>(\n target: T,\n ...sources: any[]\n): T {\n if (!sources.length) return target\n const source = sources.shift()\n\n if (isObject(target) && isObject(source)) {\n for (const key in source) {\n if (isObject(source[key])) {\n // @ts-ignore\n if (!target[key]) {\n Object.assign(target, { [key]: {} })\n }\n // @ts-ignore\n deepMerge(target[key], source[key])\n } else {\n Object.assign(target, { [key]: source[key] })\n }\n }\n }\n\n return deepMerge(target, ...sources)\n}\n\n/**\n * 在托管页下上传query中指定的用户自定义字段进行补全\n * @param params 指定上传的用户自定义字段\n */\nexport const getUserRegisterParams = (params?: string[]) => {\n const query = qs.parse(window.location.search, {\n ignoreQueryPrefix: true,\n })\n return Object.keys(query)\n .map((key) => ({\n key,\n value: query[key],\n }))\n .filter((item) => item.value)\n .filter((item) => (params ? params.includes(item.key) : true))\n}\n\n// 微信内置浏览器\nexport const isWeChatBrowser = () => {\n if (typeof navigator === 'undefined') {\n return null\n }\n return (\n /MicroMessenger/i.test(navigator?.userAgent) &&\n !/wxwork/i.test(navigator.userAgent)\n )\n}\n\nexport const isLarkBrowser = () => {\n if (typeof navigator === 'undefined') {\n return null\n }\n return /Lark/i.test(navigator.userAgent)\n}\n\nexport const isQtWebEngine = () => {\n if (typeof navigator === 'undefined') {\n return null\n }\n return /QtWebEngine/i.test(navigator.userAgent)\n}\n\nexport const isXiaomiBrowser = () => {\n if (typeof navigator === 'undefined') {\n return null\n }\n return /MiuiBrowser/i.test(navigator.userAgent)\n}\nexport const isDingtalkBrowser = () => {\n if (typeof navigator === 'undefined') {\n return null\n }\n return /dingtalk/i.test(navigator.userAgent)\n}\nexport const isQQBrowser = () => {\n if (typeof navigator === 'undefined') {\n return null\n }\n return /MQQBrowser/i.test(navigator.userAgent)\n}\n// qq 内置浏览器\nexport const isQQBuiltInBrowser = () => {\n if (typeof navigator === 'undefined') {\n return null\n }\n return / QQ/i.test(navigator.userAgent)\n}\n// 企业微信内置浏览器\nexport const isWeWorkBuiltInBrowser = () => {\n if (typeof navigator === 'undefined') {\n return null\n }\n return (\n /MicroMessenger/i.test(navigator.userAgent) &&\n /wxwork/i.test(navigator.userAgent)\n )\n}\n// 特殊浏览器 后续可能会增加\n\nexport const isEdgeBrowser = () => {\n const parser = UAParser()\n\n return parser.browser.name === 'Edge'\n}\n\nexport const isWeiboBrowser = () => {\n if (typeof navigator === 'undefined') {\n return null\n }\n return /Weibo/i.test(navigator.userAgent)\n}\n\nexport const isAlipayBrowser = () => {\n if (typeof navigator === 'undefined') {\n return null\n }\n return /Alipay/i.test(navigator.userAgent)\n}\n\nexport const isBaiduBrowser = () => {\n if (typeof navigator === 'undefined') {\n return null\n }\n return /Baidu/i.test(navigator.userAgent)\n}\n\nexport const isWeComeBrowser = () => /wxwork/i.test(navigator.userAgent)\n\nexport const isMobile = () => {\n return window.navigator.userAgent.match(\n /(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i\n )\n}\n\n/* 利用浏览器的 UA 判断是否为不支持弹窗的特殊浏览器 */\nexport const isSpecialBrowser = () => {\n // 1. 首先筛选出一定是特殊浏览器的 UA\n if (\n isWeChatBrowser() ||\n isWeComeBrowser() ||\n isLarkBrowser() ||\n isDingtalkBrowser() ||\n isQtWebEngine() ||\n isXiaomiBrowser() ||\n isQQBrowser() ||\n isMobile()\n ) {\n return true\n }\n\n // 2. 利用 ua-parser-js 进一步判断,筛选出很可能不是特殊浏览器的 UA\n // 由于一些特殊浏览器也可能会被误判为非特殊,所以需要首先经过第 1 步筛选\n const parser = UAParser()\n const nonSpecialBrowsers = [\n 'Chrome',\n 'Firefox',\n 'Safari',\n 'Opera',\n 'IE',\n 'Edge',\n ]\n if (nonSpecialBrowsers.includes(parser.browser.name ?? '')) {\n return false\n }\n\n // 3. 可能有一些 UA 没有任何特征,这种情况下一律默认为特殊浏览器\n return true\n}\n\nexport const assembledAppHost = (identifier: string, host: string) => {\n const hostUrl = new URL(host)\n\n const splitHost = hostUrl.hostname.split('.')\n\n const port = hostUrl.port\n\n splitHost.shift()\n\n // eslint-disable-next-line prettier/prettier\n return `${hostUrl.protocol}//${identifier}.${splitHost.join('.')}${\n port && `:${port}`\n }`\n}\n\n// 拼接请求链接\nexport const assembledRequestHost = (\n requestHostname: string,\n configHost: string\n) => {\n const identifier = requestHostname.split('.')[0]\n\n const hostUrl = new URL(configHost)\n const splitHost = hostUrl.hostname.split('.')\n\n splitHost.shift()\n\n // 看看是否有端口号\n const port = hostUrl.port\n\n return `${hostUrl.protocol}//${identifier}.${splitHost.join('.')}${\n port && `:${port}`\n }`\n}\n\nexport enum PasswordStrength {\n NoCheck,\n Low,\n Middle,\n High,\n AUTO,\n}\n\nexport const PASSWORD_STRENGTH_TEXT_MAP: Record<\n PasswordStrength,\n {\n placeholder: () => string\n validateMessage: () => string\n }\n> = {\n [PasswordStrength.NoCheck]: {\n placeholder: () => i18n.t('login.inputPwd'),\n validateMessage: () => i18n.t('login.inputPwd'),\n },\n [PasswordStrength.Low]: {\n placeholder: () => i18n.t('login.setPwdLimit1'),\n validateMessage: () => i18n.t('login.setPwdLimitMsg1'),\n },\n [PasswordStrength.Middle]: {\n placeholder: () => i18n.t('login.login.setPwdLimit2'),\n validateMessage: () => i18n.t('login.setPwdLimitMsg2'),\n },\n [PasswordStrength.High]: {\n placeholder: () => i18n.t('login.login.setPwdLimit3'),\n validateMessage: () => i18n.t('login.setPwdLimitMsg3'),\n },\n [PasswordStrength.AUTO]: {\n placeholder: () => i18n.t('login.inputPwd'),\n validateMessage: () => i18n.t('login.inputPwd'),\n },\n}\n\nconst SYMBOL_TYPE_PATTERNS = [\n /\\d+/,\n /[a-zA-Z]/,\n /[`~!@#$%^&*()_\\-+=<>?:\"{}|,.\\\\/;'\\\\[\\]·~!@#¥%……&*()——\\-+={}|《》?:“”【】、;‘',。、]/,\n // /[-!$%^&*()_+|~=`{}[\\]:\";'<>?,@./]/,\n]\n\nexport const getSymbolTypeLength = (pwd: string) => {\n return SYMBOL_TYPE_PATTERNS.map((pattern) => pattern.test(pwd)).filter(\n (item) => item\n ).length\n}\n\nexport const getPasswordValidate = (\n strength: PasswordStrength = PasswordStrength.NoCheck,\n customPasswordStrength: any = {},\n fieldRequiredRuleMessage?: string\n): Rule[] => {\n const required = [\n ...fieldRequiredRule(i18n.t('common.password'), fieldRequiredRuleMessage),\n // {\n // validateTrigger: 'onBlur',\n // validator(_: any, value: any) {\n // if ((value ?? '').indexOf(' ') !== -1) {\n // return Promise.reject(i18n.t('common.checkPasswordHasSpace'))\n // }\n // return Promise.resolve()\n // },\n // },\n ]\n const getCustomPassword = () => {\n if (i18n.language === 'zh-CN' && customPasswordStrength?.zhMessageOpen) {\n return customPasswordStrength?.zhMessage\n }\n if (i18n.language === 'en-US' && customPasswordStrength?.enMessageOpen) {\n return customPasswordStrength?.enMessage\n }\n if (i18n.language === 'ja-JP' && customPasswordStrength?.jaMessageOpen) {\n return customPasswordStrength?.jaMessage\n }\n if (i18n.language === 'ja-JP' && customPasswordStrength?.jpMessageOpen) {\n return customPasswordStrength?.jpMessage\n }\n if (i18n.language === 'zh-TW' && customPasswordStrength?.twMessageOpen) {\n return customPasswordStrength?.twMessage\n }\n return customPasswordStrength?.message\n }\n const validateMap: Record<PasswordStrength, Rule[]> = {\n [PasswordStrength.NoCheck]: [...required],\n [PasswordStrength.Low]: [\n ...required,\n {\n validateTrigger: 'onBlur',\n validator(r, v) {\n if (v && v.length < 6) {\n return Promise.reject(\n PASSWORD_STRENGTH_TEXT_MAP[PasswordStrength.Low].validateMessage()\n )\n }\n return Promise.resolve()\n },\n },\n ],\n [PasswordStrength.Middle]: [\n ...required,\n {\n validateTrigger: 'onBlur',\n validator(r, v) {\n if (v && (v.length < 6 || getSymbolTypeLength(v) < 2)) {\n return Promise.reject(\n PASSWORD_STRENGTH_TEXT_MAP[\n PasswordStrength.Middle\n ].validateMessage()\n )\n }\n return Promise.resolve()\n },\n },\n ],\n [PasswordStrength.High]: [\n ...required,\n {\n validateTrigger: 'onBlur',\n validator(r, v) {\n if (v && (v.length < 6 || getSymbolTypeLength(v) < 3)) {\n return Promise.reject(\n PASSWORD_STRENGTH_TEXT_MAP[\n PasswordStrength.High\n ].validateMessage()\n )\n }\n return Promise.resolve(true)\n },\n },\n ],\n [PasswordStrength.AUTO]: [\n ...required,\n {\n validateTrigger: 'onBlur',\n pattern: customPasswordStrength?.regex,\n message: getCustomPassword(),\n },\n ],\n }\n\n return validateMap[strength]\n}\n\nexport const getPasswordValidateRules = (\n strength: PasswordStrength = PasswordStrength.NoCheck,\n customPasswordStrength: any = {},\n customValidateTrigger?: string,\n fieldRequiredRuleMessage?: string\n): Rule[] => {\n const required = [\n ...fieldRequiredRule(i18n.t('common.password'), fieldRequiredRuleMessage),\n ]\n const getCustomPassword = () => {\n if (i18n.language === 'zh-CN' && customPasswordStrength?.zhMessageOpen) {\n return customPasswordStrength?.zhMessage\n }\n if (i18n.language === 'en-US' && customPasswordStrength?.enMessageOpen) {\n return customPasswordStrength?.enMessage\n }\n if (i18n.language === 'ja-JP' && customPasswordStrength?.jaMessageOpen) {\n return customPasswordStrength?.jaMessage\n }\n if (i18n.language === 'ja-JP' && customPasswordStrength?.jpMessageOpen) {\n return customPasswordStrength?.jpMessage\n }\n if (i18n.language === 'zh-TW' && customPasswordStrength?.twMessageOpen) {\n return customPasswordStrength?.twMessage\n }\n return customPasswordStrength?.message\n }\n const validateMap: Record<PasswordStrength, Rule[]> = {\n [PasswordStrength.NoCheck]: [...required],\n [PasswordStrength.Low]: [\n ...required,\n {\n validateTrigger: customValidateTrigger,\n validator(r, v) {\n if (v && v.length < 6) {\n return Promise.reject(\n PASSWORD_STRENGTH_TEXT_MAP[PasswordStrength.Low].validateMessage()\n )\n }\n return Promise.resolve()\n },\n },\n ],\n [PasswordStrength.Middle]: [\n ...required,\n {\n validateTrigger: customValidateTrigger,\n validator(r, v) {\n if (v && (v.length < 6 || getSymbolTypeLength(v) < 2)) {\n return Promise.reject(\n PASSWORD_STRENGTH_TEXT_MAP[\n PasswordStrength.Middle\n ].validateMessage()\n )\n }\n return Promise.resolve()\n },\n },\n ],\n [PasswordStrength.High]: [\n ...required,\n {\n validateTrigger: customValidateTrigger,\n validator(r, v) {\n if (v && (v.length < 6 || getSymbolTypeLength(v) < 3)) {\n return Promise.reject(\n PASSWORD_STRENGTH_TEXT_MAP[\n PasswordStrength.High\n ].validateMessage()\n )\n }\n return Promise.resolve(true)\n },\n },\n ],\n [PasswordStrength.AUTO]: [\n ...required,\n {\n validateTrigger: customValidateTrigger,\n pattern: customPasswordStrength?.regex,\n message: getCustomPassword(),\n },\n ],\n }\n\n return validateMap[strength]\n}\n\nexport const sleep = (delay: number) =>\n new Promise((resolve) => setTimeout(resolve, delay))\n\nexport const shoudGoToComplete = (\n user: User,\n contextType: ComplateFiledsPlace,\n config: ApplicationConfig | undefined,\n autoRegister?: boolean //是否登录注册合并\n) => {\n // console.log('需要补全吗?', user, contextType, config)\n // 先判断开关,再对比字段。\n let needGo = false\n // 判断新版本\n if (\n config?.complateFiledsPlace?.length &&\n config.complateFiledsPlace.includes(contextType) &&\n config?.extendsFields &&\n config?.extendsFields?.length > 0\n ) {\n needGo = true\n }\n\n //autoRegister 开启注册登录合并后 就不区分登录注册场景 只要 complateFiledsPlace 有值即可\n\n if (\n autoRegister &&\n config?.complateFiledsPlace?.length &&\n config?.extendsFields &&\n config?.extendsFields?.length > 0\n ) {\n needGo = true\n }\n // 兼容老版本\n if (\n !config?.complateFiledsPlace?.length &&\n config?.extendsFieldsEnabled &&\n config?.extendsFields &&\n config?.extendsFields?.length > 0\n ) {\n needGo = true\n }\n // 对比字段\n const allFieldsToComp = config?.extendsFields\n if (\n needGo &&\n contextType === 'register' &&\n allFieldsToComp &&\n allFieldsToComp.length > 0\n ) {\n if (\n user.email &&\n allFieldsToComp?.length === 1 &&\n allFieldsToComp[0]?.type === 'internal' &&\n allFieldsToComp[0]?.name === 'email'\n ) {\n return false\n }\n if (\n user.phone &&\n allFieldsToComp?.length === 1 &&\n allFieldsToComp[0]?.type === 'internal' &&\n allFieldsToComp[0]?.name === 'phone'\n ) {\n return false\n }\n if (\n allFieldsToComp\n .filter((item) => item.type === 'user')\n .map((i) => i.name)\n //@ts-ignore\n .map((i) => user[i])\n .filter((i) => Boolean(i)).length === 0\n )\n return false\n\n return true\n }\n if (\n needGo &&\n contextType === 'login' &&\n allFieldsToComp &&\n allFieldsToComp.length > 0\n ) {\n // console.log('判断补全')\n // TODO 自动注册登录\n needGo = false\n const userFields = allFieldsToComp.filter(\n (item) => item.type === 'internal'\n )\n const udvs = allFieldsToComp.filter((item) => item.type !== 'internal')\n for (const f of userFields) {\n const currKey = f.name\n // gender 特例\n if (currKey === 'gender' && user['gender'] === 'U') {\n needGo = true\n break\n }\n //@ts-ignore\n if (!user[currKey] || user[currKey] === '') {\n needGo = true\n break\n }\n }\n if (!needGo) {\n const { customData } = user\n if (customData) {\n for (const f of udvs) {\n if (!customData[f.name] || customData[f.name] === '') {\n needGo = true\n break\n }\n }\n }\n }\n }\n return needGo\n}\n\nexport const transformMethod = (method: RegisterMethods | string) => {\n switch (method) {\n case RegisterMethods.Phone:\n case RegisterMethods.EmailCode:\n case RegisterSortMethods.EmailCode:\n return RegisterSortMethods.Phone\n case RegisterMethods.Email:\n return RegisterSortMethods.Email\n default:\n return method\n }\n}\n\nexport const transformSortMethod = (method: RegisterSortMethods | string) => {\n switch (method) {\n case RegisterSortMethods.Email:\n return RegisterMethods.Email\n case RegisterSortMethods.EmailCode:\n return RegisterMethods.EmailCode\n case RegisterSortMethods.Phone:\n return RegisterMethods.Phone\n default:\n return method\n }\n}\n\nexport const mailDesensitization = (mail: string) => {\n const mailArr = mail.split('@')\n const mailName = mailArr[0].substr(0, 1) + '***'\n return mailName + '@' + mailArr[1]\n}\n\nexport const phoneDesensitization = (phone: string) => {\n return phone.replace(/(\\d{3})\\d*(\\d{4})/, '$1****$2')\n}\n\nexport const getHundreds = (num: number) => {\n return Math.floor(num / 100)\n}\n\nexport const GuardPropsFilter = (pre: GuardProps, current: GuardProps) => {\n const preAttribute = Object.keys(pre).filter((name) => name.startsWith('on'))\n\n const currentAttribute = Object.keys(current).filter((name) =>\n name.startsWith('on')\n )\n\n return isEqual(omit(pre, preAttribute), omit(current, currentAttribute))\n}\n\nexport const getDocumentNode = (node: Node & ParentNode): Document => {\n if (node.nodeName === '#document') {\n return node as Document\n }\n\n return getDocumentNode(node.parentNode as Node & ParentNode)\n}\n\n// 1. 手机号验证码注册\n// - 手机号验证码登录\n// - 手机号密码登录\n// - 非手机号的密码登录\n// 2. 邮箱验证码注册\n// - 邮箱验证码登录\n// - 邮箱密码登录\n// - 非邮箱的密码登录\n// 3. 邮箱密码注册\n// - 邮箱密码登录\n// - 邮箱验证码登录\n// - 非邮箱的密码登录\n\nexport const getLoginTypePipe = (\n publicConfig: ApplicationConfig,\n registerMethod: RegisterMethods\n) => {\n const loginTabs = publicConfig?.loginTabs.list // 支持的登录方式\n const verifyCodeTabMethods =\n publicConfig?.verifyCodeTabConfig?.enabledLoginMethods ?? [] // 支持的验证码登录方式\n const passwordTabMethods =\n publicConfig?.passwordTabConfig?.enabledLoginMethods ?? [] // 支持的密码登录方式\n // 通过手机验证码注册成功\n if (registerMethod === RegisterMethods.Phone) {\n if (\n loginTabs.includes(LoginMethods.PhoneCode) &&\n verifyCodeTabMethods.includes('phone-code')\n ) {\n // situation 1 手机号验证码登录\n return {\n specifyDefaultLoginMethod: LoginMethods.PhoneCode,\n lockMethod: 'phone-code',\n }\n } else if (\n loginTabs.includes(LoginMethods.Password) &&\n passwordTabMethods.includes('phone-password')\n ) {\n // situation 2 手机号密码登录\n return { specifyDefaultLoginMethod: LoginMethods.Password }\n } else {\n return undefined\n }\n }\n // 通过邮箱验证码注册成功\n if (registerMethod === RegisterMethods.EmailCode) {\n if (\n loginTabs.includes(LoginMethods.PhoneCode) &&\n verifyCodeTabMethods.includes('email-code')\n ) {\n // situation 1 邮箱验证码登录\n return {\n specifyDefaultLoginMethod: LoginMethods.PhoneCode,\n lockMethod: 'email-code',\n }\n } else if (\n loginTabs.includes(LoginMethods.Password) &&\n passwordTabMethods.includes('email-password')\n ) {\n // situation 2 邮箱密码登录\n return { specifyDefaultLoginMethod: LoginMethods.Password }\n } else {\n return undefined\n }\n }\n // 通过邮箱密码注册成功\n if (registerMethod === RegisterMethods.Email) {\n if (\n loginTabs.includes(LoginMethods.Password) &&\n passwordTabMethods.includes('email-password')\n ) {\n // situation 1 邮箱密码登录\n return { specifyDefaultLoginMethod: LoginMethods.Password }\n } else if (\n loginTabs.includes(LoginMethods.PhoneCode) &&\n verifyCodeTabMethods.includes('email-code')\n ) {\n // situation 2 邮箱验证码登录\n return {\n specifyDefaultLoginMethod: LoginMethods.PhoneCode,\n lockMethod: 'email-code',\n }\n } else {\n return undefined\n }\n }\n}\n\n// 对用户输入的数据进行校验判断是否是手机号或者邮箱\nexport const getPasswordIdentify = (identity: string): string => {\n return validate('phone', identity) || validate('email', identity)\n ? identity\n : ''\n}\n\nexport const getCurrentLng = () => {\n if (Object.keys(LngTextMapping).includes(i18n.language)) {\n return i18n.language as Lang\n } else {\n return i18n?.languages?.[i18n?.languages?.length - 1] as Lang\n }\n}\n\nexport const regexFromString = (string: string) => {\n var match = /^\\/(.*)\\/([a-z]*)$/.exec(string)\n if (match) {\n return new RegExp(match[1], match[2])\n }\n return null\n}\nexport const getI18nLabel = (\n method: string | RegisterSortMethods,\n i18nFields: Map<string, TabFieldsI18nItem>,\n defaultLanguageConfig: Lang\n) => {\n const lang = getCurrentLng()\n const key = method.split('-')[0]\n if (i18nFields.get(key)) {\n return (\n (i18nFields.get(key) as TabFieldsI18nItem)?.i18n?.[lang] ??\n (i18nFields.get(key) as TabFieldsI18nItem)?.i18n?.[\n defaultLanguageConfig\n ] ??\n (i18nFields.get(key) as TabFieldsI18nItem).label\n )\n }\n return ''\n}\n\nexport const getSortLabels = (\n methods: string[],\n i18nConfig: Map<string, TabFieldsI18nItem>,\n defaultLanguageConfig: Lang\n) => {\n let labels: string[] = []\n methods.forEach((v) => {\n const label = getI18nLabel(v, i18nConfig, defaultLanguageConfig)\n if (label) {\n labels.push(label)\n }\n })\n\n return labels.join(' / ')\n}\n\n// tab 排序\nexport const getSortTabs = (tabs: string[], tab?: string) => {\n const position = tabs.findIndex((item) => item === tab)\n\n if (position > 0) {\n const item = tabs.splice(position, 1)\n tabs.unshift(item[0])\n }\n\n return tabs\n}\n","export enum LoggerType {\n INFO = 'INFO',\n WARN = 'WARN',\n ERROR = 'ERROR',\n}\n","import some from 'lodash/some'\nimport { getGuardWindow } from '../Guard/core/useAppendConfig'\nimport { i18n } from './locales'\n\nconst isOriginMatched = (\n whitelist: string[],\n corsWhitelist: string[],\n origin: string\n) => {\n const wildcard = require('wildcard')\n\n if (corsWhitelist.includes(origin)) {\n return true\n }\n\n if (\n some(corsWhitelist, (allowedOrigin) => {\n return !!wildcard(allowedOrigin, origin)\n })\n ) {\n return true\n }\n\n if (whitelist.includes(origin)) {\n return true\n }\n\n if (\n some(whitelist, (allowedOrigin) => {\n return !!wildcard(allowedOrigin, origin)\n })\n ) {\n return true\n }\n return false\n}\n\nexport const corsVerification = (\n allowedOrigins: string[] = [],\n corsWhitelist: string[] = []\n) => {\n const guardWindow = getGuardWindow()\n\n if (guardWindow && allowedOrigins.length > 0) {\n const origin = guardWindow.location.origin\n const allowed = isOriginMatched(allowedOrigins, corsWhitelist, origin)\n if (!allowed) {\n throw new Error(\n `${i18n.t('common.corsErrorMessage')}${i18n.t(\n 'common.corsErrorMessage2'\n )}`\n )\n }\n }\n}\n","import { LoggerType } from './interface'\n\nlet logger: Logger\n\nexport class Logger {\n public static printType = [LoggerType.ERROR]\n\n /**\n * 打印日志\n * @param message 日志信息\n * @param type 日志类型\n */\n public static log(message: string, type: LoggerType = LoggerType.INFO) {\n const log = {\n type,\n message,\n }\n console.log(JSON.stringify(log))\n }\n\n public static info(message: string) {\n this.log(message, LoggerType.INFO)\n }\n\n public static warn(message: string) {\n this.log(message, LoggerType.WARN)\n }\n\n public static error(message: string) {\n this.log(message, LoggerType.ERROR)\n }\n}\n\nexport const getLogger = () => {\n if (logger === undefined) logger = new Logger()\n\n return logger\n}\n\nexport const useLogger = getLogger\n","export enum GuardModuleType {\n ERROR = 'error', //错误页\n LOGIN = 'login', //登录页\n REGISTER = 'register', //注册页\n MFA = 'mfa', // 二次 mfa 认证页\n FORGET_PWD = 'forgetPassword', // 忘记密码页\n FORCED_PASSWORD_RESET = 'forcedPasswordReset', // 登陆安全策略 密码轮换页\n NOTICE_PASSWORD_RESET = 'noticePasswordReset', //提示修改密码页\n FIRST_LOGIN_PASSWORD = 'firstLoginPassword', //首次登录修改密码页\n UNSAFE_PASSWORD_RESET = 'unsafePasswordReset', // 密码强度不符合要求修改密码页\n DOWNLOAD_AT = 'downloadAT', //下载 Authenticator 页\n BIND_TOTP = 'bindTotp', // 绑定 TOTP页\n ANY_QUESTIONS = 'anyQuestions', // 问题反馈页\n LOGIN_COMPLETE_INFO = 'loginCompleteInfo', // 登录信息补全\n REGISTER_PASSWORD = 'registerPassword', // 验证码注册拉起密码补全页\n REGISTER_COMPLETE_INFO = 'registerCompleteInfo', //注册信息补全页\n RECOVERY_CODE = 'recoveryCode', // MFA 恢复码展示页\n SUBMIT_SUCCESS = 'submitSuccess', // 提交成功展示页\n IDENTITY_BINDING_ASK = 'identityBindingAsk', // 身份源绑定 问询页\n IDENTITY_BINDING = 'identityBinding', // 身份源绑定页\n IDENTITY_BINDING_NO_ASK = 'identityBindingNoAsk', // 身份源绑定页不问询\n SELF_UNLOCK = 'selfUnlock', // 自助解锁页\n FLOW_SELECT_ACCOUNT = 'flowSelectAccount', // 选择登录账号\n /** 多租户门户选择页 */\n TENANT_PORTAL = 'tenant-portal',\n New_SUBMIT_SUCCESS = 'newSubmitSuccess', // 提交成功展示页\n RESET_ACCOUNT_NAME = 'resetAccountName',\n}\nexport interface GuardModuleAction {\n action: string\n module?: GuardModuleType\n message?: string\n initData?: any\n}\n","import {\n assembledRequestHost as utilAssembledRequestHost,\n transformSortMethod,\n} from '..'\nimport { GuardLocalConfig } from '../../Guard/config'\nimport { useCallback, useEffect, useMemo, useState } from 'react'\nimport { AuthingResponse } from '../http'\nimport { GuardHttp } from '../guardHttp'\nimport { corsVerification } from '../corsVerification'\nimport { Logger } from '../logger'\nimport { GuardPageConfig } from '../../Type'\nimport {\n ApplicationConfig,\n LoginMethods,\n RegisterMethods,\n} from '../../Type/application'\n\nlet publicConfigMap: Record<string, ApplicationConfig> = {}\n\nexport const getPublicConfig = (appId: string) => publicConfigMap?.[appId]\n\nexport const setPublicConfig = (appId: string, config: ApplicationConfig) => {\n return (publicConfigMap[appId] = config)\n}\n\nlet pageConfigMap: Record<string, GuardPageConfig> = {}\n\nexport const getPageConfig = (appId: string) => pageConfigMap?.[appId]\n\nexport const setPageConfig = (appId: string, config: GuardPageConfig) =>\n (pageConfigMap[appId] = config)\n\nconst requestPublicConfig = async (\n appId: string,\n httpClient: GuardHttp\n): Promise<ApplicationConfig> => {\n let res: AuthingResponse<ApplicationConfig>\n\n const { get } = httpClient\n\n try {\n res = await get<ApplicationConfig>(\n `/api/v2/applications/${appId}/public-config`\n )\n } catch (error) {\n Logger.error('Please check your config or network')\n throw new Error('Please check your config or network')\n }\n\n if (res.code !== 200 || !res.data) {\n Logger.error(res?.message ?? 'Please check your config')\n throw new Error(res?.message ?? 'Please check your config')\n }\n\n corsVerification(res.data.allowedOrigins, res.data.corsWhitelist)\n\n setPublicConfig(appId, res.data)\n\n httpClient.setUserpoolId(res.data.userPoolId)\n\n return getPublicConfig(appId)\n}\n\nconst requestGuardPageConfig = async (\n appId: string,\n httpClient: GuardHttp\n): Promise<GuardPageConfig> => {\n let res: AuthingResponse<GuardPageConfig>\n\n const { get } = httpClient\n\n try {\n res = await get<GuardPageConfig>(\n `/api/v2/applications/${appId}/components-public-config/guard`\n )\n } catch (error) {\n Logger.error('Please check your config or network')\n throw new Error('Please check your config or network')\n }\n\n if (res.code !== 200 || !res.data) {\n Logger.error(res?.message ?? 'Please check your config')\n throw new Error(res?.message ?? 'Please check your config')\n }\n\n setPageConfig(appId, res.data)\n\n return getPageConfig(appId)\n}\n\nexport const useMergeDefaultConfig = (\n defaultConfig: GuardLocalConfig,\n config?: Partial<GuardLocalConfig>\n): GuardLocalConfig | undefined => {\n const [mergedConfig, setMergedConfig] = useState<GuardLocalConfig>()\n\n useEffect(() => {\n setMergedConfig({\n ...defaultConfig,\n ...config,\n })\n }, [defaultConfig, config])\n\n return mergedConfig\n}\n\nconst mergedPublicConfig = (\n config: GuardLocalConfig,\n publicConfig: ApplicationConfig\n): GuardLocalConfig => {\n const autoRegister =\n config.autoRegister ??\n publicConfig.ssoPageComponentDisplay.autoRegisterThenLoginHintInfo\n\n const registerMethods = publicConfig.passwordTabConfig.validRegisterMethods?.concat(\n publicConfig.verifyCodeTabConfig?.validRegisterMethods?.map((item) =>\n transformSortMethod(item)\n ) || []\n )\n\n const mergedPublicConfig: GuardLocalConfig = {\n ...config,\n title: config.title ?? publicConfig.name,\n logo: !!config.logo ? config.logo : publicConfig.logo,\n loginMethods:\n config?.loginMethods ??\n (publicConfig.loginTabs?.list as LoginMethods[]) ??\n [],\n passwordLoginMethods:\n config?.passwordLoginMethods ??\n publicConfig.passwordTabConfig.validLoginMethods ??\n [],\n // 默认登录方式\n defaultLoginMethod:\n config.defaultLoginMethod ??\n (publicConfig.loginTabs.default as LoginMethods),\n // 禁止重制密码\n disableResetPwd: !!(\n config.disableResetPwd ??\n !publicConfig.ssoPageComponentDisplay?.forgetPasswordBtn\n ),\n // 是否自动注册\n autoRegister,\n registerMethods:\n config.registerMethods ??\n (autoRegister\n ? registerMethods\n : (publicConfig.registerTabs?.list as RegisterMethods[])),\n defaultRegisterMethod:\n config.defaultRegisterMethod ??\n (publicConfig.registerTabs.default as RegisterMethods),\n // 禁止注册\n disableRegister: !!(\n config.disableRegister ??\n !publicConfig.ssoPageComponentDisplay.registerBtn\n ),\n // publicKey\n publicKey: config.publicKey ?? publicConfig.publicKey,\n // 注册协议\n agreementEnabled: config.agreementEnabled ?? publicConfig.agreementEnabled,\n agreements: config.agreements ?? publicConfig.agreements,\n contentCss: config.contentCss ?? publicConfig.css,\n }\n\n return mergedPublicConfig\n}\n\n// host 拼接\nconst assembledRequestHost = (\n config: GuardLocalConfig,\n publicConfig: ApplicationConfig\n) => {\n const host = config?.__internalRequest__\n ? config?.host\n : utilAssembledRequestHost(publicConfig.requestHostname, config?.host!)\n\n return host\n}\n\n/**\n * 请求服务console关于guard的配置\n * @param forceUpdate\n * @param appId\n * @param config\n * @param httpClient\n * @param setError\n */\nexport const useFetchConsoleConfig = (\n forceUpdate: number,\n appId?: string,\n config?: GuardLocalConfig,\n httpClient?: GuardHttp,\n setError?: any\n) => {\n const [publicConfig, setPublicConfig] = useState<ApplicationConfig>()\n const [pageConfig, setPageConfig] = useState<GuardPageConfig>()\n const initPublicConfig = useCallback(async () => {\n if (httpClient && appId) {\n if (!getPublicConfig(appId)) {\n try {\n await Promise.all([\n await requestPublicConfig(appId, httpClient),\n await requestGuardPageConfig(appId, httpClient),\n ])\n } catch (error) {\n setError(error)\n }\n }\n setPublicConfig(getPublicConfig(appId))\n setPageConfig(getPageConfig(appId))\n }\n }, [appId, httpClient, setError])\n\n useEffect(() => {\n initPublicConfig()\n }, [initPublicConfig, forceUpdate])\n\n return useMemo(() => {\n if (publicConfig && config && pageConfig) {\n return {\n finallyConfig: {\n ...mergedPublicConfig(config, publicConfig),\n host: assembledRequestHost(config, publicConfig),\n },\n guardPageConfig: pageConfig,\n }\n } else {\n return {\n finallyConfig: undefined,\n guardPageConfig: undefined,\n }\n }\n }, [config, pageConfig, publicConfig])\n}\n","import { AuthenticationClient } from 'authing-js-sdk'\nimport { Lang } from 'authing-js-sdk/build/main/types'\nimport { useEffect, useMemo, useState } from 'react'\nimport { useGlobalAuthClient } from '../AuthClientProvider/AuthClientProvider'\nimport version from '../version'\nimport { GuardLocalConfig } from './config'\n\nlet authClient: AuthenticationClient\n\nconst checkAuthClientProps = (\n client: AuthenticationClient,\n props: {\n appId: string\n tenantId?: string\n }\n): boolean => {\n const { appId, tenantId } = props\n\n if (client.options.appId !== appId) {\n throw new Error(\n 'AuthClientProvider 与 Guard AppId 初始化不同,请检查初始化时传入的 AppId 是否正确'\n )\n }\n\n if (tenantId && client.options.tenantId !== tenantId) {\n throw new Error(\n 'AuthClientProvider 与 Guard TenantId 初始化不同,请检查初始化时传入的 TenantId 是否正确'\n )\n }\n\n return true\n}\n\nexport const initGuardAuthClient = (\n config: GuardLocalConfig,\n appId: string,\n tenantId?: string\n) => {\n const host = config.host\n const lang = config.lang\n\n if (!authClient) {\n try {\n authClient = new AuthenticationClient({\n appHost: host,\n tenantId: tenantId,\n appId,\n lang: lang as Lang,\n requestFrom: `Guard@${version}`,\n onError: (code, msg: any) => {\n console.error(code, msg)\n },\n })\n } catch (error: any) {\n throw error\n }\n }\n\n return authClient\n}\n\nexport const useInitGuardAuthClient = (props: {\n config?: GuardLocalConfig\n appId?: string\n authClient?: AuthenticationClient\n setError?: any\n tenantId?: string\n}) => {\n const { config, appId, setError, tenantId } = props\n const globalClient = useGlobalAuthClient()\n\n const [client, setClient] = useState<AuthenticationClient>()\n\n useEffect(() => {\n if (!config || !appId) return\n\n const host = config.host\n const lang = config.lang\n const propsAuthClient = props?.authClient\n\n // 优先检测 props 中的 authClient 对象\n if (propsAuthClient) {\n try {\n checkAuthClientProps(propsAuthClient, { appId, tenantId })\n\n setClient(propsAuthClient)\n\n return\n } catch (error) {\n setError(error)\n }\n }\n // 如果 props 中的 authClient 对象不存在,则检测全局的 authClient 对象\n if (globalClient) {\n try {\n checkAuthClientProps(globalClient, { appId, tenantId })\n\n setClient(globalClient)\n\n return\n } catch (error) {\n setError(error)\n }\n }\n\n // 如果全局的 authClient 对象也不存在,则初始化一个新的 authClient 对象\n try {\n const authClient = new AuthenticationClient({\n appHost: host,\n tenantId: tenantId,\n appId,\n lang: lang as Lang,\n requestFrom: `Guard@${version}`,\n onError: (code, msg: any) => {\n console.error(code, msg)\n },\n })\n\n setClient(authClient)\n } catch (error) {\n setError(error)\n }\n }, [appId, config, globalClient, props?.authClient, setError, tenantId])\n\n useMemo(() => {\n if (!client) return\n authClient = client\n }, [client])\n\n return client\n}\n\nexport const getGuardAuthClient = () => {\n if (!authClient) {\n throw new Error('Please initialize GuardAuthClient')\n }\n\n return authClient\n}\n\nexport const useGuardAuthClient = () => getGuardAuthClient()\n","import React from 'react'\nimport { AuthenticationClient, CommonMessage, User } from 'authing-js-sdk'\nimport { GuardModuleType } from '../Guard/module'\nimport { FacePlugin } from '../_utils/facePlugin/interface'\nimport { ApplicationConfig } from './application'\nexport * from './application'\nexport type { CommonMessage, User }\n\nexport type Lang = 'zh-CN' | 'en-US' | 'zh-TW' | 'ja-JP'\n\nexport enum GuardMode {\n Modal = 'modal',\n Normal = 'normal',\n}\n\nexport interface IG2FCProps extends IG2Events {\n appId?: string\n tenantId?: string\n config?: Partial<IG2Config>\n visible?: boolean\n initData?: any\n appendConfig?: GuardAppendConfig\n facePlugin?: FacePlugin\n authClient?: AuthenticationClient\n}\n\nexport interface GuardAppendConfig {\n internalRequest?: boolean\n singleComponent?: boolean\n unAuthFlow?: boolean\n publicConfig?: ApplicationConfig\n pageConfig?: GuardPageConfig\n}\n\nexport interface IG2FCViewProps extends IG2FCProps {\n config: IG2Config\n}\n\nexport interface IG2Config {\n title?: string\n logo?: string\n lang?: string\n langRange?: Lang[]\n host: string\n isHost?: boolean // 判断是否处于托管页面\n mode: GuardMode\n clickCloseable: boolean\n escCloseable: boolean\n userpool?: string\n contentCss?: string\n target?: HTMLElement | string\n style?: React.CSSProperties\n __internalRequest__?: boolean\n __singleComponent__?: boolean\n __unAuthFlow__?: boolean\n}\n\nconst defaultG2Config: IG2Config = {\n escCloseable: true,\n clickCloseable: true,\n mode: GuardMode.Normal,\n host: 'https://core.authing.cn',\n}\n\nexport interface IG2Events {\n onLoad?: (authClient: AuthenticationClient) => void\n onLoadError?: (error: any) => void\n onClose?: () => void\n onLangChange?: (lang: Lang) => void\n // __codePaser?: (code: number) => Function\n __changeModule?: (moduleName: GuardModuleType, initData?: any) => void\n}\n\nexport const getDefaultG2Config = (): IG2Config => defaultG2Config\n\nexport const LanguageMap: any = {\n 'en-US': 'US',\n en: 'GB',\n 'en-GB': 'GB',\n 'ja-JP': 'JP',\n 'de-DE': 'DE',\n 'zh-CN': 'CN',\n}\n\nexport enum InputMethod {\n EmailCode = 'email-code',\n PhoneCode = 'phone-code',\n}\n\nexport enum GuardPageSene {\n Global = 'global',\n}\n\nexport interface GuardPageConfig {\n [GuardPageSene.Global]: {\n showChangeLanguage: boolean\n defaultLanguage: Lang | 'browser'\n }\n}\n\nexport enum EmailScene {\n // 通知模版\n // - 欢迎邮件 WELCOME\n WELCOME_EMAIL = 'WELCOME_EMAIL',\n // - 首次创建用户通知 FIRST_LOGIN_VERIFY\n FIRST_CREATED_USER = 'FIRST_CREATED_USER',\n\n // 注册/登录验证码模板 VERIFY_CODE\n // - 注册验证码\n REGISTER_VERIFY_CODE = 'REGISTER_VERIFY_CODE',\n // - 登录验证码\n LOGIN_VERIFY_CODE = 'LOGIN_VERIFY_CODE',\n // - MFA 验证\n MFA_VERIFY_CODE = 'MFA_VERIFY_CODE',\n // - 信息补全验证码\n INFORMATION_COMPLETION_VERIFY_CODE = 'INFORMATION_COMPLETION_VERIFY_CODE',\n\n // 验证模版 VERIFY_EMAIL\n // - 首次邮箱登录验证\n FIRST_EMAIL_LOGIN_VERIFY = 'FIRST_EMAIL_LOGIN_VERIFY',\n // - 在控制台发起验证\n CONSOLE_CONDUCTED_VERIFY = 'CONSOLE_CONDUCTED_VERIFY',\n\n // 重置密码模版 RESET_PASSWORD\n // - 重置密码验证码\n RESET_PASSWORD_VERIFY_CODE = 'RESET_PASSWORD_VERIFY_CODE',\n\n // 邮箱绑定模版 CHANGE_EMAIL\n // - 邮箱绑定验证码\n EMAIL_BIND_VERIFY_CODE = 'EMAIL_BIND_VERIFY_CODE',\n // - 邮箱解绑验证码\n EMAIL_UNBIND_VERIFY_CODE = 'EMAIL_UNBIND_VERIFY_CODE',\n // 自助解锁验证码\n SELF_UNLOCKING_VERIFY_CODE = 'SELF_UNLOCKING_VERIFY_CODE',\n}\n","import { AuthenticationClient } from 'authing-js-sdk'\nimport React from 'react'\n\nexport interface AuthClientContextProps {\n client: AuthenticationClient\n}\n\nexport const AuthClientContext = React.createContext<\n AuthClientContextProps | undefined\n>(undefined)\n","import React, { ReactNode, useContext } from 'react'\nimport { AuthClientContext, AuthClientContextProps } from './context'\n\nexport const AuthClientProvider: React.FC<\n AuthClientContextProps & {\n children: ReactNode\n }\n> = (props) => {\n const { children, client } = props\n\n const Provider = AuthClientContext.Provider\n\n return <Provider value={{ client }}>{children}</Provider>\n}\n\nexport const useGlobalAuthClient = () => {\n const authClientContext = useContext(AuthClientContext)\n\n return authClientContext?.client\n}\n","export default '4.3.10-alpha.0'","import version from './version'\n\nexport default version\n","/* eslint-disable prettier/prettier */\nimport { message } from 'antd'\nimport { User } from 'authing-js-sdk'\nimport { GuardModuleType } from '.'\nimport { CompleteInfoEvents } from '../CompleteInfo/interface'\nimport { ForgetPasswordEvents } from '../ForgetPassword/interface'\nimport { IdentityBindingEvents } from '../IdentityBinding/interface'\nimport { IdentityBindingAskEvents } from '../IdentityBindingAsk'\nimport { LoginEvents } from '../Login/interface'\nimport { RegisterEvents } from '../Register/interface'\nimport { TenantPortalEvents } from '../TenantPortalSelect/interface'\nimport { i18n } from '../_utils/locales'\nimport { StoreInstance } from './core/hooks/useMultipleAccounts'\n\ninterface OnAfterChangeModuleOptions {\n currentView: string\n currentModule: GuardModuleType\n currentTab?: string\n data?: any\n}\n\nexport interface GuardEvents\n extends LoginEvents,\n RegisterEvents,\n CompleteInfoEvents,\n ForgetPasswordEvents,\n IdentityBindingEvents,\n IdentityBindingAskEvents,\n TenantPortalEvents {\n onBeforeChangeModule?: (\n key: GuardModuleType,\n initData?: any\n ) => boolean | Promise<boolean>\n onAfterChangeModule?: (options: OnAfterChangeModuleOptions) => void\n}\n\n/**\n * 包裹用户 Events\n * 这里为必须存在的 Events\n * @param eventName 事件名\n * @param events 事件列表\n * @param callback 事件触发时前置函数\n */\nconst wrapperEvents = <\n N extends keyof GuardEvents,\n T extends Required<GuardEvents>[N] = Required<GuardEvents>[N]\n>(\n eventName: N,\n events: GuardEvents,\n callback: (oldEvent: any, ...props: Parameters<T>) => ReturnType<T>\n) => {\n // 对于特殊event进行处理\n const oldEvents = events[eventName]\n // @ts-ignore TODO: 后续类型处理\n events[eventName] = (...props: Parameters<T>) => {\n callback(oldEvents, ...props)\n return props\n }\n}\n\nexport const guardEventsFilter = (\n props: any,\n multipleInstance?: StoreInstance,\n openEventsMapping?: boolean\n) => {\n const events: GuardEvents = {}\n\n const eventsNameWhiteList = ['__changeModule']\n\n const eventsName = Object.keys(props).filter(\n (name) => name.startsWith('on') || eventsNameWhiteList.includes(name)\n )\n\n eventsName.forEach((eventName) => {\n events[eventName as keyof GuardEvents] = props[eventName]\n })\n\n // 保证必须存在 onLogin 函数\n wrapperEvents<'onLogin'>('onLogin', events, (oldEvents, ...props) => {\n const [user] = props\n multipleInstance?.setUserInfo(user)\n oldEvents && oldEvents(...props)\n })\n\n return guardEventsHijacking(events, openEventsMapping)\n}\n\nconst eventsMapping: Partial<GuardEvents> = {\n onLogin: (user: User & { encryptedPassword?: string }, client) => {\n message.success(i18n.t('common.LoginSuccess'))\n\n if (user) {\n user.token && client.setToken(user.token)\n delete user.password\n delete user.encryptedPassword\n client.setCurrentUser(user)\n }\n\n return [user, client]\n },\n\n onRegister: (...props) => {\n message.success(i18n.t('common.registrationSuccess'))\n return props\n },\n}\n\nexport const guardEventsHijacking = (\n events: GuardEvents,\n openEventsMapping?: boolean\n): GuardEvents => {\n const newEvents: GuardEvents = {}\n Object.keys(eventsMapping).forEach((eventsKey) => {\n // @ts-ignore\n newEvents[eventsKey] = (...props) => {\n // 必须执行的\n // @ts-ignore\n openEventsMapping && eventsMapping[eventsKey](...props)\n // @ts-ignore\n events[eventsKey]?.(...props)\n }\n })\n\n return {\n ...events,\n ...newEvents,\n }\n}\n\nexport const GuardEventsCamelToKebabMapping = {\n onLoad: 'load',\n onLoadError: 'load-error',\n onLogin: 'login',\n onBeforeLogin: 'before-login',\n onLoginError: 'login-error',\n onRegister: 'register',\n onBeforeRegister: 'before-register',\n onRegisterError: 'register-error',\n onEmailSend: 'email-send',\n onEmailSendError: 'email-send-error',\n onPhoneSend: 'phone-send',\n onPhoneSendError: 'phone-send-error',\n onPwdReset: 'pwd-reset',\n onPwdResetError: 'pwd-reset-error',\n onClose: 'close',\n onLoginTabChange: 'login-tab-change',\n onRegisterTabChange: 'register-tab-change',\n onRegisterInfoCompleted: 'register-info-completed',\n onRegisterInfoCompletedError: 'register-info-completed-error',\n onLangChange: 'lang-change',\n onBeforeChangeModule: 'before-change-module',\n onAfterChangeModule: 'after-change-module'\n} as const\n\nexport interface GuardEventsKebabToCamelType {\n // 加载完成,userPool 配置和应用配置(如果有 appId)加载完成\n load: GuardEvents['onLoad']\n // 加载失败\n 'load-error': GuardEvents['onLoadError']\n // 登录前,即表单校验完成,请求接口前\n 'before-login': GuardEvents['onBeforeLogin']\n // 用户登录成功\n login: GuardEvents['onLogin']\n // 用户登录失败\n 'login-error': GuardEvents['onLoginError']\n // 注册前,即表单校验完成,请求接口前\n 'before-register': GuardEvents['onBeforeRegister']\n // 注册成功\n register: GuardEvents['onRegister']\n // 注册失败\n 'register-error': GuardEvents['onRegisterError']\n // 邮件发送成功\n 'email-send': GuardEvents['onEmailSend']\n // 邮件发送失败\n 'email-send-error': GuardEvents['onEmailSendError']\n // 手机验证码发送成功\n 'phone-send': GuardEvents['onPhoneSend']\n // 手机验证码发送失败\n 'phone-send-error': GuardEvents['onPhoneSendError']\n // 重置密码成功\n 'pwd-reset': GuardEvents['onPwdReset']\n // 重置密码失败\n 'pwd-reset-error': GuardEvents['onPwdResetError']\n // 表单关闭事件\n close: GuardEvents['onClose']\n // 登录的 tab 切换\n 'login-tab-change': GuardEvents['onLoginTabChange']\n // 注册的 tab 切换\n 'register-tab-change': GuardEvents['onRegisterTabChange']\n // 注册信息补充完毕\n 'register-info-completed': GuardEvents['onRegisterInfoCompleted']\n // 注册信息补充失败\n 'register-info-completed-error': GuardEvents['onRegisterInfoCompletedError']\n // 语言切换\n 'lang-change': GuardEvents['onLangChange']\n // 切换模块前\n 'before-change-module': GuardEvents['onBeforeChangeModule']\n 'after-change-module': GuardEvents['onAfterChangeModule']\n}\n","import {\n getDefaultG2Config,\n IG2Config,\n IG2Events,\n IG2FCProps,\n IG2FCViewProps,\n} from '../Type'\nimport { AuthenticationClient, User } from 'authing-js-sdk'\nimport { QrCodeAuthenticationClient } from 'authing-js-sdk/build/main/lib/authentication/QrCodeAuthenticationClient'\nimport {\n Agreement,\n LoginMethods,\n SocialConnectionProvider,\n} from '../Type/application'\n\nexport interface LoginConfig extends IG2Config {\n autoRegister?: boolean\n disableResetPwd?: boolean\n disableRegister?: boolean\n defaultLoginMethod?: LoginMethods\n loginMethods?: LoginMethods[]\n passwordLoginMethods?: string[]\n socialConnections?: SocialConnectionProvider[]\n socialConnectionsBtnShape?: 'default' | 'button' | 'icon'\n enterpriseConnections?: string[]\n qrCodeScanOptions?: Parameters<QrCodeAuthenticationClient['startScanning']>[1]\n publicKey?: string\n agreementEnabled?: boolean\n agreements?: Agreement[]\n /**\n * 关闭二维码状态check轮询(console上使用)\n */\n _closeLoopCheckQrcode?: boolean\n}\n\nexport interface LoginEvents extends IG2Events {\n onLogin?: (user: User, authClient: AuthenticationClient) => void\n onLoginError?: (errorMessages: any) => void\n onLoginTabChange?: (activeTab: LoginMethods) => void\n onBeforeLogin?: (\n // TODO 具体的类型定义\n loginInfo: any,\n authClient: AuthenticationClient\n ) => boolean | Promise<boolean>\n}\n\nexport interface GuardLoginProps extends IG2FCProps, LoginEvents {\n config?: Partial<LoginConfig>\n}\nexport interface GuardLoginViewProps extends GuardLoginProps, IG2FCViewProps {\n config: LoginConfig\n}\n\nexport interface GuardLoginInitData {\n specifyDefaultLoginMethod?: LoginMethods //指定登录页默认登录方式\n _firstItemInitialValue?: string //第一个输入框的回填值\n _lockMethod?: string //锁定登录方式\n}\n\nexport const getDefaultLoginConfig = (): LoginConfig => ({\n ...getDefaultG2Config(),\n})\n","import { AuthenticationClient, User } from 'authing-js-sdk'\nimport { IG2FCProps, IG2Config, getDefaultG2Config, IG2Events } from '../Type'\nimport { Agreement, RegisterMethods } from '../Type/application'\n\nexport interface RegisterConfig extends IG2Config {\n disableRegister?: boolean\n registerMethods?: string[]\n defaultRegisterMethod?: string\n publicKey?: string\n agreementEnabled?: boolean\n agreements?: Agreement[]\n registerContext?: any\n}\n\nconst defaultConfig: RegisterConfig = {\n ...getDefaultG2Config(),\n}\n\nexport interface RegisterEvents extends IG2Events {\n onBeforeRegister?: (\n // TODO 类型定义补充\n registerInfo: any,\n authClient: AuthenticationClient\n ) => boolean | Promise<boolean>\n onRegister?: (user: User, authClient: AuthenticationClient) => void\n onRegisterError?: (error: any) => void\n onRegisterTabChange?: (activeTab: RegisterMethods) => void\n}\n\nexport interface GuardRegisterProps extends IG2FCProps, RegisterEvents {\n config?: Partial<RegisterConfig>\n}\n\nexport interface GuardRegisterViewProps extends GuardRegisterProps {\n config: RegisterConfig\n}\n\nconst getDefaultConfig = (): RegisterConfig => ({\n ...getDefaultG2Config(),\n ...defaultConfig,\n})\n\nexport const getDefaultRegisterConfig = getDefaultConfig\n","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nvar _ref2 = /*#__PURE__*/React.createElement(\"style\", null, \"\\n #path-f {\\n fill: none;\\n stroke: #0080ff;\\n stroke-width: 8.2;\\n stroke-dasharray: 100 220;\\n animation: dash 40s infinite linear forwards;\\n stroke-linecap: round;\\n stroke-linejoin: round;\\n\\n }\\n #path-b {\\n fill: none;\\n stroke: #eaebee;\\n stroke-width: 8;\\n stroke-linecap: round;\\n stroke-linejoin: round;\\n }\\n @keyframes dash {\\n to {\\n stroke-dashoffset: 12000;\\n }\\n }\\n \");\n\nvar _ref3 = /*#__PURE__*/React.createElement(\"g\", {\n id: \"\\\\u5355\\\\u72EC\",\n transform: \"translate(25.000000, 16.000000)\",\n fillRule: \"nonzero\",\n strokeWidth: 2\n}, /*#__PURE__*/React.createElement(\"path\", {\n d: \"M50,0 L0,30 C0,31 0,32 0,33 C0,69 20,100 50,116 C79,100 100,69 100,33 C100,32 99,31 99,30 L50,0 Z\",\n id: \"path-b\"\n}), /*#__PURE__*/React.createElement(\"path\", {\n d: \"M50,0 L0,30 C0,31 0,32 0,33 C0,69 20,100 50,116 C79,100 100,69 100,33 C100,32 99,31 99,30 L50,0 Z\",\n id: \"path-f\"\n}));\n\nfunction SvgLoading(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, [\"title\", \"titleId\"]);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: \"100%\",\n height: \"100%\",\n viewBox: \"0 0 150 150\",\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), _ref2, title === undefined ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, \"Loading\") : title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _ref3);\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgLoading);\nexport default __webpack_public_path__ + \"static/media/loading.3cf0104f.svg\";\nexport { ForwardRef as ReactComponent };","import { GuardLocalConfig } from '../config'\nimport { GuardModuleType } from '../module'\nimport isEqual from 'lodash/isEqual'\nimport { getGuardWindow } from '../core/useAppendConfig'\n\nexport interface ModuleState {\n moduleName: GuardModuleType\n initData?: any\n}\n\nexport enum ActionType {\n ChangeModule = 'ChangeModule',\n Back = 'Back',\n Init = 'Init',\n}\n\nexport interface StateMachineLog {\n action: ActionType\n date: number\n dataSource: ModuleState\n}\n\nexport type ChangeModuleEvent = (\n nextModule: GuardModuleType,\n initData?: any\n) => void\n\nlet guardStateMachine: GuardStateMachine\n\nexport class GuardStateMachine {\n // 计数器\n private order: number = 0\n\n // 总体的配置信息\n private config: Partial<GuardLocalConfig> = {}\n\n // 历史记录\n private moduleStateHistory: ModuleState[] = []\n\n private changeModuleEvent: ChangeModuleEvent\n\n // Log\n private stateMachineLog: Record<number, StateMachineLog> = {}\n\n constructor(changeModuleEvent: ChangeModuleEvent, initData: ModuleState) {\n this.changeModuleEvent = changeModuleEvent\n\n this.globalWindow()?.addEventListener('popstate', this.onPopstate)\n\n this.historyPush(initData, ActionType.Init)\n }\n\n uninstallPopstate = () => {\n this.globalWindow()?.removeEventListener('popstate', this.onPopstate)\n }\n\n globalWindow = (): Window | undefined => {\n const guardWindow = getGuardWindow()\n\n return guardWindow ?? undefined\n }\n\n next = (nextModule: GuardModuleType, initData: any) => {\n const globalWindow = this.globalWindow()\n\n const moduleData: ModuleState = {\n moduleName: nextModule,\n initData,\n }\n this.changeModuleEvent(nextModule, initData)\n\n const prevModuleData = this.moduleStateHistory.slice(1, 2)[0]\n\n if (this.isUseHistoryHijack()) {\n globalWindow?.history.pushState(\n nextModule,\n '',\n globalWindow?.location.href\n )\n }\n\n // 快照history\n if (prevModuleData && isEqual(prevModuleData, moduleData)) {\n this.back()\n } else {\n this.historyPush(moduleData)\n }\n\n // console.log('next Log', this.stateMachineLog)\n // console.log('next History', this.moduleStateHistory)\n }\n\n back = (initData: any = {}) => {\n if (this.moduleStateHistory.length <= 1) return\n const backModule = this.moduleStateHistory[1]\n\n this.changeModuleEvent(backModule.moduleName, {\n ...initData,\n ...backModule.initData,\n })\n this.moduleStateHistory.splice(0, 1)\n\n // console.log('back Log', this.stateMachineLog)\n }\n\n // 业务终点 Log 发送\n end = () => {\n // console.log('业务终点 Log', this.stateMachineLog)\n // TODO 请求\n }\n\n historyPush = (\n data: ModuleState,\n actionType: ActionType = ActionType.ChangeModule\n ) => {\n this.moduleStateHistory.unshift(data)\n\n this.stateMachineLog[this.order++] = {\n action: actionType,\n date: new Date().getTime(),\n dataSource: data,\n }\n\n if (this.moduleStateHistory.length > 10)\n this.moduleStateHistory.splice(10, this.moduleStateHistory.length - 10)\n }\n\n historyBack = (data: ModuleState) => {\n if (this.moduleStateHistory.length <= 1) return\n\n this.moduleStateHistory.splice(0, 1)\n\n this.stateMachineLog[this.order++] = {\n action: ActionType.Back,\n date: new Date().getTime(),\n dataSource: data,\n }\n }\n\n setConfig = (config: Partial<GuardLocalConfig>) => {\n this.config = config\n }\n\n isUseHistoryHijack = () => {\n return this.globalWindow()?.location.href !== 'about:blank'\n }\n\n onPopstate = () => {\n this.back()\n }\n}\n\n// export const useHistoryHijack = (back?: () => void) => {\n// const globalWindow = getGuardWindow()\n\n// const isUseHistoryHijack = useMemo(\n// () => globalWindow?.location.href !== 'about:blank',\n\n// [globalWindow?.location.href]\n// )\n\n// const next = (state: any = {}) => {\n// if (!isUseHistoryHijack) {\n// return\n// }\n\n// globalWindow?.history.pushState(state, '', globalWindow?.location.href)\n// }\n\n// useEffect(() => {\n// if (!isUseHistoryHijack) {\n// return () => {}\n// }\n\n// const onPopstate = () => {\n// back?.()\n// }\n\n// back && globalWindow?.addEventListener('popstate', onPopstate)\n\n// return () => {\n// back && globalWindow?.removeEventListener('popstate', onPopstate)\n// }\n// }, [back, globalWindow, isUseHistoryHijack])\n\n// return [next]\n// }\n\nexport const initGuardStateMachine = (\n changeMouleEvent: ChangeModuleEvent,\n initData: ModuleState\n) => {\n guardStateMachine = new GuardStateMachine(changeMouleEvent, initData)\n return guardStateMachine\n}\n\nexport const getGuardStateMachine = () => {\n if (!guardStateMachine) throw new Error('Please initialize GuardStateMachine')\n\n return guardStateMachine\n}\n\nexport const useGuardStateMachine = () => getGuardStateMachine()\n","import React from 'react'\nimport { useGuardPublicConfig } from '../_utils/context'\n\n//@ts-ignore\nimport { ReactComponent as ShieldSpinLoading } from './loading.svg'\ninterface IG2SpinProps {\n size?: number\n}\n\nexport const ShieldSpin = (props: IG2SpinProps) => {\n const publicConfig = useGuardPublicConfig()\n let size = props.size ? props.size : 50\n\n return (\n <div\n style={{\n width: size,\n height: size,\n }}\n >\n {publicConfig?.customLoading ? (\n <img src={publicConfig.customLoading} alt=\"\" width={size} />\n ) : (\n <ShieldSpinLoading />\n )}\n </div>\n )\n}\n\nexport const Spin = () => (\n <div className=\"g2-init-setting-loading\">\n <ShieldSpin size={100} />\n </div>\n)\n","import React from 'react'\nimport { ReactNode } from 'react'\nimport { GuardModuleType } from '.'\nimport { ForgetPasswordConfig } from '../ForgetPassword/interface'\nimport { getDefaultLoginConfig, LoginConfig } from '../Login/interface'\nimport { getDefaultRegisterConfig, RegisterConfig } from '../Register/interface'\nimport { ShieldSpin } from '../ShieldSpin'\n\nexport interface GuardLocalConfig\n extends RegisterConfig,\n LoginConfig,\n ForgetPasswordConfig {\n isSSO?: boolean\n defaultScenes?: GuardModuleType\n defaultInitData?: any\n showLoading?: boolean\n loadingComponent?: ReactNode\n /**\n * @description 是否调用 eventsMapping 中的事件\n */\n openEventsMapping?: boolean\n}\n\nlet defaultConfig: GuardLocalConfig = {\n ...getDefaultLoginConfig(),\n ...getDefaultRegisterConfig(),\n isSSO: false,\n defaultInitData: {},\n showLoading: true,\n openEventsMapping: true,\n _closeLoopCheckQrcode: false,\n loadingComponent: (\n <div className=\"g2-init-setting-loading\">\n <ShieldSpin size={100} />\n </div>\n ),\n}\n\nexport const getDefaultGuardLocalConfig = (): GuardLocalConfig => {\n return defaultConfig\n}\n","let flowHandleStorage: string | undefined\n\nexport const getFlowHandle = () => {\n return flowHandleStorage\n}\n\nexport const useFlowHandle = getFlowHandle\n\nexport const updateFlowHandle = (flowHandle: string) => {\n flowHandleStorage = flowHandle\n}\n\nexport const useUpdateFlowHandle = updateFlowHandle\n","import qs from 'qs'\nimport { i18n } from './locales'\nimport { CodeAction } from './responseManagement/interface'\nimport Axios, { AxiosRequestConfig, CancelTokenSource } from 'axios'\nimport { getCurrentLng } from '.'\n\nexport const requestClient = async (...rest: Parameters<typeof fetch>) => {\n const res = await fetch(...rest)\n return res.json()\n}\n\nexport interface AuthingResponse<T = any> {\n code?: number\n statusCode?: number\n apiCode?: number\n data?: T\n messages?: string\n message?: string\n flowHandle?: string\n}\n\nexport interface AuthingGuardResponse<T = any> extends AuthingResponse<T> {\n onGuardHandling?: () => CodeAction\n isFlowEnd?: boolean\n}\n\nconst timeoutAction = (cancel: CancelTokenSource['cancel']) => {\n const timer: number = 10\n return new Promise((resolve) => {\n setTimeout(() => {\n const response = {\n data: {\n code: -1,\n },\n }\n resolve(response)\n\n cancel() // 发送终止信号\n }, timer * 1000)\n })\n}\n\nrequestClient.get = async <T>(\n path: string,\n query: Record<string, any> = {},\n init?: AxiosRequestConfig\n): Promise<AuthingResponse<T>> => {\n // let controller = new AbortController()\n // let signal = controller.signal\n\n const headers: Record<string, any> = {\n ...init?.headers,\n 'Content-Type': 'application/json',\n [requestClient.langHeader]: getCurrentLng(),\n }\n\n if (requestClient.tenantId !== '')\n headers[requestClient.tenantHeader] = requestClient.tenantId\n try {\n const CancelToken = Axios.CancelToken\n const source = CancelToken.source()\n\n const res: any = await Promise.race([\n timeoutAction(source.cancel),\n Axios(\n `${requestClient.baseUrl}${path}${qs.stringify(query, {\n addQueryPrefix: true,\n })}`,\n {\n method: 'GET',\n ...init,\n withCredentials: true,\n headers,\n cancelToken: source.token,\n }\n ),\n ])\n return res?.data\n } catch (e) {\n return Promise.resolve({\n code: -2,\n })\n }\n}\n\nrequestClient.post = async <T>(\n path: string,\n data: any,\n config?: {\n headers: any\n }\n): Promise<AuthingResponse<T>> => {\n // let controller = new AbortController()\n // let signal = controller.signal\n\n const headers: Record<string, any> = {\n ...config?.headers,\n 'Content-Type': 'application/json',\n [requestClient.langHeader]: i18n.language,\n }\n\n if (requestClient.tenantId !== '')\n headers[requestClient.tenantHeader] = requestClient.tenantId\n\n try {\n const CancelToken = Axios.CancelToken\n const source = CancelToken.source()\n\n const res: any = await Promise.race([\n timeoutAction(source.cancel),\n Axios(`${requestClient.baseUrl}${path}`, {\n data,\n method: 'POST',\n withCredentials: true,\n cancelToken: source.token,\n headers: {\n 'Content-Type': 'application/json',\n ...config?.headers,\n [requestClient.langHeader]: getCurrentLng(),\n },\n }),\n ])\n return res?.data\n } catch (e) {\n return Promise.resolve({\n code: -2,\n })\n }\n\n // const res = await fetch(`${requestClient.baseUrl}${path}`, {\n // method: 'POST',\n // body: JSON.stringify(data),\n // credentials: 'include',\n // headers: {\n // 'Content-Type': 'application/json',\n // ...config?.headers,\n // [requestClient.langHeader]: i18n.language,\n // },\n // })\n}\n\nrequestClient.postForm = async <T>(\n path: string,\n formData: any,\n config?: {\n headers: any\n }\n): Promise<AuthingResponse<T>> => {\n // let controller = new AbortController()\n // let signal = controller.signal\n try {\n const CancelToken = Axios.CancelToken\n const source = CancelToken.source()\n\n const res: any = await Promise.race([\n timeoutAction(source.cancel),\n Axios(`${requestClient.baseUrl}${path}`, {\n method: 'POST',\n data: formData,\n withCredentials: true,\n cancelToken: source.token,\n headers: {\n ...config?.headers,\n [requestClient.langHeader]: getCurrentLng(),\n },\n }),\n ])\n\n return res?.data\n } catch (e) {\n return Promise.resolve({\n code: -2,\n })\n }\n}\n\nrequestClient.baseUrl = ''\nrequestClient.setBaseUrl = (base: string) => {\n requestClient.baseUrl = base.replace(/\\/$/, '')\n}\n\nconst DEFAULT_LANG_HEADER = 'x-authing-lang'\nconst DEFAULT_TENANT_HEADER = 'x-authing-app-tenant-idåå'\nrequestClient.langHeader = DEFAULT_LANG_HEADER\nrequestClient.tenantHeader = DEFAULT_TENANT_HEADER\nrequestClient.tenantId = ''\n\nrequestClient.setLangHeader = (key: string | undefined) => {\n requestClient.langHeader = key || DEFAULT_LANG_HEADER\n}\n\nrequestClient.setTenantHeader = (key: string | undefined) => {\n requestClient.tenantHeader = key || DEFAULT_LANG_HEADER\n}\n\nrequestClient.setTenantId = (tenantId: string) => {\n requestClient.tenantId = tenantId\n}\n","import { message } from 'antd'\nimport { getHundreds } from '..'\nimport { AuthingGuardResponse, AuthingResponse } from '../http'\nimport { i18n } from '../locales'\nimport { ApiCode, CodeAction } from './interface'\n\nexport const errorCodeInterceptor: (\n res: AuthingResponse<any>,\n callBack: (code: CodeAction, res: AuthingResponse) => AuthingGuardResponse\n) => AuthingResponse<any> = (res, callBack) => {\n if (res.code === -1) {\n message.error(i18n.t('common.timeout'))\n\n return res\n }\n if (res.code === -2) {\n message.error(i18n.t('common.fetchError'))\n\n return res\n }\n\n if (!res.statusCode) return res\n\n const statusCode = res.statusCode\n\n const apiCode = res.apiCode\n\n // if ([6].includes(getHundreds(statusCode))) {\n // callBack(CodeAction.RENDER_MESSAGE, res)\n\n // return res\n // }\n\n // TODO 临时逻辑 如果有 Code 的话 先不走 statusCode 的行为\n // 否则会出现 messages 渲染两次的问题\n // if (!!res.code) return res\n\n switch (getHundreds(statusCode)) {\n case 3:\n if (apiCode === ApiCode.FLOW_END) {\n return callBack(CodeAction.FLOW_END, res)\n } else {\n return callBack(CodeAction.CHANGE_MODULE, res)\n }\n\n case 4:\n case 6:\n return callBack(CodeAction.RENDER_MESSAGE, res)\n\n default:\n break\n }\n\n return res\n}\n","import version from '../version'\nimport { getFlowHandle } from './flowHandleStorage'\nimport { AuthingGuardResponse, AuthingResponse, requestClient } from './http'\nimport { errorCodeInterceptor } from './responseManagement'\nimport { CodeAction } from './responseManagement/interface'\n\nlet httpClient: GuardHttp\n\nenum InterceptorName {\n ERROR_CODE = 'errorCode',\n}\n\ntype ResponseInterceptor = (res: AuthingResponse) => AuthingResponse\n\nexport class GuardHttp {\n private requestClient: any\n private headers: Record<string, string> = {\n 'x-authing-userpool-id': '',\n 'x-authing-app-id': '',\n 'x-authing-sdk-version': version,\n 'x-authing-request-from': `Guard@${version}`,\n }\n\n private responseInterceptorMap: Map<\n InterceptorName,\n ResponseInterceptor\n > = new Map()\n\n constructor(baseUrl?: string) {\n if (!baseUrl) return\n this.getRequestClient().setBaseUrl(baseUrl)\n }\n\n private getRequestClient() {\n if (!this.requestClient) {\n this.requestClient = requestClient\n }\n\n return this.requestClient\n }\n\n setUserpoolId(userpoolId: string) {\n this.headers['x-authing-userpool-id'] = userpoolId\n return this\n }\n\n setAppId(appId: string) {\n this.headers['x-authing-app-id'] = appId\n return this\n }\n\n setTenantId(tenantId: string) {\n this.headers['x-authing-app-tenant-id'] = tenantId\n return this\n }\n\n setBaseUrl(baseUrl: string) {\n this.getRequestClient().setBaseUrl(baseUrl)\n return this\n }\n\n public getHeaders = () => this.headers\n\n public get = async <T = any>(\n path: string,\n query: Record<string, any> = {},\n config?: any\n ): Promise<AuthingGuardResponse<T>> => {\n const res = await requestClient.get<T>(path, query, {\n ...config,\n headers: { ...this.headers, ...config?.headers },\n })\n return this.responseIntercept(res)\n }\n\n public post = async <T = any>(\n path: string,\n data: any,\n config?: {\n headers: any\n }\n ): Promise<AuthingGuardResponse<T>> => {\n const res = await requestClient.post<T>(path, data, {\n headers: {\n ...this.headers,\n ...config?.headers,\n },\n })\n return this.responseIntercept(res)\n }\n\n public postForm = async <T = any>(\n path: string,\n formData: any,\n config?: {\n headers: any\n }\n ): Promise<AuthingGuardResponse<T>> => {\n const res = await requestClient.postForm<T>(path, formData, {\n headers: {\n ...this.headers,\n ...config?.headers,\n },\n })\n\n return this.responseIntercept(res)\n }\n\n public authFlow = async <T = any>(\n action: string,\n data?: any\n ): Promise<AuthingGuardResponse<T>> => {\n const flowPath = '/interaction/authFlow'\n\n const flowHandle = getFlowHandle()\n\n const requestData = {\n action,\n data,\n flowHandle,\n }\n\n const res = await requestClient.post<T>(flowPath, requestData, {\n headers: {\n ...this.headers,\n },\n })\n\n return this.responseIntercept(res)\n }\n\n // 初始化 Error code 拦截器\n public initErrorCodeInterceptor = (\n callBack: (code: CodeAction, res: AuthingResponse) => AuthingGuardResponse\n ) => {\n // 初始化 errorCode 响应拦截器\n if (this.responseInterceptorMap.has(InterceptorName.ERROR_CODE)) return\n\n this.responseInterceptorMap.set(\n InterceptorName.ERROR_CODE,\n (res) => errorCodeInterceptor(res, callBack) // 传入调度拦截器回调\n )\n\n return this\n }\n\n public responseIntercept: (res: AuthingResponse) => AuthingGuardResponse = (\n res\n ) => {\n if (this.responseInterceptorMap.size === 0) return res\n\n const interceptors = Array.from(this.responseInterceptorMap.values())\n\n return interceptors.reduce((acc, cur) => cur(acc), res)\n }\n}\n\nexport const initGuardHttp = (baseUrl: string) => {\n if (!httpClient) {\n const guardHttp = new GuardHttp(baseUrl)\n httpClient = guardHttp\n }\n\n return httpClient\n}\n\nexport const getGuardHttp = () => {\n if (!httpClient) {\n throw new Error('Please initialize Http Client')\n }\n\n return httpClient\n}\n\nexport const useGuardHttp = () => getGuardHttp()\n","export enum ErrorCode {\n OTP_MFA_CODE = 1635,\n APP_MFA_CODE = 1636,\n INPUT_CAPTCHACODE = 2000,\n USER_EXISTENCE = 2026,\n LOGIN_INVALID = 2021,\n PASSWORD_ERROR = 2333,\n USER_NOT_EXIST = 2004,\n MULTIPLE_ERROR_LOCK = 2057,\n ACCOUNT_LOCK = 2005,\n}\n","import { User } from 'authing-js-sdk'\nimport { getGuardHttp } from '../_utils/guardHttp'\n\nexport interface SessionData {\n session: null | {\n _id: string\n cookie: {\n originalMaxAge: number\n expires: Date\n secure: boolean\n httpOnly: boolean\n path: string\n sameSite: string\n }\n appId?: string\n type: string\n userId: string\n }\n userInfo?: User\n}\n\nexport const trackSession = async () => {\n const { get } = getGuardHttp()\n return await get<SessionData>(`/cas/session`, {})\n}\n","/* eslint-disable prettier/prettier */\n/**\n * 整体的思路:\n * 在所有登录方式中,当进行登录时保存登录方式(FE侧自定义)\n * 之后在登录成功(onLogin)中,触发store的方法保存用户信息以及对应的登录方式进入localStorage。\n * 当用户再次打开页面时,拿出数据进行对比。(主要对比 LoginWay ),TODO: 这里的代码主要显得乱的原因是因为枚举的不正当使用。(主要要和Server端进行互相映射,后续维护时可优化)\n *\n * 核心思路:登录成功时,保存的FE侧自定义 LoginWay\n * 再次打开页面时,初始化时先根据 FE 自定义的 LoginWay 跳转到不同的 tab 下(way)下使用 account 进行回填。TODO: 这里也可优化,应该在登录成功时候就进行 LoginWay 的格式化,而非转来转去。(但是这样无法直观的体现是哪种方式进行登录)\n */\n\nimport { useCallback, useEffect, useMemo, useState } from 'react'\nimport { cloneDeep } from 'lodash'\nimport { SelectOptions } from '../../../Login/multipleAccounts/panel'\nimport { getPublicConfig } from '../../../_utils/config'\n\nconst MULTIPLE_ACCOUNT_KEY = '__authing__multiple_accounts'\n\n// 多账号计算 way 方式\nconst MULTIPLE_ACCOUNT_LISTS: LoginWay[] = [\n 'email',\n 'phone',\n 'password',\n 'phone-code',\n 'email-code',\n 'ad',\n 'ldap',\n 'ldap-password',\n 'ldap-email',\n 'ldap-phone',\n]\n\n// 扫码登录方式\nexport const QR_CODE_WAY: LoginWay[] = [\n 'wechat-miniprogram-qrcode',\n 'wechatmp-qrcode',\n 'app-qrcode',\n]\n\n// 展示多账号时 默认排除的登录方式\nconst EXCLUDE_CODE_WAY: LoginWay[] = QR_CODE_WAY.concat('social')\n\n/**\n * 登录时所有支持的登录列表(前端定义列表)\n * 这里稍微有点乱 因为Login中的登录方式和这里的不匹配,暂时放在了一起\n */\nexport type LoginWay =\n | 'email' // 邮箱密码登录\n | 'phone' // 手机号密码登录\n | 'password' // 用户名登录 | 自定义扩展字段登录\n | 'phone-code' // 手机号验证码登录\n | 'email-code' // 邮箱验证码登录\n | 'social' // 社会化登录\n | 'wechat-miniprogram-qrcode' // 小程序扫码登录\n | 'wechatmp-qrcode' // 公众号扫码登录方式\n | 'app-qrcode' // App 扫码登录方式\n | 'ad' // AD 登录方式\n | 'ldap' // LDAP 登录方式\n | 'ldap-password'\n | 'ldap-email'\n | 'ldap-phone'\n | 'authing-otp-push'\n\n/**\n * when: 多账号页面跳转进入登录页面\n * 携带的回填数据信息\n */\nexport interface BackFillMultipleState\n extends Omit<\n User,\n | 'id'\n | 'name'\n | 'nickname'\n | 'username'\n | 'phone'\n | 'email'\n | 'photo'\n | '_updateTime'\n > {\n /**\n * 回填的账号名称 邮箱/用户名/手机\n */\n account: string\n}\n\n/**\n * Store instance\n */\nexport type StoreInstance = ReturnType<MultipleAccount['getStore']>\n\n/**\n * originStore 类型\n */\ninterface MultipleStore {\n [appId: string]: CurrentStore\n}\n\n/**\n * 当前 userId 对应的类型\n */\nexport interface CurrentStore {\n [id: string]: User\n}\n\nexport interface User {\n /**\n * userId\n */\n id: string\n /**\n * Tab 栏状态\n */\n tab: 'input' | 'qrcode'\n /**\n * 登录方式\n */\n way: LoginWay\n /**\n * 姓名\n */\n name?: string | null\n /**\n * 昵称\n */\n nickname?: string | null\n /**\n * 用户名\n */\n username?: string | null\n /**\n * 手机号\n */\n phone?: string | null\n /**\n * 邮箱\n */\n email?: string | null\n /**\n * 头像\n */\n photo?: string | null\n /**\n * qrCodeId 对应的ID\n */\n qrCodeId?: string\n /**\n * 国际化短信区号\n */\n phoneCountryCode?: string\n /**\n * 国际化短信选择框回填\n */\n areaCode?: string\n /**\n * 登录时间\n */\n _updateTime?: string\n}\n\nclass MultipleAccount {\n /**\n * 原始的登录账号\n */\n private originAccount: string = ''\n private originWay: string = ''\n /**\n * 原始的 localStore 值\n */\n private originStore: MultipleStore = {}\n /**\n * 当前 AppId Store\n */\n private currentStore: MultipleStore[string] = {}\n /**\n * 单账号直接回填\n */\n private firstBackFillData?: BackFillMultipleState\n /**\n * server 返回支持的登录方式\n */\n private serverSideLoginMethods: LoginWay[]\n\n /**\n * 是否显示多账号登录页面\n * true 存在\n */\n private memberState: boolean\n /**\n * 二维码登录时的ID\n */\n private qrCodeId?: string\n /**\n * 国际化短信前缀 区号\n */\n private phoneCountryCode?: string\n /**\n * 国际化短信前缀 选中地区编号\n */\n private areaCode?: string\n private tabStatus?: 'qrcode' | 'input'\n /**\n * 当前登录二级状态\n */\n private loginWay?: LoginWay\n private appId: string\n /**\n * 是否开启国际化短信\n */\n private isInternationSms?: boolean\n\n constructor() {\n // 二级别Tab\n this.loginWay = undefined\n // 一级Tab\n this.tabStatus = undefined\n this.qrCodeId = undefined\n // 国际化短信\n this.phoneCountryCode = undefined\n this.areaCode = undefined\n\n this.originStore = {}\n this.currentStore = {}\n\n this.appId = ''\n this.memberState = false\n this.firstBackFillData = undefined\n this.serverSideLoginMethods = []\n }\n\n /**\n * 页面首次加载时初始化 Store\n * 从 LocalStore 中拿值 放到这里来\n */\n private initStore = (\n appId: string,\n options: {\n serverSideLoginMethods: LoginWay[]\n isInternationSms: boolean\n }\n ) => {\n const { serverSideLoginMethods, isInternationSms } = options\n this.appId = appId\n this.isInternationSms = isInternationSms\n this.serverSideLoginMethods = serverSideLoginMethods\n // TODO: 单独抽离 utils 方法 localStorage\n this.originStore =\n JSON.parse(localStorage.getItem(MULTIPLE_ACCOUNT_KEY) || '{}') || {}\n\n // 当前 Appid 中所有的内容\n this.currentStore = this.getCurrentStore(this.originStore)\n // 初始化回填页面 & 回填数据\n const { backfillData, memberState } = this.initMemberState()\n this.firstBackFillData = backfillData\n this.memberState = memberState\n }\n\n /**\n * 初始化记住账号相关信息\n * @param normalCount\n * @returns\n */\n private initMemberState = () => {\n // 获取到对应的 验证码个数,默认的个数\n const { qrCount, normalCount } = this.memberStateCount()\n // 登录是否渲染多账号状态\n let memberState = false\n // 需要回填的数据\n let backfillData: BackFillMultipleState | undefined\n if (normalCount > 1) {\n // 多个有效的账号\n memberState = true\n } else if (normalCount === 1) {\n // 单个有效账号\n backfillData = this.initBackfillData('input')\n memberState = false\n } else if (qrCount >= 1) {\n // 仅有二维码\n memberState = false\n backfillData = this.initBackfillData('qrCode')\n }\n return {\n memberState,\n backfillData,\n }\n }\n\n /**\n * 获取当前ID下有效账号个数\n * @returns qrCount 有效的二维码登录个数 normalCount 有效的账号登录方式\n */\n private memberStateCount = () => {\n let qrCount = 0\n let normalCount = 0\n const values = Object.values(this.currentStore)\n for (const value of values) {\n const { tab } = value\n // 1. 扫码登录\n if (tab === 'qrcode') {\n qrCount++\n }\n // 2. 正常回填的个数\n if (tab === 'input') {\n normalCount++\n }\n }\n return {\n qrCount,\n normalCount,\n }\n }\n\n /**\n * 初始化第一次的数据 TODO: 逻辑有点脏 待整理\n */\n private initBackfillData = (initWay: 'qrCode' | 'input') => {\n // TODO: backfillData 回填时考虑 AD 和 LDAP 对应的账号\n const wayLists = initWay === 'qrCode' ? QR_CODE_WAY : MULTIPLE_ACCOUNT_LISTS\n const userLists = Object.values(this.currentStore)\n const user = userLists.find((i) => wayLists.includes(i.way))\n // 如果是扫码的用户 回填状态就可以了\n if (user && wayLists.includes(user.way)) {\n const data =\n initWay === 'qrCode'\n ? {\n account: '',\n way: user.way,\n }\n : this.getAccountByWay(user.way, user)\n\n return {\n ...data,\n tab: user.tab,\n qrCodeId: user.qrCodeId,\n phoneCountryCode: user.phoneCountryCode,\n areaCode: user.areaCode,\n }\n }\n }\n\n /**\n * 根据前端存储的登录方式返回后端映射方式\n * @param front\n */\n private getServerLoginMethodByFront = (front: LoginWay) => {\n // 排除 social 方式 TODO: Mappint 常量抽离\n const mapping: Record<Exclude<LoginWay, 'social'>, string> = {\n ldap: 'ldap',\n 'ldap-password': 'ldap',\n 'ldap-phone': 'ldap',\n 'ldap-email': 'ldap',\n ad: 'ad',\n email: 'email-password',\n password: 'username-password',\n phone: 'phone-password',\n 'email-code': 'phone-code',\n 'phone-code': 'phone-code',\n 'wechat-miniprogram-qrcode': 'wechat-miniprogram-qrcode',\n 'wechatmp-qrcode': 'wechatmp-qrcode',\n 'app-qrcode': 'app-qrcode',\n 'authing-otp-push': 'authing-otp-push'\n }\n if (front !== 'social') {\n return mapping[front]\n }\n }\n\n /**\n * 当前 Store DONE\n */\n private getCurrentStore = (originStore: MultipleStore) => {\n const currentStore = originStore[this.appId] || {}\n const serverSideLoginMethods = this.serverSideLoginMethods\n const result = Object.create(null)\n\n for (const [key, value] of Object.entries(currentStore)) {\n // 1. 过滤 Server 关闭的账号\n const passMethod = this.validateMethod(value, serverSideLoginMethods)\n // 2. 校验国际化短信 过滤\n const passMsm = this.validateInternationSms(value)\n if (passMsm && passMethod) {\n result[key] = cloneDeep(value)\n }\n }\n return result\n }\n\n /**\n * 国际化短信过滤\n * true 表示通过 需要保留\n * false 表示不通过 需要过滤\n */\n private validateInternationSms = (user: User) => {\n if (user.way !== 'phone-code') {\n return true\n }\n const isInternationSms = this.isInternationSms\n const { phoneCountryCode, areaCode } = user\n // 这个用户是否是国际化短信登录\n const currentIsInternationSms = phoneCountryCode || areaCode\n return isInternationSms ? currentIsInternationSms : !currentIsInternationSms\n }\n\n /**\n * 校验有效的登录方式账号\n * @param user\n * @param serverSideLoginMethods\n * @returns\n */\n private validateMethod = (user: User, serverSideLoginMethods: LoginWay[]) => {\n const { way } = user\n const serverWay = this.getServerLoginMethodByFront(way)\n const validateInternationSms = this.validateInternationSms(user)\n return (\n validateInternationSms &&\n serverWay &&\n serverSideLoginMethods.includes(serverWay as any)\n )\n }\n\n /**\n *\n * @param tab 一级Tab状态\n * @param way 二级Tab状态\n * @param id 二维码登录时 记录对应的二维码 ID\n */\n private setLoginWay = (\n tab: 'input' | 'qrcode',\n way: LoginWay,\n id?: string,\n internation?: {\n phoneCountryCode: string\n areaCode: string\n }\n ) => {\n this.tabStatus = tab\n this.loginWay = way\n this.qrCodeId = id\n // 国际化短信的区号\n if (internation) {\n const { phoneCountryCode, areaCode } = internation\n this.phoneCountryCode = phoneCountryCode\n this.areaCode = areaCode\n }\n }\n\n /**\n * 设置/更新 store 内的用户信息\n */\n private setUserInfo = (\n user: Omit<User & { id: string, loginAccount?: string }, 'way' | 'tab' | 'phoneCountryCode'> // 添加扩展字段登录名\n ) => {\n // 排除 ad 登录方式\n if (!user || !this.loginWay || !this.tabStatus || this.loginWay === 'ad') {\n console.log(`User or LoginWay does not exist.`)\n return\n }\n const { photo, nickname, phone, username, email, id, name, loginAccount } = user\n this.currentStore[id] = Object.assign({\n way: this.loginWay, // 登录方式\n tab: this.tabStatus, // 当前大tab 扫码 or 输入\n photo,\n nickname,\n phone,\n username: loginAccount || username,\n name,\n email,\n id,\n qrCodeId: this.qrCodeId,\n phoneCountryCode: this.phoneCountryCode,\n areaCode: this.areaCode,\n _updateTime: Date.now(),\n })\n this.saveStore()\n }\n\n /**\n * 持久化保存\n */\n private saveStore = () => {\n const newStore = Object.assign({}, this.originStore, {\n [this.appId]: this.currentStore,\n })\n localStorage.setItem(MULTIPLE_ACCOUNT_KEY, JSON.stringify(newStore))\n }\n\n /**\n * 根据登录的 account 判断本次登录的方式\n * @param account 登录输入的账号\n * @param param1 登录成功返回的相关信息 用户名/手机号/邮箱\n * @returns\n */\n private setLoginWayByHttpData = (\n account: string,\n data: {\n username?: string\n phone?: string\n email?: string\n }\n ) => {\n // TODO: 临时保存对应的account\n this.originAccount = account\n this.originWay = 'password'\n const { username, phone, email } = data\n switch (account) {\n case username:\n return this.setLoginWay('input', 'password')\n case phone:\n return this.setLoginWay('input', 'phone')\n case email:\n return this.setLoginWay('input', 'email')\n default:\n return this.setLoginWay('input', 'password')\n }\n }\n\n /**\n * 根据登录的 account 判断本次LDAP登录方式\n * @param account 登录输入的账号\n * @param param1 登录成功返回的相关信息 用户名/手机号/邮箱\n * @returns\n */\n private setLoginWayByLDAPData = (\n account: string,\n data: {\n name?: string\n phone?: string\n email?: string\n }\n ) => {\n this.originAccount = account\n this.originWay = 'ldap'\n const { name, phone, email } = data\n switch (account) {\n case name:\n return this.setLoginWay('input', 'ldap-password')\n case phone:\n return this.setLoginWay('input', 'ldap-phone')\n case email:\n return this.setLoginWay('input', 'ldap-email')\n // MFA 情况都不匹配,那么直接处理 name\n default:\n return this.setLoginWay('input', 'ldap-password')\n }\n }\n\n /**\n * 根据用户 ID 删除 localStorage 中当前用户 ID\n */\n private delUserById = (id: string) => {\n // 1. 在 current Store 中删除当前ID\n if (id in this.currentStore) {\n delete this.currentStore[id]\n // 2. 更新 localStorage\n this.saveStore()\n }\n return id\n }\n\n /**\n * 获得多账号登录页面的所有用户列表\n * @param excludeWays\n */\n private getMemoUser = (excludeWays: LoginWay[] = EXCLUDE_CODE_WAY) => {\n const currentStore = this.currentStore\n const result: SelectOptions[] = []\n\n for (const item of Object.values(currentStore)) {\n const { way } = item\n const value = this._mappingUser(item)\n if (!excludeWays.includes(way)) {\n result.push(value)\n }\n }\n // 这里没有过滤\n return result.sort((a, b) => b._updateTime - a._updateTime).slice(0, 3)\n }\n\n /**\n * 根据 id 获得当前已登录的用户信息\n * @param userId\n * @returns User / undefined\n */\n private getMemoSingleUser: (\n id: string\n ) => { way: LoginWay; account: string } | undefined = (userId: string) => {\n // 根据登录方式进行过滤映射\n const currentUser = this.currentStore[userId]\n if (currentUser) {\n // 根据登录方式进行处理\n const { way, phoneCountryCode, areaCode } = currentUser\n const { account, way: parseWay } = this.getAccountByWay(way, currentUser)\n return {\n account,\n way: parseWay,\n // fix: 回填时需要携带国际化信息。\n phoneCountryCode,\n areaCode,\n }\n }\n }\n\n /**\n * 该方法仅仅需要回填账号的登录方式,其他都不计入\n * 当用户名/手机号/邮箱/AD/LDAP 相同时,根据登录顺序匹配不同的账号\n * 根据记住的用户登录方式获取对应的登录账户名\n * @param way\n * @param user\n * @returns\n */\n private getAccountByWay: (\n way: LoginWay,\n user: User\n ) => { way: LoginWay; account: string } = (way: LoginWay, user: User) => {\n const { email, phone, username, name } = user\n // 根据对应的 LoginWay 进行返回\n switch (way) {\n case 'email':\n return { account: email!, way: 'password' }\n case 'email-code':\n return { account: email!, way: 'phone-code' }\n case 'phone-code':\n return { account: phone!, way: 'phone-code' }\n case 'phone':\n return { account: phone!, way: 'password' }\n case 'password':\n return { account: username!, way: 'password' }\n case 'ad':\n return { account: name!, way: 'ad' }\n case 'ldap-password':\n return { account: name!, way: 'ldap' }\n case 'ldap-email':\n return { account: email!, way: 'ldap' }\n case 'ldap-phone':\n return { account: phone!, way: 'ldap' }\n case 'authing-otp-push':\n return { account: username! || phone!, way: 'authing-otp-push' }\n default:\n throw new Error(`已登录用户匹配不到的登录方式`)\n }\n }\n\n private _mappingUser = (value: User) => {\n const {\n id,\n photo,\n name,\n nickname,\n username,\n email,\n phone,\n _updateTime,\n phoneCountryCode,\n way,\n } = value\n // 1. 姓名 > 昵称 > username\n const title = name || nickname || username || undefined\n // 2. 处理手机号是否是国家化显示\n const parsePhone = phoneCountryCode ? `${phoneCountryCode} ${phone}` : phone\n // 3. phone > email\n const description = parsePhone || email || undefined\n return {\n title,\n description,\n id,\n photo: photo || '',\n // 国际化 phoneCountryCode\n _updateTime: parseInt(_updateTime || '0'),\n way\n }\n }\n\n /**\n * 外部暴露方法\n */\n getStore = () => {\n return {\n initStore: this.initStore,\n // 当前登录方式\n setLoginWay: this.setLoginWay,\n // 设置用户信息\n setUserInfo: this.setUserInfo,\n // TODO: 脏逻辑\n setLoginWayByHttpData: this.setLoginWayByHttpData,\n setLoginWayByLDAPData: this.setLoginWayByLDAPData,\n // 获得当前 AppId 下对应的数据\n getMemoUser: this.getMemoUser,\n // 获得当前 userId 下的对应单个用户信息\n getMemoSingleUser: this.getMemoSingleUser,\n // 删除记录的登录账号\n delUserById: this.delUserById,\n // 是否存在已经登陆账号 > 1\n getMemberState: () => this.memberState,\n // 首次需要回填的数据 单账号记住登录下\n getFirstBackFillData: () => this.firstBackFillData,\n // 原始的登录账号和密码\n getOriginAccount: () => this.originAccount,\n getOriginWay: () => this.originWay,\n }\n }\n}\n\n/**\n * MultipleAccounts 相关 Hook\n * Finally Config 类型过滤\n */\nconst useMultipleAccounts = ({\n appId,\n finallyConfig,\n}: {\n appId?: string\n finallyConfig?: any\n}) => {\n // 页面状态,两种 'isMultipleAccount' TODO: 改成 reducer\n const [isMultipleAccount, setMultipleAccount] = useState(false)\n // 页面记住的数据 给一个初始值\n const [multipleAccountData, setMultipleAccountData] = useState<\n undefined | BackFillMultipleState\n >(undefined)\n\n const [storeInstance, setStoreInstance] = useState<StoreInstance | undefined>(\n undefined\n )\n\n /**\n * 修改登录页是否是多账号登录的状态\n */\n const changeMultipleState = useCallback((type: 'login' | 'multiple') => {\n const boolean = type === 'multiple'\n setMultipleAccount(boolean)\n }, [])\n\n /**\n * 当从账号进入登录页时,更新登录页需要回填的信息\n * 账号信息 & 登录方式\n */\n const updateBackFillData = useCallback((data: BackFillMultipleState) => {\n // 当访完成一次之后 立即清空该数据\n setMultipleAccountData(data)\n }, [])\n\n /**\n * 清空数据\n */\n const clearBackFillData = useCallback(() => {\n setMultipleAccountData(undefined)\n }, [])\n\n /**\n * 更新页面状态 & 数据回填\n */\n const referMultipleState = useCallback(\n (type: 'login' | 'multiple', data?: BackFillMultipleState) => {\n changeMultipleState(type)\n if (data) {\n // updateBackFillData\n updateBackFillData(data)\n }\n },\n [updateBackFillData, changeMultipleState]\n )\n\n /**\n * 初始化数据 & 初始化登录页面渲染状态\n */\n const initFirstState = useCallback(\n (storeInstance: StoreInstance) => {\n const type = storeInstance.getMemberState() ? 'multiple' : 'login'\n // 根据初始值 初始化数据\n referMultipleState(type, storeInstance.getFirstBackFillData())\n },\n [referMultipleState]\n )\n\n useEffect(() => {\n if (!appId || !finallyConfig) {\n return\n }\n const publicConfig = getPublicConfig(appId)\n\n if (!publicConfig?.enableLoginAccountSwitch) {\n return\n }\n // 最终支持的登录方式 用于过滤有效登录方式\n const serverSideLoginMethods = finallyConfig?.loginMethods || []\n // 输入框 邮箱/用户名/手机号 + 密码\n const configLists = finallyConfig?.passwordLoginMethods || []\n // 是否支持国际化短信\n const isInternationSms =\n publicConfig?.internationalSmsConfig?.enabled || false\n // 创建实例\n const instance = new MultipleAccount()\n // 获取实例\n const storeInstance = instance.getStore()\n // 增加一个多的 国际化短信是否开启\n storeInstance.initStore(appId, {\n serverSideLoginMethods: [...configLists, ...serverSideLoginMethods],\n isInternationSms,\n })\n setStoreInstance(storeInstance)\n // 根据 instance 中的状态和数据初始化登录页面状态\n initFirstState(storeInstance)\n }, [appId, finallyConfig, referMultipleState, initFirstState])\n\n return useMemo(() => {\n return {\n instance: storeInstance,\n isMultipleAccount,\n referMultipleState,\n multipleAccountData,\n clearBackFillData,\n }\n }, [\n storeInstance,\n isMultipleAccount,\n referMultipleState,\n multipleAccountData,\n clearBackFillData,\n ])\n}\n\nexport default useMultipleAccounts\n","import { useMemo } from 'react'\nimport { ApplicationConfig } from '../Type'\n\n/** **当前租户应用** 下的租户信息获取和操作处理,将租户相关的处理收拢 */\nexport class MultipleTenant {\n private $config: ApplicationConfig | null\n private $tenantId: string | null\n\n // 不直接使用变量而使用函数形式,是为了后续更加容易扩展并获取实时数据\n constructor(tenantId: string, config: ApplicationConfig) {\n this.$tenantId = tenantId ?? null\n this.$config = config ?? null\n }\n\n /** 获取租户ID */\n public getCurrentTenantId = () => {\n return this.$tenantId\n }\n\n /** 获取租户详情 */\n public getCurrentTenantInfo = () => {\n return this.$config?.tenantInfo\n }\n\n /**是否为【租户控制台】 */\n public isTenantConsole = () => {\n return this.$config?.isTenantConsole\n }\n /** 是否为租户【单点登录】 */\n public isTenantSSO = () => {\n return this.$tenantId && this.$config?.isTenantDefault === false\n }\n /** 是否为租户【单点登录面板】 */\n public isTenantSSOLaunchPad = () => {\n return this.$tenantId && this.$config?.isTenantDefault === true\n }\n}\n\n/** 初始化多租户实例 */\nexport const useMultipleTenant = (\n tenantId: string,\n publicConfig: ApplicationConfig\n) => {\n const tenantInstance = useMemo(() => {\n if (!publicConfig) return\n return new MultipleTenant(tenantId, publicConfig)\n }, [publicConfig, tenantId])\n return tenantInstance\n}\n","import { GuardProps } from '..'\nimport React, {\n ReactNode,\n useCallback,\n useEffect,\n useMemo,\n useReducer,\n useState,\n} from 'react'\nimport { useInitGuardAuthClient } from '../authClient'\nimport { GuardEvents, guardEventsFilter } from '../event'\nimport { insertStyles, regexFromString, removeStyles } from '../../_utils'\nimport { getDefaultGuardLocalConfig } from '../config'\nimport { GuardModuleType } from '../module'\n\nimport {\n GuardStateMachine,\n initGuardStateMachine,\n ModuleState,\n} from '../GuardModule/stateMachine'\nimport { SessionData, trackSession } from '../sso'\nimport {\n getPublicConfig,\n useMergeDefaultConfig,\n useFetchConsoleConfig,\n} from '../../_utils/config'\nimport { GuardHttp, initGuardHttp } from '../../_utils/guardHttp'\nimport { initGuardI18n } from '../../_utils/locales'\nimport { useGuardXContext } from '../../_utils/context'\nimport { useGuardIconfont } from '../../IconFont/useGuardIconfont'\nimport { useInitGuardAppendConfig } from './useAppendConfig'\nimport { useInitAppId } from '../../_utils/initAppId'\nimport { updateFlowHandle } from '../../_utils/flowHandleStorage'\nimport { ApplicationConfig } from '../../Type/application'\nimport { AuthenticationClient } from 'authing-js-sdk'\nimport { Lang } from '../../Type'\nimport { i18n } from '../../_utils/locales'\n\n// hooks\nimport useMultipleAccounts from './hooks/useMultipleAccounts'\nimport { useMultipleTenant } from '../../_utils/tenant'\nimport Axios from 'axios'\n\ninterface IBaseAction<T = string, P = any> {\n type: T & string\n payload?: Partial<P>\n}\n\nexport const RenderContext: React.FC<{\n guardProps: GuardProps\n initState: ModuleState\n children: ReactNode\n}> = ({ guardProps, initState, children }) => {\n const { tenantId, config } = guardProps\n // 强制刷新\n const [forceUpdate, setForceUpdate] = useState(Date.now())\n\n const [events, setEvents] = useState<GuardEvents>()\n const [authClint, setAuthClint] = useState<AuthenticationClient>()\n const [httpClient, setHttpClient] = useState<GuardHttp>()\n const [publicConfig, setPublicConfig] = useState<ApplicationConfig>()\n const [cdnBase, setCdnBase] = useState<string>()\n const [error, setError] = useState()\n const [isAuthFlow, setIsAuthFlow] = useState(true)\n const [i18nInit, setI18nInit] = useState(false)\n const appId = useInitAppId(guardProps.appId, guardProps.authClient, setError)\n\n const [defaultLanguageConfig, setDefaultLanguageConfig] = useState<Lang>()\n\n const [isForeignUserpool, setIsForeignUserpool] = useState(false)\n\n useInitGuardAppendConfig(setForceUpdate, appId, guardProps.appendConfig)\n\n // 状态机\n const [\n guardStateMachine,\n setGuardStateMachine,\n ] = useState<GuardStateMachine>()\n\n const { Provider } = useGuardXContext()\n\n // modules 定义\n const moduleReducer: (\n state: ModuleState,\n action: IBaseAction<GuardModuleType, ModuleState>\n ) => ModuleState = (state, { type, payload }) => {\n return {\n moduleName: type,\n initData: payload?.initData,\n }\n }\n\n // Modules Reducer\n const [moduleState, changeModule] = useReducer(moduleReducer, initState)\n\n // Flow Handle init\n useEffect(() => {\n if (initState.initData?.flowHandle) {\n updateFlowHandle(initState.initData.flowHandle)\n }\n }, [initState.initData])\n\n // Change Module\n const onChangeModule = useCallback(\n async (moduleName: GuardModuleType, initData: any = {}) => {\n if (\n !events?.onBeforeChangeModule ||\n (await events.onBeforeChangeModule(moduleName, initData))\n ) {\n changeModule({\n type: moduleName,\n payload: {\n initData: initData ?? {},\n },\n })\n }\n },\n [events]\n )\n\n // 合并默认值\n const defaultMergedConfig = useMergeDefaultConfig(\n getDefaultGuardLocalConfig(),\n config\n )\n\n // HttpClient\n useEffect(() => {\n if (!appId || !defaultMergedConfig) return\n\n const httpClient = initGuardHttp(defaultMergedConfig.host)\n httpClient.setAppId(appId)\n tenantId && httpClient.setTenantId(tenantId)\n\n setHttpClient(httpClient)\n }, [appId, defaultMergedConfig, tenantId])\n\n /**\n *\n */\n const { finallyConfig, guardPageConfig } = useFetchConsoleConfig(\n forceUpdate,\n appId,\n defaultMergedConfig,\n httpClient,\n setError\n )\n\n const multipleInstance = useMultipleAccounts({\n appId,\n finallyConfig,\n })\n\n const tenantInstance = useMultipleTenant(tenantId!, publicConfig!)\n // // guardPageConfig\n // const guardPageConfig = useGuardPageConfig(\n // forceUpdate,\n // error,\n // appId,\n // httpClient,\n // setError\n // )\n\n const sdkClient = useInitGuardAuthClient({\n config: finallyConfig,\n appId,\n tenantId,\n setError,\n authClient: guardProps.authClient,\n })\n\n // iconfont\n const iconfontLoaded = useGuardIconfont(cdnBase)\n\n // SSO 登录\n useEffect(() => {\n if (!config?.isSSO || !authClint || !events || !httpClient) return\n\n trackSession().then((sessionData) => {\n // 这个接口没有 code, data, 直接返回了数据\n let typedData = (sessionData as unknown) as SessionData\n if (typedData.userInfo) {\n events?.onLogin?.(typedData.userInfo, authClint!)\n }\n })\n }, [appId, authClint, config?.isSSO, events, httpClient])\n\n useEffect(() => {\n if (httpClient && finallyConfig) {\n httpClient?.setBaseUrl(finallyConfig.host)\n }\n }, [finallyConfig, httpClient])\n\n useEffect(() => {\n if (!appId) return\n\n const publicConfig = getPublicConfig(appId)\n\n if (!publicConfig) return\n\n setPublicConfig(publicConfig)\n\n setCdnBase(publicConfig.cdnBase)\n }, [appId, finallyConfig])\n\n // I18n\n useEffect(() => {\n if (guardPageConfig && publicConfig && defaultMergedConfig) {\n const { defaultLanguage } = guardPageConfig.global\n initGuardI18n(\n {\n defaultLanguage:\n (defaultMergedConfig?.lang as Lang) ?? defaultLanguage,\n },\n setI18nInit\n )\n\n setDefaultLanguageConfig(i18n.language as Lang)\n }\n }, [defaultMergedConfig, guardPageConfig, publicConfig, setI18nInit])\n\n // AuthClient\n useEffect(() => {\n setAuthClint(sdkClient)\n }, [sdkClient])\n\n // initEvents\n useEffect(() => {\n if (!defaultMergedConfig) return\n\n const events = guardEventsFilter(\n {\n ...guardProps,\n },\n multipleInstance.instance,\n defaultMergedConfig?.openEventsMapping\n )\n setEvents(events)\n }, [guardProps, multipleInstance, defaultMergedConfig])\n\n // 状态机相关\n useEffect(() => {\n const guardStateMachine = initGuardStateMachine(onChangeModule, initState)\n setGuardStateMachine(guardStateMachine)\n\n return () => {\n guardStateMachine.uninstallPopstate()\n }\n }, [initState, onChangeModule])\n\n // 自定义 CSS 处理\n useEffect(() => {\n if (finallyConfig && finallyConfig.contentCss)\n insertStyles(finallyConfig.contentCss, 'appConfig')\n\n return () => removeStyles('appConfig')\n }, [finallyConfig])\n\n // 是否使用 Guard auth flow\n useEffect(() => {\n if (!finallyConfig) return\n\n setIsAuthFlow(!Boolean(finallyConfig?.__unAuthFlow__))\n }, [finallyConfig])\n\n // 是否是国外用户池\n useEffect(() => {\n const baseUrl = finallyConfig?.host\n\n if (appId && baseUrl) {\n try {\n Axios.get<\n any,\n {\n data: {\n code: number\n data: boolean\n message: string\n }\n }\n >(`${baseUrl}/api/v2/application/${appId}/check-app-is-show-code`)\n .then((res) => {\n const { code, data } = res?.data || {}\n if (code === 200) {\n setIsForeignUserpool(data)\n }\n })\n .catch((error) => {\n console.log('error', error)\n })\n } catch (error) {\n console.log('error', error)\n }\n }\n }, [appId, finallyConfig?.host])\n\n const moduleEvents = useMemo(() => {\n if (!events && !guardStateMachine) return undefined\n return {\n changeModule: async (moduleName: GuardModuleType, initData?: any) => {\n guardStateMachine?.next(moduleName, initData)\n },\n backModule: () => {\n guardStateMachine?.back()\n },\n }\n }, [events, guardStateMachine])\n\n const contextLoaded = useMemo(() => {\n const list = [\n appId,\n events,\n defaultMergedConfig,\n finallyConfig,\n httpClient,\n moduleEvents,\n publicConfig,\n authClint,\n guardPageConfig,\n iconfontLoaded,\n // 保证 store 加载完成\n multipleInstance,\n // 保证 i18n 初始化完成\n i18nInit,\n defaultLanguageConfig,\n tenantInstance,\n ]\n\n return !list.includes(undefined) && !list.includes(false)\n }, [\n appId,\n events,\n defaultMergedConfig,\n finallyConfig,\n httpClient,\n moduleEvents,\n publicConfig,\n authClint,\n guardPageConfig,\n iconfontLoaded,\n multipleInstance,\n i18nInit,\n defaultLanguageConfig,\n tenantInstance,\n ])\n\n const phoneRegex = useMemo(() => {\n const str =\n publicConfig?.regexRules?.find((item) => item.key === 'phone')\n ?.userpoolLevel ?? ''\n if (str) {\n try {\n const regex = regexFromString(str)\n return regex\n } catch (error) {}\n }\n return null\n }, [publicConfig?.regexRules])\n\n // TODO 触发 onLoad 事件\n useEffect(() => {\n if (!contextLoaded || error) return\n\n events?.onLoad?.(authClint!)\n }, [authClint, contextLoaded, error, events])\n\n const contextValues = useMemo(\n () =>\n contextLoaded\n ? {\n contextLoaded,\n isAuthFlow,\n defaultMergedConfig,\n finallyConfig,\n publicConfig,\n httpClient,\n appId,\n tenantId,\n events,\n ...moduleEvents,\n initData: moduleState.initData,\n currentModule: moduleState,\n guardPageConfig,\n // 多账号相关信息 store 实例\n multipleInstance,\n phoneRegex,\n defaultLanguageConfig,\n tenantInstance,\n isForeignUserpool,\n }\n : {\n defaultMergedConfig,\n },\n [\n appId,\n contextLoaded,\n defaultMergedConfig,\n events,\n finallyConfig,\n guardPageConfig,\n httpClient,\n isAuthFlow,\n moduleEvents,\n moduleState,\n publicConfig,\n tenantId,\n multipleInstance,\n phoneRegex,\n defaultLanguageConfig,\n tenantInstance,\n isForeignUserpool,\n ]\n )\n\n const renderContext = useMemo(() => {\n if (!contextValues) return null\n return <Provider value={contextValues}>{children}</Provider>\n }, [Provider, children, contextValues])\n\n const RenderErrorContext = useCallback(() => {\n events?.onLoadError?.(error)\n return (\n <Provider\n value={{\n contextLoaded: true,\n defaultMergedConfig,\n initData: {\n error: error,\n },\n currentModule: {\n moduleName: GuardModuleType.ERROR,\n initData: {\n error,\n },\n },\n }}\n >\n {children}\n </Provider>\n )\n }, [Provider, children, defaultMergedConfig, error, events])\n\n const render = useMemo(() => {\n if (error) return <RenderErrorContext />\n\n if (contextLoaded || Boolean(defaultMergedConfig)) return renderContext\n\n return null\n }, [\n contextLoaded,\n defaultMergedConfig,\n error,\n renderContext,\n RenderErrorContext,\n ])\n\n return render\n}\n","import { AuthenticationClient } from 'authing-js-sdk'\nimport { useEffect, useMemo } from 'react'\nimport { useGlobalAuthClient } from '../AuthClientProvider'\n\nexport interface UseInitAppidProps {\n propsAppid?: string\n propsAuthClient?: AuthenticationClient\n setError?: any\n}\n\nexport const useInitAppId = (\n propsAppid?: string,\n propsAuthClient?: AuthenticationClient,\n setError?: any\n) => {\n const globalAuthClient = useGlobalAuthClient()\n\n const appId = useMemo(() => {\n if (propsAppid) {\n return propsAppid\n } else if (propsAuthClient && propsAuthClient.options.appId) {\n return propsAuthClient.options.appId\n } else if (globalAuthClient && globalAuthClient.options.appId) {\n return globalAuthClient.options.appId\n }\n\n return undefined\n }, [globalAuthClient, propsAppid, propsAuthClient])\n\n useEffect(() => {\n if (appId) return\n\n setError?.(new Error('appId is required'))\n }, [appId, setError])\n\n return appId\n}\n","import { useCallback, useEffect, useState } from 'react'\nimport { getGuardWindow } from '../Guard/core/useAppendConfig'\nimport { GenerateSvg } from './iconfont'\nimport Axios from 'axios'\nexport const useGuardIconfont = (cdnBase?: string, setError?: any) => {\n const [loaded, setLoaded] = useState<boolean>(false)\n\n const initIconfont = useCallback(async () => {\n if (!cdnBase) return\n\n try {\n const res = await Axios(`${cdnBase}/svg-string/guard`)\n\n const body = res.data\n\n const guardWindow = getGuardWindow()\n\n if (!guardWindow) return\n GenerateSvg(guardWindow.document, body)\n\n setLoaded(true)\n } catch (error) {\n setError?.(error)\n }\n }, [cdnBase, setError])\n\n useEffect(() => {\n initIconfont()\n }, [initIconfont])\n\n return loaded\n}\n","import { useRef, useCallback, useEffect } from 'react'\nimport { useMediaQuery } from 'react-responsive'\nimport phone from 'phone'\n// import { LanguageMap } from '../../Type'\nimport {\n isDingtalkBrowser,\n isLarkBrowser,\n // isQQBrowser,\n isQQBuiltInBrowser,\n isSpecialBrowser,\n isWeChatBrowser,\n isWeWorkBuiltInBrowser,\n} from '..'\nimport { GuardLocalConfig } from '../../Guard'\nimport { getGuardWindow } from '../../Guard/core/useAppendConfig'\nimport {\n ApplicationConfig,\n SocialConnectionItem,\n SocialConnectionProvider,\n} from '../../Type/application'\nexport interface PhoneValidResult {\n isValid: boolean\n phoneNumber: string\n countryIso2: string\n countryIso3: string\n countryCode: string\n}\n// 某些社会化登录会在 tabs 中显示,或者无法在 Guard 中使用,所以底部不显示了\nexport const HIDE_SOCIALS = [\n 'wechat:miniprogram:app-launch',\n 'wechat:miniprogram:qrconnect',\n // 'wechat:webpage-authorization',\n 'wechat:miniprogram:default',\n 'wechatwork:addressbook',\n 'wechat:mobile',\n]\n\nexport const HIDE_SOCIALS_SHOWIN_ENTERPRISE = [\n 'dingtalk',\n 'lark-public',\n 'lark-internal',\n 'wechatwork:corp:qrconnect',\n 'wechatwork:service-provider:qrconnect',\n 'wechatwork:agency:qrconnect',\n]\n\nlet thisAppId: string = ''\n\nexport const useAppId = (appId?: string) => {\n if (appId) {\n thisAppId = appId\n }\n\n return thisAppId\n}\n\nexport const useDebounce = (\n // 回调函数\n fn: any,\n // 延迟时间\n delay: number\n) => {\n const timer = useRef<{ time: any }>({ time: null })\n const errorBody = useRef<{ body: any }>({ body: null })\n\n useEffect(() => {\n return () => {\n // eslint-disable-next-line react-hooks/exhaustive-deps\n timer.current.time && clearInterval(timer.current.time)\n }\n }, [])\n\n return useCallback(\n (...args: any[]) => {\n if (timer.current.time) {\n clearTimeout(timer.current.time)\n timer.current.time = null\n }\n timer.current.time = setTimeout(() => {\n // fn.apply(this, args);\n const res = fn(...args)\n timer.current.time = null\n errorBody.current.body = res\n }, delay)\n // if (errorBody.current.body) {\n // return Promise.reject(errorBody.current.body)\n // } else {\n // return Promise.resolve()\n // }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [timer.current, delay]\n )\n}\n\nexport const useMediaSize = () => {\n const isPhoneMedia = useMediaQuery({\n maxWidth: 450,\n })\n\n return {\n isPhoneMedia,\n }\n}\n// shaking 抖动\nexport const useShaking = () => {\n // form input\n const inputs = document.getElementsByClassName('authing-g2-input')\n // 必选协议\n const agreements = document.getElementsByClassName(\n 'authing-agreements-item-invalid'\n )\n const saftyCode = document.getElementsByClassName('authing-g2-code-input')\n\n const bindTotpSecretSave = document.getElementsByClassName(\n 'g2-mfa-bindTotp-secretSave'\n )\n // 挂载 shaking\n const MountShaking = () => {\n Array.from(inputs).forEach((input) => {\n input.classList.add('shaking')\n })\n Array.from(agreements).forEach((agreement) => {\n agreement.classList.add('shaking')\n })\n saftyCode[0] && saftyCode[0].classList.add('shaking')\n bindTotpSecretSave[0] && bindTotpSecretSave[0].classList.add('shaking')\n }\n // 卸载 shaking\n const UnMountShaking = () => {\n Array.from(inputs).forEach((input) => {\n input.classList.remove('shaking')\n })\n Array.from(agreements).forEach((agreement) => {\n agreement.classList.remove('shaking')\n })\n saftyCode[0] && saftyCode[0].classList.remove('shaking')\n bindTotpSecretSave[0] && bindTotpSecretSave[0].classList.remove('shaking')\n }\n return { MountShaking, UnMountShaking }\n}\n\n/**\n * 解析手机号\n * @param fieldValue 字段值\n * @param areaCode 区号\n * @returns\n */\nexport const parsePhone = (\n isInternationSms: boolean,\n fieldValue: string,\n areaCode: string = 'CN'\n) => {\n let countryCode = undefined\n\n let phoneNumber = fieldValue\n // 未开启国家化短信\n if (!isInternationSms) {\n return { phoneNumber, countryCode: undefined }\n }\n // 处理 类似 192*******9 情况\n if (phone(fieldValue, { country: areaCode }).isValid) {\n const parsePhone = phone(fieldValue, {\n country: areaCode,\n }) as PhoneValidResult\n\n countryCode = parsePhone.countryCode as string\n\n phoneNumber = parsePhone.phoneNumber.split(countryCode)[1]\n } else if (phone(fieldValue).isValid) {\n // 处理 +86 19294229909 情况\n const parsePhone = phone(fieldValue) as PhoneValidResult\n\n countryCode = parsePhone.countryCode as string\n\n phoneNumber = parsePhone.phoneNumber.split(countryCode)[1]\n }\n\n return { countryCode, phoneNumber }\n}\n\nexport enum SocialConnectionEvent {\n Message = 'message',\n Auth = 'auth',\n}\n\n/**\n *\n * @param config\n * @returns[socialConnectionObjs 社交身份源连接对象 enterpriseConnectionObjs 企业身份源连接对象 isNoMethod 是否没有身份源 ]\n */\nexport const useMethod: (params: {\n config: GuardLocalConfig\n publicConfig: ApplicationConfig\n}) => any = ({ config, publicConfig }) => {\n const noLoginMethods = !config?.loginMethods?.length\n let enterpriseConnectionObjs: ApplicationConfig['identityProviders']\n if (config.enterpriseConnections) {\n enterpriseConnectionObjs =\n publicConfig?.identityProviders?.filter?.((item) =>\n config.enterpriseConnections!.includes(item.identifier)\n ) || []\n } else {\n enterpriseConnectionObjs = publicConfig?.identityProviders || []\n }\n\n let socialConnectionObjs: (SocialConnectionItem & { action?: string })[]\n\n if (!config.socialConnections) {\n socialConnectionObjs = [...(publicConfig?.socialConnections || [])]\n } else {\n const socials = config.socialConnections\n socialConnectionObjs =\n publicConfig?.socialConnections?.filter?.((item) =>\n socials.includes(item.provider)\n ) ?? []\n }\n\n socialConnectionObjs = socialConnectionObjs\n ?.filter((item) => {\n // 某些社会化登录会在 tabs 中显示,或者无法在 Guard 中使用,所以底部不显示了\n return !HIDE_SOCIALS.includes(item.provider)\n })\n .filter((item: any) => {\n // 某些在企业身份源创建的社交身份源归为企业身份源方式显示\n if (HIDE_SOCIALS_SHOWIN_ENTERPRISE.includes(item.provider)) {\n if (\n !enterpriseConnectionObjs.find(\n (connection: any) => connection.identifier === item.identifier\n )\n ) {\n enterpriseConnectionObjs.push(item)\n }\n return false\n }\n return true\n })\n\n // 在所有身份源下都要隐藏\n const hiddenSocialConnection = [\n 'wechat:mobile',\n 'wechat:miniprogram:app-launch',\n 'wechat:miniprogram:default',\n 'apple',\n 'yidun',\n ]\n\n switch (true) {\n // 微信内置浏览器\n case isWeChatBrowser():\n // 显示 点击提示\n const wechatDisplayButtonsMessage = [\n SocialConnectionProvider.WECHATPC,\n SocialConnectionProvider.GITHUB,\n SocialConnectionProvider.QQ,\n SocialConnectionProvider.APPLE_WEB,\n SocialConnectionProvider.ALIPAY,\n SocialConnectionProvider.LINKEDIN,\n SocialConnectionProvider.BAIDU,\n SocialConnectionProvider.GOOGLE,\n SocialConnectionProvider.WEIBO,\n SocialConnectionProvider.FACEBOOK,\n SocialConnectionProvider.SLACK,\n SocialConnectionProvider.DINGTALK,\n 'wechatwork:mobile',\n 'instagram',\n 'qingcloud',\n 'gitee',\n 'gitlab',\n ]\n\n // 各个浏览器下特殊的身份源隐藏规则\n const hiddenSocialConnectionInWeChatBrowser: string[] = [\n SocialConnectionProvider.WECHATPC,\n ]\n\n socialConnectionObjs = socialConnectionObjs\n .filter(\n (item) =>\n ![\n ...hiddenSocialConnection,\n ...hiddenSocialConnectionInWeChatBrowser,\n ].includes(item.provider)\n )\n .map((item) => {\n if (wechatDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n enterpriseConnectionObjs = enterpriseConnectionObjs\n .filter(\n (item: any) =>\n !(item?.provider && hiddenSocialConnection.includes(item.provider))\n )\n .map((item: any) => {\n if (wechatDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n break\n // qq 内置浏览器\n case isQQBuiltInBrowser():\n const qqbuiltDisplayButtonsMessage = [\n SocialConnectionProvider.WECHATPC,\n SocialConnectionProvider.WECHATMP,\n SocialConnectionProvider.APPLE_WEB,\n SocialConnectionProvider.GOOGLE,\n SocialConnectionProvider.ALIPAY,\n SocialConnectionProvider.WECHATWORK_CORP_QRCONNECT,\n SocialConnectionProvider.DINGTALK,\n 'wechatwork:agency:qrconnect',\n 'wechatwork:mobile',\n ]\n // 各个浏览器下特殊的身份源隐藏规则\n const hiddenSocialConnectionInQQBuiltInBrowser = [\n SocialConnectionProvider.WECHATMP,\n ]\n socialConnectionObjs = socialConnectionObjs\n .filter(\n (item) =>\n ![\n ...hiddenSocialConnection,\n ...hiddenSocialConnectionInQQBuiltInBrowser,\n ].includes(item.provider)\n )\n .map((item) => {\n if (qqbuiltDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n enterpriseConnectionObjs = enterpriseConnectionObjs\n .filter(\n (item: any) =>\n !(item?.provider && hiddenSocialConnection.includes(item.provider))\n )\n .map((item: any) => {\n if (qqbuiltDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n break\n // 企业微信内置浏览器\n case isWeWorkBuiltInBrowser():\n const weWorkBuiltDisplayButtonsMessage = [\n SocialConnectionProvider.WECHATPC,\n SocialConnectionProvider.WECHATMP,\n SocialConnectionProvider.GITHUB,\n SocialConnectionProvider.QQ,\n SocialConnectionProvider.APPLE_WEB,\n SocialConnectionProvider.ALIPAY,\n SocialConnectionProvider.LINKEDIN,\n SocialConnectionProvider.BAIDU,\n SocialConnectionProvider.GOOGLE,\n SocialConnectionProvider.WEIBO,\n SocialConnectionProvider.FACEBOOK,\n SocialConnectionProvider.SLACK,\n SocialConnectionProvider.DINGTALK,\n 'wechatwork:mobile',\n 'instagram',\n 'qingcloud',\n 'gitee',\n 'gitlab',\n ]\n // 各个浏览器下特殊的身份源隐藏规则\n const hiddenSocialConnectionInWeWorkBuiltInBrowser = [\n SocialConnectionProvider.WECHATMP,\n ]\n socialConnectionObjs = socialConnectionObjs\n .filter(\n (item) =>\n ![\n ...hiddenSocialConnection,\n ...hiddenSocialConnectionInWeWorkBuiltInBrowser,\n ].includes(item.provider)\n )\n .map((item) => {\n if (weWorkBuiltDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n enterpriseConnectionObjs = enterpriseConnectionObjs\n .filter(\n (item: any) =>\n !(item?.provider && hiddenSocialConnection.includes(item.provider))\n )\n .map((item: any) => {\n if (weWorkBuiltDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n break\n // 钉钉内置浏览器\n case isDingtalkBrowser():\n const dingTalkDisplayButtonsMessage = [\n SocialConnectionProvider.WECHATPC,\n SocialConnectionProvider.WECHATMP,\n SocialConnectionProvider.QQ,\n SocialConnectionProvider.APPLE_WEB,\n SocialConnectionProvider.GOOGLE,\n SocialConnectionProvider.ALIPAY,\n SocialConnectionProvider.WECHATWORK_CORP_QRCONNECT,\n 'wechatwork:agency:qrconnect',\n 'wechatwork:mobile',\n ]\n\n // 各个浏览器下特殊的身份源隐藏规则\n const hiddenSocialConnectionInDingtalkBrowser = [\n SocialConnectionProvider.WECHATMP,\n ]\n\n socialConnectionObjs = socialConnectionObjs\n .filter(\n (item) =>\n ![\n ...hiddenSocialConnection,\n ...hiddenSocialConnectionInDingtalkBrowser,\n ].includes(item.provider)\n )\n .map((item) => {\n if (dingTalkDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n enterpriseConnectionObjs = enterpriseConnectionObjs\n .filter(\n (item: any) =>\n !(item?.provider && hiddenSocialConnection.includes(item.provider))\n )\n .map((item: any) => {\n if (dingTalkDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n break\n // 飞书内置浏览器\n case isLarkBrowser():\n const larkDisplayButtonsMessage = [\n SocialConnectionProvider.WECHATPC,\n SocialConnectionProvider.WECHATMP,\n SocialConnectionProvider.GITHUB,\n SocialConnectionProvider.QQ,\n SocialConnectionProvider.APPLE_WEB,\n SocialConnectionProvider.ALIPAY,\n SocialConnectionProvider.LINKEDIN,\n SocialConnectionProvider.BAIDU,\n SocialConnectionProvider.GOOGLE,\n SocialConnectionProvider.WEIBO,\n SocialConnectionProvider.FACEBOOK,\n SocialConnectionProvider.SLACK,\n SocialConnectionProvider.DINGTALK,\n 'gitlab',\n 'gitee',\n 'instagram',\n 'wechatwork:agency:qrconnect',\n 'wechatwork:mobile',\n ]\n\n // 各个浏览器下特殊的身份源隐藏规则\n const hiddenSocialConnectionInLarkBrowser = [\n SocialConnectionProvider.WECHATMP,\n ]\n\n socialConnectionObjs = socialConnectionObjs\n .filter(\n (item) =>\n ![\n ...hiddenSocialConnection,\n ...hiddenSocialConnectionInLarkBrowser,\n ].includes(item.provider)\n )\n .map((item) => {\n if (larkDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n enterpriseConnectionObjs = enterpriseConnectionObjs\n .filter(\n (item: any) =>\n !(item?.provider && hiddenSocialConnection.includes(item.provider))\n )\n .map((item: any) => {\n if (larkDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n break\n // pc 浏览器\n default:\n const pcDisplayButtonsMessage = [\n SocialConnectionProvider.WECHATMP,\n 'wechatwork:mobile',\n ]\n\n // 各个浏览器下特殊的身份源隐藏规则\n const hiddenSocialConnectionInPCBrowser = [\n SocialConnectionProvider.WECHATMP,\n ]\n\n socialConnectionObjs = socialConnectionObjs\n .filter(\n (item) =>\n ![\n ...hiddenSocialConnection,\n ...hiddenSocialConnectionInPCBrowser,\n ].includes(item.provider)\n )\n .map((item) => {\n if (pcDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n enterpriseConnectionObjs = enterpriseConnectionObjs\n .filter(\n (item: any) =>\n !(item?.provider && hiddenSocialConnection.includes(item.provider))\n )\n .map((item: any) => {\n if (pcDisplayButtonsMessage.includes(item.provider)) {\n item.action = SocialConnectionEvent.Message\n } else {\n item.action = SocialConnectionEvent.Auth\n }\n return item\n })\n break\n }\n\n const guardWindow = getGuardWindow()\n\n if (!guardWindow) return\n\n if (!config?.isHost && (isSpecialBrowser() || !guardWindow.postMessage)) {\n // 嵌入模式下特殊浏览器不显示所有身份源登录\n socialConnectionObjs = []\n enterpriseConnectionObjs = []\n }\n\n const isNoMethod: boolean =\n noLoginMethods &&\n (!publicConfig?.ssoPageComponentDisplay.socialLoginBtns ||\n !socialConnectionObjs.length) &&\n (!publicConfig?.ssoPageComponentDisplay.idpBtns ||\n !enterpriseConnectionObjs.length)\n return [socialConnectionObjs, enterpriseConnectionObjs, isNoMethod]\n}\n","import { getGuardHttp } from '../_utils/guardHttp'\n\nexport enum BindTotpBusinessAction {\n VerifyTotpFirstTime = 'verify-totp-first-time',\n ConfirmTotpRecoveryCode = 'confirm-totp-recovery-code',\n}\n\nexport const authFlow = async (\n action: BindTotpBusinessAction,\n content: any\n) => {\n const { authFlow } = getGuardHttp()\n\n const res = await authFlow(action, { ...content })\n\n return res\n}\n","import { Button } from 'antd'\nimport React, { useMemo } from 'react'\nimport { ButtonProps } from 'antd/lib/button'\nimport { useGuardButtonState } from '../_utils/context'\nimport './styles.less'\n\nexport interface GuardButtonProps extends ButtonProps {}\n\nexport const GuardButton: React.FC<GuardButtonProps> = (props) => {\n const { spin } = useGuardButtonState()\n\n const { type } = props\n\n const isLockButtonClick = useMemo(() => {\n return spin\n }, [spin])\n\n const buttonClassName = useMemo(() => {\n let { className } = props\n\n if (type) {\n className += ` guard-button-link-like`\n }\n\n if (isLockButtonClick) {\n className += ' guard-button-disabled'\n }\n\n return className\n }, [isLockButtonClick, props, type])\n\n return (\n <Button\n {...props}\n className={buttonClassName}\n onClick={(e) => {\n if (isLockButtonClick) {\n // // 阻止事件冒泡\n // e.stopPropagation()\n return\n }\n\n if (props.onClick) {\n props.onClick(e)\n }\n }}\n />\n )\n}\n","import React, {\n forwardRef,\n useState,\n useImperativeHandle,\n useEffect,\n} from 'react'\nimport { useShaking } from '../_utils/hooks'\nimport { GuardButton } from '../GuardButton'\nimport { useGuardButtonState } from '../_utils/context'\nimport { ButtonProps } from 'antd/lib/button'\n\ninterface SubmitButtonProps extends ButtonProps {\n text?: string\n className?: string\n onClick?: any\n disabled?: boolean\n}\nconst SubmitButton = (props: SubmitButtonProps, ref: any) => {\n const { spinChange, spin: buttonSpin } = useGuardButtonState()\n let [spin, setSpin] = useState(false) // spin 状态需要手动设置关闭\n let [shaking, setShaking] = useState(false) // 抖动状态会自动关闭\n let { MountShaking, UnMountShaking } = useShaking() // 协议和 form input 抖动的挂载和卸载\n\n useEffect(() => {\n let timeOut: NodeJS.Timeout\n if (shaking === true) {\n timeOut = setTimeout(() => {\n UnMountShaking()\n }, 1000)\n }\n\n return () => {\n clearTimeout(timeOut)\n }\n }, [UnMountShaking, shaking])\n\n useImperativeHandle(ref, () => ({\n onError: (text?: string) => {\n setSpin(false)\n MountShaking()\n setShaking(true)\n spinChange(false)\n },\n onSpin: (sp: boolean) => {\n setSpin(sp)\n spinChange(sp)\n },\n }))\n\n let propsCls = props.className ? props.className : ''\n // let shakingCls = shaking ? 'shaking' : ''\n let shakingCls = ''\n return (\n <GuardButton\n {...props}\n size={props?.size ?? 'large'}\n type={props?.type ?? 'primary'}\n htmlType={props?.htmlType ?? 'submit'}\n loading={spin}\n disabled={buttonSpin ? true : props?.disabled ?? spin}\n onClick={props.onClick ? props.onClick : () => {}}\n className={`authing-g2-submit-button ${propsCls} ${shakingCls}`}\n >\n {props.text}\n </GuardButton>\n )\n}\nexport default forwardRef(SubmitButton)\n","import { getDefaultG2Config, IG2Config, IG2Events, IG2FCProps } from '../Type'\nimport { AuthenticationClient, User } from 'authing-js-sdk'\n\nexport interface MFAConfig extends IG2Config {\n autoRegister: boolean\n}\n\nconst defaultConfig: MFAConfig = {\n ...getDefaultG2Config(),\n autoRegister: false,\n}\n\nexport const getDefaultMFAConfig = (): MFAConfig => ({\n ...getDefaultG2Config(),\n ...defaultConfig,\n})\n\nexport interface MFAEvents extends IG2Events {\n onLogin?: (user: User, authClient: AuthenticationClient) => void\n}\n\nexport enum MFAType {\n SMS = 'SMS',\n EMAIL = 'EMAIL',\n TOTP = 'OTP',\n FACE = 'FACE',\n}\n\nexport interface GuardMFAInitData {\n mfaToken: string\n applicationMfa: {\n mfaPolicy: MFAType\n sort: number\n status: 0 | 1\n }[]\n phoneCountryCode?: string\n faceMfaEnabled: boolean\n totpMfaEnabled: boolean\n email?: string\n phone?: string\n avatar?: string\n nickme?: string\n username?: string\n current?: MFAType\n mfaPhoneCountryCode?: string\n mfaPhone?: string\n mfaEmail?: string\n}\n\nexport interface GuardMFAProps extends IG2FCProps, MFAEvents {\n config: Partial<MFAConfig>\n initData: GuardMFAInitData\n}\n\nexport interface GuardMFAViewProps extends GuardMFAProps {\n config: MFAConfig\n initData: GuardMFAInitData\n}\n","import { Form, Checkbox, Typography } from 'antd'\nimport React, { useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport SubmitButton from '../../SubmitButton'\nimport { useGuardIsAuthFlow } from '../../_utils/context'\nimport { authFlow, BindTotpBusinessAction } from '../businessRequest'\n\nconst { Paragraph } = Typography\n\nexport interface BindSuccessProps {\n onBind: any\n secret: string\n}\n\nexport const BindSuccess: React.FC<BindSuccessProps> = ({ secret, onBind }) => {\n // const [isSaved, setIsSaved] = useState(false)\n const submitButtonRef = useRef<any>(null)\n\n const [form] = Form.useForm()\n\n const { t } = useTranslation()\n\n const isAuthFlow = useGuardIsAuthFlow()\n\n const bindSuccess = async () => {\n submitButtonRef.current?.onSpin(true)\n\n await form.validateFields()\n\n if (isAuthFlow) {\n const { data, isFlowEnd, onGuardHandling } = await authFlow(\n BindTotpBusinessAction.ConfirmTotpRecoveryCode,\n {}\n )\n submitButtonRef.current?.onSpin(false)\n if (isFlowEnd) {\n onBind(data)\n } else {\n // TODO 需要 onError 抖动吗 当 from 表单校验通过的时候 onError 是没有意义的\n submitButtonRef.current?.onError()\n onGuardHandling?.()\n }\n } else {\n submitButtonRef.current?.onSpin(false)\n onBind()\n }\n }\n\n return (\n <>\n <p className=\"authing-g2-mfa-title\">{t('common.totpText1')}</p>\n <p className=\"authing-g2-mfa-tips\">{t('common.totpText2')}</p>\n\n <div className=\"g2-mfa-bindTotp-copySecret\">\n <Paragraph copyable>{secret}</Paragraph>\n </div>\n\n <Form\n form={form}\n onFinish={bindSuccess}\n style={{ width: '100%' }}\n onFinishFailed={() => submitButtonRef.current?.onError()}\n >\n <Form.Item\n className=\"authing-g2-input-form g2-mfa-totp-verify-input\"\n name=\"remember\"\n rules={[\n {\n validator: (_, value) => {\n if (!value) {\n return Promise.reject()\n }\n return Promise.resolve()\n },\n },\n ]}\n valuePropName=\"checked\"\n >\n <Checkbox className=\"g2-mfa-bindTotp-secretSave\">\n {t('login.rememberedSecret')}\n </Checkbox>\n </Form.Item>\n\n <SubmitButton text={t('common.bindSuccess')} ref={submitButtonRef} />\n </Form>\n </>\n )\n}\n","import React, { useRef, useState } from 'react'\nimport { GuardButton } from '../GuardButton'\nimport { getClassnames } from '../_utils'\nimport { i18n } from '../_utils/locales'\nimport './styles.less'\n\nexport interface ImageProProps\n extends React.ImgHTMLAttributes<HTMLImageElement> {\n src: string\n className?: string\n alt?: string\n imgClassName?: string\n size?: number | string\n width?: number | string\n height?: number | string\n borderRadius?: number | string\n noSpin?: boolean\n}\n\nexport const ImagePro = (props: ImageProProps) => {\n let { borderRadius, noSpin, alt, style, ...imgProps } = props\n let [loaded, setLoaded] = useState(noSpin === true ? true : false)\n let w: number | string = 0\n let h: number | string = 0\n if (props.size) {\n // size 存在,说明是正方形,让宽高等于 size\n w = props.size\n h = props.size\n } else {\n // 如果 size 不存在,说明长方形,尝试读取宽高\n w = props.width ? props.width : 'auto'\n h = props.height ? props.height : 'auto'\n }\n\n return (\n <div\n style={{ width: w, height: h }}\n className={getClassnames([\n 'g2-base-imagepro-container',\n 'g2-base-image-background-animation',\n loaded ? 'loaded' : 'unload',\n props?.className,\n ])}\n >\n <img\n {...imgProps}\n style={{\n width: w,\n height: '100%',\n borderRadius: borderRadius,\n ...style,\n }}\n className=\"g2-base-imagepro\"\n draggable={false}\n alt={alt || 'image'}\n onLoad={() => setLoaded(true)}\n />\n </div>\n )\n}\n\nexport const ImagePro2 = (props: ImageProProps) => {\n let { borderRadius, noSpin, alt, style, ...imgProps } = props\n let [loaded, setLoaded] = useState(noSpin === true ? true : false)\n const maskRef = useRef<any>(null)\n let w: number | string = 0\n let h: number | string = 0\n if (props.size) {\n // size 存在,说明是正方形,让宽高等于 size\n w = props.size\n h = props.size\n } else {\n // 如果 size 不存在,说明长方形,尝试读取宽高\n w = props.width ? props.width : 'auto'\n h = props.height ? props.height : 'auto'\n }\n\n return (\n <div\n style={{ width: w, height: h }}\n className={getClassnames([\n 'g2-base-imagepro-container',\n 'g2-base-imagepro-container2',\n 'g2-base-image-background-animation',\n loaded ? 'loaded' : 'unload',\n props?.className,\n ])}\n onClick={(e: any) => {\n setLoaded(false)\n props?.onClick && props?.onClick(e)\n if (maskRef.current) {\n maskRef.current.classList.remove('g2-base-imagepro-mask-show')\n }\n }}\n id=\"g2-base-imagepro-container\"\n onMouseMove={() => {\n if (maskRef.current) {\n maskRef.current.classList.add('g2-base-imagepro-mask-show')\n }\n }}\n >\n <img\n {...imgProps}\n style={{\n width: w,\n height: '100%',\n borderRadius: borderRadius,\n ...style,\n }}\n className=\"g2-base-imagepro\"\n draggable={false}\n alt={alt || 'image'}\n onLoad={() => setLoaded(true)}\n />\n {loaded && (\n <div className=\"g2-base-imagepro-mask\" ref={maskRef}>\n <span style={{ marginRight: 4 }}>\n {i18n.t('login.verifyCodeTip')}\n </span>\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <g clip-path=\"url(#clip0_968_21911)\">\n <path\n d=\"M3.64204 2.95599C4.85175 1.90776 6.39937 1.33176 8.00004 1.33399C11.682 1.33399 14.6667 4.31866 14.6667 8.00066C14.6667 9.42466 14.22 10.7447 13.46 11.8273L11.3334 8.00066H13.3334C13.3335 6.95507 13.0262 5.93253 12.4498 5.06016C11.8734 4.1878 11.0533 3.5041 10.0915 3.09407C9.12966 2.68405 8.06852 2.56579 7.04001 2.754C6.01151 2.94221 5.06101 3.42859 4.30671 4.15266L3.64204 2.95599ZM12.358 13.0453C11.1483 14.0935 9.60072 14.6696 8.00004 14.6673C4.31804 14.6673 1.33337 11.6827 1.33337 8.00066C1.33337 6.57666 1.78004 5.25666 2.54004 4.17399L4.66671 8.00066H2.66671C2.66662 9.04624 2.97388 10.0688 3.55027 10.9412C4.12665 11.8135 4.94675 12.4972 5.90859 12.9072C6.87042 13.3173 7.93156 13.4355 8.96007 13.2473C9.98857 13.0591 10.9391 12.5727 11.6934 11.8487L12.358 13.0453Z\"\n fill=\"white\"\n />\n </g>\n <defs>\n <clipPath id=\"clip0_968_21911\">\n <rect width=\"16\" height=\"16\" fill=\"white\" />\n </clipPath>\n </defs>\n </svg>\n </div>\n )}\n {!loaded && (\n <GuardButton\n className=\"g2-base-imagepro-mask g2-base-imagepro-loading\"\n loading\n />\n )}\n </div>\n )\n}\n","import Form, { FormItemProps } from 'antd/lib/form'\nimport React from 'react'\nimport { useTranslation } from 'react-i18next'\nimport './style.less'\nexport interface VerifyCodeFormItemProps extends FormItemProps {\n codeLength: number\n ruleKeyword?: string\n}\n\nexport const VerifyCodeFormItem: React.FC<VerifyCodeFormItemProps> = (\n props\n) => {\n const { t } = useTranslation()\n const {\n codeLength,\n ruleKeyword = t('common.captchaCode'),\n ...formItemProps\n } = props\n return (\n <Form.Item\n validateTrigger={['onChange']}\n name=\"mfaCode\"\n className=\"g2-mfa-totp-verify-input\"\n validateFirst={true}\n rules={[\n {\n type: 'array',\n validateTrigger: ['onChange'],\n message: t('common.isMissing', {\n name: ruleKeyword,\n }),\n required: true,\n },\n {\n type: 'array',\n validateTrigger: [''],\n message: t('common.fullCaptchaCode', {\n name: ruleKeyword,\n }),\n min: codeLength,\n },\n ]}\n {...formItemProps}\n />\n )\n}\n","import { Divider, Input } from 'antd'\nimport React, {\n FC,\n Fragment,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from 'react'\nimport './style.less'\n\ninterface VerifyCodeInputProps extends React.HTMLAttributes<HTMLDivElement> {\n length?: number\n size?: string\n gutter?: string\n onEenter?: Function\n showDivider?: boolean\n onChange?: any\n value?: Array<number | string>\n onFinish?: any\n}\n\nexport const VerifyCodeInput: FC<VerifyCodeInputProps> = ({\n length = 4,\n size = '46px',\n gutter = length > 4 ? '14px' : '24px',\n className,\n onEenter,\n showDivider,\n onChange: onChangeProps,\n value,\n onFinish,\n ...rest\n}) => {\n const inputRef = useRef<any[]>([])\n\n const codeInputRef = useRef<HTMLDivElement>(null)\n\n const fromClipboard = useRef<boolean>(false)\n\n const [verifyCode, setVerifyCode] = useState(value ?? [])\n const [focusIndex, setFocusIndex] = useState<number>(0)\n\n // 聚焦控制\n useEffect(() => {\n inputRef.current[focusIndex].focus()\n }, [focusIndex])\n\n const onChange = useCallback(\n (codes: string[]) => {\n // const filteredCodes = codes.filter((code) => !!code)\n setVerifyCode(codes)\n onChangeProps?.(codes)\n },\n [onChangeProps]\n )\n\n const handleChange = useCallback(\n (val: string | undefined = '', index: number) => {\n const num = parseInt(val)\n if (isNaN(num)) {\n val = ''\n } else {\n val = String(num)\n }\n const codes = [...verifyCode]\n codes[index] = val.split('').slice(-1)[0] || ''\n onChange(codes as string[])\n if (Boolean(val) && Boolean(inputRef.current[index + 1])) {\n setFocusIndex(index + 1)\n }\n\n // 验证码填写完成后 直接触发 onFinish\n if (\n codes.filter((code) => Boolean(code)).length >= length &&\n index >= length - 1\n ) {\n onFinish?.(codes)\n }\n },\n [length, onChange, onFinish, verifyCode]\n )\n\n const handleKeyDown = (evt: any, index: number) => {\n const currentVal = verifyCode[index]\n switch (evt.key) {\n case 'Backspace':\n if (!currentVal && inputRef.current[index - 1]) {\n handleChange('', index - 1)\n inputRef.current[index - 1].focus()\n }\n break\n\n case 'Enter':\n onEenter?.()\n break\n\n case 'Left':\n case 'ArrowLeft':\n evt.preventDefault()\n if (inputRef.current[index - 1]) {\n inputRef.current[index - 1].focus()\n }\n break\n case 'Right':\n case 'ArrowRight':\n evt.preventDefault()\n if (inputRef.current[index + 1]) {\n inputRef.current[index + 1].focus()\n }\n break\n default:\n break\n }\n }\n\n useEffect(() => {\n const el = codeInputRef.current\n\n const pasteEvent = (e: ClipboardEvent) => {\n e.preventDefault()\n e.stopPropagation()\n\n let paste = e.clipboardData?.getData('text')\n\n if (paste && !isNaN(parseInt(paste))) {\n if (paste.length < length) {\n const data = verifyCode.map((_i, index) => paste?.[index] ?? '')\n onChange(data)\n setFocusIndex(paste.length)\n } else {\n const data = paste.slice(0, length).split('')\n onChange(data)\n setFocusIndex(length - 1)\n }\n }\n }\n el?.addEventListener('paste', pasteEvent)\n\n return () => {\n el?.removeEventListener('paste', pasteEvent)\n }\n }, [length, onChange, setVerifyCode, verifyCode])\n\n return (\n <div ref={codeInputRef} className=\"authing-g2-code-input\" {...rest}>\n {new Array(length).fill(0).map((_, index) => {\n return (\n <Fragment key={index}>\n <Input\n onFocus={() => setFocusIndex(index)}\n ref={(el) => (inputRef.current[index] = el)}\n style={{\n width: size,\n minWidth: size,\n minHeight: size,\n height: size,\n lineHeight: size,\n marginLeft: index === 0 ? 0 : gutter,\n }}\n className=\"authing-g2-code-input-item\"\n size=\"large\"\n autoFocus={index === 0}\n onKeyDown={(evt) => handleKeyDown(evt, index)}\n value={verifyCode[index]}\n maxLength={2}\n onChange={(evt) => {\n evt.persist()\n if (fromClipboard.current) {\n fromClipboard.current = false\n return false\n }\n // @ts-ignore\n if (evt.nativeEvent.isComposing) {\n return\n }\n\n const nextValue = evt.target.value\n /**\n * https://github.com/devfolioco/react-otp-input/issues/322\n * ios 下 otp 自动填充在chrome内核浏览器下会触发两次 并且第一次会直接塞otp复制的值(maxlength 限制无效) 如 1246 第二次则根据maxlength 截取塞 12\n * 针对这种情况取第一次值隔离第二次调用\n * safari 是单个input 塞对应的值\n */\n if (nextValue.length === length) {\n fromClipboard.current = true\n onChange(nextValue.split(''))\n setFocusIndex(length - 1)\n return\n }\n const preValue = verifyCode[index] || ''\n const changeValue =\n nextValue.split('').filter((item) => item !== preValue)[0] ||\n nextValue.slice(-1)\n\n handleChange(changeValue, index)\n }}\n pattern=\"[0-9]*\"\n type=\"tel\"\n />\n {showDivider && index === Math.floor(length / 2 - 1) && (\n <Divider className=\"authing-g2-code-input-divider\" />\n )}\n </Fragment>\n )\n })}\n </div>\n )\n}\n","import { Form } from 'antd'\nimport React, { useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useAsyncFn } from 'react-use'\n\nimport { GuardModuleType } from '../../Guard/module'\nimport { useGuardHttp } from '../../_utils/guardHttp'\nimport SubmitButton from '../../SubmitButton'\nimport { ImagePro } from '../../ImagePro'\nimport { VerifyCodeFormItem } from '../../MFA/VerifyCodeInput/VerifyCodeFormItem'\nimport { VerifyCodeInput } from '../../MFA/VerifyCodeInput'\nimport { useGuardIsAuthFlow } from '../../_utils/context'\nimport { authFlow, BindTotpBusinessAction } from '../businessRequest'\nexport interface SecurityCodeProps {\n mfaToken: string\n qrcode: string\n onNext: any\n changeModule: any\n}\n\nexport const SecurityCode: React.FC<SecurityCodeProps> = ({\n mfaToken,\n qrcode,\n onNext,\n changeModule,\n}) => {\n const [form] = Form.useForm()\n const submitButtonRef = useRef<any>(null)\n\n const { t } = useTranslation()\n\n const { post } = useGuardHttp()\n\n const isAuthFlow = useGuardIsAuthFlow()\n\n const onJump = () => {\n changeModule?.(GuardModuleType.DOWNLOAD_AT)\n }\n\n const [, bindTotp] = useAsyncFn(async () => {\n submitButtonRef.current?.onSpin(true)\n\n await form.validateFields()\n const saftyCode = form.getFieldValue('saftyCode')\n\n if (isAuthFlow) {\n // 这里绑定成功过返回的是 statusCode\n const { statusCode, onGuardHandling } = await authFlow(\n BindTotpBusinessAction.VerifyTotpFirstTime,\n {\n totp: saftyCode.join(''),\n }\n )\n submitButtonRef.current?.onSpin(false)\n\n if (statusCode === 200) {\n onNext()\n } else {\n submitButtonRef.current?.onError()\n onGuardHandling?.()\n }\n } else {\n const { code, data, onGuardHandling } = await post(\n '/api/v2/mfa/totp/associate/confirm',\n {\n authenticator_type: 'totp',\n totp: saftyCode.join(''),\n source: 'APPLICATION',\n },\n {\n headers: {\n authorization: mfaToken,\n },\n }\n )\n submitButtonRef.current?.onSpin(false)\n\n if (code === 200) {\n onNext(data)\n } else {\n submitButtonRef.current?.onError()\n onGuardHandling?.()\n }\n }\n }, [mfaToken])\n\n return (\n <>\n <p className=\"authing-g2-mfa-title\">{t('user.mfaBind')}</p>\n <p\n className=\"authing-g2-mfa-tips\"\n style={{\n textAlign: 'left',\n }}\n >\n {t('common.usePhoneOpen')}({t('common.noValidator')}{' '}\n <span\n style={{\n color: '#215AE5',\n cursor: 'pointer',\n }}\n onClick={onJump}\n >\n {t('common.clickTodownload')}\n </span>\n ) {t('common.mfaText1')}\n </p>\n <ImagePro className=\"g2-mfa-bindTotp-qrcode\" src={qrcode} alt=\"qrcode\" />\n <Form\n className=\"g2-mfa-bindTotp-securityCode-form\"\n form={form}\n onSubmitCapture={() => {}}\n onFinish={bindTotp}\n onFinishFailed={(e) => {\n submitButtonRef.current.onError()\n }}\n >\n <VerifyCodeFormItem\n codeLength={6}\n name=\"saftyCode\"\n ruleKeyword={t('user.numberSafteyCode')}\n >\n <VerifyCodeInput\n length={6}\n showDivider={false}\n gutter={'10px'}\n onFinish={bindTotp}\n />\n </VerifyCodeFormItem>\n\n <SubmitButton text={t('user.nextStep')} ref={submitButtonRef} />\n </Form>\n </>\n )\n}\n","import { message } from 'antd'\nimport { User } from 'authing-js-sdk'\nimport React, { useEffect, useMemo, useState } from 'react'\nimport { useAsyncFn } from 'react-use'\nimport { ErrorCode } from '../_utils/GuardErrorCode'\nimport { useGuardHttp } from '../_utils/guardHttp'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport { GuardModuleType } from '../Guard/module'\nimport { ShieldSpin, Spin } from '../ShieldSpin'\nimport { BindSuccess } from './core/bindSuccess'\nimport { SecurityCode } from './core/securityCode'\nimport { GuardBindTotpInitData } from './interface'\nimport { useTranslation } from 'react-i18next'\nimport './styles.less'\nimport {\n useGuardEvents,\n useGuardInitData,\n useGuardIsAuthFlow,\n useGuardModule,\n} from '../_utils/context'\nimport { MFAType } from '../MFA/interface'\nimport { BackCustom } from '../Back'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nenum BindTotpType {\n SECURITY_CODE = 'securityCode',\n BIND_SUCCESS = 'bindSuccess',\n}\n\nexport const GuardBindTotpView: React.FC = () => {\n const initData = useGuardInitData<GuardBindTotpInitData>()\n\n const events = useGuardEvents()\n\n const { changeModule } = useGuardModule()\n\n const { get, post } = useGuardHttp()\n\n const isAuthFlow = useGuardIsAuthFlow()\n\n useGuardView()\n\n const { t } = useTranslation()\n\n const [secret, setSecret] = useState('')\n\n const [qrcode, setQrcode] = useState('')\n\n const [user, setUser] = useState<User>()\n\n const [bindTotpType, setBindTotpType] = useState<BindTotpType>(\n BindTotpType.SECURITY_CODE\n )\n\n const authClient = useGuardAuthClient()\n\n const [bindInfo, fetchBindInfo] = useAsyncFn(async () => {\n const query = {\n // type: 'totp',\n source: 'APPLICATION',\n }\n const config = {\n headers: {\n authorization: initData.mfaToken,\n },\n }\n\n try {\n const { code, message: msg } = await get<any>(\n `/api/v2/mfa/authenticator`,\n query,\n config\n )\n if (code === ErrorCode.LOGIN_INVALID) {\n message.error(msg)\n changeModule?.(GuardModuleType.LOGIN, {})\n return\n }\n } catch (error: any) {\n message.error(error?.message)\n }\n\n try {\n const { data, code, onGuardHandling } = await post<any>(\n '/api/v2/mfa/totp/associate',\n query,\n config\n )\n if (code === 200) {\n setSecret(data.recovery_code)\n setQrcode(data.qrcode_data_url)\n } else {\n onGuardHandling?.()\n }\n } catch (error: any) {\n message.error(error?.message)\n }\n }, [])\n\n const onBind = (resUser?: User) => {\n if (isAuthFlow && resUser) {\n events?.onLogin?.(resUser, authClient)\n } else {\n if (user) {\n events?.onLogin?.(user, authClient)\n }\n }\n }\n\n const onNext = (user?: User) => {\n if (isAuthFlow) {\n setBindTotpType(BindTotpType.BIND_SUCCESS)\n } else {\n setUser(user)\n setBindTotpType(BindTotpType.BIND_SUCCESS)\n }\n }\n\n useEffect(() => {\n fetchBindInfo()\n }, [fetchBindInfo])\n\n const renderContent = useMemo<\n Record<BindTotpType, (props: any) => React.ReactNode>\n >(\n () => ({\n [BindTotpType.SECURITY_CODE]: (props) => <SecurityCode {...props} />,\n [BindTotpType.BIND_SUCCESS]: (props) => <BindSuccess {...props} />,\n }),\n []\n )\n\n const renderBack = useMemo(() => {\n const onBack = () => {\n changeModule?.(GuardModuleType.MFA, {\n ...initData,\n current: MFAType.TOTP,\n })\n }\n\n return <BackCustom onBack={onBack}>{t('common.backToVerify')}</BackCustom>\n }, [changeModule, initData, t])\n\n return (\n <>\n {bindInfo.loading ? (\n <Spin />\n ) : (\n <div className=\"g2-view-container g2-bind-totp\">\n {renderBack}\n <div className=\"g2-mfa-content g2-mfa-bindTotp\">\n {bindInfo.loading ? (\n <ShieldSpin />\n ) : (\n renderContent[bindTotpType]({\n mfaToken: initData.mfaToken,\n qrcode,\n secret,\n onBind,\n onNext,\n changeModule: changeModule,\n })\n )}\n </div>\n </div>\n )}\n </>\n )\n}\n","import React, { useCallback, useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { GuardModuleType } from '..'\nimport { GuardButton } from '../GuardButton'\nimport { IconFont } from '../IconFont'\nimport { useGuardFinallyConfig, useGuardModule } from '../_utils/context'\nimport './styles.less'\n\nexport interface BackProps {\n isRender?: boolean\n}\n\nexport const BackLogin: React.FC<BackProps> = (props) => {\n const { changeModule } = useGuardModule()\n\n const config = useGuardFinallyConfig()\n\n const { t } = useTranslation()\n\n const onBack = useCallback(() => changeModule?.(GuardModuleType.LOGIN), [\n changeModule,\n ])\n\n const { isRender = true } = props\n\n const renderBack = useMemo(() => {\n if (!isRender) return null\n\n const whitelist = [GuardModuleType.LOGIN, GuardModuleType.REGISTER]\n\n // 初始场景不是 登录 或者注册时候,不显示返回按钮\n if (config.defaultScenes && !whitelist.includes(config.defaultScenes)) {\n return null\n }\n\n return (\n <GuardButton\n type=\"link\"\n onClick={onBack}\n className=\"g2-view-mfa-back-hover\"\n >\n <IconFont type=\"authing-arrow-left-s-line\" style={{ fontSize: 24 }} />\n <span>{t('common.backLoginPage')}</span>\n </GuardButton>\n )\n }, [isRender, config.defaultScenes, onBack, t])\n\n return (\n <div className=\"g2-view-back\" style={{ display: 'inherit' }}>\n {renderBack}\n </div>\n )\n}\n\nexport interface BackCustomProps extends BackProps {\n onBack?: () => void\n}\n\nexport const BackCustom: React.FC<\n BackCustomProps & {\n children: any\n }\n> = (props) => {\n const { changeModule } = useGuardModule()\n\n const { t } = useTranslation()\n\n const {\n onBack = () => changeModule?.(GuardModuleType.LOGIN),\n isRender = true,\n children = t('common.backLoginPage'),\n } = props\n\n const renderBack = useMemo(() => {\n if (!isRender) return null\n\n return (\n <GuardButton\n type=\"link\"\n onClick={onBack}\n className=\"g2-view-mfa-back-hover\"\n >\n <IconFont type=\"authing-arrow-left-s-line\" style={{ fontSize: 24 }} />\n <span>{children}</span>\n </GuardButton>\n )\n }, [children, isRender, onBack])\n\n return (\n <div className=\"g2-view-back\" style={{ display: 'inherit' }}>\n {renderBack}\n </div>\n )\n}\n","import { useEffect } from 'react'\n\nimport {\n useGuardEvents,\n useGuardModule,\n useGuardMultipleInstance,\n} from '../../../_utils/context'\n\ninterface Options {\n changeTab?: React.Dispatch<any>\n currentTab?: string\n}\n\nexport function useGuardView(options: Options = {}) {\n const { currentTab, changeTab } = options\n\n const { changeModule, currentModule } = useGuardModule()\n\n const events = useGuardEvents()\n\n const { isMultipleAccount } = useGuardMultipleInstance()\n\n // 修改 View 的方式:changeModule、changeTab\n // 为避免 Guard 组件多次渲染及复杂的依赖创建及销毁判断\n // 直接将其挂载到 window 上最方便\n useEffect(() => {\n window.$$guard = Object.assign({}, window.$$guard, {\n viewContext: {\n ...window.$$guard?.viewContext,\n changeModule,\n changeTab,\n },\n })\n }, [changeModule, changeTab])\n\n useEffect(() => {\n let currentView: string = currentModule.moduleName\n\n if (currentTab) {\n currentView += `:${currentTab}`\n }\n\n window.$$guard = Object.assign({}, window.$$guard, {\n viewContext: {\n ...window.$$guard?.viewContext,\n currentModule: currentModule.moduleName,\n currentTab,\n currentView,\n },\n })\n\n if (events?.onAfterChangeModule && !isMultipleAccount && currentModule) {\n events.onAfterChangeModule({\n currentView,\n currentModule: currentModule.moduleName,\n currentTab: currentTab,\n data: currentModule.initData,\n })\n }\n }, [currentModule, currentTab, events, isMultipleAccount])\n}\n","import { useCallback, useState } from 'react'\n\nexport const useCheckRepeat = (\n checkFn: (\n value: any,\n resolve: (value: unknown) => void,\n reject: (reason?: any) => void\n ) => void\n) => {\n const [timer, setTimer] = useState<NodeJS.Timeout>()\n\n const checkRepeat = useCallback(\n async (_: any, value: any) => {\n if (timer) {\n clearTimeout(timer)\n }\n\n return new Promise((resolve, reject) => {\n const timeout = setTimeout(() => {\n checkFn(value, resolve, reject)\n }, 500)\n\n setTimer(timeout)\n })\n },\n [checkFn, timer]\n )\n\n return checkRepeat\n}\n","import { Form } from 'antd'\nimport React, { useMemo } from 'react'\nimport { fieldRequiredRule, VALIDATE_PATTERN } from '../_utils'\nimport { useGuardHttp } from '../_utils/guardHttp'\nimport { useTranslation } from 'react-i18next'\nimport { ValidatorFormItemMetaProps, ValidatorFormItemProps } from '.'\nimport { Rule } from 'antd/lib/form'\nimport { useGuardPhoneRegex, useGuardPublicConfig } from '../_utils/context'\nimport { phone } from 'phone'\nimport { useCheckRepeat } from './useCheckRepeat'\n\nconst ValidatorFormItem: React.FC<ValidatorFormItemMetaProps> = (props) => {\n const {\n checkRepeat = false,\n checkExist = false,\n method,\n name,\n required,\n areaCode, //国际化区号\n isCheckPattern = true,\n ...formItemProps\n } = props\n const publicConfig = useGuardPublicConfig()\n const { get } = useGuardHttp()\n const { t } = useTranslation()\n\n const checkInternationalSms = useMemo(() => {\n return (\n publicConfig.internationalSmsConfig?.enabled &&\n method === 'phone' &&\n isCheckPattern\n )\n }, [isCheckPattern, method, publicConfig.internationalSmsConfig?.enabled])\n\n const phoneRegex = useGuardPhoneRegex()\n\n const methodContent = useMemo(() => {\n if (method === 'email')\n return {\n field: t('common.emailLabel'),\n checkRepeatErrorMessage: t('common.checkEmail'),\n formatErrorMessage: t('common.emailFormatError'),\n checkExistErrorMessage: t('common.noFindEmail'),\n pattern: VALIDATE_PATTERN.email,\n }\n else if (method === 'username') {\n return {\n field: t('common.username'),\n checkRepeatErrorMessage: t('common.checkUserName'),\n checkExistErrorMessage: t('common.noFindUsername'),\n formatErrorMessage: t('common.usernameFormatError'),\n pattern: VALIDATE_PATTERN.username,\n }\n } else if (method === 'phone') {\n return {\n field: t('common.phone'),\n checkRepeatErrorMessage: t('common.checkPhone'),\n checkExistErrorMessage: t('common.noFindPhone'),\n formatErrorMessage: t('common.phoneFormateError'),\n pattern:\n !isCheckPattern && publicConfig.internationalSmsConfig?.enabled\n ? /^[0-9]*$/\n : phoneRegex || VALIDATE_PATTERN.phone, //开启国际化短信,但不限制pattern eg:单手机号密码登录方式时🤢\n }\n }\n\n // 自定义字段\n return {\n field: t('common.account'),\n checkRepeatErrorMessage: t('common.checkCustomName'),\n checkExistErrorMessage: t('common.noFindUsername'),\n formatErrorMessage: t('common.customNameFormatError'),\n pattern: VALIDATE_PATTERN.username,\n }\n }, [\n isCheckPattern,\n method,\n publicConfig.internationalSmsConfig?.enabled,\n t,\n phoneRegex,\n ])\n\n const checkRepeatRet = (\n value: any,\n resolve: (value: unknown) => void,\n reject: (reason?: any) => void\n ) => {\n get<boolean>(`/api/v2/users/find`, {\n userPoolId: publicConfig?.userPoolId,\n key: value,\n type: method,\n }).then(({ data }) => {\n if (checkExist) {\n Boolean(data)\n ? resolve(true)\n : reject(methodContent.checkExistErrorMessage)\n }\n if (checkRepeat) {\n Boolean(data)\n ? reject(methodContent.checkRepeatErrorMessage)\n : resolve(true)\n }\n })\n }\n\n const checkRepeatFn = useCheckRepeat(checkRepeatRet)\n\n const formatRules = useMemo<Rule>(() => {\n if (checkInternationalSms) {\n return {\n validateTrigger: 'onBlur',\n validator: async (_, value) => {\n if (!value || phone(value, { country: areaCode }).isValid)\n return Promise.resolve()\n return Promise.reject(t('common.internationPhoneMessage'))\n },\n }\n }\n\n return {\n validateTrigger: 'onBlur',\n pattern: methodContent.pattern,\n message: methodContent.formatErrorMessage,\n }\n }, [\n areaCode,\n checkInternationalSms,\n methodContent.formatErrorMessage,\n methodContent.pattern,\n t,\n ])\n\n const rules = useMemo<Rule[]>(() => {\n // 如果不是必填就不校验\n if (required === false) return []\n\n // 必填项的默认校验规则\n const rules = [...fieldRequiredRule(methodContent.field)]\n\n // 格式校验\n rules.push(formatRules)\n\n // 是否校验重复\n if (checkRepeat || checkExist) {\n rules.push({\n validator: checkRepeatFn,\n validateTrigger: [],\n })\n }\n\n return rules\n }, [\n required,\n methodContent.field,\n formatRules,\n checkRepeat,\n checkExist,\n checkRepeatFn,\n ])\n return (\n <Form.Item\n validateFirst={true}\n validateTrigger={['onBlur', 'onChange']}\n rules={[...rules, ...(formItemProps?.rules ?? [])]}\n name={name ?? method}\n {...formItemProps}\n />\n )\n}\nexport const EmailFormItem: React.FC<ValidatorFormItemProps> = (props) => (\n <ValidatorFormItem required method=\"email\" {...props} />\n)\nexport const PhoneFormItem: React.FC<ValidatorFormItemProps> = (props) => (\n <ValidatorFormItem required method=\"phone\" {...props} />\n)\n\nexport const UserNameFormItem: React.FC<ValidatorFormItemProps> = (props) => (\n <ValidatorFormItem required method=\"username\" {...props} />\n)\n\nexport const CustomNameFormItem: React.FC<\n ValidatorFormItemProps & { method: string }\n> = (props) => <ValidatorFormItem required {...props} />\n","import { FormInstance, FormItemProps } from 'antd/lib/form'\nimport FormItem from 'antd/lib/form/FormItem'\nimport { PasswordFormItem } from './PasswordFormItem'\nimport {\n EmailFormItem,\n PhoneFormItem,\n UserNameFormItem,\n CustomNameFormItem,\n} from './ValidatorFormItem'\n\nexport interface ValidatorFormItemProps extends FormItemProps {\n form?: FormInstance\n checkRepeat?: boolean\n checkExist?: boolean\n areaCode?: string //国际化区号\n /**\n * 控制内部FormItem组件关于pattern的校验规则\n */\n isCheckPattern?: boolean\n}\n\nexport interface ValidatorFormItemMetaProps extends ValidatorFormItemProps {\n method: 'email' | 'phone' | 'username' | string\n}\n\nexport interface PasswordFormItemProps extends FormItemProps {}\n\nexport interface ICheckProps {\n check: (values: any) => void\n}\n\ntype InternalFormItemType = typeof FormItem\n\ninterface FormItemInterface extends InternalFormItemType {\n Password: typeof PasswordFormItem\n Email: typeof EmailFormItem\n Phone: typeof PhoneFormItem\n UserName: typeof UserNameFormItem\n CustomName: typeof CustomNameFormItem\n}\n\nconst CustomFormItem = FormItem as FormItemInterface\n\nCustomFormItem.Password = PasswordFormItem\nCustomFormItem.Email = EmailFormItem\nCustomFormItem.Phone = PhoneFormItem\nCustomFormItem.UserName = UserNameFormItem\nCustomFormItem.CustomName = CustomNameFormItem\nexport default CustomFormItem\n","import { Form } from 'antd'\nimport React from 'react'\nimport { PasswordFormItemProps } from '.'\nimport { getPasswordValidate } from '../_utils'\nimport { useGuardInitData, useGuardPublicConfig } from '../_utils/context'\nexport interface ExPasswordFormItemProps extends PasswordFormItemProps {\n fieldRequiredRuleMessage?: string\n}\nexport const PasswordFormItem: React.FC<ExPasswordFormItemProps> = (props) => {\n const { rules, fieldRequiredRuleMessage, ...fromItemProos } = props\n\n const publicConfig = useGuardPublicConfig()\n const initData = useGuardInitData<any>()\n let { passwordStrength, customPasswordStrength } = publicConfig\n const {\n passwordStrength: userPasswordStrength,\n customPasswordStrength: userCustomPasswordStrength,\n } = initData\n\n if (userPasswordStrength || userCustomPasswordStrength) {\n passwordStrength = userPasswordStrength\n customPasswordStrength = userCustomPasswordStrength\n }\n\n return publicConfig ? (\n <Form.Item\n validateTrigger={['onChange', 'onBlur']}\n validateFirst={true}\n name=\"password\"\n rules={[\n ...getPasswordValidate(\n passwordStrength,\n customPasswordStrength,\n fieldRequiredRuleMessage\n ),\n ...(rules ?? []),\n ]}\n {...fromItemProos}\n />\n ) : (\n <Form.Item {...props} />\n )\n}\n","import { getGuardHttp } from '../_utils/guardHttp'\n\nexport enum ChangePasswordBusinessAction {\n ResetPassword = 'reset-password-first-time',\n FirstLoginReset = 'reset-password-forced',\n ResetPasswordStrengthDetection = 'reset-password-strength-detection',\n}\n\nexport const authFlow = async (\n action: ChangePasswordBusinessAction,\n content: {\n password: string\n oldPassword?: string\n }\n) => {\n const { authFlow } = getGuardHttp()\n\n const res = await authFlow(action, { ...content })\n\n return res\n}\n","import { Input } from 'antd'\nimport React from 'react'\nimport { IconFont } from '../IconFont'\nexport const InputPassword = (props: any) => {\n return (\n <Input.Password\n autoComplete=\"off\"\n {...props}\n iconRender={(visible) => (\n <span style={{ display: 'flex', height: '100%', alignItems: 'center' }}>\n {visible ? (\n <IconFont type=\"authing-a-eye-line1\" />\n ) : (\n <IconFont type=\"authing-a-eye-close-line1\" />\n )}\n </span>\n )}\n />\n )\n}\n","import React, { useState } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nexport const usePasswordErrorText = () => {\n const { t } = useTranslation()\n const [show, setPasswordErrorTextShow] = useState(false)\n return {\n setPasswordErrorTextShow,\n getPassWordUnsafeText: () => {\n return (\n <>\n {show ? (\n <div\n style={{\n marginBottom: 23,\n fontSize: 12,\n color: '#E8353E',\n display: 'block',\n }}\n >\n {t('common.passwordUnsafeTip')}\n </div>\n ) : (\n <></>\n )}\n </>\n )\n },\n }\n}\n","import React, { useRef, useCallback } from 'react'\nimport { Form } from 'antd'\nimport CustomFormItem from '../../ValidatorRules'\nimport { InputPassword } from '../../InputPassword'\nimport { useMediaSize } from '../../_utils/hooks'\nimport { IconFont } from '../../IconFont'\nimport { useTranslation } from 'react-i18next'\nimport SubmitButton from '../../SubmitButton'\nimport { RegisterCompletePasswordInitData } from '../../CompleteInfo/interface'\nimport {\n useGuardEvents,\n useGuardInitData,\n useGuardModule,\n useGuardPublicConfig,\n} from '../../_utils/context'\nimport { GuardModuleType } from '../../Guard'\nimport { useGuardAuthClient } from '../../Guard/authClient'\nimport { getGuardHttp } from '../../_utils/guardHttp'\nimport { usePasswordErrorText } from '../../_utils/useErrorText'\nimport { ApiCode } from '../../_utils/responseManagement/interface'\nexport const CompletePassword: React.FC = () => {\n const { t } = useTranslation()\n\n const events = useGuardEvents()\n\n const [form] = Form.useForm()\n\n const { isPhoneMedia } = useMediaSize()\n\n const { post } = getGuardHttp()\n const {\n businessRequestName,\n content,\n isChangeComplete,\n onRegisterSuccess,\n onRegisterFailed,\n } = useGuardInitData<RegisterCompletePasswordInitData>()\n\n let submitButtonRef = useRef<any>(null)\n\n const { changeModule } = useGuardModule()\n // 密码加密公钥\n const { publicKey } = useGuardPublicConfig()\n\n let client = useGuardAuthClient()\n\n const encrypt = client.options.encryptFunction\n const {\n getPassWordUnsafeText,\n setPasswordErrorTextShow,\n } = usePasswordErrorText()\n const onFinish = useCallback(\n async (values: any) => {\n // 密码加密处理(邮箱验证码是通过 post 直接发送需要加密 其他通过 sdk 在内部加密了 这一步无需加密)\n const password = await encrypt!(values.password, publicKey)\n\n submitButtonRef.current?.onSpin(true)\n\n if (isChangeComplete) {\n // 需要进行信息补全\n changeModule?.(GuardModuleType.REGISTER_COMPLETE_INFO, {\n businessRequestName,\n content: {\n ...content,\n password,\n },\n onRegisterSuccess,\n onRegisterFailed,\n })\n return\n } else {\n // 直接注册\n try {\n if (businessRequestName === 'registerByEmailCode') {\n const {\n statusCode,\n apiCode,\n data,\n onGuardHandling,\n message,\n } = await post('/api/v2/register-email-code', {\n ...content,\n password,\n postUserInfoPipeline: false,\n })\n submitButtonRef.current.onSpin(false)\n if (statusCode === 200) {\n onRegisterSuccess(data)\n // events?.onRegister?.(data, authClient)\n // changeModule?.(GuardModuleType.LOGIN)\n } else {\n if (statusCode === ApiCode.UNSAFE_PASSWORD_TIP) {\n setPasswordErrorTextShow(true)\n }\n onGuardHandling?.()\n onRegisterFailed(apiCode, data, message)\n events?.onRegisterError?.({\n code: apiCode,\n data,\n message,\n })\n }\n } else if (businessRequestName === 'registerByPhoneCode') {\n // TODO: 修改 Rustful\n const {\n data,\n statusCode,\n apiCode,\n onGuardHandling,\n message,\n } = await post(`/api/v2/register-phone-code`, {\n ...content,\n password,\n postUserInfoPipeline: false,\n })\n if (statusCode === 200) {\n submitButtonRef.current?.onSpin(false)\n onRegisterSuccess(data)\n } else {\n if (apiCode === ApiCode.UNSAFE_PASSWORD_TIP) {\n setPasswordErrorTextShow(true)\n }\n onGuardHandling?.()\n submitButtonRef.current?.onSpin(false)\n onRegisterFailed(apiCode, data, message)\n events?.onRegisterError?.({\n apiCode,\n data,\n message,\n })\n }\n }\n } catch (error: any) {\n submitButtonRef.current?.onSpin(false)\n // const { code, message: errorMessage, data } = error\n // if (code === ApiCode.UNSAFE_PASSWORD_TIP) {\n // setPasswordErrorTextShow(true)\n // }\n // submitButtonRef.current.onError()\n // message.error(errorMessage)\n // onRegisterFailed(code, data, errorMessage)\n // events?.onRegisterError?.({\n // code,\n // data,\n // message,\n // })\n }\n }\n },\n [\n businessRequestName,\n changeModule,\n content,\n encrypt,\n events,\n isChangeComplete,\n onRegisterFailed,\n onRegisterSuccess,\n post,\n publicKey,\n setPasswordErrorTextShow,\n ]\n )\n\n return (\n <div className=\"authing-g2-login-phone-code\">\n <Form\n name=\"resetPassword\"\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => {\n submitButtonRef?.current?.onError()\n }}\n autoComplete=\"off\"\n >\n <CustomFormItem.Password\n className=\"authing-g2-input-form\"\n name=\"password\"\n required={true}\n >\n <InputPassword\n autoFocus={!isPhoneMedia}\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputPwd')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </CustomFormItem.Password>\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"password2\"\n rules={[\n {\n validator(_, value) {\n let pwd = form.getFieldValue('password')\n if (!value) {\n return Promise.reject(t('login.inputPwd'))\n }\n if (value !== pwd) {\n return Promise.reject(t('common.repeatPasswordDoc'))\n }\n return Promise.resolve()\n },\n },\n ]}\n >\n <InputPassword\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputPwdAgain')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n {getPassWordUnsafeText()}\n <Form.Item className=\"authing-g2-sumbit-form submit-form\">\n <SubmitButton\n className=\"forget-password\"\n text={t('common.confirm')}\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n","import { AuthenticationClient, CommonMessage, User } from 'authing-js-sdk'\nimport { getDefaultG2Config, IG2Config, IG2Events, IG2FCProps } from '../Type'\n\nexport interface CompleteInfoConfig extends IG2Config {}\n\nconst defaultConfig: CompleteInfoConfig = {\n ...getDefaultG2Config(),\n}\n\nexport const getDefaultCompleteInfoConfig = (): CompleteInfoConfig => ({\n ...getDefaultG2Config(),\n ...defaultConfig,\n})\n\nexport interface CompleteInfoEvents extends IG2Events {\n onRegisterInfoCompleted?: (\n user: User,\n udfs: {\n key: any\n value: any\n }[],\n authClient: AuthenticationClient\n ) => void\n onRegisterInfoCompletedError?: (\n error: CommonMessage,\n udfs: {\n key: any\n value: any\n }[],\n authClient: AuthenticationClient\n ) => void\n}\n\nexport interface GuardCompleteInfoProps extends IG2FCProps, CompleteInfoEvents {\n config: Partial<CompleteInfoConfig>\n}\n\nexport interface GuardCompleteInfoViewProps extends GuardCompleteInfoProps {\n config: CompleteInfoConfig\n initData: any\n onLogin?: any\n}\n\nexport type ExtendsFieldType = 'user' | 'internal'\n\nexport interface ExtendsField {\n type: ExtendsFieldType\n name: string\n label: string\n inputType: string\n required: boolean\n validateRules: any[]\n}\n\nexport enum FormValidateRule {\n NONE = 'none',\n EMAIL = 'email',\n PHONE = 'phone',\n IS_NUMBER = 'isNumber',\n REG_EXP = 'regExp',\n}\n\nexport interface CompleteInfoRule {\n type: FormValidateRule\n content: string\n errorMessage?: string\n}\n\nexport interface CompleteInfoSelectOption {\n value: string\n label: string\n}\n\nexport interface CompleteInfoMetaData {\n type: CompleteInfoBaseControls | CompleteInfoExtendsControls\n label: string\n name: string\n required: boolean\n validateRules: CompleteInfoRule[]\n options?: CompleteInfoSelectOption[]\n}\n\nexport enum CompleteInfoBaseControls {\n USERNAME = 'username',\n PHONE = 'phone',\n EMAIL = 'email',\n}\n\nexport enum CompleteInfoExtendsControls {\n IMAGE = 'image',\n NUMBER = 'number',\n DATE = 'date',\n DATE_TIME = 'datetime',\n SELECT = 'select',\n DROPDOWN = 'dropdown',\n BOOLEAN = 'boolean',\n STRING = 'string',\n TEXT = 'text',\n GENDER = 'gender',\n COUNTRY = 'country',\n}\n\nexport interface CompleteInfoInitData {\n skip: boolean\n metaData: CompleteInfoMetaData[]\n}\n\nexport interface RegisterCompleteInfoInitData {\n content: any\n businessRequestName:\n | 'registerByEmail'\n | 'registerByPhoneCode'\n | 'registerByEmailCode'\n onRegisterFailed: Function\n onRegisterSuccess: Function\n}\n\nexport interface RegisterCompletePasswordInitData\n extends RegisterCompleteInfoInitData {\n isChangeComplete: boolean\n}\nexport interface CompleteInfoRequest {\n fieldValues: {\n name: string\n value: string\n code?: string\n }[]\n}\n\nexport enum OmitCompleteInfo {\n 'registerByEmail' = 'email',\n 'registerByPhoneCode' = 'phone',\n 'registerByEmailCode' = 'email',\n 'phone-password' = 'phone',\n}\n","import React, { useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { Form, message } from 'antd'\nimport { useGuardAuthClient } from '../../Guard/authClient'\nimport SubmitButton from '../../SubmitButton'\nimport CustomFormItem from '../../ValidatorRules'\nimport { IconFont } from '../../IconFont'\nimport { InputPassword } from '../../InputPassword'\nimport {\n useGuardInitData,\n useGuardIsAuthFlow,\n useGuardPublicConfig,\n} from '../../_utils/context'\nimport { authFlow, ChangePasswordBusinessAction } from '../businessRequest'\nimport { ApiCode } from '../../_utils/responseManagement/interface'\nimport { useMediaSize } from '../../_utils/hooks'\nimport { usePasswordErrorText } from '../../_utils/useErrorText'\ninterface FirstLoginResetProps {\n onReset: any\n}\nexport const FirstLoginReset: React.FC<FirstLoginResetProps> = ({\n onReset,\n}) => {\n const { t } = useTranslation()\n\n const initData = useGuardInitData<{ token: string }>()\n\n const isAuthFlow = useGuardIsAuthFlow()\n\n const { publicKey } = useGuardPublicConfig()\n\n let [form] = Form.useForm()\n\n let client = useGuardAuthClient()\n\n const encrypt = client.options.encryptFunction\n\n const { isPhoneMedia } = useMediaSize()\n\n let submitButtonRef = useRef<any>(null)\n const {\n getPassWordUnsafeText,\n setPasswordErrorTextShow,\n } = usePasswordErrorText()\n const onFinish = async (values: any) => {\n let newPassword = values.password\n submitButtonRef.current?.onSpin(true)\n\n if (isAuthFlow) {\n // 重置密码成功不会返回 UserInfo\n const { apiCode, onGuardHandling, message: msg } = await authFlow(\n ChangePasswordBusinessAction.FirstLoginReset,\n {\n password: await encrypt!(newPassword, publicKey),\n }\n )\n submitButtonRef.current?.onSpin(false)\n\n if (apiCode === ApiCode.ABORT_FLOW) {\n onReset()\n } else if (apiCode === ApiCode.UNSAFE_PASSWORD_TIP) {\n message.error(msg)\n setPasswordErrorTextShow(true)\n } else {\n submitButtonRef.current?.onError()\n onGuardHandling?.()\n }\n } else {\n try {\n let res = await client.resetPasswordByFirstLoginToken({\n token: initData.token,\n password: newPassword,\n })\n onReset(res)\n } catch (error: any) {\n message.error(error.message)\n submitButtonRef?.current?.onError()\n } finally {\n submitButtonRef.current?.onSpin(false)\n }\n }\n }\n\n return (\n <div className=\"authing-g2-login-phone-code\">\n <Form\n name=\"resetPassword\"\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => {\n submitButtonRef?.current?.onError()\n }}\n autoComplete=\"off\"\n >\n <CustomFormItem.Password\n className=\"authing-g2-input-form\"\n name=\"password\"\n required={true}\n >\n <InputPassword\n autoFocus={!isPhoneMedia}\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputNewPwd')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </CustomFormItem.Password>\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"password2\"\n rules={[\n {\n validator(_, value) {\n let pwd = form.getFieldValue('password')\n if (!value) {\n return Promise.reject(t('login.inputPwd'))\n }\n if (value !== pwd) {\n return Promise.reject(t('common.repeatPasswordDoc'))\n }\n return Promise.resolve()\n },\n },\n ]}\n >\n <InputPassword\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputPwdAgain')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n {getPassWordUnsafeText()}\n <Form.Item className=\"authing-g2-sumbit-form submit-form\">\n <SubmitButton\n className=\"forget-password\"\n text={t('common.confirm')}\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n","import React, { useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { Form, message } from 'antd'\nimport SubmitButton from '../../SubmitButton'\nimport { useGuardAuthClient } from '../../Guard/authClient'\nimport CustomFormItem from '../../ValidatorRules'\nimport { fieldRequiredRule } from '../../_utils'\nimport { InputPassword } from '../../InputPassword'\nimport { IconFont } from '../../IconFont'\nimport {\n useGuardInitData,\n useGuardIsAuthFlow,\n useGuardPublicConfig,\n} from '../../_utils/context'\nimport { authFlow, ChangePasswordBusinessAction } from '../businessRequest'\nimport { ApiCode } from '../../_utils/responseManagement/interface'\nimport { useMediaSize } from '../../_utils/hooks'\nimport { usePasswordErrorText } from '../../_utils/useErrorText'\n\ninterface RotateResetProps {\n onReset: any\n onFinishCallBack?: any\n}\n\nexport const RotateReset = (props: RotateResetProps) => {\n const { t } = useTranslation()\n\n const { onReset, onFinishCallBack } = props\n\n let [form] = Form.useForm()\n\n const { publicKey } = useGuardPublicConfig()\n\n let authClient = useGuardAuthClient()\n\n const { isPhoneMedia } = useMediaSize()\n\n const encrypt = authClient.options.encryptFunction\n\n const isAuthFlow = useGuardIsAuthFlow()\n\n let submitButtonRef = useRef<any>(null)\n\n const initData = useGuardInitData<{ token: string }>()\n const {\n getPassWordUnsafeText,\n setPasswordErrorTextShow,\n } = usePasswordErrorText()\n const onFinish = async (values: any) => {\n if (onFinishCallBack instanceof Function) {\n const data = await onFinishCallBack(values)\n if (data.code === ApiCode.UNSAFE_PASSWORD_TIP) {\n message.error(data.message)\n setPasswordErrorTextShow(true)\n }\n return\n }\n let { password, oldPassword } = values\n submitButtonRef?.current?.onSpin(true)\n\n if (isAuthFlow) {\n const { apiCode, onGuardHandling, message: msg } = await authFlow(\n ChangePasswordBusinessAction.ResetPassword,\n {\n password: await encrypt!(password, publicKey),\n oldPassword: await encrypt!(oldPassword, publicKey),\n }\n )\n\n submitButtonRef?.current?.onSpin(false)\n\n // 重置密码 返回的是流程终止\n if (apiCode === ApiCode.ABORT_FLOW) {\n onReset()\n } else if (apiCode === ApiCode.UNSAFE_PASSWORD_TIP) {\n message.error(msg)\n setPasswordErrorTextShow(true)\n } else {\n submitButtonRef?.current?.onError()\n onGuardHandling?.()\n }\n } else {\n try {\n let res = await authClient.resetPasswordByForceResetToken({\n token: initData.token,\n newPassword: password,\n oldPassword: oldPassword,\n })\n props.onReset({ code: 200, data: res })\n } catch (error: any) {\n message.error(error.message)\n submitButtonRef?.current?.onError()\n } finally {\n submitButtonRef?.current?.onSpin(false)\n }\n }\n }\n\n return (\n <div className=\"authing-g2-login-phone-code\">\n <Form\n name=\"resetPassword\"\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => {\n submitButtonRef?.current?.onError()\n }}\n autoComplete=\"off\"\n >\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"oldPassword\"\n rules={[...fieldRequiredRule(t('common.password'))]}\n >\n <InputPassword\n autoFocus={!isPhoneMedia}\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('user.inputCurrPwd')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n <CustomFormItem.Password\n className=\"authing-g2-input-form\"\n name=\"password\"\n >\n <InputPassword\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputNewPwd')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </CustomFormItem.Password>\n <CustomFormItem.Password\n className=\"authing-g2-input-form\"\n name=\"password2\"\n rules={[\n {\n validator(_, value) {\n let pwd = form.getFieldValue('password')\n if (!value) {\n return Promise.reject(t('login.inputPwd'))\n }\n if (value !== pwd) {\n return Promise.reject(t('common.repeatPasswordDoc'))\n }\n return Promise.resolve()\n },\n },\n ]}\n >\n <InputPassword\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputPwdAgain')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </CustomFormItem.Password>\n {getPassWordUnsafeText()}\n <Form.Item className=\"authing-g2-sumbit-form submit-form\">\n <SubmitButton\n className=\"forget-password\"\n text={t('common.confirm')}\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n","import React, { useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { Form, message } from 'antd'\nimport { useGuardAuthClient } from '../../Guard/authClient'\nimport SubmitButton from '../../SubmitButton'\nimport CustomFormItem from '../../ValidatorRules'\nimport { IconFont } from '../../IconFont'\nimport { InputPassword } from '../../InputPassword'\nimport {\n useGuardInitData,\n useGuardIsAuthFlow,\n useGuardPublicConfig,\n} from '../../_utils/context'\nimport { authFlow, ChangePasswordBusinessAction } from '../businessRequest'\nimport { ApiCode } from '../../_utils/responseManagement/interface'\nimport { useMediaSize } from '../../_utils/hooks'\nimport { usePasswordErrorText } from '../../_utils/useErrorText'\ninterface PasswordNotSafeResetProps {\n onReset: any\n}\nexport const PasswordNotSafeReset: React.FC<PasswordNotSafeResetProps> = ({\n onReset,\n}) => {\n const { t } = useTranslation()\n\n const initData = useGuardInitData<{ token: string }>()\n\n const isAuthFlow = useGuardIsAuthFlow()\n\n const { publicKey } = useGuardPublicConfig()\n\n let [form] = Form.useForm()\n\n let client = useGuardAuthClient()\n\n const encrypt = client.options.encryptFunction\n\n const { isPhoneMedia } = useMediaSize()\n\n let submitButtonRef = useRef<any>(null)\n const {\n getPassWordUnsafeText,\n setPasswordErrorTextShow,\n } = usePasswordErrorText()\n const onFinish = async (values: any) => {\n let newPassword = values.password\n submitButtonRef.current?.onSpin(true)\n\n if (isAuthFlow) {\n // 重置密码成功不会返回 UserInfo\n const { apiCode, onGuardHandling, message: msg } = await authFlow(\n ChangePasswordBusinessAction.ResetPasswordStrengthDetection,\n {\n password: await encrypt!(newPassword, publicKey),\n }\n )\n submitButtonRef.current?.onSpin(false)\n\n if (apiCode === ApiCode.ABORT_FLOW) {\n onReset()\n } else if (apiCode === ApiCode.UNSAFE_PASSWORD_TIP) {\n message.error(msg)\n setPasswordErrorTextShow(true)\n } else {\n submitButtonRef.current?.onError()\n onGuardHandling?.()\n }\n } else {\n try {\n let res = await client.resetPasswordByFirstLoginToken({\n token: initData.token,\n password: newPassword,\n })\n onReset(res)\n } catch (error: any) {\n message.error(error.message)\n submitButtonRef?.current?.onError()\n } finally {\n submitButtonRef.current?.onSpin(false)\n }\n }\n }\n\n return (\n <div className=\"authing-g2-login-phone-code\">\n <Form\n name=\"resetPassword\"\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => {\n submitButtonRef?.current?.onError()\n }}\n autoComplete=\"off\"\n >\n <CustomFormItem.Password\n className=\"authing-g2-input-form\"\n name=\"password\"\n required={true}\n >\n <InputPassword\n autoFocus={!isPhoneMedia}\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputNewPwd')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </CustomFormItem.Password>\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"password2\"\n rules={[\n {\n validator(_, value) {\n let pwd = form.getFieldValue('password')\n if (!value) {\n return Promise.reject(t('login.inputPwd'))\n }\n if (value !== pwd) {\n return Promise.reject(t('common.repeatPasswordDoc'))\n }\n return Promise.resolve()\n },\n },\n ]}\n >\n <InputPassword\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputPwdAgain')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n {getPassWordUnsafeText()}\n <Form.Item className=\"authing-g2-sumbit-form submit-form\">\n <SubmitButton\n className=\"forget-password\"\n text={t('common.confirm')}\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n","import { message } from 'antd'\nimport React, { ReactNode, useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { GuardModuleType } from '../Guard/module'\nimport { ImagePro } from '../ImagePro'\nimport {\n useGuardFinallyConfig,\n useGuardInitData,\n useGuardModule,\n} from '../_utils/context'\nimport { CompletePassword } from './core/completePassword'\nimport { FirstLoginReset } from './core/firstLoginReset'\nimport { RotateReset } from './core/rotateReset'\nimport { PasswordNotSafeReset } from './core/PasswordNotSafeReset'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\n// 手动修改密码,并非「忘记密码」\n// 进入的场景是读取配置:1开了首次登录修改密码 || 2开了密码轮换\nexport const GuardChangePassword: React.FC<{\n title: string\n explain: string\n children: ReactNode\n}> = (props) => {\n const { title, explain, children } = props\n\n const config = useGuardFinallyConfig()\n\n const typeContent = useMemo(\n () => ({\n title,\n explain,\n }),\n [explain, title]\n )\n\n useGuardView()\n\n return (\n <div className=\"g2-view-container g2-change-password\">\n <div className=\"g2-view-header\">\n <ImagePro\n src={config?.logo!}\n size={48}\n borderRadius={4}\n alt=\"\"\n className=\"icon\"\n />\n <div className=\"title\">{typeContent.title}</div>\n <div className=\"title-explain\">{typeContent.explain}</div>\n </div>\n <div className=\"g2-view-tabs\">{children}</div>\n </div>\n )\n}\n\nexport const GuardFirstLoginPasswordResetView: React.FC = () => {\n const { t } = useTranslation()\n\n const { changeModule } = useGuardModule()\n\n const onReset = () => {\n message.success(t('common.updatePsswordSuccess'))\n setTimeout(() => {\n changeModule?.(GuardModuleType.LOGIN)\n }, 500)\n }\n\n const config = useGuardFinallyConfig()\n\n const coreForm = <FirstLoginReset onReset={onReset} />\n\n return (\n <GuardChangePassword\n title={`${t('common.welcome')} ${config.title}`}\n explain={t('common.initPasswordText')}\n >\n {coreForm}\n </GuardChangePassword>\n )\n}\n\nexport const GuardPasswordNotSafeResetView: React.FC = () => {\n const { t } = useTranslation()\n\n const { changeModule } = useGuardModule()\n\n const onReset = () => {\n message.success(t('common.updatePsswordSuccess'))\n setTimeout(() => {\n changeModule?.(GuardModuleType.LOGIN)\n }, 500)\n }\n\n const config = useGuardFinallyConfig()\n\n const coreForm = <PasswordNotSafeReset onReset={onReset} />\n\n return (\n <GuardChangePassword\n title={`${t('common.welcome')} ${config.title}`}\n explain={t('common.unsafePasswordChangeText')}\n >\n {coreForm}\n </GuardChangePassword>\n )\n}\n\nexport const GuardForcedPasswordResetView: React.FC = () => {\n const { t } = useTranslation()\n\n const { changeModule } = useGuardModule()\n\n const initData = useGuardInitData<{ forcedCycle: number }>()\n\n const onReset = () => {\n message.success(t('common.updatePsswordSuccess'))\n setTimeout(() => {\n changeModule?.(GuardModuleType.LOGIN)\n }, 500)\n }\n\n const coreForm = <RotateReset onReset={onReset} />\n\n return (\n <GuardChangePassword\n title={t('user.modifyPwd')}\n explain={t('user.modifyPwdText', {\n number: initData.forcedCycle,\n })}\n >\n {coreForm}\n </GuardChangePassword>\n )\n}\n\nexport const GuardNoticePasswordResetView: React.FC = () => {\n const { t } = useTranslation()\n\n const { changeModule } = useGuardModule()\n\n const initData = useGuardInitData<{\n forcedCycle: number\n onFinishCallBack: any\n }>()\n\n const onReset = () => {\n message.success(t('common.updatePsswordSuccess'))\n setTimeout(() => {\n changeModule?.(GuardModuleType.LOGIN)\n }, 500)\n }\n\n const coreForm = (\n <RotateReset\n onReset={onReset}\n onFinishCallBack={initData.onFinishCallBack}\n />\n )\n\n return (\n <GuardChangePassword\n title={t('user.modifyPwd')}\n explain={t('user.modifyNoticePwdText', {\n number: initData.forcedCycle,\n })}\n >\n {coreForm}\n </GuardChangePassword>\n )\n}\n\nexport const GuardRegisterCompletePasswordView: React.FC = () => {\n const { t } = useTranslation()\n\n const config = useGuardFinallyConfig()\n\n return (\n <GuardChangePassword\n title={`${t('common.welcome')} ${config.title}`}\n explain={t('common.registerCompletePasswordDesc')}\n >\n <CompletePassword />\n </GuardChangePassword>\n )\n}\n","import { User } from 'authing-js-sdk'\nimport { getGuardHttp } from '../_utils/guardHttp'\nimport { CompleteInfoRequest, RegisterCompleteInfoInitData } from './interface'\n\nexport enum CompleteInfoAuthFlowAction {\n Complete = 'complete-completion',\n Skip = 'skip-completion',\n}\n\nexport const authFlow = async (\n action: CompleteInfoAuthFlowAction,\n data?: CompleteInfoRequest\n) => {\n const { authFlow } = getGuardHttp()\n\n const res = await authFlow(action, data)\n\n return res\n}\n\nconst registerMethod = (\n fnName: RegisterCompleteInfoInitData['businessRequestName'] | string,\n content: any,\n profile: any\n) => {\n const { post } = getGuardHttp()\n\n if (fnName === 'registerByEmail') {\n const phoneToken = profile.phoneToken\n\n delete profile.phoneToken\n\n return post(`/api/v2/register-email`, {\n ...content,\n profile: {\n ...content.profile,\n ...profile,\n },\n phoneToken,\n postUserInfoPipeline: true,\n })\n } else if (fnName === 'registerByPhoneCode') {\n const emailToken = profile?.emailToken\n\n delete profile?.emailToken\n return post(`/api/v2/register-phone-code`, {\n ...content,\n profile: {\n ...content.profile,\n ...profile,\n },\n emailToken,\n postUserInfoPipeline: true,\n })\n } else if (fnName === 'registerByEmailCode') {\n const phoneToken = profile.phoneToken\n\n delete profile.phoneToken\n return post('/api/v2/register-email-code', {\n ...content,\n profile: {\n ...content.profile,\n ...profile,\n },\n phoneToken,\n postUserInfoPipeline: true,\n }) as Promise<User>\n } else {\n const phoneToken = profile.phoneToken\n const emailToken = profile.emailToken\n\n delete profile.phoneToken\n delete profile.emailToken\n return post(`/api/v2/register-${fnName.split('-')[0]}`, {\n ...content,\n profile: {\n ...content.profile,\n ...profile,\n },\n postUserInfoPipeline: true,\n phoneToken,\n emailToken,\n })\n }\n}\n\nexport const registerSkipMethod = (\n fnName: RegisterCompleteInfoInitData['businessRequestName'] | string,\n content: any\n) => {\n const { post } = getGuardHttp()\n\n if (fnName === 'registerByEmail') {\n return post(`/api/v2/register-email`, content)\n } else if (fnName === 'registerByPhoneCode') {\n return post(`/api/v2/register-phone-code`, content)\n } else if (fnName === 'registerByEmailCode') {\n return post('/api/v2/register-email-code', content)\n } else {\n return post(`/api/v2/register-${fnName.split('-')[0]}`, content)\n }\n}\n\nexport const registerRequest = async (\n action: CompleteInfoAuthFlowAction,\n registerFnName: RegisterCompleteInfoInitData['businessRequestName'],\n registerContent: any,\n registerProfile?: any\n) => {\n if (action === CompleteInfoAuthFlowAction.Skip) {\n return await registerSkipMethod(registerFnName, registerContent)\n } else if (action === CompleteInfoAuthFlowAction.Complete) {\n return await registerMethod(\n registerFnName,\n registerContent,\n registerProfile\n )\n }\n}\n","import Input, { InputProps } from 'antd/lib/input'\nimport React, { useEffect, useState } from 'react'\n\nexport interface InputNumberProps extends InputProps {}\n\nconst isPhone = (propsValue?: string | number | readonly string[]) =>\n /^[0-9]*$/.test(String(propsValue))\n\nexport const InputNumber = React.forwardRef<any, InputNumberProps>(\n (props, ref) => {\n const { onChange, value: propsValue, ...inputProps } = props\n const [value, setValue] = useState<InputNumberProps['value']>(\n isPhone(propsValue) ? propsValue : ''\n )\n\n const valueChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n setValue(e.target.value)\n onChange?.(e)\n }\n\n useEffect(() => {\n setValue(isPhone(propsValue) ? propsValue : '')\n }, [propsValue])\n\n return (\n <Input\n autoComplete=\"off\"\n {...inputProps}\n ref={ref}\n value={value}\n type=\"tel\"\n pattern=\"[0-9]*\"\n onChange={(e) => {\n let v = e.target.value\n if (!/^[0-9]*$/.test(v)) {\n return\n }\n\n valueChange(e)\n }}\n />\n )\n }\n)\n","import { Button } from 'antd'\nimport React, { FC, useState, useRef, useEffect, useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport './style.less'\nimport { ButtonProps } from 'antd/lib/button'\nimport { i18n } from '../_utils/locales'\n\nconst TIME = 60\nexport interface SendCodeProps extends ButtonProps {\n beforeSend: () => Promise<boolean>\n btnRef?: React.RefObject<HTMLButtonElement>\n setSent?: (value: boolean) => void\n sendDesc?: string\n}\n\nconst useSentCounter = (effect: any) => {\n const [countDown, setCountDown] = useState(0)\n const timerRef = useRef<any>(0)\n\n useEffect(() => {\n return () => clearInterval(timerRef.current)\n }, [])\n\n useEffect(() => {\n if (countDown <= 0) {\n clearInterval(timerRef.current)\n effect?.(false)\n } else {\n effect?.(true)\n }\n }, [countDown, effect])\n\n const enabled = useMemo(() => countDown <= 0, [countDown])\n\n const send = () => {\n setCountDown(TIME)\n\n timerRef.current = setInterval(() => {\n setCountDown((prev) => {\n return prev - 1\n })\n }, 1000)\n }\n\n return {\n enabled,\n send,\n countDown,\n }\n}\n\nexport const SendCodeBtn: FC<SendCodeProps> = (props) => {\n const { t } = useTranslation()\n const {\n sendDesc = t('login.clickSent'),\n beforeSend,\n btnRef,\n setSent,\n ...buttonProps\n } = props\n const { enabled, send, countDown } = useSentCounter(setSent)\n const [loading, setLoading] = useState(false)\n const disabled = useMemo(() => {\n return !enabled || loading\n }, [enabled, loading])\n\n const onClick = async (e: React.MouseEvent<HTMLButtonElement>) => {\n setLoading(true)\n if (disabled) {\n return\n }\n let beforeStop = !(await beforeSend())\n if (beforeStop) {\n setLoading(false)\n return\n }\n setLoading(false)\n send()\n }\n\n return (\n <Button\n {...buttonProps}\n className={`${\n buttonProps.type ?? 'authing-g2-send-code-btn g2-loading-btn-center'\n } ${i18n.language === 'ja-JP' ? 'send-code-btn-jp' : ''}`}\n disabled={disabled}\n loading={loading}\n onClick={onClick}\n ref={btnRef}\n >\n {loading === true && <span></span>}\n {loading === false && (\n <span>\n {enabled\n ? sendDesc\n : t('common.retryAfterTime', {\n time: countDown,\n })}\n </span>\n )}\n </Button>\n )\n}\n","import { Col, Row } from 'antd'\nimport React, { FC } from 'react'\n\nimport { SendCodeBtn } from './SendCodeBtn'\n\nimport { i18n } from '../_utils/locales'\n\nimport './style.less'\nimport { useTranslation } from 'react-i18next'\n\nimport { InputProps } from 'antd/lib/input'\nimport { InputNumber } from '../InputNumber'\n\nexport interface SendPhoneCodeProps extends InputProps {\n form?: any\n beforeSend?: any // 点击的时候先做这个\n autoSubmit?: boolean //验证码输入完毕是否自动提交\n}\n\nexport const SendCode: FC<SendPhoneCodeProps> = ({\n value,\n onChange,\n autoSubmit = false,\n form,\n beforeSend,\n maxLength,\n ...inputProps\n}) => {\n const { t } = useTranslation()\n return (\n <>\n <Row justify=\"space-between\" align=\"middle\">\n <Col\n span={/ja/.test(i18n.language) ? 9 : 15}\n className=\"g2-send-code-input-col\"\n >\n <InputNumber\n value={value}\n onChange={(e) => {\n onChange?.(e)\n if (!autoSubmit) return\n if (maxLength && e.target.value.length >= maxLength) {\n form?.submit()\n }\n }}\n {...inputProps}\n maxLength={maxLength}\n />\n </Col>\n <Col offset={1} span={/ja/.test(i18n.language) ? 14 : 8}>\n <SendCodeBtn\n beforeSend={beforeSend}\n sendDesc={t('common.sendVerifyCode')}\n />\n </Col>\n </Row>\n </>\n )\n}\n","import { message } from 'antd'\nimport React, { FC } from 'react'\nimport './style.less'\nimport { useTranslation } from 'react-i18next'\nimport { validate } from '../_utils'\nimport { InputProps } from 'antd/lib/input'\nimport { SendCode } from './index'\nimport { getGuardHttp } from '../_utils/guardHttp'\nimport { EmailScene } from '../Type'\nimport { useGuardEvents } from '../_utils/context'\nimport { useGuardAuthClient } from '../Guard/authClient'\nexport interface SendCodeByEmailProps extends InputProps {\n data?: string\n form?: any\n onSendCodeBefore?: any // 点击的时候先做这个\n fieldName?: string\n autoSubmit?: boolean //验证码输入完毕是否自动提交\n scene: EmailScene\n}\n\nexport const SendCodeByEmail: FC<SendCodeByEmailProps> = (props) => {\n const {\n scene,\n data,\n form,\n onSendCodeBefore,\n fieldName,\n ...remainProps\n } = props\n const { t } = useTranslation()\n const events = useGuardEvents()\n const authClient = useGuardAuthClient()\n const { post } = getGuardHttp()\n const sendEmail = async (email: string) => {\n if (!email) {\n message.error(t('login.inputEmail'))\n return {\n status: false,\n error: {\n code: 400,\n message: t('login.inputEmail'),\n },\n }\n }\n if (!validate('email', email)) {\n message.error(t('common.emailFormatError'))\n return {\n status: false,\n error: {\n code: 400,\n message: t('common.emailFormatError'),\n },\n }\n }\n try {\n const { code, message: tips, apiCode } = await post(\n '/api/v2/email/send',\n {\n email,\n scene,\n }\n )\n if (apiCode === 2080) {\n // 一分钟只能发一次邮箱验证码的提示信息,特殊处理\n message.error(tips)\n return {\n status: false,\n error: {\n code: apiCode,\n message: tips,\n },\n }\n }\n if (code === 200) {\n return {\n status: true,\n }\n } else {\n message.error(t('login.sendCodeTimeout'))\n return {\n status: false,\n error: {\n code,\n message: t('login.sendCodeTimeout'),\n },\n }\n }\n // await await authClient.sendEmail(email, scene)\n // onSend?.()\n } catch (error) {\n // onError?.(error)\n return {\n status: false,\n error: {\n message: JSON.stringify(error),\n code: 401,\n },\n }\n }\n }\n\n return (\n <SendCode\n beforeSend={() => {\n return onSendCodeBefore()\n .then(async (b: any) => {\n let email = form ? form.getFieldValue(fieldName || 'email') : data\n const { status, error } = await sendEmail(email)\n if (status) {\n events?.onEmailSend?.(authClient, scene)\n } else {\n events?.onEmailSendError?.(error, authClient, scene)\n }\n return status\n })\n .catch((e: any) => {\n events?.onEmailSendError?.(e, authClient, scene)\n return false\n })\n }}\n form={form}\n {...remainProps}\n />\n )\n}\n","import { message } from 'antd'\nimport React, { FC } from 'react'\nimport { SceneType } from 'authing-js-sdk'\nimport './style.less'\nimport { useTranslation } from 'react-i18next'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport { InputProps } from 'antd/lib/input'\nimport { SendCode } from './index'\nimport { parsePhone } from '../_utils/hooks'\nimport { useGuardEvents } from '../_utils/context'\nimport { useGuardHttp } from '../_utils/guardHttp'\nexport interface SendCodeByPhoneProps extends InputProps {\n data?: string\n form?: any\n onSendCodeBefore?: any // 点击的时候先做这个\n fieldName?: string\n autoSubmit?: boolean //验证码输入完毕是否自动提交\n scene: SceneType\n areaCode?: string //国际区号\n isInternationSms?: boolean //是否是国际短信\n codeFieldName?: string\n captchaCode?: string\n}\n\nexport const SendCodeByPhone: FC<SendCodeByPhoneProps> = (props) => {\n const {\n scene,\n data,\n form,\n areaCode,\n onSendCodeBefore,\n fieldName,\n isInternationSms = false,\n codeFieldName,\n captchaCode,\n ...remainProps\n } = props\n const { t } = useTranslation()\n\n const authClient = useGuardAuthClient()\n\n const events = useGuardEvents()\n const { post } = useGuardHttp()\n\n const sendPhone = async (\n phone: string,\n countryCode?: string,\n captchaCode?: string\n ) => {\n try {\n // await authClient.sendSmsCode(phone, countryCode, scene)\n /**\n * 这个 post 方法请求时,接口报错或者超时 code 会返回 -1、-2,这个时候全局会给出提示,并且不会抛错\n * 会继续走下面逻辑,不走 catch\n * post 方法:packages/react-components/components/_utils/http.ts\n * 响应拦截:packages/react-components/components/_utils/responseManagement/index.ts\n */\n const data = await post('/api/v2/sms/send', {\n phone,\n phoneCountryCode: countryCode,\n scene,\n captchaCode,\n })\n const { code, statusCode, message: msg } = data\n // 200 表示请求成功,不报错\n if (statusCode === 200 || code === 200) {\n return { status: true }\n } else {\n // 由于使用项目中 post 方法进行请求,外层进行了处理,不会抛错,catch 不会走,在这对 code 进行针对处理\n // 'ECONNABORTED' 不知道是不是只有 sdk 报错,所以我在接口这也写了,防止接口也会1报这个错\n if ((code as any) === 'ECONNABORTED') {\n message.error(t('login.sendCodeTimeout'))\n return {\n status: false,\n error: data,\n }\n }\n // code 不是 -1、-2 时,并且 msg 存在, 那么进行报错\n if (!(code === -1 || code === -2)) {\n msg && message.error(msg)\n }\n // 这里看之前 sdk catch 中把整个 error对象传递的,所以报错时我就把整个返回值当作 error 对象传递了,而不是单独传递 message\n // 看的本文件 117行 onPhoneSendError 函数接受的 error 类型是一个对象「只包含 code、message」\n return { status: false, error: data }\n }\n // return { status: true }\n } catch (error: any) {\n if (error.code === 'ECONNABORTED') {\n message.error(t('login.sendCodeTimeout'))\n return {\n status: false,\n error,\n }\n }\n const { message: msg } = JSON.parse(error.message)\n message.error(msg)\n return {\n status: false,\n error,\n }\n }\n }\n\n return (\n <>\n <SendCode\n beforeSend={() => {\n return onSendCodeBefore()\n .then(async (b: any) => {\n let fieldValue = form\n ? form.getFieldValue(fieldName || 'phone')\n : data\n const { phoneNumber, countryCode } = parsePhone(\n isInternationSms,\n fieldValue,\n areaCode\n )\n\n const code = form\n ? form?.getFieldValue(codeFieldName || 'captchaCode')\n : captchaCode\n\n const { status, error } = await sendPhone(\n phoneNumber,\n countryCode,\n code\n )\n if (status) {\n events?.onPhoneSend?.(authClient, scene)\n } else {\n events?.onPhoneSendError?.(error, authClient, scene)\n }\n return status\n })\n .catch((e: any) => {\n events?.onPhoneSendError?.(e, authClient, scene)\n return false\n })\n }}\n form={form}\n {...remainProps}\n />\n </>\n )\n}\n","export interface IsoType {\n iso: string\n regions: string\n regions_en: string\n phoneCountryCode: string\n}\nexport const isoInfo: IsoType[] = [\n {\n iso: 'CA',\n regions: '加拿大',\n regions_en: 'Canada',\n phoneCountryCode: '+1',\n },\n {\n iso: 'US',\n regions: '美国',\n regions_en: 'United States',\n phoneCountryCode: '+1',\n },\n {\n iso: 'KZ',\n regions: '哈萨克斯坦',\n regions_en: 'Kazakhstan',\n phoneCountryCode: '+7',\n },\n {\n iso: 'RU',\n regions: '俄罗斯',\n regions_en: 'Russia',\n phoneCountryCode: '+7',\n },\n {\n iso: 'EG',\n regions: '埃及',\n regions_en: 'Egypt',\n phoneCountryCode: '+20',\n },\n {\n iso: 'ZA',\n regions: '南非',\n regions_en: 'South Africa',\n phoneCountryCode: '+27',\n },\n {\n iso: 'GR',\n regions: '希腊',\n regions_en: 'Greece',\n phoneCountryCode: '+30',\n },\n {\n iso: 'NL',\n regions: '荷兰',\n regions_en: 'Netherlands',\n phoneCountryCode: '+31',\n },\n {\n iso: 'BE',\n regions: '比利时',\n regions_en: 'Belgium',\n phoneCountryCode: '+32',\n },\n {\n iso: 'FR',\n regions: '法国',\n regions_en: 'France',\n phoneCountryCode: '+33',\n },\n {\n iso: 'ES',\n regions: '西班牙',\n regions_en: 'Spain',\n phoneCountryCode: '+34',\n },\n {\n iso: 'HU',\n regions: '匈牙利',\n regions_en: 'Hungary',\n phoneCountryCode: '+36',\n },\n {\n iso: 'IT',\n regions: '意大利',\n regions_en: 'Italy',\n phoneCountryCode: '+39',\n },\n {\n iso: 'RO',\n regions: '罗马尼亚',\n regions_en: 'Romania',\n phoneCountryCode: '+40',\n },\n {\n iso: 'CH',\n regions: '瑞士',\n regions_en: 'Switzerland',\n phoneCountryCode: '+41',\n },\n {\n iso: 'AT',\n regions: '奥地利',\n regions_en: 'Austria',\n phoneCountryCode: '+43',\n },\n {\n iso: 'GB',\n regions: '英国',\n regions_en: 'United Kingdom',\n phoneCountryCode: '+44',\n },\n {\n iso: 'DK',\n regions: '丹麦',\n regions_en: 'Denmark',\n phoneCountryCode: '+45',\n },\n {\n iso: 'SE',\n regions: '瑞典',\n regions_en: 'Sweden',\n phoneCountryCode: '+46',\n },\n {\n iso: 'NO',\n regions: '挪威',\n regions_en: 'Norway',\n phoneCountryCode: '+47',\n },\n {\n iso: 'PL',\n regions: '波兰',\n regions_en: 'Poland',\n phoneCountryCode: '+48',\n },\n {\n iso: 'DE',\n regions: '德国',\n regions_en: 'Germany',\n phoneCountryCode: '+49',\n },\n {\n iso: 'PE',\n regions: '秘鲁',\n regions_en: 'Peru',\n phoneCountryCode: '+51',\n },\n {\n iso: 'MX',\n regions: '墨西哥',\n regions_en: 'Mexico',\n phoneCountryCode: '+52',\n },\n {\n iso: 'CU',\n regions: '古巴',\n regions_en: 'Cuba',\n phoneCountryCode: '+53',\n },\n {\n iso: 'AR',\n regions: '阿根廷',\n regions_en: 'Argentina',\n phoneCountryCode: '+54',\n },\n {\n iso: 'BR',\n regions: '巴西',\n regions_en: 'Brazil',\n phoneCountryCode: '+55',\n },\n {\n iso: 'CL',\n regions: '智利',\n regions_en: 'Chile',\n phoneCountryCode: '+56',\n },\n {\n iso: 'CO',\n regions: '哥伦比亚',\n regions_en: 'Colombia',\n phoneCountryCode: '+57',\n },\n {\n iso: 'VE',\n regions: '委内瑞拉',\n regions_en: 'Venezuela',\n phoneCountryCode: '+58',\n },\n {\n iso: 'MY',\n regions: '马来西亚',\n regions_en: 'Malaysia',\n phoneCountryCode: '+60',\n },\n {\n iso: 'AU',\n regions: '澳大利亚',\n regions_en: 'Australia',\n phoneCountryCode: '+61',\n },\n {\n iso: 'ID',\n regions: '印度尼西亚',\n regions_en: 'Indonesia',\n phoneCountryCode: '+62',\n },\n {\n iso: 'PH',\n regions: '菲律宾',\n regions_en: 'Philippines',\n phoneCountryCode: '+63',\n },\n {\n iso: 'NZ',\n regions: '新西兰',\n regions_en: 'New Zealand',\n phoneCountryCode: '+64',\n },\n {\n iso: 'SG',\n regions: '新加坡',\n regions_en: 'Singapore',\n phoneCountryCode: '+65',\n },\n {\n iso: 'TH',\n regions: '泰国',\n regions_en: 'Thailand',\n phoneCountryCode: '+66',\n },\n {\n iso: 'JP',\n regions: '日本',\n regions_en: 'Japan',\n phoneCountryCode: '+81',\n },\n {\n iso: 'KR',\n regions: '韩国',\n regions_en: 'South Korea',\n phoneCountryCode: '+82',\n },\n {\n iso: 'VN',\n regions: '越南',\n regions_en: 'Vietnam',\n phoneCountryCode: '+84',\n },\n {\n iso: 'CN',\n regions: '中国',\n regions_en: 'China',\n phoneCountryCode: '+86',\n },\n {\n iso: 'TR',\n regions: '土耳其',\n regions_en: 'Turkey',\n phoneCountryCode: '+90',\n },\n {\n iso: 'IN',\n regions: '印度',\n regions_en: 'India',\n phoneCountryCode: '+91',\n },\n {\n iso: 'PK',\n regions: '巴基斯坦',\n regions_en: 'Pakistan',\n phoneCountryCode: '+92',\n },\n {\n iso: 'AF',\n regions: '阿富汗',\n regions_en: 'Afghanistan',\n phoneCountryCode: '+93',\n },\n {\n iso: 'LK',\n regions: '斯里兰卡',\n regions_en: 'Sri Lanka',\n phoneCountryCode: '+94',\n },\n {\n iso: 'MM',\n regions: '缅甸',\n regions_en: 'Myanmar',\n phoneCountryCode: '+95',\n },\n {\n iso: 'IR',\n regions: '伊朗',\n regions_en: 'Iran',\n phoneCountryCode: '+98',\n },\n {\n iso: 'MA',\n regions: '摩洛哥',\n regions_en: 'Morocco',\n phoneCountryCode: '+212',\n },\n {\n iso: 'DZ',\n regions: '阿尔及利亚',\n regions_en: 'Algeria',\n phoneCountryCode: '+213',\n },\n {\n iso: 'TN',\n regions: '突尼斯',\n regions_en: 'Tunisia',\n phoneCountryCode: '+216',\n },\n {\n iso: 'LY',\n regions: '利比亚',\n regions_en: 'Libya',\n phoneCountryCode: '+218',\n },\n {\n iso: 'GM',\n regions: '冈比亚',\n regions_en: 'Gambia',\n phoneCountryCode: '+220',\n },\n {\n iso: 'SN',\n regions: '塞内加尔',\n regions_en: 'Senegal',\n phoneCountryCode: '+221',\n },\n {\n iso: 'MR',\n regions: '毛里塔尼亚',\n regions_en: 'Mauritania',\n phoneCountryCode: '+222',\n },\n {\n iso: 'ML',\n regions: '马里',\n regions_en: 'Mali',\n phoneCountryCode: '+223',\n },\n {\n iso: 'GN',\n regions: '几内亚',\n regions_en: 'Guinea',\n phoneCountryCode: '+224',\n },\n {\n iso: 'CI',\n regions: '象牙海岸',\n regions_en: 'Ivory Coast',\n phoneCountryCode: '+225',\n },\n {\n iso: 'BF',\n regions: '布基纳法索',\n regions_en: 'Burkina Faso',\n phoneCountryCode: '+226',\n },\n {\n iso: 'NE',\n regions: '尼日尔',\n regions_en: 'Niger',\n phoneCountryCode: '+227',\n },\n {\n iso: 'TG',\n regions: '多哥',\n regions_en: 'Togo',\n phoneCountryCode: '+228',\n },\n {\n iso: 'BJ',\n regions: '贝宁',\n regions_en: 'Benin',\n phoneCountryCode: '+229',\n },\n {\n iso: 'MU',\n regions: '毛里求斯',\n regions_en: 'Mauritius',\n phoneCountryCode: '+230',\n },\n {\n iso: 'LR',\n regions: '利比里亚',\n regions_en: 'Liberia',\n phoneCountryCode: '+231',\n },\n {\n iso: 'SL',\n regions: '塞拉利昂',\n regions_en: 'Sierra Leone',\n phoneCountryCode: '+232',\n },\n {\n iso: 'GH',\n regions: '加纳',\n regions_en: 'Ghana',\n phoneCountryCode: '+233',\n },\n {\n iso: 'NG',\n regions: '尼日利亚',\n regions_en: 'Nigeria',\n phoneCountryCode: '+234',\n },\n {\n iso: 'TD',\n regions: '乍得',\n regions_en: 'Chad',\n phoneCountryCode: '+235',\n },\n {\n iso: 'CF',\n regions: '中非共和国',\n regions_en: 'Central African Republic',\n phoneCountryCode: '+236',\n },\n {\n iso: 'CM',\n regions: '喀麦隆',\n regions_en: 'Cameroon',\n phoneCountryCode: '+237',\n },\n {\n iso: 'CV',\n regions: '开普',\n regions_en: 'Cape Verde',\n phoneCountryCode: '+238',\n },\n {\n iso: 'ST',\n regions: '圣多美和普林西比',\n regions_en: 'Sao Tome and Principe',\n phoneCountryCode: '+239',\n },\n {\n iso: 'GQ',\n regions: '赤道几内亚',\n regions_en: 'Equatorial Guinea',\n phoneCountryCode: '+240',\n },\n {\n iso: 'GA',\n regions: '加蓬',\n regions_en: 'Gabon',\n phoneCountryCode: '+241',\n },\n {\n iso: 'CG',\n regions: '刚果共和国',\n regions_en: 'Republic Of The Congo',\n phoneCountryCode: '+242',\n },\n {\n iso: 'CD',\n regions: '刚果民主共和国',\n regions_en: 'Democratic Republic of theCongo',\n phoneCountryCode: '+243',\n },\n {\n iso: 'AO',\n regions: '安哥拉',\n regions_en: 'Angola',\n phoneCountryCode: '+244',\n },\n {\n iso: 'GW',\n regions: '几内亚比绍共和国',\n regions_en: 'Guinea-Bissau',\n phoneCountryCode: '+245',\n },\n {\n iso: 'SC',\n regions: '塞舌尔',\n regions_en: 'Seychelles',\n phoneCountryCode: '+248',\n },\n {\n iso: 'SD',\n regions: '苏丹',\n regions_en: 'Sudan',\n phoneCountryCode: '+249',\n },\n {\n iso: 'RW',\n regions: '卢旺达',\n regions_en: 'Rwanda',\n phoneCountryCode: '+250',\n },\n {\n iso: 'ET',\n regions: '埃塞俄比亚',\n regions_en: 'Ethiopia',\n phoneCountryCode: '+251',\n },\n {\n iso: 'SO',\n regions: '索马里',\n regions_en: 'Somalia',\n phoneCountryCode: '+252',\n },\n {\n iso: 'DJ',\n regions: '吉布提',\n regions_en: 'Djibouti',\n phoneCountryCode: '+253',\n },\n {\n iso: 'KE',\n regions: '肯尼亚',\n regions_en: 'Kenya',\n phoneCountryCode: '+254',\n },\n {\n iso: 'TZ',\n regions: '坦桑尼亚',\n regions_en: 'Tanzania',\n phoneCountryCode: '+255',\n },\n {\n iso: 'UG',\n regions: '乌干达',\n regions_en: 'Uganda',\n phoneCountryCode: '+256',\n },\n {\n iso: 'BI',\n regions: '布隆迪',\n regions_en: 'Burundi',\n phoneCountryCode: '+257',\n },\n {\n iso: 'MZ',\n regions: '莫桑比克',\n regions_en: 'Mozambique',\n phoneCountryCode: '+258',\n },\n {\n iso: 'ZM',\n regions: '赞比亚',\n regions_en: 'Zambia',\n phoneCountryCode: '+260',\n },\n {\n iso: 'MG',\n regions: '马达加斯加',\n regions_en: 'Madagascar',\n phoneCountryCode: '+261',\n },\n {\n iso: 'RE',\n regions: '留尼汪',\n regions_en: 'Réunion Island',\n phoneCountryCode: '+262',\n },\n {\n iso: 'ZW',\n regions: '津巴布韦',\n regions_en: 'Zimbabwe',\n phoneCountryCode: '+263',\n },\n {\n iso: 'NA',\n regions: '纳米比亚',\n regions_en: 'Namibia',\n phoneCountryCode: '+264',\n },\n {\n iso: 'MW',\n regions: '马拉维',\n regions_en: 'Malawi',\n phoneCountryCode: '+265',\n },\n {\n iso: 'LS',\n regions: '莱索托',\n regions_en: 'Lesotho',\n phoneCountryCode: '+266',\n },\n {\n iso: 'BW',\n regions: '博茨瓦纳',\n regions_en: 'Botswana',\n phoneCountryCode: '+267',\n },\n {\n iso: 'SZ',\n regions: '斯威士兰',\n regions_en: 'Swaziland',\n phoneCountryCode: '+268',\n },\n {\n iso: 'KM',\n regions: '科摩罗',\n regions_en: 'Comoros',\n phoneCountryCode: '+269',\n },\n {\n iso: 'YT',\n regions: '马约特',\n regions_en: 'Mayotte',\n phoneCountryCode: '+269',\n },\n {\n iso: 'ER',\n regions: '厄立特里亚',\n regions_en: 'Eritrea',\n phoneCountryCode: '+291',\n },\n {\n iso: 'AW',\n regions: '阿鲁巴',\n regions_en: 'Aruba',\n phoneCountryCode: '+297',\n },\n {\n iso: 'FO',\n regions: '法罗群岛',\n regions_en: 'Faroe Islands',\n phoneCountryCode: '+298',\n },\n {\n iso: 'GL',\n regions: '格陵兰岛',\n regions_en: 'Greenland',\n phoneCountryCode: '+299',\n },\n {\n iso: 'GI',\n regions: '直布罗陀',\n regions_en: 'Gibraltar',\n phoneCountryCode: '+350',\n },\n {\n iso: 'PT',\n regions: '葡萄牙',\n regions_en: 'Portugal',\n phoneCountryCode: '+351',\n },\n {\n iso: 'LU',\n regions: '卢森堡',\n regions_en: 'Luxembourg',\n phoneCountryCode: '+352',\n },\n {\n iso: 'IE',\n regions: '爱尔兰',\n regions_en: 'Ireland',\n phoneCountryCode: '+353',\n },\n {\n iso: 'IS',\n regions: '冰岛',\n regions_en: 'Iceland',\n phoneCountryCode: '+354',\n },\n {\n iso: 'AL',\n regions: '阿尔巴尼亚',\n regions_en: 'Albania',\n phoneCountryCode: '+355',\n },\n {\n iso: 'MT',\n regions: '马耳他',\n regions_en: 'Malta',\n phoneCountryCode: '+356',\n },\n {\n iso: 'CY',\n regions: '塞浦路斯',\n regions_en: 'Cyprus',\n phoneCountryCode: '+357',\n },\n {\n iso: 'FI',\n regions: '芬兰',\n regions_en: 'Finland',\n phoneCountryCode: '+358',\n },\n {\n iso: 'BG',\n regions: '保加利亚',\n regions_en: 'Bulgaria',\n phoneCountryCode: '+359',\n },\n {\n iso: 'LT',\n regions: '立陶宛',\n regions_en: 'Lithuania',\n phoneCountryCode: '+370',\n },\n {\n iso: 'LV',\n regions: '拉脱维亚',\n regions_en: 'Latvia',\n phoneCountryCode: '+371',\n },\n {\n iso: 'EE',\n regions: '爱沙尼亚',\n regions_en: 'Estonia',\n phoneCountryCode: '+372',\n },\n {\n iso: 'MD',\n regions: '摩尔多瓦',\n regions_en: 'Moldova',\n phoneCountryCode: '+373',\n },\n {\n iso: 'AM',\n regions: '亚美尼亚',\n regions_en: 'Armenia',\n phoneCountryCode: '+374',\n },\n {\n iso: 'BY',\n regions: '白俄罗斯',\n regions_en: 'Belarus',\n phoneCountryCode: '+375',\n },\n {\n iso: 'AD',\n regions: '安道尔',\n regions_en: 'Andorra',\n phoneCountryCode: '+376',\n },\n {\n iso: 'MC',\n regions: '摩纳哥',\n regions_en: 'Monaco',\n phoneCountryCode: '+377',\n },\n {\n iso: 'SM',\n regions: '圣马力诺',\n regions_en: 'San Marino',\n phoneCountryCode: '+378',\n },\n {\n iso: 'UA',\n regions: '乌克兰',\n regions_en: 'Ukraine',\n phoneCountryCode: '+380',\n },\n {\n iso: 'RS',\n regions: '塞尔维亚',\n regions_en: 'Serbia',\n phoneCountryCode: '+381',\n },\n {\n iso: 'ME',\n regions: '黑山',\n regions_en: 'Montenegro',\n phoneCountryCode: '+382',\n },\n {\n iso: 'HR',\n regions: '克罗地亚',\n regions_en: 'Croatia',\n phoneCountryCode: '+385',\n },\n {\n iso: 'SI',\n regions: '斯洛文尼亚',\n regions_en: 'Slovenia',\n phoneCountryCode: '+386',\n },\n {\n iso: 'BA',\n regions: '波斯尼亚和黑塞哥维那',\n regions_en: 'Bosniaand Herzegovina',\n phoneCountryCode: '+387',\n },\n {\n iso: 'MK',\n regions: '马其顿',\n regions_en: 'Macedonia',\n phoneCountryCode: '+389',\n },\n {\n iso: 'CZ',\n regions: '捷克',\n regions_en: 'Czech',\n phoneCountryCode: '+420',\n },\n {\n iso: 'SK',\n regions: '斯洛伐克',\n regions_en: 'Slovakia',\n phoneCountryCode: '+421',\n },\n {\n iso: 'LI',\n regions: '列支敦士登',\n regions_en: 'Liechtenstein',\n phoneCountryCode: '+423',\n },\n {\n iso: 'BZ',\n regions: '伯利兹',\n regions_en: 'Belize',\n phoneCountryCode: '+501',\n },\n {\n iso: 'GT',\n regions: '瓜地马拉',\n regions_en: 'Guatemala',\n phoneCountryCode: '+502',\n },\n {\n iso: 'SV',\n regions: '萨尔瓦多',\n regions_en: 'ElSalvador',\n phoneCountryCode: '+503',\n },\n {\n iso: 'HN',\n regions: '洪都拉斯',\n regions_en: 'Honduras',\n phoneCountryCode: '+504',\n },\n {\n iso: 'NI',\n regions: '尼加拉瓜',\n regions_en: 'Nicaragua',\n phoneCountryCode: '+505',\n },\n {\n iso: 'CR',\n regions: '哥斯达黎加',\n regions_en: 'CostaRica',\n phoneCountryCode: '+506',\n },\n {\n iso: 'PA',\n regions: '巴拿马',\n regions_en: 'Panama',\n phoneCountryCode: '+507',\n },\n {\n iso: 'PM',\n regions: '圣彼埃尔和密克隆岛',\n regions_en: 'Saint Pierreand Miquelon',\n phoneCountryCode: '+508',\n },\n {\n iso: 'HT',\n regions: '海地',\n regions_en: 'Haiti',\n phoneCountryCode: '+509',\n },\n {\n iso: 'GP',\n regions: '瓜德罗普岛',\n regions_en: 'Guadeloupe',\n phoneCountryCode: '+590',\n },\n {\n iso: 'BO',\n regions: '玻利维亚',\n regions_en: 'Bolivia',\n phoneCountryCode: '+591',\n },\n {\n iso: 'GY',\n regions: '圭亚那',\n regions_en: 'Guyana',\n phoneCountryCode: '+592',\n },\n {\n iso: 'EC',\n regions: '厄瓜多尔',\n regions_en: 'Ecuador',\n phoneCountryCode: '+593',\n },\n {\n iso: 'GF',\n regions: '法属圭亚那',\n regions_en: 'French Guiana',\n phoneCountryCode: '+594',\n },\n {\n iso: 'PY',\n regions: '巴拉圭',\n regions_en: 'Paraguay',\n phoneCountryCode: '+595',\n },\n {\n iso: 'SR',\n regions: '苏里南',\n regions_en: 'Suriname',\n phoneCountryCode: '+597',\n },\n {\n iso: 'UY',\n regions: '乌拉圭',\n regions_en: 'Uruguay',\n phoneCountryCode: '+598',\n },\n {\n iso: 'BQ',\n regions: '荷兰加勒比',\n regions_en: 'Caribisch Nederland',\n phoneCountryCode: '+599',\n },\n {\n iso: 'CW',\n regions: '库拉索',\n regions_en: 'Curacao',\n phoneCountryCode: '+599',\n },\n {\n iso: 'TL',\n regions: '东帝汶',\n regions_en: 'East Timor',\n phoneCountryCode: '+670',\n },\n {\n iso: 'BN',\n regions: '文莱',\n regions_en: 'Brunei',\n phoneCountryCode: '+673',\n },\n {\n iso: 'NR',\n regions: '拿鲁岛',\n regions_en: 'Nauru',\n phoneCountryCode: '+674',\n },\n {\n iso: 'PG',\n regions: '巴布亚新几内亚',\n regions_en: 'Papua New Guinea',\n phoneCountryCode: '+675',\n },\n {\n iso: 'TO',\n regions: '汤加',\n regions_en: 'Tonga',\n phoneCountryCode: '+676',\n },\n {\n iso: 'SB',\n regions: '所罗门群岛',\n regions_en: 'Solomon Islands',\n phoneCountryCode: '+677',\n },\n {\n iso: 'VU',\n regions: '瓦努阿图',\n regions_en: 'Vanuatu',\n phoneCountryCode: '+678',\n },\n {\n iso: 'FJ',\n regions: '斐济',\n regions_en: 'Fiji',\n phoneCountryCode: '+679',\n },\n {\n iso: 'PW',\n regions: '帕劳',\n regions_en: 'Palau',\n phoneCountryCode: '+680',\n },\n {\n iso: 'CK',\n regions: '库克群岛',\n regions_en: 'Cook Islands',\n phoneCountryCode: '+682',\n },\n {\n iso: 'WS',\n regions: '萨摩亚',\n regions_en: 'Samoa',\n phoneCountryCode: '+685',\n },\n {\n iso: 'KI',\n regions: '基里巴斯',\n regions_en: 'Kiribati',\n phoneCountryCode: '+686',\n },\n {\n iso: 'NC',\n regions: '新喀里多尼亚',\n regions_en: 'New Caledonia',\n phoneCountryCode: '+687',\n },\n {\n iso: 'PF',\n regions: '法属波利尼西亚',\n regions_en: 'French Polynesia',\n phoneCountryCode: '+689',\n },\n {\n iso: 'FM',\n regions: '密克罗尼西亚',\n regions_en: 'Micronesia',\n phoneCountryCode: '+691',\n },\n {\n iso: 'MH',\n regions: '马绍尔群岛',\n regions_en: 'Marshall Islands',\n phoneCountryCode: '+692',\n },\n {\n iso: 'KP',\n regions: '朝鲜',\n regions_en: 'Korea Democratic Rep.',\n phoneCountryCode: '+850',\n },\n {\n iso: 'HK',\n regions: '中国香港',\n regions_en: 'Hong Kong',\n phoneCountryCode: '+852',\n },\n {\n iso: 'MO',\n regions: '中国澳门',\n regions_en: 'Macau',\n phoneCountryCode: '+853',\n },\n {\n iso: 'KH',\n regions: '柬埔寨',\n regions_en: 'Cambodia',\n phoneCountryCode: '+855',\n },\n {\n iso: 'LA',\n regions: '老挝',\n regions_en: 'Laos',\n phoneCountryCode: '+856',\n },\n {\n iso: 'BD',\n regions: '孟加拉国',\n regions_en: 'Bangladesh',\n phoneCountryCode: '+880',\n },\n {\n iso: 'TW',\n regions: '中国台湾',\n regions_en: 'Taiwan',\n phoneCountryCode: '+886',\n },\n {\n iso: 'MV',\n regions: '马尔代夫',\n regions_en: 'Maldives',\n phoneCountryCode: '+960',\n },\n {\n iso: 'LB',\n regions: '黎巴嫩',\n regions_en: 'Lebanon',\n phoneCountryCode: '+961',\n },\n {\n iso: 'JO',\n regions: '约旦',\n regions_en: 'Jordan',\n phoneCountryCode: '+962',\n },\n {\n iso: 'SY',\n regions: '叙利亚',\n regions_en: 'Syria',\n phoneCountryCode: '+963',\n },\n {\n iso: 'IQ',\n regions: '伊拉克',\n regions_en: 'Iraq',\n phoneCountryCode: '+964',\n },\n {\n iso: 'KW',\n regions: '科威特',\n regions_en: 'Kuwait',\n phoneCountryCode: '+965',\n },\n {\n iso: 'SA',\n regions: '沙特阿拉伯',\n regions_en: 'Saudi Arabia',\n phoneCountryCode: '+966',\n },\n {\n iso: 'YE',\n regions: '也门',\n regions_en: 'Yemen',\n phoneCountryCode: '+967',\n },\n {\n iso: 'OM',\n regions: '阿曼',\n regions_en: 'Oman',\n phoneCountryCode: '+968',\n },\n {\n iso: 'AE',\n regions: '阿拉伯联合酋长国',\n regions_en: 'United Arab Emirates',\n phoneCountryCode: '+971',\n },\n {\n iso: 'IL',\n regions: '以色列',\n regions_en: 'Israel',\n phoneCountryCode: '+972',\n },\n {\n iso: 'BH',\n regions: '巴林',\n regions_en: 'Bahrain',\n phoneCountryCode: '+973',\n },\n {\n iso: 'QA',\n regions: '卡塔尔',\n regions_en: 'Qatar',\n phoneCountryCode: '+974',\n },\n {\n iso: 'BT',\n regions: '不丹',\n regions_en: 'Bhutan',\n phoneCountryCode: '+975',\n },\n {\n iso: 'MN',\n regions: '蒙古',\n regions_en: 'Mongolia',\n phoneCountryCode: '+976',\n },\n {\n iso: 'NP',\n regions: '尼泊尔',\n regions_en: 'Nepal',\n phoneCountryCode: '+977',\n },\n {\n iso: 'TJ',\n regions: '塔吉克斯坦',\n regions_en: 'Tajikistan',\n phoneCountryCode: '+992',\n },\n {\n iso: 'TM',\n regions: '土库曼斯坦',\n regions_en: 'Turkmenistan',\n phoneCountryCode: '+993',\n },\n {\n iso: 'AZ',\n regions: '阿塞拜疆',\n regions_en: 'Azerbaijan',\n phoneCountryCode: '+994',\n },\n {\n iso: 'GE',\n regions: '格鲁吉亚',\n regions_en: 'Georgia',\n phoneCountryCode: '+995',\n },\n {\n iso: 'KG',\n regions: '吉尔吉斯斯坦',\n regions_en: 'Kyrgyzstan',\n phoneCountryCode: '+996',\n },\n {\n iso: 'UZ',\n regions: '乌兹别克斯坦',\n regions_en: 'Uzbekistan',\n phoneCountryCode: '+998',\n },\n {\n iso: 'BS',\n regions: '巴哈马',\n regions_en: 'Bahamas',\n phoneCountryCode: '+1242',\n },\n {\n iso: 'BB',\n regions: '巴巴多斯',\n regions_en: 'Barbados',\n phoneCountryCode: '+1246',\n },\n {\n iso: 'AI',\n regions: '安圭拉',\n regions_en: 'Anguilla',\n phoneCountryCode: '+1264',\n },\n {\n iso: 'AG',\n regions: '安提瓜和巴布达',\n regions_en: 'Antigua and Barbuda',\n phoneCountryCode: '+1268',\n },\n {\n iso: 'VG',\n regions: '英属处女群岛',\n regions_en: 'VirginIslands,British',\n phoneCountryCode: '+1284',\n },\n {\n iso: 'KY',\n regions: '开曼群岛',\n regions_en: 'Cayman Islands',\n phoneCountryCode: '+1345',\n },\n {\n iso: 'BM',\n regions: '百慕大群岛',\n regions_en: 'Bermuda',\n phoneCountryCode: '+1441',\n },\n {\n iso: 'GD',\n regions: '格林纳达',\n regions_en: 'Grenada',\n phoneCountryCode: '+1473',\n },\n {\n iso: 'TC',\n regions: '特克斯和凯科斯群岛',\n regions_en: 'Turksand Caicos Islands',\n phoneCountryCode: '+1649',\n },\n {\n iso: 'MS',\n regions: '蒙特塞拉特岛',\n regions_en: 'Montserrat',\n phoneCountryCode: '+1664',\n },\n {\n iso: 'GU',\n regions: '关岛',\n regions_en: 'Guam',\n phoneCountryCode: '+1671',\n },\n {\n iso: 'AS',\n regions: '美属萨摩亚',\n regions_en: 'American Samoa',\n phoneCountryCode: '+1684',\n },\n {\n iso: 'LC',\n regions: '圣露西亚',\n regions_en: 'Saint Lucia',\n phoneCountryCode: '+1758',\n },\n {\n iso: 'DM',\n regions: '多米尼加',\n regions_en: 'Dominica',\n phoneCountryCode: '+1767',\n },\n {\n iso: 'VC',\n regions: '圣文森特和格林纳丁斯',\n regions_en: 'Saint Vincent and The Grenadines',\n phoneCountryCode: '+1784',\n },\n {\n iso: 'PR',\n regions: '波多黎各',\n regions_en: 'Puerto Rico',\n phoneCountryCode: '+1787',\n },\n {\n iso: 'DO',\n regions: '多米尼加共和国',\n regions_en: 'dominican republic',\n phoneCountryCode: '+1809',\n },\n {\n iso: 'TT',\n regions: '特立尼达和多巴哥',\n regions_en: 'Trinidadand Tobago',\n phoneCountryCode: '+1868',\n },\n {\n iso: 'KN',\n regions: '圣基茨和尼维斯',\n regions_en: 'Saint Kitts and Nevis',\n phoneCountryCode: '+1869',\n },\n {\n iso: 'JM',\n regions: '牙买加',\n regions_en: 'Jamaica',\n phoneCountryCode: '+1876',\n },\n]\n","import React, { FC } from 'react'\nimport { Select, Tooltip } from 'antd'\nimport { isoInfo, IsoType } from '../../../_utils/countryList'\nimport './styles.less'\nimport { IconFont } from '../../../IconFont'\nimport { i18n } from '../../../_utils/locales'\n\nexport interface VirtualDropdownProps {\n /**\n * 回填的国际化区号\n */\n regionCode?: string\n value?: string\n onChange?: (value: string) => void\n style?: React.CSSProperties\n}\nexport const VirtualDropdown: FC<VirtualDropdownProps> = (props) => {\n const { value, onChange } = props\n\n // 只能单次遍历了\n\n // const [open, setOpen] = useState(false)\n const options = isoInfo.map((info: IsoType) => {\n return {\n value: info.iso,\n key: info.iso,\n children: info.phoneCountryCode,\n label: (\n <div className=\"select-option-item\">\n <span>{info.phoneCountryCode}</span>\n <div className=\"country\">\n <Tooltip\n title={i18n.language === 'zh-CN' ? info.regions : info.regions_en}\n >\n {i18n.language === 'zh-CN' ? info.regions : info.regions_en}\n </Tooltip>\n </div>\n </div>\n ),\n region: info.regions,\n region_en: info.regions_en,\n }\n })\n\n // 现在需要回填国际化短信\n\n return (\n <Select\n showSearch\n dropdownClassName=\"areacode-virtual-dropdown\"\n bordered={false}\n listHeight={258}\n options={options}\n value={value}\n onChange={onChange}\n optionLabelProp=\"children\"\n dropdownMatchSelectWidth={138}\n filterOption={(input, option: any) => {\n if (option.children.toLowerCase().indexOf(input.toLowerCase()) >= 0) {\n return true\n }\n if (option.region.toLowerCase().indexOf(input.toLowerCase()) >= 0) {\n return true\n }\n if (option.region_en.toLowerCase().indexOf(input.toLowerCase()) >= 0) {\n return true\n }\n return false\n // return option.children.toLowerCase().indexOf(input.toLowerCase()) >= 0\n }}\n suffixIcon={\n <>\n <IconFont\n className={'areacode-virtual-dropdown-icon'}\n type={'authing-arrow-down-s-fill'}\n style={{ width: 20, height: 20 }}\n />\n </>\n }\n />\n )\n}\n","import Input, { InputProps } from 'antd/lib/input'\nimport React, { useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport { VirtualDropdown } from './VirtualDropdown'\nexport interface InputInternationPhoneProps extends InputProps {\n areaCode: string\n onAreaCodeChange: (areaCode: string) => void\n}\nexport const InputInternationPhone: React.FC<InputInternationPhoneProps> = (\n props\n) => {\n const {\n areaCode,\n onAreaCodeChange,\n onChange,\n value: formValue,\n ...inputProps\n } = props\n const { t } = useTranslation()\n\n const [value, setValue] = useState(\n /^[^a-zA-Z]*$/.test(String(formValue)) ? formValue : ''\n )\n\n // 当formValue变化时候\n useEffect(() => {\n setValue(/^[^a-zA-Z]*$/.test(String(formValue)) ? formValue : '')\n }, [formValue])\n\n const valueChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n setValue(e.target.value)\n onChange?.(e)\n }\n\n return (\n <>\n <Input\n autoComplete=\"off\"\n pattern=\"[^a-zA-Z]*\"\n value={value}\n placeholder={t('login.inputPhone')}\n {...inputProps}\n onChange={(e) => {\n let v = e.target.value\n if (!/^[^a-zA-Z]*$/.test(v)) {\n return\n }\n valueChange(e)\n }}\n prefix={\n <VirtualDropdown value={areaCode} onChange={onAreaCodeChange} />\n }\n maxLength={20}\n />\n </>\n )\n}\n","import { PlusOutlined } from '@ant-design/icons'\nimport { message, Spin, Upload } from 'antd'\nimport { UploadChangeParam } from 'antd/lib/upload'\nimport React, { FC, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useGuardFinallyConfig } from '../_utils/context'\n\nexport const UploadImage: FC<{\n value?: string\n onChange?: (value: string) => void\n}> = ({ value, onChange }) => {\n const [uploading, setUploading] = useState(false)\n const { t } = useTranslation()\n const { host } = useGuardFinallyConfig()\n\n const onStatusChange = (info: UploadChangeParam) => {\n const { status } = info.file\n\n if (status === 'uploading') {\n setUploading(true)\n } else {\n setUploading(false)\n }\n\n if (status === 'done') {\n const { code, message: errMsg, data } = info.file.response\n if (code !== 200) {\n return message.error(errMsg)\n }\n const { url } = data\n onChange?.(url)\n } else if (status === 'error') {\n message.error(\n t('common.uploadFail', {\n name: info.file.name,\n })\n )\n }\n }\n\n const uploadButton = (\n <div>\n <PlusOutlined />\n <div style={{ marginTop: 8 }}>Upload</div>\n </div>\n )\n\n return (\n <Upload\n name=\"file\"\n accept=\"image/*\"\n listType=\"picture-card\"\n showUploadList={false}\n action={`${host}/api/v2/upload?folder=photos`}\n onChange={onStatusChange}\n >\n <Spin size=\"small\" spinning={uploading}>\n {value ? (\n <img src={value} alt=\"\" style={{ width: '100%' }} />\n ) : (\n uploadButton\n )}\n </Spin>\n </Upload>\n )\n}\n","import React, { useCallback, useEffect, useMemo, useRef, useState } from 'react'\nimport { Form, Input, Select, DatePicker, message } from 'antd'\nimport { useTranslation } from 'react-i18next'\nimport { useAsyncFn } from 'react-use'\nimport { i18n } from '../../_utils/locales'\nimport {\n CompleteInfoBaseControls,\n CompleteInfoExtendsControls,\n CompleteInfoMetaData,\n CompleteInfoRequest,\n} from '../interface'\nimport { useGuardHttp } from '../../_utils/guardHttp'\nimport SubmitButton from '../../SubmitButton'\nimport { InputNumber } from '../../InputNumber'\nimport { SceneType } from 'authing-js-sdk'\nimport CustomFormItem from '../../ValidatorRules'\nimport { fieldRequiredRule, getCurrentLng } from '../../_utils'\nimport { SendCodeByEmail } from '../../SendCode/SendCodeByEmail'\nimport { SendCodeByPhone } from '../../SendCode/SendCodeByPhone'\nimport { useGuardPublicConfig } from '../../_utils/context'\nimport { parsePhone } from '../../_utils/hooks'\nimport { InputInternationPhone } from '../../Login/core/withVerifyCode/InputInternationPhone'\nimport { EmailScene } from '../../Type'\nimport { UploadImage } from '../../UploadImage'\n\nconst MomentPicker: any = DatePicker\nexport interface CompleteInfoProps {\n metaData: CompleteInfoMetaData[]\n businessRequest: (data: CompleteInfoRequest) => Promise<void>\n}\n\nexport interface FieldMetadata {\n key: string\n options: any\n}\n\nconst filterOption = (input: any, option: any) => {\n return (\n option.props.value.toLowerCase().indexOf(input.toLowerCase()) >= 0 ||\n option.props.label.toLowerCase().indexOf(input.toLowerCase()) >= 0\n )\n}\n\nexport const CompleteInfo: React.FC<CompleteInfoProps> = (props) => {\n const { metaData, businessRequest } = props\n\n const config = useGuardPublicConfig()\n\n const verifyCodeLength = config?.verifyCodeLength\n\n const submitButtonRef = useRef<any>(null)\n\n const [countryList, setCountryList] = useState<any>([])\n\n const isInternationSms = config?.internationalSmsConfig?.enabled || false\n\n const [areaCode, setAreaCode] = useState(\n config?.internationalSmsConfig?.defaultISOType || 'CN'\n )\n\n const { get, post } = useGuardHttp()\n\n const { t } = useTranslation()\n\n const [form] = Form.useForm()\n\n const loadInitCountryList = useCallback(async () => {\n const { data } = await get(`/api/v2/country-list`)\n\n const countryMap = i18n.language === 'zh-CN' ? data?.zh : data?.en\n\n const countryList: { label: string; value: string }[] = []\n\n for (const [key, value] of Object.entries(countryMap)) {\n countryList.push({\n label: value + ` (${key})`,\n value: key,\n })\n }\n\n setCountryList(countryList)\n }, [get])\n\n useEffect(() => {\n if (!metaData.map((i) => i.name).includes('country')) return\n loadInitCountryList()\n }, [loadInitCountryList, metaData])\n\n const PhoneAccount = useCallback(\n (props: any) => {\n if (isInternationSms) {\n return (\n <InputInternationPhone\n {...props}\n className=\"authing-g2-input\"\n size=\"large\"\n areaCode={areaCode}\n onAreaCodeChange={(value: string) => {\n setAreaCode(value)\n form.getFieldValue(['internal phone:phone']) &&\n form.validateFields(['internal phone:phone'])\n }}\n maxLength={20}\n />\n )\n } else {\n return (\n <InputNumber\n {...props}\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n key=\"internal-phone:phone123\"\n type=\"tel\"\n size=\"large\"\n maxLength={11}\n placeholder={t('login.inputPhone')}\n />\n )\n }\n },\n [areaCode, form, isInternationSms, t]\n )\n const baseControlMap: Record<\n string,\n (props?: any) => React.ReactNode | undefined\n > = useMemo(\n () => ({\n gender: (props) => (\n <Select\n key={props.key}\n className=\"authing-g2-select\"\n options={[\n { label: i18n.t('common.man'), value: 'M' },\n { label: i18n.t('common.female'), value: 'F' },\n ]}\n />\n ),\n country: (props) => (\n <Select\n key={props.key}\n className=\"authing-g2-select\"\n options={countryList}\n showSearch\n filterOption={filterOption}\n />\n ),\n image: () => <UploadImage />,\n number: (props) => (\n <InputNumber\n key={props.key}\n style={{ width: '100%' }}\n className=\"authing-g2-input\"\n />\n ),\n date: (props) => (\n <MomentPicker\n key={props.key}\n className=\"authing-g2-input\"\n style={{ width: '100%' }}\n placeholder={i18n.t('common.pleaseSelectDate')}\n />\n ),\n datetime: (props) => (\n <MomentPicker\n key={props.key}\n className=\"authing-g2-input\"\n style={{ width: '100%' }}\n placeholder={i18n.t('common.pleaseSelectDate')}\n />\n ),\n select: (props: any) => (\n <Select\n key={props.key}\n className=\"authing-g2-select\"\n showSearch\n options={props.options}\n filterOption={filterOption}\n />\n ),\n dropdown: (props: any) => (\n <Select\n key={props.key}\n className=\"authing-g2-select\"\n showSearch\n options={props.options}\n filterOption={filterOption}\n />\n ),\n boolean: (props) => (\n <Select\n key={props.key}\n className=\"authing-g2-select\"\n options={[\n { label: i18n.t('common.yes'), value: true as any },\n { label: i18n.t('common.no'), value: false as any },\n ]}\n />\n ),\n string: (props) => (\n <Input\n key={props.key}\n type=\"text\"\n size=\"large\"\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n />\n ),\n text: (props) => (\n <Input\n key={props.key}\n type=\"text\"\n size=\"large\"\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n />\n ),\n }),\n [countryList]\n )\n const internalControlMap: Record<\n string,\n (props: any) => React.ReactNode | undefined\n > = useMemo(\n () => ({\n username: (props: any) => (\n <CustomFormItem.UserName\n validateFirst={true}\n className=\"authing-g2-input-form\"\n name=\"username\"\n key={props.key}\n label={props.label ?? i18n.t('common.username')}\n required={props.required}\n checkRepeat={true}\n >\n <Input\n className=\"authing-g2-input\"\n autoComplete=\"username\"\n key=\"internal-username:asdf\"\n size=\"large\"\n maxLength={11}\n placeholder={t('login.inputUsername')}\n />\n </CustomFormItem.UserName>\n ),\n phone: (props: { required?: boolean; label?: string }) => (\n <>\n <CustomFormItem.Phone\n validateFirst={true}\n className={\n isInternationSms\n ? 'authing-g2-input-form remove-padding'\n : 'authing-g2-input-form'\n }\n name=\"phone\"\n key=\"internal-phone:phone\"\n label={props.label ?? i18n.t('common.phoneLabel')}\n required={props.required}\n checkRepeat={true}\n areaCode={areaCode}\n >\n <PhoneAccount />\n </CustomFormItem.Phone>\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"phoneCode\"\n key=\"internal-phone:code\"\n rules={\n props.required\n ? fieldRequiredRule(t('common.captchaCode'))\n : undefined\n }\n >\n <SendCodeByPhone\n isInternationSms={isInternationSms}\n areaCode={areaCode}\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"one-time-code\"\n size=\"large\"\n placeholder={t('common.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n scene={SceneType.SCENE_TYPE_COMPLETE_PHONE}\n maxLength={verifyCodeLength}\n fieldName=\"phone\"\n form={form}\n onSendCodeBefore={() => form.validateFields(['phone'])}\n />\n </Form.Item>\n </>\n ),\n email: (props: { required?: boolean; label?: string }) => (\n <>\n <CustomFormItem.Email\n className=\"authing-g2-input-form\"\n name=\"email\"\n checkRepeat={true}\n label={props.label ?? i18n.t('common.email')}\n required={props.required}\n key=\"internal email:email13\"\n validateFirst={true}\n >\n <Input\n className=\"authing-g2-input\"\n autoComplete=\"email\"\n size=\"large\"\n placeholder={t('login.inputEmail')}\n />\n </CustomFormItem.Email>\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"emailCode\"\n key=\"internal email:code1432\"\n rules={\n props.required\n ? fieldRequiredRule(t('common.captchaCode'))\n : undefined\n }\n >\n <SendCodeByEmail\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"one-time-code\"\n size=\"large\"\n placeholder={t('common.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n maxLength={verifyCodeLength}\n data={''}\n scene={EmailScene.INFORMATION_COMPLETION_VERIFY_CODE}\n fieldName=\"email\"\n form={form}\n onSendCodeBefore={() => form.validateFields(['email'])}\n />\n </Form.Item>\n </>\n ),\n }),\n [PhoneAccount, areaCode, form, isInternationSms, t, verifyCodeLength]\n )\n\n const getMetaDateLabel = useCallback(\n (metaData: CompleteInfoMetaData) => {\n let label: string = ''\n\n const fieldsI18n = config.extendsFieldsI18n?.[metaData.name]\n\n const currentLng = getCurrentLng()\n\n if (fieldsI18n?.[currentLng]?.enabled && fieldsI18n?.[currentLng].value) {\n label = fieldsI18n?.[currentLng].value\n } else {\n label = metaData.label || metaData.name\n }\n\n return label\n },\n [config.extendsFieldsI18n]\n )\n\n const generateRules = useCallback(\n (metaData: CompleteInfoMetaData) => {\n const formRules = []\n\n const label = getMetaDateLabel(metaData)\n\n const rules = metaData.validateRules ?? []\n\n const required = metaData.required ?? false\n\n if (required) {\n formRules.push({\n type:\n metaData.type === CompleteInfoExtendsControls.DATE_TIME\n ? ('object' as const)\n : undefined,\n required: true,\n validateTrigger: 'onChange',\n message: t('login.noEmpty', { label: label }),\n })\n }\n\n // TODO 后端的 rule Type 有很多 前端目前只做了两种的映射\n rules.forEach((rule) => {\n switch (rule.type) {\n case 'isNumber':\n formRules.push({\n type: 'number',\n validateTrigger: 'onBlur',\n message: rule.errorMessage || '请填写数字',\n })\n break\n case 'regExp':\n formRules.push({\n validateTrigger: 'onBlur',\n pattern: new RegExp((rule.content as any).replaceAll('/', '')),\n message: rule.errorMessage,\n })\n break\n default:\n break\n }\n })\n\n return formRules\n },\n [getMetaDateLabel, t]\n )\n\n const inputElement = useCallback(\n (metaData: CompleteInfoMetaData) => {\n // const label =\n // i18n.language === 'zh-CN'\n // ? metaData.label || metaData.name\n // : metaData.name\n const label = getMetaDateLabel(metaData)\n\n // 这部分的控件分两种 一个集成控件(手机号 + 验证码)一种是基础控件 分开处理\n if (\n (Object.values(CompleteInfoBaseControls) as (\n | CompleteInfoBaseControls\n | CompleteInfoExtendsControls\n )[]).includes(metaData.type)\n ) {\n return internalControlMap[metaData.name]({\n required: metaData.required,\n label: label,\n })\n } else {\n const userFormItem = (children: React.ReactNode) => (\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n rules={generateRules(metaData)}\n key={metaData.name}\n name={metaData.name}\n label={label}\n style={{ marginBottom: 8 }}\n >\n {children}\n </Form.Item>\n )\n // 国家名和性别的控件需要单独和name匹配\n if (['country', 'gender'].includes(metaData.name)) {\n return userFormItem(\n baseControlMap[metaData.name]({\n options: metaData.options,\n key: metaData.name,\n })\n )\n } else if (Object.keys(baseControlMap).includes(metaData.type)) {\n return userFormItem(\n baseControlMap[metaData.type]({\n options: metaData.options,\n key: metaData.name,\n })\n )\n }\n return userFormItem(\n <Input type=\"text\" className=\"authing-g2-input\" autoComplete=\"off\" />\n )\n }\n },\n [baseControlMap, generateRules, getMetaDateLabel, internalControlMap]\n )\n\n const formFieldsV2 = useMemo(() => {\n return metaData.map((data) => inputElement(data))\n }, [inputElement, metaData])\n\n const [, onFinish] = useAsyncFn(\n async (values: any) => {\n const fieldKeys = Object.keys(values)\n // 先过滤掉 为空的字段\n .filter((key) => values[key] !== undefined && values[key] !== '')\n\n submitButtonRef.current?.onSpin(true)\n\n const fieldValues = fieldKeys\n // 再过滤掉 两个验证码的字段\n .filter((key) => !['phoneCode', 'emailCode'].includes(key))\n .map((key) => {\n const baseData = {\n name: key,\n value: values[key],\n }\n // 给这两个字段添加一个验证码\n // 国际化短信 需要携带区号\n // TODO 默认这里手机号与邮箱 都是有验证码的\n if (key === 'phone') {\n if (isInternationSms) {\n const { countryCode } = parsePhone(\n isInternationSms,\n values[key],\n areaCode\n )\n return {\n ...baseData,\n code: values.phoneCode,\n phoneCountryCode: countryCode,\n }\n }\n\n return { ...baseData, code: values.phoneCode }\n }\n if (key === 'email') return { ...baseData, code: values.emailCode }\n return baseData\n })\n\n try {\n // 对特殊字段提前进行 precheck 不然直接调用注册接口失败也会导致上一步验证码失效\n // 用户名 check\n if (fieldKeys.includes('username')) {\n const { data: checkResult, code: checkCode } = await get(\n '/api/v2/users/is-user-exists',\n {\n username: values.username,\n }\n )\n // checkResult 为 true 时 代表用户名已存在 直接报message 并且不调用注册接口\n if (checkCode === 200 && checkResult) {\n message.error(t('common.userNameIsExists'))\n return\n }\n }\n // 手机验证码check\n if (fieldKeys.includes('phone')) {\n const options: any = {\n phone: values.phone,\n phoneCode: values.phoneCode,\n }\n if (isInternationSms) {\n const { countryCode } = parsePhone(\n isInternationSms,\n values.phone,\n areaCode\n )\n options.phoneCountryCode = countryCode\n }\n const {\n statusCode: checkCode,\n data: { valid, message: checkMessage },\n } = await post('/api/v2/sms/preCheckCode', options)\n if (checkCode !== 200 || !valid) {\n message.error(checkMessage)\n return\n }\n }\n // 邮箱验证码check\n if (fieldKeys.includes('email')) {\n const {\n statusCode: checkCode,\n data: { valid, message: checkMessage },\n } = await post('/api/v2/email/preCheckCode', {\n email: values.email,\n emailCode: values.emailCode,\n })\n if (checkCode !== 200 || !valid) {\n message.error(checkMessage)\n return\n }\n }\n\n await businessRequest?.({ fieldValues })\n } catch (error) {\n // TODO\n // throw new Error(error)\n } finally {\n submitButtonRef.current?.onSpin(false)\n }\n },\n [areaCode]\n )\n\n return (\n <Form\n layout=\"vertical\"\n form={form}\n onFinish={onFinish}\n onSubmitCapture={() => submitButtonRef.current.onSpin(true)}\n onFinishFailed={() => submitButtonRef.current.onError()}\n className=\"authing-g2-completeInfo-form authing-g2-form-required-item-icon-after\"\n >\n {formFieldsV2}\n\n <Form.Item className=\"authing-g2-sumbit-form\">\n <SubmitButton\n text={t('common.problem.form.submit')}\n ref={submitButtonRef}\n className=\"password g2-completeInfo-submit\"\n />\n </Form.Item>\n </Form>\n )\n}\n","import { Tabs } from 'antd'\nimport React, { ReactNode, useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { ImagePro } from '../ImagePro'\nimport './styles.less'\nimport { useGuardModule, useGuardPublicConfig } from '../_utils/context'\nimport { BackCustom } from '../Back'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nenum DownloadType {\n IOS = 'ios',\n Android = 'Android',\n}\n\nexport const GuardDownloadATView: React.FC = () => {\n useGuardView()\n\n const { t } = useTranslation()\n\n const publicConfig = useGuardPublicConfig()\n\n const { backModule } = useGuardModule()\n\n const cdnBase = publicConfig?.cdnBase\n\n const downloadConfig: Record<DownloadType, any> = useMemo(\n () => ({\n [DownloadType.IOS]: {\n title: t('common.downloadTotpAppIOS'),\n google: `${cdnBase}/GoogleAuthenticator-Apple.png`,\n microsoft: `${cdnBase}/MicrosoftAuthenticator-Apple.png`,\n },\n [DownloadType.Android]: {\n title: t('common.downloadTotpAppAndroid'),\n google: `${cdnBase}/GoogleAuthenticator-Authing.png`,\n microsoft: `${cdnBase}/MicrosoftAuthenticator-Baidu.png`,\n },\n }),\n [cdnBase, t]\n )\n\n const renderTab = useMemo(\n () =>\n (Object.keys(downloadConfig) as DownloadType[]).map<ReactNode>(\n (value: DownloadType, index: number) => (\n <Tabs.TabPane\n tab={downloadConfig[value].title}\n key={index}\n className=\"g2-mfa-download-at-tab\"\n >\n <span className=\"g2-mfa-totp-download-subtitle\">\n {t('common.downloadTotpAppDocs')}\n </span>\n <div className=\"g2-mfa-totp-download-qrcode\">\n <div className=\"g2-mfa-totp-download-qrcode-item\">\n <ImagePro\n width={120}\n height={120}\n className=\"g2-mfa-totp-download-image\"\n src={downloadConfig[value].google}\n alt=\"Google Authenticator\"\n />\n <span className=\"g2-mfa-totp-download-qrcode-text\">\n Google Authenticator\n </span>\n </div>\n <div className=\"g2-mfa-totp-download-qrcode-item\">\n <ImagePro\n width={120}\n height={120}\n className=\"g2-mfa-totp-download-image\"\n src={downloadConfig[value].microsoft}\n alt=\"Microsoft Authenticator\"\n />\n <span className=\"g2-mfa-totp-download-qrcode-text\">\n Microsoft Authenticator\n </span>\n </div>\n </div>\n </Tabs.TabPane>\n )\n ),\n [downloadConfig, t]\n )\n\n const renderBack = useMemo(() => {\n const onBack = () => backModule?.()\n\n return <BackCustom onBack={onBack}>{t('common.backToMFA')}</BackCustom>\n }, [backModule, t])\n\n return (\n <div className=\"g2-view-container g2-download-authenticator\">\n {renderBack}\n <div className=\"g2-view-tabs g2-mfa-totp-download-tabs\">\n <Tabs defaultActiveKey={DownloadType.IOS}>{renderTab}</Tabs>\n </div>\n </div>\n )\n}\n","import { User } from 'authing-js-sdk'\nimport {\n CompleteInfoBaseControls,\n CompleteInfoExtendsControls,\n CompleteInfoMetaData,\n CompleteInfoRequest,\n CompleteInfoRule,\n ExtendsField,\n} from '../CompleteInfo/interface'\nimport { ApplicationConfig } from '../Type/application'\n\nexport const completeFieldsFilter = (user: User, field: ExtendsField) => {\n if (!user) {\n return true\n }\n const { name } = field\n if (name === 'email' && user?.email) {\n return false\n }\n if (name === 'phone' && user?.phone) {\n return false\n }\n if (name === 'username') {\n if (user[name] === user['phone'] || user[name] === user['email']) {\n return true\n }\n }\n\n // gender 默认是 U\n if (name === 'gender' && user[name] === 'U') {\n return true\n }\n // 如果基础字段里面已经有了,不再要求补全\n if (\n user[name as keyof User] !== undefined &&\n user[name as keyof User] !== null\n ) {\n return false\n }\n // 如果扩展信息又了,不再要求补全\n const customData = user.customData\n if (\n customData &&\n customData[name] !== undefined &&\n customData[name] !== null\n ) {\n return false\n }\n return true\n}\n\nexport const extendsFieldsToMetaData = (\n extendsFields: ApplicationConfig['extendsFields'] = [],\n selectOptions: {\n key: string\n options: {\n value: string\n label: string\n }[]\n }[]\n): CompleteInfoMetaData[] =>\n extendsFields.map((item) => {\n return {\n type: item.inputType as\n | CompleteInfoBaseControls\n | CompleteInfoExtendsControls,\n label: item.label,\n name: item.name,\n required: item.required,\n validateRules: item.validateRules.map<CompleteInfoRule>((rule) => ({\n type: rule.type,\n content: rule.content,\n errorMessage: rule.error,\n })),\n options: selectOptions.find((option) => option.key === item.name)\n ?.options,\n }\n })\n\nexport const fieldValuesToRegisterProfile = (\n extendsFields: ApplicationConfig['extendsFields'],\n fieldValues?: CompleteInfoRequest['fieldValues']\n) => {\n const udf: { key: string; value: string }[] = []\n const registerProfile: Record<string, any> = {}\n\n fieldValues?.forEach(({ name, value, code }) => {\n const fieldType = extendsFields.find((item) => item.name === name)?.type\n\n // 根据字段类型生成不同的数据结构\n if (fieldType === 'internal') {\n if (name === 'phone') registerProfile.phoneToken = code\n\n if (name === 'email') registerProfile.emailToken = code\n\n registerProfile[name] = value\n } else if (fieldType === 'user') {\n udf.push({\n key: name,\n value,\n })\n }\n })\n\n return { registerProfile, udf }\n}\n","import React, { useCallback, useEffect, useMemo, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { ImagePro } from '../ImagePro'\nimport { CompleteInfo } from './core/completeInfo'\nimport {\n CompleteInfoInitData,\n CompleteInfoMetaData,\n CompleteInfoRequest,\n OmitCompleteInfo,\n RegisterCompleteInfoInitData,\n} from './interface'\nimport './styles.less'\nimport { IconFont } from '../IconFont'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport {\n useGuardButtonState,\n useGuardEvents,\n useGuardFinallyConfig,\n useGuardHttpClient,\n useGuardInitData,\n useGuardMultipleInstance,\n useGuardPublicConfig,\n} from '../_utils/context'\nimport {\n authFlow,\n CompleteInfoAuthFlowAction,\n registerRequest,\n} from './businessRequest'\nimport { extendsFieldsToMetaData, fieldValuesToRegisterProfile } from './utils'\nimport { GuardButton } from '../GuardButton'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport const GuardCompleteInfo: React.FC<{\n metaData: CompleteInfoMetaData[]\n skipComplateFileds: boolean\n businessRequest: (\n action: CompleteInfoAuthFlowAction,\n data?: CompleteInfoRequest\n ) => Promise<void>\n}> = ({ metaData, businessRequest, skipComplateFileds }) => {\n useGuardView()\n\n const config = useGuardFinallyConfig()\n\n const { t } = useTranslation()\n\n const { spinChange } = useGuardButtonState()\n\n const [skipLoading, setSkipLoading] = useState(false)\n\n const onSkip = async () => {\n spinChange(true)\n setSkipLoading(true)\n\n await businessRequest(CompleteInfoAuthFlowAction.Skip)\n setSkipLoading(false)\n spinChange(false)\n }\n\n return (\n <div className=\"g2-view-container g2-complete-info\">\n <div className=\"g2-view-header\">\n <div className=\"g2-completeInfo-header\">\n <ImagePro\n src={config?.logo!}\n size={48}\n borderRadius={4}\n alt=\"\"\n className=\"icon\"\n />\n\n {skipComplateFileds && (\n <GuardButton\n className=\"g2-completeInfo-header-skip\"\n type=\"link\"\n loading={skipLoading}\n onClick={() => onSkip()}\n >\n {!skipLoading && (\n <IconFont type=\"authing-a-share-forward-line1\" />\n )}\n <span>{t('common.skip')}</span>\n </GuardButton>\n )}\n </div>\n\n <div className=\"title\">{t('common.perfectUserInfo')}</div>\n <div className=\"title-explain\">\n {t('common.welcomeDoc', { name: config.title })}\n </div>\n </div>\n <div className=\"g2-view-tabs g2-completeInfo-content\">\n <CompleteInfo\n metaData={metaData}\n businessRequest={async (data) =>\n await businessRequest?.(CompleteInfoAuthFlowAction.Complete, data)\n }\n />\n </div>\n </div>\n )\n}\n\nexport const GuardLoginCompleteInfoView: React.FC = () => {\n const { metaData, skip } = useGuardInitData<CompleteInfoInitData>()\n\n const events = useGuardEvents()\n\n const authClient = useGuardAuthClient()\n\n const { instance: multipleInstance } = useGuardMultipleInstance()\n\n const businessRequest = async (\n action: CompleteInfoAuthFlowAction,\n data?: CompleteInfoRequest\n ) => {\n const { isFlowEnd, data: resData, onGuardHandling } = await authFlow(\n action,\n data\n )\n\n // 第一次登录的信息 TODO: 脏逻辑 没时间\n const originAccount = multipleInstance?.getOriginAccount()\n const methods: any =\n multipleInstance?.getOriginWay() === 'password'\n ? multipleInstance?.setLoginWayByHttpData\n : multipleInstance?.setLoginWayByLDAPData\n resData &&\n multipleInstance &&\n originAccount &&\n methods(originAccount, resData)\n\n if (isFlowEnd) {\n events?.onLogin?.(resData, authClient)\n } else {\n onGuardHandling?.()\n }\n }\n\n return (\n <GuardCompleteInfo\n metaData={metaData}\n businessRequest={businessRequest}\n skipComplateFileds={skip}\n />\n )\n}\n\nexport const GuardRegisterCompleteInfoView: React.FC = () => {\n const initData = useGuardInitData<RegisterCompleteInfoInitData>()\n\n const publicConfig = useGuardPublicConfig()\n\n const events = useGuardEvents()\n\n const authClient = useGuardAuthClient()\n\n const { get } = useGuardHttpClient()\n\n const config = useGuardFinallyConfig()\n\n const [selectOptions, setSelectOptions] = useState<\n Array<{\n key: string\n options: {\n value: string\n label: string\n }[]\n }>\n >()\n\n const [metaData, setMetaData] = useState<CompleteInfoMetaData[]>()\n\n // 过滤掉 phone 或者 email\n const extendsFields = useMemo(() => {\n return publicConfig?.extendsFields.filter(\n (field) => field.name !== OmitCompleteInfo[initData.businessRequestName]\n )\n }, [initData.businessRequestName, publicConfig?.extendsFields])\n\n const skipComplateFileds = publicConfig?.skipComplateFileds\n\n const loadingComponent = useMemo(() => {\n return config.loadingComponent\n }, [config.loadingComponent])\n\n const loadSelectOptions = useCallback(async () => {\n const { data: selectOptions } = await get(\n `/api/v2/udfs/field-metadata-for-completion`,\n undefined,\n {}\n )\n\n setSelectOptions(selectOptions)\n }, [get])\n\n const businessRequest = async (\n action: CompleteInfoAuthFlowAction,\n data?: CompleteInfoRequest\n ) => {\n const { registerProfile, udf } = fieldValuesToRegisterProfile(\n extendsFields,\n data?.fieldValues\n )\n const content = {\n ...initData.content,\n params: JSON.stringify(\n JSON.parse(\n initData.content?.params ? initData.content?.params : '[]'\n ).concat(udf)\n ),\n }\n const user: any = await registerRequest(\n action,\n initData.businessRequestName,\n content,\n registerProfile\n )\n if (user.statusCode === 200) {\n initData.onRegisterSuccess(user.data)\n events?.onRegisterInfoCompleted?.(user.data, content, authClient)\n } else {\n user?.onGuardHandling?.()\n const { apiCode, message: errorMessage, data } = user\n initData.onRegisterFailed(apiCode, data, errorMessage)\n events?.onRegisterInfoCompletedError?.(\n {\n code: apiCode,\n message: errorMessage,\n },\n content,\n authClient\n )\n }\n }\n\n useEffect(() => {\n loadSelectOptions()\n }, [loadSelectOptions])\n\n useEffect(() => {\n if (!selectOptions) return\n\n const metaData = extendsFieldsToMetaData(extendsFields, selectOptions)\n\n setMetaData(metaData)\n }, [extendsFields, selectOptions])\n\n return (\n <>\n {!metaData ? (\n loadingComponent\n ) : (\n <GuardCompleteInfo\n metaData={metaData}\n skipComplateFileds={skipComplateFileds}\n businessRequest={businessRequest}\n />\n )}\n </>\n )\n}\n","import React, { useCallback, useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { Form, message } from 'antd'\n// import { useGuardAuthClient } from '../../Guard/authClient'\nimport { fieldRequiredRule, validate } from '../../_utils'\nimport SubmitButton from '../../SubmitButton'\n\nimport { IconFont } from '../../IconFont'\n\nimport { SceneType } from 'authing-js-sdk'\nimport { SendCodeByEmail } from '../../SendCode/SendCodeByEmail'\nimport { SendCodeByPhone } from '../../SendCode/SendCodeByPhone'\nimport { FormItemIdentify } from '../../Login/core/withVerifyCode/FormItemIdentify'\nimport { InputIdentify } from './inputIdentify'\nimport { parsePhone, useMediaSize } from '../../_utils/hooks'\nimport { EmailScene } from '../../Type'\n\nimport { getGuardHttp } from '../../_utils/guardHttp'\n\n// import { useGuardEvents, useGuardPublicConfig } from '../../_utils/context'\nexport enum InputMethodMap {\n email = 'email-code',\n phone = 'phone-code',\n}\ninterface ResetPasswordProps {\n // onReset: any\n publicConfig: any\n setControlShow: any\n setPolicyStrength: any\n setCustomPasswordStrength: any\n setPhoneOrEmailText: any\n // onSend: (type: 'email' | 'phone') => void\n // onSendError: (type: 'email' | 'phone', error: any) => void\n setResetToken: React.Dispatch<React.SetStateAction<string>>\n}\nexport const ResetPassword = (props: ResetPasswordProps) => {\n const { t } = useTranslation()\n let [form] = Form.useForm()\n let [identify, setIdentify] = useState('')\n let [codeMethod, setCodeMethod] = useState<'phone' | 'email'>('phone')\n let submitButtonRef = useRef<any>(null)\n const { isPhoneMedia } = useMediaSize()\n const { post } = getGuardHttp()\n // let authClient = useGuardAuthClient()\n // const events = useGuardEvents()\n // const { publicKey } = useGuardPublicConfig()\n const verifyCodeLength = props.publicConfig.verifyCodeLength ?? 4\n // 是否开启了国际化短信功能\n const isInternationSms =\n props.publicConfig.internationalSmsConfig?.enabled || false\n // const {\n // // getPassWordUnsafeText,\n // setPasswordErrorTextShow,\n // } = usePasswordErrorText()\n const onFinish = async (values: any) => {\n // 校验手机号和验证码\n let identify = values.identify\n let code = values.code\n // let identify = form.getFieldsValue().identify\n // let code = form.getFieldsValue().code\n // let tempPassword = values.password\n let context = new Promise(() => {})\n // const newPassword = await authClient.options?.encryptFunction?.(\n // tempPassword,\n // publicKey\n // )\n if (codeMethod === 'email') {\n context = post(\n '/api/v2/users/password/forget/check-code',\n {\n email: identify,\n code,\n // newPassword,\n }\n // config\n )\n // context = client.resetPasswordByEmailCode(identify, code, newPassword)\n }\n if (codeMethod === 'phone') {\n const { phoneNumber: phone, countryCode: phoneCountryCode } = parsePhone(\n isInternationSms,\n identify\n )\n context = post('/api/v2/users/password/forget/check-code', {\n phone,\n code,\n // newPassword,\n phoneCountryCode,\n })\n // context = client.resetPasswordByPhoneCode(\n // phoneNumber,\n // code,\n // newPassword,\n // countryCode\n // )\n }\n\n context\n .then((r: any) => {\n const { code } = r\n if (code !== 200) {\n message.error(r?.message)\n return\n }\n const passwordStrength = r?.data.passwordStrength\n let customPasswordStrength = {}\n if (r?.data?.customPasswordStrength?.enabled) {\n customPasswordStrength = r?.data?.customPasswordStrength\n }\n // if (code === ApiCode.UNSAFE_PASSWORD_TIP) {\n // setPasswordErrorTextShow(true)\n // }\n // props.onSend(codeMethod)\n // props.onReset(r)\n if (code === 200) {\n props.setPhoneOrEmailText(identify)\n props.setPolicyStrength(passwordStrength)\n if (r?.data?.customPasswordStrength?.enabled) {\n props.setCustomPasswordStrength(customPasswordStrength)\n }\n props.setControlShow(false)\n props.setResetToken(r?.data?.resetPasswordToken)\n }\n })\n .catch((e) => {\n // submitButtonRef.current.onError()\n // props.onSendError(codeMethod, e)\n message.error(e.message)\n return\n // props.onReset(e)\n })\n }\n\n const SendCode = useCallback(\n (props: any) => {\n return (\n <>\n {codeMethod === 'phone' && (\n <SendCodeByPhone\n {...props}\n isInternationSms={isInternationSms}\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('login.resetPassword.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n prefix={\n <IconFont\n type=\"authing-a-shield-check-line1\"\n style={{ color: '#878A95' }}\n />\n }\n scene={SceneType.SCENE_TYPE_RESET}\n maxLength={verifyCodeLength}\n data={identify}\n onSendCodeBefore={async () => {\n await form.validateFields(['identify'])\n }}\n />\n )}\n {codeMethod === 'email' && (\n <SendCodeByEmail\n {...props}\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('login.resetPassword.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n prefix={\n <IconFont\n type=\"authing-a-shield-check-line1\"\n style={{ color: '#878A95' }}\n />\n }\n scene={EmailScene.RESET_PASSWORD_VERIFY_CODE}\n maxLength={verifyCodeLength}\n data={identify}\n onSendCodeBefore={async () => {\n await form.validateFields(['identify'])\n }}\n />\n )}\n </>\n )\n },\n [codeMethod, form, identify, isInternationSms, t, verifyCodeLength]\n )\n\n return (\n // .map((item, index) => (index === 0 ? `「${item}」` : item))\n\n <div className=\"authing-g2-login-phone-code\">\n <Form\n name=\"rePassword\"\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => {\n submitButtonRef?.current?.onError()\n }}\n autoComplete=\"off\"\n >\n <FormItemIdentify\n name=\"identify\"\n className=\"authing-g2-input-form\"\n methods={['email-code', 'phone-code']}\n currentMethod={InputMethodMap[codeMethod]}\n checkExist={true}\n >\n <InputIdentify\n methods={['email-code', 'phone-code']}\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n autoFocus={!isPhoneMedia}\n size=\"large\"\n value={identify}\n onChange={(e) => {\n let v = e.target.value\n setIdentify(v)\n if (validate('email', v)) {\n setCodeMethod('email')\n } else {\n setCodeMethod('phone')\n }\n }}\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </FormItemIdentify>\n\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form-sendCode\"\n name=\"code\"\n rules={[...fieldRequiredRule(t('common.captchaCode'))]}\n >\n <SendCode />\n </Form.Item>\n {/* <CustomFormItem.Password\n className=\"authing-g2-input-form\"\n name=\"password\"\n >\n <InputPassword\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('user.inputNewPwd')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </CustomFormItem.Password> */}\n {/* // 这个密码记得加上 */}\n {/* {getPassWordUnsafeText()} */}\n <Form.Item className=\"authing-g2-sumbit-form submit-form\">\n <SubmitButton\n className=\"validater-account-btn\"\n text={t('login.resetPassword.nextStep')}\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n","import React, { useMemo } from 'react'\nimport { ErrorInitData } from './interface'\nimport { i18n } from '../_utils/locales'\nimport './styles.less'\nimport { useGuardInitData } from '../_utils/context'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport interface ErrorProps {\n error?: Error\n}\n\nexport const GuardErrorView: React.FC<ErrorProps> = (propsInitData) => {\n const guardXInitData = useGuardInitData<ErrorInitData>()\n\n useGuardView()\n\n const messages = useMemo(() => {\n const error = propsInitData?.error ?? guardXInitData?.error\n\n return `${error?.message}` ?? `${i18n.t('user.contactAdministrator')}`\n }, [guardXInitData?.error, propsInitData?.error])\n\n return (\n <div className=\"g2-view-container g2-view-error\">\n <div className=\"g2-error-content\">\n <div style={{ display: 'flex', justifyContent: 'center' }}>\n <div\n style={{\n width: 240,\n height: 160,\n backgroundImage:\n 'url(https://authing-files.oss-cn-zhangjiakou.aliyuncs.com/authing-guard/authing_error.svg)',\n backgroundSize: 'contain',\n }}\n />\n </div>\n <div className=\"g2-error-message\">{i18n.t('user.error')}</div>\n <span\n className=\"g2-error-message-text\"\n dangerouslySetInnerHTML={{ __html: messages }}\n />\n </div>\n </div>\n )\n}\n","import { FormItemProps, Rule } from 'antd/lib/form'\nimport FormItem from 'antd/lib/form/FormItem'\nimport React, { useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport CustomFormItem from '../../../ValidatorRules'\nimport { fieldRequiredRule, VALIDATE_PATTERN } from '../../../_utils'\nimport { phone } from 'phone'\nimport {\n useGuardHttpClient,\n useGuardPhoneRegex,\n useGuardPublicConfig,\n} from '../../../_utils/context'\nimport { useCheckRepeat } from '../../../ValidatorRules/useCheckRepeat'\nimport { parsePhone } from '../../../_utils/hooks'\nimport { VerifyLoginMethods } from '../../../Type/application'\nexport interface FormItemIdentifyProps extends FormItemProps {\n checkRepeat?: boolean // 重复性校验\n checkExist?: boolean //存在性校验\n methods: VerifyLoginMethods[]\n currentMethod: 'phone-code' | 'email-code' //当前 input 输入\n areaCode?: string //国际化手机号区号\n}\n\nconst FindMethodConversion = {\n 'phone-code': 'phone',\n 'email-code': 'email',\n}\n\nexport const FormItemIdentify: React.FC<FormItemIdentifyProps> = (props) => {\n const {\n methods,\n areaCode = 'CN',\n currentMethod,\n checkRepeat,\n checkExist,\n ...formItemProps\n } = props\n const publicConfig = useGuardPublicConfig()\n const { t } = useTranslation()\n\n const { get } = useGuardHttpClient()\n\n const phoneRegex = useGuardPhoneRegex()\n\n const checkInternationalSms =\n publicConfig.internationalSmsConfig?.enabled &&\n currentMethod === 'phone-code'\n\n const methodContent = useMemo(() => {\n if (currentMethod === 'email-code')\n return {\n field: t('common.emailLabel'),\n checkRepeatErrorMessage: t('common.checkEmail'),\n checkExistErrorMessage: t('common.noFindEmail'),\n formatErrorMessage: t('login.inputCorrectPhone'),\n pattern: VALIDATE_PATTERN.email,\n }\n else\n return {\n field: t('common.phone'),\n checkRepeatErrorMessage: t('common.checkPhone'),\n checkExistErrorMessage: t('common.noFindPhone'),\n formatErrorMessage: t('login.inputCorrectPhone'),\n pattern: phoneRegex || VALIDATE_PATTERN.phone,\n }\n }, [currentMethod, phoneRegex, t])\n\n const checkRepeatRet = (\n value: any,\n resolve: (value: unknown) => void,\n reject: (reason?: any) => void\n ) => {\n let checkValue = value\n if (currentMethod === 'phone-code' && checkInternationalSms) {\n const { phoneNumber } = parsePhone(\n checkInternationalSms,\n checkValue,\n areaCode\n )\n checkValue = phoneNumber\n }\n get<boolean>(`/api/v2/users/find`, {\n userPoolId: publicConfig?.userPoolId,\n key: checkValue,\n type: FindMethodConversion[currentMethod],\n }).then(({ data }) => {\n if (checkExist) {\n Boolean(data)\n ? resolve(true)\n : reject(methodContent.checkExistErrorMessage)\n }\n if (checkRepeat) {\n Boolean(data)\n ? reject(methodContent.checkRepeatErrorMessage)\n : resolve(true)\n }\n })\n }\n\n const checkRepeatFn = useCheckRepeat(checkRepeatRet)\n\n const formatRules = useMemo<Rule>(() => {\n if (checkInternationalSms) {\n return {\n validateTrigger: 'onBlur',\n validator: async (_, value) => {\n if (\n !value ||\n phone(value, { country: areaCode }).isValid ||\n phone(value).isValid\n )\n return Promise.resolve()\n return Promise.reject(t('common.i18nCheckErrorMessage'))\n },\n }\n }\n\n return {\n validateTrigger: 'onBlur',\n pattern: methodContent.pattern,\n message: methodContent.formatErrorMessage,\n }\n }, [\n areaCode,\n checkInternationalSms,\n methodContent.formatErrorMessage,\n methodContent.pattern,\n t,\n ])\n\n const rules = useMemo<Rule[]>(() => {\n // 如果不是必填就不校验\n\n // 必填项的默认校验规则\n const rules = [...fieldRequiredRule(t('common.phoneOrEmail'))]\n\n // 格式校验\n rules.push(formatRules)\n\n // 是否校验重复\n if (checkRepeat || checkExist) {\n rules.push({\n validator: checkRepeatFn,\n validateTrigger: [],\n })\n }\n\n return rules\n }, [t, formatRules, checkRepeat, checkExist, checkRepeatFn])\n // TODO 未来抽离\n const renderTemplate = useMemo(() => {\n if (methods.length !== 1)\n return (\n <FormItem\n validateTrigger={['onBlur', 'onChange']}\n validateFirst={true}\n rules={rules}\n {...formItemProps}\n />\n )\n\n switch (currentMethod) {\n case 'phone-code':\n return (\n <CustomFormItem.Phone\n {...formItemProps}\n areaCode={areaCode}\n checkRepeat={checkRepeat}\n checkExist={checkExist}\n />\n )\n case 'email-code':\n return (\n <CustomFormItem.Email\n {...formItemProps}\n checkRepeat={checkRepeat}\n checkExist={checkExist}\n />\n )\n }\n }, [\n areaCode,\n checkExist,\n checkRepeat,\n currentMethod,\n formItemProps,\n methods.length,\n rules,\n ])\n\n return <>{renderTemplate}</>\n}\n","import Input, { InputProps } from 'antd/lib/input'\nimport React, { useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport { IconFont } from '../../IconFont'\nimport { InputNumber } from '../../InputNumber'\nimport { VerifyLoginMethods } from '../../Type/application'\nimport { useGuardPublicConfig } from '../../_utils/context'\n\nexport interface InputIdentifyProps extends InputProps {\n methods: VerifyLoginMethods[]\n}\n\nexport const InputIdentify: React.FC<InputIdentifyProps> = (props) => {\n const { methods, ...inputProps } = props\n\n const publicConfig = useGuardPublicConfig()\n\n const { t } = useTranslation()\n\n const verifyCodeMethodsText = useMemo<\n Record<\n VerifyLoginMethods,\n {\n t: string\n sort: number\n }\n >\n >(\n () => ({\n 'email-code': {\n t: t('common.email'),\n sort: 2,\n },\n 'phone-code': {\n t: publicConfig?.internationalSmsConfig?.enabled\n ? t('common.areaCodePhone')\n : t('common.phoneNumber'),\n sort: 1,\n },\n }),\n [publicConfig, t]\n )\n\n const placeholder = useMemo(() => {\n if (publicConfig?.internationalSmsConfig?.enabled) {\n return t('login.inputAccount', {\n text: methods\n ?.map((item) => verifyCodeMethodsText[item])\n .sort((a, b) => a.sort - b.sort)\n .map((item) => item.t)\n .map((item, index) => (index === 0 ? `「${item}」` : item))\n .join(' / '),\n })\n } else {\n return t('login.inputAccount', {\n text: methods\n ?.map((item) => verifyCodeMethodsText[item])\n .sort((a, b) => a.sort - b.sort)\n .map((item) => item.t)\n .join(' / '),\n })\n }\n }, [\n methods,\n t,\n verifyCodeMethodsText,\n publicConfig?.internationalSmsConfig?.enabled,\n ])\n\n const renderInput = useMemo(() => {\n if (methods.length === 1 && methods[0] === 'phone-code') {\n // TODO 开启国际化配置并登录方式为手机号码时\n return (\n <InputNumber maxLength={11} placeholder={placeholder} {...inputProps} />\n )\n }\n\n return (\n <Input\n maxLength={50} // 手机号限长 20 字符,多种组合是 50 字符\n placeholder={placeholder}\n {...inputProps}\n prefix={\n <IconFont type=\"authing-a-user-line1\" style={{ color: '#878A95' }} />\n }\n />\n )\n }, [inputProps, methods, placeholder])\n\n return <>{renderInput}</>\n}\n","import { Input } from 'antd'\nimport { PasswordProps } from 'antd/lib/input'\nimport React from 'react'\nimport { IconFont } from '../../IconFont'\nexport const InputPasswordForget = React.forwardRef<\n React.RefObject<Input>,\n PasswordProps\n>((props, ref) => {\n return (\n <Input.Password\n autoComplete=\"off\"\n ref={ref}\n {...props}\n iconRender={(visible) => (\n <span style={{ display: 'flex', height: '100%', alignItems: 'center' }}>\n {visible ? (\n <IconFont\n type=\"authing-authing-eye-fill\"\n style={{ color: '#4E5969' }}\n />\n ) : (\n <IconFont\n type=\"authing-authing-eye-off-fill\"\n style={{ color: '#A9AEB8' }}\n />\n )}\n </span>\n )}\n maxLength={35}\n />\n )\n})\n","import React, { useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { Form, message } from 'antd'\n\nimport { GuardModuleType } from '../Guard/module'\nimport { ResetPassword } from './core/resetPassword'\n\nimport { ImagePro } from '../ImagePro'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport {\n useGuardEvents,\n useGuardFinallyConfig,\n useGuardModule,\n useGuardPublicConfig,\n} from '../_utils/context'\nimport { InputPasswordForget } from './InputPassword/index'\nimport { IconFont } from '../IconFont'\nimport SubmitButton from '../SubmitButton'\nimport { getGuardHttp } from '../_utils/guardHttp'\n// import axios, { Axios } from 'axios'\nimport {\n // getPasswordValidate,\n getPasswordValidateRules,\n PasswordStrength,\n} from '../_utils'\nimport { usePasswordErrorText } from '../_utils/useErrorText'\nimport { ApiCode } from '../_utils/responseManagement/interface'\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n// import './styles.less'\n// let passwordTimer: any = null\nexport const GuardForgetPassword: React.FC = () => {\n const { t } = useTranslation()\n\n const events = useGuardEvents()\n\n const publicConfig = useGuardPublicConfig()\n\n const authClient = useGuardAuthClient()\n\n const config = useGuardFinallyConfig()\n\n useGuardView()\n\n const { changeModule } = useGuardModule()\n const [controlShow, setControlShow] = useState(true)\n const [policyStrength, setPolicyStrength] = useState(0)\n const [customPasswordStrength, setCustomPasswordStrength] = useState({})\n const [phoneOrEmailText, setPhoneOrEmailText] = useState('')\n const {\n getPassWordUnsafeText,\n setPasswordErrorTextShow,\n } = usePasswordErrorText()\n\n // 忘记密码的 token,在第二步重置密码时传给后端\n const [resetToken, setResetToken] = useState('')\n\n /**\n * 「返回」的回调函数,goBack 是 null 的时候就隐藏「第一步的返回按钮、最后提交成功后的返回和自动跳转」\n * goBack 不等于 null 时,如果传入就使用传入的,不然就默认跳转到 登录模块\n */\n const needBack = config?.goBack !== null\n const goBack = config?.goBack ?? (() => changeModule?.(GuardModuleType.LOGIN))\n\n let [form] = Form.useForm()\n const { post } = getGuardHttp()\n let submitBtnRef = useRef<any>(null)\n const onFinish = async () => {\n // 重置密码\n let data = form.getFieldsValue()\n const newPassword = await authClient.options?.encryptFunction?.(\n data.password,\n publicConfig.publicKey\n )\n const repeatPassword = await authClient.options?.encryptFunction?.(\n data.repeatPassword,\n publicConfig.publicKey\n )\n let res = post('/api/v2/users/password/password-reset', {\n newPassword,\n repeatPassword,\n // ...phoneOrEmail, // 不用传 phone 和 email 了\n resetPasswordToken: resetToken,\n })\n\n res\n .then((r: any) => {\n const { code } = r\n if (code === ApiCode.UNSAFE_PASSWORD_TIP) {\n setPasswordErrorTextShow(true)\n }\n if (code !== 200) {\n events?.onPwdResetError?.(r, authClient)\n message.error(r?.message)\n return\n }\n events?.onPwdReset?.(authClient)\n // 返回登录\n const initData = {\n title: t('common.resetSuccess'),\n message: t('common.resetSuccessMessage'),\n needBack,\n goBack,\n }\n changeModule?.(GuardModuleType.New_SUBMIT_SUCCESS, {\n ...initData,\n })\n // props.onSend(codeMethod)\n })\n .catch((e) => {\n submitBtnRef.current.onError()\n // props.onSendError(codeMethod, e)\n events?.onPwdResetError?.(e, authClient)\n message.error(e.message)\n return\n })\n }\n const rules = () => {\n let passwordStrength = [\n PasswordStrength.NoCheck,\n PasswordStrength.Low,\n PasswordStrength.Middle,\n PasswordStrength.High,\n PasswordStrength.AUTO,\n ]\n let rule = getPasswordValidateRules(\n passwordStrength[policyStrength],\n customPasswordStrength,\n 'onChange',\n t('login.resetPassword.pleaseInputPassword')\n )\n return rule\n }\n // const onSend = (type: 'phone' | 'email') => {\n // if (type === 'phone') events?.onPwdPhoneSend?.(authClient)\n // if (type === 'email') events?.onPwdEmailSend?.(authClient)\n // }\n // const onSendError = (type: 'phone' | 'email', error: any) => {\n // if (type === 'phone')\n // events?.onPwdPhoneSendError?.(error as CommonMessage, authClient)\n // if (type === 'email')\n // events?.onPwdEmailSendError?.(error as CommonMessage, authClient)\n // }\n\n return controlShow ? (\n <div className=\"g2-view-container g2-forget-password g2-password-reset-pageWrap g2-password-reset-step1\">\n <div className=\"g2-view-header\">\n <ImagePro\n src={config?.logo!}\n size={48}\n borderRadius={4}\n alt=\"\"\n className=\"icon\"\n />\n <div className=\"title\">{t('login.resetPwd')}</div>\n <div className=\"title-explain\">\n {t('login.resetPassword.resetPasswordText1')}\n </div>\n </div>\n <div className=\"g2-view-tabs\">\n <ResetPassword\n // onReset={onReset}\n publicConfig={publicConfig}\n setControlShow={setControlShow}\n setPolicyStrength={setPolicyStrength}\n setCustomPasswordStrength={setCustomPasswordStrength}\n setPhoneOrEmailText={setPhoneOrEmailText}\n setResetToken={setResetToken}\n />\n </div>\n {needBack && (\n <div className=\"g2-tips-line\">\n <div className=\"link-like back-to-login\" onClick={goBack}>\n {t('login.resetPassword.back')}\n </div>\n </div>\n )}\n {/* <ChangeLanguage langRange={langRange} onLangChange={props.onLangChange} /> */}\n </div>\n ) : (\n <div className=\"g2-view-container g2-forget-password g2-password-reset-pageWrap g2-password-reset-step2\">\n <div className=\"g2-view-header\">\n <ImagePro\n src={config?.logo!}\n size={48}\n borderRadius={4}\n alt=\"\"\n className=\"icon\"\n />\n <div className=\"title\">{t('login.resetPwd')}</div>\n <div className=\"title-explain\">\n {t('login.resetPassword.resetPasswordText2', {\n account: phoneOrEmailText,\n })}\n </div>\n </div>\n <div className=\"g2-view-tabs\">\n <Form\n name=\"resetPassword\"\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => {\n submitBtnRef?.current?.onError()\n }}\n autoComplete=\"off\"\n >\n <Form.Item\n className=\"authing-g2-input-form-password\"\n name=\"password\"\n rules={\n // {\n // required: true,\n // message: t('login.resetPassword.pleaseInputPassword'),\n // },\n rules()\n }\n >\n <InputPasswordForget\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.resetPassword.inputNewPwd')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95', marginBottom: 2 }}\n />\n }\n />\n </Form.Item>\n <Form.Item\n className=\"authing-g2-input-form-password-repeat\"\n name=\"repeatPassword\"\n validateFirst={true}\n rules={[\n {\n required: true,\n message: t('login.resetPassword.pleaseInputPassword'),\n },\n ({ getFieldValue }) => ({\n validator: (_, value) => {\n let password = getFieldValue('password')\n if (password === undefined && value === undefined) {\n return Promise.resolve()\n }\n if (password === value) {\n return Promise.resolve()\n } else {\n return Promise.reject(\n t('login.resetPassword.checkPasswordDiff')\n )\n }\n },\n }),\n ]}\n >\n <InputPasswordForget\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.resetPassword.confirmNewPwd')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95', marginBottom: 2 }}\n />\n }\n // suffix={<div>111</div>}\n />\n </Form.Item>\n {getPassWordUnsafeText()}\n <Form.Item className=\"authing-g2-sumbit-form submit-form\">\n <SubmitButton\n className=\"reset-password-button\"\n text={t('login.resetPassword.reset')}\n ref={submitBtnRef}\n />\n </Form.Item>\n </Form>\n </div>\n <div className=\"g2-tips-line\">\n <div\n className=\"link-like back-to-login\"\n onClick={() => setControlShow(true)}\n >\n {t('login.resetPassword.back')}\n </div>\n </div>\n </div>\n )\n}\n","import { FormItemProps } from 'antd/lib/form'\nimport FormItem from 'antd/lib/form/FormItem'\nimport React, { useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport CustomFormItem from '../../../ValidatorRules'\nimport { fieldRequiredRule } from '../../../_utils'\n\nexport interface FormItemAccountProps extends FormItemProps {\n validPasswordLoginMethods: string[]\n}\n\nexport const FormItemAccount: React.FC<FormItemAccountProps> = (props) => {\n const { validPasswordLoginMethods, ...formItemPtops } = props\n const { t } = useTranslation()\n\n const runderTemplate = useMemo(() => {\n if (validPasswordLoginMethods.length !== 1)\n return (\n <FormItem\n validateTrigger={['onBlur', 'onChange']}\n rules={fieldRequiredRule(t('common.account'))}\n {...formItemPtops}\n />\n )\n\n switch (validPasswordLoginMethods[0]) {\n case 'phone-password':\n return (\n <CustomFormItem.Phone {...formItemPtops} isCheckPattern={false} />\n )\n case 'email-password':\n return <CustomFormItem.Email {...formItemPtops} />\n }\n\n return <CustomFormItem.UserName {...formItemPtops} />\n }, [formItemPtops, validPasswordLoginMethods, t])\n\n return <>{runderTemplate}</>\n}\n","import Input, { InputProps } from 'antd/lib/input'\nimport React, { useMemo } from 'react'\nimport { InputNumber } from '../../../InputNumber'\n\nexport interface InputAccountProps extends InputProps {\n passwordLoginMethods: string[]\n placeholder: string\n}\n\nexport const InputAccount: React.FC<InputAccountProps> = (props) => {\n const { passwordLoginMethods: methods, placeholder, ...inputProps } = props\n\n const runderInput = useMemo(() => {\n if (methods.length === 1 && methods[0] === 'phone-password')\n return (\n <InputNumber maxLength={20} placeholder={placeholder} {...inputProps} />\n )\n\n return <Input placeholder={placeholder} {...inputProps} />\n }, [inputProps, methods, placeholder])\n\n return <>{runderInput}</>\n}\n","import Input, { InputProps } from 'antd/lib/input'\nimport React from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { ImagePro2 } from '../../../ImagePro'\n\nexport interface GraphicVerifyCodeProps extends InputProps {\n verifyCodeUrl: string\n changeCode: () => void\n}\n\nexport const GraphicVerifyCode: React.FC<GraphicVerifyCodeProps> = (props) => {\n const { verifyCodeUrl, changeCode, ...inputProps } = props\n\n const { t } = useTranslation()\n\n return (\n <div className=\"g2-graphic-verify-code\">\n <Input {...inputProps} />\n\n <ImagePro2\n className=\"g2-captcha-code-image\"\n src={verifyCodeUrl}\n alt={t('login.captchaCode')}\n height=\"46px\"\n width=\"134px\" // 为了第一次加载图片,和后面刷新(或者显示时)宽度一致,免得宽度会变化,从100到134\n style={{ cursor: 'pointer' }}\n onClick={() => changeCode()}\n />\n </div>\n )\n}\n","import React, { FC, useState, useMemo, useEffect } from 'react'\nimport { Space, Checkbox } from 'antd'\nimport './style.less'\nimport { getClassnames } from '../../../_utils'\nimport { Agreement } from '../../../Type/application'\nimport { useAgreements } from '../../../Guard/core/hooks/useAgreements'\n\nexport interface AgreementsProps {\n value?: boolean\n onChange?: (value: boolean) => void\n style?: React.CSSProperties\n agreements: Agreement[]\n showError?: boolean\n}\n\nexport const Agreements: FC<AgreementsProps> = ({\n showError,\n onChange = () => {},\n style,\n agreements,\n}) => {\n const [acceptList, setAcceptList] = useState<(string | number)[]>([])\n\n const toggleItemCheck = (id: string | number) => {\n setAcceptList((prev) => {\n if (prev.includes(id)) {\n return prev.filter((item) => item !== id)\n }\n return [...prev, id]\n })\n }\n\n useAgreements({\n agreements,\n checkedAgreements: acceptList,\n checkAllAgreements() {\n const acceptList = agreements.map((agreement) => {\n return agreement.id\n })\n setAcceptList(acceptList)\n },\n unCheckAllAgreements() {\n setAcceptList([])\n },\n })\n\n /** 是否可以注册 */\n const isAccept = useMemo(() => {\n /** 所有必须勾选的都勾了就可以通过 */\n return agreements\n .filter((item) => item.required)\n .every((item) => acceptList.includes(item.id))\n }, [acceptList, agreements])\n\n useEffect(() => {\n onChange(isAccept)\n }, [isAccept, onChange])\n\n return (\n <div\n className={getClassnames([\n 'authing-agreements',\n showError && 'authing-agreements-error',\n ])}\n >\n {agreements.map((item) => {\n return (\n <div\n key={item.id}\n style={{ ...style }}\n className={getClassnames([\n 'authing-agreements-item',\n item.required &&\n !acceptList.includes(item.id) &&\n 'authing-agreements-item-invalid',\n ])}\n onClick={(e: any) => {\n e.persist()\n if (e.target.nodeName !== 'A') {\n toggleItemCheck(item.id)\n }\n }}\n >\n <Space align=\"start\" size={5}>\n <Checkbox\n className=\"authing-agreements-checkbox\"\n checked={acceptList.includes(item.id)}\n />\n <div\n className=\"authing-agreements-item-content\"\n dangerouslySetInnerHTML={{\n __html: item.title,\n }}\n ></div>\n </Space>\n </div>\n )\n })}\n </div>\n )\n}\n","import { useEffect } from 'react'\n\nimport { Agreement } from '../../../Type'\n\ninterface Options {\n agreements: Agreement[]\n checkedAgreements: (string | number)[]\n checkAllAgreements: () => void\n unCheckAllAgreements: () => void\n}\n\nexport function useAgreements(options: Options) {\n const {\n agreements,\n checkedAgreements,\n checkAllAgreements,\n unCheckAllAgreements,\n } = options\n\n const agreementsContext = {\n agreements,\n checkedAgreements,\n checkAllAgreements,\n unCheckAllAgreements,\n }\n\n useEffect(() => {\n window.$$guard = Object.assign({}, window.$$guard, {\n agreementsContext,\n })\n }, [agreements, checkedAgreements])\n\n return agreementsContext\n}\n","/* eslint-disable prettier/prettier */\nimport { FormInstance } from 'antd/lib/form'\nimport { useEffect, useCallback, useRef, useLayoutEffect } from 'react'\nimport {\n BackFillMultipleState,\n LoginWay,\n} from '../../Guard/core/hooks/useMultipleAccounts'\nimport { useGuardMultipleInstance } from '../../_utils/context'\n\n/**\n * 多账号登录下 账户 & 登录方式自动回填\n * TODO: HOOK 参数有时间整理成为对象,开始没有想到有这么多\n * 调用地方 core 中需要回填的两个登录方式\n */\nfunction useLoginMultipleBackFill(options: {\n form: FormInstance<any>\n way: LoginWay\n formKey: string\n backfillData?: BackFillMultipleState\n isOnlyInternationSms?: boolean\n setAreaCode?: React.Dispatch<React.SetStateAction<string>>\n cancelBackfill?: boolean\n changeCurrentMethod?: (account: string) => void\n}) {\n const {\n form,\n way,\n formKey,\n backfillData,\n isOnlyInternationSms,\n setAreaCode,\n cancelBackfill,\n changeCurrentMethod,\n } = options\n // 获得格式化后的回填 account,如果是国际化选择框,还需要改变对应选项\n const parseFillData = useCallback(() => {\n const prefix = isOnlyInternationSms\n ? ''\n : backfillData?.phoneCountryCode\n ? backfillData?.phoneCountryCode + ` `\n : ''\n\n const content = backfillData?.account || ''\n\n const account = prefix + content\n\n return {\n account,\n areaCode: backfillData?.areaCode,\n }\n }, [isOnlyInternationSms, backfillData])\n\n // initData 如果存在值表示已经回填过了\n useEffect(() => {\n const matchLoginWay = backfillData?.way === way\n if (backfillData && matchLoginWay && !cancelBackfill) {\n const { account, areaCode } = parseFillData()\n areaCode && setAreaCode?.(areaCode)\n changeCurrentMethod?.(account)\n form.setFieldsValue({\n [formKey]: account,\n })\n }\n }, [\n backfillData,\n cancelBackfill,\n form,\n formKey,\n way,\n setAreaCode,\n parseFillData,\n changeCurrentMethod,\n ])\n}\n\n/**\n * 多账号统一状态管理\n * @param setLoginWay\n * @returns\n */\nfunction useLoginMultiple(setLoginWay: React.Dispatch<any>) {\n const multipleQrWay = useRef<string>()\n // 多账号实例\n const {\n instance: multipleInstance,\n referMultipleState,\n isMultipleAccount,\n multipleAccountData: backfillData,\n } = useGuardMultipleInstance()\n\n const onBackFillData = useCallback(\n (data: BackFillMultipleState) => {\n const { way, qrCodeId } = data\n const qrCodeDefaultTab = qrCodeId ? way + qrCodeId : way\n multipleQrWay.current = qrCodeDefaultTab\n setLoginWay(way)\n },\n [setLoginWay]\n )\n\n // 没办法了 TODO: 我真的是没办法了... 只有Default方式去硬逻辑加载\n if (backfillData?.qrCodeId) {\n multipleQrWay.current = backfillData.way + backfillData?.qrCodeId\n }\n\n useLayoutEffect(() => {\n // 非多账号登录页面 并且存在返回值\n if (!isMultipleAccount && backfillData) {\n onBackFillData(backfillData)\n }\n }, [isMultipleAccount, backfillData, onBackFillData])\n\n return {\n isMultipleAccount,\n multipleInstance,\n referMultipleState,\n backfillData,\n defaultQrWay: multipleQrWay.current,\n }\n}\n\nexport { useLoginMultipleBackFill, useLoginMultiple }\n","export const getCaptchaUrl = (host: string) => {\n const url = new URL(host)\n url.pathname = '/api/v2/security/captcha'\n url.search = `?r=${+new Date()}`\n return url.href\n}\n","import React, { useCallback, useEffect, useMemo, useRef, useState } from 'react'\nimport { Form } from 'antd'\nimport { useTranslation } from 'react-i18next'\nimport { useGuardHttp } from '../../../_utils/guardHttp'\nimport { useGuardAuthClient } from '../../../Guard/authClient'\nimport {\n fieldRequiredRule,\n getSortLabels,\n getUserRegisterParams,\n} from '../../../_utils'\nimport { ErrorCode } from '../../../_utils/GuardErrorCode'\nimport SubmitButton from '../../../SubmitButton'\nimport { FormItemAccount } from './FormItemAccount'\nimport { InputAccount } from './InputAccount'\nimport { GraphicVerifyCode } from './GraphicVerifyCode'\nimport { IconFont } from '../../../IconFont'\nimport { InputPassword } from '../../../InputPassword'\nimport { Agreements } from '../../../Register/components/Agreements'\nimport { AuthingGuardResponse, AuthingResponse } from '../../../_utils/http'\nimport { CodeAction } from '../../../_utils/responseManagement/interface'\nimport { useMediaSize } from '../../../_utils/hooks'\nimport {\n useGuardDefaultLanguage,\n useGuardFinallyConfig,\n useGuardInitData,\n useGuardPublicConfig,\n useRobotVerify,\n} from '../../../_utils/context'\nimport { GuardLoginInitData } from '../../interface'\nimport {\n Agreement,\n LoginMethods,\n TabFieldsI18nItem,\n RegisterMethods,\n} from '../../../Type/application'\nimport {\n BackFillMultipleState,\n StoreInstance,\n} from '../../../Guard/core/hooks/useMultipleAccounts'\nimport { useForm } from 'antd/lib/form/Form'\nimport { useLoginMultipleBackFill } from '../../hooks/useLoginMultiple'\nimport { getCaptchaUrl } from '../../../_utils/getCaptchaUrl'\ninterface LoginWithPasswordProps {\n // configs\n publicKey: string\n autoRegister?: boolean\n host?: string\n\n // events\n // onLogin: any\n onBeforeLogin?: any\n onLoginSuccess?: any\n onLoginFailed?: any\n // 越过 login 正常的请求,返回一个 res\n onLoginRequest?: (loginInfo: any) => Promise<AuthingResponse>\n passwordLoginMethods: string[]\n\n agreements: Agreement[]\n loginWay?: LoginMethods\n submitButText?: string\n saveIdentify?: (type: LoginMethods, identity: string) => void\n /**\n * 根据输入的账号 & 返回获得对应的登录方法\n */\n multipleInstance?: StoreInstance\n /**\n * 多账号回填的数据\n */\n backfillData?: BackFillMultipleState\n}\n\nexport const LoginWithPassword = (props: LoginWithPasswordProps) => {\n const {\n agreements,\n onLoginFailed,\n onLoginSuccess,\n saveIdentify,\n multipleInstance,\n backfillData,\n passwordLoginMethods,\n } = props\n\n const [form] = useForm()\n\n const {\n _firstItemInitialValue = '',\n specifyDefaultLoginMethod,\n } = useGuardInitData<GuardLoginInitData>()\n\n useLoginMultipleBackFill({\n form,\n way: LoginMethods.Password,\n formKey: 'account',\n backfillData,\n cancelBackfill: LoginMethods.Password === specifyDefaultLoginMethod,\n })\n\n const [acceptedAgreements, setAcceptedAgreements] = useState(false)\n const { isPhoneMedia } = useMediaSize()\n const [validated, setValidated] = useState(false)\n\n let { t, i18n } = useTranslation()\n let { post } = useGuardHttp()\n let client = useGuardAuthClient()\n\n const publicConfig = useGuardPublicConfig()\n const config = useGuardFinallyConfig()\n const defaultLanguageConfig = useGuardDefaultLanguage()\n const robotVerify = useRobotVerify()\n\n let submitButtonRef = useRef<any>(null)\n\n const [showCaptcha, setShowCaptcha] = useState(\n robotVerify === 'always_enable'\n )\n const [verifyCodeUrl, setVerifyCodeUrl] = useState('')\n const [remainCount, setRemainCount] = useState(0)\n const [accountLock, setAccountLock] = useState(false)\n\n const encrypt = client.options.encryptFunction\n\n const loginRequest = useCallback(\n async (loginInfo: any): Promise<AuthingGuardResponse> => {\n if (!!props.onLoginRequest) {\n const res = await props.onLoginRequest(loginInfo)\n return res\n }\n\n // onLogin\n const { data: loginData } = loginInfo\n let url = publicConfig?.mergeAdAndAccountPasswordLogin\n ? '/api/v2/login/ad-all-in-one'\n : '/api/v2/login/account'\n let account = loginData.identity && loginData.identity.trim()\n let password = loginData.password\n let captchaCode = loginData.captchaCode && loginData.captchaCode.trim()\n\n let body = {\n account: account,\n password: await encrypt!(password, props.publicKey),\n captchaCode,\n customData: config?.isHost\n ? getUserRegisterParams(['login_page_context'])\n : undefined,\n autoRegister: props.autoRegister,\n withCustomData: false,\n }\n const res = await post(url, body)\n\n return res\n },\n [\n config?.isHost,\n encrypt,\n post,\n props,\n publicConfig?.mergeAdAndAccountPasswordLogin,\n ]\n )\n\n const onFinish = async (values: any) => {\n setValidated(true)\n if (agreements?.length && !acceptedAgreements) {\n submitButtonRef.current.onError()\n return\n }\n setRemainCount(0)\n\n setAccountLock(false)\n\n // onBeforeLogin\n submitButtonRef?.current?.onSpin(true)\n let loginInfo = {\n type: LoginMethods.Password,\n data: {\n identity: values.account,\n password: values.password,\n captchaCode: values.captchaCode,\n },\n }\n let context = await props.onBeforeLogin?.(loginInfo)\n if (!context && !!props.onBeforeLogin) {\n submitButtonRef?.current?.onSpin(false)\n return\n }\n\n // 图形验证码出现后,不管是「图形验证码」错了,还是「账号」「密码」错了,都要重新发验证码\n if (verifyCodeUrl) {\n setVerifyCodeUrl(getCaptchaUrl(props.host!))\n }\n const res = await loginRequest(loginInfo)\n\n onLoginRes(res, values.account)\n }\n\n const onLoginRes = (res: AuthingGuardResponse, account: string) => {\n const { code, apiCode, message: msg, data, onGuardHandling } = res\n submitButtonRef?.current?.onSpin(false)\n // 更新本次登录方式\n data &&\n multipleInstance &&\n multipleInstance.setLoginWayByHttpData(account, data)\n\n if (code === 200) {\n onLoginSuccess(data, msg)\n } else {\n // 需要「图形验证码」并且是第一次,就发一次,后面存在的时候会在点击登录,表单校验通过后,不论对错都要重新请求验证码\n if (apiCode === ErrorCode.INPUT_CAPTCHACODE && !verifyCodeUrl) {\n setVerifyCodeUrl(getCaptchaUrl(props.host!))\n setShowCaptcha(true)\n }\n\n if (apiCode === ErrorCode.PASSWORD_ERROR) {\n if ((data as any)?.remainCount ?? false) {\n setRemainCount((data as any)?.remainCount ?? 0)\n submitButtonRef?.current?.onSpin(false)\n // TODO 临时拦截密码错误限制不报 message\n // props.onLogin(9999, data, msg)\n onLoginFailed?.(9999, data, msg)\n return\n }\n }\n\n if (\n apiCode === ErrorCode.ACCOUNT_LOCK ||\n apiCode === ErrorCode.MULTIPLE_ERROR_LOCK\n ) {\n // 账号锁定\n setAccountLock(true)\n }\n\n // 响应拦截器处理通用错误以及changeModule\n // 本次请求成功 && 当前请求\n const handMode = onGuardHandling?.()\n if (handMode) {\n }\n // 向上层抛出错误\n handMode === CodeAction.RENDER_MESSAGE && onLoginFailed?.(code, data, msg)\n }\n }\n\n useEffect(() => {\n setRemainCount(0)\n setAccountLock(false)\n }, [props.loginWay])\n\n useEffect(() => {\n setShowCaptcha(robotVerify === 'always_enable')\n if (robotVerify === 'always_enable') {\n setVerifyCodeUrl(getCaptchaUrl(props.host!))\n }\n }, [robotVerify, props.host])\n\n const submitText = useMemo(() => {\n if (props.submitButText) return props.submitButText\n\n return props.autoRegister &&\n !publicConfig.registerDisabled &&\n config.registerMethods?.filter(\n (item) =>\n // @ts-ignore\n ![RegisterMethods.Phone, RegisterMethods.EmailCode].includes(item)\n )?.length\n ? `${t('common.login')} / ${t('common.register')}`\n : t('common.login')\n }, [props, t, publicConfig.registerDisabled, config.registerMethods])\n\n const formValuesChange = (changedValues: Record<string, any>) => {\n if (changedValues?.account && saveIdentify) {\n saveIdentify(LoginMethods.Password, changedValues?.account)\n }\n }\n\n const i18nFields = useMemo(() => {\n const i18nMap = new Map<string, TabFieldsI18nItem>()\n publicConfig.tabMethodsFields.forEach((item) => {\n i18nMap.set(item.key, item)\n })\n return i18nMap\n }, [publicConfig.tabMethodsFields])\n\n const placeholder = useMemo(() => {\n // 登录注册合并\n if (config?.autoRegister) {\n // 密码 placeholder\n const methods = [...passwordLoginMethods]\n return t('login.inputAccount', {\n text: getSortLabels(methods, i18nFields, defaultLanguageConfig),\n })\n }\n // 登录注册分页\n return t('login.inputAccount', {\n text: getSortLabels(\n [...passwordLoginMethods],\n i18nFields,\n defaultLanguageConfig\n ),\n })\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n config?.autoRegister,\n i18n,\n i18nFields,\n defaultLanguageConfig,\n passwordLoginMethods,\n t,\n ])\n\n return (\n <div className=\"authing-g2-login-password\">\n <Form\n name=\"passworLogin\"\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current.onError()}\n autoComplete=\"off\"\n form={form}\n onValuesChange={formValuesChange}\n >\n <FormItemAccount\n name=\"account\"\n className=\"authing-g2-input-form\"\n validPasswordLoginMethods={\n publicConfig?.passwordTabConfig?.validLoginMethods || []\n }\n initialValue={\n specifyDefaultLoginMethod === LoginMethods.Password\n ? _firstItemInitialValue\n : ''\n }\n // TODO\n // 开启国际化手机号场景且只有手机号情况下 不应再根据区号去验证手机号\n >\n <InputAccount\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n size=\"large\"\n autoFocus={!isPhoneMedia}\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n passwordLoginMethods={passwordLoginMethods}\n placeholder={placeholder}\n />\n </FormItemAccount>\n <Form.Item\n name=\"password\"\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n rules={fieldRequiredRule(t('common.password'))}\n >\n <InputPassword\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputLoginPwd')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n {/* 图形验证码 */}\n {showCaptcha && (\n <Form.Item\n className=\"authing-g2-input-form\"\n validateTrigger={['onBlur', 'onChange']}\n name=\"captchaCode\"\n rules={fieldRequiredRule(t('common.captchaCode'))}\n >\n <GraphicVerifyCode\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputCaptchaCode')}\n verifyCodeUrl={verifyCodeUrl}\n changeCode={() => setVerifyCodeUrl(getCaptchaUrl(props.host!))}\n />\n </Form.Item>\n )}\n {remainCount !== 0 && !accountLock && (\n <span\n style={{\n marginBottom: 23,\n fontSize: 12,\n color: '#E8353E',\n display: 'block',\n }}\n >\n {t('common.loginFailCheck', {\n number: remainCount,\n })}\n </span>\n )}\n {accountLock && (\n <span\n style={{\n marginBottom: 23,\n fontSize: 12,\n color: '#E8353E',\n display: 'block',\n }}\n >\n {t('common.accountLock')}\n </span>\n )}\n\n {Boolean(agreements?.length) && (\n <Agreements\n onChange={setAcceptedAgreements}\n agreements={agreements}\n showError={validated}\n />\n )}\n <Form.Item className=\"authing-g2-sumbit-form\">\n <SubmitButton\n // TODO 产品还没想好 暂时不上\n // disabled={\n // !!agreements.find((item) => item.required && !acceptedAgreements)\n // }\n text={submitText}\n className=\"password\"\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n","import React, { useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { Form, Input, message } from 'antd'\nimport { ErrorCode } from '../../_utils/GuardErrorCode'\n// import { useGuardAuthClient } from '../../Guard/authClient'\nimport SubmitButton from '../../SubmitButton'\nimport { fieldRequiredRule } from '../../_utils'\nimport { IconFont } from '../../IconFont'\nimport { InputPassword } from '../../InputPassword'\nimport { Agreements } from '../../Register/components/Agreements'\nimport { useGuardHttpClient } from '../../_utils/context'\nimport { CodeAction } from '../../_utils/responseManagement/interface'\nimport { useMediaSize } from '../../_utils/hooks'\nimport { Agreement, LoginMethods } from '../../Type/application'\nimport {\n BackFillMultipleState,\n StoreInstance,\n} from '../../Guard/core/hooks/useMultipleAccounts'\nimport { useLoginMultipleBackFill } from '../hooks/useLoginMultiple'\n\ninterface LoginWithLDAPProps {\n // configs\n publicKey: string\n autoRegister?: boolean\n host?: string\n\n // events\n // onLogin: any\n onLoginSuccess: any\n onLoginFailed: any\n onBeforeLogin: any\n agreements: Agreement[]\n /**\n * 根据输入的账号 & 返回获得对应的登录方法\n */\n multipleInstance?: StoreInstance\n /**\n * 多账号回填的数据\n */\n backfillData?: BackFillMultipleState\n}\n\nexport const LoginWithLDAP = (props: LoginWithLDAPProps) => {\n const {\n agreements,\n onLoginSuccess,\n onLoginFailed,\n multipleInstance,\n backfillData,\n } = props\n\n const [form] = Form.useForm()\n\n // const { responseIntercept } = useGuardHttpClient()\n useLoginMultipleBackFill({\n form,\n way: 'ldap',\n formKey: 'account',\n backfillData,\n })\n\n const [acceptedAgreements, setAcceptedAgreements] = useState(false)\n\n const { isPhoneMedia } = useMediaSize()\n\n const [validated, setValidated] = useState(false)\n // let client = useGuardAuthClient()\n const { post } = useGuardHttpClient()\n const { t } = useTranslation()\n let submitButtonRef = useRef<any>(null)\n\n const [showCaptcha, setShowCaptcha] = useState(false)\n const [verifyCodeUrl, setVerifyCodeUrl] = useState('')\n const captchaUrl = `${props.host}/api/v2/security/captcha`\n const getCaptchaUrl = () => `${captchaUrl}?r=${+new Date()}`\n\n const onFinish = async (values: any) => {\n setValidated(true)\n if (agreements?.length && !acceptedAgreements) {\n submitButtonRef.current?.onError()\n return\n }\n // onBeforeLogin\n submitButtonRef.current?.onSpin(true)\n let loginInfo = {\n type: LoginMethods.LDAP,\n data: {\n identity: values.account,\n password: values.password,\n captchaCode: values.captchaCode,\n },\n }\n let context = await props.onBeforeLogin(loginInfo)\n if (!context) {\n submitButtonRef.current?.onSpin(false)\n return\n }\n\n // onLogin\n let username = values.account && values.account.trim()\n let password = values.password\n\n try {\n const { code, data, onGuardHandling } = await post(\n '/api/v2/ldap/verify-user',\n {\n username,\n password,\n }\n )\n\n submitButtonRef.current.onSpin(false)\n // 更新本次登录方式\n data &&\n multipleInstance &&\n multipleInstance.setLoginWayByLDAPData(username, data)\n\n if (code === 200) {\n onLoginSuccess(data)\n } else {\n if (code === ErrorCode.INPUT_CAPTCHACODE) {\n setVerifyCodeUrl(getCaptchaUrl())\n setShowCaptcha(true)\n }\n const handMode = onGuardHandling?.()\n // 向上层抛出错误\n handMode === CodeAction.RENDER_MESSAGE && onLoginFailed(code, data)\n }\n } catch (error: any) {\n submitButtonRef.current?.onSpin(false)\n if (error.code === 'ECONNABORTED') {\n message.error(t('common.timeoutLDAP'))\n onLoginFailed(2333, {})\n } else {\n console.log(error)\n }\n }\n\n // let captchaCode = values.captchaCode && values.captchaCode.trim()\n // await client\n // .loginByLdap(account, password)\n // .then((user) => {\n // onLoginSuccess(user)\n // })\n // .catch((error: any) => {\n // if (error.code === 'ECONNABORTED') {\n // message.error(t('common.timeoutLDAP'))\n // onLoginFailed(2333, {})\n // } else {\n // submitButtonRef.current?.onError()\n // let parsedMessage: any = {}\n // try {\n // parsedMessage = JSON.parse(error.message) || error\n // } catch {\n // console.log('message 解析失败')\n // }\n // const { code, statusCode, apiCode, message, data } = parsedMessage\n // if (code === ErrorCode.INPUT_CAPTCHACODE) {\n // setVerifyCodeUrl(getCaptchaUrl())\n // setShowCaptcha(true)\n // }\n // // TODO 错误信息返回不符合 AuthingResponse 的格式 暂用 code 替代\n // const { onGuardHandling } = responseIntercept({\n // statusCode: statusCode || code,\n // apiCode,\n // data,\n // message,\n // code,\n // })\n // const handMode = onGuardHandling?.()\n // // 向上层抛出错误\n // handMode === CodeAction.RENDER_MESSAGE && onLoginFailed(code, data)\n // }\n // })\n // .finally(() => {\n // submitButtonRef.current?.onSpin(false)\n // })\n }\n\n return (\n <div className=\"authing-g2-login-ldap\">\n <Form\n form={form}\n name=\"passworLogin\"\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current?.onError()}\n autoComplete=\"off\"\n >\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"account\"\n rules={fieldRequiredRule(t('common.account'))}\n >\n <Input\n autoFocus={!isPhoneMedia}\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('login.inputLdapUsername')}\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"password\"\n rules={fieldRequiredRule(t('common.password'))}\n >\n <InputPassword\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputLdapPwd')}\n // prefix={<LockOutlined style={{ color: '#878A95' }} />}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n {showCaptcha && (\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"captchaCode\"\n rules={[{ required: true, message: t('login.inputCaptchaCode') }]}\n >\n <Input\n className=\"authing-g2-input add-after\"\n size=\"large\"\n placeholder={t('login.inputCaptchaCode')}\n addonAfter={\n <img\n className=\"g2-captcha-code-image\"\n src={verifyCodeUrl}\n alt={t('login.captchaCode')}\n style={{ height: '2em', cursor: 'pointer' }}\n onClick={() => setVerifyCodeUrl(getCaptchaUrl())}\n />\n }\n />\n </Form.Item>\n )}\n {Boolean(agreements?.length) && (\n <Agreements\n onChange={setAcceptedAgreements}\n agreements={agreements}\n showError={validated}\n />\n )}\n <Form.Item className=\"authing-g2-sumbit-form\">\n <SubmitButton\n // disabled={\n // !!agreements.find((item) => item.required && !acceptedAgreements)\n // }\n text={t('common.login')}\n className=\"password\"\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n","import { Form, Input, message } from 'antd'\nimport { useForm } from 'antd/lib/form/Form'\nimport { LoginMethods } from 'authing-js-sdk'\nimport React, { useEffect, useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport {\n BackFillMultipleState,\n StoreInstance,\n} from '../../Guard/core/hooks/useMultipleAccounts'\nimport { useGuardAuthClient } from '../../Guard/authClient'\nimport { IconFont } from '../../IconFont'\nimport { InputPassword } from '../../InputPassword'\nimport { Agreements } from '../../Register/components/Agreements'\nimport SubmitButton from '../../SubmitButton'\nimport { Agreement } from '../../Type/application'\nimport version from '../../version/version'\nimport { fieldRequiredRule } from '../../_utils'\nimport {\n useGuardAppId,\n useGuardFinallyConfig,\n useGuardHttpClient,\n useGuardPublicConfig,\n useRobotVerify,\n} from '../../_utils/context'\nimport { useMediaSize } from '../../_utils/hooks'\nimport { requestClient } from '../../_utils/http'\nimport { i18n } from '../../_utils/locales'\nimport { CodeAction } from '../../_utils/responseManagement/interface'\nimport { ErrorCode } from '../../_utils/GuardErrorCode'\nimport { getCaptchaUrl } from '../../_utils/getCaptchaUrl'\nimport { GraphicVerifyCode } from './withPassword/GraphicVerifyCode'\n// import { useLoginMultipleBackFill } from '../hooks/useLoginMultiple'\n\ninterface LoginWithADProps {\n // configs\n publicKey: string\n autoRegister?: boolean\n // host?: string\n\n // events\n // onLogin: any\n onLoginSuccess: any\n onLoginFailed: any\n onBeforeLogin: any\n agreements: Agreement[]\n /**\n * 回填的数据\n */\n backfillData?: BackFillMultipleState\n /**\n * 根据输入的账号 & 返回获得对应的登录方法\n */\n multipleInstance?: StoreInstance\n}\n\nexport const LoginWithAD = (props: LoginWithADProps) => {\n const { agreements, onLoginFailed, onLoginSuccess } = props\n\n const [acceptedAgreements, setAcceptedAgreements] = useState(false)\n\n const [validated, setValidated] = useState(false)\n\n const robotVerify = useRobotVerify()\n\n const [showCaptcha, setShowCaptcha] = useState(\n robotVerify === 'always_enable'\n )\n const [verifyCodeUrl, setVerifyCodeUrl] = useState('')\n\n const publicConfig = useGuardPublicConfig()\n\n const { host } = useGuardFinallyConfig()\n\n const appId = useGuardAppId()\n\n const { responseIntercept } = useGuardHttpClient()\n\n const { t } = useTranslation()\n\n const { isPhoneMedia } = useMediaSize()\n\n let client = useGuardAuthClient()\n\n // const { post } = useGuardHttpClient()\n\n const [form] = useForm()\n\n // useLoginMultipleBackFill({\n // form,\n // way: 'ad',\n // formKey: 'account',\n // backfillData,\n // })\n\n let submitButtonRef = useRef<any>(null)\n\n const onFinish = async (values: any) => {\n setValidated(true)\n if (agreements?.length && !acceptedAgreements) {\n submitButtonRef.current?.onError()\n return\n }\n // onBeforeLogin\n submitButtonRef.current?.onSpin(true)\n let loginInfo = {\n type: LoginMethods.AD,\n data: {\n identity: values.account,\n password: values.password,\n captchaCode: values.captchaCode,\n },\n }\n let context = await props.onBeforeLogin(loginInfo)\n if (!context) {\n submitButtonRef.current?.onSpin(false)\n return\n }\n\n // onLogin\n let username = values.account && values.account.trim()\n let password = values.password\n let captchaCode = values.captchaCode\n\n const encrypt = client.options.encryptFunction\n\n const encryptPassword = await encrypt!(password, props.publicKey)\n\n // 图形验证码出现后,不管是「图形验证码」错了,还是「账号」「密码」错了,都要重新发验证码\n if (verifyCodeUrl) {\n setVerifyCodeUrl(getCaptchaUrl(host))\n }\n\n // todo\n try {\n const api = `${host}/api/v2/ad/verify-user`\n\n const fetchRes = await fetch(api, {\n method: 'POST',\n body: JSON.stringify({\n username,\n password: encryptPassword,\n captchaCode,\n }),\n credentials: 'include',\n headers: {\n 'Content-Type': 'application/json',\n [requestClient.langHeader]: i18n.language,\n 'x-authing-userpool-id': publicConfig.userPoolId,\n 'x-authing-app-id': appId,\n 'x-authing-sdk-version': version,\n 'x-authing-request-from': `Guard@${version}`,\n },\n })\n\n const res = await fetchRes.json()\n\n const { code, apiCode, data, onGuardHandling } = responseIntercept(res)\n\n // // 更新本次登录方式\n // data && multipleInstance && multipleInstance.setLoginWay('input', 'ad')\n\n submitButtonRef.current?.onSpin(false)\n\n if (code === 200) {\n onLoginSuccess(data)\n } else {\n // 需要「图形验证码」并且是第一次,就发一次,后面存在的时候会在点击登录,表单校验通过后,不论对错都要重新请求验证码\n if (apiCode === ErrorCode.INPUT_CAPTCHACODE && !verifyCodeUrl) {\n setVerifyCodeUrl(getCaptchaUrl(host))\n setShowCaptcha(true)\n }\n\n const handMode = onGuardHandling?.()\n // 向上层抛出错误\n handMode === CodeAction.RENDER_MESSAGE && onLoginFailed(code, data)\n }\n } catch (error: any) {\n submitButtonRef.current?.onSpin(false)\n if (error.code === 'ECONNABORTED') {\n message.error(t('common.timeoutAD'))\n onLoginFailed(2333, {})\n } else {\n console.log(error)\n }\n }\n\n // await client\n // .loginByAd(account, password)\n // .then((user) => {\n // // props.onLogin(200, user)\n // onLoginSuccess(user)\n // })\n // .catch((error: any) => {\n // if (error.code === 'ECONNABORTED') {\n // message.error(t('common.timeoutAD'))\n // onLoginFailed(2333, {})\n // } else {\n // submitButtonRef.current?.onError()\n // let parsedMessage: any = {}\n // try {\n // parsedMessage = JSON.parse(error.message) || error\n // } catch {\n // console.log('message 解析失败')\n // }\n // const { code, statusCode, apiCode, message, data } = parsedMessage\n // // TODO 错误信息返回不符合 AuthingResponse 的格式 暂用 code 替代\n // const { onGuardHandling } = responseIntercept({\n // statusCode: statusCode || code,\n // apiCode,\n // data,\n // message,\n // code,\n // })\n\n // const handMode = onGuardHandling?.()\n // // 向上层抛出错误\n // handMode === CodeAction.RENDER_MESSAGE && onLoginFailed(code, data)\n // }\n // })\n // .finally(() => {\n // submitButtonRef.current?.onSpin(false)\n // })\n }\n\n useEffect(() => {\n setShowCaptcha(robotVerify === 'always_enable')\n if (robotVerify === 'always_enable') {\n setVerifyCodeUrl(getCaptchaUrl(host))\n }\n }, [robotVerify, host])\n\n return (\n <div className=\"authing-g2-login-ad\">\n <Form\n form={form}\n name=\"adLogin\"\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current.onError()}\n autoComplete=\"off\"\n >\n {publicConfig?.ssoPageComponentDisplay.userPasswordInput && (\n <>\n <Form.Item\n className=\"authing-g2-input-form\"\n name=\"account\"\n validateTrigger={['onBlur', 'onChange']}\n rules={fieldRequiredRule(t('common.account'))}\n >\n <Input\n autoFocus={!isPhoneMedia}\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={\n publicConfig?.mergeAdAndAccountPasswordLogin\n ? t('common.jobNumber')\n : t('login.inputAdUsername')\n }\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"password\"\n rules={fieldRequiredRule(t('common.password'))}\n >\n <InputPassword\n autoComplete=\"off\"\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={\n publicConfig?.mergeAdAndAccountPasswordLogin\n ? t('login.inputPwd')\n : t('login.inputAdPwd')\n }\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n {/* 图形验证码 */}\n {showCaptcha && (\n <Form.Item\n className=\"authing-g2-input-form\"\n validateTrigger={['onBlur', 'onChange']}\n name=\"captchaCode\"\n rules={fieldRequiredRule(t('common.captchaCode'))}\n >\n <GraphicVerifyCode\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputCaptchaCode')}\n verifyCodeUrl={verifyCodeUrl}\n changeCode={() => setVerifyCodeUrl(getCaptchaUrl(host))}\n />\n </Form.Item>\n )}\n {Boolean(agreements?.length) && (\n <Agreements\n onChange={setAcceptedAgreements}\n agreements={agreements}\n showError={validated}\n />\n )}\n <Form.Item className=\"authing-g2-sumbit-form\">\n <SubmitButton\n // disabled={\n // !!agreements.find(\n // (item) => item.required && !acceptedAgreements\n // )\n // }\n text={t('common.login')}\n className=\"password\"\n ref={submitButtonRef}\n />\n </Form.Item>\n </>\n )}\n </Form>\n </div>\n )\n}\n","import React, { ReactElement, useMemo } from 'react'\nimport className from 'classnames'\nimport './index.less'\nimport { useImage } from './hooks/useImage'\nimport { useStatus } from './hooks/useStatus'\nimport { ShieldSpin } from '../ShieldSpin'\nimport { CodeStatusDescriptions } from './WorkQrCode'\nimport { useTranslation } from 'react-i18next'\n\n// 目前 UI 支持的状态(满载)\nexport type CodeStatus =\n | 'loading'\n | 'ready'\n | 'already'\n | 'success'\n | 'error'\n | 'expired'\n | 'cancel'\n | 'MFA'\n\nexport const prefix: string = 'refactor'\n\nexport interface UiQrProps {\n /**\n * Loading 组件\n */\n loadingComponent?: React.ReactElement\n /**\n * 二维码组件三种状态\n * ready 准备状态\n * already 已扫描状态\n * success 扫描成功/登录成功状态\n * error 错误状态(超时、网络错误)\n */\n status: CodeStatus\n /**\n * 二维码 URL\n */\n src?: string\n /**\n * 二维码底部内容\n */\n descriptions: CodeStatusDescriptions\n /**\n * 外层 container 样式\n */\n containerStyle?: React.CSSProperties\n /**\n * 内层 container 样式(图片)\n */\n imageStyle?: React.CSSProperties\n /**\n * 二维码图片准备好的回调\n */\n onLoad?: () => void\n /**\n * 点击遮罩中的内容区\n * status 当前组件所处状态\n */\n onClickMaskEl?: (status: CodeStatus) => void\n /**\n * 点击全部遮罩区域\n * status 当前组件所处状态\n */\n onMaskContent?: (status: CodeStatus) => void\n}\n\nconst QrCode: React.FC<UiQrProps> = (props) => {\n const {\n status,\n loadingComponent,\n src,\n descriptions,\n containerStyle,\n imageStyle,\n onLoad,\n onClickMaskEl,\n onMaskContent,\n } = props\n const { t } = useTranslation()\n const [statusCls, statusComponent] = useStatus(status)\n\n const [baseUrl] = useImage(src, {\n onLoad,\n })\n const classPrefix: any = `${prefix}-qrcode`\n const classes = className(classPrefix, statusCls)\n\n const Loading = useMemo(() => {\n return loadingComponent || <ShieldSpin />\n }, [loadingComponent])\n\n return (\n <div className={classes} style={containerStyle}>\n {status === 'loading' ? (\n Loading\n ) : (\n <>\n <span\n className={`${prefix}__image-wrapper`}\n onClick={() => onMaskContent && onMaskContent(status)}\n >\n {statusComponent && (\n <div className={`${prefix}-qrcode__mask`}>\n {React.cloneElement(statusComponent as ReactElement, {\n onClick: (e: React.MouseEvent) => {\n onClickMaskEl && onClickMaskEl(status)\n ;(statusComponent as ReactElement).props.onClick?.(e)\n },\n })}\n </div>\n )}\n <img\n className={`${prefix}__image`}\n src={baseUrl}\n alt={t('common.qrcode')}\n style={imageStyle}\n />\n </span>\n {/* 统一的处理模板 */}\n <div className={`${prefix}__desc`}>{descriptions[status]}</div>\n </>\n )}\n </div>\n )\n}\n\nconst UiQrCode = React.memo(QrCode)\n\nexport { UiQrCode }\n","import React, { useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { IconFont } from '../../IconFont'\nimport { CodeStatus, prefix } from '../UiQrCode'\n\n/**\n * 根据不同状态添加不同的元素\n * 维护不同状态的处理\n */\nconst useStatus = (status: CodeStatus) => {\n const classes = `${prefix}-qrcode--${status}`\n\n const { t } = useTranslation()\n\n /**\n * 不同状态的中间组件\n * TODO: 应该外部传入 具体看后续需求吧,如果有非统一状态外部覆盖\n * 否则保持内部统一模板无需改动\n */\n const componentMapping = useMemo(() => {\n const mapping: Record<CodeStatus, React.ReactNode> = {\n loading: null,\n ready: null,\n already: (\n <>\n <IconFont\n type=\"authing-checkbox-circle-fill\"\n style={{ width: '40px', height: '40px' }}\n />\n <span className={`${prefix}-inner__title--already`}>\n {t('login.scanSuccess')}\n </span>\n </>\n ),\n cancel: (\n <>\n <IconFont\n type=\"authing-refer-qr-code\"\n style={{ width: '40px', height: '40px' }}\n />\n <span className={`${prefix}-inner__title--refer`}>\n {t('login.qrcodeRefer')}\n </span>\n </>\n ),\n expired: (\n <>\n <IconFont\n type=\"authing-refer-qr-code\"\n style={{ width: '40px', height: '40px' }}\n />\n <span className={`${prefix}-inner__title--refer`}>\n {t('login.qrcodeRefer')}\n </span>\n </>\n ),\n error: (\n <>\n <IconFont\n type=\"authing-refer-qr-code\"\n style={{ width: '40px', height: '40px' }}\n />\n <span className={`${prefix}-inner__title--refer`}>\n {t('login.qrcodeNetWorkError')}\n </span>\n </>\n ),\n success: (\n <>\n <IconFont\n type=\"authing-checkbox-circle-fill\"\n style={{ width: '40px', height: '40px' }}\n />\n <span className={`${prefix}-inner__title--already`}>\n {t('login.scanSuccess')}\n </span>\n </>\n ),\n MFA: null,\n }\n return mapping[status]\n }, [status, t])\n\n return [classes, componentMapping]\n}\n\nexport { useStatus }\n","import { useCallback, useEffect, useState } from 'react'\nimport axios from 'axios'\n\nconst useImage = (\n src: string | undefined,\n options: {\n onLoad?: () => void\n }\n) => {\n const [baseUrl, setBaseUrl] = useState<string>()\n\n const { onLoad } = options\n\n /**\n * 预加载图片,转 base64。触发 onLoad,仅此而已\n */\n const preFetchImage = useCallback(async () => {\n const { data: blob } = await axios.get(src!, {\n responseType: 'blob',\n })\n const fileReader = new FileReader()\n\n fileReader.onload = (e: ProgressEvent<FileReader>) => {\n const base64 = e.target?.result as string\n setBaseUrl(base64)\n onLoad && onLoad()\n }\n fileReader.readAsDataURL(blob)\n }, [src, onLoad])\n\n // 每次 render 都会请求 不应该\n useEffect(() => {\n if (src) {\n preFetchImage()\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [src])\n\n return [baseUrl]\n}\n\nexport { useImage }\n","import { useReducer } from 'react'\nimport { CodeStatus } from '../UiQrCode'\n\nexport type ReducerType = 'change' | 'changeStatus' | 'changeDesc'\n\nexport type RootState = {\n /**\n * 状态\n */\n status: CodeStatus\n /**\n * 底部描述\n */\n // description: React.ReactNode\n /**\n * 当前二维码 URL\n */\n src?: string\n /**\n * 二维码随机值\n */\n random?: string\n}\n\nconst reducer = (\n state: RootState,\n action: {\n type: ReducerType\n payload: Partial<RootState>\n }\n) => {\n switch (action.type) {\n case 'changeStatus':\n if (state.status === action.payload.status) {\n return state\n }\n return { ...state, ...action.payload }\n // case 'changeDesc':\n // if (state.description === action.payload.description) {\n // return state\n // }\n // return { ...state, ...action.payload }\n case 'change':\n return { ...state, ...action.payload }\n default:\n return state\n }\n}\n\n/**\n * QrCode 准备阶段 Hook\n */\nconst usePreQrCode = () => {\n /**\n * reducer 控制\n */\n const [state, dispatch] = useReducer(reducer, {\n status: 'loading',\n // description: '',\n src: undefined,\n random: undefined,\n })\n\n return {\n state,\n dispatch,\n }\n}\n\nexport { usePreQrCode }\n","import React, {\n forwardRef,\n ForwardRefRenderFunction,\n useCallback,\n useImperativeHandle,\n useMemo,\n} from 'react'\nimport { ShieldSpin } from '../ShieldSpin'\nimport { useGuardHttpClient } from '../_utils/context'\nimport { usePreQrCode } from './hooks/usePreQrCode'\nimport { QrCodeResponse, useQrCode } from './hooks/usePostQrCode'\nimport { CodeStatus, UiQrCode, UiQrProps } from './UiQrCode'\n\n/**\n * 二维码不同状态下的底部描述文字\n */\nexport type CodeStatusDescriptions = Partial<\n Record<\n Exclude<CodeStatus, 'loading'>,\n React.ReactNode | ((referQrCode?: () => void) => React.ReactNode)\n >\n>\n\nexport interface WorkQrCodeRef {\n referQrCode: () => Promise<\n | {\n random: string\n url: string\n }\n | undefined\n >\n}\n\ninterface WorkQrCodeProps extends Omit<UiQrProps, 'description' | 'status'> {\n /**\n * 二维码场景\n */\n scene: 'WXAPP_AUTH' | 'APP_AUTH' | 'WECHATMP_AUTH'\n /**\n * 不同状态请求文字\n */\n descriptions: CodeStatusDescriptions\n /**\n * 睡眠时间 默认 1000\n */\n sleepTime?: number\n /**\n * 每当状态变化时,触发的 callback 。\n */\n onStatusChange?: (status: CodeStatus, data: QrCodeResponse) => void\n /**\n * 不同状态下点击遮罩中间区域方法\n */\n onClickMaskContent?: (status: CodeStatus) => void\n /**\n * 不同二维码下生成配置\n */\n qrCodeScanOptions?: any\n}\n\nconst WorkQrCodeComponent: ForwardRefRenderFunction<any, WorkQrCodeProps> = (\n props,\n ref\n) => {\n const {\n scene,\n descriptions,\n sleepTime = 1000,\n onStatusChange,\n onClickMaskContent,\n qrCodeScanOptions = {},\n ...rest\n } = props\n\n const {\n context,\n customData,\n withCustomData,\n extIdpConnId,\n } = qrCodeScanOptions\n\n const { get, post } = useGuardHttpClient()\n\n /**\n * 生成图片\n */\n const genCodeRequest = useCallback(\n () =>\n post<{ random: string; url: string }>(`/api/v2/qrcode/gene`, {\n autoMergeQrCode: false,\n scene,\n /**\n * 请求上下文,将会传递到 Pipeline 中\n */\n context,\n /**\n * 是否获取用户自定义数据\n */\n params: customData,\n /**\n * 是否获取用户自定义数据\n */\n withCustomData,\n /**\n * 多租户用的额外的 Idp Id。\n */\n extIdpConnId,\n }),\n [scene, post, context, customData, extIdpConnId, withCustomData]\n )\n\n const { state, dispatch } = usePreQrCode()\n\n /**\n * 状态检查方法\n */\n const checkedRequest = useCallback(\n async () => get(`/api/v2/qrcode/check?random=${state.random}`),\n [state.random, get]\n )\n\n /**\n * 交换用户信息方法\n */\n const exchangeUserInfo = useCallback(\n async (ticket: string) =>\n post(`/api/v2/qrcode/userinfo`, {\n ticket,\n }),\n [post]\n )\n\n useQrCode(\n {\n state,\n dispatch,\n sleepTime,\n descriptions,\n onStatusChange,\n },\n\n {\n genCodeRequest,\n exchangeUserInfo,\n readyCheckedRequest: checkedRequest,\n alreadyCheckedRequest: checkedRequest,\n }\n )\n\n /**\n * 二维码渲染完成后重置状态\n */\n const onLoadQrcCode = () => {\n dispatch({\n type: 'changeStatus',\n payload: {\n status: 'ready',\n },\n })\n }\n\n /**\n * 刷新二维码方法\n */\n const referQrCode = useCallback(() => {\n dispatch({\n type: 'changeStatus',\n payload: {\n status: 'loading',\n },\n })\n }, [dispatch])\n\n /**\n * 内置的默认遮罩点击事件\n */\n const processDefaultMaskClick = (status: CodeStatus) => {\n switch (status) {\n case 'cancel':\n case 'expired':\n case 'error':\n referQrCode()\n break\n default:\n break\n }\n }\n\n /**\n * 点击遮罩触发\n * @param status\n */\n const handlerMaskClick = (status: CodeStatus) => {\n if (onClickMaskContent) {\n onClickMaskContent(status)\n } else {\n processDefaultMaskClick(status)\n }\n }\n\n useImperativeHandle(\n ref,\n () => {\n return {\n referQrCode,\n }\n },\n [referQrCode]\n )\n\n /**\n * 渲染时进行格式化描述\n */\n const formatterDescriptions = useMemo(() => {\n let formatDescriptions: CodeStatusDescriptions = {}\n descriptions &&\n Object.keys(descriptions).forEach((key) => {\n const parseKey = key as keyof CodeStatusDescriptions\n const value = descriptions[parseKey]\n if (typeof value === 'function') {\n formatDescriptions[parseKey] = value(referQrCode)\n } else {\n formatDescriptions[parseKey] = value\n }\n })\n return formatDescriptions\n }, [descriptions, referQrCode])\n\n return (\n <UiQrCode\n src={state.src}\n descriptions={formatterDescriptions}\n status={state.status}\n loadingComponent={<ShieldSpin />}\n onLoad={onLoadQrcCode}\n onMaskContent={handlerMaskClick}\n {...rest}\n ></UiQrCode>\n )\n}\n\nconst WorkQrCode = forwardRef(WorkQrCodeComponent)\nexport { WorkQrCode }\n","import { useCallback, useEffect } from 'react'\nimport { sleep } from '../../_utils'\nimport { useGuardFinallyConfig } from '../../_utils/context'\nimport { AuthingGuardResponse, AuthingResponse } from '../../_utils/http'\nimport { CodeStatus } from '../UiQrCode'\nimport { CodeStatusDescriptions } from '../WorkQrCode'\nimport { ReducerType, RootState } from './usePreQrCode'\n\nexport interface QrCodeResponse {\n /**\n * 根据状态确定不同的流程\n */\n status: number\n /**\n * 返回的随机值\n */\n random: number\n /**\n * 返回的用户信息\n */\n userInfo?: any\n /**\n * 扫码成功后 Tick 换取用户信息\n */\n ticket?: string\n /**\n * MFA 状态下的返回\n */\n scannedResult?: AuthingResponse\n}\n\n/**\n * 二维码请求相关\n */\ninterface QrCodeRequest {\n genCodeRequest?: () => Promise<\n AuthingGuardResponse<{\n random: string\n url: string\n }>\n >\n /**\n * 未扫码下的请求方法\n */\n readyCheckedRequest?: () => Promise<AuthingGuardResponse<QrCodeResponse>>\n /**\n * 已经扫码下的请求方法(待确认)\n */\n alreadyCheckedRequest?: () => Promise<AuthingGuardResponse<QrCodeResponse>>\n /**\n * 使用 ticket 交换用户信息\n */\n exchangeUserInfo?: (ticket: string) => Promise<any>\n}\n\ninterface QrCodeOptions {\n state: RootState\n dispatch: React.Dispatch<{\n type: ReducerType\n payload: Partial<RootState>\n }>\n descriptions: CodeStatusDescriptions\n /**\n * check 轮询间隔时间\n */\n sleepTime?: number\n /**\n * 状态改变时触发事件,仅在 Server 返回的二维码状态改变时进行触发\n */\n onStatusChange?: (status: CodeStatus, data: QrCodeResponse) => void\n}\n\n/**\n * 二维码处理阶段\n * 二维码处理阶段分为两个主要流程\n * 1. 同一状态下的轮询逻辑处理\n * 2. 根据不同返回状态码进行处理\n */\nexport const useQrCode = (options: QrCodeOptions, request: QrCodeRequest) => {\n let destroy = false\n\n const { state, dispatch, sleepTime, onStatusChange } = options\n\n const finallyConfig = useGuardFinallyConfig()\n\n const {\n readyCheckedRequest,\n alreadyCheckedRequest,\n exchangeUserInfo,\n genCodeRequest,\n } = request\n\n /**\n * 根据 Server 返回的状态码决定对应的二维码展示状态\n * @param res\n * @returns\n */\n const getStatusByRes = useCallback((res: QrCodeResponse) => {\n const lists: CodeStatus[] = [\n 'expired',\n 'ready',\n 'already',\n 'success',\n 'cancel',\n 'MFA',\n 'error',\n ]\n const index = res.status + 1\n return lists[index]\n }, [])\n\n // 根据响应\n const processReady = async () => {\n if (\n state.status === 'ready' &&\n readyCheckedRequest &&\n !finallyConfig?._closeLoopCheckQrcode\n ) {\n sleepTime && (await sleep(sleepTime))\n // 再次发起请求\n uniteRequestHandler(readyCheckedRequest)\n }\n }\n\n // already 待确认状态的请求方法\n const processAReady = async () => {\n if (\n state.status === 'already' &&\n alreadyCheckedRequest &&\n !finallyConfig?._closeLoopCheckQrcode\n ) {\n sleepTime && (await sleep(sleepTime))\n uniteRequestHandler(alreadyCheckedRequest)\n }\n }\n\n // TODO: 方法留着,以后业务扩充。当状态改变时,内部需要处理的状态\n // success 下的处理\n const processSuccess = () => {\n if (state.status === 'success') {\n // changeDesc(descriptions.success)\n }\n }\n\n // 处理过期\n const processExpired = () => {\n if (state.status === 'expired') {\n // changeDesc(descriptions.expired)\n }\n }\n\n // 处理用户取消确认\n const processCancel = () => {\n if (state.status === 'cancel') {\n // changeDesc(descriptions.cancel)\n }\n }\n\n // 处理 MFA 状态的函数\n const processMFA = () => {\n if (state.status === 'MFA') {\n // changeDesc(descriptions.MFA)\n }\n }\n\n // Server 返回未知错误\n const processError = () => {\n // 修改 status 同时修改\n if (state.status === 'error') {\n // changeDesc(descriptions.error)\n }\n }\n\n /**\n * 触发事件\n * @param status\n * @param data\n */\n const emitEvents = async (status: CodeStatus, data: QrCodeResponse) => {\n if (data.ticket && exchangeUserInfo) {\n const { data: user } = await exchangeUserInfo(data.ticket)\n onStatusChange && onStatusChange(status, { ...user, ticket: data.ticket })\n } else {\n onStatusChange && onStatusChange(status, data)\n }\n }\n\n /**\n * Server 接口返回才会进入:根据不同返回码进行流转\n */\n const processFlowByResponse: (res: QrCodeResponse) => void = (\n res: QrCodeResponse\n ) => {\n if (destroy) {\n return\n }\n const prev = state.status\n const next = getStatusByRes(res)\n const statusWillChange = prev !== next\n // 状态已经改变 交给状态的 Handler 来改变\n if (statusWillChange) {\n // 改变状态\n changeStatus(next)\n // 触发改变状态的用户事件\n emitEvents(next, res)\n return\n }\n // 状态未改变 交给 ResponseFlow 处理\n processResponseFlow(res)\n }\n\n /**\n * Loading 状态的处理函数\n */\n const processLoading = async () => {\n // 重新切换为 Loading 时,重新调用生成二维码的方式\n if (genCodeRequest) {\n const { data } = await genCodeRequest()\n if (data) {\n const { url, random } = data\n dispatch({\n type: 'change',\n payload: {\n src: url,\n random,\n },\n })\n }\n }\n }\n\n /**\n * 响应状态未改变下的 Flow 处理\n * @param res\n */\n const processResponseFlow = (res: QrCodeResponse) => {\n // 未改变状态 进入处理流程\n switch (res.status) {\n // 过期\n case -1:\n processExpired()\n break\n // 未扫码状态\n case 0:\n processReady()\n break\n // 已经扫码\n case 1:\n processAReady()\n break\n // 成功状态\n case 2:\n processSuccess()\n break\n // 取消状态\n case 3:\n processCancel()\n break\n // mfa 状态\n case 4:\n processMFA()\n break\n // 未知错误\n case 5:\n processError()\n break\n default:\n throw new Error(`不满足的Server Code:${res.status}`)\n }\n }\n\n /**\n * 更改状态\n * @param status\n * @returns\n */\n const changeStatus = (status: CodeStatus) =>\n dispatch({\n type: 'changeStatus',\n payload: {\n status,\n },\n })\n\n /**\n * 更改描述\n * @param description\n * @returns\n */\n // const changeDesc = (description?: ReactNode) =>\n // dispatch({\n // type: 'changeDesc',\n // payload: {\n // description,\n // },\n // })\n\n /**\n * 共用的统一的请求处理\n */\n const uniteRequestHandler = async (\n request: () => Promise<AuthingGuardResponse<QrCodeResponse>>\n ) => {\n try {\n // 状态切换时 请求还在请求中,所以状态切换完毕后\n const { data } = await request()\n if (data) {\n await processFlowByResponse(data)\n } else {\n throw new Error(`返回数据不匹配`)\n }\n } catch (e: any) {\n changeStatus('error')\n }\n }\n\n // 每个状态下的处理函数\n const flowHandlers = {\n loading: processLoading,\n ready: processReady,\n already: processAReady,\n success: processSuccess,\n error: processError,\n expired: processExpired,\n cancel: processCancel,\n MFA: processMFA,\n }\n\n // 每次状态变化流转下一个 flowHandler\n useEffect(() => {\n const handler = flowHandlers[state.status]\n handler()\n return () => {\n // 阻止上一次 Render 内的作用域方法\n // eslint-disable-next-line react-hooks/exhaustive-deps\n destroy = true\n }\n }, [state.status])\n}\n","import { UiQrCode } from './UiQrCode'\nimport { WorkQrCode } from './WorkQrCode'\n\ntype IQrCode = typeof WorkQrCode & {\n UI: typeof UiQrCode\n}\n\nconst QrCode = WorkQrCode as IQrCode\n\nQrCode.UI = UiQrCode\n\nexport { QrCode }\n","import { QrCode } from '../../Qrcode'\nimport React, { useRef } from 'react'\nimport { CodeStatus } from '../../Qrcode/UiQrCode'\nimport { QrCodeResponse } from '../../Qrcode/hooks/usePostQrCode'\nimport { message } from 'antd'\nimport { useGuardEvents, useGuardHttpClient } from '../../_utils/context'\nimport { WorkQrCodeRef } from '../../Qrcode/WorkQrCode'\nimport { useTranslation } from 'react-i18next'\nimport { StoreInstance } from '../../Guard/core/hooks/useMultipleAccounts'\nimport { LoginMethods } from '../..'\nimport { useGuardAuthClient } from '../../Guard/authClient'\n\ninterface LoginWithAppQrcodeProps {\n // onLogin: any\n onLoginSuccess: any\n canLoop: boolean\n // qrCodeScanOptions: any\n multipleInstance?: StoreInstance\n}\n\nexport const LoginWithAppQrcode = (props: LoginWithAppQrcodeProps) => {\n const codeRef = useRef<WorkQrCodeRef>()\n\n const { canLoop } = props\n\n const { responseIntercept } = useGuardHttpClient()\n\n const events = useGuardEvents()\n\n const authClient = useGuardAuthClient()\n\n const { t } = useTranslation()\n\n if (!canLoop) {\n return null\n }\n\n const descriptions: any = {\n already: (referQrCode: () => void) => (\n <span className=\"qrcode__again-scan\" onClick={referQrCode}>\n {t('login.scanAgain')}\n </span>\n ),\n ready: t('login.appScanLogin'),\n success: t('common.LoginSuccess'),\n MFA: t('common.LoginSuccess'),\n }\n\n /**\n * Sever Status 发生变化\n * @param status\n * @param data\n */\n const onStatusChange = async (status: CodeStatus, data: QrCodeResponse) => {\n switch (status) {\n case 'success':\n if (events?.onBeforeLogin) {\n const isContinue = await events?.onBeforeLogin(\n { type: LoginMethods.AppQr, data },\n authClient\n )\n if (!isContinue) {\n break\n }\n }\n props.multipleInstance &&\n props.multipleInstance.setLoginWay('qrcode', LoginMethods.AppQr)\n props.onLoginSuccess(data)\n break\n case 'error':\n if (data.scannedResult) {\n const { message: msg } = data.scannedResult\n message.error(msg)\n }\n break\n case 'MFA':\n if (data.scannedResult) {\n const { onGuardHandling } = responseIntercept(data.scannedResult)\n onGuardHandling?.()\n }\n break\n default:\n break\n }\n }\n\n return (\n <QrCode\n ref={codeRef}\n scene=\"APP_AUTH\"\n descriptions={descriptions}\n onStatusChange={onStatusChange}\n imageStyle={{\n height: '166px',\n width: '166px',\n }}\n />\n )\n}\n","import { getGuardHttp } from '../../_utils/guardHttp'\n\nexport const enum ResetAccountBusinessAction {\n ResetName = 'reset-username-before-auth',\n}\n\nexport const authFlow = async (\n action: ResetAccountBusinessAction,\n content: {\n username: string\n }\n) => {\n const { authFlow } = getGuardHttp()\n\n const res = await authFlow(action, { ...content })\n\n return res\n}\n","import { message } from 'antd'\nimport React from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { QrCode } from '../../Qrcode'\nimport { QrCodeResponse } from '../../Qrcode/hooks/usePostQrCode'\nimport { CodeStatus } from '../../Qrcode/UiQrCode'\nimport { useGuardEvents, useGuardHttpClient } from '../../_utils/context'\nimport { StoreInstance } from '../../Guard/core/hooks/useMultipleAccounts'\nimport { LoginMethods } from '../..'\nimport { isWeChatBrowser } from '../../_utils'\nimport { useGuardAuthClient } from '../../Guard/authClient'\n\ninterface LoginWithWechatMiniQrcodeProps {\n // onLogin: any\n onLoginSuccess: any\n canLoop: boolean\n qrCodeScanOptions: any\n // 当前登录方式 对应的id\n id: string\n multipleInstance?: StoreInstance\n}\n\nexport const LoginWithWechatMiniQrcode = (\n props: LoginWithWechatMiniQrcodeProps\n) => {\n const { canLoop, qrCodeScanOptions } = props\n\n const { t } = useTranslation()\n\n const { responseIntercept } = useGuardHttpClient()\n\n const events = useGuardEvents()\n\n const authClient = useGuardAuthClient()\n\n if (!canLoop) {\n return null\n }\n\n const descriptions: any = {\n already: (referQrCode: () => void) => (\n <span className=\"qrcode__again-scan\" onClick={referQrCode}>\n {t('login.scanAgain')}\n </span>\n ),\n ready: isWeChatBrowser()\n ? t('common.loginWithWechatmpQrcodeTipsTitle')\n : t('login.wechatScanLogin'),\n success: t('common.LoginSuccess'),\n MFA: t('common.LoginSuccess'),\n }\n\n /**\n * 状态发生变化时的处理函数\n * @param status\n * @param data\n */\n const onStatusChange = async (status: CodeStatus, data: QrCodeResponse) => {\n switch (status) {\n case 'success':\n if (events?.onBeforeLogin) {\n const isContinue = await events?.onBeforeLogin(\n { type: LoginMethods.WxMinQr, data },\n authClient\n )\n if (!isContinue) {\n break\n }\n }\n\n props.multipleInstance &&\n props.multipleInstance.setLoginWay(\n 'qrcode',\n LoginMethods.WxMinQr,\n props.id\n )\n\n props.onLoginSuccess(data)\n break\n case 'error':\n // 怎么模拟这里的 error\n if (data.scannedResult) {\n const { message: msg } = data.scannedResult\n message.error(msg)\n }\n break\n case 'MFA':\n const { onGuardHandling } = responseIntercept(data.scannedResult!)\n onGuardHandling?.()\n break\n default:\n break\n }\n }\n\n return (\n <QrCode\n scene=\"WXAPP_AUTH\"\n descriptions={descriptions}\n onStatusChange={onStatusChange}\n qrCodeScanOptions={qrCodeScanOptions}\n imageStyle={{\n height: '166px',\n width: '166px',\n }}\n />\n )\n}\n","import React from 'react'\nimport { useGuardEvents, useGuardHttpClient } from '../../_utils/context'\nimport { message } from 'antd'\nimport { QrCode } from '../../Qrcode'\nimport { CodeStatus } from '../../Qrcode/UiQrCode'\nimport { QrCodeResponse } from '../../Qrcode/hooks/usePostQrCode'\nimport { useTranslation } from 'react-i18next'\nimport { StoreInstance } from '../../Guard/core/hooks/useMultipleAccounts'\nimport { LoginMethods } from '../..'\nimport { isWeChatBrowser } from '../../_utils'\nimport { useGuardAuthClient } from '../../Guard/authClient'\ninterface LoginWithWechatmpQrcodeProps {\n // onLogin: any\n onLoginSuccess: any\n canLoop: boolean\n qrCodeScanOptions: any\n // 当前登录方式 对应的id\n id: string\n /**\n * 多账号存储实例\n */\n multipleInstance?: StoreInstance\n}\n\nexport const LoginWithWechatmpQrcode = (\n props: LoginWithWechatmpQrcodeProps\n) => {\n const { canLoop, qrCodeScanOptions } = props\n\n const { t } = useTranslation()\n\n const { responseIntercept } = useGuardHttpClient()\n\n const events = useGuardEvents()\n\n const authClient = useGuardAuthClient()\n\n if (!canLoop) {\n return null\n }\n\n const descriptions: any = {\n already: (referQrCode: () => void) => (\n <span className=\"qrcode__again-scan\" onClick={referQrCode}>\n {t('login.scanAgain')}\n </span>\n ),\n ready: isWeChatBrowser()\n ? t('common.loginWithWechatmpQrcodeTipsTitle')\n : t('login.wechatScanLogin'),\n success: t('common.LoginSuccess'),\n MFA: t('common.LoginSuccess'),\n }\n\n /**\n * 状态发生变化时的处理函数\n * @param status\n * @param data\n */\n const onStatusChange = async (status: CodeStatus, data: QrCodeResponse) => {\n switch (status) {\n case 'success':\n if (events?.onBeforeLogin) {\n const isContinue = await events?.onBeforeLogin(\n { type: LoginMethods.WechatMpQrcode, data },\n authClient\n )\n if (!isContinue) {\n break\n }\n }\n props.multipleInstance &&\n props.multipleInstance.setLoginWay(\n 'qrcode',\n LoginMethods.WechatMpQrcode,\n props.id\n )\n\n props.onLoginSuccess(data)\n break\n case 'error':\n // 怎么模拟这里的 error\n if (data.scannedResult) {\n const { message: msg } = data.scannedResult\n message.error(msg)\n }\n break\n case 'MFA':\n const { onGuardHandling } = responseIntercept(data.scannedResult!)\n onGuardHandling?.()\n break\n default:\n break\n }\n }\n\n return (\n <QrCode\n scene=\"WECHATMP_AUTH\"\n descriptions={descriptions}\n onStatusChange={onStatusChange}\n qrCodeScanOptions={qrCodeScanOptions}\n imageStyle={{\n height: '166px',\n width: '166px',\n }}\n />\n )\n}\n","import { ErrorCode } from '../_utils/GuardErrorCode'\nimport { GuardModuleAction, GuardModuleType } from '../Guard/module'\nimport { MFAType } from '../MFA/interface'\n\nexport const codeMap: Record<number, GuardModuleAction> = {\n [ErrorCode.APP_MFA_CODE]: {\n // 跳转去 mfa 验证\n action: 'changeModule',\n module: GuardModuleType.MFA,\n },\n [ErrorCode.OTP_MFA_CODE]: {\n // 跳转去 mfa 验证\n action: 'changeModule',\n module: GuardModuleType.MFA,\n initData: {\n current: MFAType.TOTP,\n totpMfaEnabled: true,\n },\n },\n [ErrorCode.INPUT_CAPTCHACODE]: {\n // 需要输入图形验证码\n action: 'message',\n },\n 500: {\n action: 'message',\n },\n 1002: {\n // 登录太频繁\n action: 'message',\n },\n 2820002: {\n // ldap url报错信息\n action: 'message',\n },\n 2333: {\n // 密码错误\n action: 'message',\n },\n 2057: {\n // 多次错误登录导致账号锁定\n action: 'accountLock',\n },\n 2005: {\n // 账号锁定\n action: 'accountLock',\n },\n 2042: {\n // 禁止未验证邮箱注册\n action: 'message',\n },\n 2001: {\n // 验证码过期\n action: 'message',\n },\n 1576: {\n action: 'message',\n },\n 2029: {\n action: 'message',\n },\n 3720001: {\n // 01 02 03 计量计费相关\n action: 'message',\n },\n 3720002: {\n action: 'message',\n },\n 3720003: {\n action: 'message',\n },\n 2130010: {\n // 无权登录此应用\n action: 'message',\n },\n 2120008: {\n action: 'message',\n },\n 2031: {\n // 禁止注册\n action: 'message',\n },\n 1640: {\n action: 'changeModule',\n module: GuardModuleType.IDENTITY_BINDING,\n },\n 1641: {\n action: 'changeModule',\n module: GuardModuleType.IDENTITY_BINDING_ASK,\n },\n 1642: {\n action: 'changeModule',\n module: GuardModuleType.LOGIN_COMPLETE_INFO,\n },\n 1666: {\n action: 'changeModule',\n module: GuardModuleType.IDENTITY_BINDING_NO_ASK,\n },\n 1108: {\n action: 'changeModule',\n module: GuardModuleType.RESET_ACCOUNT_NAME,\n },\n // 1643: {},\n 408: {\n action: 'message',\n },\n}\n","import { Avatar, message } from 'antd'\nimport qs from 'qs'\nimport React, { useCallback } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { getGuardWindow } from '../../../Guard/core/useAppendConfig'\nimport { GuardButton } from '../../../GuardButton'\nimport { IconFont } from '../../../IconFont'\nimport { Protocol } from '../../../Type/application'\nimport version from '../../../version/version'\nimport { isSpecialBrowser, popupCenter } from '../../../_utils'\nimport { useGuardTenantId } from '../../../_utils/context'\nimport { SocialConnectionEvent } from '../../../_utils/hooks'\nimport { i18n } from '../../../_utils/locales'\n\nconst baseLoginPathMapping: Partial<Record<Protocol, string | null>> = {\n [Protocol.OIDC]: '/connections/oidc/init',\n [Protocol.SAML]: '/connections/saml/init',\n [Protocol.CAS]: '/connections/cas/init',\n [Protocol.OAUTH]: '/connections/oauth2/init',\n [Protocol.AZURE_AD]: '/connections/azure-ad/init',\n [Protocol.AD_KERBEROS]: '/connections/ad-kerberos/init',\n}\n\nconst loginUrlFieldMapping: Partial<Record<Protocol, string>> = {\n [Protocol.OIDC]: 'oidcConnectionLoginUrl',\n [Protocol.SAML]: 'samlRequest',\n [Protocol.CAS]: 'casConnectionLoginUrl',\n [Protocol.OAUTH]: 'authUrl',\n [Protocol.AZURE_AD]: 'authorizationUrl',\n [Protocol.AD_KERBEROS]: 'authorizationUrl',\n}\n\nexport const IdpButton = (props: any) => {\n // TODO: 能不能加个类型\n const { i, appId, appHost, isHost } = props\n\n const { t } = useTranslation()\n const tenantId = useGuardTenantId()\n\n const renderBtn = useCallback(() => {\n const query: Record<string, any> = {\n from_guard: '1',\n app_id: appId,\n guard_version: `Guard@${version}`,\n ...(tenantId && { tenant_id: tenantId }),\n }\n\n if (isHost) {\n delete query.from_guard\n query.from_hosted_guard = '1'\n\n if (isSpecialBrowser()) {\n query.redirected = '1'\n\n const guardWindow = getGuardWindow()\n if (guardWindow) {\n // 如果 isHost 是 true,则从 url 获取 finish_login_url 作为 social.authorize 方法的 targetUrl 参数\n query.redirect_url = qs.parse(guardWindow.location.search)?.[\n 'finish_login_url'\n ]\n }\n }\n }\n\n if (i?.provider) {\n // 社交身份源\n const iconType = `authing-${i.provider.replace(/:/g, '-')}`\n\n const onLogin = () => {\n if (i.action === SocialConnectionEvent.Message) {\n message.error(\n t('login.socialConnectionMessage', {\n provider:\n i.displayName ??\n (i18n.language === 'zh-CN' ? i.name : i.name_en) ??\n i.provider,\n })\n )\n } else if (i.action === SocialConnectionEvent.Auth) {\n const initUrl = `${appHost}/connections/social/${\n i.identifier\n }?${qs.stringify(query)}`\n if (query.redirected) {\n window.location.replace(initUrl)\n } else {\n popupCenter(initUrl)\n }\n }\n }\n\n return (\n <GuardButton\n key={i.identifier}\n className=\"g2-guard-third-login-btn\"\n block\n size=\"large\"\n icon={\n <IconFont\n type={`${iconType}-fill`}\n style={{ fontSize: 20, marginRight: 8 }}\n />\n }\n onClick={onLogin}\n >\n {t('login.loginBy', {\n name: i.displayName,\n })}\n </GuardButton>\n )\n } else {\n let initUrl: string\n\n if (isHost) {\n // 托管登录页,直接写死登录 URL\n query.identifier = i.identifier\n\n const basePath = baseLoginPathMapping[i.protocol as Protocol]\n if (!basePath) {\n return null\n }\n\n initUrl = `${appHost}${basePath}?${qs.stringify(query)}`\n } else {\n const field = loginUrlFieldMapping[i.protocol as Protocol]\n if (!field) {\n return null\n }\n\n // 嵌入式组件,从配置字段获取登录 URL\n initUrl = i.config[field]\n }\n\n return (\n <GuardButton\n key={i.identifier}\n className=\"g2-guard-third-login-btn\"\n block\n size=\"large\"\n icon={<Avatar size={20} src={i.logo} style={{ marginRight: 8 }} />}\n onClick={() => {\n if (query.redirected) {\n window.location.replace(initUrl)\n } else {\n popupCenter(initUrl)\n }\n }}\n >\n {t('login.loginBy', {\n name: i.displayName,\n })}\n </GuardButton>\n )\n }\n }, [appId, i, t, isHost, appHost, tenantId])\n return renderBtn()\n}\n","import { message, Space, Tooltip } from 'antd'\nimport { Lang } from 'authing-js-sdk/build/main/types'\nimport React, { useEffect } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { i18n } from '../../_utils/locales'\nimport { isSpecialBrowser, popupCenter } from '../../_utils'\nimport querystring from 'query-string'\nimport { IconFont } from '../../IconFont'\nimport './style.less'\nimport { useMediaSize, SocialConnectionEvent } from '../../_utils/hooks'\nimport { useGuardPublicConfig, useGuardTenantId } from '../../_utils/context'\nimport { IdpButton } from './IdpButton'\nimport { usePostMessage } from './postMessage'\nimport { CodeAction } from '../../_utils/responseManagement/interface'\nimport version from '../../version/version'\nimport { GuardLocalConfig } from '../../Guard'\nimport { getGuardWindow } from '../../Guard/core/useAppendConfig'\nimport { GuardButton } from '../../GuardButton'\nimport { ApplicationConfig, SocialConnectionItem } from '../../Type/application'\nimport { StoreInstance } from '../../Guard/core/hooks/useMultipleAccounts'\n\nexport interface SocialLoginProps {\n appId: string\n config: GuardLocalConfig\n // onLogin: any\n onLoginFailed: any\n onLoginSuccess: any\n enterpriseConnectionObjs: ApplicationConfig['identityProviders']\n socialConnectionObjs: SocialConnectionItem[]\n /**\n * 根据输入的账号 & 返回获得对应的登录方法\n */\n multipleInstance?: StoreInstance\n}\n\nexport const SocialLogin: React.FC<SocialLoginProps> = ({\n appId,\n config,\n onLoginFailed,\n onLoginSuccess,\n enterpriseConnectionObjs,\n socialConnectionObjs,\n multipleInstance,\n}) => {\n const noLoginMethods = !config?.loginMethods?.length\n\n const publicConfig = useGuardPublicConfig()\n\n const userPoolId = publicConfig?.userPoolId\n\n const { t } = useTranslation()\n\n const { isPhoneMedia } = useMediaSize()\n\n const onMessage = usePostMessage()\n\n const tenantId = useGuardTenantId()\n\n useEffect(() => {\n const onPostMessage = (evt: MessageEvent) => {\n const res = onMessage(evt)\n if (!res) return\n\n // 更新本次登录方式\n multipleInstance && multipleInstance.setLoginWay('input', 'social')\n\n const { code, data, onGuardHandling } = res\n\n if (code === 200) {\n onLoginSuccess(data)\n } else {\n const handMode = onGuardHandling?.()\n // 向上层抛出错误\n handMode === CodeAction.RENDER_MESSAGE && onLoginFailed(code, data)\n }\n }\n\n const guardWindow = getGuardWindow()\n\n guardWindow?.addEventListener('message', onPostMessage)\n return () => {\n guardWindow?.removeEventListener('message', onPostMessage)\n }\n }, [onLoginFailed, multipleInstance, onLoginSuccess, onMessage])\n\n const idpButtons = enterpriseConnectionObjs.map((i: any) => {\n return (\n <IdpButton\n key={i.identifier}\n i={i}\n appId={appId}\n appHost={config?.host}\n userPoolId={userPoolId}\n isHost={config?.isHost}\n />\n )\n })\n\n const socialLoginButtons = socialConnectionObjs.map((item: any) => {\n let iconType = `authing-${item.provider.replace(/:/g, '-')}`\n\n const query: Record<string, any> = {\n from_guard: '1',\n app_id: appId,\n guard_version: `Guard@${version}`,\n }\n\n if (tenantId) {\n query.tenant_id = tenantId\n }\n\n if (config?.isHost) {\n query.from_hosted_guard = '1'\n\n if (isSpecialBrowser()) {\n query.redirected = '1'\n\n const guardWindow = getGuardWindow()\n if (guardWindow) {\n // 如果 isHost 是 true,则从 url 获取 finish_login_url 作为 social.authorize 方法的 targetUrl 参数\n query.redirect_url = querystring.parse(guardWindow.location.search)?.[\n 'finish_login_url'\n ]\n }\n }\n }\n\n const onLogin = () => {\n if (item.action === SocialConnectionEvent.Message) {\n message.error(\n t('login.socialConnectionMessage', {\n provider:\n item.displayName ??\n (i18n.language === 'zh-CN' ? item.name : item.name_en) ??\n item.provider,\n })\n )\n } else if (item.action === SocialConnectionEvent.Auth) {\n const initUrl = `${config.host}/connections/social/${\n item.identifier\n }?${querystring.stringify(query)}`\n\n if (query.redirected) {\n window.location.replace(initUrl)\n } else {\n popupCenter(initUrl)\n }\n }\n }\n\n const shape = config.socialConnectionsBtnShape\n if (shape === 'button') {\n return (\n <GuardButton\n key={item.id}\n block\n size=\"large\"\n className=\"g2-guard-third-login-btn\"\n icon={\n <IconFont\n type={`${iconType}-fill`}\n style={{ fontSize: 20, marginRight: 8 }}\n />\n }\n onClick={onLogin}\n style={{\n marginBottom: 8,\n }}\n >\n {item.displayName ??\n (i18n.language === 'zh-CN' ? item.name : item.name_en) ??\n item.provider}\n </GuardButton>\n )\n } else if (shape === 'icon') {\n return isPhoneMedia ? (\n <GuardButton\n className=\"g2-social-login-item\"\n onClick={onLogin}\n icon={<IconFont type={`${iconType}-fill`} />}\n ></GuardButton>\n ) : (\n <Tooltip\n key={item.id}\n title={item.tooltip?.[i18n.language as Lang] || item.name}\n trigger={['hover', 'click', 'contextMenu']}\n >\n <GuardButton\n className=\"g2-social-login-item\"\n onClick={onLogin}\n icon={<IconFont type={`${iconType}-fill`} />}\n ></GuardButton>\n </Tooltip>\n )\n } else {\n return noLoginMethods ? (\n <GuardButton\n key={item.id}\n block\n size=\"large\"\n className=\"g2-guard-third-login-btn\"\n icon={\n <IconFont\n type={`${iconType}-fill`}\n style={{ fontSize: 20, marginRight: 8 }}\n />\n }\n onClick={onLogin}\n >\n {item.displayName ??\n (i18n.language === 'zh-CN' ? item.name : item.name_en) ??\n item.provider}\n </GuardButton>\n ) : isPhoneMedia ? (\n <GuardButton\n className=\"g2-social-login-item\"\n onClick={onLogin}\n key={item.id}\n icon={<IconFont type={`${iconType}-fill`} />}\n ></GuardButton>\n ) : (\n <Tooltip\n overlayStyle={{ fontFamily: 'sans-serif' }}\n key={item.id}\n title={\n item.displayName ||\n item.tooltip?.[i18n.language as Lang] ||\n item.name\n }\n trigger={['hover', 'click', 'contextMenu']}\n >\n <GuardButton\n className=\"g2-social-login-item\"\n onClick={onLogin}\n icon={<IconFont type={`${iconType}-fill`} />}\n ></GuardButton>\n </Tooltip>\n )\n }\n })\n const idp = enterpriseConnectionObjs.length ? (\n <>\n {!noLoginMethods && (\n <div className=\"g2-social-login-title\">\n {i18n.t('login.otherLoginWay')}\n </div>\n )}\n <div className=\"g2-social-login-list\">{idpButtons}</div>\n </>\n ) : null\n\n const socialLogin =\n socialLoginButtons.length > 0 && noLoginMethods ? (\n <Space\n size={noLoginMethods ? 0 : 12}\n className=\"g2-guard-full-width-space no-login-methods\"\n direction=\"vertical\"\n >\n {socialLoginButtons}\n </Space>\n ) : (\n socialLoginButtons.length > 0 && (\n <>\n <div className=\"g2-social-login-title\">\n {t('login.thridAccLogin')}\n </div>\n <div className=\"g2-social-login-list\">{socialLoginButtons}</div>\n </>\n )\n )\n\n return (\n <>\n {!noLoginMethods && (\n <div\n style={{\n flex: 1,\n minHeight: 16,\n }}\n />\n )}\n <Space\n size={noLoginMethods ? 0 : 8}\n direction=\"vertical\"\n className=\"g2-guard-full-width-space\"\n >\n {!publicConfig?.ssoPageComponentDisplay.idpBtns || idp}\n {!publicConfig?.ssoPageComponentDisplay.socialLoginBtns || socialLogin}\n </Space>\n </>\n )\n}\n","import { useGuardHttpClient } from '../../_utils/context'\nimport { AuthingResponse } from '../../_utils/http'\n\n// 处理所有使用 postMessage 方式的登录\nexport const usePostMessage = () => {\n // 借用一下 GuardHttpClient 的方法\n const { responseIntercept } = useGuardHttpClient()\n\n const onMessage = (evt: MessageEvent) => {\n const { message, data, event, code } = evt.data\n\n const { source } = event || {}\n // 社会化登录是用 authing-js-sdk 实现的,不用再在这里回调了\n // if (source === 'authing' && eventType === 'socialLogin') {\n // return\n // }\n\n if (source !== 'authing') {\n return\n }\n\n // 如果直接为 200 代表成功了\n if (code === 200) {\n return { code, data, onGuardHandling: undefined }\n }\n\n // TODO 完整的登陆信息 在 message 中 以 Json 的形式返回 待优化\n let parsedMessage: any\n try {\n parsedMessage = JSON.parse(message)\n } catch (error) {\n console.error('Json parse error in postMessage')\n console.error(`message: ${message}, code: ${code}`)\n return\n }\n\n const {\n code: authingCode,\n statusCode,\n apiCode,\n message: authingMessage,\n data: authingResData,\n flowHandle,\n } = parsedMessage\n\n const res = responseIntercept({\n statusCode,\n apiCode,\n data: authingResData,\n message: authingMessage,\n code: authingCode,\n flowHandle,\n })\n\n return res\n }\n\n return onMessage\n}\n\nexport const useErrorHandling = () => {\n // 借用一下 GuardHttpClient 的方法\n const { responseIntercept } = useGuardHttpClient()\n\n const errorHandling = (res: AuthingResponse) => {\n const { message } = res\n\n const parsedMsg = JSON.parse(message!)\n\n const {\n code: authingCode,\n statusCode,\n apiCode,\n message: authingMessage,\n data: authingResData,\n } = parsedMsg\n\n const response = responseIntercept({\n statusCode,\n apiCode,\n data: authingResData,\n message: authingMessage,\n code: authingCode,\n })\n\n return response\n }\n\n return errorHandling\n}\n","import { Popover } from 'antd'\nimport React, { useMemo, useCallback } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { IconFont } from '../../IconFont'\nimport { useMediaSize } from '../../_utils/hooks'\nimport './style.less'\n\ninterface SelectPanelProps {\n lists: SelectOptions[]\n /**\n * 点击删除\n */\n handleDel: (id: string) => void\n /**\n * 点击 li\n */\n onClick: (id: string) => void\n}\n\nexport interface SelectOptions {\n /**\n * 头像\n */\n photo?: string\n /**\n * 标题\n */\n title?: string\n /**\n * 描述\n */\n description?: string\n /**\n * 用户 ID 唯一标识符\n */\n id: string | 'other'\n /**\n * 显示操作栏 default: true\n */\n operation?: boolean\n /**\n * 登录时间\n */\n _updateTime: number\n /**\n * 替代图片元素\n */\n element?: React.ReactElement\n\n way: string\n}\n\nconst SelectPanel: React.FC<SelectPanelProps> = (props) => {\n const { lists, handleDel, onClick } = props\n const { t } = useTranslation()\n\n const { isPhoneMedia } = useMediaSize()\n\n const triggerWay = useMemo(() => {\n return isPhoneMedia ? 'click' : 'hover'\n }, [isPhoneMedia])\n\n const finallyLists = useMemo(() => {\n return [\n ...lists,\n {\n operation: false,\n id: 'other',\n title: t('login.useOtherAccount'),\n element: (\n <div className=\"g2-multiple__icon--add-line\">\n <IconFont\n style={{ fontSize: 24, color: '#4E5969' }}\n type=\"authing-add-line\"\n ></IconFont>\n </div>\n ),\n },\n ]\n }, [lists, t])\n\n const onDel = useCallback(\n (e: React.MouseEvent, id: string) => {\n handleDel(id)\n e.stopPropagation()\n },\n [handleDel]\n )\n\n const renderLits = useMemo(() => {\n return finallyLists.map((option) => {\n const {\n photo,\n title,\n description,\n id,\n operation = true,\n element,\n } = option as SelectOptions\n return (\n <li className=\"g2-multiple__li\" key={id} onClick={() => onClick(id)}>\n {element ? (\n element\n ) : (\n <img className=\"g2-multiple__avatar\" alt=\"\" src={photo} />\n )}\n\n <section className=\"g2-multiple__body\">\n {title && <span className=\"g2-multiple__title\">{title}</span>}\n <span\n className={title ? 'g2-multiple__desc' : 'g2-multiple__title'}\n >\n {description}\n </span>\n </section>\n {operation && (\n <span\n className=\"g2-multiple__op\"\n onClick={(e) => e.stopPropagation()}\n >\n <Popover\n trigger={triggerWay}\n overlayClassName=\"g2-multiple__op-wrapper\"\n getPopupContainer={(triggerNode) => triggerNode}\n content={\n <div\n className=\"g2-multiple__del\"\n onClick={(e: React.MouseEvent) => onDel(e, id)}\n >\n <IconFont\n style={{\n fontSize: 20,\n marginRight: 8,\n }}\n type=\"authing-indeterminate-circle-line\"\n />\n {t('common.del')}\n </div>\n }\n >\n <div className=\"g2-multiple__icon\">\n <IconFont type=\"authing-more-fill\"></IconFont>\n </div>\n </Popover>\n </span>\n )}\n </li>\n )\n })\n }, [finallyLists, onClick, onDel, t, triggerWay])\n\n return <ul className=\"g2-multiple\">{renderLits}</ul>\n}\n\nexport { SelectPanel }\n","import React, { useCallback, useState } from 'react'\nimport { SelectPanel } from './panel'\nimport {\n LoginWay,\n StoreInstance,\n} from '../../Guard/core/hooks/useMultipleAccounts'\nimport { GuardModuleType } from '../../Guard'\n\ninterface MultipleAccountsProps {\n /**\n * 多账号存储实例\n */\n multipleInstance?: StoreInstance\n /**\n * 切换 Guard 方法\n */\n changeModule?: (moduleName: GuardModuleType, initData?: any) => Promise<void>\n /**\n * 切换多账号状态\n */\n referMultipleState?: (\n type: 'login' | 'multiple',\n data?: { account: string; way: LoginWay }\n ) => void\n}\n\nconst MultipleAccountsFC: React.FC<MultipleAccountsProps> = (props) => {\n const [, setState] = useState<number>(0)\n const { multipleInstance, referMultipleState } = props\n\n // 默认只有一个多选实例\n const lists = multipleInstance?.getMemoUser()\n const forceUpdate = useCallback(() => setState(Math.random), [])\n\n if (!lists) {\n // 这里应该额外处理下 其实本质上应该是存在的\n return null\n }\n\n /**\n * 用户手动删除记录的用户\n */\n const handleDelAccount = (id: string) => {\n multipleInstance?.delUserById(id)\n const lists = multipleInstance?.getMemoUser()\n if (lists?.length === 0) {\n // 7.15: 如果仅剩一个需求跳转\n referMultipleState?.('login')\n } else {\n forceUpdate()\n }\n }\n\n /**\n * jump Login Page\n * 点击 li\n * 根据对应不同的内容进行回填上去\n */\n const changeState = (id: string | 'other') => {\n // way && account\n const data = multipleInstance?.getMemoSingleUser(id)\n referMultipleState?.('login', data)\n }\n\n return (\n <SelectPanel\n lists={lists}\n onClick={changeState}\n handleDel={handleDelAccount}\n />\n )\n}\n\nconst MultipleAccounts = React.memo(MultipleAccountsFC)\n\nexport { MultipleAccounts }\n","import { Form, Input, message } from 'antd'\nimport React, { FC, useCallback, useRef } from 'react'\nimport { useGuardAuthClient } from '../../Guard/authClient'\nimport { IconFont } from '../../IconFont'\nimport SubmitButton from '../../SubmitButton'\nimport CustomFormItem from '../../ValidatorRules'\nimport { useGuardEvents } from '../../_utils/context'\nimport { i18n } from '../../_utils/locales'\nimport { ApiCode } from '../../_utils/responseManagement/interface'\nimport { authFlow, ResetAccountBusinessAction } from './businessRequest'\nimport './style.less'\n\nexport const ResetAccountName: FC = () => {\n let submitButtonRef = useRef<any>(null)\n const [form] = Form.useForm()\n const events = useGuardEvents()\n const authClient = useGuardAuthClient()\n\n const onFinish = useCallback(\n async (values) => {\n try {\n const {\n apiCode,\n onGuardHandling,\n message: msg,\n isFlowEnd,\n data,\n } = await authFlow(ResetAccountBusinessAction.ResetName, values)\n\n submitButtonRef.current?.onSpin(false)\n\n if (isFlowEnd) {\n events?.onLogin?.(data, authClient)\n } else if (apiCode === ApiCode.RESET_ACCOUNT_NAME) {\n // 用户名重复\n message.error(msg)\n } else {\n submitButtonRef.current?.onError()\n onGuardHandling?.()\n }\n } catch (error) {}\n },\n [authClient, events]\n )\n\n return (\n <div className=\"g2-view-reset-username\">\n <div className=\"g2-view-reset-username__title\">\n {i18n.t('common.resetAccount.title')}\n </div>\n <Form\n name=\"passworLogin\"\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current?.onError()}\n autoComplete=\"off\"\n form={form}\n >\n <CustomFormItem.UserName>\n <Input\n className=\"authing-g2-input\"\n size=\"large\"\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n placeholder={i18n.t('login.inputUsername')}\n />\n </CustomFormItem.UserName>\n <Form.Item className=\"authing-g2-sumbit-form\">\n <SubmitButton\n text={i18n.t('common.sure')}\n className=\"password\"\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n","import Input, { InputProps } from 'antd/lib/input'\nimport React, { useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { IconFont } from '../../../IconFont'\nimport { InputNumber } from '../../../InputNumber'\nimport { VerifyLoginMethods } from '../../../Type/application'\nimport { useGuardPublicConfig } from '../../../_utils/context'\n\nexport interface InputIdentifyProps extends InputProps {\n methods: VerifyLoginMethods[]\n}\n\nexport const InputIdentify: React.FC<InputIdentifyProps> = (props) => {\n const { methods, ...inputProps } = props\n\n const publicConfig = useGuardPublicConfig()\n\n const { t } = useTranslation()\n\n const verifyCodeMethodsText = useMemo<\n Record<\n VerifyLoginMethods,\n {\n t: string\n sort: number\n }\n >\n >(\n () => ({\n 'email-code': {\n t: t('common.email'),\n sort: 2,\n },\n 'phone-code': {\n t: publicConfig?.internationalSmsConfig?.enabled\n ? t('common.areaCodePhone')\n : t('common.phoneNumber'),\n sort: 1,\n },\n }),\n [publicConfig, t]\n )\n\n const placeholder = useMemo(\n () =>\n t('login.inputAccount', {\n text: methods\n ?.map((item) => verifyCodeMethodsText[item])\n .sort((a, b) => a.sort - b.sort)\n .map((item) => item.t)\n .join(' / '),\n }),\n [methods, t, verifyCodeMethodsText]\n )\n\n const renderInput = useMemo(() => {\n if (methods.length === 1 && methods[0] === 'phone-code') {\n // TODO 开启国际化配置并登录方式为手机号码时\n return (\n <InputNumber maxLength={11} placeholder={placeholder} {...inputProps} />\n )\n }\n\n return (\n <Input\n placeholder={placeholder}\n {...inputProps}\n prefix={\n <IconFont type=\"authing-a-user-line1\" style={{ color: '#878A95' }} />\n }\n />\n )\n }, [inputProps, methods, placeholder])\n\n return <>{renderInput}</>\n}\n","import React, { useCallback, useEffect, useMemo, useRef, useState } from 'react'\nimport { Form } from 'antd'\nimport { useTranslation } from 'react-i18next'\nimport {\n fieldRequiredRule,\n getUserRegisterParams,\n validate,\n} from '../../../_utils'\nimport SubmitButton from '../../../SubmitButton'\nimport { IconFont } from '../../../IconFont'\nimport { Agreements } from '../../../Register/components/Agreements'\nimport { SceneType } from 'authing-js-sdk'\nimport { SendCodeByPhone } from '../../../SendCode/SendCodeByPhone'\nimport {\n useGuardFinallyConfig,\n useGuardHttpClient,\n useGuardInitData,\n useGuardPublicConfig,\n useIsForeignUserpool,\n} from '../../../_utils/context'\nimport { SendCodeByEmail } from '../../../SendCode/SendCodeByEmail'\nimport { FormItemIdentify } from './FormItemIdentify'\nimport { InputIdentify } from './inputIdentify'\nimport './styles.less'\nimport { InputInternationPhone } from './InputInternationPhone'\nimport { parsePhone, useMediaSize } from '../../../_utils/hooks'\nimport { EmailScene, InputMethod } from '../../../Type'\nimport { CodeAction } from '../../../_utils/responseManagement/interface'\nimport { GuardLoginInitData } from '../../interface'\nimport { LoginMethods, RegisterMethods } from '../../../Type/application'\nimport { useLoginMultipleBackFill } from '../../hooks/useLoginMultiple'\nimport { GraphicVerifyCode } from '../withPassword/GraphicVerifyCode'\nimport { getCaptchaUrl } from '../../../_utils/getCaptchaUrl'\n\nconst LoginWithVerifyCode = (props: any) => {\n const publicConfig = useGuardPublicConfig()\n\n const config = useGuardFinallyConfig()\n\n const {\n _firstItemInitialValue = '',\n specifyDefaultLoginMethod,\n _lockMethod,\n } = useGuardInitData<GuardLoginInitData>()\n const {\n agreements,\n methods,\n autoRegister,\n submitButText,\n onLoginFailed,\n onLoginSuccess,\n saveIdentify,\n multipleInstance,\n backfillData,\n } = props\n\n const verifyCodeLength = publicConfig?.verifyCodeLength ?? 4\n\n const { post } = useGuardHttpClient()\n\n const { isPhoneMedia } = useMediaSize()\n\n // 是否开启了国际化短信功能\n const isInternationSms =\n publicConfig?.internationalSmsConfig?.enabled || false\n\n const acceptedAgreements = useRef(false)\n\n const [validated, setValidated] = useState(false)\n\n const [identify, setIdentify] = useState('')\n\n const [currentMethod, setCurrentMethod] = useState<InputMethod>(\n specifyDefaultLoginMethod ? _lockMethod ?? methods[0] : methods[0]\n )\n // 是否仅开启国际化短信\n const [isOnlyInternationSms, setInternationSms] = useState(false)\n // 区号 默认\n const [areaCode, setAreaCode] = useState(\n publicConfig?.internationalSmsConfig?.defaultISOType || 'CN'\n )\n\n const isForeignUserpool = useIsForeignUserpool()\n const [verifyCodeUrl, setVerifyCodeUrl] = useState('')\n\n let [form] = Form.useForm()\n\n const changeMethod = useCallback(\n (v: string) => {\n if (methods.length === 1) return\n if (validate('email', v)) {\n setCurrentMethod(InputMethod.EmailCode)\n } else {\n // 放开手机号校验 方便同时开启邮箱和短信国际化手机号通过\n setCurrentMethod(InputMethod.PhoneCode)\n }\n },\n [methods.length]\n )\n\n const changeCurrentMethod = useCallback(\n (v: string) => {\n setIdentify(v)\n changeMethod(v)\n },\n [changeMethod]\n )\n\n useLoginMultipleBackFill({\n form,\n way: LoginMethods.PhoneCode,\n formKey: 'identify',\n backfillData,\n isOnlyInternationSms,\n setAreaCode,\n cancelBackfill: specifyDefaultLoginMethod === LoginMethods.PhoneCode,\n changeCurrentMethod,\n })\n\n let submitButtonRef = useRef<any>(null)\n const { t } = useTranslation()\n\n const SendCode = useCallback(\n (props: any) => {\n if (isOnlyInternationSms) {\n return (\n <SendCodeByPhone\n {...props}\n form={form}\n fieldName=\"identify\"\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('common.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n areaCode={areaCode}\n prefix={\n <IconFont\n type=\"authing-a-shield-check-line1\"\n style={{ color: '#878A95' }}\n />\n }\n isInternationSms={isInternationSms}\n scene={SceneType.SCENE_TYPE_LOGIN}\n maxLength={verifyCodeLength}\n onSendCodeBefore={async () => {\n await form.validateFields(['identify'])\n await form.validateFields(['captchaCode'])\n }}\n />\n )\n }\n\n return (\n <>\n {currentMethod === InputMethod.PhoneCode && (\n <SendCodeByPhone\n {...props}\n isInternationSms={isInternationSms}\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('common.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n areaCode={areaCode}\n prefix={\n <IconFont\n type=\"authing-a-shield-check-line1\"\n style={{ color: '#878A95' }}\n />\n }\n scene={SceneType.SCENE_TYPE_LOGIN}\n maxLength={verifyCodeLength}\n form={form}\n fieldName={'identify'}\n data={identify}\n codeFieldName={'captchaCode'}\n onSendCodeBefore={async () => {\n await form.validateFields(['identify'])\n await form.validateFields(['captchaCode'])\n }}\n />\n )}\n {currentMethod === InputMethod.EmailCode && (\n <SendCodeByEmail\n {...props}\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('common.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n prefix={\n <IconFont\n type=\"authing-a-shield-check-line1\"\n style={{ color: '#878A95' }}\n />\n }\n form={form}\n fieldName={'identify'}\n scene={EmailScene.LOGIN_VERIFY_CODE}\n maxLength={verifyCodeLength}\n data={identify}\n onSendCodeBefore={async () => {\n await form.validateFields(['identify'])\n }}\n />\n )}\n </>\n )\n },\n [\n areaCode,\n currentMethod,\n form,\n identify,\n isInternationSms,\n isOnlyInternationSms,\n t,\n verifyCodeLength,\n ]\n )\n\n useEffect(() => {\n // 开启国际化配置且登录方式为手机号码时\n if (\n methods.length === 1 &&\n methods[0] === 'phone-code' &&\n publicConfig &&\n publicConfig.internationalSmsConfig?.enabled\n ) {\n setInternationSms(true)\n }\n }, [publicConfig, methods])\n\n useEffect(() => {\n /** 如果是国外用户池,那么有图形验证码,需要请求图片 */\n if (isForeignUserpool) {\n setVerifyCodeUrl(getCaptchaUrl(config.host!))\n }\n }, [isForeignUserpool, config?.host])\n\n useEffect(() => {\n // 方法发生变化时,图像验证码数据应该清空\n if (isForeignUserpool) {\n form?.setFieldsValue({ captchaCode: undefined })\n }\n }, [form, currentMethod, isForeignUserpool])\n\n const loginByPhoneCode = async (values: any) => {\n const reqContent: any = {\n phone: values.phoneNumber,\n code: values.code,\n customData: config?.isHost\n ? getUserRegisterParams(['login_page_context'])\n : undefined,\n autoRegister: autoRegister,\n withCustomData: false,\n }\n\n if (publicConfig && publicConfig.internationalSmsConfig?.enabled)\n reqContent.phoneCountryCode = values.phoneCountryCode\n\n const { code, data, onGuardHandling } = await post(\n '/api/v2/login/phone-code',\n reqContent\n )\n\n submitButtonRef.current?.onSpin(false)\n\n if (code === 200) {\n // props.onLogin(200, data)\n onLoginSuccess(data)\n } else {\n const handMode = onGuardHandling?.()\n // 向上层抛出错误\n handMode === CodeAction.RENDER_MESSAGE && onLoginFailed(code, data)\n }\n }\n\n // 邮箱验证码登录\n const loginByEmailCode = async (values: any) => {\n const reqContent = {\n email: values.identify,\n code: values.code,\n customData: config?.isHost\n ? getUserRegisterParams(['login_page_context'])\n : undefined,\n autoRegister: autoRegister,\n withCustomData: false,\n }\n const { code, data, onGuardHandling } = await post(\n '/api/v2/login/email-code',\n reqContent\n )\n\n submitButtonRef.current?.onSpin(false)\n\n if (code === 200) {\n // props.onLogin(200, data)\n onLoginSuccess(data)\n } else {\n const handMode = onGuardHandling?.()\n // 向上层抛出错误\n handMode === CodeAction.RENDER_MESSAGE && onLoginFailed(code, data)\n }\n }\n\n const onFinish = async (values: any) => {\n setValidated(true)\n if (agreements?.length && !acceptedAgreements.current) {\n // message.error(t('common.loginProtocolTips'))\n submitButtonRef.current.onError()\n return\n }\n // 解析手机号码 ==> 输出 phoenNumber 和 phoneCountryCode\n const { phoneNumber, countryCode: phoneCountryCode } = parsePhone(\n isInternationSms,\n values.identify,\n areaCode\n )\n // onBeforeLogin\n submitButtonRef.current?.onSpin(true)\n\n let loginInfo = {\n type: currentMethod,\n data: {\n identity: phoneNumber,\n code: values.code,\n phoneCountryCode,\n },\n }\n\n let context = await props.onBeforeLogin?.(loginInfo)\n\n if (!context && !!props.onBeforeLogin) {\n submitButtonRef.current?.onSpin(false)\n return\n }\n // 身份源绑定\n if (!!props.onLoginRequest) {\n const res = await props.onLoginRequest?.(loginInfo)\n const { code, apiCode, data, onGuardHandling } = res\n\n submitButtonRef.current?.onSpin(false)\n if (code === 200) {\n onLoginSuccess(data)\n } else {\n const handMode = onGuardHandling?.()\n // 向上层抛出错误 执行绑定失败钩子\n handMode === CodeAction.RENDER_MESSAGE &&\n onLoginFailed(apiCode ?? code, data)\n }\n return\n }\n\n // 其实这里应该是保存两个 一个是 countryCode 一个是对应的 code\n multipleInstance &&\n multipleInstance.setLoginWay(\n 'input',\n currentMethod === 'phone-code' ? 'phone-code' : 'email-code',\n undefined,\n isInternationSms\n ? {\n phoneCountryCode,\n areaCode,\n }\n : undefined\n )\n\n if (currentMethod === 'phone-code') {\n await loginByPhoneCode({ ...values, phoneNumber, phoneCountryCode })\n } else {\n await loginByEmailCode(values)\n }\n }\n\n const submitText = useMemo(() => {\n if (submitButText) return submitButText\n\n return autoRegister &&\n !publicConfig.registerDisabled &&\n config.registerMethods?.filter((item) =>\n // @ts-ignore\n [RegisterMethods.Phone, RegisterMethods.EmailCode].includes(item)\n )?.length\n ? `${t('common.login')} / ${t('common.register')}`\n : t('common.login')\n }, [\n autoRegister,\n submitButText,\n t,\n config.registerMethods,\n publicConfig.registerDisabled,\n ])\n // 为了 refresh input\n const AreaCodePhoneAccount = useCallback(\n (props: any) => {\n return (\n <InputInternationPhone\n {...props}\n className=\"authing-g2-input\"\n size=\"large\"\n areaCode={areaCode}\n onAreaCodeChange={(value: string) => {\n setAreaCode(value)\n form.getFieldValue(['identify']) &&\n form.validateFields(['identify'])\n }}\n />\n )\n },\n [areaCode, form]\n )\n\n const formValuesChange = (changedValues: Record<string, any>) => {\n if (changedValues?.identify && saveIdentify) {\n saveIdentify(LoginMethods.PhoneCode, changedValues?.identify)\n }\n }\n\n return (\n <div className=\"authing-g2-login-phone-code\">\n <Form\n name=\"phoneCode\"\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current.onError()}\n autoComplete=\"off\"\n onValuesChange={formValuesChange}\n >\n <FormItemIdentify\n initialValue={\n specifyDefaultLoginMethod === LoginMethods.PhoneCode\n ? _firstItemInitialValue\n : ''\n }\n name=\"identify\"\n className={\n isOnlyInternationSms\n ? 'authing-g2-input-form remove-padding'\n : 'authing-g2-input-form'\n }\n methods={methods}\n checkExist={!autoRegister}\n currentMethod={currentMethod}\n areaCode={areaCode}\n >\n {isOnlyInternationSms ? (\n <AreaCodePhoneAccount autoFocus={!isPhoneMedia} />\n ) : (\n <InputIdentify\n className=\"authing-g2-input\"\n size=\"large\"\n autoFocus={!isPhoneMedia}\n value={identify}\n methods={methods}\n onChange={(e) => {\n let v = e.target.value\n changeMethod(v)\n }}\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n )}\n </FormItemIdentify>\n\n {/* 图形验证码 国外用户池并且是手机号 */}\n {isForeignUserpool && currentMethod === InputMethod.PhoneCode && (\n <Form.Item\n className=\"authing-g2-input-form\"\n validateTrigger={['onBlur', 'onChange']}\n name=\"captchaCode\"\n rules={fieldRequiredRule(t('common.captchaCode'))}\n >\n <GraphicVerifyCode\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputCaptchaCode')}\n verifyCodeUrl={verifyCodeUrl}\n changeCode={() => setVerifyCodeUrl(getCaptchaUrl(config.host!))}\n />\n </Form.Item>\n )}\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"code\"\n rules={[...fieldRequiredRule(t('common.captchaCode'))]}\n >\n <SendCode />\n </Form.Item>\n {Boolean(agreements?.length) && (\n <Agreements\n onChange={(val) => {\n acceptedAgreements.current = val\n }}\n agreements={agreements}\n showError={validated}\n />\n )}\n <Form.Item className=\"authing-g2-sumbit-form\">\n <SubmitButton\n text={submitText}\n className=\"password\"\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n\nexport { LoginWithVerifyCode }\n","import { Select } from 'antd'\nimport React from 'react'\n\nimport { SelectorOptions, Selector } from './types'\n\ninterface PushLoginGuideSelectorProps {\n defaultValue: Selector\n onChange: (value: Selector) => void\n options: SelectorOptions\n}\n\nexport function PushLoginGuideSelector(props: PushLoginGuideSelectorProps) {\n const { defaultValue, onChange, options } = props\n\n return (\n <Select\n defaultValue={defaultValue}\n onChange={onChange}\n options={options}\n dropdownMatchSelectWidth={false}\n showArrow={true}\n />\n )\n}\n","import React, { CSSProperties, ReactNode, useEffect, useState } from 'react'\n\ninterface LazyloadImageProps {\n src: string\n placeholder: ReactNode\n className?: string\n style?: CSSProperties\n alt?: string\n width?: string\n height?: string\n}\n\nexport function LazyloadImage(props: LazyloadImageProps) {\n const { src, placeholder, className, style, alt, width, height } = props\n\n const [loadStatus, setLoadStatus] = useState<boolean>(false)\n\n const image = new Image(0, 0)\n\n image.src = src\n\n useEffect(() => {\n image.onload = () => {\n setLoadStatus(true)\n }\n })\n\n return (\n <>\n {(loadStatus && (\n <img\n src={src}\n width={width}\n height={height}\n className={className}\n style={style}\n alt={alt}\n />\n )) ||\n placeholder}\n </>\n )\n}\n","import React, { useMemo } from 'react'\n\nimport { Spin } from 'antd'\n\nimport { useTranslation } from 'react-i18next'\n\nimport { LazyloadImage } from '../../../LazyloadImage'\nimport {\n useGuardAppId,\n useGuardFinallyConfig,\n useGuardPublicConfig,\n} from '../../../_utils/context'\n\nimport { QRCodeSVG } from 'qrcode.react'\n\nexport function HowBindClient() {\n const { t } = useTranslation()\n\n const config = useGuardFinallyConfig()\n\n const publicConfig = useGuardPublicConfig()\n\n const appId = useGuardAppId()\n\n const qrcodeInfo = useMemo(() => {\n const data = {\n appId,\n appHost: config.host,\n scene: 'APP_OPTIONS',\n userPoolId: publicConfig.userPoolId,\n }\n return JSON.stringify(data)\n }, [config, appId])\n\n return (\n <>\n <div className=\"guide-step\">\n <div className=\"title\">\n <span className=\"dot\"></span>\n <span>1. {t('login.installAuthingToken')}</span>\n </div>\n <div className=\"desc\">{t('login.downloadAuthingToken')}</div>\n <div className=\"qrcode-container space-between\">\n <div className=\"qrcode-app grey-bg\">\n <LazyloadImage\n src=\"https://cdn.authing.co/authing-assets/qrcode-download-android.png\"\n placeholder={<Spin />}\n className=\"qrcode-verifier download-app\"\n alt={t('login.downloadAndroid')}\n ></LazyloadImage>\n <div className=\"qrcode-tips\">{t('login.downloadAndroid')}</div>\n </div>\n <div className=\"qrcode-app grey-bg\">\n <LazyloadImage\n src=\"https://cdn.authing.co/authing-assets/qrcode-download-ios.png\"\n placeholder={<Spin />}\n className=\"qrcode-verifier download-app\"\n alt={t('login.downloadIOS')}\n ></LazyloadImage>\n <div className=\"qrcode-tips\">{t('login.downloadIOS')}</div>\n </div>\n </div>\n </div>\n\n <div className=\"guide-step\">\n <div className=\"title\">\n <span className=\"dot\"></span>\n <span>2. {t('login.openAppList')}</span>\n </div>\n <div className=\"desc\">{t('login.addApp')}</div>\n <LazyloadImage\n src=\"https://files.authing.co/authing-guard/push-login-open-application-list.svg\"\n placeholder={<Spin />}\n className=\"qrcode-verifier\"\n alt={t('login.downloadIOS')}\n ></LazyloadImage>\n </div>\n\n <div className=\"guide-step\">\n <div className=\"title\">\n <span className=\"dot\"></span>\n <span>3. {t('login.openLoginPage')}</span>\n </div>\n <div className=\"desc\">{t('login.scanQrcode')}</div>\n <LazyloadImage\n src=\"https://files.authing.co/authing-guard/push-login-open-application.svg\"\n placeholder={<Spin />}\n className=\"qrcode-verifier\"\n alt={t('login.downloadIOS')}\n ></LazyloadImage>\n </div>\n\n <div className=\"guide-step\">\n <div className=\"title\">\n <span className=\"dot\"></span>\n <span>4. {t('login.scanFollowingQrcode')}</span>\n </div>\n <div\n className=\"qrcode-container center grey-bg\"\n style={{\n marginTop: '16px',\n padding: '25px 0',\n boxSizing: 'border-box',\n }}\n >\n <QRCodeSVG\n size={80}\n value={qrcodeInfo}\n style={{ padding: '5px', backgroundColor: '#fff' }}\n ></QRCodeSVG>\n </div>\n </div>\n\n <div className=\"guide-step\">\n <div className=\"title\">\n <span className=\"dot\"></span>\n <span>5. {t('login.relevanceApp')}</span>\n </div>\n <div className=\"desc\">{t('login.receiveMessageFromAuthingToken')}</div>\n <div className=\"qrcode-container center grey-bg\">\n <LazyloadImage\n src=\"https://files.authing.co/authing-guard/push-login-relevance-application.svg\"\n placeholder={<Spin />}\n className=\"qrcode-verifier\"\n alt={t('login.receiveMessageFromAuthingToken')}\n ></LazyloadImage>\n </div>\n </div>\n </>\n )\n}\n","import { Spin } from 'antd'\nimport React from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { LazyloadImage } from '../../../LazyloadImage'\n\nexport function HowUsePushLogin() {\n const { t } = useTranslation()\n\n return (\n <>\n <div className=\"guide-step\">\n <div className=\"title\">\n <span className=\"dot\"></span>\n <span>1. {t('login.inputAccountInWeb')}</span>\n </div>\n <div className=\"desc\">{t('login.clickLoginButton')}</div>\n <div className=\"qrcode-container center grey\">\n <LazyloadImage\n src=\"https://files.authing.co/authing-guard/push-login-input-account.svg\"\n placeholder={<Spin />}\n className=\"qrcode-verifier\"\n alt={t('login.clickLoginButton')}\n ></LazyloadImage>\n </div>\n </div>\n\n <div className=\"guide-step\">\n <div className=\"title\">\n <span className=\"dot\"></span>\n <span>2. {t('login.receiveMessageInApp')}</span>\n </div>\n <div className=\"desc\">{t('login.confirmLoginInApp')}</div>\n <div className=\"qrcode-container center grey\">\n <LazyloadImage\n src=\"https://files.authing.co/authing-guard/push-login-receive-message-in-app.svg\"\n placeholder={<Spin />}\n className=\"qrcode-verifier\"\n alt={t('login.confirmLoginInApp')}\n ></LazyloadImage>\n </div>\n </div>\n </>\n )\n}\n","import React from 'react'\n\nimport { Spin } from 'antd'\n\nimport { useTranslation } from 'react-i18next'\n\nimport { LazyloadImage } from '../../../LazyloadImage'\n\nexport function HowGetAppLoginUrl() {\n const { t } = useTranslation()\n\n return (\n <>\n <div className=\"guide-step\">\n <div className=\"title\">\n <span className=\"dot\"></span>\n <span>1. {t('login.getCodeFromAdmin')}</span>\n </div>\n <div className=\"desc\">{t('login.getCodeFromAdminTips')}</div>\n <div className=\"qrcode-container center grey\">\n <LazyloadImage\n src=\"https://files.authing.co/authing-guard/push-login-get-associated-qrcode-from-admin.svg\"\n placeholder={<Spin />}\n className=\"qrcode-verifier\"\n alt={t('login.getCodeFromAdmin')}\n ></LazyloadImage>\n </div>\n </div>\n\n <div className=\"guide-step\">\n <div className=\"title\">\n <span className=\"dot\"></span>\n <span>2. {t('login.getCodeFromPersonalCenter')}</span>\n </div>\n <div className=\"desc\">{t('login.getCodeFromPersonalCenterTips')}</div>\n <div className=\"qrcode-container center grey\">\n <LazyloadImage\n src=\"https://files.authing.co/authing-guard/push-login-get-code-from-personal.svg\"\n placeholder={<Spin />}\n className=\"qrcode-verifier\"\n alt={t('login.getCodeFromPersonalCenter')}\n ></LazyloadImage>\n </div>\n </div>\n\n <div className=\"guide-step\">\n <div className=\"title\">\n <span className=\"dot\"></span>\n <span>3. {t('login.getLoginUrlFromConsole')}</span>\n </div>\n <div className=\"desc\">{t('login.getLoginUrlFromConsoleTips')}</div>\n <div className=\"qrcode-container center grey\">\n <LazyloadImage\n src=\"https://files.authing.co/authing-guard/push-login-get-login-url-from-console.png\"\n placeholder={<Spin />}\n className=\"qrcode-verifier\"\n alt={t('login.getLoginUrlFromConsole')}\n ></LazyloadImage>\n </div>\n </div>\n </>\n )\n}\n","import React, { useMemo, useState } from 'react'\n\nimport { Drawer } from 'antd'\n\nimport { useTranslation } from 'react-i18next'\n\nimport { PushLoginGuideSelector } from './PushLoginGuideSelector'\n\nimport { HowBindClient } from './HowBindClient'\nimport { HowUsePushLogin } from './HowUsePushLogin'\nimport { HowGetAppLoginUrl } from './HowGetAppLoginUrl'\n\nimport {\n PushLoginGudeModalProps,\n Selector,\n SelectorOption,\n SelectorOptions,\n} from './types'\nimport { useMediaSize } from '../../../_utils/hooks'\nimport { IconFont } from '../../../IconFont'\n\nexport function PushLoginGudeModal(props: PushLoginGudeModalProps) {\n const { visible, onClose } = props\n\n const { t } = useTranslation()\n\n const howBindClient = t('login.howBindClient')\n const howGetAppLoginUrl = t('login.howGetAppLoginUrl')\n const howUsePushLogin = t('login.howUsePushLogin')\n\n const [selector, setSelector] = useState<Selector>('howUsePushLogin')\n\n const { isPhoneMedia } = useMediaSize()\n\n const selectorOptions = useMemo<SelectorOptions>(() => {\n return [\n {\n value: 'howUsePushLogin',\n label: howUsePushLogin,\n },\n {\n value: 'howBindClient',\n label: howBindClient,\n },\n {\n value: 'howGetAppLoginUrl',\n label: howGetAppLoginUrl,\n },\n ]\n }, [howUsePushLogin, howBindClient, howGetAppLoginUrl])\n\n const onSelectorChange = (value: Selector) => {\n const selector = selectorOptions.find(\n (option: SelectorOption) => option.value === value\n )\n if (selector) {\n setSelector(selector.value)\n }\n }\n\n const componentMap = {\n howBindClient: <HowBindClient />,\n howGetAppLoginUrl: <HowGetAppLoginUrl />,\n howUsePushLogin: <HowUsePushLogin />,\n }\n\n return (\n <Drawer\n title={\n <PushLoginGuideSelector\n defaultValue=\"howUsePushLogin\"\n onChange={onSelectorChange}\n options={selectorOptions}\n />\n }\n placement=\"right\"\n onClose={onClose}\n visible={visible}\n width={isPhoneMedia ? '375' : '640'}\n closeIcon={<IconFont type=\"authing-close-line\" />}\n >\n {componentMap[selector]}\n </Drawer>\n )\n}\n","import React, { useMemo, useRef, useState } from 'react'\n\nimport { Form, Input, message } from 'antd'\n\nimport { IconFont } from '../../../IconFont'\n\nimport { useMediaSize } from '../../../_utils/hooks'\n\nimport SubmitButton from '../../../SubmitButton'\n\nimport { OnPushSuccessProps, OnLoginProps } from './types'\n\nimport { AuthingGuardResponse } from '../../../_utils/http'\n\nimport { useTranslation } from 'react-i18next'\n\nimport {\n useGuardDefaultLanguage,\n useGuardFinallyConfig,\n useGuardPublicConfig,\n} from '../../../_utils/context'\n\nimport { getSortLabels } from '../../../_utils'\n\nimport { Agreement, TabFieldsI18nItem } from '../../../Type'\n\nimport { Agreements } from '../../../Register/components/Agreements'\n\nimport { PushLoginGudeModal } from './PushLoginGuideModal'\n\ninterface BeforeLoginProps {\n onPushSuccess: (props: OnPushSuccessProps) => void\n signinByPush: (\n props: OnLoginProps\n ) => Promise<\n AuthingGuardResponse<{\n pushCodeId: string\n }>\n >\n pushLoginStatus: boolean\n onchangePushLoginStatus: () => void\n defaultAccount: string\n setAccount: React.Dispatch<any>\n agreements: Agreement[]\n}\n\nexport function BeforeLogin(props: BeforeLoginProps) {\n const {\n onPushSuccess,\n signinByPush,\n pushLoginStatus,\n setAccount,\n agreements,\n } = props\n\n const { isPhoneMedia } = useMediaSize()\n\n const { t } = useTranslation()\n\n const config = useGuardFinallyConfig()\n\n const publicConfig = useGuardPublicConfig()\n\n const defaultLanguageConfig = useGuardDefaultLanguage()\n\n const [form] = Form.useForm()\n\n const [acceptedAgreements, setAcceptedAgreements] = useState(false)\n\n const [validated, setValidated] = useState(false)\n\n let submitButtonRef = useRef<any>(null)\n\n const i18nFields = useMemo(() => {\n const i18nMap = new Map<string, TabFieldsI18nItem>()\n publicConfig.tabMethodsFields.forEach((item) => {\n i18nMap.set(item.key, item)\n })\n return i18nMap\n }, [publicConfig.tabMethodsFields])\n\n const onPushLogin = async (account: string) => {\n setValidated(true)\n\n if (agreements?.length && !acceptedAgreements) {\n submitButtonRef?.current.onError()\n return\n }\n\n if (!account) {\n return message.error(t('login.enterAccount'))\n }\n\n const { statusCode, message: _message, data } = await signinByPush({\n account,\n })\n\n if (statusCode === 200) {\n setAccount(account)\n onPushSuccess({\n pushCodeId: data?.pushCodeId || '',\n })\n } else {\n message.error(_message)\n }\n }\n\n const onFinish = async (values: any) => {\n const { account } = values\n\n onPushLogin(account)\n }\n\n const [visible, setVisible] = useState<boolean>(false)\n\n const onCloseModal = () => {\n setVisible(false)\n }\n\n const openModal = () => {\n setVisible(true)\n }\n\n const placeholder = useMemo(() => {\n const methods =\n publicConfig.authingOtpPushTabConfig?.validLoginMethods || []\n\n // 登录注册合并\n if (config?.autoRegister) {\n return t('login.inputAccount', {\n text: getSortLabels(methods, i18nFields, defaultLanguageConfig),\n })\n }\n\n // 登录注册分页\n return t('login.inputAccount', {\n text: getSortLabels([...methods], i18nFields, defaultLanguageConfig),\n })\n }, [\n config?.autoRegister,\n i18nFields,\n defaultLanguageConfig,\n publicConfig.authingOtpPushTabConfig?.validLoginMethods,\n t,\n ])\n\n return (\n <div>\n {!pushLoginStatus && (\n <div className=\"push-login-error-tips-container\">\n <div className=\"push-login-error-warning-box\">\n <IconFont\n type=\"authing-error-warning-fill1\"\n className=\"icon-push-login-error-warning\"\n />\n <div>{t('login.getOtpLoginRequestAgain')}</div>\n </div>\n <div onClick={props.onchangePushLoginStatus}>\n <IconFont type=\"authing-close-line\" className=\"close-line\" />\n </div>\n </div>\n )}\n <Form onFinish={onFinish} form={form}>\n <Form.Item name=\"account\">\n <Input\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n size=\"large\"\n autoFocus={!isPhoneMedia}\n placeholder={placeholder}\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n {Boolean(agreements?.length) && (\n <Agreements\n agreements={agreements}\n showError={validated}\n onChange={setAcceptedAgreements}\n />\n )}\n <Form.Item className=\"authing-g2-sumbit-form\">\n <SubmitButton\n text={t('login.loginText')}\n htmlType=\"submit\"\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n <div className=\"how-use-push-login\" onClick={openModal}>\n {t('login.howUsePushLogin')}?\n </div>\n <PushLoginGudeModal visible={visible} onClose={onCloseModal} />\n </div>\n )\n}\n","import React from 'react'\n\nimport { Button, Form } from 'antd'\n\nimport './styles.less'\n\nimport { IconFont } from '../../../IconFont'\n\nimport { useTranslation } from 'react-i18next'\n\ninterface PendingLoginProps {\n onCancelLogin: () => void\n}\n\nexport function PendingLogin(props: PendingLoginProps) {\n const onCancelLogin = () => {\n props.onCancelLogin()\n }\n\n const { t } = useTranslation()\n\n return (\n <>\n <div className=\"pending-tips\">\n <div className=\"code-success\">\n <IconFont type=\"authing-checkbox-circle-fill\" />\n </div>\n <div>{t('login.otpLoginPendingText')}</div>\n </div>\n <Form>\n <Form.Item className=\"authing-g2-sumbit-form\">\n <Button\n block\n style={{\n width: '348px',\n height: '44px',\n background: '#F2F3F5',\n borderRadius: '4px',\n border: 'none',\n }}\n onClick={onCancelLogin}\n >\n {t('login.authingOtpPushCancelLogin')}\n </Button>\n </Form.Item>\n </Form>\n </>\n )\n}\n","import React, { useCallback, useEffect, useRef, useState } from 'react'\n\nimport { useGuardHttp } from '../../../_utils/guardHttp'\n\nimport { BeforeLogin } from './BeforeLogin'\n\nimport { PendingLogin } from './PendingLogin'\n\nimport {\n OnPushSuccessProps,\n CheckPushCodeStatusProps,\n OnLoginProps,\n LoginStatus,\n LoginWithAuthingOtpPushProps,\n} from './types'\n\nimport { message } from 'antd'\n\nimport { useGuardPublicConfig } from '../../../_utils/context'\n\nimport { LoginMethods } from '../../../Type/application'\n\nexport function LoginWithAuthingOtpPush(props: LoginWithAuthingOtpPushProps) {\n const { onLoginSuccess, multipleInstance, agreements } = props\n\n const [loginStatus, setLoginStatus] = useState<LoginStatus>('before')\n\n const [pushCodeId, setPushCodeId] = useState<string>('')\n\n const [pushLoginStatus, setPushLoginStatus] = useState<boolean>(true)\n\n const timer = useRef<NodeJS.Timeout | undefined>()\n\n const [account, setAccount] = useState<string>('')\n\n const clearTimer = () => {\n timer.current && clearInterval(timer.current)\n }\n\n const { post, get } = useGuardHttp()\n\n const publicConfig = useGuardPublicConfig()\n\n const onPushSuccess = (props: OnPushSuccessProps) => {\n setLoginStatus('pending')\n setPushCodeId(props.pushCodeId)\n }\n\n const onCancelLogin = useCallback(() => {\n clearTimer()\n setLoginStatus('before')\n }, [])\n\n const onchangePushLoginStatus = useCallback((status: boolean = true) => {\n setPushLoginStatus(status)\n }, [])\n\n const signinByPush = async (props: OnLoginProps) => {\n const { account } = props\n const url = '/api/v3/signin-by-push'\n const body = {\n account,\n }\n return await post(url, body)\n }\n\n const checkPushCodeStatus = useCallback(\n async (props: CheckPushCodeStatusProps) => {\n const { pushCodeId } = props\n const url = `/api/v3/check-pushcode-status?pushCodeId=${pushCodeId}`\n return await get(url)\n },\n [get]\n )\n\n const getUserInfo = useCallback(\n async (accessToken: string) => {\n const url = '/api/v2/users/me/info'\n const config = {\n headers: {\n 'x-authing-userpool-id': publicConfig.userPoolId,\n authorization: `Bearer ${accessToken}`,\n },\n }\n return await get(url, {}, config)\n },\n [get, publicConfig.userPoolId]\n )\n\n const onPushLogin = async () => {\n const { statusCode, data, message: _message } = await checkPushCodeStatus({\n pushCodeId,\n })\n\n if (statusCode !== 200) {\n message.error(_message)\n onCancelLogin()\n return\n }\n\n if (data.status === 'AUTHORIZED') {\n const { access_token } = data.tokenSet\n\n clearTimer()\n\n const { code, data: _userInfo, message } = await getUserInfo(access_token)\n\n if (code === 200) {\n multipleInstance?.setLoginWay('input', LoginMethods.AuthingOtpPush)\n onLoginSuccess(_userInfo, message)\n return\n }\n }\n\n if (data.status !== 'PUSHED') {\n setPushLoginStatus(false)\n onCancelLogin()\n }\n }\n\n useEffect(() => {\n if (!pushCodeId) {\n return\n }\n\n timer.current = setInterval(onPushLogin, 1000)\n\n return () => {\n clearTimer()\n }\n }, [\n pushCodeId,\n checkPushCodeStatus,\n getUserInfo,\n onLoginSuccess,\n onCancelLogin,\n ])\n\n const loginStatusMap = {\n before: (\n <BeforeLogin\n defaultAccount={account}\n setAccount={setAccount}\n onPushSuccess={onPushSuccess}\n signinByPush={signinByPush}\n pushLoginStatus={pushLoginStatus}\n onchangePushLoginStatus={onchangePushLoginStatus}\n agreements={agreements}\n />\n ),\n pending: <PendingLogin onCancelLogin={onCancelLogin} />,\n }\n\n return <div>{loginStatusMap[loginStatus]}</div>\n}\n","import React, {\n useEffect,\n useLayoutEffect,\n useState,\n useRef,\n useMemo,\n useCallback,\n FC,\n} from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { message, Popover, Tabs, Tag, Tooltip } from 'antd'\nimport intersection from 'lodash/intersection'\n\nimport { LoginWithPassword } from './core/withPassword/index'\nimport { LoginWithLDAP } from './core/withLDAP'\nimport { LoginWithAD } from './core/withAD'\nimport { LoginWithAppQrcode } from './core/withAppQrcode'\nimport { LoginWithWechatMiniQrcode } from './core/withWechatMiniQrcode'\nimport { LoginWithWechatmpQrcode } from './core/withWechatmpQrcode'\nimport { codeMap } from './codemap'\nimport { SocialLogin } from './socialLogin'\nimport { MultipleAccounts } from './multipleAccounts'\nimport { ResetAccountName } from './resetAccountName'\n\nimport { GuardModuleType } from '../Guard/module'\nimport { IconFont } from '../IconFont'\nimport { ChangeLanguage } from '../ChangeLanguage'\nimport { fallbackLng, i18n } from '../_utils/locales'\n\nimport './styles.less'\nimport {\n useGuardAppId,\n useGuardEvents,\n useGuardFinallyConfig,\n useGuardInitData,\n useGuardModule,\n useGuardPublicConfig,\n useGuardTenantProvider,\n} from '../_utils/context'\nimport { getPasswordIdentify, getSortTabs } from '../_utils'\nimport { LoginWithVerifyCode } from './core/withVerifyCode'\nimport { useMediaSize, useMethod } from '../_utils/hooks'\nimport { getGuardDocument } from '../_utils/guardDocument'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport { GuardLoginInitData } from './interface'\nimport { GuardButton } from '../GuardButton'\nimport {\n LoginMethods,\n QrCodeItem,\n VerifyLoginMethods,\n} from '../Type/application'\nimport { useLoginMultiple } from './hooks/useLoginMultiple'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\nimport { LoginWithAuthingOtpPush } from './core/withAuthingOtpPush/index'\n\nconst inputWays = [\n LoginMethods.Password,\n LoginMethods.PhoneCode,\n LoginMethods.AD,\n LoginMethods.LDAP,\n LoginMethods.AuthingOtpPush,\n]\nconst qrcodeWays = [\n LoginMethods.AppQr,\n LoginMethods.WxMinQr,\n LoginMethods.WechatMpQrcode,\n]\n\nconst useMethods = (config: any) => {\n let dlm = config?.defaultLoginMethod\n let propsMethods = config?.loginMethods\n if (!propsMethods?.includes(dlm)) {\n dlm = propsMethods?.[0]\n }\n let renderInputWay = intersection(propsMethods, inputWays).length > 0\n let renderQrcodeWay = intersection(propsMethods, qrcodeWays).length > 0\n return [dlm, renderInputWay, renderQrcodeWay]\n}\n\nconst useDisables = (data: any) => {\n let { disableResetPwd, disableRegister } = data.config\n let { loginWay, autoRegister } = data\n\n if (loginWay === LoginMethods.PhoneCode) {\n disableResetPwd = true\n }\n if ([LoginMethods.LDAP, LoginMethods.AuthingOtpPush].includes(loginWay)) {\n disableResetPwd = true\n disableRegister = true\n }\n if (loginWay === LoginMethods.AD) {\n // TODO P0 需求暂时先取消掉\n // disableResetPwd = true\n disableRegister = true\n }\n if (autoRegister === true) {\n disableRegister = true\n }\n return { disableResetPwd, disableRegister }\n}\n\nconst useSwitchStates = (loginWay: LoginMethods) => {\n let switchText = i18n.t('login.scanLogin')\n if (qrcodeWays.includes(loginWay)) {\n switchText = i18n.t('login.moreWays')\n }\n let inputNone = !inputWays.includes(loginWay) ? 'none' : ''\n let qrcodeNone = !qrcodeWays.includes(loginWay) ? 'none' : ''\n\n return { switchText, inputNone, qrcodeNone }\n}\n\nconst computedTabName = (str: string) => {\n if (str.length > 20) {\n return `${str.substring(0, 20)}...`\n }\n return str\n}\n\nexport const GuardLoginView: FC<{ isResetPage?: boolean }> = ({\n isResetPage = false,\n}) => {\n const { specifyDefaultLoginMethod } = useGuardInitData<GuardLoginInitData>()\n\n const config = useGuardFinallyConfig()\n\n const appId = useGuardAppId()\n\n const { changeModule } = useGuardModule()\n\n const events = useGuardEvents()\n\n const publicConfig = useGuardPublicConfig()\n\n let [defaultMethod, renderInputWay, renderQrcodeWay] = useMethods(config)\n\n const agreementEnabled = config?.agreementEnabled\n\n const { t } = useTranslation()\n\n const [loginWay, setLoginWay] = useState(\n specifyDefaultLoginMethod || defaultMethod\n )\n\n useGuardView({\n currentTab: loginWay,\n changeTab: setLoginWay,\n })\n\n const {\n defaultQrWay,\n backfillData,\n multipleInstance,\n isMultipleAccount,\n referMultipleState,\n } = useLoginMultiple(setLoginWay)\n\n const [canLoop, setCanLoop] = useState(false) // 允许轮询\n\n const client = useGuardAuthClient()\n\n const qrcodeTabsSettings = publicConfig?.qrcodeTabsSettings\n\n const [errorNumber, setErrorNumber] = useState(0)\n\n const [accountLock, setAccountLock] = useState(false)\n\n const identifyRef = useRef<Record<string, string>>({} as any)\n\n const tenantProvider = useGuardTenantProvider()\n\n /** 页面相关标签 */\n const tags = useMemo(() => {\n return ([\n tenantProvider?.isTenantConsole() && {\n name: i18n.t('login.tenant.consoleManage'),\n },\n tenantProvider?.isTenantSSOLaunchPad() && {\n name: t('login.tenant.ssoPad'),\n },\n ] as Array<{\n name: string\n color?: string\n backgroundColor?: string\n }>).filter(Boolean)\n }, [t, tenantProvider])\n\n let publicKey = config?.publicKey!\n\n // let autoRegister = props.config?.autoRegister\n let ms = config?.loginMethods\n\n const firstInputWay = inputWays.filter((way) => ms?.includes(way))[0]\n\n const firstQRcodeWay = qrcodeWays.filter((way) => ms?.includes(way))[0]\n\n let { disableResetPwd, disableRegister } = useDisables({\n config: config,\n loginWay,\n autoRegister: config?.autoRegister,\n })\n\n const hiddenTab = useMemo(() => {\n const scanLogins = ms\n ? ms.filter((method) => qrcodeWays.includes(method))\n : [] //取到扫码登录类型\n if (scanLogins.length > 1) {\n // 如果有两个以上的code 类型\n return false\n } else if (!scanLogins.includes(LoginMethods.AppQr)) {\n // 如果只有一个且那一个还不是 app 类型\n if (\n qrcodeTabsSettings &&\n (qrcodeTabsSettings?.[LoginMethods.WechatMpQrcode].length > 1 ||\n qrcodeTabsSettings?.[LoginMethods.WxMinQr].length > 1)\n ) {\n return false\n } else {\n return true\n }\n } else {\n return true\n }\n }, [ms, qrcodeTabsSettings])\n\n const defaultQrCodeWay = useMemo(() => {\n // 如果存在多账号的二维码方式\n if (defaultQrWay) {\n return defaultQrWay\n }\n if (\n [LoginMethods.WechatMpQrcode, LoginMethods.WxMinQr].includes(\n defaultMethod\n )\n ) {\n const id = qrcodeTabsSettings?.[defaultMethod as LoginMethods]?.find(\n (i: { id: string; title: string; isDefault?: boolean | undefined }) =>\n i.isDefault\n )?.id\n return defaultMethod + id\n } else {\n return defaultMethod\n }\n }, [defaultQrWay, defaultMethod, qrcodeTabsSettings])\n\n const onLoginSuccess = useCallback(\n (data: any, message?: string) => {\n events?.onLogin?.(data, client)\n },\n [client, events]\n )\n\n // 保存用户输入的手机号、邮箱,在点击 问题反馈时带上\n const saveIdentify = useCallback((type: LoginMethods, identity: string) => {\n identifyRef.current = {\n ...identifyRef.current,\n [type]: getPasswordIdentify(identity),\n }\n }, [])\n\n // 重置用户名页面\n useEffect(() => {\n if (isResetPage) {\n message.info({\n content: i18n.t('common.resetAccount.message'),\n className: 'g2-view-message-info',\n })\n }\n }, [isResetPage])\n\n const onLoginFailed = useCallback(\n (code: number, data: any, message?: string) => {\n // TODO 与拦截器中 render-message 同步\n const action = codeMap[code]\n if (action?.action === 'message') {\n setErrorNumber(errorNumber + 1)\n }\n\n if (action?.action === 'accountLock') {\n setAccountLock(true)\n }\n\n events?.onLoginError?.({\n code,\n data,\n message,\n })\n },\n [errorNumber, events]\n )\n\n const onBeforeLogin = useCallback(\n (loginInfo: any) => {\n if (events?.onBeforeLogin) {\n return events?.onBeforeLogin?.(loginInfo, client)\n }\n return () => console.log('Guard not onBeforeLogin hooks')\n },\n [client, events]\n )\n\n useEffect(() => {\n if (qrcodeWays.includes(loginWay)) {\n setCanLoop(true)\n } else {\n setCanLoop(false)\n }\n // 可以设定 = fasle 的时候关闭 qrcode 的几个定时器\n // 不关的话,第二次进入会更快,也没什么代价(只有轮询)\n }, [loginWay])\n\n let { switchText, inputNone, qrcodeNone } = useSwitchStates(loginWay)\n //availableAt 0或者null-注册时,1-登录时,2-注册和登录时 注册登录合并时应该登录注册协议全部显示\n const agreements = useMemo(\n () =>\n agreementEnabled\n ? config?.agreements?.filter(\n (agree) =>\n fallbackLng(i18n.language).find((lng) =>\n lng.includes(agree.lang)\n ) &&\n (config?.autoRegister || !!agree?.availableAt)\n ) ?? []\n : [],\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [agreementEnabled, config?.autoRegister, config?.agreements, i18n.language]\n )\n\n const verifyLoginMethods = useMemo<VerifyLoginMethods[]>(\n () =>\n publicConfig?.verifyCodeTabConfig?.enabledLoginMethods ?? ['phone-code'],\n\n [publicConfig?.verifyCodeTabConfig?.enabledLoginMethods]\n )\n\n const [\n socialConnectionObjs,\n enterpriseConnectionObjs,\n isNoMethod,\n ] = useMethod({ config, publicConfig })\n\n const noLoginMethods = !config?.loginMethods?.length\n\n const { isPhoneMedia } = useMediaSize()\n\n // 渲染前执行\n useLayoutEffect(() => {\n if (noLoginMethods && !isPhoneMedia) {\n // 无表单登录方式,且不是手机端\n const document = getGuardDocument()\n // pc 下\n const containerDOM = document.getElementsByClassName(\n 'g2-view-container'\n )?.[0]\n\n if (containerDOM) {\n // @ts-ignore\n containerDOM.style['min-height'] = isNoMethod ? '456px' : '280px'\n containerDOM.classList.add('no-login-methods-view')\n return () => {\n // @ts-ignore\n containerDOM.style['min-height'] = '540px'\n containerDOM.classList.remove('no-login-methods-view')\n }\n }\n }\n }, [isNoMethod, isPhoneMedia, noLoginMethods])\n\n useEffect(() => {\n const document = getGuardDocument()\n\n const containerDOM = document.getElementsByClassName('g2-view-header')?.[0]\n const innerContainer = document.querySelector(\n '.g2-view-login>.g2-view-container-inner'\n )\n if (isPhoneMedia && noLoginMethods) {\n if (containerDOM) {\n containerDOM.classList.add('g2-view-header-mobile')\n }\n if (innerContainer) {\n innerContainer.classList.add('g2-view-login-mobile-inner')\n }\n } else {\n containerDOM?.classList.remove('g2-view-header-mobile')\n innerContainer?.classList.remove('g2-view-login-mobile-inner')\n }\n return () => {\n containerDOM?.classList.remove('g2-view-header-mobile')\n innerContainer?.classList.remove('g2-view-login-mobile-inner')\n }\n }, [isPhoneMedia, noLoginMethods])\n\n // 获取登录 tab 多语言\n const {\n password: passwordI18n,\n verifyCode: verifyCodeI18n,\n ad: adI18n,\n ldap: ldapI18n,\n } =\n publicConfig?.ssoPageComponentDisplay?.loginMethodsI18nDisplaySettings || {}\n\n const PasswordTab = useMemo(\n () =>\n ms?.includes(LoginMethods.Password) && (\n <Tabs.TabPane\n key={LoginMethods.Password}\n tab={computedTabName(\n passwordI18n?.tab?.i18n?.[i18n.language] ||\n passwordI18n?.tab?.default ||\n t('login.pwdLogin')\n )}\n >\n <LoginWithPassword\n loginWay={loginWay}\n publicKey={publicKey}\n autoRegister={config?.autoRegister}\n host={config?.host}\n // onLogin={onLogin}\n backfillData={backfillData}\n onLoginSuccess={onLoginSuccess}\n onLoginFailed={onLoginFailed}\n onBeforeLogin={onBeforeLogin}\n saveIdentify={saveIdentify}\n passwordLoginMethods={config?.passwordLoginMethods ?? []}\n agreements={agreements}\n multipleInstance={multipleInstance}\n />\n </Tabs.TabPane>\n ),\n [\n agreements,\n ms,\n multipleInstance,\n backfillData,\n config,\n publicKey,\n loginWay,\n onBeforeLogin,\n saveIdentify,\n onLoginFailed,\n onLoginSuccess,\n t,\n passwordI18n,\n ]\n )\n\n const CodeTab = useMemo(\n () =>\n ms?.includes(LoginMethods.PhoneCode) && (\n <Tabs.TabPane\n key={LoginMethods.PhoneCode}\n tab={computedTabName(\n verifyCodeI18n?.tab?.i18n?.[i18n.language] ||\n verifyCodeI18n?.tab?.default ||\n t('common.verifyCodeLogin')\n )}\n >\n <LoginWithVerifyCode\n verifyCodeLength={publicConfig?.verifyCodeLength}\n autoRegister={config?.autoRegister}\n onBeforeLogin={onBeforeLogin}\n // onLogin={onLogin}\n onLoginSuccess={onLoginSuccess}\n onLoginFailed={onLoginFailed}\n saveIdentify={saveIdentify}\n agreements={agreements}\n methods={verifyLoginMethods}\n backfillData={backfillData}\n multipleInstance={multipleInstance}\n />\n </Tabs.TabPane>\n ),\n [\n agreements,\n ms,\n multipleInstance,\n backfillData,\n config,\n onBeforeLogin,\n saveIdentify,\n onLoginFailed,\n onLoginSuccess,\n publicConfig?.verifyCodeLength,\n verifyLoginMethods,\n verifyCodeI18n,\n t,\n ]\n )\n\n const LdapTab = useMemo(\n () =>\n ms?.includes(LoginMethods.LDAP) && (\n <Tabs.TabPane\n key={LoginMethods.LDAP}\n tab={computedTabName(\n ldapI18n?.tab?.i18n?.[i18n.language] ||\n ldapI18n?.tab?.default ||\n t('login.ldapLogin')\n )}\n >\n <LoginWithLDAP\n publicKey={publicKey}\n autoRegister={config?.autoRegister}\n host={config?.host}\n // onLogin={onLogin}\n onLoginSuccess={onLoginSuccess}\n onLoginFailed={onLoginFailed}\n onBeforeLogin={onBeforeLogin}\n agreements={agreements}\n backfillData={backfillData}\n multipleInstance={multipleInstance}\n />\n </Tabs.TabPane>\n ),\n [\n agreements,\n backfillData,\n config?.autoRegister,\n config?.host,\n multipleInstance,\n onBeforeLogin,\n onLoginFailed,\n onLoginSuccess,\n publicKey,\n ms,\n t,\n ldapI18n,\n ]\n )\n\n const ADTab = useMemo(\n () =>\n ms?.includes(LoginMethods.AD) && (\n <Tabs.TabPane\n key={LoginMethods.AD}\n tab={computedTabName(\n adI18n?.tab?.i18n?.[i18n.language] ||\n adI18n?.tab?.default ||\n t('login.adLogin')\n )}\n >\n <LoginWithAD\n backfillData={backfillData}\n multipleInstance={multipleInstance}\n publicKey={publicKey}\n autoRegister={config?.autoRegister}\n // onLogin={onLogin}\n onLoginSuccess={onLoginSuccess}\n onLoginFailed={onLoginFailed}\n onBeforeLogin={onBeforeLogin}\n agreements={agreements}\n />\n </Tabs.TabPane>\n ),\n [\n agreements,\n backfillData,\n config?.autoRegister,\n multipleInstance,\n onBeforeLogin,\n onLoginFailed,\n onLoginSuccess,\n publicKey,\n ms,\n t,\n adI18n,\n ]\n )\n\n const WxMiniQrTab = useCallback(\n (item: QrCodeItem) => {\n return (\n <Tabs.TabPane\n key={LoginMethods.WxMinQr + item.id}\n tab={item.title ?? t('login.scanLogin')}\n >\n <LoginWithWechatMiniQrcode\n id={item.id}\n multipleInstance={multipleInstance}\n onLoginSuccess={onLoginSuccess}\n canLoop={canLoop}\n qrCodeScanOptions={{\n extIdpConnId: item.id,\n }}\n />\n </Tabs.TabPane>\n )\n },\n [canLoop, multipleInstance, onLoginSuccess, t]\n )\n\n const AppQrTab = useCallback(() => {\n return (\n <Tabs.TabPane key={LoginMethods.AppQr} tab={t('login.appScanLogin')}>\n <LoginWithAppQrcode\n multipleInstance={multipleInstance}\n onLoginSuccess={onLoginSuccess}\n canLoop={canLoop}\n />\n </Tabs.TabPane>\n )\n }, [canLoop, multipleInstance, onLoginSuccess, t])\n\n const WechatMpQrTab = useCallback(\n (item: QrCodeItem) => {\n return (\n <Tabs.TabPane\n key={LoginMethods.WechatMpQrcode + item.id}\n tab={item.title ?? t('login.wechatmpQrcode')}\n >\n <LoginWithWechatmpQrcode\n id={item.id}\n multipleInstance={multipleInstance}\n onLoginSuccess={onLoginSuccess}\n canLoop={canLoop}\n qrCodeScanOptions={{\n extIdpConnId: item.id,\n }}\n />\n </Tabs.TabPane>\n )\n },\n [canLoop, multipleInstance, onLoginSuccess, t]\n )\n\n const AuthingOtpPushTab = useMemo(() => {\n return (\n ms?.includes(LoginMethods.AuthingOtpPush) && (\n <Tabs.TabPane\n key={LoginMethods.AuthingOtpPush}\n tab={t('login.authingOtpPushLogin')}\n >\n <LoginWithAuthingOtpPush\n onLoginSuccess={onLoginSuccess}\n multipleInstance={multipleInstance}\n initData={backfillData}\n agreements={agreements}\n ></LoginWithAuthingOtpPush>\n </Tabs.TabPane>\n )\n )\n }, [ms, onLoginSuccess, t, backfillData, multipleInstance, agreements])\n\n // 登录方式对应 tab Component\n const tabMap = useMemo(() => {\n return {\n [LoginMethods.Password]: PasswordTab,\n [LoginMethods.PhoneCode]: CodeTab,\n [LoginMethods.LDAP]: LdapTab,\n [LoginMethods.AD]: ADTab,\n [LoginMethods.AuthingOtpPush]: AuthingOtpPushTab,\n }\n }, [PasswordTab, CodeTab, LdapTab, ADTab, AuthingOtpPushTab])\n\n const GeneralLoginComponent = useMemo(() => {\n const total = ms?.filter((tabName) =>\n [\n LoginMethods.Password,\n LoginMethods.PhoneCode,\n LoginMethods.LDAP,\n LoginMethods.AD,\n LoginMethods.AuthingOtpPush,\n ].includes(tabName)\n )\n\n if (total) {\n return getSortTabs(total, config.defaultLoginMethod ?? '').map(\n (tabName) =>\n tabMap[\n tabName as\n | LoginMethods.Password\n | LoginMethods.PhoneCode\n | LoginMethods.LDAP\n | LoginMethods.AD\n | LoginMethods.AuthingOtpPush\n ]\n )\n }\n return null\n }, [config.defaultLoginMethod, ms, tabMap])\n\n const QrCodeTabMap = useMemo(() => {\n return {\n [LoginMethods.AppQr]: AppQrTab,\n [LoginMethods.WechatMpQrcode]: WechatMpQrTab,\n [LoginMethods.WxMinQr]: WxMiniQrTab,\n }\n }, [AppQrTab, WechatMpQrTab, WxMiniQrTab])\n\n const CodeLoginComponent = useMemo(() => {\n const qrCodeMap: {\n [name: string]: {\n type: LoginMethods.WechatMpQrcode | LoginMethods.WxMinQr\n title: string\n id: string\n }\n } = {}\n\n Object.keys(qrcodeTabsSettings).forEach((key) => {\n qrcodeTabsSettings[key as LoginMethods].forEach((item) => {\n qrCodeMap[item.id] = {\n type: key as LoginMethods.WechatMpQrcode | LoginMethods.WxMinQr,\n title: item.title,\n id: item.id,\n }\n })\n })\n\n const loginMethodsSort =\n publicConfig.qrCodeSortConfig?.loginMethodsSort || []\n\n const sortWithType = (loginMethodsSort || []).map((key) => {\n return {\n key,\n type: qrCodeMap[key]?.type || LoginMethods.AppQr,\n }\n })\n\n const position = sortWithType?.findIndex(\n (item) => item.type === defaultMethod\n )\n\n if (position > 0) {\n const item = loginMethodsSort.splice(position, 1)\n loginMethodsSort.unshift(item[0])\n }\n\n return (loginMethodsSort || []).map((key) => {\n return qrCodeMap[key]\n ? QrCodeTabMap[qrCodeMap[key].type]?.(qrCodeMap[key])\n : QrCodeTabMap[LoginMethods.AppQr]()\n })\n }, [\n QrCodeTabMap,\n qrcodeTabsSettings,\n publicConfig.qrCodeSortConfig?.loginMethodsSort,\n defaultMethod,\n ])\n\n return (\n <div className=\"g2-view-container g2-view-login\">\n <div className=\"g2-view-container-inner\">\n {isNoMethod ? (\n <>\n <div className=\"g2-view-header\">\n <img src={config?.logo} alt=\"\" className=\"icon\" />\n <div className=\"title\">{config?.title}</div>\n {!!publicConfig?.welcomeMessage && (\n <div className=\"title-description\">\n {publicConfig?.welcomeMessage[i18n.language]}\n </div>\n )}\n </div>\n <div className=\"no-login-methods-view\">\n <IconFont\n type=\"authing-bianzu\"\n style={{ width: 178, height: 120 }}\n />\n <span className=\"no-login-methods-desc\">\n {t('login.noLoginMethodsDesc')}\n </span>\n </div>\n </>\n ) : (\n <>\n {/* 两种方式都需要渲染的时候,才出现切换按钮 */}\n {!isMultipleAccount && renderInputWay && renderQrcodeWay && (\n <div className=\"g2-qrcode-switch\">\n {/* <div className=\"switch-text\">{switchText}</div> */}\n <Popover\n placement=\"leftTop\"\n visible={true}\n content={switchText}\n overlayClassName={\n switchText === i18n.t('login.moreWays')\n ? 'long-switch-text'\n : 'switch-text'\n }\n getPopupContainer={(node: any) => {\n if (node) {\n return node.parentElement\n }\n return document.body\n }}\n >\n <div\n className=\"switch-img\"\n onClick={() => {\n message.destroy()\n if (inputWays.includes(loginWay)) {\n setLoginWay(firstQRcodeWay)\n } else if (qrcodeWays.includes(loginWay)) {\n setLoginWay(firstInputWay)\n }\n }}\n >\n <div className=\"imgae-mask\" />\n <IconFont\n type=\"authing-a-erweima22\"\n className={`qrcode-switch-image ${inputNone}`}\n />\n <IconFont\n type=\"authing-diannao\"\n className={`qrcode-switch-image ${qrcodeNone}`}\n />\n </div>\n </Popover>\n </div>\n )}\n <div className=\"g2-view-header\">\n <img src={config?.logo} alt=\"\" className=\"icon\" />\n <div className=\"title\">\n {isMultipleAccount\n ? t('login.selectLoginAccount')\n : config?.title}\n </div>\n {!!publicConfig?.welcomeMessage && (\n <div className=\"title-description\">\n {publicConfig?.welcomeMessage[i18n.language]}\n </div>\n )}\n {/* 提供头部打标签的功能 */}\n {tags?.map?.((it, i) => (\n <Tag\n className=\"authing-header-tag\"\n style={{\n color: it?.color,\n backgroundColor: it?.backgroundColor,\n }}\n key={i}\n >\n {it.name}\n </Tag>\n ))}\n </div>\n {isMultipleAccount ? (\n <MultipleAccounts\n multipleInstance={multipleInstance}\n referMultipleState={referMultipleState}\n changeModule={changeModule}\n />\n ) : (\n <>\n {renderInputWay && (\n <div className={inputNone}>\n {!isResetPage ? (\n <div className={`g2-view-tabs`}>\n <Tabs\n destroyInactiveTabPane={true}\n onChange={(k: any) => {\n setLoginWay(k)\n message.destroy()\n events?.onLoginTabChange?.(k)\n }}\n activeKey={loginWay}\n >\n {GeneralLoginComponent}\n </Tabs>\n </div>\n ) : (\n <ResetAccountName />\n )}\n\n <div className={`g2-tips-line`}>\n {!disableResetPwd && !isResetPage && (\n <div>\n <GuardButton\n type=\"link\"\n className=\"link-like forget-password-link\"\n onClick={() =>\n changeModule?.(GuardModuleType.FORGET_PWD, {})\n }\n >\n {t('login.forgetPwd')}\n </GuardButton>\n {(errorNumber >= 2 || accountLock) && (\n <span style={{ margin: '0 4px', color: '#EAEBEE' }}>\n 丨\n </span>\n )}\n </div>\n )}\n {isResetPage && (\n <GuardButton\n type=\"link\"\n onClick={() => {\n changeModule?.(GuardModuleType.LOGIN)\n }}\n >\n {t('common.backLoginPage')}\n </GuardButton>\n )}\n {(errorNumber >= 2 || accountLock) && (\n <Tooltip title={t('common.feedback')}>\n <div\n className=\"touch-tip question-feedback\"\n onClick={() =>\n changeModule?.(GuardModuleType.ANY_QUESTIONS, {\n identify: identifyRef.current[loginWay],\n })\n }\n >\n <IconFont\n type={'authing-a-question-line1'}\n style={{ fontSize: 16 }}\n />\n </div>\n </Tooltip>\n )}\n\n {!disableRegister && (\n <span className=\"go-to-register\">\n {/* <span className=\"gray\">{t('common.noAccYet')}</span> */}\n <GuardButton\n type=\"link\"\n className=\"link-like register-link\"\n onClick={() =>\n changeModule?.(GuardModuleType.REGISTER, {})\n }\n >\n {t('common.registerImmediate')}\n </GuardButton>\n </span>\n )}\n </div>\n </div>\n )}\n {renderQrcodeWay && (\n <div\n className={`g2-view-tabs ${qrcodeNone} ${\n hiddenTab && 'hidden'\n }`}\n >\n <Tabs\n destroyInactiveTabPane={true}\n defaultActiveKey={defaultQrCodeWay}\n onChange={(k: any) => {\n message.destroy()\n events?.onLoginTabChange?.(k)\n }}\n >\n {CodeLoginComponent}\n </Tabs>\n </div>\n )}\n </>\n )}\n <div className=\"g2-social-login\">\n <SocialLogin\n appId={appId}\n config={config!}\n multipleInstance={multipleInstance}\n // onLogin={onLogin}\n onLoginSuccess={onLoginSuccess}\n onLoginFailed={onLoginFailed}\n socialConnectionObjs={socialConnectionObjs}\n enterpriseConnectionObjs={enterpriseConnectionObjs}\n />\n </div>\n </>\n )}\n </div>\n <ChangeLanguage\n langRange={config?.langRange}\n onLangChange={events?.onLangChange}\n />\n </div>\n )\n}\n","import { useGuardIsAuthFlow } from '../_utils/context'\nimport { getGuardHttp } from '../_utils/guardHttp'\n\nexport enum MfaBusinessAction {\n VerifyEmail = 'verify-email',\n VerifySms = 'verify-sms',\n VerifyTotp = 'verify-totp',\n VerifyFace = 'verify-face',\n AssociateFace = 'associate-face',\n}\n\nexport const authFlow = async (action: MfaBusinessAction, content: any) => {\n const { authFlow } = getGuardHttp()\n\n const res = await authFlow(action, { ...content })\n\n return res\n}\n\ninterface VerifySmsContent {\n phone: string\n code: string\n mfaToken?: string\n phoneCountryCode?: string\n}\n\ninterface VerifyEmailContent {\n email: string\n code: string\n mfaToken?: string\n}\n\ninterface VerifyTotpContent {\n totp: string\n mfaToken?: string\n}\n\ninterface VerifyFaceContent {\n photo: string\n mfaToken?: string\n}\n\ninterface AssociateFaceContent {\n photoA: string\n photoB: string\n isExternalPhoto?: boolean\n mfaToken?: string\n}\n\nexport const VerifyEmail = async (content: VerifyEmailContent) => {\n const { email, code, mfaToken } = content\n const { post } = getGuardHttp()\n\n return await post(\n '/api/v2/applications/mfa/email/verify',\n {\n email,\n code,\n },\n {\n headers: {\n authorization: `Bearer ${mfaToken}`,\n },\n }\n )\n}\n\nexport const VerifySms = async (content: VerifySmsContent) => {\n const { phone, code, mfaToken, phoneCountryCode } = content\n const { post } = getGuardHttp()\n\n return await post(\n '/api/v2/applications/mfa/sms/verify',\n {\n phone,\n code,\n phoneCountryCode,\n },\n {\n headers: {\n authorization: `Bearer ${mfaToken}`,\n },\n }\n )\n}\n\nexport const VerifyTotp = async (content: VerifyTotpContent) => {\n const { totp, mfaToken } = content\n const { post } = getGuardHttp()\n\n return await post(\n '/api/v2/applications/mfa/totp/verify',\n {\n totp,\n },\n {\n headers: {\n authorization: `Bearer ${mfaToken}`,\n },\n }\n )\n}\n\nexport const VerifyFace = async (content: VerifyFaceContent) => {\n const { photo, mfaToken } = content\n const { post } = getGuardHttp()\n\n return await post(\n '/api/v2/applications/mfa/face/verify',\n {\n photo,\n },\n {\n headers: {\n authorization: `Bearer ${mfaToken}`,\n },\n }\n )\n}\n\nexport const AssociateFace = async (content: AssociateFaceContent) => {\n const { photoA, photoB, isExternalPhoto, mfaToken } = content\n const { post } = getGuardHttp()\n\n return await post(\n '/api/v2/mfa/face/associate',\n {\n photoA,\n photoB,\n isExternalPhoto,\n },\n {\n headers: {\n authorization: `Bearer ${mfaToken}`,\n },\n }\n )\n}\n\nexport const useMfaBusinessRequest = () => {\n const isFlow = useGuardIsAuthFlow()\n\n const request = {\n [MfaBusinessAction.VerifyEmail]: (content: VerifyEmailContent) => {\n if (isFlow) {\n return authFlow(MfaBusinessAction.VerifyEmail, content)\n }\n\n return VerifyEmail(content)\n },\n [MfaBusinessAction.VerifySms]: (content: VerifySmsContent) => {\n if (isFlow) {\n return authFlow(MfaBusinessAction.VerifySms, content)\n }\n\n return VerifySms(content)\n },\n [MfaBusinessAction.VerifyTotp]: (content: VerifyTotpContent) => {\n if (isFlow) {\n return authFlow(MfaBusinessAction.VerifyTotp, content)\n }\n\n return VerifyTotp(content)\n },\n [MfaBusinessAction.VerifyFace]: (content: VerifyFaceContent) => {\n if (isFlow) {\n return authFlow(MfaBusinessAction.VerifyFace, content)\n }\n\n return VerifyFace(content)\n },\n [MfaBusinessAction.AssociateFace]: (content: AssociateFaceContent) => {\n if (isFlow) {\n return authFlow(MfaBusinessAction.AssociateFace, content)\n }\n\n return AssociateFace(content)\n },\n }\n\n return request\n}\n","import { GuardModuleType } from '../../Guard/module'\nimport { useGuardModule } from '../context'\nimport { FacePlugin } from './interface'\n\nlet facePluginInstance: FacePlugin\n\nexport const getFacePlugin = () => {\n if (!facePluginInstance) {\n return undefined\n }\n\n return facePluginInstance\n}\n\nexport const useFacePlugin = () => {\n const { changeModule } = useGuardModule()\n\n if (!facePluginInstance) {\n changeModule?.(GuardModuleType.ERROR, {\n error: new Error('为使用 face 模块,请先安装 face-api-guard 插件'),\n })\n\n return undefined\n }\n\n return facePluginInstance\n}\n\nexport const initFacePlugin = (facePlugin: FacePlugin) => {\n facePluginInstance = facePlugin\n\n return facePluginInstance\n}\n","enum FaceErrorName {\n NotAllowedError = 'NotAllowedError',\n AbortError = 'AbortError',\n NotReadableError = 'NotReadableError',\n OverconstrainedError = 'OverconstrainedError',\n SecurityError = 'SecurityError',\n}\nexport interface FaceErrorMessage extends DOMException {\n name: FaceErrorName\n}\nexport const faceErrorMessage = (error: FaceErrorMessage) => {\n let message: string = ''\n switch (error.name) {\n case FaceErrorName.NotAllowedError:\n message = 'login.AuthorizationCamera'\n break\n case FaceErrorName.SecurityError:\n message = 'login.checkPreferences'\n break\n case FaceErrorName.OverconstrainedError:\n message = 'login.requireError'\n break\n default:\n message = 'login.hardwareSupport'\n }\n return message\n}\n","import { Input, message, message as Message } from 'antd'\nimport { Form } from 'antd'\nimport React, { useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { VerifyCodeInput } from '../VerifyCodeInput'\nimport { SendCodeBtn } from '../../SendCode/SendCodeBtn'\nimport SubmitButton from '../../SubmitButton'\nimport CustomFormItem from '../../ValidatorRules'\nimport { MFAConfig } from '../interface'\nimport { VerifyCodeFormItem } from '../VerifyCodeInput/VerifyCodeFormItem'\nimport { IconFont } from '../../IconFont'\nimport { mailDesensitization } from '../../_utils'\nimport { useGuardPublicConfig } from '../../_utils/context'\nimport { MfaBusinessAction, useMfaBusinessRequest } from '../businessRequest'\nimport { EmailScene } from '../../Type'\nimport { getGuardHttp } from '../../_utils/guardHttp'\n\ninterface BindMFAEmailProps {\n mfaToken: string\n onBind: (email: string) => void\n config: any\n}\nexport const BindMFAEmail: React.FC<BindMFAEmailProps> = ({\n mfaToken,\n onBind,\n config,\n}) => {\n const submitButtonRef = useRef<any>(null)\n\n const { t } = useTranslation()\n\n const [form] = Form.useForm()\n\n const onFinish = async ({ email }: any) => {\n await form.validateFields()\n submitButtonRef.current?.onSpin(false)\n try {\n onBind(email)\n } catch (e: any) {\n const error = JSON.parse(e?.message)\n submitButtonRef.current.onError()\n Message.error(error.message)\n }\n }\n return (\n <>\n <p className=\"authing-g2-mfa-title\">{t('common.mfaCertification')}</p>\n <p className=\"authing-g2-mfa-tips\">{t('common.bindEmailDoc')}</p>\n <Form\n form={form}\n onSubmitCapture={() => submitButtonRef.current.onSpin(true)}\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current.onError()}\n >\n <CustomFormItem.Email\n className=\"authing-g2-input-form\"\n name=\"email\"\n form={form}\n // checkRepeat={true}\n required={true}\n >\n <Input\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('login.inputEmail')}\n prefix={\n <IconFont\n type=\"authing-a-mail-line3\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </CustomFormItem.Email>\n\n <SubmitButton text={t('common.sure')} ref={submitButtonRef} />\n </Form>\n </>\n )\n}\n\ninterface VerifyMFAEmailProps {\n email: string\n mfaToken: string\n onVerify: (code: number, data: any) => void\n sendCodeRef: React.RefObject<HTMLButtonElement>\n codeLength: number\n}\n\nexport const VerifyMFAEmail: React.FC<VerifyMFAEmailProps> = ({\n email,\n mfaToken,\n onVerify,\n sendCodeRef,\n codeLength,\n}) => {\n const { post } = getGuardHttp()\n const businessRequest = useMfaBusinessRequest()[MfaBusinessAction.VerifyEmail]\n\n const submitButtonRef = useRef<any>(null)\n\n const { t } = useTranslation()\n\n const [form] = Form.useForm()\n\n const [sent, setSent] = useState(false)\n\n const sendVerifyCode = async () => {\n try {\n const { code, message: tips, apiCode } = await post(\n '/api/v2/email/send',\n {\n email,\n scene: EmailScene.MFA_VERIFY_CODE,\n }\n )\n if (apiCode === 2080) {\n // 一分钟只能发一次邮箱验证码的提示信息,特殊处理\n message.error(tips)\n return false\n }\n if (code === 200) {\n setSent(true)\n return true\n } else {\n message.error(t('login.sendCodeTimeout'))\n return false\n }\n // await authClient.sendEmail(email!, EmailScene.MFA_VERIFY_CODE)\n // setSent(true)\n // return true\n } catch (e: any) {\n if (e.code === 'ECONNABORTED') {\n message.error(t('login.sendCodeTimeout'))\n return false\n }\n const errorMessage = JSON.parse(e.message)\n message.error(errorMessage.message)\n return false\n }\n }\n\n const onFinish = async (values: any) => {\n submitButtonRef.current?.onSpin(true)\n const mfaCode = form.getFieldValue('mfaCode')\n\n const requestData = {\n mfaToken,\n email: email!,\n code: mfaCode.join(''),\n }\n\n const { isFlowEnd, data, onGuardHandling } = await businessRequest(\n requestData\n )\n\n submitButtonRef.current?.onSpin(false)\n\n if (isFlowEnd) {\n onVerify(200, data)\n } else {\n submitButtonRef.current?.onError()\n onGuardHandling?.()\n }\n }\n\n return (\n <>\n <p className=\"authing-g2-mfa-title\">{t('common.mfaCertification')}</p>\n <p className=\"authing-g2-mfa-tips\">\n {sent\n ? `${t('login.verifyCodeSended')} ${mailDesensitization(email)}`\n : t('common.emailMfaCheck')}\n </p>\n <Form\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current?.onError()}\n >\n <VerifyCodeFormItem\n codeLength={codeLength}\n ruleKeyword={t('common.captchaCode')}\n >\n <VerifyCodeInput length={codeLength} onFinish={onFinish} />\n </VerifyCodeFormItem>\n\n <SendCodeBtn\n btnRef={sendCodeRef}\n setSent={setSent}\n beforeSend={() => sendVerifyCode()}\n type=\"link\"\n />\n\n <SubmitButton\n text={t('common.sure')}\n ref={submitButtonRef}\n className=\"g2-mfa-submit-button\"\n />\n </Form>\n </>\n )\n}\n\nexport const MFAEmail: React.FC<{\n mfaToken: string\n email?: string\n mfaLogin: any\n config: MFAConfig\n}> = ({ email: userEmail, mfaToken, mfaLogin, config }) => {\n const [email, setEmail] = useState(userEmail)\n const sendCodeRef = useRef<HTMLButtonElement>(null)\n\n const publicConfig = useGuardPublicConfig()\n\n const codeLength = publicConfig?.verifyCodeLength\n\n return (\n <>\n {email ? (\n <VerifyMFAEmail\n mfaToken={mfaToken}\n email={email}\n onVerify={(code, data) => {\n mfaLogin(code, data)\n }}\n sendCodeRef={sendCodeRef}\n codeLength={codeLength ?? 4}\n />\n ) : (\n <BindMFAEmail\n config={config}\n mfaToken={mfaToken}\n onBind={(email: string) => {\n setEmail(email)\n sendCodeRef.current?.click()\n }}\n />\n )}\n </>\n )\n}\n","import { message } from 'antd'\nimport { Form } from 'antd'\nimport { SceneType } from 'authing-js-sdk'\nimport React, { useCallback, useMemo, useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { VerifyCodeInput } from '../VerifyCodeInput'\nimport { useGuardAuthClient } from '../../Guard/authClient'\nimport { SendCodeBtn } from '../../SendCode/SendCodeBtn'\nimport SubmitButton from '../../SubmitButton'\nimport CustomFormItem from '../../ValidatorRules'\nimport { VerifyCodeFormItem } from '../VerifyCodeInput/VerifyCodeFormItem'\nimport { GuardMFAInitData, MFAConfig } from '../interface'\nimport { InputNumber } from '../../InputNumber'\nimport { IconFont } from '../../IconFont'\nimport { phoneDesensitization } from '../../_utils'\nimport { useGuardPublicConfig } from '../../_utils/context'\nimport { useMfaBusinessRequest, MfaBusinessAction } from '../businessRequest'\nimport { InputInternationPhone } from '../../Login/core/withVerifyCode/InputInternationPhone'\nimport { parsePhone } from '../../_utils/hooks'\nexport interface BindMFASmsProps {\n mfaToken: string\n onBind: (phone: string) => void\n config: any\n areaCode: string\n setAreaCode: (areaCode: string) => void\n isInternationSms: boolean\n}\n\nexport const BindMFASms: React.FC<BindMFASmsProps> = ({\n mfaToken,\n onBind,\n config,\n areaCode,\n setAreaCode,\n isInternationSms,\n}) => {\n const submitButtonRef = useRef<any>(null)\n const { t } = useTranslation()\n const [form] = Form.useForm()\n\n const onFinish = async ({ phone }: any) => {\n await form.validateFields()\n submitButtonRef.current?.onSpin(false)\n try {\n onBind(phone)\n } catch (e) {\n // do nothing\n submitButtonRef.current?.onError()\n }\n }\n\n const PhoneAccount = useCallback(\n (props: any) => {\n if (isInternationSms) {\n return (\n <InputInternationPhone\n {...props}\n className=\"authing-g2-input\"\n size=\"large\"\n areaCode={areaCode}\n onAreaCodeChange={(value: string) => {\n setAreaCode(value)\n form.getFieldValue(['phone']) && form.validateFields(['phone'])\n }}\n maxLength={20}\n />\n )\n } else {\n return (\n <InputNumber\n {...props}\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('login.inputPhone')}\n prefix={\n <IconFont\n type=\"authing-a-smartphone-line1\"\n style={{ color: '#878A95' }}\n />\n }\n maxLength={20}\n />\n )\n }\n },\n [areaCode, form, isInternationSms, setAreaCode, t]\n )\n return (\n <>\n <h3 className=\"authing-g2-mfa-title\">{t('common.mfaCertification')}</h3>\n <p className=\"authing-g2-mfa-tips\">{t('login.bindPhoneInfo')}</p>\n <Form\n form={form}\n onSubmitCapture={() => submitButtonRef.current.onSpin(true)}\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current.onError()}\n >\n <CustomFormItem.Phone\n className={\n isInternationSms\n ? 'authing-g2-input-form remove-padding'\n : 'authing-g2-input-form'\n }\n name=\"phone\"\n form={form}\n // checkRepeat={true}\n required={true}\n areaCode={areaCode}\n >\n <PhoneAccount />\n </CustomFormItem.Phone>\n <SubmitButton text={t('common.sure')} ref={submitButtonRef} />\n </Form>\n </>\n )\n}\n\nexport interface VerifyMFASmsProps {\n mfaToken: string\n phone: string\n onVerify: (code: number, data: any) => void\n sendCodeRef: React.RefObject<HTMLButtonElement>\n codeLength: number\n areaCode: string //绑定选择的\n phoneCountryCode?: string //后端返回的国家区号\n isInternationSms: boolean\n userPhone?: string\n}\n\nexport const VerifyMFASms: React.FC<VerifyMFASmsProps> = ({\n mfaToken,\n phone,\n userPhone,\n onVerify,\n sendCodeRef,\n codeLength = 4,\n areaCode,\n phoneCountryCode,\n isInternationSms,\n}) => {\n const authClient = useGuardAuthClient()\n\n const submitButtonRef = useRef<any>(null)\n\n const { t } = useTranslation()\n\n const [form] = Form.useForm()\n\n const [sent, setSent] = useState<boolean>(false)\n\n const { phoneNumber, countryCode } = parsePhone(\n isInternationSms,\n phone,\n areaCode\n )\n\n const businessRequest = useMfaBusinessRequest()[MfaBusinessAction.VerifySms]\n\n const onFinish = async (values: any) => {\n submitButtonRef.current?.onSpin(true)\n const mfaCode = form.getFieldValue('mfaCode')\n\n const requestData: any = {\n mfaToken,\n phone: phone!,\n code: mfaCode.join(''),\n phoneCountryCode: phoneCountryCode ? phoneCountryCode : countryCode,\n }\n\n const { isFlowEnd, data, onGuardHandling } = await businessRequest(\n requestData\n )\n\n submitButtonRef.current?.onSpin(false)\n\n if (isFlowEnd) {\n onVerify(200, data)\n } else {\n submitButtonRef.current.onError()\n onGuardHandling?.()\n }\n }\n\n const tips = useMemo(\n () =>\n sent\n ? `${t('login.verifyCodeSended')} ${\n isInternationSms\n ? phoneCountryCode\n ? phoneCountryCode\n : countryCode\n : ''\n } ${phoneDesensitization(phone)}`\n : t('common.SmsMfaCheck'),\n [countryCode, isInternationSms, phone, phoneCountryCode, sent, t]\n )\n\n const sendVerifyCode = async () => {\n try {\n await authClient.sendSmsCode(\n userPhone ? userPhone : phoneNumber,\n phoneCountryCode ? phoneCountryCode : countryCode,\n SceneType.SCENE_TYPE_MFA_VERIFY\n )\n return true\n } catch (e: any) {\n if (e.code === 'ECONNABORTED') {\n message.error(t('login.sendCodeTimeout'))\n return false\n }\n const errorMessage = JSON.parse(e.message)\n message.error(errorMessage.message)\n return false\n }\n }\n\n return (\n <>\n <h3 className=\"authing-g2-mfa-title\">{t('common.mfaCertification')}</h3>\n <p className=\"authing-g2-mfa-tips\">{tips}</p>\n <Form\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current.onError()}\n >\n <VerifyCodeFormItem\n codeLength={codeLength}\n ruleKeyword={t('common.captchaCode')}\n >\n <VerifyCodeInput length={codeLength} onFinish={onFinish} />\n </VerifyCodeFormItem>\n\n <SendCodeBtn\n btnRef={sendCodeRef}\n beforeSend={() => sendVerifyCode()}\n type=\"link\"\n setSent={setSent}\n />\n\n <SubmitButton\n text={t('common.sure')}\n ref={submitButtonRef}\n className=\"g2-mfa-submit-button\"\n />\n </Form>\n </>\n )\n}\n\nexport const MFASms: React.FC<{\n // mfaToken: string\n // phone?: string\n mfaLogin: any\n config: MFAConfig\n initData: GuardMFAInitData\n}> = ({\n mfaLogin,\n config,\n initData: {\n mfaPhone: userPhone,\n mfaToken,\n mfaPhoneCountryCode: phoneCountryCode,\n },\n}) => {\n const [phone, setPhone] = useState(userPhone)\n\n const sendCodeRef = useRef<HTMLButtonElement>(null)\n\n const publicConfig = useGuardPublicConfig()\n\n const codeLength = publicConfig?.verifyCodeLength\n const [areaCode, setAreaCode] = useState(\n publicConfig?.internationalSmsConfig?.defaultISOType || 'CN'\n )\n\n const isInternationSms = Boolean(\n publicConfig?.internationalSmsConfig?.enabled\n )\n // todo 后续改 不用 phone 作为判断模式\n return (\n <>\n {phone ? (\n <VerifyMFASms\n mfaToken={mfaToken}\n phone={phone}\n userPhone={userPhone}\n phoneCountryCode={phoneCountryCode}\n isInternationSms={isInternationSms}\n onVerify={(code, data) => {\n mfaLogin(code, data)\n }}\n codeLength={codeLength ?? 4}\n sendCodeRef={sendCodeRef}\n areaCode={areaCode}\n />\n ) : (\n <BindMFASms\n config={config}\n mfaToken={mfaToken}\n areaCode={areaCode}\n setAreaCode={setAreaCode}\n isInternationSms={isInternationSms}\n onBind={(phone: string) => {\n setPhone(phone)\n sendCodeRef.current?.click()\n }}\n />\n )}\n </>\n )\n}\n","import { getFacePlugin } from '../../_utils/facePlugin'\n\nlet inputSize = 512\nlet scoreThreshold = 0.5\n\nexport const devicesConstraints = {\n video: {\n width: 210,\n height: 210,\n },\n}\nexport const FACE_SCORE = 0.65\n\nexport function getFaceDetectorOptions() {\n const facePlugin = getFacePlugin()\n\n if (facePlugin) {\n const { TinyFaceDetectorOptions } = facePlugin\n return new TinyFaceDetectorOptions({ inputSize, scoreThreshold })\n }\n}\n\nexport function getCurrentFaceDetectionNet() {\n const facePlugin = getFacePlugin()\n\n if (facePlugin) {\n const { nets } = facePlugin\n\n return nets.tinyFaceDetector\n }\n}\n\nexport function isFaceDetectionModelLoaded() {\n return !!getCurrentFaceDetectionNet().params\n}\n\nexport function dataURItoBlob(base64Data: any) {\n var byteString\n if (base64Data.split(',')[0].indexOf('base64') >= 0)\n byteString = atob(base64Data.split(',')[1])\n else byteString = unescape(base64Data.split(',')[1])\n var mimeString = base64Data.split(',')[0].split(':')[1].split(';')[0]\n var ia = new Uint8Array(byteString.length)\n for (var i = 0; i < byteString.length; i++) {\n ia[i] = byteString.charCodeAt(i)\n }\n return new Blob([ia], { type: mimeString })\n}\n","import { getGuardHttp } from '../_utils/guardHttp'\n\nexport enum TotpRecoveryCodeBusinessAction {\n RecoveryTotp = 'recovery-totp',\n ConfirmTotpRecoveryCode = 'confirm-totp-recovery-code',\n}\n\nexport async function authFlow<T>(\n action: TotpRecoveryCodeBusinessAction,\n content: any\n) {\n const { authFlow } = getGuardHttp()\n\n const res = await authFlow<T>(action, { ...content })\n\n return res\n}\n","import React, {\n useCallback,\n useContext,\n useEffect,\n useRef,\n useState,\n} from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useGuardHttp } from '../../_utils/guardHttp'\nimport {\n FACE_SCORE,\n devicesConstraints,\n dataURItoBlob,\n getCurrentFaceDetectionNet,\n getFaceDetectorOptions,\n isFaceDetectionModelLoaded,\n} from './face_deps'\nimport { ImagePro } from '../../ImagePro'\nimport SubmitButton from '../../SubmitButton'\nimport { message } from 'antd'\nimport { faceErrorMessage } from '../../_utils/errorFace'\nimport { MFABackStateContext } from '..'\nimport { useGuardButtonState, useGuardPublicConfig } from '../../_utils/context'\nimport { MfaBusinessAction, useMfaBusinessRequest } from '../businessRequest'\nimport { getFacePlugin } from '../../_utils/facePlugin'\n\nconst useDashoffset = (percent: number) => {\n // 接受 0 - 1,返回 0-700 之间的偏移量\n let offset = percent * 7\n\n // 在识别成功的时候,返回绿色\n let dashStyle = {}\n return { offset, dashStyle }\n}\n\nexport const MFAFace = (props: any) => {\n const mfaBackContext = useContext(MFABackStateContext)\n\n let { postForm } = useGuardHttp()\n\n let { t } = useTranslation()\n\n const [faceState, setFaceState] = useState('ready') // ready, identifying, retry\n\n const [percent, setPercent] = useState(0) // 识别进度(相似性)\n\n const mfaBusinessRequest = useMfaBusinessRequest()\n\n const { spinChange } = useGuardButtonState()\n\n const verifyRequest = mfaBusinessRequest[MfaBusinessAction.VerifyFace]\n\n const bindRequest = mfaBusinessRequest[MfaBusinessAction.AssociateFace]\n\n const videoRef = useRef<HTMLVideoElement>(null)\n const canvasRef = useRef<HTMLCanvasElement>(null)\n const interval = useRef<NodeJS.Timeout | undefined>()\n const p1 = useRef<string>() // p1 key\n const p2 = useRef<string>() // p2 key\n const cooldown = useRef<number>(0) // p2 cooldown, * 500ms\n const publicConfig = useGuardPublicConfig()\n\n const cdnBase = publicConfig?.cdnBase\n\n let { offset, dashStyle } = useDashoffset(percent)\n\n const _FACE_SCORE = publicConfig?.mfa?.faceScore ?? FACE_SCORE\n // 预加载数据\n useEffect(() => {\n // 载入 cdn\n getCurrentFaceDetectionNet().loadFromUri(\n `${cdnBase}/face-api/v1/tiny_face_detector_model-weights_manifest.json`\n )\n\n if (faceState !== 'identifying') {\n return // 不存在 video dom,不要去尝试了\n }\n let devicesContext = navigator.mediaDevices.getUserMedia(devicesConstraints)\n devicesContext\n .then((stream) => {\n videoRef.current!.srcObject = stream\n })\n .catch((e) => {\n const msg = faceErrorMessage(e)\n message.error(t(msg))\n\n // 没有设备,或没有授权\n // console.error(e)\n // setVideoType(VideoAction.ERROR)\n // setProgressStatus('exception')\n // setPercent(100)\n // setVideoError(e.message)\n })\n\n return () => {\n interval.current && clearInterval(interval.current)\n }\n }, [faceState, interval, props.config, cdnBase, t])\n\n // 监听 faceState\n useEffect(() => {\n // if (faceState === 'identifying' || faceState === 'retry') {\n // props.setShowMethods(false)\n // } else {\n // props.setShowMethods(true)\n // }\n if (mfaBackContext?.mfaBackState === 'check') {\n props.setShowMethods(false)\n } else {\n props.setShowMethods(true)\n }\n }, [mfaBackContext?.mfaBackState, props])\n\n // 上传文件\n const uploadImage = async (blob: Blob) => {\n spinChange(true)\n const formData = new FormData()\n formData.append('folder', 'photos')\n formData.append('file', blob, 'personal.jpeg')\n\n let url = '/api/v2/upload?folder=photos&private=true'\n let result = await postForm<any>(url, formData)\n let key = result.data?.key\n\n spinChange(false)\n\n return key\n }\n\n // get base 64\n const getBase64 = (videoDom: any) => {\n const canvas = canvasRef.current!\n const ctx = canvas!.getContext('2d')!\n ctx.clearRect(0, 0, canvas.width, canvas.height)\n ctx.drawImage(videoDom, 0, 0, canvas.width, canvas.height)\n const base64Data = canvas.toDataURL('image/jpeg', 1.0)\n return base64Data\n }\n\n const faceBind = async () => {\n const requestData = {\n photoA: p1.current!,\n photoB: p2.current!,\n mfaToken: props.initData.mfaToken,\n }\n const result = await bindRequest(requestData)\n\n const { isFlowEnd, onGuardHandling, code, data } = result\n\n if (isFlowEnd) {\n props.mfaLogin(200, data)\n } else {\n if (code === 1700 || code === 1701 || code === 1702) {\n p1.current = undefined\n\n p2.current = undefined\n\n interval.current = undefined\n\n cooldown.current = 0\n\n setFaceState('retry')\n } else {\n onGuardHandling?.()\n }\n }\n }\n\n const faceCheck = async () => {\n const requestData = {\n photo: p1.current!,\n mfaToken: props.initData.mfaToken,\n }\n\n spinChange(true)\n\n const result = await verifyRequest(requestData)\n\n spinChange(false)\n\n const { isFlowEnd, onGuardHandling, data, code } = result\n\n if (isFlowEnd) {\n props.mfaLogin(200, data)\n } else {\n if (code === 1700 || code === 1701 || code === 1702) {\n p1.current = undefined\n\n p2.current = undefined\n\n interval.current = undefined\n\n cooldown.current = 0\n\n setFaceState('retry')\n } else {\n onGuardHandling?.()\n }\n }\n }\n\n // bind 的情况\n const goToBindScene = (key: string) => {\n if (!p1.current) {\n p1.current = key\n } else {\n if (cooldown.current > 0) {\n cooldown.current -= 1\n }\n if (cooldown.current <= 0) {\n p2.current = key\n // 彻底上传完了,应该走验证了\n interval.current && clearInterval(interval.current)\n faceBind()\n }\n }\n }\n\n // goToCheck 的情况\n const goToCheckScene = (key: string) => {\n p1.current = key\n interval.current && clearInterval(interval.current)\n faceCheck()\n }\n\n // 识别成功,自动前进到下一个步骤\n const quitIdentifying = (blob: Blob) => {\n setPercent(100)\n uploadImage(blob).then((key) => {\n if (props.initData?.faceMfaEnabled === true) {\n goToCheckScene(key)\n } else {\n goToBindScene(key)\n }\n })\n }\n\n const autoShoot = useCallback(async () => {\n if (!interval.current) {\n interval.current = setInterval(() => autoShoot(), 500)\n }\n const videoDom = videoRef.current!\n if (videoDom?.paused || videoDom?.ended || !isFaceDetectionModelLoaded()) {\n return\n }\n const options = getFaceDetectorOptions()\n\n const facePlugin = getFacePlugin()\n\n if (!facePlugin) return\n\n const { detectSingleFace } = facePlugin\n\n const result = await detectSingleFace(videoDom, options)\n\n if (result) {\n if (result.score > _FACE_SCORE) {\n const base64Data = getBase64(videoDom)\n const blob = dataURItoBlob(base64Data)\n quitIdentifying(blob) // 识别成功,退出识别\n } else {\n // 识别失败,但是有结果,设置相似性\n setPercent(() => {\n return (result.score / _FACE_SCORE) * 100\n })\n // ('识别失败,但是有结果,设置相似性', percent)\n }\n } else {\n setPercent(10)\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [])\n\n return (\n <div>\n <h3 className=\"authing-g2-mfa-title\">{t('common.mfaCertification')}</h3>\n {faceState === 'ready' || mfaBackContext?.mfaBackState === 'login' ? (\n <>\n <p className=\"authing-g2-mfa-tips\">\n {props.initData?.faceMfaEnabled\n ? t('common.faceCheck')\n : t('common.faceText2')}\n </p>\n <ImagePro\n className=\"g2-mfa-face-image\"\n width={247}\n height={131}\n src={`${cdnBase}/face.png`}\n alt=\"\"\n />\n\n <SubmitButton\n onClick={() => {\n // 设置状态之前 校验是否支持面容 (api 和 设备)\n // TODO 之后添加人脸识别插件支持 减小包体积\n if (navigator.mediaDevices) {\n setFaceState('identifying')\n mfaBackContext?.setMfaBackState &&\n mfaBackContext.setMfaBackState('check')\n autoShoot()\n } else {\n message.error(t('login.mediaDevicesSupport'))\n }\n }}\n text={t('common.faceText3')}\n className=\"mfa-face\"\n />\n </>\n ) : (\n <p className=\"authing-g2-mfa-tips\">{t('common.faceCheck')}</p>\n )}\n\n <div\n className=\"g2-mfa-face-identifying\"\n style={{\n display:\n faceState !== 'ready' && mfaBackContext?.mfaBackState !== 'login'\n ? 'flex'\n : 'none',\n }}\n >\n <video\n className=\"video-round\"\n ref={videoRef}\n style={{ transform: 'rotateY(180deg)' }}\n // onLoadedMetadata={() => onIdentify()}\n id=\"inputVideo\"\n autoPlay\n muted\n playsInline\n />\n <div\n className=\"video-round mesh\"\n style={{\n display: faceState === 'retry' ? 'flex' : 'none',\n }}\n onClick={() => {\n setFaceState('identifying')\n setPercent(0)\n autoShoot()\n }}\n >\n {t('common.faceText4')}\n </div>\n\n <div className=\"video-round ring\">\n <svg width={240} height={240} fill=\"none\">\n <circle\n className=\"svg-circle-running\"\n style={dashStyle}\n strokeDasharray={700} // 根据周长做 0-700 之间的数值表示准确率\n strokeDashoffset={700 - offset} // 处理这个 offset, 0-700之间的数\n cx={120}\n cy={120}\n r={110}\n />\n </svg>\n </div>\n </div>\n\n <canvas\n style={{\n width: 210,\n height: 210,\n opacity: 0,\n position: 'absolute',\n display: 'none',\n }}\n ref={canvasRef}\n />\n </div>\n )\n}\n","import { Form } from 'antd'\nimport React, { useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useAsyncFn } from 'react-use'\nimport { GuardModuleType } from '../../Guard/module'\nimport { GuardMFAInitData, MFAConfig } from '../interface'\nimport SubmitButton from '../../SubmitButton'\nimport { VerifyCodeFormItem } from '../VerifyCodeInput/VerifyCodeFormItem'\nimport { VerifyCodeInput } from '../VerifyCodeInput'\nimport { IconFont } from '../../IconFont'\nimport { MfaBusinessAction, useMfaBusinessRequest } from '../businessRequest'\nimport { useGuardInitData } from '../../_utils/context'\nimport { GuardButton } from '../../GuardButton'\n\nexport interface BindMFATotpProps {\n initData: GuardMFAInitData\n changeModule: any\n}\n\nexport const BindMFATotp: React.FC<BindMFATotpProps> = ({\n changeModule,\n initData,\n}) => {\n const { t } = useTranslation()\n\n const next = () => changeModule(GuardModuleType.BIND_TOTP, initData)\n return (\n <>\n <p className=\"authing-g2-mfa-title\">{t('common.mfaCertification')}</p>\n <p className=\"authing-g2-mfa-tips\">{t('common.otpText1')}</p>\n\n <div style={{ display: 'flex', justifyContent: 'center' }}>\n <IconFont type=\"authing-otp\" style={{ width: 247, height: 131 }} />\n </div>\n <SubmitButton\n text={t('common.sure')}\n onClick={next}\n className=\"g2-mfa-submit-button bind-totp\"\n />\n </>\n )\n}\n\nexport interface VerifyMFATotpProps {\n mfaToken: string\n mfaLogin: any\n changeModule: any\n}\n\nexport const VerifyMFATotp: React.FC<VerifyMFATotpProps> = ({\n mfaToken,\n mfaLogin,\n changeModule,\n}) => {\n const { t } = useTranslation()\n\n const [form] = Form.useForm()\n\n const submitButtonRef = useRef<any>(null)\n\n const initData = useGuardInitData<GuardMFAInitData>()\n\n const businessRequest = useMfaBusinessRequest()[MfaBusinessAction.VerifyTotp]\n\n const [, onFinish] = useAsyncFn(async () => {\n submitButtonRef.current?.onSpin(true)\n\n const mfaCode = form.getFieldValue('mfaCode')\n\n const requestData = {\n totp: mfaCode.join(''),\n mfaToken,\n }\n\n const { isFlowEnd, data, onGuardHandling } = await businessRequest(\n requestData\n )\n\n submitButtonRef.current?.onSpin(false)\n\n if (isFlowEnd) {\n mfaLogin(200, data)\n } else {\n submitButtonRef.current.onError()\n\n onGuardHandling?.()\n }\n }, [mfaToken])\n\n return (\n <>\n <p className=\"authing-g2-mfa-title\">{t('common.mfaCertification')}</p>\n <p className=\"authing-g2-mfa-tips\">{t('login.inputSixCode')}</p>\n <Form\n form={form}\n onSubmitCapture={() => {}}\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current.onError()}\n >\n <VerifyCodeFormItem codeLength={6}>\n <VerifyCodeInput\n length={6}\n showDivider={false}\n gutter={'10px'}\n onFinish={onFinish}\n />\n </VerifyCodeFormItem>\n\n <SubmitButton text={t('common.sure')} ref={submitButtonRef} />\n <p className=\"authing-g2-mfa-totp-recoveryCode\">\n {t('common.hasLooseSaftyCode')}\n <GuardButton\n type=\"link\"\n onClick={() => {\n changeModule(GuardModuleType.RECOVERY_CODE, {\n ...initData,\n })\n }}\n >\n {t('common.useRecoverCode')}\n </GuardButton>\n </p>\n </Form>\n </>\n )\n}\n\nexport interface MFATotpProps {\n changeModule: any\n config: MFAConfig\n initData: GuardMFAInitData\n mfaLogin: any\n}\n\nexport const MFATotp: React.FC<MFATotpProps> = ({\n changeModule,\n initData,\n mfaLogin,\n}) => {\n return (\n <>\n {initData.totpMfaEnabled ? (\n <VerifyMFATotp\n mfaToken={initData.mfaToken}\n mfaLogin={mfaLogin}\n changeModule={changeModule}\n />\n ) : (\n <BindMFATotp initData={initData} changeModule={changeModule} />\n )}\n </>\n )\n}\n","import React, { useMemo, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { IconFont } from '../../IconFont'\nimport { GuardMFAInitData, MFAType } from '../interface'\nimport { i18n } from '../../_utils/locales'\nimport './style.less'\nimport { useGuardInitData } from '../../_utils/context'\nimport { GuardButton } from '../../GuardButton'\nimport { getFacePlugin } from '../../_utils/facePlugin'\n\nexport interface MFAMethodsProps {\n method: MFAType\n onChangeMethod: (type: MFAType) => void\n}\n\nconst methodTitleMapping: Record<\n MFAType,\n {\n title: () => string\n icon: string\n }\n> = {\n [MFAType.EMAIL]: {\n title: () => i18n.t('common.EmailVerification'),\n icon: 'authing-mail',\n },\n [MFAType.SMS]: {\n title: () => i18n.t('common.SMS'),\n icon: 'authing-phone',\n },\n [MFAType.TOTP]: {\n title: () => i18n.t('common.OTPVerification'),\n icon: 'authing-totp',\n },\n [MFAType.FACE]: {\n title: () => i18n.t('common.faceVerification'),\n icon: 'authing-face',\n },\n}\n\nexport const MFAMethods: React.FC<MFAMethodsProps> = ({\n method,\n onChangeMethod,\n}) => {\n const [currentMethod, setCurrentMethod] = useState(method)\n const { t } = useTranslation()\n\n const { applicationMfa } = useGuardInitData<GuardMFAInitData>()\n\n const otherMethods = useMemo(\n () =>\n applicationMfa\n .filter((item) =>\n Object.keys(methodTitleMapping).includes(item.mfaPolicy)\n )\n .filter((item) => item.mfaPolicy !== currentMethod)\n .filter((item) => {\n if (item.mfaPolicy === MFAType.FACE) {\n const facePlugin = getFacePlugin()\n\n return Boolean(facePlugin)\n }\n\n return true\n })\n .sort((a, b) => a.sort - b.sort)\n .map((item) => (\n <GuardButton\n className=\"g2-guard-mfa-methods-btn\"\n onClick={(e) => {\n onChangeMethod(item.mfaPolicy)\n setCurrentMethod(item.mfaPolicy)\n }}\n key={item.mfaPolicy}\n >\n <IconFont type={methodTitleMapping[item.mfaPolicy].icon} />\n {`${methodTitleMapping[item.mfaPolicy].title()}`}\n </GuardButton>\n )),\n [applicationMfa, currentMethod, onChangeMethod]\n )\n\n return (\n <>\n {otherMethods.length !== 0 && (\n <>\n <div\n style={{\n minHeight: 32,\n }}\n />\n <div className=\"g2-mfa-method\">\n <div className=\"g2-mfa-method-title\">\n {t('login.otherVerifyWay')}\n </div>\n {otherMethods}\n </div>\n </>\n )}\n </>\n )\n}\n","import { GuardModuleAction, GuardModuleType } from '../Guard/module'\n\nexport const codeMap: Record<number, GuardModuleAction> = {\n // 待添加\n 2021: {\n action: 'changeModule',\n module: GuardModuleType.LOGIN,\n },\n 1700: {\n action: 'insideFix',\n message: 'verification failed, let components inside fix is fine.',\n },\n 1701: {\n action: 'insideFix',\n message: 'verification failed, let components inside fix is fine.',\n },\n 1702: {\n action: 'insideFix',\n message: 'verification failed, let components inside fix is fine.',\n },\n 500: {\n action: 'message',\n },\n 6001: {\n action: 'message',\n },\n 602: {\n action: 'message',\n },\n}\n","import React, { useMemo, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { GuardModuleType } from '../Guard/module'\nimport { MFAEmail } from './core/email'\nimport { MFASms } from './core/sms'\nimport { MFAFace } from './core/face'\nimport { MFATotp } from './core/totp'\nimport { MFAMethods } from './mfaMethods'\nimport { GuardMFAInitData, MFAType } from './interface'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport { codeMap } from './codemap'\nimport './styles.less'\nimport { message } from 'antd'\nimport {\n useGuardEvents,\n useGuardFinallyConfig,\n useGuardInitData,\n useGuardModule,\n} from '../_utils/context'\nimport { BackCustom, BackLogin } from '../Back'\nimport { ChangeLanguage } from '../ChangeLanguage'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\ninterface MFABackStateContextType {\n setMfaBackState: React.Dispatch<React.SetStateAction<string>>\n mfaBackState: string\n}\nexport const MFABackStateContext = React.createContext<\n MFABackStateContextType | undefined\n>(undefined)\n\nconst ComponentsMapping: Record<MFAType, (props: any) => React.ReactNode> = {\n [MFAType.EMAIL]: ({ config, initData, mfaLogin }) => (\n <MFAEmail\n config={config}\n mfaToken={initData.mfaToken}\n email={initData.mfaEmail}\n mfaLogin={mfaLogin}\n />\n ),\n [MFAType.SMS]: ({ config, initData, mfaLogin }) => (\n <MFASms config={config} initData={initData} mfaLogin={mfaLogin} />\n ),\n [MFAType.TOTP]: ({ initData, config, changeModule, mfaLogin }) => (\n <MFATotp\n changeModule={changeModule}\n config={config}\n initData={initData}\n mfaLogin={mfaLogin}\n />\n ),\n [MFAType.FACE]: ({ config, initData, mfaLogin, setShowMethods }) => (\n <MFAFace\n config={config}\n initData={initData}\n mfaLogin={mfaLogin}\n setShowMethods={setShowMethods}\n />\n ),\n}\n\nexport const GuardMFAView: React.FC = () => {\n const initData = useGuardInitData<GuardMFAInitData>()\n\n const config = useGuardFinallyConfig()\n\n const { changeModule } = useGuardModule()\n\n useGuardView()\n\n const events = useGuardEvents()\n\n const [currentMethod, setCurrentMethod] = useState(\n initData.current ??\n initData.applicationMfa?.sort((a, b) => a.sort - b.sort)[0].mfaPolicy\n )\n\n const [mfaBackState, setMfaBackState] = useState<string>('login')\n const [showMethods, setShowMethods] = useState(true)\n const client = useGuardAuthClient()\n const { t } = useTranslation()\n\n const __codePaser = (code: number, msg?: string) => {\n const action = codeMap[code]\n\n if (code === 200) {\n return (data: any) => {\n events?.onLogin?.(data, client!) // 登录成功\n }\n }\n\n if (!action) {\n return (data: any) => {\n console.error('not catch code', code)\n // message.error(data.message)\n }\n }\n\n // 解析成功\n if (action?.action === 'changeModule') {\n let m = action.module ? action.module : GuardModuleType.ERROR\n let init = action.initData ? action.initData : {}\n return (initData?: any) => changeModule?.(m, { ...initData, init })\n }\n if (action?.action === 'insideFix') {\n return () => {}\n }\n\n if (action?.action === 'message') {\n return (data: any) => {\n data.message ? message.error(data.message) : message.error(msg)\n }\n }\n\n // 最终结果\n return () => {\n console.error('last action at mfaview')\n }\n }\n\n const mfaLogin = (code: any, data: any, message?: string) => {\n const callback = __codePaser?.(code, message)\n\n if (!data) {\n data = {}\n }\n\n data.__message = message\n\n callback?.(data)\n }\n\n const renderBack = useMemo(() => {\n if (currentMethod === MFAType.FACE && mfaBackState === 'check') {\n return (\n <BackCustom\n onBack={() => {\n setCurrentMethod(\n initData.applicationMfa.find(\n (item) => item.mfaPolicy === MFAType.FACE\n )\n ? MFAType.FACE\n : initData.applicationMfa?.sort((a, b) => a.sort - b.sort)[0]\n .mfaPolicy\n )\n setShowMethods(true)\n setMfaBackState('login')\n }}\n >\n {t('common.backToVerify')}\n </BackCustom>\n )\n }\n\n return <BackLogin />\n }, [currentMethod, initData.applicationMfa, mfaBackState, t])\n\n return (\n // 返回验证页和返回登录页 需要获取内部 face 模式下的状态\n <MFABackStateContext.Provider\n value={{ setMfaBackState: setMfaBackState, mfaBackState: mfaBackState }}\n >\n <div className=\"g2-view-container g2-view-mfa\">\n {renderBack}\n <div className=\"g2-mfa-content\">\n {ComponentsMapping[currentMethod]({\n config: config,\n initData: initData,\n changeModule: changeModule,\n mfaLogin: mfaLogin,\n setShowMethods: setShowMethods,\n })}\n </div>\n {showMethods && (\n <MFAMethods\n method={currentMethod}\n onChangeMethod={(type) => {\n setCurrentMethod(type)\n }}\n />\n )}\n <ChangeLanguage\n langRange={config?.langRange}\n onLangChange={events?.onLangChange}\n />\n </div>\n </MFABackStateContext.Provider>\n )\n}\n","import React, { useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { Form, Input, message, Modal, Progress, Select, Upload } from 'antd'\nimport SubmitButton from '../../SubmitButton'\nimport { PlusOutlined } from '@ant-design/icons'\nimport { UploadFile } from 'antd/lib/upload/interface'\nimport { useGuardHttp } from '../../_utils/guardHttp'\nimport { fieldRequiredRule, validate } from '../../_utils'\nimport { IconFont } from '../../IconFont'\nimport { useGuardInitData } from '../../_utils/context'\ninterface describeQuestionsProps {\n appId: string\n host: string\n onSuccess: any\n}\n\nexport const DescribeQuestions = (props: describeQuestionsProps) => {\n const { t } = useTranslation()\n const initData = useGuardInitData<{ identify: string }>()\n // 不清楚为什么放出去之后,i18n 的结果全是 undefeated\n const typeProblemMap: any = {\n 0: [\n t('common.problem.noVerifyTip.tip'),\n t('common.problem.noVerifyTip.type1'),\n t('common.problem.noVerifyTip.type2'),\n t('common.problem.noVerifyTip.type3'),\n ],\n 1: [\n t('common.problem.noLoginTips'),\n t('common.problem.noLoginTip.type1'),\n t('common.problem.noLoginTip.type2'),\n ],\n 2: [\n t('common.problem.noRegisterTip.tip'),\n t('common.problem.noRegisterTip.type1'),\n t('common.problem.noRegisterTip.type2'),\n t('common.problem.noRegisterTip.type3'),\n ],\n 3: [\n t('common.problem.noAccountTip.tip'),\n t('common.problem.noAccountTip.type1'),\n t('common.problem.noAccountTip.type2'),\n ],\n 4: [\n t('common.problem.noResetPassTip.tip'),\n t('common.problem.noResetPassTip.type1'),\n t('common.problem.noResetPassTip.type2'),\n ],\n 5: [t('common.problem.lockedTips')],\n 6: [],\n }\n\n const typeOperations = [\n {\n label: t('common.problem.noVerify'),\n value: 0,\n },\n {\n label: t('common.problem.noLogin'),\n value: 1,\n },\n {\n label: t('common.problem.noRegister'),\n value: 2,\n },\n {\n label: t('common.problem.noAccount'),\n value: 3,\n },\n {\n label: t('common.problem.noResetPass'),\n value: 4,\n },\n {\n label: t('common.problem.locked'),\n value: 5,\n },\n {\n label: t('common.problem.other'),\n value: 6,\n },\n ]\n\n const [form] = Form.useForm()\n const { post } = useGuardHttp()\n const [uploadUrl, setUploadUrl] = useState([])\n const [previewVisible, setPreviewVisible] = useState(false)\n const [previewImage, setPreviewImage] = useState()\n const [fileList, setFileList] = useState<UploadFile<any>[]>([])\n const [typeProblem, setTypeProblem] = useState(0)\n const submitButtonRef = useRef<any>(null)\n const textMap = typeProblemMap[typeProblem]\n\n const onFinish = (values: any) => {\n submitButtonRef?.current?.onSpin(true)\n const params = {\n type: typeProblem,\n description: values.description,\n phone: values.identify,\n images: uploadUrl,\n appId: props.appId,\n }\n // TODO 暂不支持国际化短信参数\n let context = post('/api/v2/feedback', params)\n context.then((res) => {\n if (res.code === 200) {\n submitButtonRef?.current?.onSpin(false)\n props.onSuccess()\n } else {\n submitButtonRef?.current?.onSpin(false)\n message.error(res.message)\n }\n })\n }\n\n const handlePreview = async (file: any) => {\n let url\n if (file.status === 'error' || file.response) {\n url = await new Promise((resolve) => {\n const reader = new FileReader()\n reader.readAsDataURL(file.originFileObj)\n reader.onload = () => resolve(reader.result)\n })\n } else {\n url = file.response.data.url\n }\n // setPreviewImage(file.url);\n // file 没有 url 属性,需要改成下面的用法\n // let url = file.response.data.url\n setPreviewImage(url)\n setPreviewVisible(true)\n }\n\n return (\n <div className=\"authing-g2-describe-questions authing-g2-form-required-item-icon-after\">\n <Form\n name=\"resetPassword\"\n layout=\"vertical\"\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => {\n submitButtonRef?.current?.onError()\n }}\n autoComplete=\"off\"\n >\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"identify\"\n label={t('common.problem.form.phone')}\n validateFirst={true}\n initialValue={initData?.identify}\n rules={[\n ...fieldRequiredRule(t('common.problem.form.phone')),\n {\n validator: async (_, value) => {\n if (!value) {\n return\n }\n if (validate('email', value) || validate('phone', value)) {\n return\n } else {\n throw new Error(t('login.inputCorrectPhoneOrEmail'))\n }\n },\n },\n ]}\n >\n <Input\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('login.inputPhoneOrEmail')}\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form \"\n label={t('common.problem.form.question')}\n name=\"questionPicker\"\n initialValue={typeProblem}\n >\n <Select\n className=\"authing-g2-select\"\n onChange={(value: number) => {\n setTypeProblem(value)\n }}\n >\n {typeOperations?.map(({ value, label }) => (\n <Select.Option\n key={value}\n value={value}\n className={`authing-g2-question-option ${\n typeProblem === value\n ? 'authing-g2-question-option-active'\n : ''\n }`}\n >\n {label}\n </Select.Option>\n ))}\n </Select>\n </Form.Item>\n <div className=\"authing-g2-input-form\">\n {textMap?.map((item: any, index: any) => (\n <div key={index}>{item}</div>\n ))}\n </div>\n\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"description\"\n label={t('common.problem.form.questionDescript')}\n >\n <Input.TextArea\n className=\"authing-g2-questions-textarea\"\n maxLength={200}\n showCount\n rows={4}\n style={{\n marginBottom: 10,\n }}\n />\n </Form.Item>\n\n <div className=\"authing-g2-input-form\">\n <div className=\"label-title\">\n {t('common.problem.form.questionClip')}\n </div>\n <div className=\"g2-questions\">\n <Upload\n action={`${props.host}/api/v2/upload?folder=photos`}\n listType=\"picture-card\"\n accept=\"image/png, image/jpeg, image/jpg\"\n className=\"authing-g2-questions-upload-self\"\n fileList={fileList}\n onPreview={handlePreview}\n onChange={(e) => {\n setFileList(e.fileList)\n const imgUrl: any = e.fileList.map((item: any) => {\n const response = item.response\n return response?.data.url\n })\n setUploadUrl(imgUrl)\n }}\n beforeUpload={(file) => {\n if (\n ['image/png', 'image/jpeg', 'image/jpg'].includes(file.type)\n ) {\n return true\n }\n return Promise.reject(file)\n }}\n itemRender={(n, file) => {\n return (\n <>\n {file.status === 'uploading' ? (\n <div\n style={{\n padding: 6,\n borderRadius: 2,\n border: '1px solid #d9d9d9',\n }}\n >\n <Progress\n showInfo={false}\n style={{\n margin: 1,\n }}\n width={40}\n type=\"circle\"\n percent={file.percent}\n />\n </div>\n ) : (\n n\n )}\n </>\n )\n }}\n >\n {fileList.length < 4 && <PlusOutlined />}\n </Upload>\n </div>\n </div>\n\n <Form.Item className=\"authing-g2-sumbit-form submit-form\">\n <SubmitButton\n className=\"forget-password\"\n text={t('common.problem.form.submit')}\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n\n <Modal\n visible={previewVisible}\n title={null}\n footer={null}\n onCancel={() => setPreviewVisible(false)}\n >\n <img alt=\"example\" style={{ width: '100%' }} src={previewImage} />\n </Modal>\n </div>\n )\n}\n","import React from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { ImagePro } from '../ImagePro'\nimport { DescribeQuestions } from './core/describeQuestions'\nimport { GuardModuleType } from '../Guard/module'\nimport {\n useGuardAppId,\n useGuardFinallyConfig,\n useGuardModule,\n} from '../_utils/context'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport const GuardNeedHelpView = (props: any) => {\n const { t } = useTranslation()\n\n const appId = useGuardAppId()\n\n const { changeModule } = useGuardModule()\n\n const config = useGuardFinallyConfig()\n\n const onSuccess = () => {\n changeModule?.(GuardModuleType.SUBMIT_SUCCESS)\n }\n\n useGuardView()\n\n return (\n <div className=\"g2-view-container g2-need-help\">\n <div className=\"g2-view-header\">\n <ImagePro\n src={config.logo!}\n size={48}\n borderRadius={4}\n alt=\"\"\n className=\"icon\"\n />\n\n <div className=\"title\">{t('common.problem.title')}</div>\n </div>\n <div className=\"g2-view-tabs\">\n <DescribeQuestions\n appId={appId}\n host={config.host}\n onSuccess={onSuccess}\n />\n </div>\n <div className=\"g2-tips-line \">\n <div className=\"back-to-login\">\n <span className=\"gray\">{t('common.noQuestions')}</span>\n <span\n className=\"link-like\"\n onClick={() => changeModule?.(GuardModuleType.LOGIN)}\n >\n {t('common.goToLogin')}\n </span>\n </div>\n </div>\n </div>\n )\n}\n","import { Checkbox, Form, Typography } from 'antd'\nimport React, { useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport SubmitButton from '../../SubmitButton'\nimport { useGuardIsAuthFlow } from '../../_utils/context'\nimport { authFlow, TotpRecoveryCodeBusinessAction } from '../businessRequest'\n\nconst { Paragraph } = Typography\n\nexport const SaveCode: React.FC<{\n secret: string\n onBind: any\n}> = (props) => {\n const { secret, onBind } = props\n\n const { t } = useTranslation()\n\n const [form] = Form.useForm()\n\n const isAuthFlow = useGuardIsAuthFlow()\n\n const submitButtonRef = useRef<any>(null)\n\n const bindSuccess = async () => {\n submitButtonRef.current?.onSpin(true)\n\n if (isAuthFlow) {\n const { isFlowEnd, data, onGuardHandling } = await authFlow(\n TotpRecoveryCodeBusinessAction.ConfirmTotpRecoveryCode,\n {}\n )\n\n submitButtonRef.current?.onSpin(false)\n if (isFlowEnd) {\n onBind(data)\n } else {\n submitButtonRef.current?.onError()\n onGuardHandling?.()\n }\n } else {\n try {\n await form.validateFields()\n onBind()\n } catch (e: any) {\n submitButtonRef.current?.onError()\n } finally {\n submitButtonRef.current?.onSpin(false)\n }\n }\n }\n\n return (\n <>\n <p className=\"authing-g2-mfa-title\">{t('common.useRecoverCode')}</p>\n <p className=\"authing-g2-mfa-tips\">{t('common.totpGenerateCode')}</p>\n\n <div className=\"g2-mfa-bindTotp-copySecret\">\n <Paragraph copyable>{secret}</Paragraph>\n </div>\n\n <Form\n form={form}\n onFinish={bindSuccess}\n style={{ width: '100%' }}\n onFinishFailed={() => submitButtonRef.current?.onError()}\n >\n <Form.Item\n className=\"authing-g2-input-form g2-mfa-totp-recoveryCode-input\"\n name=\"remember\"\n rules={[\n {\n validator: (_, value) => {\n if (!value) {\n return Promise.reject(t('common.pleaseRecordKey'))\n }\n return Promise.resolve()\n },\n },\n ]}\n valuePropName=\"checked\"\n >\n <Checkbox className=\"g2-mfa-bindTotp-secretSave\">\n {t('login.rememberedSecret')}\n </Checkbox>\n </Form.Item>\n\n <SubmitButton text={t('common.confirm')} ref={submitButtonRef} />\n </Form>\n </>\n )\n}\n","import { getGuardHttp, useGuardHttp } from '../_utils/guardHttp'\nexport enum IdentityBindingBusinessAction {\n PhoneCode = 'phone-code',\n EmailCode = 'emial-code',\n Password = 'password',\n}\nexport interface PhoneCodeParams {\n phone: string\n code: string\n phoneCountryCode?: string\n}\nexport interface EmailCodeParams {\n email: string\n code: string\n}\nexport interface PasswordParams {\n account: string\n password: string\n captchaCode: string\n}\n\nexport enum IdentityBindingAction {\n CreateUser = 'create-federation-account',\n BindByPassword = 'bind-identity-by-password',\n BindByPhoneCode = 'bind-identity-by-phone-code',\n BindByEmailCode = 'bind-identity-by-email-code',\n RegisterByPassword = 'register-bind-by-password',\n RegisterByPhoneCode = 'register-bind-by-phone-code',\n RegisterByEmailCode = 'register-bind-by-email-code',\n}\n\nexport const PhoneCode = async (params: PhoneCodeParams) => {\n // const { phone, code, phoneCountryCode } = params\n\n const { post } = getGuardHttp()\n\n return await post('/interaction/federation/binding/byPhoneCode', params)\n}\n\nexport const EmailCode = async (params: EmailCodeParams) => {\n const { email, code } = params\n\n const { post } = getGuardHttp()\n\n return await post('/interaction/federation/binding/byEmailCode', {\n email,\n code,\n })\n}\n\nexport const Password = async (params: PasswordParams) => {\n const { account, password } = params\n\n const { post } = getGuardHttp()\n\n return await post('/interaction/federation/binding/byAccount', {\n account,\n password,\n })\n}\n\nexport const useIdentityBindingBusinessRequest = (\n type: 'register' | 'bind' = 'bind'\n) => {\n const { authFlow } = useGuardHttp()\n\n const request = {\n [IdentityBindingBusinessAction.PhoneCode]: (params: PhoneCodeParams) => {\n return authFlow(\n type === 'bind'\n ? IdentityBindingAction.BindByPhoneCode\n : IdentityBindingAction.RegisterByPhoneCode,\n params\n )\n },\n [IdentityBindingBusinessAction.EmailCode]: (params: EmailCodeParams) => {\n return authFlow(\n type === 'bind'\n ? IdentityBindingAction.BindByEmailCode\n : IdentityBindingAction.RegisterByEmailCode,\n params\n )\n },\n [IdentityBindingBusinessAction.Password]: (params: PasswordParams) => {\n return authFlow(\n type === 'bind'\n ? IdentityBindingAction.BindByPassword\n : IdentityBindingAction.RegisterByPassword,\n params\n )\n },\n }\n\n return request\n}\n","import { Form, Input } from 'antd'\nimport React, { useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { User } from 'authing-js-sdk'\nimport { IconFont } from '../../IconFont'\nimport SubmitButton from '../../SubmitButton'\nimport { useGuardIsAuthFlow } from '../../_utils/context'\nimport { useGuardHttp } from '../../_utils/guardHttp'\nimport { authFlow, TotpRecoveryCodeBusinessAction } from '../businessRequest'\n\nexport interface UseCodeProps {\n mfaToken: string\n onSubmit: (recoveryCode: string, user?: User) => void\n}\n\nexport const UseCode: React.FC<UseCodeProps> = ({ mfaToken, onSubmit }) => {\n const { t } = useTranslation()\n\n const isAuthFlow = useGuardIsAuthFlow()\n\n const [form] = Form.useForm()\n\n const { post } = useGuardHttp()\n\n let submitButtonRef = useRef<any>(null)\n\n const onFinish = async (values: any) => {\n submitButtonRef.current?.onSpin(true)\n\n if (isAuthFlow) {\n const { data, onGuardHandling, statusCode } = await authFlow<{\n recoveryCode: string\n }>(TotpRecoveryCodeBusinessAction.RecoveryTotp, {\n recoveryCode: values.recoveryCode,\n })\n\n submitButtonRef.current?.onSpin(false)\n\n if (statusCode === 200) {\n onSubmit(data!.recoveryCode)\n } else {\n submitButtonRef.current?.onError()\n\n onGuardHandling?.()\n }\n } else {\n try {\n const res = await post(\n '/api/v2/mfa/totp/recovery',\n {\n recoveryCode: form.getFieldValue('recoveryCode'),\n },\n {\n headers: {\n authorization: mfaToken,\n },\n }\n )\n if (res.code === 200) {\n // @ts-ignore\n onSubmit(res.recoveryCode, res.data)\n } else {\n // message.error(res.message)\n submitButtonRef.current?.onError()\n res.onGuardHandling?.()\n }\n } catch (error) {\n // TODO: handle error\n submitButtonRef.current?.onError()\n } finally {\n submitButtonRef.current?.onSpin(false)\n }\n }\n }\n\n return (\n <>\n <p className=\"authing-g2-mfa-title\">{t('common.useRecoverCode')}</p>\n <p className=\"authing-g2-mfa-tips\">{t('login.mfaAfterReset')}</p>\n <Form\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current.onError()}\n >\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"recoveryCode\"\n rules={[\n {\n required: true,\n message: t('login.inputRecoverCode'),\n },\n ]}\n >\n <Input\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('login.inputRecoverCode')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n\n <Form.Item className=\"authing-g2-sumbit-form submit-form\">\n <SubmitButton text={t('common.sure')} ref={submitButtonRef} />\n </Form.Item>\n </Form>\n </>\n )\n}\n","import React, { useMemo, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { GuardModuleType } from '..'\nimport { User } from 'authing-js-sdk'\nimport { BackCustom } from '../Back'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport { GuardMFAInitData, MFAType } from '../MFA/interface'\nimport {\n useGuardEvents,\n useGuardInitData,\n useGuardIsAuthFlow,\n useGuardModule,\n} from '../_utils/context'\nimport { SaveCode } from './core/saveCode'\nimport { UseCode } from './core/useCode'\nimport './style.less'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport const RecoveryCode: React.FC = () => {\n const { changeModule } = useGuardModule()\n\n const initData = useGuardInitData<GuardMFAInitData>()\n\n const events = useGuardEvents()\n\n const { t } = useTranslation()\n\n useGuardView()\n\n const [user, setUser] = useState<User>()\n\n const [code, setCode] = useState<string>()\n\n const authClient = useGuardAuthClient()\n\n const onBind = () => {\n if (user) events?.onLogin?.(user, authClient)\n }\n\n const renderBack = useMemo(() => {\n return (\n <BackCustom\n onBack={() =>\n changeModule?.(GuardModuleType.MFA, {\n ...initData,\n current: MFAType.TOTP,\n })\n }\n >\n {t('common.backToVerify')}\n </BackCustom>\n )\n }, [changeModule, initData, t])\n\n return (\n <div className=\"g2-view-container g2-mfa-recovery-code\">\n {renderBack}\n <div className=\"g2-mfa-content\">\n {user && code ? (\n <SaveCode secret={code} onBind={onBind} />\n ) : (\n <UseCode\n mfaToken={initData.mfaToken}\n onSubmit={(code, user) => {\n setUser(user)\n setCode(code)\n }}\n />\n )}\n </div>\n </div>\n )\n}\n\nexport const RecoveryCodeAuthFlow: React.FC = () => {\n const { changeModule } = useGuardModule()\n\n const initData = useGuardInitData<GuardMFAInitData>()\n\n const [recoveryCode, setRecoveryCode] = useState<string>()\n\n const events = useGuardEvents()\n\n const authClient = useGuardAuthClient()\n\n const onBind = (user: User) => {\n if (user) events?.onLogin?.(user, authClient)\n }\n\n const { t } = useTranslation()\n\n const renderBack = useMemo(() => {\n return (\n <BackCustom\n onBack={() =>\n changeModule?.(GuardModuleType.MFA, {\n ...initData,\n current: MFAType.TOTP,\n })\n }\n >\n {t('common.backToVerify')}\n </BackCustom>\n )\n }, [changeModule, initData, t])\n\n return (\n <div className=\"g2-view-container g2-mfa-recovery-code\">\n {renderBack}\n <div className=\"g2-mfa-content\">\n {recoveryCode ? (\n <SaveCode secret={recoveryCode} onBind={onBind} />\n ) : (\n <UseCode\n mfaToken={initData.mfaToken}\n onSubmit={(code) => {\n setRecoveryCode(code)\n }}\n />\n )}\n </div>\n </div>\n )\n}\n\nexport const GuardRecoveryCodeView: React.FC = () => {\n const isAuthFlow = useGuardIsAuthFlow()\n\n return <>{isAuthFlow ? <RecoveryCodeAuthFlow /> : <RecoveryCode />}</>\n}\n","import { useGuardPublicConfig } from '../_utils/context'\nimport omit from 'lodash/omit'\n// 是否进行注册信息补全\nexport const useIsChangeComplete = (currentMode: 'phone' | 'email') => {\n const { extendsFields } = useGuardPublicConfig()\n\n const { complateFiledsPlace } = useGuardPublicConfig()\n\n // 开关控制 如果没有 register 就不开启了\n if (!complateFiledsPlace.includes('register')) {\n return false\n }\n // 排除掉已有的字段\n if (\n !Boolean(omit(extendsFields, currentMode)) ||\n extendsFields.length === 0\n ) {\n // 为空就不补了~\n return false\n }\n\n // 字段唯一 切 与注册的方式相同 就不补了\n if (extendsFields.length === 1 && extendsFields[0].name === currentMode) {\n return false\n }\n\n // 其他的补\n return true\n}\n","import { Form, Input, message } from 'antd'\nimport { RegisterMethods } from 'authing-js-sdk'\nimport React, { useRef, useState, useCallback, useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useAsyncFn } from 'react-use'\nimport { useGuardAuthClient } from '../../Guard/authClient'\nimport { getDeviceName, getUserRegisterParams } from '../../_utils'\nimport { Agreements } from '../components/Agreements'\nimport SubmitButton from '../../SubmitButton'\nimport CustomFormItem from '../../ValidatorRules'\nimport { IconFont } from '../../IconFont'\nimport { InputPassword } from '../../InputPassword'\nimport { InputNumber } from '../../InputNumber'\nimport { useIsChangeComplete } from '../utils'\nimport {\n useGuardFinallyConfig,\n useGuardHttpClient,\n useGuardModule,\n} from '../../_utils/context'\nimport { GuardModuleType } from '../../Guard'\nimport { parsePhone, useMediaSize } from '../../_utils/hooks'\nimport { ApiCode } from '../../_utils/responseManagement/interface'\nimport { usePasswordErrorText } from '../../_utils/useErrorText'\nimport { Agreement, ApplicationConfig } from '../../Type/application'\nimport { InputInternationPhone } from '../../Login/core/withVerifyCode/InputInternationPhone'\n\nexport interface RegisterWithEmailProps {\n // onRegister: Function\n onRegisterSuccess: Function\n onRegisterFailed: Function\n onBeforeRegister?: Function\n publicConfig?: ApplicationConfig\n agreements: Agreement[]\n registeContext?: any\n label?: string\n method?: string\n}\n\nexport const RegisterWithEmail: React.FC<RegisterWithEmailProps> = ({\n label,\n method,\n onRegisterSuccess,\n onRegisterFailed,\n onBeforeRegister,\n agreements,\n registeContext,\n publicConfig,\n}) => {\n const { t } = useTranslation()\n const submitButtonRef = useRef<any>(null)\n const { isPhoneMedia } = useMediaSize()\n const authClient = useGuardAuthClient()\n const [form] = Form.useForm()\n const config = useGuardFinallyConfig()\n const isChangeComplete = useIsChangeComplete('email')\n const { changeModule } = useGuardModule()\n const { post } = useGuardHttpClient()\n\n const [acceptedAgreements, setAcceptedAgreements] = useState(false)\n const [validated, setValidated] = useState(false)\n\n // 区号 默认\n const [areaCode, setAreaCode] = useState(\n publicConfig?.internationalSmsConfig?.defaultISOType || 'CN'\n )\n const isInternationSms =\n publicConfig?.internationalSmsConfig?.enabled || false\n\n const {\n getPassWordUnsafeText,\n setPasswordErrorTextShow,\n } = usePasswordErrorText()\n const [, onFinish] = useAsyncFn(\n async (values: any) => {\n submitButtonRef.current?.onSpin(true)\n\n if (onBeforeRegister) {\n try {\n const canRegister = await onBeforeRegister(\n {\n type: RegisterMethods.Email,\n data: {\n identity: values.email || values.account,\n password: values.password,\n code: values.code,\n },\n },\n authClient\n )\n if (!canRegister) {\n submitButtonRef.current?.onSpin(false)\n return\n }\n } catch (e: any) {\n if (typeof e === 'string') {\n message.error(e)\n } else {\n message.error(e?.message)\n }\n submitButtonRef.current?.onSpin(false)\n return\n }\n }\n\n await form.validateFields()\n setValidated(true)\n\n if (agreements?.length && !acceptedAgreements) {\n submitButtonRef.current.onError()\n return\n }\n let { email, password, account } = values\n\n // 加密密码\n const encrypt = authClient.options.encryptFunction\n const encryptPassword = await encrypt!(password, config.publicKey!)\n\n const context = registeContext ?? {}\n\n let phoneCountryCode\n\n if (method === 'phone-password') {\n const { phoneNumber, countryCode } = parsePhone(\n isInternationSms,\n account,\n areaCode\n )\n account = phoneNumber\n phoneCountryCode = countryCode\n }\n\n // 注册使用的详情信息\n const registerContent = {\n account, // 自定义字段登录用户名\n email,\n password: encryptPassword,\n phoneCountryCode,\n profile: {\n browser:\n typeof navigator !== 'undefined' ? navigator.userAgent : null,\n device: getDeviceName(),\n },\n forceLogin: false,\n generateToken: true,\n clientIp: undefined,\n params: config?.isHost\n ? JSON.stringify(getUserRegisterParams(['login_page_context']))\n : undefined,\n context: JSON.stringify(context),\n phoneToken: undefined,\n }\n\n // onRegisterSuccess 注册成功后需要回到对应的登录页面\n const onRegisterSuccessIntercept = (user: any) => {\n onRegisterSuccess(user, {\n registerFrom: RegisterMethods.Email,\n account: email || account,\n })\n }\n if (isChangeComplete) {\n changeModule?.(GuardModuleType.REGISTER_COMPLETE_INFO, {\n businessRequestName: method || 'registerByEmail',\n content: {\n ...registerContent,\n },\n onRegisterSuccess: onRegisterSuccessIntercept,\n onRegisterFailed,\n })\n\n return\n }\n\n const { statusCode, data, message: errorMessage, apiCode } = await post(\n `/api/v2/register-${(method || 'email').split('-')[0]}`,\n {\n ...registerContent,\n postUserInfoPipeline: false,\n }\n )\n\n if (statusCode === 200) {\n onRegisterSuccessIntercept(data)\n } else {\n if (apiCode === ApiCode.UNSAFE_PASSWORD_TIP) {\n setPasswordErrorTextShow(true)\n }\n submitButtonRef.current.onError()\n onRegisterFailed(apiCode, data, errorMessage)\n message.error(errorMessage)\n }\n },\n [form, acceptedAgreements],\n { loading: false }\n )\n\n const PhoneAccount = useCallback(\n (props) => {\n if (publicConfig && publicConfig.internationalSmsConfig?.enabled) {\n return (\n <InputInternationPhone\n {...props}\n className=\"authing-g2-input\"\n size=\"large\"\n areaCode={areaCode}\n onAreaCodeChange={(value: string) => {\n setAreaCode(value)\n form.getFieldValue(['phone']) && form.validateFields(['phone'])\n }}\n maxLength={20}\n />\n )\n } else {\n return (\n <InputNumber\n {...props}\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputPhone')}\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n maxLength={11}\n />\n )\n }\n },\n [areaCode, form, publicConfig, t]\n )\n\n const AccountForm = useMemo(() => {\n if (!method) return null\n\n if (method === 'phone-password') {\n return (\n <CustomFormItem.Phone\n key=\"account\"\n name=\"account\"\n className={\n publicConfig?.internationalSmsConfig?.enabled\n ? 'authing-g2-input-form remove-padding'\n : 'authing-g2-input-form'\n }\n validateFirst={true}\n form={form}\n checkRepeat={true}\n required={true}\n areaCode={areaCode}\n >\n <PhoneAccount autoFocus={!isPhoneMedia} />\n </CustomFormItem.Phone>\n )\n }\n return (\n <CustomFormItem.CustomName\n method={method?.split('-')[0]}\n key={method}\n name=\"account\"\n className=\"authing-g2-input-form\"\n validateFirst={true}\n form={form}\n checkRepeat={true}\n required={true}\n >\n <Input\n maxLength={50}\n autoFocus={!isPhoneMedia}\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('login.inputAccount', {\n text: label,\n })}\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n ></Input>\n </CustomFormItem.CustomName>\n )\n }, [\n PhoneAccount,\n method,\n isPhoneMedia,\n areaCode,\n label,\n t,\n form,\n publicConfig?.internationalSmsConfig?.enabled,\n ])\n return (\n <div className=\"authing-g2-register-email\">\n <Form\n form={form}\n name=\"emailRegister\"\n autoComplete=\"off\"\n onSubmitCapture={() => submitButtonRef.current.onSpin(true)}\n onFinish={(values: any) => {\n onFinish(values)\n }}\n onFinishFailed={() => submitButtonRef.current.onError()}\n onValuesChange={(_, values) => {\n if (values['password'] && values['new-password']) {\n form.validateFields(['new-password'])\n }\n }}\n >\n {/* 新建自定义注册 */}\n {method && label ? (\n AccountForm\n ) : (\n <CustomFormItem.Email\n key=\"email\"\n name=\"email\"\n className=\"authing-g2-input-form\"\n validateFirst={true}\n form={form}\n checkRepeat={true}\n required={true}\n >\n <Input\n autoFocus={!isPhoneMedia}\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('login.inputEmail')}\n // prefix={<UserOutlined style={{ color: '#878A95' }} />}\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </CustomFormItem.Email>\n )}\n\n <CustomFormItem.Password\n key=\"password\"\n name=\"password\"\n className=\"authing-g2-input-form\"\n validateFirst={true}\n >\n <InputPassword\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputPwd')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </CustomFormItem.Password>\n <CustomFormItem.Password\n key=\"new-password\"\n name=\"new-password\"\n fieldRequiredRuleMessage={t('common.repeatPasswordDoc')}\n rules={[\n {\n validateTrigger: 'onBlur',\n validator: (_, value) => {\n if (value !== form.getFieldValue('password') && value) {\n return Promise.reject(t('common.repeatPasswordDoc'))\n } else {\n return Promise.resolve()\n }\n },\n },\n ]}\n className=\"authing-g2-input-form\"\n validateFirst={true}\n >\n <InputPassword\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('common.passwordAgain')}\n // prefix={<LockOutlined style={{ color: '#878A95' }} />}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </CustomFormItem.Password>\n {Boolean(agreements?.length) && (\n <Agreements\n onChange={setAcceptedAgreements}\n agreements={agreements}\n showError={validated}\n />\n )}\n {getPassWordUnsafeText()}\n <Form.Item className=\"authing-g2-sumbit-form\">\n <SubmitButton\n // disabled={\n // !!agreements.find((item) => item.required && !acceptedAgreements)\n // }\n text={t('common.register')}\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n","import { Form, message } from 'antd'\nimport React, { useCallback, useEffect, useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport {\n fieldRequiredRule,\n getDeviceName,\n getUserRegisterParams,\n validate,\n} from '../../_utils'\nimport { Agreements } from '../components/Agreements'\nimport SubmitButton from '../../SubmitButton'\nimport { IconFont } from '../../IconFont'\nimport { SceneType } from 'authing-js-sdk'\nimport { SendCodeByPhone } from '../../SendCode/SendCodeByPhone'\nimport { InputInternationPhone } from '../../Login/core/withVerifyCode/InputInternationPhone'\nimport { parsePhone, useMediaSize } from '../../_utils/hooks'\nimport { useIsChangeComplete } from '../utils'\nimport {\n useGuardFinallyConfig,\n useGuardModule,\n useIsForeignUserpool,\n} from '../../_utils/context'\nimport { GuardModuleType } from '../../Guard'\nimport { useGuardHttp } from '../../_utils/guardHttp'\nimport { useGuardAuthClient } from '../../Guard/authClient'\nimport { FormItemIdentify } from '../../Login/core/withVerifyCode/FormItemIdentify'\nimport { InputIdentify } from '../../Login/core/withVerifyCode/inputIdentify'\nimport { EmailScene, InputMethod } from '../..'\nimport { SendCodeByEmail } from '../../SendCode/SendCodeByEmail'\nimport {\n Agreement,\n ApplicationConfig,\n RegisterMethods,\n} from '../../Type/application'\nimport { getCaptchaUrl } from '../../_utils/getCaptchaUrl'\nimport { GraphicVerifyCode } from '../../Login/core/withPassword/GraphicVerifyCode'\n\nexport interface RegisterWithCodeProps {\n // onRegister: Function\n onRegisterSuccess: Function\n onRegisterFailed: Function\n onBeforeRegister?: Function\n agreements: Agreement[]\n publicConfig?: ApplicationConfig\n registeContext?: any\n methods: any[]\n}\n\n/**\n * 手机 Code 注册\n * @param param0\n * @returns\n */\nexport const RegisterWithCode: React.FC<RegisterWithCodeProps> = ({\n onRegisterSuccess,\n onRegisterFailed,\n onBeforeRegister,\n agreements,\n publicConfig,\n registeContext,\n methods = [],\n}) => {\n const { t } = useTranslation()\n\n const isPhoneChangeComplete = useIsChangeComplete('phone')\n\n const isEmailChangeComplete = useIsChangeComplete('email')\n\n const config = useGuardFinallyConfig()\n\n const { isPhoneMedia } = useMediaSize()\n\n const authClient = useGuardAuthClient()\n\n const { changeModule } = useGuardModule()\n\n const { post } = useGuardHttp()\n\n const submitButtonRef = useRef<any>(null)\n\n const [form] = Form.useForm()\n\n const [acceptedAgreements, setAcceptedAgreements] = useState(false)\n\n const [validated, setValidated] = useState(false)\n\n // 区号 默认\n const [areaCode, setAreaCode] = useState(\n publicConfig?.internationalSmsConfig?.defaultISOType || 'CN'\n )\n\n const verifyCodeLength = publicConfig?.verifyCodeLength ?? 4\n\n const [currentMethod, setCurrentMethod] = useState(methods[0])\n\n const [identify, setIdentify] = useState('')\n const [captchaCode, setCaptchaCode] = useState('')\n // 是否仅开启国际化短信\n const [isOnlyInternationSms, setInternationSms] = useState(false)\n // 是否开启了国际化短信功能\n const isInternationSms =\n publicConfig?.internationalSmsConfig?.enabled || false\n\n const isForeignUserpool = useIsForeignUserpool()\n const [verifyCodeUrl, setVerifyCodeUrl] = useState('')\n\n useEffect(() => {\n // 开启国际化配置且登录方式为手机号码时\n if (\n methods.length === 1 &&\n methods[0] === 'phone-code' &&\n publicConfig &&\n publicConfig.internationalSmsConfig?.enabled\n ) {\n setInternationSms(true)\n }\n }, [methods, publicConfig])\n\n useEffect(() => {\n /** 如果是国外用户池,那么有图形验证码,需要请求图片 */\n if (isForeignUserpool) {\n setVerifyCodeUrl(getCaptchaUrl(config.host!))\n }\n }, [isForeignUserpool, config?.host])\n\n useEffect(() => {\n // 方法发生变化时,图像验证码数据应该清空\n if (isForeignUserpool) {\n form?.setFieldsValue({ captchaCode: undefined })\n }\n }, [form, currentMethod, isForeignUserpool])\n\n const registerByPhoneCode = useCallback(\n async (values: any) => {\n const needPassword =\n config.passwordLoginMethods?.includes('phone-password') &&\n publicConfig?.enableCompletePassword\n\n submitButtonRef.current?.onSpin(true)\n\n values.phone = values.identify\n if (onBeforeRegister) {\n try {\n const canRegister = await onBeforeRegister(\n {\n type: RegisterMethods.Phone,\n data: {\n identity: values.phone,\n password: values.password,\n code: values.code,\n },\n },\n authClient\n )\n if (!canRegister) {\n submitButtonRef.current.onSpin(false)\n return\n }\n } catch (e: any) {\n if (typeof e === 'string') {\n message.error(e)\n } else {\n message.error(e?.message)\n }\n submitButtonRef.current.onSpin(false)\n return\n }\n }\n try {\n await form.validateFields()\n\n setValidated(true)\n\n if (agreements?.length && !acceptedAgreements) {\n // message.error(t('common.registerProtocolTips'))\n submitButtonRef.current.onError()\n // submitButtonRef.current.onSpin(false)\n return\n }\n\n const { phone, code } = values\n\n const context = registeContext ?? {}\n\n const { phoneNumber, countryCode: phoneCountryCode } = parsePhone(\n isInternationSms,\n phone,\n areaCode\n )\n\n // 注册\n // const options: any = {\n // context,\n // generateToken: true,\n // // 托管模式下注册携带query上自定义参数login_page_context\n // params: config?.isHost\n // ? getUserRegisterParams(['login_page_context'])\n // : undefined,\n // }\n\n // if (isInternationSms) {\n // options.phoneCountryCode = phoneCountryCode\n // }\n\n const registerContent = {\n phone: phoneNumber,\n code,\n phoneCountryCode: isInternationSms ? phoneCountryCode : undefined,\n // password: undefined, // TODO: 手机号验证码不需要密码\n profile: {\n browser:\n typeof navigator !== 'undefined' ? navigator.userAgent : null,\n device: getDeviceName(),\n },\n forceLogin: false,\n generateToken: true,\n clientIp: undefined,\n params: config?.isHost\n ? JSON.stringify(getUserRegisterParams(['login_page_context']))\n : undefined,\n context: JSON.stringify(context),\n emailToken: undefined,\n }\n // onRegisterSuccess 注册成功后需要回到对应的登录页面\n const onRegisterSuccessIntercept = (user: any) => {\n onRegisterSuccess(user, {\n registerFrom: RegisterMethods.Phone,\n account: isInternationSms ? '' : phoneNumber,\n })\n }\n\n if (needPassword) {\n // 判断验证码是否正确\n const {\n statusCode: checkCode,\n data: { valid, message: checkMessage },\n } = await post('/api/v2/sms/preCheckCode', {\n phone: phoneNumber,\n phoneCode: code,\n phoneCountryCode,\n })\n // 验证码校验通过 进入密码补全流程\n if (checkCode === 200 && valid) {\n changeModule?.(GuardModuleType.REGISTER_PASSWORD, {\n businessRequestName: 'registerByPhoneCode',\n content: {\n ...registerContent,\n },\n isChangeComplete: isPhoneChangeComplete,\n onRegisterSuccess: onRegisterSuccessIntercept,\n onRegisterFailed,\n })\n return\n } else {\n submitButtonRef.current.onError()\n message.error(checkMessage)\n return\n }\n } else {\n // 看看是否要跳转到 信息补全\n if (isPhoneChangeComplete) {\n // 判断验证码是否正确\n const {\n statusCode: checkCode,\n data: { valid, message: checkMessage },\n } = await post('/api/v2/sms/preCheckCode', {\n phone: phoneNumber,\n phoneCode: code,\n phoneCountryCode,\n })\n\n if (checkCode === 200 && valid) {\n changeModule?.(GuardModuleType.REGISTER_COMPLETE_INFO, {\n businessRequestName: 'registerByPhoneCode',\n content: {\n ...registerContent,\n },\n onRegisterSuccess: onRegisterSuccessIntercept,\n onRegisterFailed,\n })\n return\n } else {\n submitButtonRef.current.onError()\n message.error(checkMessage)\n return\n }\n }\n\n /**\n * 手机号注册接口\n */\n const { data, statusCode, apiCode, message: errMessage } = await post(\n `/api/v2/register-phone-code`,\n {\n ...registerContent,\n postUserInfoPipeline: false,\n }\n )\n if (statusCode === 200) {\n submitButtonRef.current?.onSpin(false)\n onRegisterSuccessIntercept(data)\n } else {\n submitButtonRef.current.onError()\n message.error(errMessage)\n !needPassword && onRegisterFailed(apiCode, data, errMessage)\n }\n }\n } catch (error: any) {\n // TODO 确认无误后 删除 catch\n const { message: errorMessage, code, data } = error\n submitButtonRef.current.onError()\n message.error(errorMessage)\n !needPassword && onRegisterFailed(code, data, errorMessage)\n } finally {\n submitButtonRef.current?.onSpin(false)\n }\n },\n [\n config?.isHost,\n config.passwordLoginMethods,\n onBeforeRegister,\n authClient,\n form,\n agreements?.length,\n acceptedAgreements,\n registeContext,\n isInternationSms,\n areaCode,\n post,\n changeModule,\n isPhoneChangeComplete,\n onRegisterSuccess,\n onRegisterFailed,\n publicConfig?.enableCompletePassword,\n ]\n )\n\n const registerByEmailCode = useCallback(\n async (values: any) => {\n const needPassword =\n config.passwordLoginMethods?.includes('email-password') &&\n publicConfig?.enableCompletePassword\n submitButtonRef.current.onSpin(true)\n values.email = values.identify\n if (onBeforeRegister) {\n try {\n const canRegister = await onBeforeRegister(\n {\n type: RegisterMethods.EmailCode,\n data: {\n identity: values.email,\n password: values.password,\n code: values.code,\n },\n },\n authClient\n )\n if (!canRegister) {\n submitButtonRef.current.onSpin(false)\n return\n }\n } catch (e: any) {\n if (typeof e === 'string') {\n message.error(e)\n } else {\n message.error(e?.message)\n }\n submitButtonRef.current.onSpin(false)\n return\n }\n }\n\n try {\n await form.validateFields()\n setValidated(true)\n\n if (agreements?.length && !acceptedAgreements) {\n submitButtonRef.current.onError()\n return\n }\n const { email, code } = values\n\n const context = registeContext ?? {}\n // 注册使用的详情信息\n const registerContent = {\n email,\n code,\n profile: {\n browser:\n typeof navigator !== 'undefined' ? navigator.userAgent : null,\n device: getDeviceName(),\n },\n context: JSON.stringify(context),\n generateToken: true,\n // 托管模式下注册携带query上自定义参数login_page_context\n params: config?.isHost\n ? JSON.stringify(getUserRegisterParams(['login_page_context'])) // 特殊处理 resetful api\n : undefined,\n }\n\n // onRegisterSuccess 注册成功后需要回到对应的登录页面\n const onRegisterSuccessIntercept = (user: any) => {\n onRegisterSuccess(user, {\n registerFrom: RegisterMethods.EmailCode,\n account: email,\n })\n }\n\n if (needPassword) {\n // 判断验证码是否正确\n const {\n statusCode: checkCode,\n data: { valid, message: checkMessage },\n } = await post('/api/v2/email/preCheckCode', {\n email: email,\n emailCode: code,\n })\n // 验证码校验通过 进入密码补全流程\n if (checkCode === 200 && valid) {\n changeModule?.(GuardModuleType.REGISTER_PASSWORD, {\n businessRequestName: 'registerByEmailCode', //用于判断后续使用哪个注册api\n content: {\n ...registerContent,\n },\n isChangeComplete: isEmailChangeComplete,\n onRegisterSuccess: onRegisterSuccessIntercept,\n onRegisterFailed,\n })\n return\n } else {\n submitButtonRef.current.onError()\n message.error(checkMessage)\n return\n }\n } else {\n // 看看是否要跳转到 信息补全\n if (isEmailChangeComplete) {\n // 判断验证码是否正确\n const {\n statusCode: checkCode,\n data: { valid, message: checkMessage },\n } = await post('/api/v2/email/preCheckCode', {\n email: email,\n emailCode: code,\n })\n if (checkCode === 200 && valid) {\n changeModule?.(GuardModuleType.REGISTER_COMPLETE_INFO, {\n businessRequestName: 'registerByEmailCode', //用于判断后续使用哪个注册api\n content: {\n ...registerContent,\n },\n onRegisterSuccess: onRegisterSuccessIntercept,\n onRegisterFailed,\n })\n return\n } else {\n submitButtonRef.current.onError()\n message.error(checkMessage)\n return\n }\n }\n // 注册\n const {\n statusCode,\n data,\n apiCode,\n onGuardHandling,\n message: registerMessage,\n } = await post('/api/v2/register-email-code', {\n ...registerContent,\n postUserInfoPipeline: false,\n })\n submitButtonRef.current.onSpin(false)\n if (statusCode === 200) {\n onRegisterSuccessIntercept(data)\n } else {\n onGuardHandling?.()\n onRegisterFailed(apiCode, data, registerMessage)\n }\n }\n } catch (error: any) {\n const { message: errorMessage, code, data } = error\n submitButtonRef.current.onError()\n message.error(errorMessage)\n !needPassword && onRegisterFailed(code, data, message)\n } finally {\n submitButtonRef.current?.onSpin(false)\n }\n },\n [\n config?.isHost,\n config.passwordLoginMethods,\n onBeforeRegister,\n authClient,\n form,\n agreements?.length,\n acceptedAgreements,\n registeContext,\n post,\n changeModule,\n isEmailChangeComplete,\n onRegisterSuccess,\n onRegisterFailed,\n publicConfig?.enableCompletePassword,\n ]\n )\n\n const onFinish = useCallback(\n async (values: any) => {\n if (currentMethod === InputMethod.EmailCode) {\n await registerByEmailCode(values)\n } else if (currentMethod === InputMethod.PhoneCode) {\n await registerByPhoneCode(values)\n }\n },\n [currentMethod, registerByEmailCode, registerByPhoneCode]\n )\n\n const SendCode = useCallback(\n (props: any) => {\n if (isOnlyInternationSms) {\n return (\n <SendCodeByPhone\n {...props}\n form={form}\n fieldName=\"identify\"\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('common.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n areaCode={areaCode}\n prefix={\n <IconFont\n type=\"authing-a-shield-check-line1\"\n style={{ color: '#878A95' }}\n />\n }\n isInternationSms={isInternationSms}\n scene={SceneType.SCENE_TYPE_REGISTER}\n maxLength={verifyCodeLength}\n onSendCodeBefore={async () => {\n await form.validateFields(['identify'])\n await form.validateFields(['captchaCode'])\n }}\n />\n )\n }\n\n return (\n <>\n {currentMethod === InputMethod.PhoneCode && (\n <SendCodeByPhone\n {...props}\n isInternationSms={isInternationSms}\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('common.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n areaCode={areaCode}\n prefix={\n <IconFont\n type=\"authing-a-shield-check-line1\"\n style={{ color: '#878A95' }}\n />\n }\n scene={SceneType.SCENE_TYPE_REGISTER}\n maxLength={verifyCodeLength}\n data={identify}\n captchaCode={captchaCode}\n onSendCodeBefore={async () => {\n await form.validateFields(['identify'])\n await form.validateFields(['captchaCode'])\n }}\n />\n )}\n {currentMethod === InputMethod.EmailCode && (\n <SendCodeByEmail\n {...props}\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('common.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n prefix={\n <IconFont\n type=\"authing-a-shield-check-line1\"\n style={{ color: '#878A95' }}\n />\n }\n scene={EmailScene.REGISTER_VERIFY_CODE}\n maxLength={verifyCodeLength}\n data={identify}\n onSendCodeBefore={async () => {\n await form.validateFields(['identify'])\n }}\n />\n )}\n </>\n )\n },\n [\n areaCode,\n currentMethod,\n form,\n identify,\n isInternationSms,\n isOnlyInternationSms,\n t,\n verifyCodeLength,\n captchaCode,\n ]\n )\n\n // 为了 refresh input\n const AreaCodePhoneAccount = useCallback(\n (props: any) => {\n return (\n <InputInternationPhone\n {...props}\n className=\"authing-g2-input\"\n size=\"large\"\n areaCode={areaCode}\n onAreaCodeChange={(value: string) => {\n setAreaCode(value)\n form.getFieldValue(['identify']) &&\n form.validateFields(['identify'])\n }}\n />\n )\n },\n [areaCode, form]\n )\n\n return (\n <div className=\"authing-g2-register-email\">\n <Form\n form={form}\n name=\"emailRegister\"\n autoComplete=\"off\"\n onSubmitCapture={() => submitButtonRef.current.onSpin(true)}\n onFinish={onFinish}\n onFinishFailed={() => submitButtonRef.current.onError()}\n >\n <FormItemIdentify\n name=\"identify\"\n className={\n isOnlyInternationSms\n ? 'authing-g2-input-form remove-padding'\n : 'authing-g2-input-form'\n }\n methods={methods}\n currentMethod={currentMethod}\n areaCode={areaCode}\n checkRepeat={true}\n required={true}\n >\n {isOnlyInternationSms ? (\n <AreaCodePhoneAccount autoFocus={!isPhoneMedia} />\n ) : (\n <InputIdentify\n className=\"authing-g2-input\"\n size=\"large\"\n autoFocus={!isPhoneMedia}\n value={identify}\n methods={methods}\n onChange={(e) => {\n let v = e.target.value\n setIdentify(v)\n if (methods.length === 1) return\n if (validate('email', v)) {\n setCurrentMethod(InputMethod.EmailCode)\n } else {\n // 放开手机号校验 方便同时开启邮箱和短信国际化手机号通过\n setCurrentMethod(InputMethod.PhoneCode)\n }\n }}\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n )}\n </FormItemIdentify>\n\n {/* 图形验证码 国外用户池并且是手机号 */}\n {isForeignUserpool && currentMethod === InputMethod.PhoneCode && (\n <Form.Item\n className=\"authing-g2-input-form\"\n validateTrigger={['onBlur', 'onChange']}\n name=\"captchaCode\"\n rules={fieldRequiredRule(t('common.captchaCode'))}\n >\n <GraphicVerifyCode\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('login.inputCaptchaCode')}\n verifyCodeUrl={verifyCodeUrl}\n changeCode={() => setVerifyCodeUrl(getCaptchaUrl(config.host!))}\n onChange={(e) => {\n setCaptchaCode(e.target.value)\n }}\n />\n </Form.Item>\n )}\n\n <Form.Item\n key=\"code\"\n name=\"code\"\n validateTrigger={['onBlur', 'onChange']}\n rules={fieldRequiredRule(t('common.captchaCode'))}\n className=\"authing-g2-input-form\"\n validateFirst={true}\n >\n <SendCode />\n </Form.Item>\n {Boolean(agreements?.length) && (\n <Agreements\n onChange={setAcceptedAgreements}\n agreements={agreements}\n showError={validated}\n />\n )}\n <Form.Item className=\"authing-g2-sumbit-form\">\n <SubmitButton\n // disabled={\n // !!agreements.find((item) => item.required && !acceptedAgreements)\n // }\n text={t('common.register')}\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n","import React, { useEffect, useMemo, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { Tabs } from 'antd'\nimport { ChangeLanguage } from '../ChangeLanguage'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport { GuardModuleType } from '../Guard/module'\nimport { RegisterWithEmail } from './core/WithEmail'\nimport { RegisterWithCode } from './core/WithCode'\nimport {\n getI18nLabel,\n getLoginTypePipe,\n getSortTabs,\n transformMethod,\n} from '../_utils'\nimport { fallbackLng, i18n } from '../_utils/locales'\nimport {\n useGuardDefaultLanguage,\n useGuardEvents,\n useGuardFinallyConfig,\n useGuardModule,\n useGuardPublicConfig,\n} from '../_utils/context'\nimport { GuardLoginInitData } from '../Login/interface'\nimport {\n RegisterMethods,\n RegisterSortMethods,\n TabFieldsI18nItem,\n} from '../Type/application'\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport const GuardRegisterView: React.FC = () => {\n const events = useGuardEvents()\n\n const config = useGuardFinallyConfig()\n\n const { changeModule } = useGuardModule()\n\n const { t } = useTranslation()\n const agreementEnabled = config?.agreementEnabled\n const { langRange } = config\n const authClient = useGuardAuthClient()\n\n const publicConfig = useGuardPublicConfig()\n\n const defaultLanguageConfig = useGuardDefaultLanguage()\n\n const verifyRegisterMethods = useMemo<string[]>(() => {\n const verifyLoginMethods = []\n const { registerMethods } = config\n if (registerMethods?.includes(RegisterMethods.EmailCode)) {\n verifyLoginMethods.push('email-code')\n }\n if (registerMethods?.includes(RegisterMethods.Phone)) {\n verifyLoginMethods.push('phone-code')\n }\n\n return verifyLoginMethods\n }, [config])\n\n const registerContextProps = useMemo(\n () => ({\n onRegisterSuccess: (\n data: any = {},\n registerInfo: {\n registerFrom: RegisterMethods\n account: string\n }, //以何种方式注册成功\n message?: string\n ) => {\n const initData = getLoginTypePipe(\n publicConfig,\n registerInfo.registerFrom\n )\n const loginInitData: GuardLoginInitData = {}\n if (initData) {\n loginInitData.specifyDefaultLoginMethod =\n initData.specifyDefaultLoginMethod\n\n initData?.lockMethod &&\n (loginInitData._lockMethod = initData.lockMethod)\n\n loginInitData._firstItemInitialValue = registerInfo.account\n }\n events?.onRegister?.(data, authClient)\n changeModule?.(GuardModuleType.LOGIN, loginInitData)\n },\n onRegisterFailed: (code: number, data: any = {}, message?: string) => {\n // if (message) Message.error(message)\n\n events?.onRegisterError?.({\n code,\n data,\n message,\n })\n },\n registeContext: config.registerContext,\n onBeforeRegister: events?.onBeforeRegister,\n //availableAt 0或者null-注册时,1-登录时,2-注册和登录时\n agreements: agreementEnabled\n ? config?.agreements?.filter(\n (agree) =>\n fallbackLng(i18n.language).find((lng) =>\n lng.includes(agree.lang)\n ) && agree?.availableAt !== 1\n ) ?? []\n : [],\n publicConfig: publicConfig,\n methods: verifyRegisterMethods,\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [\n agreementEnabled,\n config?.agreements,\n events?.onBeforeRegister,\n i18n.language,\n verifyRegisterMethods,\n ]\n )\n\n const tabMapping: Record<\n string,\n { component: React.ReactNode; name: string }\n > = useMemo(() => {\n let verifyCodeLogin: string = ''\n if (verifyRegisterMethods.length > 1) {\n verifyCodeLogin = t('common.verifyCodeRegister')\n } else {\n if (verifyRegisterMethods.includes('phone-code')) {\n verifyCodeLogin = t('common.phoneVerifyCode')\n } else if (verifyRegisterMethods.includes('email-code')) {\n verifyCodeLogin = t('common.emailVerifyCode')\n } else {\n verifyCodeLogin = t('common.verifyCodeRegister')\n }\n }\n return {\n [RegisterSortMethods.Email]: {\n component: <RegisterWithEmail {...registerContextProps} />,\n name: t('common.EmailRegister'),\n },\n [RegisterSortMethods.Phone]: {\n component: <RegisterWithCode {...registerContextProps} />,\n name: verifyCodeLogin,\n },\n }\n }, [registerContextProps, t, verifyRegisterMethods])\n\n // i18nFields 数据\n const i18nFields = useMemo(() => {\n const i18nMap = new Map<string, TabFieldsI18nItem>()\n publicConfig.tabMethodsFields.forEach((item) => {\n i18nMap.set(item.key, item)\n })\n return i18nMap\n }, [publicConfig.tabMethodsFields])\n\n const [activeKey, setActiveKey] = useState<string>('')\n\n const defaultMethod = useMemo(() => {\n return (\n config.defaultRegisterMethod &&\n transformMethod(config.defaultRegisterMethod)\n )\n }, [config.defaultRegisterMethod])\n\n useEffect(() => {\n if (defaultMethod) {\n setActiveKey(defaultMethod)\n }\n }, [defaultMethod])\n\n useGuardView({\n currentTab: activeKey,\n changeTab: setActiveKey,\n })\n\n const renderTab = useMemo(() => {\n const { registerMethods = [] } = config\n\n // registerMethods 处理,改版后支持自定义 method\n const filterRegisterMethods = [\n ...new Set(\n [...registerMethods]?.map((method) => {\n return transformMethod(method)\n })\n ),\n ]\n\n return getSortTabs(filterRegisterMethods, defaultMethod).map((method) => {\n const tab = tabMapping[method]\n const name = getI18nLabel(method, i18nFields, defaultLanguageConfig)\n return (\n <Tabs.TabPane\n tab={tab?.name || t('common.registerTab', { text: name })}\n key={method}\n >\n {tab?.component || (\n <RegisterWithEmail\n label={name}\n method={method}\n {...registerContextProps}\n />\n )}\n </Tabs.TabPane>\n )\n })\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n config,\n tabMapping,\n publicConfig,\n defaultMethod,\n i18nFields,\n i18n.language,\n registerContextProps,\n defaultLanguageConfig,\n t,\n ])\n\n return (\n <div className=\"g2-view-container g2-view-register\">\n <div className=\"g2-view-container-inner\">\n <div className=\"g2-view-header\">\n <img src={config?.logo} alt=\"\" className=\"icon\" />\n\n <div className=\"title\">{config?.title}</div>\n </div>\n <div className=\"g2-view-tabs\">\n <Tabs\n destroyInactiveTabPane={true}\n // defaultActiveKey={defaultMethod}\n activeKey={activeKey}\n onChange={(activeKey) => {\n setActiveKey(activeKey)\n events?.onRegisterTabChange?.(activeKey as RegisterMethods)\n }}\n >\n {renderTab}\n </Tabs>\n </div>\n <div className=\"g2-tips-line\">\n <span className=\"back-to-login\">\n {/* <span className=\"gray\">{t('common.alreadyHasAcc')}</span> */}\n <span\n className=\"link-like\"\n onClick={() => changeModule?.(GuardModuleType.LOGIN, {})}\n >\n {t('common.backLoginPage')}\n </span>\n </span>\n </div>\n </div>\n <ChangeLanguage\n langRange={langRange}\n onLangChange={events?.onLangChange}\n />\n </div>\n )\n}\n","import React, { useEffect, useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { GuardModuleType } from '..'\nimport { ImagePro } from '../ImagePro'\nimport SubmitButton from '../SubmitButton'\nimport {\n useGuardInitData,\n useGuardModule,\n useGuardPublicConfig,\n} from '../_utils/context'\nimport { SubmitSuccessInitData } from './interface'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport const GuardSubmitSuccessView: React.FC = () => {\n const { t } = useTranslation()\n\n const initData = useGuardInitData<SubmitSuccessInitData>()\n\n const { changeModule: __changeModule } = useGuardModule()\n\n const [countDown, setCountDown] = useState(5)\n\n const timerRef = useRef<any>(0)\n\n const publicConfig = useGuardPublicConfig()\n\n useGuardView()\n\n const {\n title = t('common.problem.successTip'),\n message = t('common.problem.successTipMsg'),\n text = t('common.backLoginPage'),\n countDesc = t('common.pToLogin'),\n changeModule = GuardModuleType.LOGIN,\n } = initData ?? {}\n const cdnBase = publicConfig?.cdnBase\n\n useEffect(() => {\n timerRef.current = setInterval(() => {\n setCountDown((prev) => {\n return prev - 1\n })\n }, 1000)\n\n return () => clearInterval(timerRef.current)\n }, [])\n\n useEffect(() => {\n if (countDown <= 0) {\n clearInterval(timerRef.current)\n __changeModule?.(changeModule)\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [countDown])\n\n return (\n <div className=\"g2-view-container g2-submit-success\">\n <div className=\"g2-view-tabs g2-questions-send-success-page\">\n <ImagePro\n className=\"plate\"\n src={`${cdnBase}/questions-send-ok.png`}\n alt=\"\"\n width={191}\n height={146}\n />\n <div className=\"title\">{title}</div>\n <div className=\"message\">{message}</div>\n <SubmitButton\n onClick={() => {\n __changeModule?.(changeModule)\n }}\n text={text as string}\n />\n <div className=\"timer-tip\">\n {countDown} {countDesc}\n </div>\n </div>\n </div>\n )\n}\n","import React, { useCallback, useEffect, useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { Form } from 'antd'\nimport { fieldRequiredRule, validate, getPasswordIdentify } from '../../_utils'\nimport SubmitButton from '../../SubmitButton'\nimport { IconFont } from '../../IconFont'\nimport { InputPassword } from '../../InputPassword'\nimport { SceneType } from 'authing-js-sdk'\nimport { SendCodeByEmail } from '../../SendCode/SendCodeByEmail'\nimport { SendCodeByPhone } from '../../SendCode/SendCodeByPhone'\nimport { FormItemIdentify } from '../../Login/core/withVerifyCode/FormItemIdentify'\nimport { InputIdentify } from '../../Login/core/withVerifyCode/inputIdentify'\nimport { parsePhone, useMediaSize } from '../../_utils/hooks'\nimport { EmailScene } from '../../Type'\nimport { useGuardHttp } from '../../_utils/guardHttp'\nimport { useGuardAuthClient } from '../../Guard/authClient'\nimport {\n useGuardEvents,\n useGuardInitData,\n useGuardPublicConfig,\n} from '../../_utils/context'\n\nexport enum InputMethodMap {\n email = 'email-code',\n phone = 'phone-code',\n}\nexport const SelfUnlock = ({\n identifyRef,\n}: {\n identifyRef?: React.MutableRefObject<string>\n}) => {\n const { t } = useTranslation()\n let [form] = Form.useForm()\n let [identify, setIdentify] = useState('')\n let [codeMethod, setCodeMethod] = useState<'phone' | 'email'>('phone')\n let submitButtonRef = useRef<any>(null)\n const { isPhoneMedia } = useMediaSize()\n let authClient = useGuardAuthClient()\n const events = useGuardEvents()\n\n const initData = useGuardInitData<{\n defaultEmail: 'string'\n defaultPhone: 'string'\n }>()\n\n useEffect(() => {\n if (initData.defaultEmail) {\n setIdentify(initData.defaultEmail)\n form.setFieldsValue({\n identify: initData.defaultEmail,\n })\n setCodeMethod('email')\n }\n if (initData.defaultPhone) {\n setIdentify(initData.defaultPhone)\n form.setFieldsValue({\n identify: initData.defaultPhone,\n })\n setCodeMethod('phone')\n }\n }, [initData, form])\n\n useEffect(() => {\n if (identifyRef) {\n identifyRef.current = getPasswordIdentify(identify)\n }\n }, [identify, identifyRef])\n\n const { authFlow } = useGuardHttp()\n\n const {\n publicKey,\n verifyCodeLength,\n internationalSmsConfig,\n selfUnlockStrategy = 'password-captcha', // 'captcha' | 'password-captcha'\n } = useGuardPublicConfig()\n\n // 是否开启了国际化短信功能\n const isInternationSms = internationalSmsConfig?.enabled || false\n\n const onFinish = async (values: any) => {\n let identify = values.identify\n\n let code = values.code\n\n let password = values.password || ''\n\n const encryptPassWord = await authClient.options?.encryptFunction?.(\n password,\n publicKey\n )\n // 密码,经过加密后的, 仅“验证码”时不传 password 字段\n password =\n selfUnlockStrategy === 'password-captcha' ? encryptPassWord : undefined\n\n if (codeMethod === 'email') {\n const { isFlowEnd, data, onGuardHandling } = await authFlow(\n 'unlock-account-by-email',\n {\n email: identify, // 用户输入的邮箱\n code, // 验证码\n password,\n }\n )\n submitButtonRef.current?.onSpin(false)\n if (isFlowEnd) {\n events?.onLogin?.(data, authClient!) // 登录成功\n } else {\n onGuardHandling?.()\n }\n }\n if (codeMethod === 'phone') {\n const { phoneNumber } = parsePhone(isInternationSms, identify)\n const { isFlowEnd, data, onGuardHandling } = await authFlow(\n 'unlock-account-by-phone',\n {\n phone: phoneNumber, // 用户输入的邮箱\n code, // 验证码\n password,\n }\n )\n submitButtonRef.current?.onSpin(false)\n if (isFlowEnd) {\n events?.onLogin?.(data, authClient!) // 登录成功\n } else {\n onGuardHandling?.()\n }\n }\n }\n\n const SendCode = useCallback(\n (props: any) => {\n return (\n <>\n {codeMethod === 'phone' && (\n <SendCodeByPhone\n {...props}\n isInternationSms={isInternationSms}\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('common.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n prefix={\n <IconFont\n type=\"authing-a-shield-check-line1\"\n style={{ color: '#878A95' }}\n />\n }\n scene={SceneType.SCENE_TYPE_RESET}\n maxLength={verifyCodeLength}\n data={identify}\n onSendCodeBefore={async () => {\n await form.validateFields(['identify'])\n }}\n />\n )}\n {codeMethod === 'email' && (\n <SendCodeByEmail\n {...props}\n className=\"authing-g2-input g2-send-code-input\"\n autoComplete=\"off\"\n size=\"large\"\n placeholder={t('common.inputFourVerifyCode', {\n length: verifyCodeLength,\n })}\n prefix={\n <IconFont\n type=\"authing-a-shield-check-line1\"\n style={{ color: '#878A95' }}\n />\n }\n scene={EmailScene.SELF_UNLOCKING_VERIFY_CODE}\n maxLength={verifyCodeLength}\n data={identify}\n onSendCodeBefore={async () => {\n await form.validateFields(['identify'])\n }}\n value={identify}\n />\n )}\n </>\n )\n },\n [codeMethod, form, identify, isInternationSms, t, verifyCodeLength]\n )\n\n return (\n <div className=\"authing-g2-login-phone-code\">\n <Form\n name=\"resetPassword\"\n form={form}\n onFinish={onFinish}\n onFinishFailed={() => {\n submitButtonRef?.current?.onError()\n }}\n autoComplete=\"off\"\n >\n <FormItemIdentify\n name=\"identify\"\n className=\"authing-g2-input-form\"\n methods={['email-code', 'phone-code']}\n currentMethod={InputMethodMap[codeMethod]}\n >\n <InputIdentify\n methods={['email-code', 'phone-code']}\n className=\"authing-g2-input\"\n autoComplete=\"off\"\n autoFocus={!isPhoneMedia}\n size=\"large\"\n value={identify}\n onChange={(e) => {\n let v = e.target.value\n setIdentify(v)\n if (validate('email', v)) {\n setCodeMethod('email')\n } else {\n setCodeMethod('phone')\n }\n }}\n prefix={\n <IconFont\n type=\"authing-a-user-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </FormItemIdentify>\n\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"code\"\n rules={[...fieldRequiredRule(t('common.captchaCode'))]}\n >\n <SendCode />\n </Form.Item>\n {selfUnlockStrategy === 'password-captcha' && (\n <Form.Item\n validateTrigger={['onBlur', 'onChange']}\n className=\"authing-g2-input-form\"\n name=\"password\"\n rules={[...fieldRequiredRule(t('common.password'))]}\n >\n <InputPassword\n className=\"authing-g2-input\"\n size=\"large\"\n placeholder={t('user.inputOldPwd')}\n prefix={\n <IconFont\n type=\"authing-a-lock-line1\"\n style={{ color: '#878A95' }}\n />\n }\n />\n </Form.Item>\n )}\n <Form.Item className=\"authing-g2-sumbit-form submit-form\">\n <SubmitButton\n className=\"forget-password\"\n text={t('common.unlock')}\n ref={submitButtonRef}\n />\n </Form.Item>\n </Form>\n </div>\n )\n}\n","import { Tabs } from 'antd'\nimport React, { useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { GuardModuleType } from '..'\nimport { BackCustom, BackLogin } from '../Back'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport { LoginWithPassword } from '../Login/core/withPassword'\nimport { LoginWithVerifyCode } from '../Login/core/withVerifyCode'\nimport { PasswordLoginMethods } from '../Type/application'\nimport {\n useGuardButtonState,\n useGuardEvents,\n useGuardFinallyConfig,\n useGuardInitData,\n useGuardModule,\n useGuardPublicConfig,\n} from '../_utils/context'\nimport { fallbackLng, i18n } from '../_utils/locales'\nimport {\n IdentityBindingBusinessAction,\n useIdentityBindingBusinessRequest,\n} from './businessRequest'\nimport { GuardIdentityBindingInitData } from './interface'\nimport './styles.less'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport const GuardIdentityBindingView: React.FC<{\n skipAsk?: boolean // 是否跳过询问页面\n}> = ({ skipAsk = false }) => {\n const initData = useGuardInitData<GuardIdentityBindingInitData>()\n\n const config = useGuardFinallyConfig()\n\n const { backModule } = useGuardModule()\n\n useGuardView()\n\n const { t } = useTranslation()\n\n const events = useGuardEvents()\n\n const { publicKey, agreementEnabled } = config\n\n const publicConfig = useGuardPublicConfig()\n\n const { spinChange } = useGuardButtonState()\n\n const isInternationSms =\n publicConfig?.internationalSmsConfig?.enabled || false\n\n const authClient = useGuardAuthClient()\n const bindType = skipAsk ? 'register' : 'bind'\n const phoneCodeRequest = useIdentityBindingBusinessRequest(bindType)[\n IdentityBindingBusinessAction.PhoneCode\n ]\n const emailCodeRequest = useIdentityBindingBusinessRequest(bindType)[\n IdentityBindingBusinessAction.EmailCode\n ]\n const PasswordRequest = useIdentityBindingBusinessRequest(bindType)[\n IdentityBindingBusinessAction.Password\n ]\n\n const bindMethodsMap = {\n 'phone-code': async (data: any) => {\n const { identity, code, phoneCountryCode } = data\n\n const options: any = {\n phone: identity,\n code,\n }\n\n if (isInternationSms) {\n options.phoneCountryCode = phoneCountryCode\n }\n return await phoneCodeRequest(options)\n },\n 'email-code': async (data: any) => {\n const { identity: email, code } = data\n return await emailCodeRequest({ email, code })\n },\n password: async (data: any) => {\n const { identity: account, password } = data\n\n const encrypt = authClient.options.encryptFunction\n\n const captchaCode = data.captchaCode && data.captchaCode.trim()\n\n const encryptPassword = await encrypt!(password, publicKey!)\n\n return await PasswordRequest({\n account,\n password: encryptPassword,\n captchaCode,\n })\n },\n }\n\n const onLoginSuccess = (data: any) => {\n events?.onBinding?.(data, authClient!) // 绑定成功\n\n events?.onLogin?.(data, authClient!) // 登录成功\n }\n\n const onLoginFailed = (code: number, data: any, message?: string) => {\n events?.onBindingError?.({\n code,\n data,\n message,\n })\n events?.onLoginError?.({\n code,\n data,\n message,\n })\n }\n\n const onBind = async (loginInfo: any) => {\n const { type, data } = loginInfo\n\n spinChange(true)\n\n const res = await bindMethodsMap[\n type as 'phone-code' | 'email-code' | 'password'\n ]?.(data)\n\n const { isFlowEnd } = res\n\n spinChange(false)\n\n if (isFlowEnd) {\n // 🤮 TODO 日后必要优化\n return {\n ...res,\n apiCode: 200,\n code: 200,\n }\n }\n\n return res\n }\n\n const agreements = useMemo(\n () =>\n agreementEnabled\n ? config?.agreements?.filter(\n (agree) =>\n fallbackLng(i18n.language).find((lng) =>\n lng.includes(agree.lang)\n ) && !!agree?.availableAt\n ) ?? []\n : [],\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [agreementEnabled, config?.agreements, i18n.language]\n )\n\n const passwordLoginMethods = useMemo<PasswordLoginMethods[]>(() => {\n const loginMethodsBase = [\n 'username-password',\n 'email-password',\n 'phone-password',\n ]\n\n // @ts-ignore\n return initData.methods.filter((method) =>\n loginMethodsBase.includes(method)\n ) as PasswordLoginMethods[]\n }, [initData.methods])\n\n const codeLoginMethods = useMemo(() => {\n const loginMethodsBase = ['email-code', 'phone-code']\n\n return initData.methods.filter((method) =>\n loginMethodsBase.includes(method)\n )\n }, [initData.methods])\n\n const bindText = useMemo(() => {\n if (skipAsk) {\n return `${t('common.bind')} / ${t('common.register')}`\n }\n return t('common.bind')\n }, [skipAsk, t])\n\n const methods = [\n {\n key: 'code',\n title: t('common.verifyCodeLogin'),\n component: (\n <LoginWithVerifyCode\n verifyCodeLength={publicConfig?.verifyCodeLength}\n autoRegister={!!skipAsk}\n onLoginRequest={onBind}\n // onLogin={onLogin}\n onLoginSuccess={onLoginSuccess}\n onLoginFailed={onLoginFailed}\n agreements={agreements}\n methods={codeLoginMethods}\n submitButText={bindText}\n />\n ),\n },\n {\n key: 'password',\n title: t('login.bindPwdLogin'),\n component: (\n <LoginWithPassword\n publicKey={publicKey!}\n autoRegister={!!skipAsk}\n host={config.host}\n onLoginRequest={onBind}\n passwordLoginMethods={passwordLoginMethods}\n // onLogin={onLogin}\n onLoginSuccess={onLoginSuccess}\n onLoginFailed={onLoginFailed}\n agreements={agreements}\n submitButText={bindText}\n />\n ),\n },\n ]\n\n const renderBack = useMemo(() => {\n if (initData.source === GuardModuleType.IDENTITY_BINDING_ASK)\n return (\n <BackCustom onBack={() => backModule?.()}>\n {t('common.back')}\n </BackCustom>\n )\n\n return <BackLogin />\n }, [backModule, initData.source, t])\n\n return (\n <div className=\"g2-view-container g2-view-identity-binding\">\n {renderBack}\n\n <div className=\"g2-view-identity-binding-content\">\n <div className=\"g2-view-identity-binding-content-logo\">\n <img src={config?.logo} alt=\"\" className=\"logo\" />\n </div>\n <div className=\"g2-view-identity-binding-content-title\">\n <span>\n {skipAsk\n ? t('common.identityBindingSkipAskTitle')\n : t('common.identityBindingTitle')}\n </span>\n </div>\n <div className=\"g2-view-identity-binding-content-desc\">\n <span>\n {skipAsk\n ? t('common.identityBindingSkipAskDesc')\n : t('common.identityBindingDesc')}\n </span>\n </div>\n <div className=\"g2-view-identity-binding-content-login\">\n <Tabs>\n {methods\n .filter((method) => {\n if (method.key === 'password')\n return passwordLoginMethods.length !== 0\n\n if (method.key === 'code') return codeLoginMethods.length !== 0\n\n return true\n })\n .map((method) => (\n <Tabs.TabPane key={method.key} tab={method.title}>\n {method.component}\n </Tabs.TabPane>\n ))}\n </Tabs>\n </div>\n </div>\n </div>\n )\n}\n","import React from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useAsyncFn } from 'react-use'\nimport { GuardModuleType } from '..'\nimport { BackLogin } from '../Back'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport { GuardButton } from '../GuardButton'\nimport { IconFont } from '../IconFont'\nimport { IdentityBindingAction } from '../IdentityBinding/businessRequest'\nimport {\n useGuardButtonState,\n useGuardEvents,\n useGuardInitData,\n useGuardModule,\n} from '../_utils/context'\nimport { useGuardHttp } from '../_utils/guardHttp'\nimport { GuardIdentityBindingAskInitData } from './interface'\nimport './styles.less'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport const GuardIdentityBindingAskView: React.FC = () => {\n const initData = useGuardInitData<GuardIdentityBindingAskInitData>()\n\n const { changeModule } = useGuardModule()\n\n useGuardView()\n\n const { t } = useTranslation()\n\n const { authFlow } = useGuardHttp()\n\n const authClient = useGuardAuthClient()\n\n const events = useGuardEvents()\n\n const { spinChange } = useGuardButtonState()\n\n const onCreate = (data: any) => {\n events?.onLogin?.(data, authClient)\n\n events?.onCreate?.(data, authClient)\n }\n\n const onCreateError = (code: any, data: any) => {\n events?.onCreateError?.({\n code,\n data,\n })\n events?.onLoginError?.({\n code,\n data,\n })\n }\n\n const [createLoading, createAccount] = useAsyncFn(async () => {\n spinChange(true)\n const { code, onGuardHandling, data, isFlowEnd } = await authFlow(\n IdentityBindingAction.CreateUser\n )\n\n spinChange(false)\n\n if (isFlowEnd) {\n onCreate(data)\n } else {\n onCreateError(code, data)\n\n onGuardHandling?.()\n }\n }, [])\n\n const bindingAccount = () => {\n changeModule?.(GuardModuleType.IDENTITY_BINDING, {\n ...initData,\n source: GuardModuleType.IDENTITY_BINDING_ASK,\n })\n }\n\n return (\n <div className=\"g2-view-container g2-view-identity-binding-ask\">\n <BackLogin />\n\n <div className=\"g2-view-identity-binding-ask-content\">\n <div className=\"g2-view-identity-binding-ask-content-title\">\n <span>{t('common.identityBindingAskTitle')}</span>\n </div>\n <div className=\"g2-view-identity-binding-ask-content-desc\">\n <span>{t('common.identityBindingAskDesc')}</span>\n </div>\n <div className=\"g2-view-identity-binding-ask-content-img\">\n <IconFont type=\"authing-bind\" />\n </div>\n <div className=\"g2-view-identity-binding-ask-content-button-group\">\n <GuardButton\n className=\"g2-view-identity-binding-ask-content-button g2-view-identity-binding-ask-content-button-create\"\n loading={createLoading.loading}\n onClick={createAccount}\n >\n {t('common.identityBindingCreate')}\n </GuardButton>\n <GuardButton\n className=\" g2-view-identity-binding-ask-content-button g2-view-identity-binding-ask-content-button-binding authing-g2-submit-button\"\n onClick={bindingAccount}\n type=\"primary\"\n >\n {t('common.identityBindingBinding')}\n </GuardButton>\n </div>\n </div>\n </div>\n )\n}\n","import { ConfigProvider, message, Modal } from 'antd'\nimport React, { useEffect, useMemo } from 'react'\nimport { GuardModuleType, GuardProps } from '..'\nimport { GuardBindTotpView } from '../../BindTotp'\nimport {\n GuardFirstLoginPasswordResetView,\n GuardForcedPasswordResetView,\n GuardNoticePasswordResetView,\n GuardPasswordNotSafeResetView,\n GuardRegisterCompletePasswordView,\n} from '../../ChangePassword'\nimport {\n GuardLoginCompleteInfoView,\n GuardRegisterCompleteInfoView,\n} from '../../CompleteInfo'\nimport { GuardDownloadATView } from '../../DownloadAuthenticator'\nimport { GuardErrorView } from '../../Error'\nimport { GuardForgetPassword } from '../../ForgetPassword'\nimport { GuardLoginView } from '../../Login'\nimport { GuardMFAView } from '../../MFA'\nimport { GuardNeedHelpView } from '../../NeedHelpView'\nimport { GuardRecoveryCodeView } from '../../RecoveryCode'\nimport { GuardRegisterView } from '../../Register'\nimport { GuardSubmitSuccessView } from '../../SubmitSuccess'\nimport {\n useGuardButtonContext,\n useGuardContextLoaded,\n useGuardCurrentModule,\n useGuardDefaultMergedConfig,\n useGuardHttpClient,\n useGuardModule,\n} from '../../_utils/context'\nimport zhCN from 'antd/lib/locale/zh_CN'\nimport enUS from 'antd/lib/locale/en_US'\nimport jaJP from 'antd/lib/locale/ja_JP'\nimport { i18n } from '../../_utils/locales'\nimport { GuardMode } from '../..'\nimport { IconFont } from '../../IconFont'\nimport { AuthingGuardResponse, AuthingResponse } from '../../_utils/http'\nimport {\n CodeAction,\n ChangeModuleApiCodeMapping,\n ApiCode,\n} from '../../_utils/responseManagement/interface'\nimport { GuardIdentityBindingView } from '../../IdentityBinding'\nimport { GuardIdentityBindingAskView } from '../../IdentityBindingAsk'\nimport '../styles.less'\nimport { updateFlowHandle } from '../../_utils/flowHandleStorage'\nimport { GuardUnlockView } from '../../SelfUnlock'\nimport { GuardSelectAccountView } from '../../SelectAccount'\nimport { GuardTenantPortalSelectView } from '../../TenantPortalSelect'\nimport { GuardNewSubmitSuccessView } from '../../NewSubmitSuccess'\n\nconst PREFIX_CLS = 'authing-ant'\n\nmessage.config({\n prefixCls: `${PREFIX_CLS}-message`,\n})\n\nexport enum LangMAP {\n zhCn = 'zh-CN',\n enUs = 'en-US',\n jaJp = 'ja-JP',\n}\n\nconst langMap = {\n [LangMAP.zhCn]: zhCN,\n [LangMAP.enUs]: enUS,\n [LangMAP.jaJp]: jaJP,\n}\n\nexport const RenderModule: React.FC<{\n guardProps: GuardProps\n}> = ({ guardProps }) => {\n const defaultMergedConfig = useGuardDefaultMergedConfig()\n\n const contextLoaded = useGuardContextLoaded()\n\n const { moduleName } = useGuardCurrentModule()\n\n const httpClient = useGuardHttpClient()\n\n const { changeModule } = useGuardModule()\n\n const { GuardButtonProvider } = useGuardButtonContext()\n\n const loadingComponent = useMemo(() => {\n return defaultMergedConfig.loadingComponent\n }, [defaultMergedConfig])\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n const ComponentsMapping: Record<\n GuardModuleType,\n (key: string) => React.ReactNode\n > = {\n // Error\n [GuardModuleType.ERROR]: (key: string) => <GuardErrorView key={key} />,\n // Login\n [GuardModuleType.LOGIN]: (key: string) => <GuardLoginView key={key} />,\n [GuardModuleType.RESET_ACCOUNT_NAME]: (key: string) => (\n <GuardLoginView key={key} isResetPage />\n ),\n // 身份源绑定\n [GuardModuleType.IDENTITY_BINDING]: (key: string) => (\n <GuardIdentityBindingView key={key} />\n ),\n // 身份源绑定 跳过询问页面\n [GuardModuleType.IDENTITY_BINDING_NO_ASK]: (key: string) => (\n <GuardIdentityBindingView key={key} skipAsk={true} />\n ),\n // 身份源绑定 问询\n [GuardModuleType.IDENTITY_BINDING_ASK]: (key: string) => (\n <GuardIdentityBindingAskView key={key} />\n ),\n // MFA\n [GuardModuleType.MFA]: (key: string) => <GuardMFAView key={key} />,\n // 注册\n [GuardModuleType.REGISTER]: (key: string) => (\n <GuardRegisterView key={key} />\n ),\n // 下载 Authenticator\n [GuardModuleType.DOWNLOAD_AT]: (key: string) => (\n <GuardDownloadATView key={key} />\n ),\n // 忘记密码 -> 重置密码\n [GuardModuleType.FORGET_PWD]: (key: string) => (\n <GuardForgetPassword key={key} />\n ),\n // 首次登录修改密码\n [GuardModuleType.FIRST_LOGIN_PASSWORD]: (key: string) => (\n <GuardFirstLoginPasswordResetView key={key} />\n ),\n // 提示修改密码\n [GuardModuleType.NOTICE_PASSWORD_RESET]: (key: string) => (\n <GuardNoticePasswordResetView key={key} />\n ),\n // 登陆安全策略 密码轮换\n [GuardModuleType.FORCED_PASSWORD_RESET]: (key: string) => (\n <GuardForcedPasswordResetView key={key} />\n ),\n // 绑定 TOTP\n [GuardModuleType.BIND_TOTP]: (key: string) => (\n <GuardBindTotpView key={key} />\n ),\n // 问题反馈\n [GuardModuleType.ANY_QUESTIONS]: (key: string) => (\n <GuardNeedHelpView key={key} />\n ),\n // MFA 恢复码\n [GuardModuleType.RECOVERY_CODE]: (key: string) => (\n <GuardRecoveryCodeView key={key} />\n ),\n // 提交成功\n [GuardModuleType.SUBMIT_SUCCESS]: (key: string) => (\n <GuardSubmitSuccessView key={key} />\n ),\n // 注册信息补全\n [GuardModuleType.REGISTER_COMPLETE_INFO]: (key: string) => (\n <GuardRegisterCompleteInfoView key={key} />\n ),\n // 登录信息补全\n [GuardModuleType.LOGIN_COMPLETE_INFO]: (key: string) => (\n <GuardLoginCompleteInfoView key={key} />\n ),\n // 注册密码补全\n [GuardModuleType.REGISTER_PASSWORD]: (key: string) => (\n <GuardRegisterCompletePasswordView key={key} />\n ),\n // 自助解锁\n [GuardModuleType.SELF_UNLOCK]: (key: string) => (\n <GuardUnlockView key={key} />\n ),\n [GuardModuleType.UNSAFE_PASSWORD_RESET]: (key) => (\n <GuardPasswordNotSafeResetView key={key} />\n ),\n [GuardModuleType.FLOW_SELECT_ACCOUNT]: (key) => (\n <GuardSelectAccountView key={key} />\n ),\n [GuardModuleType.TENANT_PORTAL]: (key) => <GuardTenantPortalSelectView />,\n [GuardModuleType.New_SUBMIT_SUCCESS]: (key) => (\n <GuardNewSubmitSuccessView key={key} />\n ),\n }\n\n // 初始化 请求拦截器 (Error Code)\n useEffect(() => {\n if (!httpClient || !changeModule) return\n\n // 错误码处理回调 切换 module 和 错误信息提示\n const errorCodeCb = (\n code: CodeAction,\n res: AuthingResponse\n ): AuthingGuardResponse => {\n // 判断有没有 flowHandle\n res.flowHandle && updateFlowHandle(res.flowHandle)\n\n const codeActionMapping = {\n [CodeAction.CHANGE_MODULE]: () => {\n const nextModule = ChangeModuleApiCodeMapping[res.apiCode!]\n\n const nextData = res.data\n\n changeModule(nextModule, nextData)\n return CodeAction.CHANGE_MODULE\n },\n [CodeAction.RENDER_MESSAGE]: () => {\n message.error(res.message ?? res.messages)\n return CodeAction.RENDER_MESSAGE\n },\n [CodeAction.FLOW_END]: () => {\n return CodeAction.FLOW_END\n },\n }\n\n const codeAction = codeActionMapping[code]\n\n if (!codeAction) return res\n\n if (res.apiCode === ApiCode.FLOW_END) {\n const newData = res.data.user\n\n return {\n ...res,\n onGuardHandling: codeAction,\n isFlowEnd: true,\n data: newData ? { ...newData } : res,\n }\n }\n\n return {\n ...res,\n onGuardHandling: codeAction,\n }\n }\n\n httpClient.initErrorCodeInterceptor(errorCodeCb)\n }, [httpClient, changeModule])\n\n const renderModule = useMemo(() => {\n if (contextLoaded) {\n // 传入的渲染指令不正确的情况处理\n if (!moduleName || !ComponentsMapping[moduleName]) {\n return (\n <GuardErrorView\n error={\n new Error(`未知错误!moduleName 为 <b>${moduleName}</b> 无法识别`)\n }\n />\n )\n }\n return ComponentsMapping[moduleName](new Date().toString())\n } else if (loadingComponent) {\n return loadingComponent\n }\n\n return null\n }, [ComponentsMapping, contextLoaded, loadingComponent, moduleName])\n\n const visible = useMemo(() => {\n return guardProps.visible\n }, [guardProps.visible])\n\n const renderGuardContent = useMemo(() => {\n return <GuardButtonProvider>{renderModule}</GuardButtonProvider>\n }, [GuardButtonProvider, renderModule])\n\n return (\n <ConfigProvider\n prefixCls={PREFIX_CLS}\n locale={langMap[i18n.language as LangMAP]}\n >\n {defaultMergedConfig.mode === GuardMode.Modal ? (\n <Modal\n className=\"authing-g2-render-module-modal\"\n closeIcon={\n <IconFont type=\"authing-close-line\" className=\"g2-modal-close\" />\n }\n closable={defaultMergedConfig.clickCloseable ?? true}\n visible={visible}\n onCancel={guardProps?.onClose}\n keyboard={defaultMergedConfig.escCloseable}\n maskClosable={false} // 点击蒙层,是否允许关闭\n getContainer={defaultMergedConfig.target ?? false}\n >\n <div className=\"authing-g2-render-module\">{renderGuardContent}</div>\n </Modal>\n ) : (\n <div\n style={defaultMergedConfig.style}\n className={`authing-g2-render-module ${\n defaultMergedConfig.__internalRequest__\n ? ''\n : 'authing-g2-render-module-normal'\n }`}\n >\n {renderGuardContent}\n </div>\n )}\n </ConfigProvider>\n )\n}\n","import React, { useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport { GuardModuleType } from '../Guard'\nimport { SelfUnlock } from './core/selfUnlock'\n\nimport { ImagePro } from '../ImagePro'\nimport { useGuardFinallyConfig, useGuardModule } from '../_utils/context'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport const GuardUnlockView: React.FC = () => {\n const { t } = useTranslation()\n\n const config = useGuardFinallyConfig()\n\n const { changeModule } = useGuardModule()\n\n const identifyRef = useRef('')\n\n useGuardView()\n\n return (\n <div className=\"g2-view-container g2-forget-password\">\n <div className=\"g2-view-header\">\n <ImagePro\n src={config?.logo!}\n size={48}\n borderRadius={4}\n alt=\"\"\n className=\"icon\"\n />\n <div className=\"title\">{t('login.selfUnlock')}</div>\n <div className=\"title-explain\">{t('login.selfUnlockText')}</div>\n </div>\n <div className=\"g2-view-tabs\">\n <SelfUnlock identifyRef={identifyRef} />\n </div>\n <div className=\"g2-tips-line\">\n <span>{t('user.unlockTip')} </span>\n <span\n className=\"link-like\"\n onClick={() =>\n changeModule?.(GuardModuleType.ANY_QUESTIONS, {\n identify: identifyRef.current,\n })\n }\n >\n {t('common.feedback')}\n </span>\n <div\n className=\"link-like back-to-login\"\n onClick={() => changeModule?.(GuardModuleType.LOGIN)}\n >\n {t('common.backLoginPage')}\n </div>\n </div>\n {/* <ChangeLanguage langRange={langRange} onLangChange={props.onLangChange} /> */}\n </div>\n )\n}\n","import { User } from 'authing-js-sdk'\nimport React, { useCallback, useMemo } from 'react'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport { ImagePro } from '../ImagePro'\nimport {\n useGuardEvents,\n useGuardFinallyConfig,\n useGuardHttpClient,\n useGuardInitData,\n} from '../_utils/context'\nimport './style.less'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport const GuardSelectAccountView = () => {\n const config = useGuardFinallyConfig()\n const events = useGuardEvents()\n const authClient = useGuardAuthClient()\n const { post } = useGuardHttpClient()\n const loadingComponent = useMemo(() => {\n return config.loadingComponent\n }, [config.loadingComponent])\n const initData = useGuardInitData<{\n accounts: User[]\n i18n: string\n }>()\n\n useGuardView()\n\n const onClick = useCallback(\n async (user: User) => {\n const { isFlowEnd, data, onGuardHandling } = await post(\n '/interaction/federation/binding/select',\n {\n account: user.id,\n }\n )\n if (isFlowEnd) {\n events?.onLogin?.(data, authClient)\n } else {\n onGuardHandling?.()\n }\n },\n [authClient, post, events]\n )\n const renderList = useMemo(() => {\n if (!initData) {\n return null\n }\n return initData?.accounts.map((user) => {\n const { id, photo, phone, email, username, nickname, name } = user\n const title = name || nickname || username || undefined\n const description = phone || email\n return (\n <li\n className=\"g2-select-account__li\"\n key={id}\n onClick={() => onClick(user)}\n >\n <img className=\"g2-select-account__avatar\" alt=\"\" src={photo || ''} />\n <div className=\"g2-select-account__body\">\n {title && <span className=\"g2-select-account__title\">{title}</span>}\n <span\n className={title ? 'g2-multiple__desc' : 'g2-multiple__title'}\n >\n {description}\n </span>\n </div>\n </li>\n )\n })\n }, [onClick, initData])\n const title = useMemo(() => {\n if (!initData) return ''\n return initData.i18n\n }, [initData])\n return (\n <>\n {!initData ? (\n loadingComponent\n ) : (\n <div className=\"g2-view-container\">\n <div className=\"g2-view-header\">\n <ImagePro\n src={config?.logo!}\n size={48}\n borderRadius={4}\n alt=\"\"\n className=\"icon\"\n />\n <div className=\"title\">{title}</div>\n </div>\n <div className=\"g2-view-tabs\">\n <ul className=\"g2-select-account_wrapper\">{renderList}</ul>\n </div>\n </div>\n )}\n </>\n )\n}\n","import './styles.less'\n\nimport Avatar, { AvatarProps } from 'antd/lib/avatar'\nimport Tag, { TagProps } from 'antd/lib/tag'\nimport React from 'react'\n\nexport interface GuardFaceProps {\n /** 顶部 avatar 头像展示 */\n avatar: AvatarProps | string\n /** 标题头部 */\n title: React.ReactNode\n /** 标题描述 */\n description?: React.ReactNode\n /** 标签功能 */\n tags?: TagProps[]\n}\n\n/** 顶部通用区域封装,同时兼容样式的层叠和功能的自定义 */\nexport const GuardFace = (props: GuardFaceProps) => {\n const { avatar, title, description, tags } = props\n const avatarProps: AvatarProps =\n typeof avatar === 'string'\n ? { shape: 'square', size: 48, src: avatar }\n : avatar\n return (\n <div className=\"g2-view-header\">\n <Avatar className=\"g2-view-avatar icon\" {...avatarProps} />\n <div className=\"title\">{title}</div>\n <div className=\"title-description\">{description}</div>\n {tags?.map?.((tag, i) => (\n <Tag key={i} className=\"authing-header-tag\" {...tag} />\n ))}\n </div>\n )\n}\n","import './styles.less'\n\nimport { Avatar, List } from 'antd'\nimport { AvatarProps } from 'antd/lib/avatar'\nimport { ListItemProps, ListProps } from 'antd/lib/list'\nimport classNames from 'classnames'\nimport React, { CSSProperties } from 'react'\n\nexport interface GuardSelectItem {\n /** avatar 头像展示 */\n avatar?: AvatarProps | string\n /** 标题 */\n title?: React.ReactNode\n /** 描述 */\n description?: React.ReactNode\n /** 右侧操作组 */\n actions?: ListItemProps['actions']\n /** 右侧额外的渲染内容 */\n extra?: ListItemProps['extra']\n /** 数据项子内容,便于自定义 */\n children?: React.ReactNode\n /** 其他元字段 */\n [key: string]: any\n}\n\nexport interface GuardSelectProps<T = any> extends ListProps<any> {\n /**数据项之间的间隙,默认`20px` */\n gap?: CSSProperties['marginBottom']\n /** 数据源 */\n dataSource: T[]\n\n onSelect?: (item?: T, index?: number) => void\n}\n\n/** 选择列表组件 兼容绝大多数选择场景 */\nexport const GuardSelect = <D extends GuardSelectItem = any>(\n props: GuardSelectProps<D>\n) => {\n const { dataSource, onSelect, gap = 20, ...listProps } = props\n\n return (\n <List\n split={false}\n size=\"small\"\n {...listProps}\n className={classNames(listProps.className, 'authing-guard-select-list')}\n dataSource={dataSource}\n renderItem={(item, i) => (\n <List.Item\n actions={item?.actions}\n extra={item?.extra}\n key={i}\n onClick={() => onSelect?.(item, i)}\n className={classNames('authing-guard-select-list-item')}\n style={dataSource?.length !== i + 1 ? { marginBottom: gap } : {}}\n >\n <List.Item.Meta\n avatar={\n typeof item?.avatar === 'string' ? (\n <Avatar size={40} src={item.avatar} />\n ) : (\n <Avatar size={40} {...item.avatar} />\n )\n }\n title={item?.title}\n description={item?.description}\n />\n </List.Item>\n )}\n />\n )\n}\n","import './styles.less'\n\nimport { omit } from 'lodash'\nimport React, { useCallback, useMemo } from 'react'\n\nimport {\n useGuardCurrentModule,\n useGuardEvents,\n useGuardHttpClient,\n useGuardInitData,\n} from '../_utils/context'\nimport { useGuardAuthClient } from '../Guard/authClient'\nimport { GuardFace } from '../GuardFace'\nimport { GuardSelect } from '../GuardSelect'\nimport { IconFont } from '../IconFont'\nimport {\n TenantPortalDataItem,\n TenantPortalDataType,\n TenantPortalSelectType,\n} from './interface'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport const GuardTenantPortalSelectView = () => {\n const { moduleName } = useGuardCurrentModule()\n const {\n list,\n title,\n description,\n logo,\n } = useGuardInitData<TenantPortalDataType>()\n const events = useGuardEvents()\n const authClient = useGuardAuthClient()\n const http = useGuardHttpClient()\n\n useGuardView()\n\n const handleSelect = useCallback(\n async (item?: TenantPortalDataItem) => {\n const metaData = omit<TenantPortalDataItem>(item, [\n 'avatar',\n 'extra',\n 'userName',\n 'title',\n ]) as TenantPortalSelectType\n events?.onTenantSelect?.(metaData)\n if (item?.host) {\n http.setBaseUrl(item?.host)\n }\n const { isFlowEnd, onGuardHandling, data } = await http.authFlow(\n moduleName\n )\n if (isFlowEnd) {\n setTimeout(() => events?.onLogin?.(data, authClient)) // 让选择事件先行,登录成功宏任务异步,方便异步并发\n } else {\n onGuardHandling?.()\n }\n },\n [authClient, events, http, moduleName]\n )\n\n const dataSource = useMemo<TenantPortalDataItem[]>(\n () =>\n list?.map?.((it) => ({\n ...it,\n title: it.tenantName!,\n description: it.userName!,\n avatar: { size: 40, src: it.tenantLogo! },\n extra: (\n <IconFont\n type=\"authing-arrow-left-s-line\" // 没有右箭头,使用左箭头旋转\n className=\"authing-gaurd-select-extra-icon\"\n />\n ),\n })) as TenantPortalDataItem[],\n [list]\n )\n return (\n <div className=\"g2-view-container\">\n <div className=\"g2-view-container-inner\">\n <GuardFace title={title} description={description} avatar={logo} />\n {!!dataSource?.length && (\n <GuardSelect dataSource={dataSource} onSelect={handleSelect} />\n )}\n </div>\n </div>\n )\n}\n","import React, { useEffect, useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { GuardModuleType } from '..'\nimport { ImagePro } from '../ImagePro'\nimport SubmitButton from '../SubmitButton'\nimport {\n useGuardInitData,\n useGuardModule,\n useGuardPublicConfig,\n} from '../_utils/context'\nimport { SubmitSuccessInitData } from './interface'\n\nimport { useGuardView } from '../Guard/core/hooks/useGuardView'\n\nexport const GuardNewSubmitSuccessView: React.FC = () => {\n const { t } = useTranslation()\n\n const initData = useGuardInitData<SubmitSuccessInitData>()\n\n const { changeModule: __changeModule } = useGuardModule()\n\n const [countDown, setCountDown] = useState(5)\n\n const timerRef = useRef<any>(0)\n\n const publicConfig = useGuardPublicConfig()\n\n useGuardView()\n\n const {\n title = t('login.resetPassword.successTip'),\n message = t('login.resetPassword.successTipMsg'),\n text = t('login.resetPassword.back'),\n countDesc = t('login.resetPassword.backLogin'),\n // changeModule = GuardModuleType.LOGIN,\n needBack = true,\n goBack = () => __changeModule?.(GuardModuleType.LOGIN),\n } = initData ?? {}\n const cdnBase = publicConfig?.cdnBase\n\n useEffect(() => {\n timerRef.current = setInterval(() => {\n setCountDown((prev) => {\n return prev - 1\n })\n }, 1000)\n\n return () => clearInterval(timerRef.current)\n }, [])\n\n useEffect(() => {\n if (countDown <= 0) {\n clearInterval(timerRef.current)\n needBack && goBack?.()\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [countDown, needBack, goBack])\n\n return (\n <div className=\"g2-view-container g2-submit-success g2-view-container-submit-success\">\n <div className=\"g2-view-tabs g2-questions-send-success-pageWrap\">\n <ImagePro\n className=\"plate-submit-success\"\n src={`${cdnBase}/questions-send-ok.png`}\n alt=\"\"\n width={157}\n height={120}\n />\n <div className=\"success-page-title \">{title}</div>\n <div className=\"success-page-message\">{message}</div>\n {needBack && (\n <>\n <SubmitButton\n className=\"success-page-btn\"\n onClick={() => {\n goBack?.()\n }}\n text={text as string}\n />\n <div className=\"success-page-timer-tip\">\n {countDown} {countDesc}\n </div>\n </>\n )}\n </div>\n </div>\n )\n}\n","import { GuardModuleType } from '../../Guard'\n\nexport enum CodeAction {\n // 切换 Module\n CHANGE_MODULE = 'changeModule',\n // 渲染 错误信息\n RENDER_MESSAGE = 'renderMessage',\n // 流程 结束\n FLOW_END = 'flowEnd',\n}\n\nexport enum ApiCode {\n IDENTITY_BINDING_ASK = 1641,\n\n IDENTITY_BINDING = 1640,\n\n IDENTITY_BINDING_NO_ASK = 1666,\n\n APP_MFA = 1636,\n\n MFA = 1635,\n\n ABORT_FLOW = 1699,\n\n COMPLETE_INFO = 1642,\n\n UNLOCK = 1643,\n\n FLOW_END = 1600,\n\n FIRST_LOGIN_PASSWORD = 1639,\n\n FORCED_PASSWORD_RESET = 2058,\n\n UNSAFE_PASSWORD_TIP = 2061,\n\n UNSAFE_PASSWORD_RESET = 2071,\n\n FLOW_SELECT_ACCOUNT = 2921,\n\n TENANT_PORTAL = 1644,\n\n RESET_ACCOUNT_NAME = 1108, // 用户名重复\n}\n\nexport const ChangeModuleApiCodeMapping: Record<string, GuardModuleType> = {\n [ApiCode.IDENTITY_BINDING]: GuardModuleType.IDENTITY_BINDING,\n [ApiCode.IDENTITY_BINDING_ASK]: GuardModuleType.IDENTITY_BINDING_ASK,\n [ApiCode.IDENTITY_BINDING_NO_ASK]: GuardModuleType.IDENTITY_BINDING_NO_ASK,\n [ApiCode.RESET_ACCOUNT_NAME]: GuardModuleType.RESET_ACCOUNT_NAME,\n [ApiCode.APP_MFA]: GuardModuleType.MFA,\n [ApiCode.MFA]: GuardModuleType.MFA,\n [ApiCode.ABORT_FLOW]: GuardModuleType.LOGIN,\n [ApiCode.COMPLETE_INFO]: GuardModuleType.LOGIN_COMPLETE_INFO,\n [ApiCode.FIRST_LOGIN_PASSWORD]: GuardModuleType.FIRST_LOGIN_PASSWORD,\n [ApiCode.FORCED_PASSWORD_RESET]: GuardModuleType.FORCED_PASSWORD_RESET,\n [ApiCode.UNLOCK]: GuardModuleType.SELF_UNLOCK,\n [ApiCode.UNSAFE_PASSWORD_RESET]: GuardModuleType.UNSAFE_PASSWORD_RESET,\n [ApiCode.FLOW_SELECT_ACCOUNT]: GuardModuleType.FLOW_SELECT_ACCOUNT,\n [ApiCode.TENANT_PORTAL]: GuardModuleType.TENANT_PORTAL,\n}\n","import { initFacePlugin } from '../../_utils/facePlugin'\nimport { FacePlugin } from '../../_utils/facePlugin/interface'\nimport isEqual from 'lodash/isEqual'\n\nexport const useGuardPlugin: any = (plugin: { facePlugin?: FacePlugin }) => {\n const { facePlugin } = plugin\n\n return useGuardFacePlugin(facePlugin)\n}\n\nexport const useGuardFacePlugin = (facePlugin?: FacePlugin) => {\n if (!facePlugin) return true\n\n const guardFace = initFacePlugin(facePlugin)\n\n return isEqual(guardFace, facePlugin)\n}\n","import React from 'react'\nimport { GuardProps } from '..'\nimport { ModuleState } from '../GuardModule/stateMachine'\nimport { RenderContext } from './renderContext'\nimport { RenderModule } from './renderModule'\nimport { useGuardPlugin } from './usePlugin'\n\nexport interface GuardCoreProps {\n guardProps: GuardProps\n initState: ModuleState\n}\n\nexport const GuardCore = (props: GuardCoreProps) => {\n const { guardProps, initState } = props\n\n useGuardPlugin(guardProps)\n\n return (\n <RenderContext guardProps={guardProps} initState={initState}>\n <RenderModule guardProps={guardProps} />\n </RenderContext>\n )\n}\n","import { memo, useEffect, useRef, useState } from 'react'\nimport { GuardEvents } from './event'\nimport { GuardAppendConfig, IG2FCProps } from '../Type'\nimport { GuardLocalConfig } from './config'\nimport { GuardModuleType } from './module'\nimport 'moment/locale/zh-cn'\nimport { GuardCore } from './core/index'\nimport { getDocumentNode, GuardPropsFilter } from '../_utils'\nimport React from 'react'\nimport { initGuardDocument } from '../_utils/guardDocument'\n\nexport interface GuardProps extends GuardEvents, IG2FCProps {\n config?: Partial<GuardLocalConfig>\n appendConfig?: GuardAppendConfig\n}\n\ninterface ModuleState {\n moduleName: GuardModuleType\n initData: any\n}\n\nconst propsAreEqual = (pre: GuardProps, current: GuardProps) => {\n return GuardPropsFilter(pre, current)\n}\n\nexport const Guard = memo((props: GuardProps) => {\n const { config } = props\n\n const ref = useRef<HTMLDivElement>(null)\n\n const [guardWindowMount, mounted] = useState<boolean>(false)\n\n // 锁定 Guard 中 window 指向\n useEffect(() => {\n if (!ref?.current) return\n\n const guardDocument = getDocumentNode(ref.current)\n\n initGuardDocument(guardDocument)\n\n mounted(true)\n }, [])\n\n // 首页 init 数据\n const initState: ModuleState = {\n moduleName: config?.defaultScenes ?? GuardModuleType.LOGIN,\n initData: config?.defaultInitData ?? {},\n }\n\n return (\n <div ref={ref}>\n {guardWindowMount && (\n <GuardCore guardProps={props} initState={initState} />\n )}\n </div>\n )\n}, propsAreEqual)\n","import React from 'react'\nimport ReactDOM from 'react-dom'\nimport reportWebVitals from './reportWebVitals'\nimport * as facePlugin from 'face-api.js'\nimport { Guard, GuardMode } from './components'\n// import { AuthenticationClient } from 'authing-js-sdk'\n\nconst App = () => {\n return (\n <div\n // style={{\n // display: 'flex',\n // width: '100vw',\n // justifyContent: 'center',\n // alignItems: 'center',\n // WebkitUserSelect: 'none',\n // minHeight: '100vh',\n // background: '#F5F7FA',\n // }}\n >\n <Guard\n appId=\"64196bdaa5b19f2a6e4316d0\"\n config={\n {\n // host: 'https://demo-app-20230321.authn.authing-inc.co',\n // host: 'https://console.mysql.authing-inc.co/',\n // loadingComponent: 'loading------------',\n // mode: GuardMode.Modal,\n // visible: true,\n // style: { color: 'red', position: 'relative' },\n }\n }\n facePlugin={facePlugin}\n onBeforeLogin={(data) => {\n console.log('bbbb', data)\n return true\n }}\n onLoginError={(err) => {\n console.log('err: ', err)\n }}\n onLogin={(data) => {\n console.log('data: ', data)\n }}\n />\n {/* <button\n onClick={() => {\n authenticationClient.logout()\n }}\n >\n 退出登录\n </button> */}\n </div>\n )\n}\n\nReactDOM.render(<App />, document.getElementById('root'))\n\nreportWebVitals()\n"],"sourceRoot":""}
|