Login_20250812100935.tsx 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. // entrypoints/popup/pages/Login.tsx
  2. import React, { useState } from 'react';
  3. import { useNavigate } from 'react-router-dom';
  4. import { Button, Input, Message, 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 evVerify = () => {
  25. }
  26. const handleLogin = (e: React.FormEvent) => {
  27. e.preventDefault();
  28. if (!validateForm()) {
  29. return;
  30. }
  31. setLoading(true);
  32. // 模拟登录请求
  33. setTimeout(() => {
  34. // 这里添加实际的登录逻辑
  35. if (username && password) {
  36. // 模拟登录成功
  37. localStorage.setItem('isLoggedIn', 'true');
  38. setIsLoggedIn(true);
  39. // 跳转到首页
  40. navigate('/');
  41. Message.success('登录成功');
  42. } else {
  43. Message.error('登录失败,请检查用户名和密码');
  44. }
  45. setLoading(false);
  46. }, 1000);
  47. };
  48. return (
  49. <div className="bg-gray-50 p-4">
  50. <div className="text-center mb-6">
  51. <h1 className="text-2xl font-bold text-gray-800">登录</h1>
  52. </div>
  53. <Form onSubmit={handleLogin}>
  54. <Form.Item
  55. label="用户名"
  56. required
  57. help={errors.username}
  58. validateState={errors.username ? 'error' : undefined}
  59. >
  60. <Input
  61. placeholder="请输入用户名"
  62. value={username}
  63. onChange={(value) => {
  64. setUsername(value);
  65. if (errors.username) {
  66. setErrors({ ...errors, username: undefined });
  67. }
  68. }}
  69. disabled={loading}
  70. />
  71. </Form.Item>
  72. <Form.Item
  73. label="密码"
  74. required
  75. help={errors.password}
  76. validateState={errors.password ? 'error' : undefined}
  77. >
  78. <Input
  79. htmlType="password"
  80. placeholder="请输入密码"
  81. value={password}
  82. onChange={(value) => {
  83. setPassword(value);
  84. if (errors.password) {
  85. setErrors({ ...errors, password: undefined });
  86. }
  87. }}
  88. disabled={loading}
  89. />
  90. </Form.Item>
  91. <Form.Item
  92. label="验证码"
  93. name="code"
  94. required
  95. >
  96. <Input
  97. size="large"
  98. addonAfter={
  99. <img
  100. src={""}
  101. style={{ width: 70, height: 38 }}
  102. onClick={evVerify}
  103. />
  104. }
  105. autoComplete="off"
  106. />
  107. </Form.Item>
  108. <Form.Item>
  109. <Button
  110. type="primary"
  111. htmlType="submit"
  112. loading={loading}
  113. className="w-full"
  114. >
  115. {loading ? '登录中...' : '登录'}
  116. </Button>
  117. </Form.Item>
  118. </Form>
  119. <div className="mt-4 text-center text-sm text-gray-500">
  120. <p>忘记密码?请联系管理员</p>
  121. </div>
  122. </div>
  123. );
  124. }