10 changed files with 492 additions and 9 deletions
			
			
		| @ -0,0 +1,174 @@ | |||||
|  | 'use strict'; | ||||
|  | 
 | ||||
|  | async function getPatrolTemplate (ctx, next) { | ||||
|  |     try { | ||||
|  |         const models = ctx.fs.dc.models; | ||||
|  |         const { limit, page, userId } = ctx.query; | ||||
|  |         let userWhere = {}; | ||||
|  |         let options = { | ||||
|  |             include: [{ | ||||
|  |                 required: true, | ||||
|  |                 model: models.User, | ||||
|  |                 attributes: ['id', 'name'], | ||||
|  |                 where: userWhere, | ||||
|  |                 include: [{ | ||||
|  |                     required: true, | ||||
|  |                     model: models.Department, | ||||
|  |                     attributes: ['id', 'name'], | ||||
|  |                 }] | ||||
|  |             }, { | ||||
|  |                 required: true, | ||||
|  |                 model: models.Project, | ||||
|  |                 attributes: ['id', 'name'], | ||||
|  |             }] | ||||
|  |         }; | ||||
|  |         if (limit) { | ||||
|  |             options.limit = Number(limit); | ||||
|  |         } | ||||
|  |         if (page && limit) { | ||||
|  |             options.offset = Number(page) * Number(limit); | ||||
|  |         } | ||||
|  |         if (userId) { | ||||
|  |             userWhere.id = userId; | ||||
|  |         } | ||||
|  |         let res = await models.PatrolTemplate.findAndCountAll(options); | ||||
|  |         ctx.status = 200; | ||||
|  |         ctx.body = res; | ||||
|  |     } catch (error) { | ||||
|  |         ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); | ||||
|  |         ctx.status = 400; | ||||
|  |         ctx.body = { | ||||
|  |             "message": "获取巡检模板失败" | ||||
|  |         } | ||||
|  |     } | ||||
|  | } | ||||
|  | 
 | ||||
|  | async function createPatrolTemplate (ctx, next) { | ||||
|  |     const transaction = await ctx.fs.dc.orm.transaction(); | ||||
|  |     try { | ||||
|  |         const models = ctx.fs.dc.models; | ||||
|  |         const data = ctx.request.body; | ||||
|  |         const { name, describe, checkItems = [] } = data; | ||||
|  | 
 | ||||
|  |         let Template = { | ||||
|  |             name, describe | ||||
|  |         }; | ||||
|  | 
 | ||||
|  |         const templateRes = await models.PatrolTemplate.create( | ||||
|  |             Template, | ||||
|  |             { | ||||
|  |                 transaction | ||||
|  |             } | ||||
|  |         ); | ||||
|  |         await models.PatrolTemplateCheckItems.bulkCreate( | ||||
|  |             checkItems.map(cid => { | ||||
|  |                 return { | ||||
|  |                     templateId: templateRes.id, | ||||
|  |                     checkItemsId: cid | ||||
|  |                 } | ||||
|  |             }) | ||||
|  |             , { | ||||
|  |                 transaction | ||||
|  |             }) | ||||
|  | 
 | ||||
|  |         await transaction.commit(); | ||||
|  |         ctx.status = 204; | ||||
|  |     } catch (error) { | ||||
|  |         await transaction.rollback(); | ||||
|  |         ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); | ||||
|  |         ctx.status = 400; | ||||
|  |         ctx.body = { | ||||
|  |             "message": '新增巡检模板失败' | ||||
|  |         } | ||||
|  |     } | ||||
|  | } | ||||
|  | 
 | ||||
