|  |  | @ -1,34 +1,27 @@ | 
			
		
	
		
			
				
					|  |  |  | import { Button, Form, Input, Modal, Select } from 'antd'; | 
			
		
	
		
			
				
					|  |  |  | import React, { useState, useEffect } from 'react'; | 
			
		
	
		
			
				
					|  |  |  | import { connect } from 'react-redux'; | 
			
		
	
		
			
				
					|  |  |  | import { getUserList, getProjectList, positionList } from '../actions/plan'; | 
			
		
	
		
			
				
					|  |  |  | import { getCheckItemsGroup } from '../actions/checkItems'; | 
			
		
	
		
			
				
					|  |  |  | import moment from 'moment'; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | const CheckItemsModal = ({ visible, onCreate, onCancel, dispatch, type, curRecord }) => { | 
			
		
	
		
			
				
					|  |  |  |   const [pointOpt, setPointOpt] = useState(); | 
			
		
	
		
			
				
					|  |  |  |   const [points, setPoints] = useState(); | 
			
		
	
		
			
				
					|  |  |  | const CheckItemsModal = ({ visible, onOk, onCancel, curRecord, dispatch }) => { | 
			
		
	
		
			
				
					|  |  |  |   const [group, setGroup] = useState([]); | 
			
		
	
		
			
				
					|  |  |  |   const [isNewGroup, setIsNewGroup] = useState(false); | 
			
		
	
		
			
				
					|  |  |  |   const [form] = Form.useForm(); | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |   useEffect(() => { | 
			
		
	
		
			
				
					|  |  |  |     dispatch(getCheckItemsGroup()); | 
			
		
	
		
			
				
					|  |  |  |     if (type === 'create') { | 
			
		
	
		
			
				
					|  |  |  |       dispatch(getUserList()) | 
			
		
	
		
			
				
					|  |  |  |     } else { | 
			
		
	
		
			
				
					|  |  |  |       dispatch(positionList({ projectId: curRecord?.project?.id })).then(res => { | 
			
		
	
		
			
				
					|  |  |  |     dispatch(getCheckItemsGroup()).then(res => { | 
			
		
	
		
			
				
					|  |  |  |       if (res.success) { | 
			
		
	
		
			
				
					|  |  |  |           setPoints(res.payload.data?.rows) | 
			
		
	
		
			
				
					|  |  |  |           setPointOpt(res.payload.data?.rows[0]?.points?.map(p => ({ label: p.name, value: p.id }))) | 
			
		
	
		
			
				
					|  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |       }) | 
			
		
	
		
			
				
					|  |  |  |         const opt = res.payload.data?.map(g => ({ value: g.id, label: g.name })); | 
			
		
	
		
			
				
					|  |  |  |         setGroup(opt); | 
			
		
	
		
			
				
					|  |  |  |       } | 
			
		
	
		
			
				
					|  |  |  |     }); | 
			
		
	
		
			
				
					|  |  |  |   }, []) | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |   return ( | 
			
		
	
		
			
				
					|  |  |  |     <Modal | 
			
		
	
		
			
				
					|  |  |  |       visible={visible} | 
			
		
	
		
			
				
					|  |  |  |       title="新增巡检计划" | 
			
		
	
		
			
				
					|  |  |  |       title={curRecord ? "检查项修改" : "检查项添加"} | 
			
		
	
		
			
				
					|  |  |  |       okText="确定" | 
			
		
	
		
			
				
					|  |  |  |       cancelText="取消" | 
			
		
	
		
			
				
					|  |  |  |       onCancel={() => { | 
			
		
	
	
		
			
				
					|  |  | @ -36,22 +29,15 @@ const CheckItemsModal = ({ visible, onCreate, onCancel, dispatch, type, curRecor | 
			
		
	
		
			
				
					|  |  |  |         onCancel(); | 
			
		
	
		
			
				
					|  |  |  |       }} | 
			
		
	
		
			
				
					|  |  |  |       onOk={() => { | 
			
		
	
		
			
				
					|  |  |  |         if (type === 'view') { | 
			
		
	
		
			
				
					|  |  |  |           form.resetFields(); | 
			
		
	
		
			
				
					|  |  |  |           onCancel(); | 
			
		
	
		
			
				
					|  |  |  |           return; | 
			
		
	
		
			
				
					|  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |         form | 
			
		
	
		
			
				
					|  |  |  |           .validateFields() | 
			
		
	
		
			
				
					|  |  |  |           .then((values) => { | 
			
		
	
		
			
				
					|  |  |  |             form.resetFields(); | 
			
		
	
		
			
				
					|  |  |  |             const params = { | 
			
		
	
		
			
				
					|  |  |  |               ...values, | 
			
		
	
		
			
				
					|  |  |  |               startTime: values.time[0], | 
			
		
	
		
			
				
					|  |  |  |               endTime: values.time[1], | 
			
		
	
		
			
				
					|  |  |  |               points: points[0]?.points?.filter(p => values?.points?.includes(p.id)) | 
			
		
	
		
			
				
					|  |  |  |               isNewGroup | 
			
		
	
		
			
				
					|  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |             onCreate(params); | 
			
		
	
		
			
				
					|  |  |  |             onOk(params); | 
			
		
	
		
			
				
					|  |  |  |           }) | 
			
		
	
		
			
				
					|  |  |  |           .catch((info) => { | 
			
		
	
		
			
				
					|  |  |  |             console.log('Validate Failed:', info); | 
			
		
	
	
		
			
				
					|  |  | @ -64,10 +50,8 @@ const CheckItemsModal = ({ visible, onCreate, onCancel, dispatch, type, curRecor | 
			
		
	
		
			
				
					|  |  |  |         name="form_in_modal" | 
			
		
	
		
			
				
					|  |  |  |         initialValues={{ | 
			
		
	
		
			
				
					|  |  |  |           ...curRecord, | 
			
		
	
		
			
				
					|  |  |  |           points: curRecord?.points?.map(p => p.id), | 
			
		
	
		
			
				
					|  |  |  |           userDept: curRecord?.user?.department?.name, | 
			
		
	
		
			
				
					|  |  |  |         }} | 
			
		
	
		
			
				
					|  |  |  |         disabled={type === 'view'} | 
			
		
	
		
			
				
					|  |  |  |       > | 
			
		
	
		
			
				
					|  |  |  |         <Form.Item | 
			
		
	
		
			
				
					|  |  |  |           name="name" | 
			
		
	
	
		
			
				
					|  |  | @ -79,34 +63,30 @@ const CheckItemsModal = ({ visible, onCreate, onCancel, dispatch, type, curRecor | 
			
		
	
		
			
				
					|  |  |  |           <Input /> | 
			
		
	
		
			
				
					|  |  |  |         </Form.Item> | 
			
		
	
		
			
				
					|  |  |  |         <Form.Item | 
			
		
	
		
			
				
					|  |  |  |           name="groupName" | 
			
		
	
		
			
				
					|  |  |  |           name="group" | 
			
		
	
		
			
				
					|  |  |  |           label="分组名称" | 
			
		
	
		
			
				
					|  |  |  |           rules={[ | 
			
		
	
		
			
				
					|  |  |  |             { required: true, message: '请选择分组' }, | 
			
		
	
		
			
				
					|  |  |  |           ]} | 
			
		
	
		
			
				
					|  |  |  |         > | 
			
		
	
		
			
				
					|  |  |  |           { | 
			
		
	
		
			
				
					|  |  |  |             isNewGroup ? | 
			
		
	
		
			
				
					|  |  |  |               <Select options={pointOpt} disabled={!pointOpt || type === 'view'} /> : | 
			
		
	
		
			
				
					|  |  |  |               <Input /> | 
			
		
	
		
			
				
					|  |  |  |             isNewGroup | 
			
		
	
		
			
				
					|  |  |  |               ? <Input /> | 
			
		
	
		
			
				
					|  |  |  |               : <Select options={group} loading={!group?.length} /> | 
			
		
	
		
			
				
					|  |  |  |           } | 
			
		
	
		
			
				
					|  |  |  |         </Form.Item> | 
			
		
	
		
			
				
					|  |  |  |       </Form> | 
			
		
	
		
			
				
					|  |  |  |       <Button type='link' onClick={() => { | 
			
		
	
		
			
				
					|  |  |  |         setIsNewGroup(!isNewGroup); | 
			
		
	
		
			
				
					|  |  |  |       }}>创建分组</Button> | 
			
		
	
		
			
				
					|  |  |  |       }}>{isNewGroup ? '选择已有' : '创建分组'}</Button> | 
			
		
	
		
			
				
					|  |  |  |     </Modal > | 
			
		
	
		
			
				
					|  |  |  |   ); | 
			
		
	
		
			
				
					|  |  |  | }; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | function mapStateToProps(state) { | 
			
		
	
		
			
				
					|  |  |  |   const { auth, userList, structureList } = state | 
			
		
	
		
			
				
					|  |  |  |   const { auth } = state | 
			
		
	
		
			
				
					|  |  |  |   return { | 
			
		
	
		
			
				
					|  |  |  |     user: auth.user, | 
			
		
	
		
			
				
					|  |  |  |     userList: userList.data || [], | 
			
		
	
		
			
				
					|  |  |  |     structureList: structureList.data || [], | 
			
		
	
		
			
				
					|  |  |  |     userLoading: userList.isRequesting, | 
			
		
	
		
			
				
					|  |  |  |     struLoading: structureList.isRequesting | 
			
		
	
		
			
				
					|  |  |  |   } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | export default connect(mapStateToProps)(CheckItemsModal); |