巴林闲侠 2 years ago
parent
commit
a3c6d81540
  1. 10
      api/app/lib/controllers/patrolManage/checkItems.js
  2. 50
      web/client/src/sections/patrolManage/components/checkItemsModal.js
  3. 40
      web/client/src/sections/patrolManage/containers/checkItems.js
  4. 8
      web/client/src/utils/webapi.js

10
api/app/lib/controllers/patrolManage/checkItems.js

@ -25,9 +25,9 @@ async function createGroup(ctx, next) {
const models = ctx.fs.dc.models; const models = ctx.fs.dc.models;
try { try {
const data = ctx.request.body; const data = ctx.request.body;
await models.CheckItemsGroup.create(data) const rslt = await models.CheckItemsGroup.create(data);
ctx.status = 204; ctx.status = 200;
ctx.body = { message: '新建分组成功' } ctx.body = { message: '新建分组成功', groupId: rslt.dataValues.id }
} catch (error) { } catch (error) {
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
ctx.status = 400; ctx.status = 400;
@ -92,9 +92,7 @@ async function updateCheckItems(ctx, next) {
const data = ctx.request.body; const data = ctx.request.body;
const { id } = ctx.params; const { id } = ctx.params;
await models.CheckItems.update({ await models.CheckItems.update(data, {
name: data.name,
}, {
where: { where: {
id: id id: id
} }

50
web/client/src/sections/patrolManage/components/checkItemsModal.js

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

40
web/client/src/sections/patrolManage/containers/checkItems.js

@ -4,27 +4,39 @@ import { Button, Popconfirm } from 'antd';
import ProTable from '@ant-design/pro-table'; import ProTable from '@ant-design/pro-table';
import CheckItemsModal from '../components/checkItemsModal'; import CheckItemsModal from '../components/checkItemsModal';
import { createPatrolPlan, delPatrolPlan, updatePatrolPlan } from '../actions/plan'; import { createPatrolPlan, delPatrolPlan, updatePatrolPlan } from '../actions/plan';
import { getCheckItems } from '../actions/checkItems'; import { getCheckItems, createCheckItems, updateCheckItems, createCheckItemsGroup } from '../actions/checkItems';
import moment from 'moment';
function CheckItems(props) { function CheckItems(props) {
const { dispatch, user } = props; const { dispatch, user } = props;
const tableRef = useRef(); const tableRef = useRef();
const [dataSource, setDataSource] = useState([{}]); const [dataSource, setDataSource] = useState([{}]);
const [visible, setVisible] = useState(false); const [visible, setVisible] = useState(false);
const [type, setType] = useState(); const [curRecord, setCurRecord] = useState(null); // 新增 or 修改
const [curRecord, setCurRecord] = useState();
const [select, setSelect] = useState([]); const [select, setSelect] = useState([]);
const onCreate = (values) => { const onOk = async (values) => {
if (type === 'create') { let groupId = null;
dispatch(createPatrolPlan(values)).then(res => { if (values.isNewGroup) {
await dispatch(createCheckItemsGroup({ name: values.group })).then(res => {
if (res.success) {
groupId = res.payload.data?.groupId
}
})
}
if (!curRecord) {
dispatch(createCheckItems({
name: values.name,
groupId: groupId ? groupId : values.group
})).then(res => {
if (res.success) { if (res.success) {
tableRef.current.reload(); tableRef.current.reload();
} }
}) })
} else { } else {
dispatch(updatePatrolPlan({ ...values, id: curRecord.id })).then(res => { dispatch(updateCheckItems(curRecord.id, {
name: values.name,
groupId: groupId ? groupId : values.group
})).then(res => {
if (res.success) { if (res.success) {
tableRef.current.reload(); tableRef.current.reload();
} }
@ -58,7 +70,6 @@ function CheckItems(props) {
render: (_, record) => { render: (_, record) => {
return <> return <>
<Button type="link" onClick={() => { <Button type="link" onClick={() => {
setType('edit')
setCurRecord(record) setCurRecord(record)
setVisible(true) setVisible(true)
}}>修改</Button> }}>修改</Button>
@ -100,7 +111,7 @@ function CheckItems(props) {
key="add" key="add"
type='primary' type='primary'
onClick={() => { onClick={() => {
setType('create') setCurRecord(null)
setVisible(true) setVisible(true)
}} }}
>新增</Button>, >新增</Button>,
@ -108,15 +119,15 @@ function CheckItems(props) {
key="del" key="del"
type='primary' type='primary'
onClick={() => { onClick={() => {
const values = searchConfig?.form?.getFieldsValue(); // const values = searchConfig?.form?.getFieldsValue();
console.log(values); // console.log(values);
}} }}
>批量删除</Button>, >批量删除</Button>,
], ],
}} }}
rowSelection={{ rowSelection={{
selectedRowKeys: select?.map(v => v.id) || [], selectedRowKeys: select?.map(v => v.id) || [],
onChange: (selectedRowKeys, selectedRows) => { onChange: (_, selectedRows) => {
setSelect(selectedRows) setSelect(selectedRows)
} }
}} }}
@ -125,8 +136,7 @@ function CheckItems(props) {
visible ? visible ?
<CheckItemsModal <CheckItemsModal
visible={visible} visible={visible}
onCreate={onCreate} onOk={onOk}
type={type}
curRecord={curRecord} curRecord={curRecord}
onCancel={() => { onCancel={() => {
setVisible(false); setVisible(false);

8
web/client/src/utils/webapi.js

@ -31,10 +31,10 @@ export const ApiTable = {
patrolRecord: 'patrolRecord/:patrolPlanId/:startTime/:endTime/:alarm/:pointId', patrolRecord: 'patrolRecord/:patrolPlanId/:startTime/:endTime/:alarm/:pointId',
// 检查项设定 // 检查项设定
checkItems: '/checkItems', // 获取/新增 checkItems: 'checkItems', // 获取/新增
updateCheckItems: '/checkItems/{id}', updateCheckItems: 'checkItems/{id}',
delCheckItems: '/checkItems/{ids}', delCheckItems: 'checkItems/{ids}',
checkItemsGroup: '/checkItems/group', // 获取/新增 checkItemsGroup: 'checkItems/group', // 获取/新增
// 用户权限 // 用户权限
getResource: 'resource', getResource: 'resource',

Loading…
Cancel
Save