import React, { useEffect, useState } from 'react'; import { Button, Divider, Form, Header, Image, Modal } from 'semantic-ui-react'; import { Link } from 'react-router-dom'; import { API, copy, showError, showInfo, showSuccess } from '../helpers'; import Turnstile from 'react-turnstile'; const PersonalSetting = () => { const [inputs, setInputs] = useState({ wechat_verification_code: '', email_verification_code: '', email: '', }); const [status, setStatus] = useState({}); const [showWeChatBindModal, setShowWeChatBindModal] = useState(false); const [showEmailBindModal, setShowEmailBindModal] = useState(false); const [turnstileEnabled, setTurnstileEnabled] = useState(false); const [turnstileSiteKey, setTurnstileSiteKey] = useState(''); const [turnstileToken, setTurnstileToken] = useState(''); const [loading, setLoading] = useState(false); useEffect(() => { let status = localStorage.getItem('status'); if (status) { status = JSON.parse(status); setStatus(status); if (status.turnstile_check) { setTurnstileEnabled(true); setTurnstileSiteKey(status.turnstile_site_key); } } }, []); const handleInputChange = (e, { name, value }) => { setInputs((inputs) => ({ ...inputs, [name]: value })); }; const generateToken = async () => { const res = await API.get('/api/user/token'); const { success, message, data } = res.data; if (success) { await copy(data); showSuccess(`令牌已重置并已复制到剪贴板:${data}`); } else { showError(message); } }; const bindWeChat = async () => { if (inputs.wechat_verification_code === '') return; const res = await API.get( `/api/oauth/wechat/bind?code=${inputs.wechat_verification_code}` ); const { success, message } = res.data; if (success) { showSuccess('微信账户绑定成功!'); setShowWeChatBindModal(false); } else { showError(message); } }; const openGitHubOAuth = () => { window.open( `https://github.com/login/oauth/authorize?client_id=${status.github_client_id}&scope=user:email` ); }; const sendVerificationCode = async () => { if (inputs.email === '') return; if (turnstileEnabled && turnstileToken === '') { showInfo('请稍后几秒重试,Turnstile 正在检查用户环境!'); return; } setLoading(true); const res = await API.get( `/api/verification?email=${inputs.email}&turnstile=${turnstileToken}` ); const { success, message } = res.data; if (success) { showSuccess('验证码发送成功,请检查邮箱!'); } else { showError(message); } setLoading(false); }; const bindEmail = async () => { if (inputs.email_verification_code === '') return; setLoading(true); const res = await API.get( `/api/oauth/email/bind?email=${inputs.email}&code=${inputs.email_verification_code}` ); const { success, message } = res.data; if (success) { showSuccess('邮箱账户绑定成功!'); setShowEmailBindModal(false); } else { showError(message); } setLoading(false); }; return (
通用设置
账号绑定
setShowWeChatBindModal(false)} onOpen={() => setShowWeChatBindModal(true)} open={showWeChatBindModal} size={'mini'} >

微信扫码关注公众号,输入「验证码」获取验证码(三分钟内有效)

setShowEmailBindModal(false)} onOpen={() => setShowEmailBindModal(true)} open={showEmailBindModal} size={'tiny'} style={{ maxWidth: '450px' }} > 绑定邮箱地址
获取验证码 } /> {turnstileEnabled ? ( { setTurnstileToken(token); }} /> ) : ( <> )}
); }; export default PersonalSetting;