|
@@ -24,10 +24,12 @@
|
|
|
<el-button type="primary" plain icon="Plus" @click="handleAdd"> 新增 </el-button>
|
|
|
</el-col>
|
|
|
<el-col :span="1.5">
|
|
|
- <el-button type="success" plain icon="Edit" :disabled="single" @click="handleUpdate"> 修改 </el-button>
|
|
|
+ <el-button type="success" plain icon="Edit" :disabled="single" @click="handleUpdate"> 修改
|
|
|
+ </el-button>
|
|
|
</el-col>
|
|
|
<el-col :span="1.5">
|
|
|
- <el-button type="danger" plain icon="Delete" :disabled="multiple" @click="handleDelete"> 删除 </el-button>
|
|
|
+ <el-button type="danger" plain icon="Delete" :disabled="multiple" @click="handleDelete"> 删除
|
|
|
+ </el-button>
|
|
|
</el-col>
|
|
|
<right-toolbar v-model:showSearch="showSearch" @query-table="getList" />
|
|
|
</el-row>
|
|
@@ -35,12 +37,25 @@
|
|
|
|
|
|
<el-table v-loading="loading" :data="tableList" @selection-change="handleSelectionChange">
|
|
|
<el-table-column type="selection" width="55" align="center" />
|
|
|
- <el-table-column label="巡检班组名称" align="center" prop="name" width="150" />
|
|
|
- <el-table-column label="班组负责人" align="center" prop="phone" width="150" />
|
|
|
- <el-table-column label="联系电话" align="center" prop="city" width="100" />
|
|
|
- <el-table-column label="班次" align="center" prop="address" show-overflow-tooltip width="180" />
|
|
|
- <el-table-column label="成员数" align="center" show-overflow-tooltip prop="remark" width="150" />
|
|
|
- <el-table-column label="备注" align="center" prop="createTime" width="180" />
|
|
|
+ <el-table-column label="巡检班组名称" align="center" show-overflow-tooltip prop="name" width="150" />
|
|
|
+ <el-table-column label="班组负责人" align="center" prop="ext1.headerName" width="120" />
|
|
|
+ <el-table-column label="联系电话" align="center" prop="ext1.phone" width="180" />
|
|
|
+ <el-table-column label="班次" align="center" prop="workSquence" >
|
|
|
+ <template #default="scope">
|
|
|
+ <dict-tag :options="work_squence" :value="scope.row.workSquence" />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="负责路线" align="center" prop="ext1.route" >
|
|
|
+ <template #default="scope">
|
|
|
+ <dict-tag :options="check_route" :value="scope.row.ext1.route" />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="成员数" align="center">
|
|
|
+ <template #default="scope">
|
|
|
+ {{scope.row.members.length}}
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="备注" align="center" show-overflow-tooltip prop="remark" width="180" />
|
|
|
<el-table-column label="创建时间" align="center" prop="createTime" width="180" />
|
|
|
<el-table-column label="操作" align="center" width="100" fixed="right" class-name="small-padding fixed-width">
|
|
|
<template #default="scope">
|
|
@@ -65,32 +80,62 @@
|
|
|
<el-form-item label="班组负责人" prop="headerId"
|
|
|
:rules="[{ required: true, message: '班组负责人不能为空', trigger: 'change' }]">
|
|
|
<el-select v-model="form.headerId" clearable @change="setUserInfo('leader')">
|
|
|
- <el-option v-for="item in userList" :key="item.userId" :label="item.nickName" :value="item.userId"></el-option>
|
|
|
+ <el-option v-for="item in userList" :key="item.userId" :label="item.nickName"
|
|
|
+ :value="item.userId"></el-option>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
<el-col :span="12">
|
|
|
<el-form-item label="联系电话" prop="ext1.phone">
|
|
|
- <el-input v-model="form.ext1.phone" disabled />
|
|
|
+ <el-input v-model="form.ext1.phone" disabled />
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
<el-col :span="12">
|
|
|
<el-form-item label="负责路线" prop="ext1.route">
|
|
|
- <el-select v-model="form.ext1.route" clearable >
|
|
|
- <el-option label="路线一" value="1"></el-option>
|
|
|
- <el-option label="路线二" value="2"></el-option>
|
|
|
+ <el-select v-model="form.ext1.route" clearable placeholder="请选择负责路线">
|
|
|
+ <el-option v-for="dict in check_route" :key="dict.value" :label="dict.label"
|
|
|
+ :value="dict.value"></el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-form-item label="班次" prop="workSquence"
|
|
|
+ :rules="[{ required: true, message: '班次不能为空', trigger: 'blur' }]">
|
|
|
+ <el-select v-model="form.workSquence" clearable placeholder="请选择班次">
|
|
|
+ <el-option v-for="dict in work_squence" :key="dict.value" :label="dict.label"
|
|
|
+ :value="dict.value"></el-option>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
<el-col :span="12">
|
|
|
- <el-form-item label="班次" prop="workSquence" :rules="[{ required: true, message: '班次不能为空', trigger: 'blur' }]">
|
|
|
- <el-input v-model="form.workSquence" placeholder="请输入联系电话" />
|
|
|
+ <el-form-item label="备注" prop="remark">
|
|
|
+ <el-input v-model="form.remark" placeholder="请输入备注" />
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
- <!-- <el-col :span="12">
|
|
|
- <el-form-item label="负责设备" prop="deviceTypeIds"
|
|
|
- :rules="[{ required: true, message: '负责设备不能为空', trigger: 'change' }]">
|
|
|
- <el-select v-model="form.deviceTypeIds" multiple clearable placeholder="请选择负责设备">
|
|
|
+ </el-row>
|
|
|
+ <SubTitle title="班组成员" />
|
|
|
+ <el-table :data="form.members" max-height="300">
|
|
|
+ <el-table-column label="班组成员" align="center" prop="name">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-select v-model="scope.row.userId" clearable @change="setUserInfo('member', scope.$index)">
|
|
|
+ <el-option v-for="item in userList" :key="item.userId" :label="item.nickName"
|
|
|
+ :value="item.userId"></el-option>
|
|
|
+ </el-select>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="联系方式" align="center">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-input v-model="scope.row.phone" placeholder="请输入" />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="技能描述" align="center" prop="skill">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-input v-model="scope.row.skill" placeholder="请输入" />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="负责设备类型" align="center">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-select v-model="scope.row.deviceTypeIds" multiple collapse-tags clearable placeholder="请选择负责设备">
|
|
|
<el-option v-for="dict in dictGroup.deviceTypeDetailOptions" :key="dict.id"
|
|
|
:label="`${dict.ext1.brand}${dict.xh}`" :value="dict.id">
|
|
|
<span style="float: left">{{ dict.ext1.brand }}</span>
|
|
@@ -99,21 +144,23 @@
|
|
|
</span>
|
|
|
</el-option>
|
|
|
</el-select>
|
|
|
- </el-form-item>
|
|
|
- </el-col> -->
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="备注" prop="remark">
|
|
|
- <el-input v-model="form.remark" placeholder="请输入备注" />
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- </el-row>
|
|
|
- <SubTitle title="班组成员" />
|
|
|
- <el-table :data="form.members">
|
|
|
- <el-table-column label="班组成员" align="center" prop="name" />
|
|
|
- <el-table-column label="联系方式" align="center" prop="name" />
|
|
|
- <el-table-column label="技能描述" align="center" prop="name" />
|
|
|
- <el-table-column label="负责设备类型" align="center" prop="name" />
|
|
|
- <el-table-column label="操作" align="center" prop="name" />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="操作" align="center" width="80">
|
|
|
+ <template #header>
|
|
|
+ <div class="operateBtn">
|
|
|
+ <span>操作</span>
|
|
|
+ <el-icon @click="addMembers">
|
|
|
+ <CirclePlus />
|
|
|
+ </el-icon>
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+ <template #default="scope">
|
|
|
+ <el-icon @click="delMembers(scope.$index)">
|
|
|
+ <Delete />
|
|
|
+ </el-icon>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
</el-table>
|
|
|
</el-form>
|
|
|
<template #footer>
|
|
@@ -131,7 +178,8 @@ import { listInspectionTeam, getInspectionTeam, delInspectionTeam, addInspection
|
|
|
import {
|
|
|
getDeviceTypeDetailList
|
|
|
} from '@/api/deviceManage/deviceType';
|
|
|
-import {listUser} from '@/api/system/user/index'
|
|
|
+import { listUser } from '@/api/system/user/index'
|
|
|
+import { deepClone } from '@/utils';
|
|
|
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
|
|
|
|
|
|
const tableList = ref([]);
|
|
@@ -152,16 +200,25 @@ const dictGroup = reactive({
|
|
|
productorOptions: [],
|
|
|
deviceTypeDetailOptions: []
|
|
|
})
|
|
|
+const { work_squence } = toRefs<any>(proxy?.useDict('work_squence'));
|
|
|
+const { check_route } = toRefs<any>(proxy?.useDict('check_route'));
|
|
|
const initFormData = {
|
|
|
id: undefined,
|
|
|
name: undefined,
|
|
|
headerId: undefined,
|
|
|
workSquence: undefined,
|
|
|
remark: undefined,
|
|
|
- members: [],
|
|
|
+ members: [{
|
|
|
+ userId: '',
|
|
|
+ userName: '',
|
|
|
+ phone: '',
|
|
|
+ skill: '',
|
|
|
+ deviceTypeIds: [],
|
|
|
+ }],
|
|
|
ext1: <any>{
|
|
|
+ headerName:'',
|
|
|
phone: '',
|
|
|
- route:''
|
|
|
+ route: ''
|
|
|
},
|
|
|
ext2: undefined
|
|
|
};
|
|
@@ -183,7 +240,8 @@ const getList = async () => {
|
|
|
const res = await listInspectionTeam(queryParams.value);
|
|
|
tableList.value = res.rows.map((item) => ({
|
|
|
...item,
|
|
|
- ext1: item.ext1 ? JSON.parse(item.ext1) : null
|
|
|
+ ext1: item.ext1 ? JSON.parse(item.ext1) : null,
|
|
|
+ members: item.members ? JSON.parse(item.members) : null
|
|
|
}));
|
|
|
total.value = res.total;
|
|
|
loading.value = false;
|
|
@@ -197,7 +255,7 @@ const cancel = () => {
|
|
|
|
|
|
/** 表单重置 */
|
|
|
const reset = () => {
|
|
|
- form.value = { ...initFormData };
|
|
|
+ form.value = { ...deepClone(initFormData) };
|
|
|
addFormRef.value?.resetFields();
|
|
|
};
|
|
|
|
|
@@ -233,8 +291,7 @@ const handleUpdate = async (row) => {
|
|
|
const _id = row?.id || ids.value[0];
|
|
|
const { data } = await getInspectionTeam(_id);
|
|
|
data.ext1 = data.ext1 && JSON.parse(data.ext1);
|
|
|
- deviceTypeDetailList(data.productorId)
|
|
|
- data.deviceTypeIds = data.deviceTypeIds.split(',');
|
|
|
+ data.members = data.members && JSON.parse(data.members);
|
|
|
Object.assign(form.value, data);
|
|
|
dialog.visible = true;
|
|
|
dialog.title = '修改巡检班组';
|
|
@@ -244,9 +301,17 @@ const handleUpdate = async (row) => {
|
|
|
const submitForm = () => {
|
|
|
addFormRef.value?.validate(async (valid: boolean) => {
|
|
|
if (valid) {
|
|
|
+ const { ext1, members } = form.value;
|
|
|
+ if (members.length === 0) return proxy?.$modal.msgError('请选择班组成员');
|
|
|
+ let validFlag =false
|
|
|
+ members.forEach(item => {
|
|
|
+ if (item.userId===''||item.deviceTypeIds.length==0) {
|
|
|
+ validFlag=true
|
|
|
+ }
|
|
|
+ })
|
|
|
+ if (validFlag) return proxy?.$modal.msgError('请选择补充班组成员信息');
|
|
|
buttonLoading.value = true;
|
|
|
- const { ext1, deviceTypeIds } = form.value;
|
|
|
- const params = Object.assign(form.value, { ext1: JSON.stringify(ext1), deviceTypeIds: deviceTypeIds.join() });
|
|
|
+ const params = Object.assign(form.value, { ext1: JSON.stringify(ext1), members: JSON.stringify(members) });
|
|
|
if (form.value.id) {
|
|
|
await updateInspectionTeam(params).finally(() => (buttonLoading.value = false));
|
|
|
} else {
|
|
@@ -274,42 +339,49 @@ const deviceTypeDetailList = async (productorId = '') => {
|
|
|
ext1: item.ext1 ? JSON.parse(item.ext1) : null
|
|
|
}));
|
|
|
};
|
|
|
-const formatDevice = (val) => {
|
|
|
- const arr = val.split(',')
|
|
|
- let label = ''
|
|
|
- dictGroup.deviceTypeDetailOptions.forEach((item) => {
|
|
|
- arr.forEach(el => {
|
|
|
- if (el === item.id) {
|
|
|
- label += `${item.ext1.brand}${item.xh},`
|
|
|
- }
|
|
|
- })
|
|
|
- })
|
|
|
- return label.substring(0, label.length - 1)
|
|
|
-}
|
|
|
-const formatDict = (val, option: string) => {
|
|
|
- let label = '';
|
|
|
- dictGroup[option].forEach((item) => {
|
|
|
- if (val === item.id) {
|
|
|
- label = item.name;
|
|
|
- }
|
|
|
- });
|
|
|
- return label;
|
|
|
-};
|
|
|
const getUserList = () => {
|
|
|
- listUser({ status: '0', pageSize: 10000, pageNum: 1 }).then(({ code,rows}) => {
|
|
|
- if (code===200) {
|
|
|
+ listUser({ status: '0', pageSize: 10000, pageNum: 1 }).then(({ code, rows }) => {
|
|
|
+ if (code === 200) {
|
|
|
userList.value = rows
|
|
|
}
|
|
|
})
|
|
|
}
|
|
|
-const setUserInfo = (type) => {
|
|
|
- const {headerId } = form.value
|
|
|
- userList.value.forEach(item => {
|
|
|
- if (headerId===item.userId) {
|
|
|
- form.value.ext1.phone = item.phonenumber
|
|
|
- }
|
|
|
+const setUserInfo = (type, index = 0) => {
|
|
|
+ if (type === 'leader') {
|
|
|
+ form.value.ext1.phone = ''
|
|
|
+ form.value.ext1.headerName = ''
|
|
|
+ const { headerId } = form.value
|
|
|
+ userList.value.forEach(item => {
|
|
|
+ if (headerId === item.userId) {
|
|
|
+ form.value.ext1.phone = item.phonenumber
|
|
|
+ form.value.ext1.headerName = item.nickName
|
|
|
+ }
|
|
|
+ })
|
|
|
+ } else {
|
|
|
+ const { userId } = form.value.members[index]
|
|
|
+ form.value.members[index].phone = ''
|
|
|
+ form.value.members[index].userName = ''
|
|
|
+ userList.value.forEach(item => {
|
|
|
+ if (userId === item.userId) {
|
|
|
+ form.value.members[index].phone = item.phonenumber
|
|
|
+ form.value.members[index].userName = item.nickName
|
|
|
+ }
|
|
|
+ })
|
|
|
+ }
|
|
|
+
|
|
|
+}
|
|
|
+const addMembers = () => {
|
|
|
+ form.value.members.push({
|
|
|
+ userId: '',
|
|
|
+ userName: '',
|
|
|
+ phone: '',
|
|
|
+ skill: '',
|
|
|
+ deviceTypeIds: [],
|
|
|
})
|
|
|
}
|
|
|
+const delMembers = (index) => {
|
|
|
+ form.value.members.splice(index, 1)
|
|
|
+}
|
|
|
onMounted(() => {
|
|
|
getList();
|
|
|
deviceTypeDetailList()
|
|
@@ -317,50 +389,14 @@ onMounted(() => {
|
|
|
});
|
|
|
</script>
|
|
|
<style lang="scss" scoped>
|
|
|
-.card-header {
|
|
|
- display: flex;
|
|
|
- justify-content: space-between;
|
|
|
-
|
|
|
- .el-icon {
|
|
|
- cursor: pointer;
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-.custom-tree-node {
|
|
|
- flex: 1;
|
|
|
+.operateBtn {
|
|
|
display: flex;
|
|
|
- justify-content: space-between;
|
|
|
align-items: center;
|
|
|
- padding-right: 5px;
|
|
|
-}
|
|
|
|
|
|
-.node-operateBtns {
|
|
|
- div {
|
|
|
- margin-top: 3px;
|
|
|
- text-align: center;
|
|
|
+ .el-icon {
|
|
|
+ color: #409eff;
|
|
|
+ margin-left: 5px;
|
|
|
cursor: pointer;
|
|
|
-
|
|
|
- &:hover {
|
|
|
- color: #409eff;
|
|
|
- }
|
|
|
- }
|
|
|
-}
|
|
|
-</style>
|
|
|
-<style lang="scss">
|
|
|
-.customDrawer {
|
|
|
- .el-drawer__header {
|
|
|
- align-items: flex-start !important;
|
|
|
- margin-bottom: 10px;
|
|
|
-
|
|
|
- .drawer-title {
|
|
|
- .title-name {
|
|
|
- color: #000;
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- .el-drawer__body {
|
|
|
- padding-top: 0;
|
|
|
}
|
|
|
}
|
|
|
</style>
|