流程相关-分公司项目部新增

This commit is contained in:
lSun 2024-10-14 19:21:27 +08:00
parent dd1ac72020
commit 93933e6ebe
4 changed files with 1279 additions and 135 deletions

View File

@ -28,8 +28,12 @@ export function addType(data) {
}
// 修改
export function updateType(data) {
export function updateType(data,oldOrgName) {
let dataList = handle(data)
if(oldOrgName == dataList.orgName ){
delete dataList.orgName; // 删除 orgName 参数
}
console.log(dataList)
return request({
url: '/system/subOrg',
method: 'put',

View File

@ -0,0 +1,26 @@
import request from '@/utils/request'
// 查询列表
export function listType(query) {
return request({
url: '/system/subOrg/checkList',
method: 'get',
params: query
})
}
// 查询详细
export function getType(orgId) {
return request({
url: '/system/subOrg/' + orgId,
method: 'get'
})
}
// 审批/提交/撤回
export function changeStatus(orgId,reviewerStatus) {
return request({
url: '/system/subOrg/changeStatus/'+orgId+"/"+reviewerStatus,
method: 'put'
})
}

View File

@ -45,7 +45,7 @@
plain
icon="el-icon-download"
size="mini"
@click="handleUpdate"
@click=""
>导出
</el-button>
</el-col>
@ -98,7 +98,7 @@
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-if="scope.row.reviewerStatus == 0"
v-if="scope.row.reviewerStatus != 1 "
>修改
</el-button>
<el-button
@ -176,150 +176,232 @@
</el-col>
<el-col :span="12">
<el-form-item label="项目经理" required>
<el-tree
class="tree-border"
:data="managerOptions"
show-checkbox
ref="manager"
node-key="managerId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="managerDefaultCheckedKeys"
@check-change="managerHandleCheckChange"
></el-tree>
<el-input
type="textarea"
v-model="managerSelectedDataText"
readonly
placeholder="请选择项目经理"
></el-input>
<div class="tree-container">
<el-tree
class="tree-border"
:data="managerOptions"
show-checkbox
ref="manager"
node-key="managerId"
empty-text="加载中,请稍候"
:props="defaultProps"
default-expand-all
:default-checked-keys="managerDefaultCheckedKeys"
@check-change="managerHandleCheckChange"
></el-tree>
</div>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="安全员" required>
<el-tree
class="tree-border"
:data="safetyOptions"
show-checkbox
ref="safety"
node-key="safetyId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="safetyDefaultCheckedKeys"
@check-change="safetyHandleCheckChange"
></el-tree>
<el-input
type="textarea"
v-model="safetySelectedDataText"
readonly
placeholder="请选择安全员"
></el-input>
<div class="tree-container">
<el-tree
class="tree-border"
:data="safetyOptions"
show-checkbox
ref="safety"
node-key="safetyId"
empty-text="加载中,请稍候"
default-expand-all
:props="defaultProps"
:default-checked-keys="safetyDefaultCheckedKeys"
@check-change="safetyHandleCheckChange"
></el-tree>
</div>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="质检员" required>
<el-tree
class="tree-border"
:data="qualityOptions"
show-checkbox
ref="quality"
node-key="qualityId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="qualityDefaultCheckedKeys"
@check-change="qualityHandleCheckChange"
></el-tree>
<el-input
type="textarea"
v-model="qualitySelectedDataText"
readonly
placeholder="请选择质检员"
></el-input>
<div class="tree-container">
<el-tree
class="tree-border"
:data="qualityOptions"
show-checkbox
ref="quality"
node-key="qualityId"
empty-text="加载中,请稍候"
default-expand-all
:props="defaultProps"
:default-checked-keys="qualityDefaultCheckedKeys"
@check-change="qualityHandleCheckChange"
></el-tree>
</div>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="项目总工" required>
<el-tree
class="tree-border"
:data="proOptions"
show-checkbox
ref="pro"
node-key="proId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="proDefaultCheckedKeys"
@check-change="proHandleCheckChange"
></el-tree>
<el-input
type="textarea"
v-model="proSelectedDataText"
readonly
placeholder="请选择项目总工"
></el-input>
<div class="tree-container">
<el-tree
class="tree-border"
:data="proOptions"
show-checkbox
ref="pro"
node-key="proId"
empty-text="加载中,请稍候"
default-expand-all
:props="defaultProps"
:default-checked-keys="proDefaultCheckedKeys"
@check-change="proHandleCheckChange"
></el-tree>
</div>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="机械员" required>
<el-tree
class="tree-border"
:data="mechanicOptions"
show-checkbox
ref="mechanic"
node-key="mechanicId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="mechanicDefaultCheckedKeys"
@check-change="mechanicHandleCheckChange"
></el-tree>
<el-input
type="textarea"
v-model="mechanicSelectedDataText"
readonly
placeholder="请选择机械员"
></el-input>
<div class="tree-container">
<el-tree
class="tree-border"
:data="mechanicOptions"
show-checkbox
ref="mechanic"
node-key="mechanicId"
empty-text="加载中,请稍候"
default-expand-all
:props="defaultProps"
:default-checked-keys="mechanicDefaultCheckedKeys"
@check-change="mechanicHandleCheckChange"
></el-tree>
</div>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="资料员" required>
<el-tree
class="tree-border"
:data="documenterOptions"
show-checkbox
ref="documenter"
node-key="documenterId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="documenterDefaultCheckedKeys"
@check-change="documenterHandleCheckChange"
></el-tree>
<el-input
type="textarea"
v-model="documenterSelectedDataText"
readonly
placeholder="请选择资料员"
></el-input>
<div class="tree-container">
<el-tree
class="tree-border"
:data="documenterOptions"
show-checkbox
ref="documenter"
node-key="documenterId"
empty-text="加载中,请稍候"
default-expand-all
:props="defaultProps"
:default-checked-keys="documenterDefaultCheckedKeys"
@check-change="documenterHandleCheckChange"
></el-tree>
</div>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="施工员" required>
<el-tree
class="tree-border"
:data="constructionOptions"
show-checkbox
ref="construction"
node-key="constructionId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="constructionDefaultCheckedKeys"
@check-change="constructionHandleCheckChange"
></el-tree>
<el-input
type="textarea"
v-model="constructionSelectedDataText"
readonly
placeholder="请选择施工员"
></el-input>
<div class="tree-container">
<el-tree
class="tree-border"
:data="constructionOptions"
show-checkbox
ref="construction"
node-key="constructionId"
empty-text="加载中,请稍候"
default-expand-all
:props="defaultProps"
:default-checked-keys="constructionDefaultCheckedKeys"
@check-change="constructionHandleCheckChange"
></el-tree>
</div>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="材料员" required>
<el-tree
class="tree-border"
:data="materialmanOptions"
show-checkbox
ref="materialman"
node-key="materialmanId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="materialmanDefaultCheckedKeys"
@check-change="materialmanHandleCheckChange"
></el-tree>
<el-input
type="textarea"
v-model="materialmanSelectedDataText"
readonly
placeholder="请选择材料员"
></el-input>
<div class="tree-container">
<el-tree
class="tree-border"
:data="materialmanOptions"
show-checkbox
ref="materialman"
node-key="materialmanId"
empty-text="加载中,请稍候"
default-expand-all
:props="defaultProps"
:default-checked-keys="materialmanDefaultCheckedKeys"
@check-change="materialmanHandleCheckChange"
></el-tree>
</div>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="其他">
<el-tree
class="tree-border"
:data="otherOptions"
show-checkbox
ref="other"
node-key="otherId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="otherDefaultCheckedKeys"
@check-change="otherHandleCheckChange"
></el-tree>
<el-input
type="textarea"
v-model="otherSelectedDataText"
readonly
placeholder="请选择其他"
></el-input>
<div class="tree-container">
<el-tree
class="tree-border"
:data="otherOptions"
show-checkbox
ref="other"
node-key="otherId"
empty-text="加载中,请稍候"
default-expand-all
:props="defaultProps"
:default-checked-keys="otherDefaultCheckedKeys"
@check-change="otherHandleCheckChange"
></el-tree>
</div>
</el-form-item>
</el-col>
@ -327,7 +409,7 @@
</el-row>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm" v-if="details"> </el-button>
<el-button type="primary" @click="submitForm" v-if="details"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
@ -358,7 +440,7 @@ export default {
title: "",
//
open: false,
details:true,
details: true,
//
dateRange: [],
//
@ -433,6 +515,19 @@ export default {
safetyCurrentCheckedNode: [],
qualityCurrentCheckedNode: [],
proCurrentCheckedNode: [],
oldOrgName: [],
//
managerSelectedDataText: "",
safetySelectedDataText: "",
qualitySelectedDataText: "",
proSelectedDataText: "",
mechanicSelectedDataText: "",
documenterSelectedDataText: "",
constructionSelectedDataText: "",
materialmanSelectedDataText: "",
otherSelectedDataText: "",
};
},
created() {
@ -504,6 +599,25 @@ export default {
constructionIdToIdMap: {},
materialmanIdToIdMap: {},
otherIdToIdMap: {},
//
managerCurrentCheckedNode: [],
safetyCurrentCheckedNode: [],
qualityCurrentCheckedNode: [],
proCurrentCheckedNode: [],
oldOrgName: [],
//
managerSelectedDataText: "",
safetySelectedDataText: "",
qualitySelectedDataText: "",
proSelectedDataText: "",
mechanicSelectedDataText: "",
documenterSelectedDataText: "",
constructionSelectedDataText: "",
materialmanSelectedDataText: "",
otherSelectedDataText: "",
};
this.resetForm("form");
},
@ -565,9 +679,10 @@ export default {
/** 修改按钮操作 */
handleUpdate(row) {
this.reset();
const ids = row.id
const ids = row.id;
getType(ids).then(response => {
this.form = response.data;
this.oldOrgName = row.orgName
this.open = true;
this.details = true;
this.title = "分公司项目部修改";
@ -618,15 +733,15 @@ export default {
});
/** 人员 */
this.getStaffTreeselect("-1", "1", "", "manager");
this.getStaffTreeselect("-1", "2", "", "safety");
this.getStaffTreeselect("-1", "3", "", "quality");
this.getStaffTreeselect("-1", "4", "", "pro");
this.getStaffTreeselect("-1", "5", "", "mechanic");
this.getStaffTreeselect("-1", "6", "", "documenter");
this.getStaffTreeselect("-1", "7", "", "construction");
this.getStaffTreeselect("-1", "8", "", "materialman");
this.getStaffTreeselect("-1", "9", "", "other");
this.getStaffTreeselect(ids, "1", "", "manager");
this.getStaffTreeselect(ids, "2", "", "safety");
this.getStaffTreeselect(ids, "3", "", "quality");
this.getStaffTreeselect(ids, "4", "", "pro");
this.getStaffTreeselect(ids, "5", "", "mechanic");
this.getStaffTreeselect(ids, "6", "", "documenter");
this.getStaffTreeselect(ids, "7", "", "construction");
this.getStaffTreeselect(ids, "8", "", "materialman");
this.getStaffTreeselect(ids, "9", "", "other");
});
},
@ -715,7 +830,7 @@ export default {
if (this.form.id != undefined) {
updateType(this.form).then(response => {
updateType(this.form, this.oldOrgName).then(response => {
this.$modal.msgSuccess("修改成功");
this.open = false;
this.getList();
@ -746,7 +861,7 @@ export default {
handleWithdraw(row) {
const ids = row.id;
this.$modal.confirm('是否确认撤回此数据项?').then(function () {
return changeStatus(ids,"3");
return changeStatus(ids, "3");
}).then(() => {
this.getList();
this.$modal.msgSuccess("撤回成功");
@ -879,9 +994,28 @@ export default {
console.error(`Unknown type: ${types}`);
break;
}
this.updateSelectedDataText('manager', 'managerSelectedDataText');
this.updateSelectedDataText('safety', 'safetySelectedDataText');
this.updateSelectedDataText('quality', 'qualitySelectedDataText');
this.updateSelectedDataText('pro', 'proSelectedDataText');
this.updateSelectedDataText('mechanic', 'mechanicSelectedDataText');
this.updateSelectedDataText('documenter', 'documenterSelectedDataText');
this.updateSelectedDataText('construction', 'constructionSelectedDataText');
this.updateSelectedDataText('materialman', 'materialmanSelectedDataText');
this.updateSelectedDataText('other', 'otherSelectedDataText');
return Array.from(keys);
},
//
updateSelectedDataText(refName, dataPropertyName) {
this.$nextTick(() => {
const checkedNodes = this.$refs[refName].getCheckedNodes(true);
const selectedText = checkedNodes.map(node => node.name).join(', ');
this[dataPropertyName] = selectedText;
});
},
//
managerHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
@ -890,26 +1024,9 @@ export default {
this.uncheckAllWithSameId(idToUncheck, "manager");
});
} else {
/* const indexs = this.managerCurrentCheckedNode.indexOf(data.id);
if (indexs < 0 && this.managerCurrentCheckedNode.length === 1 && checked) {
this.$message({
message: '只能选择一个!',
type: 'error',
showClose: true
});
this.$nextTick(() => {
this.$refs.manager.setChecked(data, false,false);
});
}else if (this.managerCurrentCheckedNode.length === 0 && checked) {
//
// push
this.managerCurrentCheckedNode = []
this.managerCurrentCheckedNode.push(data.id)
} else if (indexs >= 0 && this.managerCurrentCheckedNode.length === 1 && !checked) {
//
this.managerCurrentCheckedNode = []
}*/
}
this.updateSelectedDataText('manager', 'managerSelectedDataText');
},
safetyHandleCheckChange(data, checked, indeterminate) {
@ -919,6 +1036,8 @@ export default {
this.uncheckAllWithSameId(idToUncheck, "safety");
});
}
this.updateSelectedDataText('safety', 'safetySelectedDataText');
},
qualityHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
@ -927,6 +1046,7 @@ export default {
this.uncheckAllWithSameId(idToUncheck, "quality");
});
}
this.updateSelectedDataText('quality', 'qualitySelectedDataText');
},
proHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
@ -935,6 +1055,7 @@ export default {
this.uncheckAllWithSameId(idToUncheck, "pro");
});
}
this.updateSelectedDataText('pro', 'proSelectedDataText');
},
mechanicHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
@ -943,6 +1064,7 @@ export default {
this.uncheckAllWithSameId(idToUncheck, "mechanic");
});
}
this.updateSelectedDataText('mechanic', 'mechanicSelectedDataText');
},
documenterHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
@ -951,6 +1073,7 @@ export default {
this.uncheckAllWithSameId(idToUncheck, "documenter");
});
}
this.updateSelectedDataText('documenter', 'documenterSelectedDataText');
},
constructionHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
@ -959,6 +1082,7 @@ export default {
this.uncheckAllWithSameId(idToUncheck, "construction");
});
}
this.updateSelectedDataText('construction', 'constructionSelectedDataText');
},
materialmanHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
@ -967,6 +1091,7 @@ export default {
this.uncheckAllWithSameId(idToUncheck, "materialman");
});
}
this.updateSelectedDataText('materialman', 'materialmanSelectedDataText');
},
otherHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
@ -975,6 +1100,7 @@ export default {
this.uncheckAllWithSameId(idToUncheck, "other");
});
}
this.updateSelectedDataText('other', 'otherSelectedDataText');
},
//
uncheckAllWithSameId(id, type) {
@ -1118,3 +1244,12 @@ export default {
}
};
</script>
<style scoped>
.tree-container {
max-height: 100px; /* 设置最大高度 */
overflow-y: auto; /* 启用垂直滚动条 */
border: 1px solid #dcdfe6; /* 可选:添加边框 */
border-radius: 4px; /* 可选:添加圆角 */
}
</style>