|  | async function updatePatrolTemplate (ctx, next) { | ||||
|  |     const transaction = await ctx.fs.dc.orm.transaction(); | ||||
|  |     try { | ||||
|  |         let errMsg = '修改巡检模板失败'; | ||||
|  |         const models = ctx.fs.dc.models; | ||||
|  |         const data = ctx.request.body; | ||||
|  |         const { name, describe, checkItems } = data; | ||||
|  | 
 | ||||
|  |         let Template = { name, describe, checkItems }; | ||||
|  | 
 | ||||
|  |         if (data && data.id) { | ||||
|  |             await models.PatrolTemplate.update(Template, { | ||||
|  |                 where: { id: data.id }, | ||||
|  |                 transaction | ||||
|  |             }) | ||||
|  |             await models.PatrolTemplateCheckItems.destroy({ | ||||
|  |                 where: { | ||||
|  |                     templateId: data.id | ||||
|  |                 }, | ||||
|  |                 transaction | ||||
|  |             }) | ||||
|  |             await models.PatrolTemplateCheckItems.bulkCreate( | ||||
|  |                 checkItems.map(cid => { | ||||
|  |                     return { | ||||
|  |                         templateId: data.id, | ||||
|  |                         checkItemsId: cid | ||||
|  |                     } | ||||
|  |                 }) | ||||
|  |                 , { | ||||
|  |                     transaction | ||||
|  |                 }) | ||||
|  |         } else { | ||||
|  |             errMsg = '请传入巡检模板id'; | ||||
|  |             throw errMsg; | ||||
|  |         } | ||||
|  |         await transaction.commit(); | ||||
|  |         ctx.status = 204; | ||||
|  |     } catch (error) { | ||||
|  |         await transaction.rollback(); | ||||
|  |         ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); | ||||
|  |         ctx.status = 400; | ||||
|  |         ctx.body = { | ||||
|  |             "message": errMsg | ||||
|  |         } | ||||
|  |     } | ||||
|  | } | ||||
|  | 
 | ||||
|  | async function delPatrolTemplate (ctx, next) { | ||||
|  |     const transaction = await ctx.fs.dc.orm.transaction(); | ||||
|  |     try { | ||||
|  |         let errMsg = '删除巡检模板失败'; | ||||
|  | 
 | ||||
|  |         const models = ctx.fs.dc.models; | ||||
|  |         const { id } = ctx.params; | ||||
|  | 
 | ||||
|  |         const record = await models.PatrolPlan.findOne({ | ||||
|  |             where: { patrolTemplateId: id } | ||||
|  |         }); | ||||
|  | 
 | ||||
|  |         if (record) { | ||||
|  |             errMsg = '不能删除有巡检记录的模板'; | ||||
|  |             throw errMsg; | ||||
|  |         } | ||||
|  | 
 | ||||
|  |         await models.PatrolTemplate.destroy({ | ||||
|  |             where: { id }, | ||||
|  |             transaction | ||||
|  |         }) | ||||
|  |         await models.PatrolTemplateCheckItems.destroy({ | ||||
|  |             where: { templateId: id }, | ||||
|  |             transaction | ||||
|  |         }) | ||||
|  | 
 | ||||
|  |         await transaction.commit(); | ||||
|  |         ctx.status = 204; | ||||
|  |     } catch (error) { | ||||
|  |         await transaction.rollback(); | ||||
|  |         ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); | ||||
|  |         ctx.status = 400; | ||||
|  |         ctx.body = { message: error } | ||||
|  |     } | ||||
|  | } | ||||
|  | 
 | ||||
|  | module.exports = { | ||||
|  |     getPatrolTemplate, | ||||
|  |     createPatrolTemplate, | ||||
|  |     updatePatrolTemplate, | ||||
|  |     delPatrolTemplate, | ||||
|  | } | ||||
| @ -0,0 +1,43 @@ | |||||
|  | /* eslint-disable*/ | ||||
|  | 'use strict'; | ||||
|  | 
 | ||||
|  | module.exports = dc => { | ||||
|  |   const DataTypes = dc.ORM; | ||||
|  |   const sequelize = dc.orm; | ||||
|  |   const PatrolTemplate = sequelize.define("patrolTemplate", { | ||||
|  |     id: { | ||||
|  |       type: DataTypes.INTEGER, | ||||
|  |       allowNull: false, | ||||
|  |       defaultValue: null, | ||||
|  |       comment: null, | ||||
|  |       primaryKey: true, | ||||
|  |       field: "id", | ||||
|  |       autoIncrement: true, | ||||
|  |       unique: "patrol_template_id_uindex" | ||||
|  |     }, | ||||
|  |     name: { | ||||
|  |       type: DataTypes.STRING, | ||||
|  |       allowNull: false, | ||||
|  |       defaultValue: null, | ||||
|  |       comment: null, | ||||
|  |       primaryKey: false, | ||||
|  |       field: "name", | ||||
|  |       autoIncrement: false | ||||
|  |     }, | ||||
|  |     describe: { | ||||
|  |       type: DataTypes.STRING, | ||||
|  |       allowNull: true, | ||||
|  |       defaultValue: null, | ||||
|  |       comment: null, | ||||
|  |       primaryKey: false, | ||||
|  |       field: "describe", | ||||
|  |       autoIncrement: false | ||||
|  |     } | ||||
|  |   }, { | ||||
|  |     tableName: "patrol_template", | ||||
|  |     comment: "", | ||||
|  |     indexes: [] | ||||
|  |   }); | ||||
|  |   dc.models.PatrolTemplate = PatrolTemplate; | ||||
|  |   return PatrolTemplate; | ||||
|  | }; | ||||
| @ -0,0 +1,51 @@ | |||||
|  | /* eslint-disable*/ | ||||
|  | 'use strict'; | ||||
|  | 
 | ||||
