Merge branch 'dev_xd' of http://62.234.3.186:3000/jiangyq/YZProjectCloud into dev_xd
commit
94a0c70313
|
@ -22,8 +22,8 @@
|
||||||
|
|
||||||
<el-dialog v-model="dialogVisible" title="预览" width="800px" append-to-body modal-class="img-preview-dlg">
|
<el-dialog v-model="dialogVisible" title="预览" width="800px" append-to-body modal-class="img-preview-dlg">
|
||||||
<template v-if="previewAll">
|
<template v-if="previewAll">
|
||||||
<el-button type="primary" class="btn-remove" @click="doDelete" size="large">
|
<el-button type="primary" class="btn-remove" @click="doDelete" size="large">
|
||||||
删除
|
删除
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-icon class="el-icon-left el-preview" v-if="showIndex > 0" @click="doLeft">
|
<el-icon class="el-icon-left el-preview" v-if="showIndex > 0" @click="doLeft">
|
||||||
<ArrowLeft />
|
<ArrowLeft />
|
||||||
|
@ -31,8 +31,9 @@
|
||||||
<el-icon class="el-icon-right el-preview" v-if="showIndex < fileList.length - 1" @click="doRight">
|
<el-icon class="el-icon-right el-preview" v-if="showIndex < fileList.length - 1" @click="doRight">
|
||||||
<ArrowRight />
|
<ArrowRight />
|
||||||
</el-icon>
|
</el-icon>
|
||||||
<template v-if="fileList.length>0">
|
<template v-if="fileList.length > 0">
|
||||||
<el-image :src="fileList[showIndex].name" fit="cover" :preview-src-list="[fileList[showIndex].name]"></el-image>
|
<el-image :src="fileList[showIndex].name" fit="cover"
|
||||||
|
:preview-src-list="[fileList[showIndex].name]"></el-image>
|
||||||
</template>
|
</template>
|
||||||
</template>
|
</template>
|
||||||
<img v-else :src="dialogImageUrl" style="display: block; max-width: 100%; margin: 0 auto" />
|
<img v-else :src="dialogImageUrl" style="display: block; max-width: 100%; margin: 0 auto" />
|
||||||
|
@ -72,7 +73,7 @@ const props = defineProps({
|
||||||
});
|
});
|
||||||
|
|
||||||
const { proxy } = getCurrentInstance();
|
const { proxy } = getCurrentInstance();
|
||||||
const emit = defineEmits();
|
const emit = defineEmits(["update:modelValue","change"]);
|
||||||
const number = ref(0);
|
const number = ref(0);
|
||||||
const uploadList = ref([]);
|
const uploadList = ref([]);
|
||||||
const dialogImageUrl = ref("");
|
const dialogImageUrl = ref("");
|
||||||
|
@ -107,25 +108,24 @@ watch(
|
||||||
{ deep: true, immediate: true }
|
{ deep: true, immediate: true }
|
||||||
);
|
);
|
||||||
|
|
||||||
function doDelete() {
|
function doDelete() {
|
||||||
proxy.$confirm("确认删除此图片?", "提示", {
|
proxy.$confirm("确认删除此图片?", "提示", {
|
||||||
confirmButtonText: "确 认",
|
confirmButtonText: "确 认",
|
||||||
cancelButtonText: "取 消"
|
cancelButtonText: "取 消"
|
||||||
}).then(() => {
|
}).then(() => {
|
||||||
handleDelete(fileList.value[showIndex.value])
|
handleDelete(fileList.value[showIndex.value])
|
||||||
if(fileList.value.length<1){
|
if (fileList.value.length < 1) {
|
||||||
dialogVisible.value=false
|
dialogVisible.value = false
|
||||||
|
}
|
||||||
|
showIndex.value--;
|
||||||
|
if (showIndex < 0) {
|
||||||
|
showIndex = 0;
|
||||||
}
|
}
|
||||||
showIndex.value--;
|
|
||||||
if(showIndex<0){
|
|
||||||
showIndex=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function doLeft() {
|
function doLeft() {
|
||||||
if (showIndex.value > 1) {
|
if (showIndex.value > 0) {
|
||||||
showIndex.value--;
|
showIndex.value--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -193,6 +193,7 @@ function handleDelete(file) {
|
||||||
if (findex > -1 && uploadList.value.length === number.value) {
|
if (findex > -1 && uploadList.value.length === number.value) {
|
||||||
fileList.value.splice(findex, 1);
|
fileList.value.splice(findex, 1);
|
||||||
emit("update:modelValue", listToString(fileList.value));
|
emit("update:modelValue", listToString(fileList.value));
|
||||||
|
emit("change")
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -206,6 +207,7 @@ function uploadedSuccessfully() {
|
||||||
uploadList.value = [];
|
uploadList.value = [];
|
||||||
number.value = 0;
|
number.value = 0;
|
||||||
emit("update:modelValue", listToString(fileList.value));
|
emit("update:modelValue", listToString(fileList.value));
|
||||||
|
emit("change")
|
||||||
proxy.$modal.closeLoading();
|
proxy.$modal.closeLoading();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -255,6 +257,7 @@ function listToString(list, separator) {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
z-index: 99;
|
z-index: 99;
|
||||||
top: 40%;
|
top: 40%;
|
||||||
|
cursor: pointer;
|
||||||
|
|
||||||
&.el-icon-right {
|
&.el-icon-right {
|
||||||
right: 5%;
|
right: 5%;
|
||||||
|
@ -272,8 +275,8 @@ function listToString(list, separator) {
|
||||||
width: auto;
|
width: auto;
|
||||||
height: auto;
|
height: auto;
|
||||||
z-index: 99;
|
z-index: 99;
|
||||||
font-size: 40px;;
|
font-size: 40px;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
|
@ -55,8 +55,8 @@ const route = useRoute()
|
||||||
const { proxy } = getCurrentInstance();
|
const { proxy } = getCurrentInstance();
|
||||||
|
|
||||||
const loginForm = ref({
|
const loginForm = ref({
|
||||||
username: "admin",
|
username: "",
|
||||||
password: "admin123",
|
password: "",
|
||||||
rememberMe: false,
|
rememberMe: false,
|
||||||
code: "",
|
code: "",
|
||||||
uuid: ""
|
uuid: ""
|
||||||
|
|
|
@ -269,7 +269,7 @@ import { getDeptRole } from "@/api/system/role";
|
||||||
import {
|
import {
|
||||||
changeUserStatus, listUser, resetUserPwd, delUser, getUser, updateUser, addUser, selectByPhone, deptTreeSelect, getUserByName
|
changeUserStatus, listUser, resetUserPwd, delUser, getUser, updateUser, addUser, selectByPhone, deptTreeSelect, getUserByName
|
||||||
} from "@/api/system/user";
|
} from "@/api/system/user";
|
||||||
import { onMounted } from "vue";
|
|
||||||
|
|
||||||
const router = useRouter();
|
const router = useRouter();
|
||||||
const { proxy } = getCurrentInstance();
|
const { proxy } = getCurrentInstance();
|
||||||
|
@ -754,6 +754,8 @@ function getUserWorkType() {
|
||||||
});
|
});
|
||||||
data.prjWorkTypeObj = obj;
|
data.prjWorkTypeObj = obj;
|
||||||
}
|
}
|
||||||
|
|
||||||
getDeptTree();
|
getDeptTree();
|
||||||
getList();
|
getList();
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -1,16 +1,17 @@
|
||||||
<template>
|
<template>
|
||||||
<div class="app-container problemmodify-draft">
|
<div class="app-container problemmodify-draft">
|
||||||
<el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="68px">
|
<el-form :model="data.queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="68px">
|
||||||
<el-form-item label="检查类型" prop="problemType">
|
<el-form-item label="检查类型" prop="problemType">
|
||||||
<el-select v-model="form.problemType" placeholder="请选择检查类型" clearable>
|
<el-select v-model="data.queryParams.problemType" placeholder="请选择检查类型" clearable>
|
||||||
<el-option v-for="dict in ssp_proble_type" :key="dict.value" :label="dict.label" :value="dict.value">
|
<el-option v-for="dict in ssp_proble_type" :key="dict.value" :label="dict.label" :value="dict.value">
|
||||||
</el-option>
|
</el-option>
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="整改人" prop="lordSent">
|
|
||||||
<el-input v-model="queryParams.lordSent" style="width: 200px;" placeholder="请输入人员姓名/联系方式" clearable @keyup.enter="handleQuery" />
|
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
<el-form-item label="整改人" prop="lordSent">
|
||||||
|
<el-input v-model="data.queryParams.userName" style="width: 200px;" placeholder="请输入人员姓名/联系方式" clearable
|
||||||
|
@keyup.enter="handleQuery" />
|
||||||
|
</el-form-item>
|
||||||
|
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
|
<el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
|
||||||
<el-button icon="Refresh" @click="resetQuery">重置</el-button>
|
<el-button icon="Refresh" @click="resetQuery">重置</el-button>
|
||||||
|
@ -19,24 +20,30 @@
|
||||||
|
|
||||||
<el-row :gutter="10" class="mb8">
|
<el-row :gutter="10" class="mb8">
|
||||||
<el-col :span="1.5">
|
<el-col :span="1.5">
|
||||||
<el-button type="primary" plain size="mini" @click="handleAdd"
|
<el-button type="primary" plain size="mini" @click="handleAdd"
|
||||||
v-hasPermi="['trouble:smzSspProblemmodifyDraft:add']">
|
v-hasPermi="['trouble:smzSspProblemmodifyDraft:add']">
|
||||||
<el-icon><Plus /></el-icon>新增</el-button>
|
<el-icon>
|
||||||
|
<Plus />
|
||||||
|
</el-icon>新增</el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="1.5">
|
<el-col :span="1.5">
|
||||||
<el-button type="warning" plain size="mini" @click="dataSynchronization" :disabled="single"
|
<el-button type="warning" plain size="mini" @click="dataSynchronization" :disabled="single"
|
||||||
v-hasPermi="['trouble:smzSspProblemmodifyDraft:add']">
|
v-hasPermi="['trouble:smzSspProblemmodifyDraft:add']">
|
||||||
<el-icon><CopyDocument /></el-icon>
|
<el-icon>
|
||||||
|
<CopyDocument />
|
||||||
|
</el-icon>
|
||||||
数据同步</el-button>
|
数据同步</el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="1.5">
|
<el-col :span="1.5">
|
||||||
<el-tooltip content="批量提交选择的数据!" placement="bottom">
|
<el-tooltip content="批量提交选择的数据!" placement="bottom">
|
||||||
<el-button type="success" plain size="mini" @click="batchSubmitForm"
|
<el-button type="success" plain size="mini" @click="batchSubmitForm" :disabled="multiple"
|
||||||
:disabled="multiple" v-hasPermi="['trouble:smzSspProblemmodifyDraft:add']">
|
v-hasPermi="['trouble:smzSspProblemmodifyDraft:add']">
|
||||||
<el-icon><Check /></el-icon>批量提交</el-button>
|
<el-icon>
|
||||||
|
<Check />
|
||||||
|
</el-icon>批量提交</el-button>
|
||||||
</el-tooltip>
|
</el-tooltip>
|
||||||
</el-col>
|
</el-col>
|
||||||
|
|
||||||
</el-row>
|
</el-row>
|
||||||
<el-alert title="操作说明" class="tips" effect="dark" type="warning" :closable="false">
|
<el-alert title="操作说明" class="tips" effect="dark" type="warning" :closable="false">
|
||||||
<template #title>
|
<template #title>
|
||||||
|
@ -44,91 +51,92 @@
|
||||||
<div><strong>批量提交:</strong>将选中行的数据,数据验证通过后一次全部提交!</div>
|
<div><strong>批量提交:</strong>将选中行的数据,数据验证通过后一次全部提交!</div>
|
||||||
</template>
|
</template>
|
||||||
</el-alert>
|
</el-alert>
|
||||||
|
<el-form :model="data.form" :rules="data.rules" ref="formRef">
|
||||||
|
<el-table :data="data.showList" @selection-change="handleSelectionChange">
|
||||||
|
<el-table-column type="selection" width="30" align="center" />
|
||||||
|
<el-table-column type="index" width="50" align="center" label="序号">
|
||||||
|
</el-table-column>
|
||||||
|
|
||||||
<el-table :data="problemmodifyDraftList">
|
<el-table-column align="center" width="180" class-name="td-up-img" label="问题图片">
|
||||||
<el-table-column type="index" width="50" align="center" label="序号">
|
<template #default="scope">
|
||||||
</el-table-column>
|
<div :class="scope.row.errSmarkUrl?'is-err':''">
|
||||||
|
<image-upload v-model="scope.row.smarkUrl" previewAll :limit="5" :isShowTip="false" @change="scope.row.errSmarkUrl=scope.row.smarkUrl?false:true"/>
|
||||||
<el-table-column align="center" width="240" class-name="td-up-img" label="问题图片">
|
</div>
|
||||||
<template #default="scope">
|
|
||||||
<image-upload v-model="scope.row.smarkUrl" previewAll :limit="5" :isShowTip="false" />
|
|
||||||
</template>
|
|
||||||
</el-table-column>
|
|
||||||
<el-table-column align="center" width="240" class-name="td-proble-type" label="隐患类型">
|
|
||||||
<template #default="scope">
|
|
||||||
<el-select v-model="scope.row.problemType" placeholder="请选择检查类型" clearable>
|
|
||||||
<el-option v-for="dict in ssp_proble_type" :key="dict.value" :label="dict.label" :value="dict.value">
|
|
||||||
</el-option>
|
|
||||||
</el-select>
|
|
||||||
<el-select v-model="scope.row.dangerType" placeholder="请选择隐患类型" clearable style="margin-top:80px;">
|
|
||||||
<el-option v-for="dict in ssp_proble_sub_type" :key="dict.value" :label="dict.label" :value="dict.value">
|
|
||||||
</el-option>
|
|
||||||
</el-select>
|
|
||||||
</template>
|
|
||||||
</el-table-column>
|
|
||||||
<el-table-column label="施工部位" align="center" prop="workParts" width="180">
|
|
||||||
<template #default="scope">
|
|
||||||
<el-input v-model="scope.row.workParts" placeholder="请输入施工部位" type="textarea" :rows="3" />
|
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="整改要求" align="center" prop="changeInfo" width="180">
|
<el-table-column align="center" width="180" class-name="td-proble-type" label="隐患类型">
|
||||||
|
<template #default="scope">
|
||||||
|
<div :class="scope.row.errProblemType?'is-err':''">
|
||||||
|
<el-select v-model="scope.row.problemType" placeholder="请选择检查类型" clearable>
|
||||||
|
<el-option v-for="dict in ssp_proble_type" :key="dict.value" :label="dict.label" :value="dict.value">
|
||||||
|
</el-option>
|
||||||
|
</el-select>
|
||||||
|
</div>
|
||||||
|
<el-select v-model="scope.row.dangerType" placeholder="请选择隐患类型" clearable style="margin-top:80px;">
|
||||||
|
<el-option v-for="dict in ssp_proble_sub_type" :key="dict.value" :label="dict.label" :value="dict.value">
|
||||||
|
</el-option>
|
||||||
|
</el-select>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column label="施工部位" align="center" prop="workParts" min-width="240" class-name="td-textarea">
|
||||||
|
<template #default="scope">
|
||||||
|
|
||||||
|
<el-input v-model="scope.row.workParts" placeholder="请输入施工部位" type="textarea" :rows="3" />
|
||||||
|
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column label="整改要求" align="center" prop="changeInfo" min-width="240" class-name="td-textarea">
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<el-input v-model="scope.row.changeInfo" placeholder="请输入整改要求" type="textarea" :rows="3" />
|
<el-input v-model="scope.row.changeInfo" placeholder="请输入整改要求" type="textarea" :rows="3" />
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="租户ID" align="center" prop="comId" />
|
<el-table-column label="问题人员" align="center" width="300" class-name="td-select">
|
||||||
<el-table-column label="项目id" align="center" prop="projectId" />
|
<template #default="scope">
|
||||||
<el-table-column label="信息类型" align="center" prop="infoType" />
|
<el-form-item label="整改人">
|
||||||
<el-table-column label="留痕图片" align="center" prop="marksPicture" />
|
<el-select v-model="scope.row.lordSent" placeholder="请选择人员" clearable
|
||||||
<el-table-column label="留痕视频" align="center" prop="marksVideo" />
|
popper-class="select-popper-group-pd">
|
||||||
<el-table-column label="拍摄位置" align="center" prop="problemArea" />
|
<el-option-group v-for="group in data.modUserList" :key="group.label" :label="group.label">
|
||||||
<el-table-column label="施工部位" align="center" prop="workParts" />
|
<el-option v-for="item in group.options" :key="item.value" :label="item.label" :value="item.value" />
|
||||||
<el-table-column label="整改要求" align="center" prop="changeInfo" />
|
</el-option-group>
|
||||||
<el-table-column label="主送人姓名" align="center" prop="lordSent" />
|
</el-select>
|
||||||
<el-table-column label="主送人手机号" align="center" prop="lordSentUser" />
|
</el-form-item>
|
||||||
<el-table-column label="抄送人姓名" align="center" prop="copySend" />
|
<el-form-item label="抄送人">
|
||||||
<el-table-column label="抄送人手机号" align="center" prop="copySendUser" />
|
<el-select v-model="scope.row.copySend" placeholder="请选择人员" clearable multiple collapse-tags
|
||||||
<el-table-column label="流程状态" align="center" prop="checkState" />
|
popper-class="select-popper-group-pd" collapse-tags-tooltip>
|
||||||
<el-table-column label="整改定位" align="center" prop="nickedArea" />
|
<el-option-group v-for="group in data.ccUserList" :key="group.label" :label="group.label">
|
||||||
<el-table-column label="整改截至时间" align="center" prop="nickedTime" width="180">
|
<el-option v-for="item in group.options" :key="item.value" :label="item.label" :value="item.value" />
|
||||||
<template #default="scope">
|
</el-option-group>
|
||||||
<span>{{ parseTime(scope.row.nickedTime, "{y}-{m}-{d}") }}</span>
|
</el-select>
|
||||||
</template>
|
</el-form-item>
|
||||||
</el-table-column>
|
<el-form-item label="复检人">
|
||||||
<el-table-column label="工程类型" align="center" prop="projectType" />
|
<el-select v-model="scope.row.recheckSend" placeholder="请选择人员" clearable
|
||||||
<el-table-column label="工序名称" align="center" prop="processName" />
|
popper-class="select-popper-group-pd" collapse-tags-tooltip>
|
||||||
<el-table-column label="工程名称" align="center" prop="projectName" />
|
<el-option-group v-for="group in data.recheckUserList" :key="group.label" :label="group.label">
|
||||||
<el-table-column label="留痕说明" align="center" prop="nickedInfo" />
|
<el-option v-for="item in group.options" :key="item.value" :label="item.label" :value="item.value" />
|
||||||
<el-table-column label="审核人" align="center" prop="checkUser" />
|
</el-option-group>
|
||||||
<el-table-column label="审核人手机号" align="center" prop="checkUserPhone" />
|
</el-select>
|
||||||
|
</el-form-item>
|
||||||
<el-table-column label="删除状态" align="center" prop="isDel" />
|
</template>
|
||||||
<el-table-column label="创建人" align="center" prop="createUser" />
|
</el-table-column>
|
||||||
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
|
|
||||||
<template #default="scope">
|
<el-table-column label="整改截至时间" align="center" prop="nickedTime" width="150">
|
||||||
<span>{{ parseTime(scope.row.createTime, "{y}-{m}-{d}") }}</span>
|
<template #default="scope">
|
||||||
</template>
|
<el-form-item label="">
|
||||||
</el-table-column>
|
<el-date-picker v-model="scope.row.nickedTime" type="date" placeholder="选择日期" value-format="yyyy-MM-dd"
|
||||||
<el-table-column label="修改人" align="center" prop="updateUser" />
|
style="width: 200px" />
|
||||||
<el-table-column label="修改时间" align="center" prop="updateTime" width="180">
|
</el-form-item>
|
||||||
<template #default="scope">
|
</template>
|
||||||
<span>{{ parseTime(scope.row.updateTime, "{y}-{m}-{d}") }}</span>
|
</el-table-column>
|
||||||
</template>
|
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
||||||
</el-table-column>
|
<template #default="scope">
|
||||||
<el-table-column label="隐患类型" align="center" prop="dangerType" />
|
<el-button link type="primary" icon="Edit" @click="submitRow(scope.row)"
|
||||||
<el-table-column label="复检人" align="center" prop="recheckSend" />
|
v-hasPermi="['trouble:problemmodifyDraft:edit']">提交</el-button><br />
|
||||||
<el-table-column label="复检人手机号" align="center" prop="recheckSendUser" />
|
<el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)"
|
||||||
<el-table-column label="角色类型" align="center" prop="roleType" />
|
v-hasPermi="['trouble:problemmodifyDraft:remove']">删除</el-button>
|
||||||
<el-table-column label="问题类型" align="center" prop="problemType" />
|
</template>
|
||||||
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
</el-table-column>
|
||||||
<template #default="scope">
|
</el-table>
|
||||||
<el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)"
|
</el-form>
|
||||||
v-hasPermi="['trouble:problemmodifyDraft:edit']">修改</el-button>
|
|
||||||
<el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)"
|
|
||||||
v-hasPermi="['trouble:problemmodifyDraft:remove']">删除</el-button>
|
|
||||||
</template>
|
|
||||||
</el-table-column>
|
|
||||||
</el-table>
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
@ -140,10 +148,12 @@ import {
|
||||||
addProblemmodifyDraft,
|
addProblemmodifyDraft,
|
||||||
updateProblemmodifyDraft,
|
updateProblemmodifyDraft,
|
||||||
} from "@/api/trouble/problemmodifyDraft";
|
} from "@/api/trouble/problemmodifyDraft";
|
||||||
|
import useUserStore from '@/store/modules/user'
|
||||||
|
import { listProProjectInfoSubdeptsUsers } from "@/api/manage/proProjectInfoSubdeptsUsers";
|
||||||
|
const userStore = useUserStore()
|
||||||
const { proxy } = getCurrentInstance();
|
const { proxy } = getCurrentInstance();
|
||||||
const { ssp_proble_type,ssp_proble_sub_type } = proxy.useDict('ssp_proble_type','ssp_proble_sub_type');
|
const { ssp_proble_type, ssp_proble_sub_type } = proxy.useDict('ssp_proble_type', 'ssp_proble_sub_type');
|
||||||
const problemmodifyDraftList = ref([]);
|
|
||||||
const open = ref(false);
|
const open = ref(false);
|
||||||
const loading = ref(true);
|
const loading = ref(true);
|
||||||
const showSearch = ref(true);
|
const showSearch = ref(true);
|
||||||
|
@ -155,110 +165,35 @@ const title = ref("");
|
||||||
const uploadFileUrl = ref(import.meta.env.VITE_APP_BASE_API + "/file/upload"); // 上传文件服务器地址
|
const uploadFileUrl = ref(import.meta.env.VITE_APP_BASE_API + "/file/upload"); // 上传文件服务器地址
|
||||||
|
|
||||||
const data = reactive({
|
const data = reactive({
|
||||||
|
dataList: [],
|
||||||
|
showList: [],
|
||||||
form: {},
|
form: {},
|
||||||
queryParams: {
|
queryParams: {
|
||||||
pageNum: 1,
|
|
||||||
pageSize: 10,
|
|
||||||
comId: null,
|
|
||||||
projectId: null,
|
|
||||||
infoType: null,
|
|
||||||
marksPicture: null,
|
|
||||||
marksVideo: null,
|
|
||||||
problemArea: null,
|
|
||||||
workParts: null,
|
|
||||||
changeInfo: null,
|
|
||||||
lordSent: null,
|
|
||||||
lordSentUser: null,
|
|
||||||
copySend: null,
|
|
||||||
copySendUser: null,
|
|
||||||
checkState: null,
|
|
||||||
nickedArea: null,
|
|
||||||
nickedTime: null,
|
|
||||||
projectType: null,
|
|
||||||
processName: null,
|
|
||||||
projectName: null,
|
|
||||||
nickedInfo: null,
|
|
||||||
checkUser: null,
|
|
||||||
checkUserPhone: null,
|
|
||||||
smarkUrl: null,
|
|
||||||
isDel: null,
|
|
||||||
createUser: null,
|
|
||||||
createTime: null,
|
|
||||||
updateUser: null,
|
|
||||||
updateTime: null,
|
|
||||||
dangerType: null,
|
|
||||||
recheckSend: null,
|
|
||||||
recheckSendUser: null,
|
|
||||||
roleType: null,
|
|
||||||
problemType: null,
|
problemType: null,
|
||||||
|
userName: null
|
||||||
},
|
},
|
||||||
rules: {
|
rules: {
|
||||||
comId: [{ required: true, message: "租户ID不能为空", trigger: "blur" }],
|
|
||||||
},
|
},
|
||||||
|
selData: [],
|
||||||
|
modUserList: [],//整改人
|
||||||
|
ccUserList: [],//抄送人
|
||||||
|
recheckUserList: [],//复检人
|
||||||
});
|
});
|
||||||
|
|
||||||
const { queryParams, form, rules } = toRefs(data);
|
const { queryParams, form, rules } = toRefs(data);
|
||||||
|
|
||||||
/** 查询安全问题草稿列表 */
|
|
||||||
function getList() {
|
|
||||||
loading.value = true;
|
|
||||||
listProblemmodifyDraft(queryParams.value).then((response) => {
|
|
||||||
problemmodifyDraftList.value = response.rows;
|
|
||||||
total.value = response.total;
|
|
||||||
loading.value = false;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// 取消按钮
|
|
||||||
function cancel() {
|
|
||||||
open.value = false;
|
|
||||||
reset();
|
|
||||||
}
|
|
||||||
|
|
||||||
// 表单重置
|
|
||||||
function reset() {
|
|
||||||
form.value = {
|
|
||||||
id: null,
|
|
||||||
comId: null,
|
|
||||||
projectId: null,
|
|
||||||
infoType: null,
|
|
||||||
marksPicture: null,
|
|
||||||
marksVideo: null,
|
|
||||||
problemArea: null,
|
|
||||||
workParts: null,
|
|
||||||
changeInfo: null,
|
|
||||||
lordSent: null,
|
|
||||||
lordSentUser: null,
|
|
||||||
copySend: null,
|
|
||||||
copySendUser: null,
|
|
||||||
checkState: null,
|
|
||||||
nickedArea: null,
|
|
||||||
nickedTime: null,
|
|
||||||
projectType: null,
|
|
||||||
processName: null,
|
|
||||||
projectName: null,
|
|
||||||
nickedInfo: null,
|
|
||||||
checkUser: null,
|
|
||||||
checkUserPhone: null,
|
|
||||||
smarkUrl: null,
|
|
||||||
isDel: null,
|
|
||||||
createUser: null,
|
|
||||||
createTime: null,
|
|
||||||
updateUser: null,
|
|
||||||
updateTime: null,
|
|
||||||
dangerType: null,
|
|
||||||
recheckSend: null,
|
|
||||||
recheckSendUser: null,
|
|
||||||
roleType: null,
|
|
||||||
problemType: null,
|
|
||||||
};
|
|
||||||
proxy.resetForm("problemmodifyDraftRef");
|
|
||||||
}
|
|
||||||
|
|
||||||
/** 搜索按钮操作 */
|
/** 搜索按钮操作 */
|
||||||
function handleQuery() {
|
function handleQuery() {
|
||||||
queryParams.value.pageNum = 1;
|
debugger
|
||||||
getList();
|
data.showList = data.dataList.filter(d => {
|
||||||
|
let ck1 = true;
|
||||||
|
if (data.queryParams.problemType) {
|
||||||
|
ck1 = d.problemType == data.queryParams.problemType;
|
||||||
|
}
|
||||||
|
return ck1;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 重置按钮操作 */
|
/** 重置按钮操作 */
|
||||||
|
@ -269,6 +204,7 @@ function resetQuery() {
|
||||||
|
|
||||||
// 多选框选中数据
|
// 多选框选中数据
|
||||||
function handleSelectionChange(selection) {
|
function handleSelectionChange(selection) {
|
||||||
|
data.selData = selection;
|
||||||
ids.value = selection.map((item) => item.id);
|
ids.value = selection.map((item) => item.id);
|
||||||
single.value = selection.length != 1;
|
single.value = selection.length != 1;
|
||||||
multiple.value = !selection.length;
|
multiple.value = !selection.length;
|
||||||
|
@ -276,21 +212,65 @@ function handleSelectionChange(selection) {
|
||||||
|
|
||||||
/** 新增按钮操作 */
|
/** 新增按钮操作 */
|
||||||
function handleAdd() {
|
function handleAdd() {
|
||||||
reset();
|
let row = {
|
||||||
open.value = true;
|
key: +new Date(),
|
||||||
title.value = "添加安全问题草稿";
|
id: null,
|
||||||
|
projectId: userStore.currentPrjId,
|
||||||
|
comId: userStore.currentComId,
|
||||||
|
problemType: null,
|
||||||
|
dangerType: null,
|
||||||
|
smarkUrl: null,
|
||||||
|
workParts: null,
|
||||||
|
changeInfo: null,
|
||||||
|
lordSent: null,
|
||||||
|
copySend: null,
|
||||||
|
recheckSend: null,
|
||||||
|
nickedTime: null,
|
||||||
|
isDel: 0,
|
||||||
|
infoType: 1
|
||||||
|
}
|
||||||
|
data.dataList.push(row);
|
||||||
|
data.showList.push(row);
|
||||||
}
|
}
|
||||||
|
/** 数据同步 */
|
||||||
/** 修改按钮操作 */
|
function dataSynchronization() {
|
||||||
function handleUpdate(row) {
|
let row = data.selData[0];
|
||||||
reset();
|
data.showList.forEach(it => {
|
||||||
const _id = row.id || ids.value;
|
if (it != row) {
|
||||||
getProblemmodifyDraft(_id).then((response) => {
|
it.problemType = row.problemType;
|
||||||
form.value = response.data;
|
it.dangerType = row.dangerType;
|
||||||
open.value = true;
|
it.smarkUrl = row.smarkUrl;
|
||||||
title.value = "修改安全问题草稿";
|
it.workParts = row.workParts;
|
||||||
|
it.changeInfo = row.changeInfo;
|
||||||
|
it.lordSent = row.lordSent;
|
||||||
|
it.copySend = row.copySend;
|
||||||
|
it.recheckSend = row.recheckSend;
|
||||||
|
it.nickedTime = row.nickedTime;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
function submitRow(row) {
|
||||||
|
debugger
|
||||||
|
if (checkRow(row)) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function checkRow(row) {
|
||||||
|
row.errSmarkUrl=false;
|
||||||
|
row.errProblemType=false;
|
||||||
|
if (!row.smarkUrl) {
|
||||||
|
row.errSmarkUrl=true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (!row.problemType) {
|
||||||
|
row.errProblemType=true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (!row.dangerType ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
/** 提交按钮 */
|
/** 提交按钮 */
|
||||||
function submitForm() {
|
function submitForm() {
|
||||||
|
@ -315,14 +295,15 @@ function submitForm() {
|
||||||
|
|
||||||
/** 删除按钮操作 */
|
/** 删除按钮操作 */
|
||||||
function handleDelete(row) {
|
function handleDelete(row) {
|
||||||
const _ids = row.id || ids.value;
|
if (data.dataList.length == 1) {
|
||||||
|
proxy.$modal.msgError("至少保留一条数据");
|
||||||
|
return;
|
||||||
|
}
|
||||||
proxy.$modal
|
proxy.$modal
|
||||||
.confirm('是否确认删除安全问题草稿编号为"' + _ids + '"的数据项?')
|
.confirm('是否确认删除数据项?')
|
||||||
.then(function () {
|
.then(function () {
|
||||||
return delProblemmodifyDraft(_ids);
|
data.showList.splice(row, 1);
|
||||||
})
|
data.dataList.splice(row, 1);
|
||||||
.then(() => {
|
|
||||||
getList();
|
|
||||||
proxy.$modal.msgSuccess("删除成功");
|
proxy.$modal.msgSuccess("删除成功");
|
||||||
})
|
})
|
||||||
.catch(() => { });
|
.catch(() => { });
|
||||||
|
@ -338,20 +319,118 @@ function handleExport() {
|
||||||
`problemmodifyDraft_${new Date().getTime()}.xlsx`
|
`problemmodifyDraft_${new Date().getTime()}.xlsx`
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
function makeSelectData(users, type) {
|
||||||
//getList();
|
let objs = {};
|
||||||
problemmodifyDraftList.value.push({});
|
users.forEach(it => {
|
||||||
|
let deptName = it.subDeptName;
|
||||||
|
if (!objs[deptName]) {
|
||||||
|
objs[deptName] = [];
|
||||||
|
}
|
||||||
|
objs[deptName].push(it);
|
||||||
|
})
|
||||||
|
let arr = [];
|
||||||
|
for (let k in objs) {
|
||||||
|
arr.push({
|
||||||
|
label: k,
|
||||||
|
options: objs[k].map(it => {
|
||||||
|
let pos = type ? `[${it.userPost == 2 ? '项目经理' : it.userPost == 3 ? '班组长' : ''}]` : ''
|
||||||
|
return {
|
||||||
|
value: it.userId,
|
||||||
|
label: it.userName + pos,
|
||||||
|
data: it
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
console.log("--->", arr)
|
||||||
|
return arr;
|
||||||
|
}
|
||||||
|
function getUserTree() {
|
||||||
|
let row = {
|
||||||
|
key: +new Date(),
|
||||||
|
id: null,
|
||||||
|
projectId: userStore.currentPrjId,
|
||||||
|
comId: userStore.currentComId,
|
||||||
|
problemType: null,
|
||||||
|
dangerType: null,
|
||||||
|
smarkUrl: null,
|
||||||
|
workParts: null,
|
||||||
|
changeInfo: null,
|
||||||
|
lordSent: null,
|
||||||
|
copySend: null,
|
||||||
|
recheckSend: null,
|
||||||
|
nickedTime: null,
|
||||||
|
isDel: 0,
|
||||||
|
infoType: 1
|
||||||
|
};
|
||||||
|
data.dataList.push(row)
|
||||||
|
data.showList.push(row);
|
||||||
|
listProProjectInfoSubdeptsUsers({ projectId: userStore.currentPrjId, pageNum: 1, pageSize: 1000 }).then(d => {
|
||||||
|
let users = d.rows || [];
|
||||||
|
data.modUserList = makeSelectData(users.filter(it => it.subDeptType == 4 || it.subDeptType == 5).filter(it => it.userPost == 2 || it.userPost == 3), true);
|
||||||
|
data.ccUserList = makeSelectData(users.filter(it => it.userPost != 4 && it.userPost != 5));
|
||||||
|
data.recheckUserList = makeSelectData(users.filter(it => it.subDeptType == 1));
|
||||||
|
})
|
||||||
|
}
|
||||||
|
getUserTree();
|
||||||
</script>
|
</script>
|
||||||
<style lang="scss">
|
<style lang="scss">
|
||||||
.problemmodify-draft{
|
.problemmodify-draft {
|
||||||
.td-up-img{
|
.td-up-img {
|
||||||
.component-upload-image{
|
.component-upload-image {
|
||||||
height: 150px;
|
height: 150px;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
.el-upload-list__item{
|
|
||||||
|
.el-upload-list__item {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.td-textarea {
|
||||||
|
.cell {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
|
||||||
|
.el-textarea {
|
||||||
|
width: 100%;
|
||||||
|
height: 150px;
|
||||||
|
|
||||||
|
.el-textarea__inner {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.td-select {
|
||||||
|
.el-select {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.is-err{
|
||||||
|
position: relative;
|
||||||
|
padding-bottom:12px;
|
||||||
|
.el-upload--picture-card{
|
||||||
|
border-color: red;
|
||||||
|
}
|
||||||
|
&::after{
|
||||||
|
content: "不为空";
|
||||||
|
color: red;
|
||||||
|
left: 0px;
|
||||||
|
font-size:12px;
|
||||||
|
position:absolute;
|
||||||
|
bottom: -6px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.select-popper-group-pd {
|
||||||
|
.el-select-group {
|
||||||
|
.el-select-dropdown__item {
|
||||||
|
padding-left: 30px;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
Loading…
Reference in New Issue