Login_20250812095358.tsx 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. // entrypoints/popup/pages/Login.tsx
  2. import React, { useState } from 'react';
  3. import { useNavigate } from 'react-router-dom';
  4. import { Button, Input, Message, Card, Form } from '@alifd/next';
  5. export default function Login({ setIsLoggedIn }: { setIsLoggedIn: (loggedIn: boolean) => void }) {
  6. const [username, setUsername] = useState('');
  7. const [password, setPassword] = useState('');
  8. const [loading, setLoading] = useState(false);
  9. const [errors, setErrors] = useState<{username?: string, password?: string}>({});
  10. const navigate = useNavigate();
  11. const validateForm = () => {
  12. const newErrors: {username?: string, password?: string} = {};
  13. if (!username.trim()) {
  14. newErrors.username = '请输入用户名';
  15. }
  16. if (!password) {
  17. newErrors.password = '请输入密码';
  18. } else if (password.length < 6) {
  19. newErrors.password = '密码长度至少为6位';
  20. }
  21. setErrors(newErrors);
  22. return Object.keys(newErrors).length === 0;
  23. };
  24. const handleLogin = (e: React.FormEvent) => {
  25. e.preventDefault();
  26. if (!validateForm()) {
  27. return;
  28. }
  29. setLoading(true);
  30. // 模拟登录请求
  31. setTimeout(() => {
  32. // 这里添加实际的登录逻辑
  33. if (username && password) {
  34. // 模拟登录成功
  35. localStorage.setItem('isLoggedIn', 'true');
  36. setIsLoggedIn(true);
  37. // 跳转到首页
  38. navigate('/');
  39. Message.success('登录成功');
  40. } else {
  41. Message.error('登录失败,请检查用户名和密码');
  42. }
  43. setLoading(false);
  44. }, 1000);
  45. };
  46. return (
  47. <div className="flex items-center justify-center min-h-screen bg-gray-50 p-4">
  48. <div className="text-center mb-6">
  49. <h1 className="text-2xl font-bold text-gray-800">系统登录</h1>
  50. <p className="text-gray-500 mt-2">请输入您的账号和密码</p>
  51. </div>
  52. <Form onSubmit={handleLogin}>
  53. <Form.Item
  54. label="用户名"
  55. required
  56. help={errors.username}
  57. validateState={errors.username ? 'error' : undefined}
  58. >
  59. <Input
  60. placeholder="请输入用户名"
  61. value={username}
  62. onChange={(value) => {
  63. setUsername(value);
  64. if (errors.username) {
  65. setErrors({...errors, username: undefined});
  66. }
  67. }}
  68. disabled={loading}
  69. />
  70. </Form.Item>
  71. <Form.Item
  72. label="密码"
  73. required
  74. help={errors.password}
  75. validateState={errors.password ? 'error' : undefined}
  76. >
  77. <Input
  78. htmlType="password"
  79. placeholder="请输入密码"
  80. value={password}
  81. onChange={(value) => {
  82. setPassword(value);
  83. if (errors.password) {
  84. setErrors({...errors, password: undefined});
  85. }
  86. }}
  87. disabled={loading}
  88. />
  89. </Form.Item>
  90. <Form.Item>
  91. <Button
  92. type="primary"
  93. htmlType="submit"
  94. loading={loading}
  95. className="w-full"
  96. >
  97. {loading ? '登录中...' : '登录'}
  98. </Button>
  99. </Form.Item>
  100. </Form>
  101. <div className="mt-4 text-center text-sm text-gray-500">
  102. <p>忘记密码?请联系管理员</p>
  103. </div>
  104. </div>
  105. );
  106. }