|  | module.exports = dc => { | ||||
|  |   const DataTypes = dc.ORM; | ||||
|  |   const sequelize = dc.orm; | ||||
|  |   const PatrolTemplateCheckItems = sequelize.define("patrolTemplateCheckItems", { | ||||
|  |     id: { | ||||
|  |       type: DataTypes.INTEGER, | ||||
|  |       allowNull: false, | ||||
|  |       defaultValue: null, | ||||
|  |       comment: null, | ||||
|  |       primaryKey: true, | ||||
|  |       field: "id", | ||||
|  |       autoIncrement: true, | ||||
|  |       unique: "patrol_template_check_items_id_uindex" | ||||
|  |     }, | ||||
|  |     templateId: { | ||||
|  |       type: DataTypes.INTEGER, | ||||
|  |       allowNull: false, | ||||
|  |       defaultValue: null, | ||||
|  |       comment: null, | ||||
|  |       primaryKey: false, | ||||
|  |       field: "template_id", | ||||
|  |       autoIncrement: false, | ||||
|  |       references: { | ||||
|  |         key: "id", | ||||
|  |         model: "patrolTemplate" | ||||
|  |       } | ||||
|  |     }, | ||||
|  |     checkItemsId: { | ||||
|  |       type: DataTypes.INTEGER, | ||||
|  |       allowNull: false, | ||||
|  |       defaultValue: null, | ||||
|  |       comment: null, | ||||
|  |       primaryKey: false, | ||||
|  |       field: "check_items_id", | ||||
|  |       autoIncrement: false, | ||||
|  |       references: { | ||||
|  |         key: "id", | ||||
|  |         model: "checkItems" | ||||
|  |       } | ||||
|  |     } | ||||
|  |   }, { | ||||
|  |     tableName: "patrol_template_check_items", | ||||
|  |     comment: "", | ||||
|  |     indexes: [] | ||||
|  |   }); | ||||
|  |   dc.models.PatrolTemplateCheckItems = PatrolTemplateCheckItems; | ||||
|  |   return PatrolTemplateCheckItems; | ||||
|  | }; | ||||
| @ -0,0 +1,17 @@ | |||||
|  | 'use strict'; | ||||
|  | 
 | ||||
|  | const patrolTemplate = require('../../controllers/patrolManage/patrolTemplate'); | ||||
|  | 
 | ||||
|  | module.exports = function (app, router, opts) { | ||||
|  |     app.fs.api.logAttr['GET/patrolTemplate'] = { content: '获取巡检模板', visible: false }; | ||||
|  |     router.get('/patrolTemplate', patrolTemplate.getPatrolTemplate); | ||||
|  | 
 | ||||
|  |     app.fs.api.logAttr['POST/patrolTemplate'] = { content: '新增巡检模板', visible: true }; | ||||
|  |     router.post('/patrolTemplate', patrolTemplate.createPatrolTemplate); | ||||
|  | 
 | ||||
|  |     app.fs.api.logAttr['PUT/patrolTemplate'] = { content: '修改巡检模板', visible: true }; | ||||
|  |     router.put('/patrolTemplate', patrolTemplate.updatePatrolTemplate); | ||||
|  | 
 | ||||
|  |     app.fs.api.logAttr['DELETE/patrolTemplate/:id'] = { content: '删除巡检模板', visible: true }; | ||||
|  |     router.del('/patrolTemplate/:id', patrolTemplate.delPatrolTemplate); | ||||
|  | }; | ||||
| @ -0,0 +1,30 @@ | |||||
|  | create table patrol_template | ||||
|  | ( | ||||
|  | 	id serial not null, | ||||
|  | 	name varchar(128) not null, | ||||
|  | 	describe varchar(1024) | ||||
|  | ); | ||||
|  | 
 | ||||
