training_data/apps/web/src/app/login.tsx

154 lines
7.8 KiB
TypeScript
Raw Normal View History

2024-09-10 10:31:24 +08:00
import React, { useState, useRef, useEffect } from 'react';
import { Form, Input, Button, message } from 'antd';
import { Link, useLocation, useNavigate } from 'react-router-dom';
import DepartmentSelect from '../components/models/department/department-select';
import { useAuth } from '../providers/auth-provider';
import SineWave from '../components/presentation/animation/sine-wave';
const LoginPage: React.FC = () => {
const [showLogin, setShowLogin] = useState(true);
const [registerLoading, setRegisterLoading] = useState(false);
2024-09-10 11:23:02 +08:00
const { login, isAuthenticated, signup } = useAuth();
2024-09-10 10:31:24 +08:00
const loginFormRef = useRef<any>(null);
const registerFormRef = useRef<any>(null);
const location = useLocation();
2024-09-10 11:23:02 +08:00
const navigate = useNavigate();
2024-09-10 10:31:24 +08:00
const onFinishLogin = async (values: any) => {
try {
const { username, password } = values;
await login(username, password);
message.success('登录成功!');
} catch (err) {
2024-09-10 11:23:02 +08:00
message.error('用户名或密码错误!');
2024-09-10 10:31:24 +08:00
console.error(err);
}
};
const onFinishRegister = async (values: any) => {
setRegisterLoading(true);
2024-09-10 11:23:02 +08:00
const { username, password, phoneNumber } = values;
2024-09-10 10:31:24 +08:00
try {
2024-09-10 11:23:02 +08:00
await signup(username, password, phoneNumber);
2024-09-10 10:31:24 +08:00
message.success('注册成功!');
setShowLogin(true);
loginFormRef.current.submit();
} catch (err) {
console.error(err);
} finally {
setRegisterLoading(false);
}
};
useEffect(() => {
if (isAuthenticated) {
const params = new URLSearchParams(location.search);
const redirectUrl = params.get('redirect_url') || '/';
navigate(redirectUrl, { replace: true });
}
}, [isAuthenticated, location]);
return (
<div className="flex justify-center items-center h-screen w-full bg-layout">
2024-09-10 11:23:02 +08:00
<div className="flex items-center transition-all overflow-hidden bg-container rounded-xl " style={{ width: 800, height: 600 }}>
2024-09-10 10:31:24 +08:00
<div className="flex-1 py-10 px-10">
{showLogin ? (
<>
<div className="text-center text-2xl text-primary select-none">
<span className="px-2"></span>
</div>
<Form ref={loginFormRef} onFinish={onFinishLogin} layout="vertical" requiredMark="optional" size="large">
<Form.Item name="username" label="用户名" rules={[{ required: true, message: '请输入用户名' }]}>
<Input />
</Form.Item>
<Form.Item name="password" label="密码" rules={[{ required: true, message: '请输入密码' }]}>
<Input.Password />
</Form.Item>
<div className="flex items-center justify-center">
<Button type="primary" htmlType="submit">
</Button>
</div>
</Form>
</>
) : (
2024-09-10 11:23:02 +08:00
<div >
2024-09-10 10:31:24 +08:00
<div className="text-center text-2xl text-primary"></div>
<Form requiredMark="optional" ref={registerFormRef} onFinish={onFinishRegister} layout="vertical" size="large">
<Form.Item name="username" label="用户名" rules={[
{ required: true, message: '请输入用户名' },
{ min: 3, max: 15, message: '用户名长度在 3 到 15 个字符' }
]}>
2024-09-10 11:23:02 +08:00
<Input />
2024-09-10 10:31:24 +08:00
</Form.Item>
2024-09-10 11:23:02 +08:00
<Form.Item name="phoneNumber" label="手机号" rules={[
{ required: false },
{ pattern: /^1[3-9]\d{9}$/, message: '请输入有效的手机号' }
]}>
<Input />
2024-09-10 10:31:24 +08:00
</Form.Item>
<Form.Item name="password" label="密码" rules={[
{ required: true, message: '请输入密码' },
{ min: 6, message: '密码长度不能小于 6 位' }
]}>
2024-09-10 11:23:02 +08:00
<Input.Password />
2024-09-10 10:31:24 +08:00
</Form.Item>
<Form.Item name="repeatPass" label="确认密码" dependencies={['password']} hasFeedback rules={[
{ required: true, message: '请再次输入密码' },
({ getFieldValue }) => ({
validator(_, value) {
if (!value || getFieldValue('password') === value) {
return Promise.resolve();
}
return Promise.reject(new Error('两次输入的密码不一致'));
}
})
]}>
2024-09-10 11:23:02 +08:00
<Input.Password />
2024-09-10 10:31:24 +08:00
</Form.Item>
<div className="flex items-center justify-center">
<Button loading={registerLoading} type="primary" htmlType="submit">
</Button>
</div>
</Form>
2024-09-10 11:23:02 +08:00
</div>
2024-09-10 10:31:24 +08:00
)}
</div>
<div className={`transition-all h-full flex-1 text-white p-10 flex items-center justify-center bg-primary`}>
{showLogin ? (
<div className="flex flex-col">
<SineWave width={300} height={200} />
<div className="text-2xl my-4"></div>
<div className="my-4 font-thin text-sm"></div>
<div
onClick={() => setShowLogin(false)}
className="hover:translate-y-1 my-8 p-2 text-center rounded-xl border-white border hover:bg-white hover:text-primary hover:shadow-xl hover:cursor-pointer transition-all"
>
</div>
</div>
) : (
<div className="flex flex-col">
<div className="text-2xl my-4"></div>
<div className="my-4 font-thin text-sm"></div>
<div
onClick={() => setShowLogin(true)}
className="hover:translate-y-1 my-8 rounded-xl text-center border-white border p-2 hover:bg-white hover:text-primary hover:shadow-xl hover:cursor-pointer transition-all"
>
</div>
<SineWave width={300} height={200} />
</div>
)}
</div>
</div>
</div>
);
};
export default LoginPage;