Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 1 | import React, { useState,useEffect } from 'react';
|
| 2 | import { useNavigate, useLocation } from 'react-router-dom';
|
| 3 | import { getUserInfo, updatePassword } from '../../api/personal';
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 4 | import './personalSubpage.css';
|
| 5 |
|
| 6 | const Setting = ({ onLogout }) => {
|
| 7 | const navigate = useNavigate();
|
| 8 | const location = useLocation();
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 9 | const [userInfo, setUserInfo] = useState(null);
|
| 10 | const [loading, setLoading] = useState(false);
|
| 11 | const [error, setError] = useState(null);
|
| 12 | const [success, setSuccess] = useState(null);
|
| 13 | const [passwordForm, setPasswordForm] = useState({
|
| 14 | oldPassword: '',
|
| 15 | newPassword: '',
|
| 16 | confirmPassword: ''
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 17 | });
|
| 18 |
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 19 | // 获取用户信息
|
| 20 | useEffect(() => {
|
| 21 | const fetchUserInfo = async () => {
|
| 22 | try {
|
| 23 | const info = await getUserInfo();
|
| 24 | setUserInfo(info);
|
| 25 | } catch (err) {
|
| 26 | console.error('获取用户信息失败:', err);
|
| 27 | }
|
| 28 | };
|
| 29 | fetchUserInfo();
|
| 30 | }, []);
|
| 31 |
|
| 32 | const handleBack = () => {
|
| 33 | navigate('/personal', {
|
| 34 | state: {
|
| 35 | fromSubpage: true,
|
| 36 | dashboardTab: location.state?.dashboardTab
|
| 37 | },
|
| 38 | replace: true
|
| 39 | });
|
| 40 | };
|
| 41 |
|
| 42 | const handlePasswordChange = (e) => {
|
| 43 | const { name, value } = e.target;
|
| 44 | setPasswordForm(prev => ({
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 45 | ...prev,
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 46 | [name]: value
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 47 | }));
|
| 48 | };
|
| 49 |
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 50 | const handlePasswordSubmit = async (e) => {
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 51 | e.preventDefault();
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 52 | setError(null);
|
| 53 | setSuccess(null);
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 54 |
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 55 | // 验证表单
|
| 56 | if (!passwordForm.oldPassword || !passwordForm.newPassword || !passwordForm.confirmPassword) {
|
| 57 | setError('请填写所有密码字段');
|
| 58 | return;
|
| 59 | }
|
| 60 |
|
| 61 | if (passwordForm.newPassword !== passwordForm.confirmPassword) {
|
| 62 | setError('新密码与确认密码不一致');
|
| 63 | return;
|
| 64 | }
|
| 65 |
|
| 66 | if (passwordForm.newPassword.length < 6) {
|
| 67 | setError('新密码长度至少为6位');
|
| 68 | return;
|
| 69 | }
|
| 70 |
|
| 71 | try {
|
| 72 | setLoading(true);
|
| 73 | await updatePassword(passwordForm.oldPassword, passwordForm.newPassword);
|
| 74 | setSuccess('密码修改成功');
|
| 75 | setPasswordForm({
|
| 76 | oldPassword: '',
|
| 77 | newPassword: '',
|
| 78 | confirmPassword: ''
|
| 79 | });
|
| 80 | } catch (err) {
|
| 81 | setError(err.message || '修改密码失败');
|
| 82 | } finally {
|
| 83 | setLoading(false);
|
| 84 | }
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 85 | };
|
| 86 |
|
| 87 | return (
|
| 88 | <div className="subpage-container">
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 89 | <button className="back-button" onClick={handleBack}>
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 90 | ← 返回个人中心
|
| 91 | </button>
|
| 92 |
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 93 | <h2 className="page-title">个人设置</h2>
|
| 94 |
|
| 95 | <div className="setting-section">
|
| 96 | <div className="user-info-card">
|
| 97 | <h3>账户信息</h3>
|
| 98 | <div className="info-item">
|
| 99 | <label>用户名:</label>
|
| 100 | <span>{userInfo?.username || '加载中...'}</span>
|
| 101 | </div>
|
| 102 | <p className="info-note">用户名不可更改</p>
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 103 | </div>
|
| 104 |
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 105 | <div className="password-form-card">
|
| 106 | <h3>修改密码</h3>
|
| 107 | <form onSubmit={handlePasswordSubmit}>
|
| 108 | <div className="form-group">
|
| 109 | <label htmlFor="oldPassword">原密码:</label>
|
| 110 | <input
|
| 111 | type="password"
|
| 112 | id="oldPassword"
|
| 113 | name="oldPassword"
|
| 114 | value={passwordForm.oldPassword}
|
| 115 | onChange={handlePasswordChange}
|
| 116 | required
|
| 117 | />
|
| 118 | </div>
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 119 |
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 120 | <div className="form-group">
|
| 121 | <label htmlFor="newPassword">新密码:</label>
|
| 122 | <input
|
| 123 | type="password"
|
| 124 | id="newPassword"
|
| 125 | name="newPassword"
|
| 126 | value={passwordForm.newPassword}
|
| 127 | onChange={handlePasswordChange}
|
| 128 | required
|
| 129 | minLength="6"
|
| 130 | />
|
| 131 | </div>
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 132 |
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 133 | <div className="form-group">
|
| 134 | <label htmlFor="confirmPassword">确认新密码:</label>
|
| 135 | <input
|
| 136 | type="password"
|
| 137 | id="confirmPassword"
|
| 138 | name="confirmPassword"
|
| 139 | value={passwordForm.confirmPassword}
|
| 140 | onChange={handlePasswordChange}
|
| 141 | required
|
| 142 | minLength="6"
|
| 143 | />
|
| 144 | </div>
|
| 145 |
|
| 146 | {error && <div className="error-message">{error}</div>}
|
| 147 | {success && <div className="success-message">{success}</div>}
|
| 148 |
|
| 149 | <button
|
| 150 | type="submit"
|
| 151 | className="submit-button"
|
| 152 | disabled={loading}
|
| 153 | >
|
| 154 | {loading ? '处理中...' : '修改密码'}
|
| 155 | </button>
|
| 156 | </form>
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 157 | </div>
|
Akane1217 | 3a7bb97 | 2025-06-01 01:05:27 +0800 | [diff] [blame] | 158 | </div>
|
Akane1217 | 65b61a7 | 2025-05-17 13:52:25 +0800 | [diff] [blame] | 159 | </div>
|
| 160 | );
|
| 161 | };
|
| 162 |
|
| 163 | export default Setting; |