|  | create unique index patrol_template_id_uindex | ||||
|  | 	on patrol_template (id); | ||||
|  | 
 | ||||
|  | alter table patrol_template | ||||
|  | 	add constraint patrol_template_pk | ||||
|  | 		primary key (id); | ||||
|  | 
 | ||||
|  | 
 | ||||
|  | create table if not exists patrol_template_check_items | ||||
|  | ( | ||||
|  |     id             serial  not null | ||||
|  |         constraint patrol_template_check_items_pk | ||||
|  |             primary key, | ||||
|  |     template_id    integer not null | ||||
|  |         constraint patrol_template_check_items_patrol_template_id_fk | ||||
|  |             references patrol_template, | ||||
|  |     check_items_id integer not null | ||||
|  |         constraint patrol_template_check_items_check_items_id_fk | ||||
|  |             references check_items | ||||
|  | ); | ||||
|  | 
 | ||||
|  | create unique index if not exists patrol_template_check_items_id_uindex | ||||
|  |     on patrol_template_check_items (id); | ||||
| @ -0,0 +1,46 @@ | |||||
|  | 'use strict'; | ||||
|  | 
 | ||||
|  | import { basicAction } from '@peace/utils' | ||||
|  | import { ApiTable } from '$utils' | ||||
|  | 
 | ||||
|  | export function getPatrolTemplate() { | ||||
|  |     return dispatch => basicAction({ | ||||
|  |         type: 'get', | ||||
|  |         dispatch: dispatch, | ||||
|  |         actionType: 'GET_PATROL_TEMPLATE', | ||||
|  |         url: ApiTable.patrolTemplate, | ||||
|  |         msg: { error: '获取巡检模板失败' }, | ||||
|  |     }); | ||||
|  | } | ||||
|  | 
 | ||||
|  | export function createPatrolTemplate(data) { | ||||
|  |     return dispatch => basicAction({ | ||||
|  |         type: 'post', | ||||
|  |         data, | ||||
|  |         dispatch: dispatch, | ||||
|  |         actionType: 'CREATE_PATROL_TEMPLATE', | ||||
|  |         url: ApiTable.patrolTemplate, | ||||
|  |         msg: { error: '新增巡检模板失败' }, | ||||
|  |     }); | ||||
|  | } | ||||
|  | 
 | ||||
|  | export function delPatrolTemplate(id) { | ||||
|  |     return dispatch => basicAction({ | ||||
|  |         type: 'del', | ||||
|  |         dispatch: dispatch, | ||||
|  |         actionType: 'DEL_PATROL_TEMPLATE', | ||||
|  |         url: ApiTable.delPatrolTemplate.replace('{id}', id), | ||||
|  |         msg: { error: '删除巡检模板失败' }, | ||||
|  |     }); | ||||
|  | } | ||||
|  | 
 | ||||
|  | export function updatePatrolTemplate(data) { | ||||
|  |     return dispatch => basicAction({ | ||||
|  |         type: 'put', | ||||
|  |         data, | ||||
|  |         dispatch: dispatch, | ||||
|  |         actionType: 'UPDATE_PATROL_TEMPLATE', | ||||
|  |         url: ApiTable.patrolTemplate, | ||||
|  |         msg: { error: '修改巡检模板失败' }, | ||||
|  |     }); | ||||
|  | } | ||||
| @ -0,0 +1,120 @@ | |||||
|  | import { Button, Form, Input, Modal, Select, DatePicker } from 'antd'; | ||||
|  | import React, { useState, useEffect } from 'react'; | ||||
|  | import { connect } from 'react-redux'; | ||||
|  | import moment from 'moment'; | ||||
|  | 
 | ||||
|  | const { RangePicker } = DatePicker; | ||||
|  | const { TextArea } = Input; | ||||
|  | 
 | ||||
