import React, {useContext, useEffect, useState} from 'react'; import {Link, useNavigate} from 'react-router-dom'; import {API, copy, isRoot, showError, showInfo, showNotice, showSuccess} from '../helpers'; import Turnstile from 'react-turnstile'; import {UserContext} from '../context/User'; import {onGitHubOAuthClicked} from './utils'; import { Avatar, Banner, Button, Card, Descriptions, Divider, Image, Input, InputNumber, Layout, Modal, Space, Tag, Typography } from "@douyinfe/semi-ui"; import {getQuotaPerUnit, renderQuota, renderQuotaWithPrompt, stringToColor} from "../helpers/render"; import EditToken from "../pages/Token/EditToken"; import EditUser from "../pages/User/EditUser"; import passwordResetConfirm from "./PasswordResetConfirm"; import TelegramLoginButton from 'react-telegram-login'; const PersonalSetting = () => { const [userState, userDispatch] = useContext(UserContext); let navigate = useNavigate(); const [inputs, setInputs] = useState({ wechat_verification_code: '', email_verification_code: '', email: '', self_account_deletion_confirmation: '', set_new_password: '', set_new_password_confirmation: '', }); const [status, setStatus] = useState({}); const [showChangePasswordModal, setShowChangePasswordModal] = useState(false); const [showWeChatBindModal, setShowWeChatBindModal] = useState(false); const [showEmailBindModal, setShowEmailBindModal] = useState(false); const [showAccountDeleteModal, setShowAccountDeleteModal] = useState(false); const [turnstileEnabled, setTurnstileEnabled] = useState(false); const [turnstileSiteKey, setTurnstileSiteKey] = useState(''); const [turnstileToken, setTurnstileToken] = useState(''); const [loading, setLoading] = useState(false); const [disableButton, setDisableButton] = useState(false); const [countdown, setCountdown] = useState(30); const [affLink, setAffLink] = useState(""); const [systemToken, setSystemToken] = useState(""); const [models, setModels] = useState([]); const [openTransfer, setOpenTransfer] = useState(false); const [transferAmount, setTransferAmount] = useState(0); useEffect(() => { // let user = localStorage.getItem('user'); // if (user) { // userDispatch({ type: 'login', payload: user }); // } // console.log(localStorage.getItem('user')) let status = localStorage.getItem('status'); if (status) { status = JSON.parse(status); setStatus(status); if (status.turnstile_check) { setTurnstileEnabled(true); setTurnstileSiteKey(status.turnstile_site_key); } } getUserData().then( (res) => { console.log(userState) } ); loadModels().then(); getAffLink().then(); setTransferAmount(getQuotaPerUnit()) }, []); useEffect(() => { let countdownInterval = null; if (disableButton && countdown > 0) { countdownInterval = setInterval(() => { setCountdown(countdown - 1); }, 1000); } else if (countdown === 0) { setDisableButton(false); setCountdown(30); } return () => clearInterval(countdownInterval); // Clean up on unmount }, [disableButton, countdown]); const handleInputChange = (name, value) => { setInputs((inputs) => ({...inputs, [name]: value})); }; const generateAccessToken = async () => { const res = await API.get('/api/user/token'); const {success, message, data} = res.data; if (success) { setSystemToken(data); await copy(data); showSuccess(`令牌已重置并已复制到剪贴板`); } else { showError(message); } }; const getAffLink = async () => { const res = await API.get('/api/user/aff'); const {success, message, data} = res.data; if (success) { let link = `${window.location.origin}/register?aff=${data}`; setAffLink(link); } else { showError(message); } }; const getUserData = async () => { let res = await API.get(`/api/user/self`); const {success, message, data} = res.data; if (success) { userDispatch({type: 'login', payload: data}); } else { showError(message); } } const loadModels = async () => { let res = await API.get(`/api/user/models`); const {success, message, data} = res.data; if (success) { setModels(data); console.log(data) } else { showError(message); } } const handleAffLinkClick = async (e) => { e.target.select(); await copy(e.target.value); showSuccess(`邀请链接已复制到剪切板`); }; const handleSystemTokenClick = async (e) => { e.target.select(); await copy(e.target.value); showSuccess(`系统令牌已复制到剪切板`); }; const deleteAccount = async () => { if (inputs.self_account_deletion_confirmation !== userState.user.username) { showError('请输入你的账户名以确认删除!'); return; } const res = await API.delete('/api/user/self'); const {success, message} = res.data; if (success) { showSuccess('账户已删除!'); await API.get('/api/user/logout'); userDispatch({type: 'logout'}); localStorage.removeItem('user'); navigate('/login'); } 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 changePassword = async () => { if (inputs.set_new_password !== inputs.set_new_password_confirmation) { showError('两次输入的密码不一致!'); return; } const res = await API.put( `/api/user/self`, { password: inputs.set_new_password } ); const {success, message} = res.data; if (success) { showSuccess('密码修改成功!'); setShowWeChatBindModal(false); } else { showError(message); } setShowChangePasswordModal(false); }; const transfer = async () => { if (transferAmount < getQuotaPerUnit()) { showError('划转金额最低为' + renderQuota(getQuotaPerUnit())); return; } const res = await API.post( `/api/user/aff_transfer`, { quota: transferAmount } ); const {success, message} = res.data; if (success) { showSuccess(message); setOpenTransfer(false); getUserData().then(); } else { showError(message); } }; const sendVerificationCode = async () => { if (inputs.email === '') { showError('请输入邮箱!'); return; } setDisableButton(true); 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 === '') { showError('请输入邮箱验证码!'); 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); userState.user.email = inputs.email; } else { showError(message); } setLoading(false); }; const getUsername = () => { if (userState.user) { return userState.user.username; } else { return 'null'; } } const handleCancel = () => { setOpenTransfer(false); } const copyText = async (text) => { if (await copy(text)) { showSuccess('已复制:' + text); } else { // setSearchKeyword(text); Modal.error({title: '无法复制到剪贴板,请手动复制', content: text}); } } return (
微信扫码关注公众号,输入「验证码」获取验证码(三分钟内有效)