2024-04-17 17:56:29 +08:00
|
|
|
import React from 'react';
|
|
|
|
import { Button, Flex, Form, Input, Select } from 'antd';
|
|
|
|
|
|
|
|
const App = () => {
|
|
|
|
const [form] = Form.useForm();
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Form
|
|
|
|
form={form}
|
2024-10-15 16:24:27 +08:00
|
|
|
scrollToFirstError={{ behavior: 'instant', block: 'end', focus: true }}
|
2024-04-17 17:56:29 +08:00
|
|
|
style={{ paddingBlock: 32 }}
|
|
|
|
labelCol={{ span: 6 }}
|
|
|
|
wrapperCol={{ span: 14 }}
|
|
|
|
>
|
|
|
|
<Form.Item wrapperCol={{ offset: 6 }}>
|
|
|
|
<Button onClick={() => form.scrollToField('bio')}>Scroll to Bio</Button>
|
|
|
|
</Form.Item>
|
|
|
|
|
|
|
|
<Form.Item name="username" label="UserName" rules={[{ required: true }]}>
|
|
|
|
<Input />
|
|
|
|
</Form.Item>
|
|
|
|
|
|
|
|
<Form.Item label="Occupation" name="occupation">
|
|
|
|
<Select
|
|
|
|
options={[
|
|
|
|
{ label: 'Designer', value: 'designer' },
|
|
|
|
{ label: 'Developer', value: 'developer' },
|
|
|
|
{ label: 'Product Manager', value: 'product-manager' },
|
|
|
|
]}
|
|
|
|
/>
|
|
|
|
</Form.Item>
|
|
|
|
|
|
|
|
<Form.Item name="motto" label="Motto">
|
|
|
|
<Input.TextArea rows={4} />
|
|
|
|
</Form.Item>
|
|
|
|
|
|
|
|
<Form.Item name="bio" label="Bio" rules={[{ required: true }]}>
|
|
|
|
<Input.TextArea rows={6} />
|
|
|
|
</Form.Item>
|
|
|
|
|
|
|
|
<Form.Item wrapperCol={{ offset: 6 }}>
|
|
|
|
<Flex gap="small">
|
|
|
|
<Button type="primary" htmlType="submit">
|
|
|
|
Submit
|
|
|
|
</Button>
|
|
|
|
<Button danger onClick={() => form.resetFields()}>
|
|
|
|
Reset
|
|
|
|
</Button>
|
|
|
|
</Flex>
|
|
|
|
</Form.Item>
|
|
|
|
</Form>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default App;
|