diff --git a/src/pages/users/components/UserModal.js b/src/pages/users/components/UserModal.js new file mode 100644 index 0000000..f70f391 --- /dev/null +++ b/src/pages/users/components/UserModal.js @@ -0,0 +1,96 @@ +import { Component } from 'react'; +import { Modal, Form, Input } from 'antd'; + +const FormItem = Form.Item; + +class UserEditModal extends Component { + + constructor(props) { + super(props); + this.state = { + visible: false, + }; + } + + showModelHandler = (e) => { + if (e) e.stopPropagation(); + this.setState({ + visible: true, + }); + }; + + hideModelHandler = () => { + this.setState({ + visible: false, + }); + }; + + okHandler = () => { + const { onOk } = this.props; + this.props.form.validateFields((err, values) => { + if (!err) { + onOk(values); + this.hideModelHandler(); + } + }); + }; + + render() { + const { children } = this.props; + const { getFieldDecorator } = this.props.form; + const { name, email, website } = this.props.record; + const formItemLayout = { + labelCol: { span: 6 }, + wrapperCol: { span: 14 }, + }; + + return ( + + + { children } + + +
+ + { + getFieldDecorator('name', { + initialValue: name, + })() + } + + + { + getFieldDecorator('email', { + initialValue: email, + })() + } + + + { + getFieldDecorator('website', { + initialValue: website, + })() + } + +
+
+
+ ); + } +} + +export default Form.create()(UserEditModal); diff --git a/src/pages/users/components/Users.js b/src/pages/users/components/Users.js index 5c17019..9773402 100644 --- a/src/pages/users/components/Users.js +++ b/src/pages/users/components/Users.js @@ -3,6 +3,7 @@ import { Table, Pagination, Popconfirm } from 'antd'; import { routerRedux } from 'dva/router'; import styles from './Users.css'; import { PAGE_SIZE } from '../constants'; +import UserModal from './UserModal'; function Users({ dispatch, list: dataSource, loading, total, page: current }) { function deleteHandler(id) { @@ -19,6 +20,13 @@ function Users({ dispatch, list: dataSource, loading, total, page: current }) { })); } + function editHandler(id, values) { + dispatch({ + type: 'users/patch', + payload: { id, values }, + }); + } + const columns = [ { title: 'Name', @@ -39,10 +47,12 @@ function Users({ dispatch, list: dataSource, loading, total, page: current }) { { title: 'Operation', key: 'operation', - render: (text, { id }) => ( + render: (text, record) => ( - Edit - + + Edit + + Delete diff --git a/src/pages/users/models/users.js b/src/pages/users/models/users.js index c13d529..6c0fd17 100644 --- a/src/pages/users/models/users.js +++ b/src/pages/users/models/users.js @@ -29,6 +29,11 @@ export default { const page = yield select(state => state.users.page); yield put({ type: 'fetch', payload: { page } }); }, + *patch({ payload: { id, values } }, { call, put, select }) { + yield call(usersService.patch, id, values); + const page = yield select(state => state.users.page); + yield put({ type: 'fetch', payload: { page } }); + }, }, subscriptions: { setup({ dispatch, history }) { diff --git a/src/pages/users/services/users.js b/src/pages/users/services/users.js index 006c47a..e2f2685 100644 --- a/src/pages/users/services/users.js +++ b/src/pages/users/services/users.js @@ -10,3 +10,10 @@ export function remove(id) { method: 'DELETE', }); } + +export function patch(id, values) { + return request(`/api/users/${id}`, { + method: 'PATCH', + body: JSON.stringify(values), + }); +}