nicecode-v2/packages/material/src/login/Login.tsx

93 lines
5.8 KiB
TypeScript

/**
* Created by jiangzhixiong on 2024/03/18
*/
import React, { FC } from 'react'
import { Button, Checkbox, Flex, Form, FormProps, Image, Input, theme } from 'antd';
import { HomeOutlined } from '@ant-design/icons';
const { useToken } = theme
interface LoginProps {
title: string;
onIconClick?: () => void
rememberPassword?: boolean
imageUrl: string;
onFinish: FormProps['onFinish']
}
const Login: FC<LoginProps> = (props) => {
const {
title,
onIconClick,
rememberPassword = true,
imageUrl,
onFinish
} = props
const [form] = Form.useForm();
const { token } = useToken()
return (
<Flex>
<Flex align='center' justify='center' style={{ position: 'relative', width: '40%', padding: `30px` }}>
<HomeOutlined
onClick={onIconClick}
style={{
position: 'absolute',
top: '30px',
left: '30px',
fontSize: `${token.sizeLG}px`,
cursor: 'pointer'
}}
/>
<div style={{ width: '56%' }}>
<h2 style={{ margin: '30px 0', fontSize: '30px' }} >{title}</h2>
<Form
layout="vertical"
form={form}
onFinish={onFinish}
>
<Form.Item
name="account"
label="账号"
rules={[
{ required: true, message: '请输入账号!' }
]}
>
<Input placeholder="请输入账号" variant="borderless" style={{ border: 'none', borderBottom: '1px solid rgba(0, 0, 0, 0.06)' }} />
</Form.Item>
<Form.Item
name="password"
label="密码"
rules={[
{ required: true, message: '请输入密码!' }
]}
>
<Input.Password placeholder="请输入密码" variant="borderless" style={{ border: 'none', borderBottom: '1px solid rgba(0, 0, 0, 0.06)' }} />
</Form.Item>
<Form.Item style={{ display: rememberPassword ? 'block' : 'none' }}>
<Form.Item name="remember" valuePropName="checked" noStyle>
<Checkbox></Checkbox>
</Form.Item>
</Form.Item>
<Form.Item>
<Button block type="primary" htmlType="submit"></Button>
</Form.Item>
</Form>
</div>
</Flex>
<div style={{ width: '60%' }}>
<Image
style={{ width: '100%' }}
src={imageUrl}
width={'100%'}
preview={false}
fallback=""
/>
</div>
</Flex>
)
}
export default Login