View File

@ -0,0 +1,979 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="85px">
<el-form-item label="申请人名称" prop="applyName">
<el-input
v-model="queryParams.applyName"
placeholder="请输入申请人名称"
clearable
style="width: 200px"
maxlength="28"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="项目部名称" prop="orgName">
<el-input
v-model="queryParams.orgName"
placeholder="请输入项目部名称"
clearable
style="width: 200px"
maxlength="28"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="部门负责人" prop="orgHeadUserName">
<el-input
v-model="queryParams.orgHeadUserName"
placeholder="请输入部门负责人"
clearable
style="width: 200px"
maxlength="28"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
<el-button
type="success"
plain
icon="el-icon-download"
size="mini"
@click="handleUpdate"
>导出
</el-button>
</el-form-item>
</el-form>
<el-table v-loading="loading" :data="typeList">
<el-table-column label="序号" align="center" width="80" type="index">
<template slot-scope="scope">
<span>{{ (queryParams.pageNum - 1) * queryParams.pageSize + scope.$index + 1 }}</span>
</template>
</el-table-column>
<el-table-column label="申请人" align="center" prop="applyName" :show-overflow-tooltip="true"/>
<el-table-column label="申请时间" align="center" prop="createTime" width="180">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.createTime) }}</span>
</template>
</el-table-column>
<el-table-column label="上级部门" align="center" prop="parentOrgName" :show-overflow-tooltip="true"/>
<el-table-column label="项目部名称" align="center" prop="orgName" :show-overflow-tooltip="true"/>
<el-table-column label="项目部负责人" align="center" prop="orgHeadUserName" :show-overflow-tooltip="true"/>
<el-table-column label="审批状态" align="center" prop="reviewerStatus" :show-overflow-tooltip="true">
<template slot-scope="scope">
<span v-if="scope.row.reviewerStatus == 0">待审核</span>
<span v-else-if="scope.row.reviewerStatus == 1">已审核</span>
<span v-else-if="scope.row.reviewerStatus == 2">未通过</span>
<span v-else-if="scope.row.reviewerStatus == 3">撤回</span>
</template>
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
icon="el-icon-search"
@click="detailsUpdate(scope.row)"
>详情
</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
>审核
</el-button>
</template>
</el-table-column>
</el-table>
<pagination
v-show="total>0"
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<!-- 添加或修改参数配置对话框 -->
<el-dialog :title="title" :visible.sync="open" width="800px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
<el-row>
<el-col :span="12" v-if="form.parentId !== 0">
<el-form-item label="上级部门" prop="parentId">
<treeselect v-model="form.parentId" :options="deptOptions" :normalizer="normalizer" :disabled="true"
placeholder="选择上级部门"/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="部门名称" prop="orgName">
<el-input v-model="form.orgName" placeholder="请输入部门名称" maxlength="30" :disabled="true" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="部门负责人" prop="orgHeadUserId">
<treeselect v-model="form.orgHeadUserId" :flat="true" :options="personOptions" :normalizer="normalizer2"
placeholder="选择部门负责人" @select="handleSelect1" :disabled="true" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="省内外" prop="isProvince">
<el-radio-group v-model="form.isProvince">
<el-radio
:disabled="true"
v-for="item in isProvinceList"
:key="item.id"
:label="item.id"
>{{ item.name }}
</el-radio>
</el-radio-group>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="位置" prop="address">
<el-input v-model="form.address" placeholder="请输入位置" maxlength="50" :disabled="true" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="项目经理" required>
<el-tree
class="tree-border"
:data="managerOptions"
show-checkbox
ref="manager"
node-key="managerId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="managerDefaultCheckedKeys"
@check-change="managerHandleCheckChange"
:disabled="true"
></el-tree>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="安全员" required>
<el-tree
class="tree-border"
:data="safetyOptions"
show-checkbox
ref="safety"
node-key="safetyId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="safetyDefaultCheckedKeys"
@check-change="safetyHandleCheckChange"
:disabled="true"
></el-tree>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="质检员" required>
<el-tree
class="tree-border"
:data="qualityOptions"
show-checkbox
ref="quality"
node-key="qualityId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="qualityDefaultCheckedKeys"
@check-change="qualityHandleCheckChange"
:disabled="true"
></el-tree>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="项目总工" required>
<el-tree
class="tree-border"
:data="proOptions"
show-checkbox
ref="pro"
node-key="proId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="proDefaultCheckedKeys"
@check-change="proHandleCheckChange"
:disabled="true"
></el-tree>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="机械员" required>
<el-tree
class="tree-border"
:data="mechanicOptions"
show-checkbox
ref="mechanic"
node-key="mechanicId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="mechanicDefaultCheckedKeys"
@check-change="mechanicHandleCheckChange"
:disabled="true"
></el-tree>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="资料员" required>
<el-tree
class="tree-border"
:data="documenterOptions"
show-checkbox
ref="documenter"
node-key="documenterId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="documenterDefaultCheckedKeys"
@check-change="documenterHandleCheckChange"
:disabled="true"
></el-tree>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="施工员" required>
<el-tree
class="tree-border"
:data="constructionOptions"
show-checkbox
ref="construction"
node-key="constructionId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="constructionDefaultCheckedKeys"
@check-change="constructionHandleCheckChange"
:disabled="true"
></el-tree>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="材料员" required>
<el-tree
class="tree-border"
:data="materialmanOptions"
show-checkbox
ref="materialman"
node-key="materialmanId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="materialmanDefaultCheckedKeys"
@check-change="materialmanHandleCheckChange"
:disabled="true"
></el-tree>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="其他">
<el-tree
class="tree-border"
:data="otherOptions"
show-checkbox
ref="other"
node-key="otherId"
empty-text="加载中,请稍候"
:props="defaultProps"
:default-checked-keys="otherDefaultCheckedKeys"
@check-change="otherHandleCheckChange"
:disabled="true"
></el-tree>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="handleAgree" v-if="details"> </el-button>
<el-button type="danger" @click="handleReject" v-if="details"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
</div>
</template>
<script>
import {listType, getType, changeStatus} from "@/api/process/branchProExamine";
import {listDept, orgPersonSelect} from "@/api/system/dept";
import Treeselect from "@riophae/vue-treeselect";
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
import {treeselect as staffTreeselect} from "@/api/process/tree";
export default {
name: "BranchPro",
components: {Treeselect},
data() {
return {
//
loading: true,
//
showSearch: true,
//
total: 0,
//
typeList: [],
//
title: "",
//
open: false,
details: true,
//
dateRange: [],
//
queryParams: {
pageNum: 1,
pageSize: 10,
orgName: undefined,
orgHeadUserName: undefined,
applyName: undefined,
reviewerStatus:0,
},
//
form: {},
//
rules: {
menuName: [
{required: true, message: "菜单名称不能为空", trigger: "blur"}
],
orderNum: [
{required: true, message: "菜单顺序不能为空", trigger: "blur"}
],
path: [
{required: true, message: "路由地址不能为空", trigger: "blur"}
],
systemType: [
{required: true, message: "请选择系统类型", trigger: "change"}
],
},
//
deptOptions: [],
personOptions: [],
isProvinceList: [{id: '1', name: '省内'}, {id: '2', name: '省外'}],
//
managerOptions: [],
safetyOptions: [],
qualityOptions: [],
proOptions: [],
mechanicOptions: [],
documenterOptions: [],
constructionOptions: [],
materialmanOptions: [],
otherOptions: [],
// id
managerDefaultCheckedKeys: [],
safetyDefaultCheckedKeys: [],
qualityDefaultCheckedKeys: [],
proDefaultCheckedKeys: [],
mechanicDefaultCheckedKeys: [],
documenterDefaultCheckedKeys: [],
constructionDefaultCheckedKeys: [],
materialmanDefaultCheckedKeys: [],
otherDefaultCheckedKeys: [],
// uniqueId id
managerIdToIdMap: {},
safetyIdToIdMap: {},
qualityIdToIdMap: {},
proIdToIdMap: {},
mechanicIdToIdMap: {},
documenterIdToIdMap: {},
constructionIdToIdMap: {},
materialmanIdToIdMap: {},
otherIdToIdMap: {},
//
defaultProps: {
children: "children",
label: "name",
disabled: "disabled" // disabled
},
//
managerCurrentCheckedNode: [],
safetyCurrentCheckedNode: [],
qualityCurrentCheckedNode: [],
proCurrentCheckedNode: [],
};
},
created() {
this.getList();
},
methods: {
/** 查询列表 */
getList() {
this.loading = true;
listType(this.queryParams).then(response => {
this.typeList = response.rows;
this.total = response.total;
this.loading = false;
}
);
},
//
cancel() {
this.open = false;
this.reset();
},
//
reset() {
this.form = {
parentId: undefined,
orgName: undefined,
address: undefined,
attendanceUserId: undefined,
attendanceUserName: undefined,
orgHeadUserId: undefined,
orgHeadUserName: undefined,
province: undefined,
applyName: undefined,
isProvince: "1",
isDepartment: "0",
//
deptOptions: [],
personOptions: [],
isProvinceList: [{id: '1', name: '省内'}, {id: '2', name: '省外'}],
//
managerOptions: [],
safetyOptions: [],
qualityOptions: [],
proOptions: [],
mechanicOptions: [],
documenterOptions: [],
constructionOptions: [],
materialmanOptions: [],
otherOptions: [],
// id
managerDefaultCheckedKeys: [],
safetyDefaultCheckedKeys: [],
qualityDefaultCheckedKeys: [],
proDefaultCheckedKeys: [],
mechanicDefaultCheckedKeys: [],
documenterDefaultCheckedKeys: [],
constructionDefaultCheckedKeys: [],
materialmanDefaultCheckedKeys: [],
otherDefaultCheckedKeys: [],
// uniqueId id
managerIdToIdMap: {},
safetyIdToIdMap: {},
qualityIdToIdMap: {},
proIdToIdMap: {},
mechanicIdToIdMap: {},
documenterIdToIdMap: {},
constructionIdToIdMap: {},
materialmanIdToIdMap: {},
otherIdToIdMap: {},
};
this.resetForm("form");
},
/** 搜索按钮操作 */
handleQuery() {
this.queryParams.pageNum = 1;
this.getList();
},
/** 重置按钮操作 */
resetQuery() {
this.dateRange = [];
this.resetForm("queryForm");
this.handleQuery();
},
/** 新增按钮操作 */
handleAdd() {
this.reset();
this.open = true;
this.details = true;
this.title = "分公司项目部新增";
/**
* 上级部门下拉选
*/
listDept().then(response => {
this.deptOptions = this.handleTree(response.data, "id");
});
/**
* 项目部负责人
*/
orgPersonSelect().then(response => {
this.personOptions = this.changeData(response.data);
});
/** 人员 */
this.getStaffTreeselect("-1", "1", "", "manager");
this.getStaffTreeselect("-1", "2", "", "safety");
this.getStaffTreeselect("-1", "3", "", "quality");
this.getStaffTreeselect("-1", "4", "", "pro");
this.getStaffTreeselect("-1", "5", "", "mechanic");
this.getStaffTreeselect("-1", "6", "", "documenter");
this.getStaffTreeselect("-1", "7", "", "construction");
this.getStaffTreeselect("-1", "8", "", "materialman");
this.getStaffTreeselect("-1", "9", "", "other");
},
//
changeData(data) { //
data.map(item => {
if (!item.disabled) {
item.isDisabled = false
} else if (item.disabled) {
item.isDisabled = true
}
item.children && item.children.length > 0 && this.changeData(item.children);
})
return data;
},
/** 修改按钮操作 */
handleUpdate(row) {
this.reset();
const ids = row.id
getType(ids).then(response => {
this.form = response.data;
this.open = true;
this.details = true;
this.title = "分公司项目部修改";
listDept().then(response => {
this.deptOptions = this.handleTree(response.data, "id");
});
/**
* 项目部负责人
*/
orgPersonSelect().then(response => {
this.personOptions = this.changeData(response.data);
});
/** 人员 */
this.getStaffTreeselect(ids, "1", "", "manager");
this.getStaffTreeselect(ids, "2", "", "safety");
this.getStaffTreeselect(ids, "3", "", "quality");
this.getStaffTreeselect(ids, "4", "", "pro");
this.getStaffTreeselect(ids, "5", "", "mechanic");
this.getStaffTreeselect(ids, "6", "", "documenter");
this.getStaffTreeselect(ids, "7", "", "construction");
this.getStaffTreeselect(ids, "8", "", "materialman");
this.getStaffTreeselect(ids, "9", "", "other");
});
},
/** 详情按钮操作 */
detailsUpdate(row) {
this.reset();
const ids = row.id
getType(ids).then(response => {
this.form = response.data;
this.open = true;
this.details = false;
this.title = "分公司项目部详情";
listDept().then(response => {
this.deptOptions = this.handleTree(response.data, "id");
});
/**
* 项目部负责人
*/
orgPersonSelect().then(response => {
this.personOptions = this.changeData(response.data);
});
/** 人员 */
this.getStaffTreeselect(ids, "1", "", "manager");
this.getStaffTreeselect(ids, "2", "", "safety");
this.getStaffTreeselect(ids, "3", "", "quality");
this.getStaffTreeselect(ids, "4", "", "pro");
this.getStaffTreeselect(ids, "5", "", "mechanic");
this.getStaffTreeselect(ids, "6", "", "documenter");
this.getStaffTreeselect(ids, "7", "", "construction");
this.getStaffTreeselect(ids, "8", "", "materialman");
this.getStaffTreeselect(ids, "9", "", "other");
});
},
/**
* 审核同意
*/
handleAgree(){
this.handleExamine("1");
},
/**
* 审核驳回
*/
handleReject(){
this.handleExamine("2");
},
/** 审核按钮操作 */
handleExamine(reviewerStatus) {
const ids = this.form.id;
this.$modal.confirm('是否确认审核此数据项?').then(function () {
return changeStatus(ids, reviewerStatus);
}).then(() => {
this.$modal.msgSuccess("审核成功");
this.open = false;
this.getList();
}).catch(() => {
});
},
/** 导出按钮操作 */
handleExport() {
this.download('system/dict/type/export', {
...this.queryParams
}, `type_${new Date().getTime()}.xlsx`)
},
/** 转换部门数据结构 */
normalizer(node) {
if (node.children && !node.children.length) {
delete node.children;
}
return {
id: node.id,
label: node.orgName,
children: node.children
};
},
/** 项目部负责人 */
normalizer2(node) {
if (node.children && !node.children.length) {
delete node.children;
}
return {
id: node.id,
label: node.name,
children: node.children
};
},
handleSelect1(value, instanceId) {
//
this.form.orgHeadUserName = value.name;
},
/** 查询员工树结构 */
getStaffTreeselect(orgId, deptRoleId, departmentId, types) {
let data = {
orgId: orgId,
deptRoleId: deptRoleId,
departmentId: departmentId,
}
staffTreeselect(data).then(response => {
//
this[`${types}Options`] = response.data;
//
this.processData(types, this[`${types}Options`]);
//
this[`${types}DefaultCheckedKeys`] = this.getCheckedKeys(types, this[`${types}Options`]);
});
},
/** 处理数据,为每个节点生成唯一标识符并建立映射 */
processData(types, nodes, parentId = '') {
const idKey = `${types}Id`;
const idMapKey = `${types}IdToIdMap`;
nodes.forEach(node => {
//
node[idKey] = `${parentId ? parentId + '-' : ''}${node.id}`;
// uniqueId id
if (!this[idMapKey]) {
this[idMapKey] = {};
}
this[idMapKey][node[idKey]] = node.id;
//
if (node.children && node.children.length > 0) {
this.processData(types, node.children, node[idKey]);
}
});
},
/** 递归获取默认选中的节点 id */
getCheckedKeys(types, nodes) {
const keys = new Set();
const recursiveCheck = (nodes, keyField) => {
nodes.forEach(node => {
if (node.isCheck === 1) {
keys.add(node[keyField]);
}
if (node.children && node.children.length > 0) {
recursiveCheck(node.children, keyField);
}
});
};
switch (types) {
case 'manager':
recursiveCheck(nodes, 'managerId');
break;
case 'safety':
recursiveCheck(nodes, 'safetyId');
break;
case 'quality':
recursiveCheck(nodes, 'qualityId');
break;
case 'pro':
recursiveCheck(nodes, 'proId');
break;
case 'mechanic':
recursiveCheck(nodes, 'mechanicId');
break;
case 'documenter':
recursiveCheck(nodes, 'documenterId');
break;
case 'construction':
recursiveCheck(nodes, 'constructionId');
break;
case 'materialman':
recursiveCheck(nodes, 'materialmanId');
break;
case 'other':
recursiveCheck(nodes, 'otherId');
break;
default:
console.error(`Unknown type: ${types}`);
break;
}
return Array.from(keys);
},
//
managerHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
const idToUncheck = data.id;
this.$nextTick(() => {
this.uncheckAllWithSameId(idToUncheck, "manager");
});
}
},
safetyHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
const idToUncheck = data.id;
this.$nextTick(() => {
this.uncheckAllWithSameId(idToUncheck, "safety");
});
}
},
qualityHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
const idToUncheck = data.id;
this.$nextTick(() => {
this.uncheckAllWithSameId(idToUncheck, "quality");
});
}
},
proHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
const idToUncheck = data.id;
this.$nextTick(() => {
this.uncheckAllWithSameId(idToUncheck, "pro");
});
}
},
mechanicHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
const idToUncheck = data.id;
this.$nextTick(() => {
this.uncheckAllWithSameId(idToUncheck, "mechanic");
});
}
},
documenterHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
const idToUncheck = data.id;
this.$nextTick(() => {
this.uncheckAllWithSameId(idToUncheck, "documenter");
});
}
},
constructionHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
const idToUncheck = data.id;
this.$nextTick(() => {
this.uncheckAllWithSameId(idToUncheck, "construction");
});
}
},
materialmanHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
const idToUncheck = data.id;
this.$nextTick(() => {
this.uncheckAllWithSameId(idToUncheck, "materialman");
});
}
},
otherHandleCheckChange(data, checked, indeterminate) {
if (!checked) { //
const idToUncheck = data.id;
this.$nextTick(() => {
this.uncheckAllWithSameId(idToUncheck, "other");
});
}
},
//
uncheckAllWithSameId(id, type) {
let tree = "";
switch (type) {
case "manager":
tree = this.$refs.manager;
if (tree && tree.store) {
const allNodes = tree.store._getAllNodes();
allNodes.forEach(node => {
if (this.managerIdToIdMap[node.key] === id) {
tree.setChecked(node, false, false);
}
});
} else {
console.error('Tree or store is not initialized yet.');
}
break;
case "safety":
tree = this.$refs.safety;
if (tree && tree.store) {
const allNodes = tree.store._getAllNodes();
allNodes.forEach(node => {
if (this.safetyIdToIdMap[node.key] === id) {
tree.setChecked(node, false, false);
}
});
} else {
console.error('Tree or store is not initialized yet.');
}
break;
case "quality":
tree = this.$refs.quality;
if (tree && tree.store) {
const allNodes = tree.store._getAllNodes();
allNodes.forEach(node => {
if (this.qualityIdToIdMap[node.key] === id) {
tree.setChecked(node, false, false);
}
});
} else {
console.error('Tree or store is not initialized yet.');
}
break;
case "pro":
tree = this.$refs.pro;
if (tree && tree.store) {
const allNodes = tree.store._getAllNodes();
allNodes.forEach(node => {
if (this.proIdToIdMap[node.key] === id) {
tree.setChecked(node, false, false);
}
});
} else {
console.error('Tree or store is not initialized yet.');
}
break;
case "mechanic":
tree = this.$refs.mechanic;
if (tree && tree.store) {
const allNodes = tree.store._getAllNodes();
allNodes.forEach(node => {
if (this.mechanicIdToIdMap[node.key] === id) {
tree.setChecked(node, false, false);
}
});
} else {
console.error('Tree or store is not initialized yet.');
}
break;
case "documenter":
tree = this.$refs.documenter;
if (tree && tree.store) {
const allNodes = tree.store._getAllNodes();
allNodes.forEach(node => {
if (this.documenterIdToIdMap[node.key] === id) {
tree.setChecked(node, false, false);
}
});
} else {
console.error('Tree or store is not initialized yet.');
}
break;
case "construction":
tree = this.$refs.construction;
if (tree && tree.store) {
const allNodes = tree.store._getAllNodes();
allNodes.forEach(node => {
if (this.constructionIdToIdMap[node.key] === id) {
tree.setChecked(node, false, false);
}
});
} else {
console.error('Tree or store is not initialized yet.');
}
break;
case "materialman":
tree = this.$refs.materialman;
if (tree && tree.store) {
const allNodes = tree.store._getAllNodes();
allNodes.forEach(node => {
if (this.materialmanIdToIdMap[node.key] === id) {
tree.setChecked(node, false, false);
}
});
} else {
console.error('Tree or store is not initialized yet.');
}
break;
case "other":
tree = this.$refs.other;
if (tree && tree.store) {
const allNodes = tree.store._getAllNodes();
allNodes.forEach(node => {
if (this.otherIdToIdMap[node.key] === id) {
tree.setChecked(node, false, false);
}
});
} else {
console.error('Tree or store is not initialized yet.');
}
break;
}
},
//
getAllCheckedKeys(type) {
//
const idMapKey = `${type}IdToIdMap`;
const ref = this.$refs[type];
const idMap = this[idMapKey];
if (!ref || !idMap) {
console.error(`Reference or ID map for type "${type}" not found.`);
return [];
}
const checkedKeys = ref.getCheckedKeys();
const checkedIds = checkedKeys.map(key => idMap[key]);
return checkedIds;
},
}
};
</script>