ant-design/components/comment/demo/editor.md

103 lines
2.1 KiB
Markdown
Raw Normal View History

2018-10-25 21:32:29 +08:00
---
order: 3
title:
2018-12-04 16:51:13 +08:00
zh-CN: 回复框
en-US: Reply Editor
2018-10-25 21:32:29 +08:00
---
## zh-CN
2018-10-28 22:09:38 +08:00
评论编辑器组件提供了相同样式的封装以支持自定义评论编辑器。
2018-10-25 21:32:29 +08:00
## en-US
2019-04-20 06:35:29 +08:00
Comment can be used as an editor, so the user can customize the contents of the component.
2018-10-25 21:32:29 +08:00
2019-05-07 14:57:32 +08:00
```jsx
import { Comment, Avatar, Form, Button, List, Input } from 'antd';
import dayjs from 'dayjs';
2018-10-25 21:32:29 +08:00
const { TextArea } = Input;
2018-10-25 21:32:29 +08:00
2018-12-01 00:24:16 +08:00
const CommentList = ({ comments }) => (
<List
dataSource={comments}
header={`${comments.length} ${comments.length > 1 ? 'replies' : 'reply'}`}
itemLayout="horizontal"
renderItem={props => <Comment {...props} />}
/>
);
2018-10-25 21:32:29 +08:00
2019-05-07 14:57:32 +08:00
const Editor = ({ onChange, onSubmit, submitting, value }) => (
<>
2018-12-04 16:51:13 +08:00
<Form.Item>
2018-12-01 00:24:16 +08:00
<TextArea rows={4} onChange={onChange} value={value} />
2018-12-04 16:51:13 +08:00
</Form.Item>
<Form.Item>
2019-05-07 14:57:32 +08:00
<Button htmlType="submit" loading={submitting} onClick={onSubmit} type="primary">
2018-12-01 00:24:16 +08:00
Add Comment
</Button>
2018-12-04 16:51:13 +08:00
</Form.Item>
</>
2018-12-01 00:24:16 +08:00
);
2018-10-25 21:32:29 +08:00
export default () => {
const [state, setState] = React.useState({
2018-10-25 21:32:29 +08:00
comments: [],
submitting: false,
2018-11-02 18:17:28 +08:00
value: '',
});
2018-10-25 21:32:29 +08:00
const handleSubmit = () => {
if (!state.value) {
2018-11-02 22:52:35 +08:00
return;
}
setState({
...state,
2018-10-25 21:32:29 +08:00
submitting: true,
});
setTimeout(() => {
setState({
2018-10-25 21:32:29 +08:00
submitting: false,
2018-11-02 18:17:28 +08:00
value: '',
2018-10-25 21:32:29 +08:00
comments: [
...state.comments,
2018-10-25 21:32:29 +08:00
{
author: 'Han Solo',
avatar: 'https://joeschmoe.io/api/v1/random',
content: <p>{state.value}</p>,
datetime: dayjs().fromNow(),
2018-10-25 21:32:29 +08:00
},
2018-10-31 20:10:42 +08:00
],
2018-10-30 19:25:54 +08:00
});
2018-10-25 21:32:29 +08:00
}, 1000);
2019-05-07 14:57:32 +08:00
};
2018-10-25 21:32:29 +08:00
const handleChange = e => {
setState({
...state,
2018-11-02 18:17:28 +08:00
value: e.target.value,
});
2019-05-07 14:57:32 +08:00
};
2018-11-02 18:17:28 +08:00
return (
<>
{state.comments.length > 0 && <CommentList comments={state.comments} />}
<Comment
avatar={<Avatar src="https://joeschmoe.io/api/v1/random" alt="Han Solo" />}
content={
<Editor
onChange={handleChange}
onSubmit={handleSubmit}
submitting={state.submitting}
value={state.value}
/>
}
/>
</>
);
};
2019-05-07 14:57:32 +08:00
```