|  | const PlanModal = ({ visible, onCreate, onCancel, dispatch, type, curRecord }) => { | ||||
|  |     const [form] = Form.useForm(); | ||||
|  | 
 | ||||
|  |     return ( | ||||
|  |         <Modal | ||||
|  |             visible={visible} | ||||
|  |             title="新增巡检模板" | ||||
|  |             okText="确定" | ||||
|  |             cancelText="取消" | ||||
|  |             onCancel={() => { | ||||
|  |                 form.resetFields(); | ||||
|  |                 onCancel(); | ||||
|  |             }} | ||||
|  |             onOk={() => { | ||||
|  |                 if (type === 'view') { | ||||
|  |                     form.resetFields(); | ||||
|  |                     onCancel(); | ||||
|  |                     return; | ||||
|  |                 } | ||||
|  |                 form | ||||
|  |                     .validateFields() | ||||
|  |                     .then((values) => { | ||||
|  |                         form.resetFields(); | ||||
|  |                         const params = { | ||||
|  |                             ...values, | ||||
|  |                         } | ||||
|  |                         // onCreate(params);
 | ||||
|  |                     }) | ||||
|  |                     .catch((info) => { | ||||
|  |                         console.log('Validate Failed:', info); | ||||
|  |                     }); | ||||
|  |             }} | ||||
|  |         > | ||||
|  |             <Form | ||||
|  |                 form={form} | ||||
|  |                 layout="vertical" | ||||
|  |                 name="form_in_modal" | ||||
|  |                 initialValues={{ | ||||
|  |                     ...curRecord, | ||||
|  |                 }} | ||||
|  |                 disabled={type === 'view'} | ||||
|  |             > | ||||
|  |                 <Form.Item | ||||
|  |                     name="name" | ||||
|  |                     label="模板名称" | ||||
|  |                     rules={[ | ||||
|  |                         { required: true, message: '请输入巡检模板名称' }, | ||||
|  |                     ]} | ||||
|  |                 > | ||||
|  |                     <Input disabled={type === 'view'} /> | ||||
|  |                 </Form.Item> | ||||
|  |                 <Form.Item | ||||
|  |                     name="describe" | ||||
|  |                     label="描述" | ||||
|  |                     rules={[]} | ||||
|  |                 > | ||||
|  |                     <TextArea rows={4} disabled={type === 'view'} /> | ||||
|  |                 </Form.Item> | ||||
|  |                 <Form.Item | ||||
|  |                     name="checkItems" | ||||
|  |                     label="检查项" | ||||
|  |                     rules={[ | ||||
|  |                         { required: true, message: '请选择检查项' }, | ||||
|  |                     ]} | ||||
|  |                 > | ||||
|  |                     <Select | ||||
|  |                         style={{ | ||||
|  |                             // width: 200,
 | ||||
|  |                         }} | ||||
|  |                         mode="multiple" | ||||
|  |                         options={[ | ||||
|  |                             { | ||||
|  |                                 label: 'Manager', | ||||
|  |                                 options: [ | ||||
|  |                                     { | ||||
|  |                                         label: 'Jack', | ||||
|  |                                         value: 'jack', | ||||
|  |                                     }, | ||||
|  |                                     { | ||||
|  |                                         label: 'Lucy', | ||||
|  |                                         value: 'lucy', | ||||
|  |                                     }, | ||||
|  |                                 ], | ||||
|  |                             }, | ||||
|  |                             { | ||||
|  |                                 label: 'Engineer', | ||||
|  |                                 options: [ | ||||
|  |                                     { | ||||
|  |                                         label: 'yiminghe', | ||||
|  |                                         value: 'Yiminghe', | ||||
|  |                                     }, | ||||
|  |                                 ], | ||||
|  |                             }, | ||||
|  |                         ]} | ||||
|  |                     /> | ||||
|  |                 </Form.Item> | ||||
|  |             </Form> | ||||
|  |         </Modal > | ||||
|  |     ); | ||||
|  | }; | ||||
|  | 
 | ||||
|  | function mapStateToProps (state) { | ||||
|  |     const { auth, userList, structureList } = state | ||||
|  |     return { | ||||
|  |         user: auth.user, | ||||
|  |         userList: userList.data || [], | ||||
|  |         structureList: structureList.data || [], | ||||
|  |         userLoading: userList.isRequesting, | ||||
|  |         struLoading: structureList.isRequesting | ||||
|  |     } | ||||
|  | } | ||||
|  | export default connect(mapStateToProps)(PlanModal); | ||||
					Loading…
					
					
				
		Reference in new issue